/** * Save data. * * @param array $data Data. * @return bool|mixed * * @throws SystemException 'ERR_VALIDATE_FORM' */ protected function saveData($data) { $result = false; //создаем объект описания данных $dataDescriptionObject = new DataDescription(); //получаем описание полей для метода $configDataDescription = $this->getConfig()->getStateConfig($this->getPreviousState()); //если в конфиге есть описание полей для метода - загружаем их if (isset($configDataDescription->fields)) { $dataDescriptionObject->loadXML($configDataDescription->fields); } //Создаем объект описания данных взятых из БД $DBDataDescription = new DataDescription(); //Загружаем в него инфу о колонках $DBDataDescription->load($this->loadDataDescription()); $this->setDataDescription($dataDescriptionObject->intersect($DBDataDescription)); $dataObject = new Data(); $dataObject->load($data); $this->setData($dataObject); //Создаем сейвер $saver = new Saver(); //Устанавливаем его режим $saver->setMode(self::COMPONENT_TYPE_FORM_ADD); $saver->setDataDescription($this->getDataDescription()); $saver->setData($this->getData()); if ($saver->validate() === true) { $saver->setFilter($this->getFilter()); $saver->save(); $result = $saver->getResult(); } else { //выдвигается пустой exception который перехватывается в методе save throw new SystemException('ERR_VALIDATE_FORM', SystemException::ERR_WARNING, $saver->getErrors()); } return $result; }
protected function main() { $id = !($id = $this->getParam('id')) ? $this->document->getID() : $id; $this->setBuilder(new SimpleBuilder()); $dd = new DataDescription(); if ($this->getConfig()->getCurrentStateConfig() && $this->getConfig()->getCurrentStateConfig()->fields) { $dd->loadXML($this->getConfig()->getCurrentStateConfig()->fields); } else { $dd->load(['Id' => ['type' => FieldDescription::FIELD_TYPE_INT], 'Name' => ['type' => FieldDescription::FIELD_TYPE_STRING], 'Title' => ['type' => FieldDescription::FIELD_TYPE_STRING], 'HtmlTitle' => ['type' => FieldDescription::FIELD_TYPE_STRING], 'DescriptionRtf' => ['type' => FieldDescription::FIELD_TYPE_HTML_BLOCK]]); } $fd = new FieldDescription('Url'); $fd->setType(FieldDescription::FIELD_TYPE_STRING); $dd->addFieldDescription($fd); $info = E()->getMap()->getDocumentInfo($id); $d = new Data(); $info['Id'] = $id; $info['Url'] = E()->getMap()->getURLByID($id); $d->load([$info]); $this->setDataDescription($dd); $this->setData($d); $m = new AttachmentManager($this->getDataDescription(), $this->getData(), 'share_sitemap', true); $m->createFieldDescription(); $m->createField('smap_id', false, $id); $this->addToolbar($this->loadToolbar()); $this->js = $this->buildJS(); }
protected function saveData() { $result = false; //если в POST не пустое значение значение первичного ключа - значит мы находимся в режиме редактирования if (isset($_POST[$this->getTableName()][$this->getPK()]) && !empty($_POST[$this->getTableName()][$this->getPK()])) { $mode = self::COMPONENT_TYPE_FORM_ALTER; $this->setFilter([$this->getPK() => $_POST[$this->getTableName()][$this->getPK()]]); } else { $mode = self::COMPONENT_TYPE_FORM_ADD; } //создаем объект описания данных $dataDescriptionObject = new DataDescription(); if (!method_exists($this, $this->getPreviousState())) { throw new SystemException('ERR_NO_ACTION', SystemException::ERR_CRITICAL); } //получаем описание полей для метода $configDataDescription = $this->getConfig()->getStateConfig($this->getPreviousState()); //если в конфиге есть описание полей для метода - загружаем их if (isset($configDataDescription->fields)) { $dataDescriptionObject->loadXML($configDataDescription->fields); } //Создаем объект описания данных взятых из БД $DBDataDescription = new DataDescription(); //Загружаем в него инфу о колонках $DBDataDescription->load($this->loadDataDescription()); $this->setDataDescription($dataDescriptionObject->intersect($DBDataDescription)); //Поле с порядком следования убираем из списка if (($col = $this->getOrderColumn()) && ($field = $this->getDataDescription()->getFieldDescriptionByName($col))) { $this->getDataDescription()->removeFieldDescription($field); } $dataObject = new Data(); $dataObject->load($this->loadData()); $this->setData($dataObject); //Создаем сейвер $saver = $this->getSaver(); //Устанавливаем его режим $saver->setMode($mode); $saver->setDataDescription($this->getDataDescription()); $saver->setData($this->getData()); if ($saver->validate() === true) { $saver->setFilter($this->getFilter()); $saver->save(); $result = $saver->getResult(); } else { //выдвигается exception который перехватывается в методе save throw new SystemException('ERR_VALIDATE_FORM', SystemException::ERR_WARNING, $this->saver->getErrors()); } //Если у нас режим вставки и определена колонка для порядка следования, // изменяем порядок следования if (($orderColumn = $this->getOrderColumn()) && $mode == self::COMPONENT_TYPE_FORM_ADD) { $linkedID = $this->getParam('linkedID'); $pk = $this->getParam('pk'); if ($linkedID) { $new_order_num = $this->dbh->getScalar('SELECT max(' . $orderColumn . ') as max_order_num FROM ' . $this->getTableName() . ' WHERE `' . $pk . '` = %s', $linkedID); } else { $new_order_num = $this->dbh->getScalar('SELECT max(' . $orderColumn . ') as max_order_num FROM ' . $this->getTableName() . ' WHERE `' . $pk . '` IS NULL AND session_id = %s ', session_id()); } $new_order_num = !$new_order_num ? 1 : $new_order_num + 1; $this->addFilterCondition([$this->getPK() . '=' . $result]); $request = 'UPDATE ' . $this->getTableName() . ' SET ' . $orderColumn . ' = %s ' . $this->dbh->buildWhereCondition($this->getFilter()); $this->dbh->modify($request, $new_order_num); } return $result; }
/** * Create data description. * * @return DataDescription */ protected function createDataDescription() { $result = new DataDescription(); if (!$this->getConfig()->getCurrentStateConfig()) { $f = new FieldDescription('lang_id'); $f->setType(FieldDescription::FIELD_TYPE_INT); $result->addFieldDescription($f); $f = new FieldDescription('lang_abbr'); $f->setType(FieldDescription::FIELD_TYPE_STRING); $result->addFieldDescription($f); $f = new FieldDescription('lang_name'); $f->setType(FieldDescription::FIELD_TYPE_STRING); $result->addFieldDescription($f); $f = new FieldDescription('lang_url'); $f->setType(FieldDescription::FIELD_TYPE_STRING); $result->addFieldDescription($f); $f = new FieldDescription('lang_real_abbr'); $f->setType(FieldDescription::FIELD_TYPE_STRING); $result->addFieldDescription($f); } else { $result->loadXML($this->getConfig()->getCurrentStateConfig()->fields); } return $result; }
/** * Save data. * @return mixed * @throws SystemException 'ERR_NO_ACTION' * @throws SystemException 'ERR_VALIDATE_FORM' */ protected function saveData() { $result = false; //если в POST не пустое значение значение первичного ключа - значит мы находимся в режиме редактирования if (isset($_POST[$this->getTableName()][$this->getPK()]) && !empty($_POST[$this->getTableName()][$this->getPK()])) { $mode = self::COMPONENT_TYPE_FORM_ALTER; $this->setFilter([$this->getPK() => $_POST[$this->getTableName()][$this->getPK()]]); } else { $mode = self::COMPONENT_TYPE_FORM_ADD; } //создаем объект описания данных $dataDescriptionObject = new DataDescription(); if (!method_exists($this, $this->getPreviousState())) { throw new SystemException('ERR_NO_ACTION', SystemException::ERR_CRITICAL); } //получаем описание полей для метода $configDataDescription = $this->getConfig()->getStateConfig($this->getPreviousState()); //если в конфиге есть описание полей для метода - загружаем их if (isset($configDataDescription->fields)) { $dataDescriptionObject->loadXML($configDataDescription->fields); } //Создаем объект описания данных взятых из БД $DBDataDescription = new DataDescription(); //Загружаем в него инфу о колонках $DBDataDescription->load($this->loadDataDescription()); $this->setDataDescription($dataDescriptionObject->intersect($DBDataDescription)); //Поле с порядком следования убираем из списка /** * @todo Надо бы это как то переделать, потому что разбросано получилось * часть кода относящаяся к обработке колонки с нумерацией здесь, часть * @see Grid::createDataDescription */ if (($col = $this->getOrderColumn()) && ($field = $this->getDataDescription()->getFieldDescriptionByName($col))) { $this->getDataDescription()->removeFieldDescription($field); } $dataObject = new Data(); $dataObject->load($this->loadData()); $this->setData($dataObject); //Создаем сейвер $saver = $this->getSaver(); //Устанавливаем его режим $saver->setMode($mode); $saver->setDataDescription($this->getDataDescription()); $saver->setData($this->getData()); if ($saver->validate() === true) { $saver->setFilter($this->getFilter()); $saver->save(); $result = $saver->getResult(); } else { //выдвигается exception который перехватывается в методе save throw new SystemException('ERR_VALIDATE_FORM', SystemException::ERR_WARNING, $this->saver->getErrors()); } //Если у нас режим вставки и определена колонка для порядка следования, изменяем порядок следования if (($orderColumn = $this->getOrderColumn()) && $mode == self::COMPONENT_TYPE_FORM_ADD) { $this->addFilterCondition([$this->getPK() . '!=' . $result]); $request = 'UPDATE ' . $this->getTableName() . ' SET ' . $orderColumn . '=' . $orderColumn . '+1 ' . $this->dbh->buildWhereCondition($this->getFilter()); $this->dbh->modify($request); } return $result; }
/** * Create data description. * * @return DataDescription * * @throws SystemException 'ERR_DEV_LOAD_DATA_DESCR_IS_FUNCTION' */ protected function createDataDescription() { // описание данных из конфигурации $configDataDescriptionObject = new DataDescription(); if ($this->getConfig()->getCurrentStateConfig()) { $configDataDescriptionObject->loadXML($this->getConfig()->getCurrentStateConfig()->fields); } // внешнее описание данных $externalDataDescription = $this->loadDataDescription(); if (is_null($externalDataDescription)) { throw new SystemException('ERR_DEV_LOAD_DATA_DESCR_IS_FUNCTION', SystemException::ERR_DEVELOPER); } // если существует внешнее описание данных - пересекаем с описанием из конфиг if ($externalDataDescription) { $externalDataDescriptionObject = new DataDescription(); $externalDataDescriptionObject->load($externalDataDescription); $configDataDescriptionObject = $configDataDescriptionObject->intersect($externalDataDescriptionObject); } return $configDataDescriptionObject; }
/** * Save data. * * @param array $data Data. * @return mixed * * @throws SystemException 'ERR_VALIDATE_FORM' */ protected function saveData(&$data) { //Обрабатываем аплоадсы $result = false; if (isset($_FILES) && !empty($_FILES)) { list($dbName, $tName) = QAL::getFQTableName($this->getTableName(), true); if (isset($_FILES[$phpTableName = $dbName . '_' . $tName])) { $fileData = []; //Переворачиваем пришедший массив в удобный для нас вид foreach ($_FILES[$phpTableName] as $fParam => $fileInfo) { foreach ($fileInfo as $fName => $val) { $fileData[$fName][$fParam] = $val; } } $uploader = new FileUploader(); foreach ($fileData as $fieldName => $fileInfo) { //Завантажувати лише якщо файл дійсно завантажили if (!empty($fileInfo['name']) && $fileInfo['size'] > 0) { $uploader->setFile($fileInfo); $uploader->upload('uploads/forms'); $data[$this->getTableName()][$fieldName] = $uploader->getFileObjectName(); $uploader->cleanUp(); } } } } //создаем объект описания данных $dataDescriptionObject = new DataDescription(); //получаем описание полей для метода $configDataDescription = $this->getConfig()->getStateConfig($this->getPreviousState()); //если в конфиге есть описание полей для метода - загружаем их if (isset($configDataDescription->fields)) { $dataDescriptionObject->loadXML($configDataDescription->fields); } //Создаем объект описания данных взятых из БД $DBDataDescription = new DataDescription(); //Загружаем в него инфу о колонках $DBDataDescription->load($this->loadDataDescription()); $this->setDataDescription($dataDescriptionObject->intersect($DBDataDescription)); $this->getDataDescription()->getFieldDescriptionByName('form_date')->removeProperty('pattern'); $dataObject = new Data(); foreach ($data[$this->getTableName()] as $key => $value) { if (is_scalar($value)) { $data[$this->getTableName()][$key] = strip_tags($value); } } $dataObject->load($data); $this->setData($dataObject); //Создаем сейвер $this->saver = new Saver(); //Устанавливаем его режим $this->saver->setMode(self::COMPONENT_TYPE_FORM_ADD); $this->saver->setDataDescription($this->getDataDescription()); $this->saver->setData($this->getData()); if ($this->saver->validate() === true) { $this->saver->setFilter($this->getFilter()); $this->saver->save(); $result = $this->saver->getResult(); } else { //выдвигается пустой exception который перехватывается в методе save //выдвигается exception который перехватывается в методе save throw new SystemException('ERR_VALIDATE_FORM', SystemException::ERR_WARNING, $this->saver->getErrors()); } return $result; }