* select: * @ select('idCountry','value',[,$extra]) * @ item('0','--select a country'[,$extra]) * @ items($countries,'id','name',$currentCountry[,$extra]) * @ endselect() * input: * @ input('iduser',$currentUser,'text'[,$extra]) * button: * @ commandbutton('idbutton','value','text'[,$extra]) * * * Note. The names of the tags are based in Java Server Faces (JSF) * * @package BladeOneHtml * @version 1.9.2 2020-05-28 (1) * @link https://github.com/EFTEC/BladeOne * @author Jorge Patricio Castro Castillo * @deprecated use https://github.com/eftec/BladeOneHtml */ trait BladeOneHtml { protected $htmlItem = []; // indicates the type of the current tag. such as select/selectgroup/etc. protected $htmlCurrentId = []; //indicates the id of the current tag. // protected function compileSelect($expression) { $this->htmlItem[] = 'select'; return $this->phpTag . "echo \$this->select{$expression}; ?>"; } protected function compileListBoxes($expression) { return $this->phpTag . "echo \$this->listboxes{$expression}; ?>"; } protected function compileLink($expression) { return $this->phpTag . "echo \$this->link{$expression}; ?>"; } protected function compileSelectGroup($expression) { $this->htmlItem[] = 'selectgroup'; $this->compilePush(''); return $this->phpTag . "echo \$this->select{$expression}; ?>"; } protected function compileRadio($expression) { $this->htmlItem[] = 'radio'; return $this->phpTag . "echo \$this->radio{$expression}; ?>"; } protected function compileCheckbox($expression) { $this->htmlItem[] = 'checkbox'; return $this->phpTag . "echo \$this->checkbox{$expression}; ?>"; } protected function compileEndSelect() { $r = @\array_pop($this->htmlItem); if (\is_null($r)) { $this->showError("@endselect", "Missing @select or so many @endselect", true); } return $this->phpTag . "echo ''; ?>"; } protected function compileEndRadio() { $r = @\array_pop($this->htmlItem); if (\is_null($r)) { return $this->showError("@EndRadio", "Missing @Radio or so many @EndRadio", true); } return ''; } protected function compileEndCheckbox() { $r = @\array_pop($this->htmlItem); if (\is_null($r)) { return $this->showError("@EndCheckbox", "Missing @Checkbox or so many @EndCheckbox", true); } return ''; } protected function compileItem($expression) { // we add a new attribute with the type of the current open tag $r = \end($this->htmlItem); $x = \trim($expression); $x = "('{$r}'," . \substr($x, 1); return $this->phpTag . "echo \$this->item{$x}; ?>"; } protected function compileItems($expression) { // we add a new attribute with the type of the current open tag $r = \end($this->htmlItem); $x = \trim($expression); $x = "('{$r}'," . \substr($x, 1); return $this->phpTag . "echo \$this->items{$x}; ?>"; } protected function compileTrio($expression) { // we add a new attribute with the type of the current open tag $r = \end($this->htmlItem); $x = \trim($expression); $x = "('{$r}'," . \substr($x, 1); return $this->phpTag . "echo \$this->trio{$x}; ?>"; } protected function compileTrios($expression) { // we add a new attribute with the type of the current open tag $r = \end($this->htmlItem); $x = \trim($expression); $x = "('{$r}'," . \substr($x, 1); return $this->phpTag . "echo \$this->trios{$x}; ?>"; } protected function compileInput($expression) { return $this->phpTag . "echo \$this->input{$expression}; ?>"; } protected function compileFile($expression) { return $this->phpTag . "echo \$this->file{$expression}; ?>"; } protected function compileImage($expression) { return $this->phpTag . "echo \$this->image{$expression}; ?>"; } protected function compileTextArea($expression) { return $this->phpTag . "echo \$this->textArea{$expression}; ?>"; } protected function compileHidden($expression) { return $this->phpTag . "echo \$this->hidden{$expression}; ?>"; } protected function compileLabel($expression) { return $this->phpTag . "// {$expression} \n echo \$this->label{$expression}; ?>"; } protected function compileCommandButton($expression) { return $this->phpTag . "echo \$this->commandButton{$expression}; ?>"; } protected function compileForm($expression) { return $this->phpTag . "echo \$this->form{$expression}; ?>"; } protected function compileEndForm() { return $this->phpTag . "echo ''; ?>"; } // // public function select($name, $value, $extra = '') { if (\strpos($extra, 'readonly') === false) { return " \n"; if (\count($allvalues) == 0) { $allvalues = []; } $html2 = ""; foreach ($allvalues as $v) { if (\is_object($v)) { $v = (array)$v; } if (!$this->listboxesFindArray($v[$fieldId], $selectedId, $fieldId)) { $html .= "\n"; } else { $html2 .= "\n"; } } $html .= " \n"; $html .= " \n"; $html .= " \n"; $html .= "
\n"; $html .= "
\n"; $html .= "
\n"; $html .= "
\n"; $html .= " \n"; $html .= " \n"; $html .= " \n"; $html .= " \n"; $html .= " \n"; $html .= "\n"; return $html; } public function selectGroup($name, $extra = '') { return $this->selectGroup($name, $extra); } public function radio($id, $value = '', $text = '', $valueSelected = '', $extra = '') { $num = \func_num_args(); if ($num > 2) { if ($value == $valueSelected) { if (\is_array($extra)) { $extra['checked'] = 'checked'; } else { $extra .= ' checked="checked"'; } } return $this->input($id, $value, 'radio', $extra) . ' ' . $text; } $this->htmlCurrentId[] = $id; return ''; } /** * @param $id * @param string $value * @param string $text * @param string|null $valueSelected * @param string|array $extra * @return string */ public function checkbox($id, $value = '', $text = '', $valueSelected = '', $extra = '') { $num = \func_num_args(); if ($num > 2) { if ($value == $valueSelected) { if (\is_array($extra)) { $extra['checked'] = 'checked'; } else { $extra .= ' checked="checked"'; } } return $this->input($id, $value, 'checkbox', $extra) . ' ' . $text; } $this->htmlCurrentId[] = $id; return ''; } /** * @param string $type type of the current open tag * @param array|string $valueId if is an array then the first value is used as value, the second is used as * extra * @param $valueText * @param array|string $selectedItem Item selected (optional) * @param string $wrapper Wrapper of the element. For example,
  • %s
  • * @param string $extra * @return string * @internal param string $fieldId Field of the id * @internal param string $fieldText Field of the value visible */ public function item($type, $valueId, $valueText, $selectedItem = '', $wrapper = '', $extra = '') { $id = @\end($this->htmlCurrentId); $wrapper = ($wrapper == '') ? '%s' : $wrapper; if (\is_array($selectedItem)) { $found = \in_array($valueId, $selectedItem); } else { $found = $valueId == $selectedItem; } $valueHtml = (!\is_array($valueId)) ? "value='{$valueId}'" : "value='{$valueId[0]}' data='{$valueId[1]}'"; switch ($type) { case 'select': $selected = ($found) ? 'selected' : ''; return \sprintf($wrapper, "\n"); break; case 'radio': $selected = ($found) ? 'checked' : ''; return \sprintf($wrapper, "convertArg($extra) . "> {$valueText}\n"); break; case 'checkbox': $selected = ($found) ? 'checked' : ''; return \sprintf($wrapper, "convertArg($extra) . "> {$valueText}\n"); break; default: return '???? type undefined: [$type] on @item
    '; } } /** * @param string $type type of the current open tag * @param array $arrValues Array of objects/arrays to show. * @param string $fieldId Field of the id (for arrValues) * @param string $fieldText Field of the id of selectedItem * @param array|string $selectedItem Item selected (optional) * @param string $selectedFieldId field of the selected item. * @param string $wrapper Wrapper of the element. For example,
  • %s
  • * @param string $extra (optional) is used for add additional information for the html object (such * as class) * @return string * @version 1.1 2017 */ public function items( $type, $arrValues, $fieldId, $fieldText, $selectedItem = '', $selectedFieldId = '', $wrapper = '', $extra = '' ) { if (\count($arrValues) == 0) { return ""; } if (\is_object(@$arrValues[0])) { $arrValues = (array)$arrValues; } if (\is_array($selectedItem)) { if (\is_object(@$selectedItem[0])) { $primitiveArray = []; foreach ($selectedItem as $v) { $primitiveArray[] = $v->{$selectedFieldId}; } $selectedItem = $primitiveArray; } } $result = ''; if (\is_object($selectedItem)) { $selectedItem = (array)$selectedItem; } foreach ($arrValues as $v) { if (\is_object($v)) { $v = (array)$v; } $result .= $this->item($type, $v[$fieldId], $v[$fieldText], $selectedItem, $wrapper, $extra); } return $result; } /** * @param string $type type of the current open tag * @param string $valueId value of the trio * @param string $valueText visible value of the trio. * @param string $value3 extra third value for select value or visual * @param array|string $selectedItem Item selected (optional) * @param string $wrapper Wrapper of the element. For example,
  • %s
  • * @param string $extra * @return string * @internal param string $fieldId Field of the id * @internal param string $fieldText Field of the value visible */ public function trio($type, $valueId, $valueText, $value3 = '', $selectedItem = '', $wrapper = '', $extra = '') { $id = @\end($this->htmlCurrentId); $wrapper = ($wrapper == '') ? '%s' : $wrapper; if (\is_array($selectedItem)) { $found = \in_array($valueId, $selectedItem); } else { $found = $valueId == $selectedItem; } switch ($type) { case 'selectgroup': $selected = ($found) ? 'selected' : ''; return \sprintf($wrapper, "\n"); break; default: return '???? type undefined: [$type] on @item
    '; } } /** * @param string $type type of the current open tag * @param array $arrValues Array of objects/arrays to show. * @param string $fieldId Field of the id * @param string $fieldText Field of the value visible * @param string $fieldThird * @param array|string $selectedItem Item selected (optional) * @param string $wrapper Wrapper of the element. For example,
  • %s
  • * @param string $extra (optional) is used for add additional information for the html object (such as * class) * @return string * @version 1.0 */ public function trios( $type, $arrValues, $fieldId, $fieldText, $fieldThird, $selectedItem = '', $wrapper = '', $extra = '' ) { if (\count($arrValues) === 0) { return ""; } if (\is_object($arrValues[0])) { $arrValues = (array)$arrValues; } $result = ''; $oldV3 = ""; foreach ($arrValues as $v) { if (\is_object($v)) { $v = (array)$v; } $v3 = $v[$fieldThird]; if ($type === 'selectgroup') { if ($v3 != $oldV3) { if ($oldV3 != "") { $result .= ""; } $oldV3 = $v3; $result .= ""; } } if ($result) { $result .= $this->trio($type, $v[$fieldId], $v[$fieldText], $v3, $selectedItem, $wrapper, $extra); } } if ($type === 'selectgroup' && $oldV3 != "") { $result .= ""; } return $result; } protected $paginationStructure=['selHtml'=>'
  • %2s
  • ' ,'html'=>'
  • %2s
  • ' ,'maxItem'=>5 ,'url'=>'']; public function pagination($id, $curPage, $maxPage, $baseUrl, $extra='') { $r=""; return $r; } public function input($id, $value = '', $type = 'text', $extra = '') { return "convertArg($extra) . " value='" . static::e($value) . "' />\n"; } public function file($id, $fullfilepath = '', $file = '', $extra = '') { return "$file convertArg($extra) . " value='" . static::e($fullfilepath) . "' />\n"; } public function textArea($id, $value = '', $extra = '') { $value = \str_replace('\n', "\n", $value); return "\n"; } public function hidden($id, $value = '', $extra = '') { return $this->input($id, $value, 'hidden', $extra); } public function label($id, $value = '', $extra = '') { return ""; } public function commandButton($id, $value = '', $text = 'Button', $type = 'submit', $extra = '') { return "\n"; } public function form($action, $method = 'post', $extra = '') { return "
    convertArg($extra)}>"; } // }