简体   繁体   English

TYPO3 Fluid v:page.languageMenu和tx_news

[英]TYPO3 fluid v:page.languageMenu and tx_news

When i need a language switcher, I usually use TypoScrict like this 当我需要语言切换器时,我通常会像这样使用TypoScrict

lib.langnav >
lib.langnav = HMENU
lib.langnav {   
  wrap = <ul>|ul
  special = language
  special.value = 0,1,3
  special.normalWhenNoLanguage = 0
    1 = TMENU
    1 {

    noBlur = 1
    NO = 1
    NO {
      additionalParams.cObject = COA
      additionalParams.cObject {
      5 = TEXT
      5.wrap = &L=1

Then I add tx_news controller and action to get translation url for news item on detail page: 然后,我添加tx_news控制器和操作以在详细信息页面上获取新闻项的翻译网址:

  10 = TEXT
  10.data = GP:tx_news_pi1|news
  10.wrap = &tx_news_pi1[news]=|
  10.required = 1

  20 = TEXT
  20.data = GP:tx_news_pi1|controller
  20.wrap = &tx_news_pi1[controller]=|
  20.required = 1

  30 = TEXT
  30.data = GP:tx_news_pi1|action
  30.wrap = &tx_news_pi1[action]=|
  30.required = 1

... and other standard things. ...和其他标准的东西。

Now when I work with FLUID, I have: 现在,当我使用FLUID时,我有:

    <v:page.languageMenu class="language-menu"
                         defaultIsoFlag="{settings.config.defaultIsoFlag}"
                         defaultLanguageLabel="{settings.config.defaultLanguageLabel}"
                         tagName="ul"
                         tagNameChildren="li"
                         linkCurrent="0"
                         as="languageMenu"
                         hideNotTranslated="1"
                         classCurrent="'current'"> ... </v:page.languageMenu>

How can I add the tx_news controller and action (make translation url for news detail pages) in fluid lang.menu ? 我怎么可以添加tx_news在流体控制器和行动(让新闻详细信息页面的翻译URL) lang.menu

I find just one solution - overwrite default View Helper for added QueryString in url. 我发现只有一种解决方案-覆盖url中添加的QueryString的默认View Helper。 In my extension (Fluid Theme) typo3conf/ext/huskytheme/Classes/ViewHelpers/Page/LanguageMenuViewHelper.php 在我的扩展名(Fluid Theme)中,typo3conf / ext / huskytheme / Classes / ViewHelpers / Page / LanguageMenuViewHelper.php

<?php
namespace HIT\Huskytheme\ViewHelpers\Page;


class LanguageMenuViewHelper extends \FluidTYPO3\Vhs\ViewHelpers\Page\LanguageMenuViewHelper {

        protected function getLanguageUrl($uid) {
        $excludedVars = trim((string) $this->arguments['excludeQueryVars']);
        $config = array(
            'parameter' => $this->getPageUid(),
            'returnLast' => 'url',
            'additionalParams' => '&L=' . $uid,
            'useCacheHash' => $this->arguments['useCHash'],
            'addQueryString' => true,
            'addQueryString.' => array(
                                'method' => 'GET',
                'exclude' => 'id,L,cHash' . ($excludedVars ? ',' . $excludedVars : '')
            )
        );
        if (TRUE === is_array($this->arguments['configuration'])) {
            $config = $this->mergeArrays($config, $this->arguments['configuration']);
        }
        return $this->cObj->typoLink('', $config);
    }

}

and in template 并在模板中

{namespace hit=HIT\Huskytheme\ViewHelpers}
...
<f:section name="LanguageMenu">
    {v:variable.typoscript(path: 'plugin.tx_huskytheme.settings') -> v:variable.set(name: 'settings' )}

    <v:variable.set name="currentlang" value="{v:page.language(normalWhenNoLanguage: 0)}" />

    <div class="lang  pull-right"> 

        <hit:page.languageMenu 
            defaultLanguageLabel="{settings.config.defaultLanguageLabel}"
            linkCurrent="0"
            as="languageMenu"
            hideNotTranslated="1"
            classCurrent="'current'"
            >

            <v:variable.set name="langcount" value="{languageMenu -> f:count()}" />

            <f:if condition="{langcount > 1}">
                <f:then>
                    <ul class="navlang">
                        <f:for each="{languageMenu}" as="item" iteration="iteration">
                            <f:if condition="{item.current}">
                                <f:then>
                                    <li class="active">
                                        <span>{item.label}</span>
                                    </li>
                                </f:then>
                                <f:else>
                                    <li class="{f:if(condition: iteration.isLast, then: 'last')}">
                                        <a href="{item.url}">{item.label}</a>
                                    </li>
                                </f:else>
                            </f:if>
                        </f:for>
                    </ul>  

                </f:then>
            </f:if>
            </hit:page.languageMenu>

    </div>
</f:section>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM