1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77: 78: 79: 80: 81: 82: 83: 84: 85: 86:
<?php
namespace Nethgui\Widget\Xhtml;
class Slider extends \Nethgui\Widget\XhtmlWidget
{
protected function getJsWidgetTypes()
{
return array_merge(array('Nethgui:inputcontrol'), parent::getJsWidgetTypes());
}
protected function renderContent()
{
$flags = $this->applyDefaultLabelAlignment($this->getAttribute('flags'), \Nethgui\Renderer\WidgetFactoryInterface::LABEL_RIGHT);
if ($flags & \Nethgui\Renderer\WidgetFactoryInterface::SLIDER_ENUMERATIVE) {
return $this->renderEnumerative();
}
return $this->renderRange();
}
private function renderEnumerative()
{
$flags = $this->getAttribute('flags');
$name = $this->getAttribute('name');
$value = $this->getAttribute('value', $this->view[$name]);
$label = $this->getAttribute('label', '${0}');
$cssClass = trim('Slider Enumerative ' . $this->getAttribute('class', ''));
$choices = $this->getChoices($name, $dataSourceName);
$tagContent = $this->optGroups($value, $choices);
return $this->labeledControlTag($label, 'select', $name, $flags, $cssClass, array(), $tagContent);
}
private function renderRange()
{
$flags = $this->getAttribute('flags');
$name = $this->getAttribute('name');
$value = $this->getAttribute('value', $this->view[$name]);
$label = $this->getAttribute('label', $this->getTranslateClosure($name . '_label'));
$cssClass = trim('Slider Range ' . $this->getAttribute('class', ''));
$range = array(
'min' => floatval($this->getAttribute('min', 0)),
'max' => floatval($this->getAttribute('max', 100)),
'step' => floatval($this->getAttribute('step', 1)),
);
$attributes = array(
'value' => strval($value),
'type' => 'text',
'data-settings' => json_encode($range),
);
return $this->labeledControlTag($label, 'input', $name, $flags, $cssClass, $attributes);
}
}