Example #1
0
 /** Создание новых и удаление удаленных полей из таблицы
  * @param $context
  * @param $table
  * @param bool $isNew
  * @return bool
  * @throws Exception
  */
 public function onExtensionAfterSave($context, $table, $isNew = false)
 {
     if ($context !== 'com_plugins.plugin' || $table->element != 'minicck') {
         return true;
     }
     $params = json_decode($table->params);
     $customfields = $params->customfields;
     if (!is_array($customfields) || count($customfields) == 0) {
         throw new Exception('Custom Fields is Empty');
         return false;
     }
     $newColumn = $oldColumn = array();
     $db = JFactory::getDbo();
     $table = $db->replacePrefix('#__minicck');
     $query = $db->getQuery(true);
     $query->select('COLUMN_NAME')->from('INFORMATION_SCHEMA.COLUMNS')->where('TABLE_NAME = ' . $db->quote($table));
     $db->setQuery($query);
     $columns = $db->loadColumn();
     if (!is_array($columns) || count($columns) == 0) {
         throw new Exception('Table Columns is Empty');
         return false;
     }
     include_once JPATH_ROOT . '/plugins/system/minicck/classes/html.class.php';
     $minicck = MiniCCKHTML::getInstance(self::$customfields);
     $flipColumns = array_flip($columns);
     //удаляем из массива служебные поля
     if (isset($flipColumns['id'])) {
         unset($columns[$flipColumns['id']]);
     }
     if (isset($flipColumns['content_id'])) {
         unset($columns[$flipColumns['content_id']]);
     }
     if (isset($flipColumns['field_values'])) {
         unset($columns[$flipColumns['field_values']]);
     }
     if (isset($flipColumns['content_type'])) {
         unset($columns[$flipColumns['content_type']]);
     }
     //формируем новые и удаленные поля
     foreach ($customfields as $k => $v) {
         if (!in_array($v->name, $columns)) {
             $tmp = array('name' => $v->name, 'type' => $v->type);
             $classname = $minicck->loadElement($tmp);
             $tmp['columnType'] = !empty($classname::$columnType) ? $classname::$columnType : 'varchar(250)';
             $newColumn[] = $tmp;
         } else {
             unset($columns[$flipColumns[$v->name]]);
         }
     }
     //если есть новые поля, то создаем
     if (count($newColumn)) {
         foreach ($newColumn as $v) {
             $db->setQuery('ALTER IGNORE TABLE `#__minicck` ADD `' . $v['name'] . '` ' . $v['columnType'] . ' NOT NULL')->execute();
         }
     }
     //если есть удаленные поля, то удаляем
     if (count($columns)) {
         foreach ($columns as $v) {
             $db->setQuery('ALTER IGNORE TABLE `#__minicck` DROP `' . $v . '`')->execute();
         }
     }
     return true;
 }
Example #2
0
 /**
  * Метод для обновления компонента.
  *
  * @param   object  $parent  Класс, который вызывает этом метод.
  *
  * @return  void
  */
 public function update($parent)
 {
     $plugin = JPluginHelper::getPlugin('system', 'minicck');
     $params = json_decode($plugin->params);
     $customfields = $params->customfields;
     if (is_array($customfields) && count($customfields) > 0) {
         $newColumn = array();
         $db = JFactory::getDbo();
         $table = $db->replacePrefix('#__minicck');
         $query = $db->getQuery(true);
         $query->select('COLUMN_NAME')->from('INFORMATION_SCHEMA.COLUMNS')->where('TABLE_NAME = ' . $db->quote($table));
         $db->setQuery($query);
         $columns = $db->loadColumn();
         if (!is_array($columns) || count($columns) == 0 || !in_array('field_values', $columns)) {
             return;
         }
         include_once JPATH_ROOT . '/plugins/system/minicck/classes/html.class.php';
         $minicck = MiniCCKHTML::getInstance(array());
         $flipColumns = array_flip($columns);
         //удаляем из массива служебные поля
         unset($columns[$flipColumns['id']], $columns[$flipColumns['content_id']], $columns[$flipColumns['field_values']]);
         $db->setQuery('ALTER IGNORE TABLE `#__minicck` ADD `content_type` varchar(50) NOT NULL')->execute();
         //формируем новые и удаленные поля
         foreach ($customfields as $v) {
             if (!in_array($v->name, $columns)) {
                 $tmp = array('name' => $v->name, 'type' => $v->type);
                 $classname = $minicck->loadElement($tmp);
                 $tmp['columnType'] = !empty($classname::$columnType) ? $classname::$columnType : 'varchar(250)';
                 $newColumn[] = $tmp;
                 $db->setQuery('ALTER IGNORE TABLE `#__minicck` ADD `' . $v->name . '` ' . $tmp['columnType'] . ' NOT NULL')->execute();
             }
         }
         //запрашиваем все данные
         $query = $db->getQuery(true);
         $query->select('*')->from('`#__minicck`');
         $data = $db->setQuery($query)->loadObjectList();
         if (!$data || !is_array($data) || !count($data)) {
             return;
         }
         //очищаем таблицу
         $query = "TRUNCATE `#__minicck`";
         $db->setQuery($query);
         $db->execute();
         foreach ($data as $v) {
             $values = (array) json_decode($v->field_values);
             $object = new stdClass();
             $object->content_id = $v->content_id;
             $object->content_type = $values['content_type'];
             foreach ($newColumn as $column) {
                 $columnName = $column['name'];
                 if (isset($values[$columnName])) {
                     $value = $values[$columnName];
                     $classname = $minicck->loadElement($column);
                     if (method_exists($classname, 'prepareToSaveValue')) {
                         $value = $classname::prepareToSaveValue($value);
                     } else {
                         $value = is_array($value) ? implode(',', $value) : $value;
                     }
                     $object->{$columnName} = $value;
                 }
             }
             $db->insertObject('#__minicck', $object);
         }
         $db->setQuery('ALTER IGNORE TABLE `#__minicck` DROP `field_values`')->execute();
     }
 }