Вход

Просмотр полной версии : Как получить значение из TS setup в php контроллере?


Илья
06.01.2012, 04:14
Привет, возникла необходимость немного изменить расширение (а ля tt_news), а именно получить значение для single страницы.

Имеем такую структуру в дереве:

Page1 (тут хранятся сами новости и есть шаблон TS setup) - PID 5
- Page2 (для single страницы) - PID 6

В TS setup Page1 нечто такое:
plugin.tx_extname_pi1.single_pid = 6

И соответственно для каждого экземпляра в базе есть значение pid - стр, на которой хранится эта новость.

В php обработчике могу получить значение pid для каждой из новости (для ссылки на single новость), примерно так:
$_link_conf = array(
'parameter' => $row['pid'],
)
а мне надо получить не само значение pid (в примере выше это 5), а значение plugin.tx_extname_pi1.single_pid со страницы с pid='pid'.
То есть в итоге получить в качестве 'parameter' = 6
Надеюсь, что не очень путано все объяснил.
Всем спасибо!..

dmartynenko
06.01.2012, 15:37
Можете описать задачу более высокого уровня?
Может попробовать видоизменить задачу и найти другое решение?

Так как что бы получить этот pid из любого места вам нужно:
1. инициализировать ядро TSFE
2. сделать вид что текущая страница #5
3. вызрать парсер TS скриптов, который соберет и "скомпилирует" все TS скрипты от 5 до корня сайта
4. потом в $TSFE->config[..] вы сможете найти нужное значение.

Но во-первых это медленно, во вторых если вы уже в режиме FE на странице скажем 7, то это и вовсе не получится.

Как инициализировать TSFE в режиме eID можете посмотреть тут: http://typo3.org/extensions/repository/view/pagepath/current/

Чаще всего для получения подобного single pid используют такой прием. Новость привязывается к категории, а в записи категории указывается pid станицы на которой должны показываться новости этой категории. Тогда получение single pid для новости сводится к одному дополнительному запросу к БД.
Если подойти со стороны БД, то можно придумать еще варианты - добавить специальное поле в pages и на странице 5 указать страницу 6 в этом поле.

Илья
06.01.2012, 17:50
Благодарю за ответ!
Действительно, новости НЕ привязаны к категориям, а просто хранятся в разных страницах. Самих категорий как-таковых нет...
Здесь не tt_news в чистом виде, и поэтому такие извращения и приходится использовать :(
По вашим пунктам 1-4 - похоже на правду, про скорость догадываюсь :(
Про страницу 7 не очень понял, думаю что все будет ок, т.к. структура страниц для всех продуктов одинакова, т.е. имеем
Page1 (тут хранятся сами новости и есть шаблон TS setup) - PID 5
- Page2 (для single страницы) - PID 6
Page3 (тут хранятся сами новости и есть шаблон TS setup) - PID 7
- Page4 (для single страницы) - PID 8
и так далее...
Доп. поле в БД - думаю что крайний вариант, т.к. не очень удобно будет редакторам сайта, да и правильнее указать это значение в родительской странице, а не во всех новостях...

dmartynenko
06.01.2012, 18:04
Страницу 7 я упомянул в том смысле, что если вы в FE на странице (7) другой ветки сайта (то есть не на странице 5 или 6, где нужный TS уже и так в TSFE), то инициализировать TSFE заново с другим pid вряд ли получиться.

И я как раз и пишу, что надо добавить на родительской странице настройку, а не в каждой новости:
добавить специальное поле в pages и на странице 5 указать страницу 6 в этом поле

Но если у вас такая четкая структура страниц "родитель со списком - один потомок для single", то id этого потомка легко найти по таблице pages.

А чем вызвана необходимость отдельной страницы для single в вашем случае? Ведь по наличию GET переменной в TYPO3 можно сделать все что угодно с TS шаблоном - вывести другой шаблон страницы, по другому его напонить, поменять режим tt_news с list на single и т.п.

Илья
06.01.2012, 18:10
А вот искать потомков в pages - это может быть выход!..
Отдельная страница для single -это то, что сразу пришло в голову и в принципе работает как надо.
Думаю, что через GET это можно было бы сделать более элегантно, но это заняло бы у меня больше времени...
Буду копать в сторону pages и получения данных из этой таблицы

Илья
09.01.2012, 04:51
dmartynenko
Действительно, через pages удалось добраться до нужных данных, как то так:

$pid_n = $row['pid'];
$single_pid_product = "SELECT uid FROM pages where pid='".$pid_n."'";
$result_select_url = mysql_query($single_pid_product);

Еще раз мерси за помощь!