Task #48383
Epic #55575: Streamline JavaScript Code in the TYPO3 Backend
RequireJS does not consider correct namespace prefix
Status: | Accepted | Start date: | 2013-05-19 | |
---|---|---|---|---|
Priority: | Should have | Due date: | ||
Assigned To: | - | % Done: | 0% |
|
Category: | Default | Spent time: | - | |
Target version: | 7.5 | |||
TYPO3 Version: | 6.1 | Complexity: | hard | |
PHP Version: | 5.3 | Sprint Focus: |
Description
My extension "mapping" uses these namespace prefixes in PHP "OliverHader\Mapping" (vendor, package).
However, the requireJS implementation in the PageRenderer ignores that and adds "TYPO3\CMS" as prefix.
The behaviour shall be the same as for PHP class files - the "\TYPO3\CMS" prefix is a special case for the Core only.
Related issues
History
#2 Updated by Daniel Siepmann over 1 year ago
The only thing I can implement at the moment is to remove the TYPO3 vender for external extensions. But I don't have any clue how to add the vendor for JS Files as it just exists inside PHP Files.
IF someone has an idea code it, or answer, so I can get into it.
#3 Updated by Benjamin Mack 15 days ago
- Assigned To set to Benjamin Mack
- Target version set to 7.4 (Backend)
- Sprint Focus set to Stabilization Sprint
#4 Updated by Mathias Brodala 12 days ago
You can manually add your prefix with the PageRenderer
hook render-preProcess
like this:
$pageRenderer->addRequireJsConfiguration([ 'paths' => [ 'Vendor/Package' => PathUtility::getRelativePath(PATH_typo3, GeneralUtility::getFileAbsFileName('EXT:package/Resources/Public/JavaScript/')), ], ]);
#5 Updated by Markus Klein 7 days ago
- Status changed from New to Rejected
- Assigned To deleted (
Benjamin Mack) - Target version deleted (
7.4 (Backend)) - Complexity changed from medium to hard
- Sprint Focus deleted (
Stabilization Sprint)
This is still private API of Core. To add you own modules you need to do it like this:
$fullJsPath = 'EXT:' . $this->extKey . '/Resources/Public/JavaScript/'; $fullJsPath = GeneralUtility::getFileAbsFileName($fullJsPath); $fullJsPath = PathUtility::getRelativePath(PATH_site, $fullJsPath); $fullJsPath = $tsfe->absRefPrefix . rtrim($fullJsPath, '/'); $pageRenderer->addRequireJsConfiguration([ 'paths' => [ 'Reelworx/MyExt' => $fullJsPath ] ]); $pageRenderer->loadRequireJsModule('Reelworx/MyExt/somemodule');
Making this API really versatile is a load of work and for sure no bug!
#6 Updated by Benjamin Mack 6 days ago
- Tracker changed from Bug to Task
- Status changed from Rejected to Accepted
- Target version set to 7.5
ok. but we should "do it right" for 7.5 then.