1ed3de3d6SAndreas Gohr<?php 2d6d97f60SAnna Dabrowska 3ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\Column; 4ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\Schema; 5ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\StructException; 6ba766201SAndreas Gohruse dokuwiki\plugin\struct\meta\Value; 793ca6f4fSAndreas Gohruse dokuwiki\plugin\struct\meta\ValueValidator; 8e46eaffdSSzymon Olewniczakuse dokuwiki\plugin\struct\types\Lookup; 9*d1482d40SAnna Dabrowskause dokuwiki\plugin\struct\types\Page; 10ed3de3d6SAndreas Gohr 11ed3de3d6SAndreas Gohr/** 123ad9c1eaSAndreas Gohr * Allows adding a single struct field as a bureaucracy field 133ad9c1eaSAndreas Gohr * 143ad9c1eaSAndreas Gohr * This class is used when a field of the type struct_field is encountered in the 153ad9c1eaSAndreas Gohr * bureaucracy syntax. 16ed3de3d6SAndreas Gohr */ 17d6d97f60SAnna Dabrowskaclass helper_plugin_struct_field extends helper_plugin_bureaucracy_field 18d6d97f60SAnna Dabrowska{ 19ed3de3d6SAndreas Gohr 203ad9c1eaSAndreas Gohr /** @var Column */ 213ad9c1eaSAndreas Gohr public $column; 22ed3de3d6SAndreas Gohr 233ad9c1eaSAndreas Gohr /** 243ad9c1eaSAndreas Gohr * Initialize the appropriate column 253ad9c1eaSAndreas Gohr * 263ad9c1eaSAndreas Gohr * @param array $args 273ad9c1eaSAndreas Gohr */ 28d6d97f60SAnna Dabrowska public function initialize($args) 29d6d97f60SAnna Dabrowska { 3089be912bSSzymon Olewniczak $this->init($args); 31ed3de3d6SAndreas Gohr 323ad9c1eaSAndreas Gohr // find the column 333ad9c1eaSAndreas Gohr try { 343ad9c1eaSAndreas Gohr $this->column = $this->findColumn($this->opt['label']); 353ad9c1eaSAndreas Gohr } catch (StructException $e) { 363ad9c1eaSAndreas Gohr msg(hsc($e->getMessage()), -1); 373ad9c1eaSAndreas Gohr } 3889be912bSSzymon Olewniczak 3989be912bSSzymon Olewniczak $this->standardArgs($args); 403ad9c1eaSAndreas Gohr } 413ad9c1eaSAndreas Gohr 423ad9c1eaSAndreas Gohr /** 436c71c031SAndreas Gohr * Sets the value and validates it 443ad9c1eaSAndreas Gohr * 456c71c031SAndreas Gohr * @param mixed $value 466c71c031SAndreas Gohr * @return bool value was set successfully validated 473ad9c1eaSAndreas Gohr */ 48d6d97f60SAnna Dabrowska protected function setVal($value) 49d6d97f60SAnna Dabrowska { 506c71c031SAndreas Gohr if (!$this->column) { 516c71c031SAndreas Gohr $value = ''; 52131fd507SSzymon Olewniczak //don't validate placeholders here 53131fd507SSzymon Olewniczak } elseif ($this->replace($value) == $value) { 5493ca6f4fSAndreas Gohr $validator = new ValueValidator(); 556c71c031SAndreas Gohr $this->error = !$validator->validateValue($this->column, $value); 566c71c031SAndreas Gohr if ($this->error) { 576c71c031SAndreas Gohr foreach ($validator->getErrors() as $error) { 586c71c031SAndreas Gohr msg(hsc($error), -1); 596c71c031SAndreas Gohr } 606c71c031SAndreas Gohr } 616c71c031SAndreas Gohr } 626c71c031SAndreas Gohr 636c71c031SAndreas Gohr if ($value === array() || $value === '') { 646c71c031SAndreas Gohr if (!isset($this->opt['optional'])) { 656c71c031SAndreas Gohr $this->error = true; 662e0e9347SSzymon Olewniczak if ($this->column) { 672e0e9347SSzymon Olewniczak $label = $this->column->getTranslatedLabel(); 682e0e9347SSzymon Olewniczak } else { 692e0e9347SSzymon Olewniczak $label = $this->opt['label']; 702e0e9347SSzymon Olewniczak } 712e0e9347SSzymon Olewniczak msg(sprintf($this->getLang('e_required'), hsc($label)), -1); 726c71c031SAndreas Gohr } 736c71c031SAndreas Gohr } 746c71c031SAndreas Gohr 756c71c031SAndreas Gohr $this->opt['value'] = $value; 766c71c031SAndreas Gohr return !$this->error; 773ad9c1eaSAndreas Gohr } 783ad9c1eaSAndreas Gohr 793ad9c1eaSAndreas Gohr /** 803ad9c1eaSAndreas Gohr * Creates the HTML for the field 813ad9c1eaSAndreas Gohr * 823ad9c1eaSAndreas Gohr * @param array $params 833ad9c1eaSAndreas Gohr * @param Doku_Form $form 843ad9c1eaSAndreas Gohr * @param int $formid 853ad9c1eaSAndreas Gohr */ 86d6d97f60SAnna Dabrowska public function renderfield($params, Doku_Form $form, $formid) 87d6d97f60SAnna Dabrowska { 883ad9c1eaSAndreas Gohr if (!$this->column) return; 893ad9c1eaSAndreas Gohr 903ad9c1eaSAndreas Gohr // this is what parent does 913ad9c1eaSAndreas Gohr $this->_handlePreload(); 923ad9c1eaSAndreas Gohr if (!$form->_infieldset) { 933ad9c1eaSAndreas Gohr $form->startFieldset(''); 943ad9c1eaSAndreas Gohr } 953ad9c1eaSAndreas Gohr if ($this->error) { 963ad9c1eaSAndreas Gohr $params['class'] = 'bureaucracy_error'; 973ad9c1eaSAndreas Gohr } 983ad9c1eaSAndreas Gohr 993ad9c1eaSAndreas Gohr // output the field 100*d1482d40SAnna Dabrowska $value = $this->createValue(); 10195838d50SAndreas Gohr $field = $this->makeField($value, $params['name']); 1023ad9c1eaSAndreas Gohr $form->addElement($field); 1033ad9c1eaSAndreas Gohr } 1043ad9c1eaSAndreas Gohr 10595838d50SAndreas Gohr /** 106*d1482d40SAnna Dabrowska * Returns a Value object for the current column. 107*d1482d40SAnna Dabrowska * Special handling for Page and Lookup literal form values. 108*d1482d40SAnna Dabrowska * 109*d1482d40SAnna Dabrowska * @return Value 110*d1482d40SAnna Dabrowska */ 111*d1482d40SAnna Dabrowska protected function createValue() 112*d1482d40SAnna Dabrowska { 113*d1482d40SAnna Dabrowska $preparedValue = $this->opt['value']; 114*d1482d40SAnna Dabrowska 115*d1482d40SAnna Dabrowska // page fields might need to be JSON encoded depending on usetitles config 116*d1482d40SAnna Dabrowska if ( 117*d1482d40SAnna Dabrowska $this->column->getType() instanceof Page 118*d1482d40SAnna Dabrowska && $this->column->getType()->getConfig()['usetitles'] 119*d1482d40SAnna Dabrowska ) { 120*d1482d40SAnna Dabrowska $preparedValue = json_encode([$this->opt['value'], null]); 121*d1482d40SAnna Dabrowska } 122*d1482d40SAnna Dabrowska 123*d1482d40SAnna Dabrowska $value = new Value($this->column, $preparedValue); 124*d1482d40SAnna Dabrowska 125*d1482d40SAnna Dabrowska // no way to pass $israw parameter to constructor, so re-set the Lookup value 126*d1482d40SAnna Dabrowska if ($this->column->getType() instanceof Lookup) { 127*d1482d40SAnna Dabrowska $value->setValue($preparedValue, true); 128*d1482d40SAnna Dabrowska } 129*d1482d40SAnna Dabrowska 130*d1482d40SAnna Dabrowska return $value; 131*d1482d40SAnna Dabrowska } 132*d1482d40SAnna Dabrowska 133*d1482d40SAnna Dabrowska /** 13495838d50SAndreas Gohr * Create the input field 13595838d50SAndreas Gohr * 13695838d50SAndreas Gohr * @param Value $field 13795838d50SAndreas Gohr * @param String $name field's name 13895838d50SAndreas Gohr * @return string 13995838d50SAndreas Gohr */ 140d6d97f60SAnna Dabrowska protected function makeField(Value $field, $name) 141d6d97f60SAnna Dabrowska { 14295838d50SAndreas Gohr $trans = hsc($field->getColumn()->getTranslatedLabel()); 14395838d50SAndreas Gohr $hint = hsc($field->getColumn()->getTranslatedHint()); 14495838d50SAndreas Gohr $class = $hint ? 'hashint' : ''; 14595838d50SAndreas Gohr $lclass = $this->error ? 'bureaucracy_error' : ''; 14695838d50SAndreas Gohr $colname = $field->getColumn()->getFullQualifiedLabel(); 1479bdb73ceSAndreas Gohr $required = $this->opt['optional'] ? '' : ' <sup>*</sup>'; 14895838d50SAndreas Gohr 1495275870bSAnna Dabrowska $id = uniqid('struct__', true); 150ee983135SMichael Große $input = $field->getValueEditor($name, $id); 15195838d50SAndreas Gohr 152ee983135SMichael Große $html = '<div class="field">'; 153ee983135SMichael Große $html .= "<label class=\"$lclass\" data-column=\"$colname\" for=\"$id\">"; 15495838d50SAndreas Gohr $html .= "<span class=\"label $class\" title=\"$hint\">$trans$required</span>"; 15595838d50SAndreas Gohr $html .= '</label>'; 156ee983135SMichael Große $html .= "<span class=\"input\">$input</span>"; 157ee983135SMichael Große $html .= '</div>'; 15895838d50SAndreas Gohr 15995838d50SAndreas Gohr return $html; 16095838d50SAndreas Gohr } 16195838d50SAndreas Gohr 1623ad9c1eaSAndreas Gohr /** 1633ad9c1eaSAndreas Gohr * Tries to find the correct column and schema 1643ad9c1eaSAndreas Gohr * 1653ad9c1eaSAndreas Gohr * @throws StructException 1663ad9c1eaSAndreas Gohr * @param string $colname 167ba766201SAndreas Gohr * @return \dokuwiki\plugin\struct\meta\Column 1683ad9c1eaSAndreas Gohr */ 169d6d97f60SAnna Dabrowska protected function findColumn($colname) 170d6d97f60SAnna Dabrowska { 1713ad9c1eaSAndreas Gohr list($table, $label) = explode('.', $colname, 2); 1723ad9c1eaSAndreas Gohr if (!$table || !$label) { 1733ad9c1eaSAndreas Gohr throw new StructException('Field \'%s\' not given in schema.field form', $colname); 1743ad9c1eaSAndreas Gohr } 1753ad9c1eaSAndreas Gohr $schema = new Schema($table); 1763ad9c1eaSAndreas Gohr return $schema->findColumn($label); 1773ad9c1eaSAndreas Gohr } 1783ad9c1eaSAndreas Gohr 1793ad9c1eaSAndreas Gohr /** 1803ad9c1eaSAndreas Gohr * This ensures all language strings are still working 1813ad9c1eaSAndreas Gohr * 1823ad9c1eaSAndreas Gohr * @return string always 'bureaucracy' 1833ad9c1eaSAndreas Gohr */ 184d6d97f60SAnna Dabrowska public function getPluginName() 185d6d97f60SAnna Dabrowska { 1863ad9c1eaSAndreas Gohr return 'bureaucracy'; 1873ad9c1eaSAndreas Gohr } 188ed3de3d6SAndreas Gohr} 189