Como adiciono um artigo ao #__content do meu componente?

11

Meu componente precisa adicionar artigos do front-end de maneira não convencional. Sei que posso inseri-los no MySQL, mas gostaria de usar as funções principais para fazê-lo (se possível).

Tendo estudado o código em components \ com_content, estou um pouco impressionado com tudo o que precisa acontecer e esperava que estivesse apenas complicando demais.

Existem exemplos disso no Joomla, ou uma convenção de etapas a serem seguidas para alcançá-lo?

Al Knight
fonte

Respostas:

6

Abra o arquivo de modelo e adicione estas linhas dentro da classe de modelo:

public function getContentTable($type = 'Content', $prefix = 'JTable', $config = array())
{
    return JTable::getInstance($type, $prefix, $config);
}

Agora você pode definir um método dentro da classe de modelo para adicionar um artigo. Algo assim:

public function addArticle()
{
    $table = $this->getContentTable();
    $table->title = "Foo";
    $table->alias = "foo";
    // or
    // $table->alias = JApplication::stringURLSafe($table->title);
    $table->catid = 2;
    $table->state = 1;
    // and so on!
    // then save it
    $table->save();
}
Farahmand
fonte
1

Eu também tive que carregar artigos de uma maneira não convencional. Eu era capaz de aproveitar muito do código do Joomla para isso. Você fez a necessidade de ajustar isso com base em suas necessidades.

Esta função retornará um artlice com um ID (numérico) ou um alias.

    function loadArticle($id){

            $app = JFactory::getApplication();
            $db = JFactory::getDBO();
            $query = $db->getQuery(true);
            $selects = array('a.introtext','a.publish_up','a.publish_down');
            $query->select($selects);
            $query->from('#__content as a');

            // select the alias or id
            $where = 'a.title = ' . $db->q(NNText::html_entity_decoder($id));
            $where .= ' OR a.alias = ' . $db->q(NNText::html_entity_decoder($id));
            if (is_numeric($id)) {
                    $where .= ' OR a.id = ' . $id;
            }

            $query->where('(' . $where . ')');

            // check the publish and unpublish dates
            $now = JFactory::getDate('now','UTC');
            $nullDate = $db->getNullDate();

            $query->where('a.state = 1');

            $query->where('( a.publish_up = ' . $db->q($nullDate) . ' OR a.publish_up <= ' . $db->q($now) . ' )');
            $query->where('( a.publish_down = ' . $db->q($nullDate) . ' OR a.publish_down >= ' . $db->q($now) . ' )');

            $db->setQuery($query);
            $article = $db->loadObject();
            return $article;
    }
Mudança de contexto
fonte
Isso parece um bom ponto de partida para obter um artigo, mas eu preciso adicionar um artigo ...
Al Knight
Desculpe, eu não
entendi #