PHP-скрипт анализирует контент из RTE (tt_news), но внутренние ссылки не отображаются как говорящие URL

У меня есть новостная статья с внутренними ссылками. В RTE я вижу ссылки вроде

http://www.yourdomain.com/?id=3

в текстовом режиме HTML. Проблема в том, что эта ссылка также появляется на веб-интерфейсе. RealURL должен преобразовать эту ссылку во что-то вроде

http://www.yourdomain.com/products/

Содержание RTE в настоящее время анализируется следующим образом

$parseObj = t3lib_div::makeInstance('t3lib_parsehtml_proc'); 
$txt = $parseObj->TS_links_rte($result['bodytext']);
$txt = $parseObj->TS_transform_rte($txt);

Я прочитал, что я должен использовать что-то вроде этого

$pObj = t3lib_div::makeInstance('tslib_pibase');
$txt = $pObj->pi_RTEcssText($result['bodytext']);

но я не знаю, как я могу получить доступ к этой функции. я получил

Fatal error: Call to a member function parseFunc() on a non-object in /home/myuser/www/home/typo3/sysext/cms/tslib/class.tslib_pibase.php on line 1384

Как правильно это сделать? Как я могу получить доступ к функции pi_RTEcssText? Должен ли я использовать класс? Есть ли другие способы сделать это без класса?

РЕДАКТИРОВАТЬ:

Я создал новый шаблон с TemplaVoila и определил lib.newscontent как путь объекта TS.

TS Основной Шаблон

includeLibs.user_news = fileadmin/templates/php_scripts/news/class.news.php

lib.newscontent = USER_INT
lib.newscontent {
  userFunc = user_news->main
  userFunc.bodytext.parseFunc < lib.parseFunc_RTE
}  

class.news.php

<?

class user_news {

    var $cObj;

    private $conf;

    function main($content,$conf) {
        $this->conf = $conf; 
        $this->setPreferences();        
        $content .= $this->aktuelleNews();

        return $content;
    }

    private function aktuelleNews() {
        $res = $GLOBALS['TYPO3_DB']->exec_SELECTquery(
                '*',         // SELECT ...
                'tt_news',     // FROM ...
                'pid=22 AND deleted=0 AND hidden=0',    // WHERE...
                '',            // GROUP BY...
                'datetime DESC'    // ORDER BY...
        );

        $i = 1;
        $out_list = '<ul id="news">';
        while ($data = $GLOBALS['TYPO3_DB']->sql_fetch_assoc($res)) {
            $date = date("d.m.Y",$data['datetime']);
            $out_list .= '<li><a href="#section'.$i.'">'.$date.': '.$data['title'].'</a></li>';
            $out_detail.= $this->outputnewsdetail($data,$i);

            $i++;
        }
        $out_list .= '</ul>';
        return $out_list . $out_detail;
    }

    private function outputnewsdetail($result,$count){
        $this->cObj->start($result, 'tt_news');

        $bodytext = $this->cObj->stdWrap($result['bodytext'], $this->conf['bodytext']);
        $bodytext = $this->cObj->parseFunc($bodytext,$GLOBALS['TSFE']->tmpl->setup['lib.']['parseFunc_RTE.']);

        return $bodytext;

    }

    private function setPreferences() {

    }

}
?>

localconf.php

include(PATH_site.'fileadmin/templates/php_scripts/news/class.news.php');

Оставшийся вопрос

Почему часть рендеринга в основном шаблоне TS не работает? я использовал

$this->cObj->parseFunc($bodytext,$GLOBALS['TSFE']->tmpl->setup['lib.']['parseFunc_RTE.']);

чтобы получить мой результат.

1 ответ

Решение

Я бы предпочел:

$txt = $this->cObj->stdWrap($result['bodytext'], $this->conf['bodytext.']);

Вам нужен ваш основной метод: $this->conf = $conf;

В вашем TypoScript добавьте parseFunc в bodytext:

 plugin.tx_yourplugin_pi1 {
    bodytext.parseFunc < lib.parseFunc_RTE
 }

Основная идея заключается в использовании обычного parseFunc, который используется элементами содержимого. Так что у вас одинаковый рендеринг. Другое преимущество заключается в том, что ваше приложение более гибкое.

Просто как примечание. Для этого стоит сделать локальный cObj и передать полные данные. Таким образом, вы можете использовать все поля в TypoScript. Например, поле = bodytext в вашем случае.

# create lokal cObj - do not override the original data!
$cObj = t3lib_div::makeInstance('tslib_cObj');
foreach ($row = ...) {
   # override data array with row. Every field in $row is now accesible via 
   # TypoScript field = fieldname
   $cObj->start($row, $tableName);
   $content .= $cObj->stdWrap($row['bodytext'], $this->conf['bodytext.']);
}

# TS Setup:
# in your case you could do somesthing like:
plugin.tx_yourplugin_pi1 {
    bodytext.parseFunc < lib.parseFunc_RTE
    bodytext.wrap = <div class="hide">|</div>
    bodytext.prepend = TEXT
    bodytext.prepend.field = bodytext
    bodytext.prepend.stripHtml = 1
    bodytext.prepend.crop = 30 | ... | 1
    bodytext.prepend.wrap = <span title="|" onclick="showBodytext()">info</span>
}

Если вам это нужно в пользовательской функции, попробуйте это так:

function user_yourfunction($content,$conf) {
    $result = *magic*
    $cObj = t3lib_div::makeInstance('tslib_cObj');
    $cObj->start($result, 'your table name');
    return $cObj->stdWrap($result['bodytext'], $conf['bodytext.']);
}

В TypoScript:

includeLibs.something = media/scripts/example_callfunction.php
page.10 = TEXT
page.10 {
   value = Hello World
   postUserFunc = user_yourfunction
   postUserFunc.bodytext.parseFunc < lib.parseFunc_RTE
}
Другие вопросы по тегам