2015-08-21 14:01:10 +12:00
|
|
|
<?php
|
2016-04-20 14:49:09 +12:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* ReadonlyField with added toggle-capabilities - will preview the first sentence of the contained
|
|
|
|
* text-value, and show the full content by a javascript-switch.
|
|
|
|
*
|
|
|
|
* Caution: Strips HTML-encoding for the preview.
|
2015-08-21 14:01:10 +12:00
|
|
|
*
|
|
|
|
* @deprecated 3.1 Use custom javascript with a ReadonlyField.
|
2016-01-06 12:34:58 +13:00
|
|
|
*
|
2015-08-21 14:01:10 +12:00
|
|
|
* @package forms
|
|
|
|
* @subpackage fields-dataless
|
|
|
|
*/
|
|
|
|
class ToggleField extends ReadonlyField {
|
|
|
|
|
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* Text shown as a link to see the full content of the field.
|
|
|
|
*
|
|
|
|
* @var string
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
|
|
|
public $labelMore;
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* Text shown as a link to see the partial view of the field content.
|
|
|
|
*
|
|
|
|
* @var string
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
|
|
|
public $labelLess;
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* Method to use when truncating this field's value (FirstSentence|FirstParagraph).
|
|
|
|
*
|
2015-08-21 14:01:10 +12:00
|
|
|
* @see Text
|
2016-04-20 14:49:09 +12:00
|
|
|
*
|
|
|
|
* @var string
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
|
|
|
public $truncateMethod = 'FirstSentence';
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* Number of characters to truncate this field's value to.
|
|
|
|
*
|
|
|
|
* @var null|int
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
|
|
|
public $truncateChars;
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2016-04-20 15:00:38 +12:00
|
|
|
/**
|
|
|
|
* @var null|int
|
|
|
|
*/
|
|
|
|
public $charNum;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
public $startClosed;
|
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
2016-04-20 14:49:09 +12:00
|
|
|
* @inheritdoc
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param string $title
|
|
|
|
* @param string $value
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
2016-04-20 15:00:38 +12:00
|
|
|
public function __construct($name, $title = '', $value = '') {
|
2015-08-21 14:01:10 +12:00
|
|
|
Deprecation::notice('4.0', 'Use custom javascript with a ReadOnlyField');
|
2016-04-20 15:00:38 +12:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
$this->labelMore = _t('ToggleField.MORE', 'more');
|
|
|
|
$this->labelLess = _t('ToggleField.LESS', 'less');
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
$this->startClosed(true);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
parent::__construct($name, $title, $value);
|
|
|
|
}
|
|
|
|
|
2016-04-20 14:49:09 +12:00
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*
|
|
|
|
* @param array $properties
|
|
|
|
*
|
|
|
|
* @return string|HTMLText
|
|
|
|
*/
|
2015-08-21 14:01:10 +12:00
|
|
|
public function Field($properties = array()) {
|
|
|
|
Requirements::javascript(FRAMEWORK_DIR . '/thirdparty/jquery/jquery.js');
|
2016-04-20 15:00:38 +12:00
|
|
|
Requirements::javascript(FRAMEWORK_DIR . '/javascript/ToggleField.js');
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2016-04-20 15:00:38 +12:00
|
|
|
if($this->startClosed) {
|
|
|
|
$this->addExtraClass('startClosed');
|
|
|
|
}
|
|
|
|
|
|
|
|
$valueForInput = '';
|
|
|
|
|
|
|
|
if($this->value) {
|
|
|
|
$valueForInput = Convert::raw2att($this->value);
|
|
|
|
}
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2016-04-20 15:00:38 +12:00
|
|
|
$rawInput = Convert::html2raw($valueForInput);
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2016-04-20 15:00:38 +12:00
|
|
|
if($this->charNum) {
|
|
|
|
$reducedValue = substr($rawInput, 0, $this->charNum);
|
|
|
|
} else {
|
|
|
|
$reducedValue = DBField::create_field('Text', $rawInput)->{$this->truncateMethod}();
|
|
|
|
}
|
2015-08-21 14:01:10 +12:00
|
|
|
|
2016-04-20 15:00:38 +12:00
|
|
|
// only create toggle field if the truncated content is shorter
|
|
|
|
if(strlen($reducedValue) < strlen($rawInput)) {
|
2015-08-21 14:01:10 +12:00
|
|
|
$content = <<<HTML
|
|
|
|
<div class="readonly typography contentLess" style="display: none">
|
2016-04-20 15:00:38 +12:00
|
|
|
$reducedValue
|
2015-08-21 14:01:10 +12:00
|
|
|
<a href="#" class="triggerMore">$this->labelMore</a>
|
|
|
|
</div>
|
|
|
|
<div class="readonly typography contentMore">
|
|
|
|
$this->value
|
|
|
|
<a href="#" class="triggerLess">$this->labelLess</a>
|
2016-01-06 12:34:58 +13:00
|
|
|
</div>
|
2015-08-21 14:01:10 +12:00
|
|
|
<br />
|
2016-04-20 15:00:38 +12:00
|
|
|
<input type="hidden" name="$this->name" value="$valueForInput" />
|
2015-08-21 14:01:10 +12:00
|
|
|
HTML;
|
|
|
|
} else {
|
|
|
|
$this->dontEscape = true;
|
|
|
|
$content = parent::Field();
|
|
|
|
}
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
return $content;
|
|
|
|
}
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2015-08-21 14:01:10 +12:00
|
|
|
/**
|
|
|
|
* Determines if the field should render open or closed by default.
|
2016-01-06 12:34:58 +13:00
|
|
|
*
|
2016-04-20 14:49:09 +12:00
|
|
|
* @param bool $bool
|
2015-08-21 14:01:10 +12:00
|
|
|
*/
|
|
|
|
public function startClosed($bool) {
|
2016-04-20 15:00:38 +12:00
|
|
|
if($bool) {
|
|
|
|
$this->addExtraClass('startClosed');
|
|
|
|
} else {
|
|
|
|
$this->removeExtraClass('startClosed');
|
|
|
|
}
|
2015-08-21 14:01:10 +12:00
|
|
|
}
|
2016-01-06 12:34:58 +13:00
|
|
|
|
2016-04-20 14:49:09 +12:00
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2015-08-21 14:01:10 +12:00
|
|
|
public function Type() {
|
|
|
|
return "toggleField";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|