Project

General

Profile

Actions

Feature #102815

closed

Support ApplicationContext in TypoScript data/getText (.if)

Added by Daniel Siepmann 11 months ago. Updated 10 months ago.

Status:
Closed
Priority:
Should have
Assignee:
-
Category:
TypoScript
Target version:
-
Start date:
2024-01-11
Due date:
% Done:

100%

Estimated time:
PHP Version:
Tags:
Complexity:
Sprint Focus:

Description

TypoScript already supports ApplicationContext within Conditions, see: #50132
But the context is not yet exposed via data/getText: https://docs.typo3.org/m/typo3/reference-typoscript/main/en-us/Functions/Data.html

This would enable to use this within `.if` conditions as well and streamline integrator experience.

Actions #1

Updated by Daniel Siepmann 11 months ago

Our current workaround looks like:

<?php

declare(strict_types=1);

/*
 * Copyright (C) 2024 Daniel Siepmann <coding@daniel-siepmann.de>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 * 02110-1301, USA.
 */

namespace Codappix\SiteCodappix\Hooks;

use TYPO3\CMS\Core\Core\Environment;
use TYPO3\CMS\Frontend\ContentObject\ContentObjectGetDataHookInterface;
use TYPO3\CMS\Frontend\ContentObject\ContentObjectRenderer;

final class ContentObjectRendererGetData implements ContentObjectGetDataHookInterface
{
    public function getDataExtension(
        $getDataString,
        array $fields,
        $sectionValue,
        $returnValue,
        ContentObjectRenderer &$parentObject
    ) {
        if ($getDataString !== 'applicationContext') {
            return $returnValue;
        }

        return Environment::getContext()->__toString();
    }

    public static function register(): void
    {
        $GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['tslib/class.tslib_content.php']['getData'][self::class] = self::class;
    }
}

Call the register method within ext_localconf.php

Usage in TypoScript:

page = PAGE
page {
    includeJSFooter {
        tracking = EXT:site_codappix/Resources/Public/Assets/Scripts/tracking.js
        tracking.if {
            value.data = applicationContext
            equals = Production
        }
    }
}
Actions #2

Updated by Daniel Siepmann 11 months ago

  • Tracker changed from Bug to Feature
  • TYPO3 Version deleted (12)
Actions #3

Updated by Gerrit Code Review 11 months ago

  • Status changed from New to Under Review

Patch set 1 for branch main of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/c/Packages/TYPO3.CMS/+/82431

Actions #4

Updated by Gerrit Code Review 11 months ago

Patch set 2 for branch main of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/c/Packages/TYPO3.CMS/+/82431

Actions #5

Updated by Gerrit Code Review 11 months ago

Patch set 3 for branch main of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/c/Packages/TYPO3.CMS/+/82431

Actions #6

Updated by Gerrit Code Review 10 months ago

Patch set 4 for branch main of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/c/Packages/TYPO3.CMS/+/82431

Actions #7

Updated by Gerrit Code Review 10 months ago

Patch set 5 for branch main of project Packages/TYPO3.CMS has been pushed to the review server.
It is available at https://review.typo3.org/c/Packages/TYPO3.CMS/+/82431

Actions #8

Updated by Daniel Siepmann 10 months ago

  • Status changed from Under Review to Resolved
  • % Done changed from 0 to 100
Actions #9

Updated by Benni Mack 10 months ago

  • Status changed from Resolved to Closed
Actions

Also available in: Atom PDF