条件付きRequireJs構成(requirejs-config.jsをプログラムでロードしますか?)


14

特定の条件(たとえば、構成に基づいて)でのみRequireJsコンポーネントを置き換えたいと思います。プログラムでモジュールの読み込みを防ぐ方法requirejs-config.jsや、それを実現する別の方法はありますか?


1
この問題の解決策を見つけましたか?
-stevensagaar

@stevensagaar残念ながらそうではありません
ファビアンシュメングラー

2
見つかった場合は、ここに答えを追加します
ファビアンシュメングラー

3
@Alex 2.2または2.3の解決策があれば、私も喜んでいます:Dがタグを更新しました。また、賞金に感謝します!
ファビアンシュメングラー

2
あなたは、ベンダー/ Magentoの/フレームワーク/ RequireJsでGETCONFIG機能を書き換え/ config.phpのか、requirejsでプラグインを作成する必要がありますしようとした必要がありrequirejs.org/docs/plugins.html
Arshad M

回答:


4

@Arshad Mコメントに基づいて、次を使用してdi.xmlを追加できます。

    <?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">

    <preference for="Magento\Framework\RequireJs\Config" type="<Vendor>\<ModuleName>\RequireJs\Config"/>

</config>

また、<Vendor> \ <ModuleName> \ RequireJs \ Config.phpで、getConfig関数をオーバーライドして、requirejsをロードしたくない条件とモジュール名を追加します(おそらくScopeConfigInterfaceから):

   <?php

namespace <Vendor>\<ModuleName>\RequireJs;

use Magento\Framework\Filesystem\File\ReadFactory;
use Magento\Framework\View\Asset\Minification;
use Magento\Framework\View\Asset\RepositoryMap;

class Config extends \Magento\Framework\RequireJs\Config
{
    /**
     * @var \Magento\Framework\RequireJs\Config\File\Collector\Aggregated
     */
    private $fileSource;
    /**
     * @var ReadFactory
     */
    private $readFactory;
    /**
     * @var \Magento\Framework\Code\Minifier\AdapterInterface
     */
    private $minifyAdapter;
    /**
     * @var Minification
     */
    private $minification;
    /**
     * @var \Magento\Framework\View\DesignInterface
     */
    private $design;

    public function __construct(\Magento\Framework\RequireJs\Config\File\Collector\Aggregated $fileSource, \Magento\Framework\View\DesignInterface $design, ReadFactory $readFactory, \Magento\Framework\View\Asset\Repository $assetRepo, \Magento\Framework\Code\Minifier\AdapterInterface $minifyAdapter, Minification $minification, RepositoryMap $repositoryMap)
    {
        parent::__construct($fileSource, $design, $readFactory, $assetRepo, $minifyAdapter, $minification, $repositoryMap);
        $this->fileSource = $fileSource;
        $this->readFactory = $readFactory;
        $this->minifyAdapter = $minifyAdapter;
        $this->minification = $minification;
        $this->design = $design;
    }

    public function getConfig()
    {
        $distributedConfig = '';
        $customConfigFiles = $this->fileSource->getFiles($this->design->getDesignTheme(), self::CONFIG_FILE_NAME);
        foreach ($customConfigFiles as $file) {
            //Your condition
            if(true){
                if($file->getModule() == "Vendor_ModuleName"){
                    continue;
                }
            }

            /** @var $fileReader \Magento\Framework\Filesystem\File\Read */
            $fileReader = $this->readFactory->create($file->getFileName(), \Magento\Framework\Filesystem\DriverPool::FILE);
            $config = $fileReader->readAll($file->getName());


            $distributedConfig .= str_replace(
                ['%config%', '%context%'],
                [$config, $file->getModule()],
                self::PARTIAL_CONFIG_TEMPLATE
            );
        }

        $fullConfig = str_replace(
            ['%function%', '%usages%'],
            [$distributedConfig],
            self::FULL_CONFIG_TEMPLATE
        );


        if ($this->minification->isEnabled('js')) {
            $fullConfig = $this->minifyAdapter->minify($fullConfig);
        }

        return $fullConfig;
    }
}

更新

@Alexおよび@Danielからのコメントの後:getentosのAfterプラグインをMagento \ Framework \ RequireJs \ Config \ File \ Collector \ Aggregatedから作成できるため、このアプローチでの新しいdi.xmlは次のようになります。

 <?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:noNamespaceSchemaLocation="urn:magento:framework:ObjectManager/etc/config.xsd">

    <type name="Magento\Framework\RequireJs\Config\File\Collector\Aggregated">
        <plugin name="requirejsConfigPlugin"
                type="<Vendor>\<ModuleName>\Plugin\RequireJs\AfterFiles"
                sortOrder="100"
        />
    </type>
</config>

そして、\ <Vendor> \ <ModuleName> \ Plugin \ RequireJs \ AfterFilesで、requirejsがロードされない条件とモジュールを設定できます。

<?php

namespace <Vendor>\<ModuleName>\Plugin\RequireJs;

class AfterFiles
{
    public function afterGetFiles(
        \Magento\Framework\RequireJs\Config\File\Collector\Aggregated $subject,
        $result
    ){
        //Your condition
        if(true) {
            foreach ($result as $key => &$file) {
                //Module to exclude
                if ($file->getModule() == "Vendor_OtherModuleName") {
                    unset($result[$key]);
                }
            }
        }
        return $result;
    }
}

いいね!$ fullConfig = parent :: getConfig()でそれを改善し、次に$ fullConfigを変更してより少ないコードをコピーして貼り付けることができると思います。どう思いますか?たぶんこれのためにGitHubでミニFOSSモジュールを作成する必要がありますか?
アレックス

1
または、代わりに$ this-> fileSource-> getFilesを書き換えることができますか?...多くのコードをコピーしていないだけに
アレックス

3
あなたにもプラグインを使用して使用することができ@Alex aroundGetConfig()afterGetConfig()、我々はそれを上書きする必要はありません、条件付きロードをachiveするためのメソッドを
ダニエル

有望に見えます、ありがとう!私はすでに賛成しました、答えを受け入れる前にできるだけ早く試してみます
ファビアンシュメングラー

2
@Alexはあなたの提案に続いて、githubで小さなモジュールを作成しました。このモジュールでは、magentoバックエンドを介してrequirejsを無効にするモジュールを選択できます。github.com/MNGemignani/magento2_requirejs_disable
gemig_hol
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.