public function getDataPage() { rex_extension::registerPoint(new rex_extension_point('YFORM_MANAGER_DATA_PAGE', $this)); // ********************************************* DATA ADD/EDIT/LIST $func = rex_request('func', 'string', ''); $data_id = rex_request('data_id', 'int', ''); $show_list = true; // -------------- rex_yform_manager_filter and sets $rex_yform_filter = rex_request('rex_yform_filter', 'array'); $rex_yform_set = rex_request('rex_yform_set', 'array'); // -------------- opener - popup for selection $popup = false; $rex_yform_manager_opener = rex_request('rex_yform_manager_opener', 'array'); if (count($rex_yform_manager_opener) > 0) { if (isset($rex_yform_manager_opener['id']) && $rex_yform_manager_opener['id'] != '') { $popup = true; // id, field, multiple } } // -------------- filter - popup for selection if (count($rex_yform_filter) > 0) { $popup = true; } if (is_bool($p = rex_request('popup', 'bool', null))) { $popup = $p; $this->setLinkVars(array('popup' => $p ? 1 : 0)); } // SearchObject $searchObject = new rex_yform_manager_search($this->table); $searchObject->setLinkVars(array("list" => rex_request('list', 'string', ''))); $searchObject->setLinkVars(array("start" => rex_request('start', 'string', ''))); $searchObject->setLinkVars(array("sort" => rex_request('sort', 'string', ''))); $searchObject->setLinkVars(array("sorttype" => rex_request('sorttype', 'string', ''))); $searchObject->setLinkVars($this->getLinkVars()); if (count($rex_yform_filter) > 0) { foreach ($rex_yform_filter as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $searchObject->setLinkVars(array('rex_yform_filter[' . $k . '][' . $k2 . ']' => $v2)); } } else { $searchObject->setLinkVars(array('rex_yform_filter[' . $k . ']' => $v)); } } } if (count($rex_yform_set) > 0) { foreach ($rex_yform_set as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $searchObject->setLinkVars(array('rex_yform_set[' . $k . '][' . $k2 . ']' => $v2)); } } else { $searchObject->setLinkVars(array('rex_yform_set[' . $k . ']' => $v)); } } } if (count($rex_yform_manager_opener) > 0) { foreach ($rex_yform_manager_opener as $k => $v) { $searchObject->setLinkVars(array('rex_yform_manager_opener[' . $k . ']' => $v)); } } $searchform = ''; if ($this->hasDataPageFunction('search')) { $searchform = '<div class="rex-addon-output"> <h3 class="rex-hl2">' . rex_i18n::msg('yform_manager_search') . '</h3> <div class="rex-addon-content"> <div class="yform" id="rex-yform">' . $searchObject->getForm() . '</div> </div> </div>'; } // -------------- DEFAULT - LISTE AUSGEBEN $link_vars = ''; foreach ($this->getLinkVars() as $k => $v) { $link_vars .= '&' . urlencode($k) . '=' . urlencode($v); } echo rex_view::title(rex_i18n::msg('yform_table') . ': ' . rex_i18n::translate($this->table->getName()) . ' <small>[' . $this->table->getTablename() . ']</small>', ''); echo rex_extension::registerPoint(new rex_extension_point('YFORM_MANAGER_REX_INFO', '')); $show_editpage = true; $show_editpage = rex_extension::registerPoint(new rex_extension_point('YFORM_MANAGER_DATA_EDIT_FUNC', $show_editpage, ['table' => $this->table, 'link_vars' => $this->getLinkVars()])); if ($show_editpage) { // -------------- DB FELDER HOLEN $field_names = array(); foreach ($this->table->getValueFields() as $field) { $field_names[] = $field->getName(); } // -------------- DB DATA HOLEN $data = array(); if ($data_id != '') { $gd = rex_sql::factory(); $gd->setQuery('select * from ' . $this->table->getTableName() . ' where id=' . $data_id); if ($gd->getRows() == 1) { $datas = $gd->getArray(); $data = current($datas); } else { $data_id = ''; } } // -------------- Opener foreach ($rex_yform_manager_opener as $k => $v) { $link_vars .= '&rex_yform_manager_opener[' . $k . ']=' . urlencode($v); } // -------------- Searchfields / Searchtext $link_vars .= '&' . http_build_query($searchObject->getSearchVars()); // -------------- FILTER UND SETS PRFEN $em_url_filter = ''; if (count($rex_yform_filter) > 0) { foreach ($rex_yform_filter as $k => $v) { if (!in_array($k, $field_names)) { unset($rex_yform_filter[$k]); } } $em_url_filter .= '&' . http_build_query(compact('rex_yform_filter')); } $em_url_set = ''; if (count($rex_yform_set) > 0) { foreach ($rex_yform_set as $k => $v) { if (!in_array($k, $field_names)) { unset($rex_yform_set[$k]); } } $em_url_filter .= '&' . http_build_query(compact('rex_yform_set')); } $em_url = $em_url_filter . $em_url_set; $em_rex_list = ''; $em_rex_list .= '&list=' . urlencode(rex_request('list', 'string')); $em_rex_list .= '&sort=' . urlencode(rex_request('sort', 'string')); $em_rex_list .= '&sorttype=' . urlencode(rex_request('sorttype', 'string')); $em_rex_list .= '&start=' . urlencode(rex_request('start', 'string')); // ---------- Popup - no menue, header ... if ($popup) { echo '<link rel="stylesheet" type="text/css" href="' . rex_plugin::get('yform', 'manager')->getAssetsUrl('popup.css') . '" />'; } // -------------- Import if (!$popup && $func == 'import' && $this->hasDataPageFunction('import')) { include rex_path::plugin('yform', 'manager', 'pages/data_import.php'); echo rex_view::info('<a href="index.php?' . $link_vars . $em_url . $em_rex_list . '"><b>« ' . rex_i18n::msg('yform_back_to_overview') . '</b></a>'); } // -------------- delete entry if ($func == 'delete' && $data_id != '' && $this->hasDataPageFunction('delete')) { $delete = true; if (rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_DELETE', $delete, array('id' => $data_id, 'value' => $data, 'table' => $this->table)))) { $query = 'delete from ' . $this->table->getTablename() . ' where id=' . $data_id; $delsql = rex_sql::factory(); $delsql->debugsql = self::$debug; $delsql->setQuery($query); echo rex_view::success(rex_i18n::msg('yform_datadeleted')); $func = ''; $this->table->removeRelationTableRelicts(); rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_DELETED', '', array('id' => $data_id, 'value' => $data, 'table' => $this->table))); } } // -------------- delete dataset if ($func == 'dataset_delete' && $this->hasDataPageFunction('truncate_table')) { $delete = true; $query = 'delete from `' . $this->table->getTablename() . '` ' . $this->getDataListQueryWhere($rex_yform_filter, $searchObject); if (rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_DATASET_DELETE', $delete, array('table' => $this->table, 'query' => &$query)))) { $delsql = rex_sql::factory(); $delsql->debugsql = self::$debug; $delsql->setQuery($query); echo rex_view::success(rex_i18n::msg('yform_dataset_deleted')); $func = ''; $this->table->removeRelationTableRelicts(); rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_DATASET_DELETED', '', array('table' => $this->table))); } } // -------------- truncate table if ($func == 'truncate_table' && $this->hasDataPageFunction('truncate_table')) { $truncate = true; if (rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_TABLE_TRUNCATE', $truncate, array('table' => $this->table)))) { $query = 'truncate table ' . $this->table->getTablename(); $trunsql = rex_sql::factory(); $trunsql->setQuery($query); echo rex_view::info(rex_i18n::msg('yform_table_truncated')); $func = ''; $this->table->removeRelationTableRelicts(); rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_TABLE_TRUNCATED', '', array('table' => $this->table))); } } // -------------- export dataset if ($func == 'dataset_export' && $this->hasDataPageFunction('export')) { ob_end_clean(); $sql = $this->getDataListQuery($rex_yform_filter, $searchObject); $data = ''; $fields = array(); $g = rex_sql::factory(); $g->setQuery($sql); $array = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_TABLE_EXPORT', $g->getArray(), array('table' => $this->table))); foreach ($array as $d) { if ($data == '') { foreach ($d as $a => $b) { $fields[] = '"' . $a . '"'; } $data = implode(';', $fields); } foreach ($d as $a => $b) { $d[$a] = '"' . str_replace('"', '""', $b) . '"'; } $data .= "\n" . implode(';', $d); } // ----- download - save as $filename = 'export_data_' . date('YmdHis') . '.csv'; $filesize = strlen($data); $filetype = 'application/octetstream'; $expires = 'Mon, 01 Jan 2000 01:01:01 GMT'; $last_modified = 'Mon, 01 Jan 2000 01:01:01 GMT'; header('Expires: ' . $expires); // Date in the past header('Last-Modified: ' . $last_modified); // always modified header('Cache-Control: no-store, no-cache, must-revalidate'); // HTTP/1.1 header('Cache-Control: post-check=0, pre-check=0', false); header('Pragma: no-cache'); header('Pragma: private'); header('Cache-control: private, must-revalidate'); header('Content-Type: ' . $filetype . '; name="' . $filename . '"'); header('Content-Disposition: attachment; filename="' . $filename . '"'); header('Content-Description: "' . $filename . '"'); header('Content-Length: ' . $filesize); echo $data; exit; } // -------------- form if ($func == 'add' && $this->hasDataPageFunction('add') || $func == 'edit') { $back = rex_view::info('<a href="index.php?' . $link_vars . $em_url . $em_rex_list . '"><b>« ' . rex_i18n::msg('yform_back_to_overview') . '</b></a>'); $yform = new rex_yform(); $yform->setDebug(self::$debug); foreach ($this->getLinkVars() as $k => $v) { $yform->setHiddenField($k, $v); } if (count($rex_yform_manager_opener) > 0) { foreach ($rex_yform_manager_opener as $k => $v) { $yform->setHiddenField('rex_yform_manager_opener[' . $k . ']', $v); } } if (count($rex_yform_filter) > 0) { foreach ($rex_yform_filter as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $yform->setHiddenField('rex_yform_filter[' . $k . '][' . $k2 . ']', $v2); } } else { $yform->setHiddenField('rex_yform_filter[' . $k . ']', $v); } } } if (count($rex_yform_set) > 0) { foreach ($rex_yform_set as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $yform->setHiddenField('rex_yform_set[' . $k . '][' . $k2 . ']', $v2); } } else { $yform->setHiddenField('rex_yform_set[' . $k . ']', $v); } } } foreach ($searchObject->getSearchVars() as $s_var => $values) { foreach ($values as $k => $v) { $yform->setHiddenField($s_var . '[' . $k . ']', $v); } } // for rexlist $yform->setHiddenField('list', rex_request('list', 'string')); $yform->setHiddenField('sort', rex_request('sort', 'string')); $yform->setHiddenField('sorttype', rex_request('sorttype', 'string')); $yform->setHiddenField('start', rex_request('start', 'string')); foreach ($this->table->getFields() as $field) { $class = 'rex_yform_' . $field->getType() . '_' . $field->getTypeName(); $cl = new $class(); $definitions = $cl->getDefinitions(); $values = array(); $i = 1; foreach ($definitions['values'] as $key => $_) { $key = $this->getFieldName($key, $field->getType()); /*if ($field->getElement($key)) { $values[] = $field->getElement($key); } elseif ($field->getElement('f' . $i)) { $values[] = $field->getElement('f' . $i); } else { $values[] = ''; }*/ $values[] = $field->getElement($key); $i++; } if ($field->getType() == 'value') { if (in_array($values[1], $this->getFilterFields())) { // Feld vorhanden -> ignorieren -> hidden feld machen // TODO: Feld trotzdem noch aufnehmen, damit validierungen etc noch funktionieren } else { $yform->setValueField($field->getTypeName(), $values); } } elseif ($field->getType() == 'validate') { $yform->setValidateField($field->getTypeName(), $values); } elseif ($field->getType() == 'action') { $yform->setActionField($field->getTypeName(), $values); } } if (rex_request('rex_yform_show_formularblock', 'string') != '') { // Optional .. kann auch geloescht werden. Dient nur zu Hilfe beim Aufbau // von yform-Formularen über php // Textblock gibt den formalarblock als text aus, um diesen in das yform modul einsetzen zu können. // rex_yform_show_formularblock=1 $text_block = ''; foreach ($this->table->getFields() as $field) { $class = 'rex_yform_' . $field->getType() . '_' . $field->getTypeName(); $cl = new $class(); $definitions = $cl->getDefinitions(); $values = array(); $i = 1; foreach ($definitions['values'] as $key => $_) { $key = $this->getFieldName($key, $field->getType()); if (isset($field[$key])) { $values[] = $field[$key]; } elseif (isset($field['f' . $i])) { $values[] = $field['f' . $i]; } else { $values[] = ''; } $i++; } if ($field->getType() == 'value') { $text_block .= "\n" . '$yform->setValueField("' . $field->getTypeName() . '",array("' . implode('","', $values) . '"));'; } else { if ($field->getType() == 'validate') { $text_block .= "\n" . '$yform->setValidateField("' . $field->getTypeName() . '",array("' . implode('","', $values) . '"));'; } else { if ($field->getType() == 'action') { $text_block .= "\n" . '$yform->setActionField("' . $field->getTypeName() . '",array("' . implode('","', $values) . '"));'; } } } // $text_block .= "\n".$field["type_name"].'|'.implode("|",$values); } echo '<pre>' . $text_block . '</pre>'; } $yform->setObjectparams('main_table', $this->table->getTablename()); // für db speicherungen und unique abfragen $yform->setObjectparams('rex_yform_set', $rex_yform_set); $yform_clone = clone $yform; $yform->setHiddenField('func', $func); // damit es neu im clone gesetzt werden kann if ($func == 'edit') { $yform->setHiddenField('data_id', $data_id); $yform->setActionField('db', array($this->table->getTablename(), "id={$data_id}")); $yform->setObjectparams('main_id', $data_id); $yform->setObjectparams('main_where', "id={$data_id}"); $yform->setObjectparams('getdata', true); $yform->setValueField('submits', array("name" => "submit", "labels" => rex_i18n::msg('yform_save') . "," . rex_i18n::msg('yform_save_apply'), "values" => "1,2", "no_db" => true, "css_classes" => "btn-save,btn-apply")); } elseif ($func == 'add') { $yform->setActionField('db', array($this->table->getTablename())); $yform->setValueField('submits', array("name" => "submit", "labels" => rex_i18n::msg('yform_add') . "," . rex_i18n::msg('yform_add_apply'), "values" => "1,2", "no_db" => true, "css_classes" => "btn-save,btn-apply")); } if ($func == 'edit') { $yform = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_UPDATE', $yform, array('table' => $this->table, 'data_id' => $data_id, 'data' => $data))); } elseif ($func == 'add') { $yform = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_ADD', $yform, array('table' => $this->table))); } $yform->executeFields(); $submit_type = 1; // normal, 2=apply foreach ($yform->objparams["values"] as $f) { if ($f->getName() == "submit") { if ($f->getValue() == 2) { // apply $yform->setObjectparams('form_showformafterupdate', 1); $yform->executeFields(); $submit_type = 2; } } } $form = $yform->executeActions(); if ($yform->objparams['actions_executed']) { if ($func == 'edit') { echo rex_view::info(rex_i18n::msg('yform_thankyouforupdate')); $yform = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_UPDATED', $yform, array('table' => $this->table, 'data_id' => $data_id, 'data' => $data))); } elseif ($func == 'add') { echo rex_view::info(rex_i18n::msg('yform_thankyouforentry')); $yform = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_ADDED', $yform, array('table' => $this->table))); if ($submit_type == 2) { $data_id = $yform->objparams['main_id']; $func = "edit"; $yform = $yform_clone; $yform->setHiddenField('func', $func); $yform->setHiddenField('data_id', $data_id); $yform->setActionField('db', array($this->table->getTablename(), "id={$data_id}")); $yform->setObjectparams('main_id', $data_id); $yform->setObjectparams('main_where', "id={$data_id}"); $yform->setObjectparams('getdata', true); $yform->setValueField('submits', array("name" => "submit", "labels" => rex_i18n::msg('yform_save') . "," . rex_i18n::msg('yform_save_apply'), "values" => "1,2", "no_db" => true, "css_classes" => "btn-save,btn-apply")); $yform->setObjectparams('form_showformafterupdate', 1); $yform->executeFields(); $form = $yform->executeActions(); } } } if ($yform->objparams['form_show'] || $yform->objparams['form_showformafterupdate']) { if ($func == 'add') { $title = rex_i18n::msg('yform_adddata'); } else { $title = rex_i18n::msg('yform_editdata'); } $fragment = new rex_fragment(); $fragment->setVar('class', 'edit', false); $fragment->setVar('title', $title); $fragment->setVar('body', $form, false); // $fragment->setVar('buttons', $buttons, false); $form = $fragment->parse('core/page/section.php'); echo $form; echo rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_FORM', '', array('form' => $form, 'func' => $func, 'this' => $this, 'table' => $this->table))); echo $back; $show_list = false; } } // ********************************************* LIST if ($show_list) { $sql = $this->getDataListQuery($rex_yform_filter, $searchObject); // ---------- LISTE AUSGEBEN /** @type rex_list $list */ $list = rex_list::factory($sql, $this->table->getListAmount()); if ($this->hasDataPageFunction('add')) { $tdIcon = '<i class="rex-icon rex-icon-table"></i>'; $thIcon = '<a href="index.php?' . $link_vars . '&func=add&' . $em_url . $em_rex_list . '"' . rex::getAccesskey(rex_i18n::msg('add'), 'add') . '><i class="rex-icon rex-icon-add"></i></a>'; $list->addColumn($thIcon, $tdIcon, 0, ['<th class="rex-table-icon">###VALUE###</th>', '<td class="rex-table-icon">###VALUE###</td>']); if (!isset($rex_yform_manager_opener['id'])) { $list->setColumnParams($thIcon, ['data_id' => '###id###', 'func' => 'edit', 'start' => rex_request('start', 'string'), 'sort' => rex_request('sort', 'string'), 'sorttype' => rex_request('sorttype', 'string'), 'list' => rex_request('list', 'string')]); } } // $list->setColumnFormat('id', 'Id'); foreach ($this->getLinkVars() as $k => $v) { $list->addParam($k, $v); } $list->addParam('table_name', $this->table->getTablename()); if (count($rex_yform_filter) > 0) { foreach ($rex_yform_filter as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $list->addParam('rex_yform_filter[' . $k . '][' . $k2 . ']', $v2); } } else { $list->addParam('rex_yform_filter[' . $k . ']', $v); } } } if (count($rex_yform_set) > 0) { foreach ($rex_yform_set as $k => $v) { if (is_array($v)) { foreach ($v as $k2 => $v2) { $list->addParam('rex_yform_set[' . $k . '][' . $k2 . ']', $v2); } } else { $list->addParam('rex_yform_set[' . $k . ']', $v); } } } if (count($rex_yform_manager_opener) > 0) { foreach ($rex_yform_manager_opener as $k => $v) { $list->addParam('rex_yform_manager_opener[' . $k . ']', $v); } } foreach ($searchObject->getSearchVars() as $s_var => $values) { foreach ($values as $k => $v) { $list->addParam($s_var . '[' . $k . ']', $v); } } $list->setColumnLabel('id', rex_i18n::msg('yform_id')); $list->setColumnLayout('id', ['<th class="rex-table-id">###VALUE###</th>', '<td class="rex-table-id" data-title="' . rex_i18n::msg('id') . '">###VALUE###</td>']); $list->setColumnParams('id', array('data_id' => '###id###', 'func' => 'edit')); $list->setColumnSortable('id'); foreach ($this->table->getFields() as $field) { if (!$field->isHiddenInList() && $field->getTypeName()) { if (method_exists('rex_yform_value_' . $field->getTypeName(), 'getListValue')) { $list->setColumnFormat($field->getName(), 'custom', array('rex_yform_value_' . $field->getTypeName(), 'getListValue'), array('field' => $field->toArray(), 'fields' => $this->table->getFields())); } } if ($field->getType() == 'value') { if ($field->isHiddenInList()) { $list->removeColumn($field->getName()); } else { $list->setColumnSortable($field->getName()); $list->setColumnLabel($field->getName(), $field->getLabel()); } } } if (isset($rex_yform_manager_opener['id'])) { $list->addColumn(rex_i18n::msg('yform_data_select'), ''); $list->setColumnFormat(rex_i18n::msg('yform_data_select'), 'custom', function ($params) { $value = ''; list($table_name, $field_name) = explode(".", $params["params"]["opener_field"]); $table = rex_yform_manager_table::get($table_name); if ($table) { $fields = $table->getValueFields(array("name" => $field_name)); if (isset($fields[$field_name])) { $target_table = $fields[$field_name]->getElement('table'); $target_field = $fields[$field_name]->getElement('field'); $values = rex_yform_value_be_manager_relation::getListValues($target_table, $target_field); $value = $values[$params['list']->getValue('id')]; } } return '<a href="javascript:yform_manager_setData(' . $params["params"]["opener_id"] . ',###id###,\'' . htmlspecialchars($value) . ' [id=###id###]\',' . $params["params"]["opener_multiple"] . ')">' . rex_i18n::msg('yform_data_select') . '</a>'; }, array("opener_id" => $rex_yform_manager_opener["id"], "opener_field" => $rex_yform_manager_opener["field"], "opener_multiple" => $rex_yform_manager_opener["multiple"])); } else { $list->addColumn(rex_i18n::msg('yform_function'), '<i class="rex-icon rex-icon-edit"></i> ' . rex_i18n::msg('yform_edit')); $list->setColumnLayout(rex_i18n::msg('yform_function'), ['<th class="rex-table-action">###VALUE###</th>', '<td class="rex-table-action">###VALUE###</td>']); $list->setColumnParams(rex_i18n::msg('yform_function'), array('data_id' => '###id###', 'func' => 'edit', 'start' => rex_request('start', 'string'), 'sort' => rex_request('sort', 'string'), 'sorttype' => rex_request('sorttype', 'string'), 'list' => rex_request('list', 'string'))); if ($this->hasDataPageFunction('delete')) { // Column layout fuer edit neu setzen $list->setColumnLayout(rex_i18n::msg('yform_function'), ['<th class="rex-table-action" colspan="2">###VALUE###</th>', '<td class="rex-table-action">###VALUE###</td>']); $list->addColumn(rex_i18n::msg('yform_delete'), '<i class="rex-icon rex-icon-delete"></i> ' . rex_i18n::msg('yform_delete')); $list->setColumnLayout(rex_i18n::msg('yform_delete'), ['', '<td class="rex-table-action">###VALUE###</td>']); $list->setColumnParams(rex_i18n::msg('yform_delete'), array('data_id' => '###id###', 'func' => 'delete', 'start' => rex_request('start', 'string'), 'sort' => rex_request('sort', 'string'), 'sorttype' => rex_request('sorttype', 'string'), 'list' => rex_request('list', 'string'))); $list->addLinkAttribute(rex_i18n::msg('yform_delete'), 'onclick', 'return confirm(\' id=###id### ' . rex_i18n::msg('yform_delete') . ' ?\')'); } } // ********************************************* $list = rex_extension::registerPoint(new rex_extension_point('YFORM_DATA_LIST', $list, array('table' => $this->table))); if ($rex_yform_filter) { $filter = array(); $getFilter = function (rex_yform_manager_field $field, $value) { if ('be_manager_relation' == $field->getTypeName()) { $listValues = rex_yform_value_be_manager_relation::getListValues($field->getElement('table'), $field->getElement('field'), array('id' => $value)); if (isset($listValues[$value])) { $value = $listValues[$value]; } } return '<b>' . rex_i18n::translate($field->getLabel()) . ':</b> ' . $value; }; foreach ($rex_yform_filter as $key => $value) { if (is_array($value)) { $relTable = rex_yform_manager_table::get($this->table->getValueField($key)->getElement('table')); foreach ($value as $k => $v) { $filter[] = $getFilter($relTable->getValueField($k), $v); } } else { $filter[] = $getFilter($this->table->getValueField($key), $value); } } echo rex_view::info(implode('<br>', $filter)); } $panel_options = ''; $data_links = []; if ($this->table->isSearchable() && $this->hasDataPageFunction('search')) { $item = []; $item['label'] = rex_i18n::msg('yform_search'); $item['attributes']['class'][] = 'btn-search'; $item['attributes']['id'] = 'searchtoggler'; $data_links[] = $item; } if (count($data_links) > 0) { $fragment = new rex_fragment(); $fragment->setVar('size', 'xs', false); $fragment->setVar('buttons', $data_links, false); $panel_options .= '<small class="rex-panel-option-title">' . rex_i18n::msg('yform_data') . '</small> ' . $fragment->parse('core/buttons/button_group.php'); } // INFO LINK $dataset_links = []; if ($this->table->isExportable() == 1 && $this->hasDataPageFunction('export')) { $item = []; $item['label'] = rex_i18n::msg('yform_export'); $item['url'] = 'index.php?' . $link_vars . '&func=dataset_export&' . $em_url . $em_rex_list; $item['attributes']['class'][] = 'btn-default'; $dataset_links[] = $item; } if ($this->hasDataPageFunction('truncate_table')) { $item = []; $item['label'] = rex_i18n::msg('yform_delete'); $item['url'] = 'index.php?' . $link_vars . '&func=dataset_delete&' . $em_url . $em_rex_list; $item['attributes']['class'][] = 'btn-delete'; $item['attributes']['id'] = 'dataset-delete'; $item['attributes']['onclick'][] = 'return confirm(\'' . rex_i18n::msg('yform_dataset_delete_confirm') . '\');'; $dataset_links[] = $item; } if (count($dataset_links) > 0) { $fragment = new rex_fragment(); $fragment->setVar('size', 'xs', false); $fragment->setVar('buttons', $dataset_links, false); $panel_options .= '<small class="rex-panel-option-title">' . rex_i18n::msg('yform_dataset') . '</small> ' . $fragment->parse('core/buttons/button_group.php'); } $table_links = array(); if (!$popup && $this->table->isImportable() && $this->hasDataPageFunction('import')) { $item = []; $item['label'] = rex_i18n::msg('yform_import'); $item['url'] = 'index.php?' . htmlspecialchars($link_vars) . '&func=import'; $item['attributes']['class'][] = 'btn-default'; $table_links[] = $item; } if (rex::getUser()->isAdmin()) { $item = []; $item['label'] = rex_i18n::msg('yform_edit'); $item['url'] = 'index.php?page=yform/manager&table_id=' . $this->table->getId() . '&func=edit'; $item['attributes']['class'][] = 'btn-default'; $table_links[] = $item; } if ($this->hasDataPageFunction('truncate_table')) { $item = []; $item['label'] = rex_i18n::msg('yform_truncate_table'); $item['url'] = 'index.php?' . $link_vars . '&func=truncate_table&' . $em_url . $em_rex_list; $item['attributes']['class'][] = 'btn-delete'; $item['attributes']['id'] = 'truncate-table'; $item['attributes']['onclick'][] = 'return confirm(\'' . rex_i18n::msg('yform_truncate_table_confirm') . '\');'; $table_links[] = $item; } if (count($table_links) > 0) { $fragment = new rex_fragment(); $fragment->setVar('size', 'xs', false); $fragment->setVar('buttons', $table_links, false); $panel_options .= '<small class="rex-panel-option-title">' . rex_i18n::msg('yform_table') . '</small> ' . $fragment->parse('core/buttons/button_group.php'); } $field_links = array(); if (rex::getUser()->isAdmin()) { $item = []; $item['label'] = rex_i18n::msg('yform_edit'); $item['url'] = 'index.php?page=yform/manager/table_field&table_name=' . $this->table->getTableName(); $item['attributes']['class'][] = 'btn-default'; $field_links[] = $item; } if (count($field_links) > 0) { $fragment = new rex_fragment(); $fragment->setVar('size', 'xs', false); $fragment->setVar('buttons', $field_links, false); $panel_options .= '<small class="rex-panel-option-title">' . rex_i18n::msg('yform_manager_fields') . '</small> ' . $fragment->parse('core/buttons/button_group.php'); } // SEARCHBLOCK $searchVars = $searchObject->getSearchVars(); $display = count($searchVars["rex_yform_searchvars"]) > 0 ? 'block' : 'none'; echo '<div id="searchblock" style="display:' . $display . ';">' . $searchform . '</div>'; $content = $list->get(); $fragment = new rex_fragment(); $fragment->setVar('title', rex_i18n::msg('yform_tabledata_overview')); $fragment->setVar('options', $panel_options, false); $fragment->setVar('content', $content, false); $content = $fragment->parse('core/page/section.php'); $content .= ' <script type="text/javascript">/* <![CDATA[ */ jQuery("#searchtoggler").click(function(){jQuery("#searchblock").slideToggle("fast");}); jQuery("#yform_help_empty_toggler").click(function(){jQuery("#yform_help_empty").slideToggle("fast");}); jQuery("#yform_search_reset").click(function(){window.location.href = "index.php?page=yform/manager/data_edit&table_name=' . $this->table->getTableName() . '";}); jQuery("#truncate-table").click(function(){if(confirm("' . rex_i18n::msg('yform_truncate_table_confirm') . '")){return true;} else {return false;}}); jQuery("#dataset-delete").click(function(){if(confirm("' . rex_i18n::msg('yform_dataset_delete_confirm') . '")){return true;} else {return false;}}); /* ]]> */</script>'; echo $content; } } // end: $show_editpage }
protected function getRelationTableFields() { $table = rex_yform_manager_table::get($this->getElement('relation_table')); $source = $table->getRelationsTo($this->params['main_table']); $target = $table->getRelationsTo($this->getElement('table')); if (!empty($source) && !empty($target)) { return array('source' => reset($source)->getName(), 'target' => reset($target)->getName()); } return array('source' => null, 'target' => null); }
} $fragment = new rex_fragment(); $fragment->setVar('class', 'edit', false); $fragment->setVar('title', $title); $fragment->setVar('body', $form, false); // $fragment->setVar('buttons', $buttons, false); $form = $fragment->parse('core/page/section.php'); echo $form; echo rex_view::info('<a href="index.php?page=' . $page . '"><b>« ' . rex_i18n::msg('yform_back_to_overview') . '</b></a>'); $show_list = false; } else { if ($func == 'edit') { echo rex_view::info(rex_i18n::msg('yform_manager_table_updated')); } elseif ($func == 'add') { $table_name = $yform->objparams['value_pool']['sql']['table_name']; $table = rex_yform_manager_table::get($table_name); if ($table) { $t = new rex_yform_manager(); $t->setTable($table); $t->generateAll(); echo rex_view::success(rex_i18n::msg('yform_manager_table_added')); } } } } } if ($func == 'delete' && rex::getUser()->isAdmin()) { $table_name = rex_request('table_name', 'string'); echo rex_yform_manager_table_api::removeTable($table_name); $func = ''; echo rex_view::success(rex_i18n::msg('yform_manager_table_deleted'));
public static function setTableField($table_name, array $table_field) { unset($table_field['id']); if ($table_name == '') { throw new Exception('table_name must be set'); } if (count($table_field) == 0) { throw new Exception('field must be a filled array'); } $fieldIdentifier = array('type_id' => $table_field['type_id'], 'type_name' => $table_field['type_name'], 'name' => $table_field['name']); $currentFields = rex_yform_manager_table::get($table_name)->getFields($fieldIdentifier); // validate specials if ($table_field['type_id'] == 'validate') { $table_field['list_hidden'] = 1; $table_field['search'] = 0; } self::createMissingFieldColumns($table_field); if (count($currentFields) > 1) { throw new Exception('more than one field found for table: ' . $table_name . ' with Fieldidentifier: ' . implode(', ', $fieldIdentifier) . ''); } elseif (count($currentFields) == 0) { // Insert $field_insert = rex_sql::factory(); $field_insert->debugsql = self::$debug; $field_insert->setTable(rex_yform_manager_field::table()); $field_insert->setValue('table_name', $table_name); foreach ($table_field as $field_name => $field_value) { $field_insert->setValue($field_name, $field_value); } if (!isset($table['prio'])) { $field_insert->setValue('prio', rex_yform_manager_table::get($table_name)->getMaximumPrio() + 1); } $field_insert->insert(); } else { // Update $currentField = $currentFields[0]->toArray(); foreach ($table_field as $field_name => $field_value) { $currentField[$field_name] = $field_value; } $field_update = rex_sql::factory(); $field_update->debugsql = self::$debug; $field_update->setTable(rex_yform_manager_field::table()); $add_where = array(); foreach ($fieldIdentifier as $field => $value) { $add_where[] = '`' . mysql_real_escape_string($field) . '`="' . mysql_real_escape_string($table_name) . '"'; } $where = 'table_name="' . mysql_real_escape_string($table_name) . '"'; if (count($add_where) > 0) { $where .= ' and (' . implode(' and ', $add_where) . ') '; } $field_update->setWhere($where); foreach ($table_field as $field_name => $field_value) { $field_update->setValue($field_name, $field_value); } $field_update->update(); } }