Beispiel #1
0
 /**
  * Cache method to populate auto-complete options
  *
  * @param   plgFabrik_Element $elementModel Element model
  * @param   string            $search       Search string
  * @param   array             $opts         Options, 'label' => field to use for label (db join)
  *
  * @since   3.0.7
  *
  * @return string  json encoded search results
  */
 public static function cacheAutoCompleteOptions($elementModel, $search, $opts = array())
 {
     $listModel = $elementModel->getListModel();
     $table = $listModel->getTable();
     $db = $listModel->getDb();
     $name = $elementModel->getFullName(false, false);
     $query = $db->getQuery(true);
     $params = $elementModel->getParams();
     $format = $params->get('date_table_format');
     $elementModel->strftimeTFormatToMySQL($format);
     $search = $db->quote('%' . addslashes($search) . '%');
     $query->select('DISTINCT(' . $name . ') AS value, ' . $name . ' AS text')->from($table->db_table_name)->where($name . ' LIKE ' . $search . ' OR DATE_FORMAT(' . $name . ', "' . $format . '" ) LIKE ' . $search);
     $db->setQuery($query);
     $tmp = $db->loadObjectList();
     $ddData = array();
     foreach ($tmp as &$t) {
         $elementModel->toLabel($t->text);
         if (!array_key_exists($t->text, $ddData)) {
             $ddData[$t->text] = $t;
         }
     }
     $ddData = array_values($ddData);
     echo json_encode($ddData);
 }
Beispiel #2
0
 /**
  * Cache method to populate autocomplete options
  *
  * @param   plgFabrik_Element  $elementModel  element model
  * @param   string             $search        serch string
  *
  * @since   3.0.7
  *
  * @return string  json encoded search results
  */
 public static function cacheAutoCompleteOptions($elementModel, $search)
 {
     $name = $elementModel->getFullName(false, false, false);
     $elementModel->encryptFieldName($name);
     $listModel = $elementModel->getListModel();
     $db = $listModel->getDb();
     $query = $db->getQuery(true);
     $tableName = $listModel->getTable()->db_table_name;
     $query->select('DISTINCT(' . $name . ') AS value, ' . $name . ' AS text')->from($tableName);
     $query->where($name . ' LIKE ' . $db->quote(addslashes('%' . $search . '%')));
     $query = $listModel->_buildQueryJoin($query);
     $query = $listModel->_buildQueryWhere(false, $query);
     $query = $listModel->pluginQuery($query);
     $db->setQuery($query);
     $tmp = $db->loadObjectList();
     foreach ($tmp as &$t) {
         $elementModel->toLabel($t->text);
     }
     return json_encode($tmp);
 }