一般的な考え方は、選択されたスコープをリクエストパラメータを通じて渡すことです。
製品の編集アクションと同じようなコードを使用する必要があると思います。
/** @var \Magento\Store\Model\StoreManagerInterface $storeManager */
$storeManager = $this->_objectManager->get('Magento\Store\Model\StoreManagerInterface');
$storeId = (int) $this->getRequest()->getParam('store', 0);
$store = $storeManager->getStore($storeId);
$storeManager->setCurrentStore($store->getCode());
この場合$store->getWebsiteId()
、実際の(選択された)WebサイトIDである必要があります。ただし、これは、標準のmagentoブロックと同じように機能するストアブロックを使用する場合にのみ実行できます(ストアスコープを選択するため)。
これは、デフォルトのストアビュー(id == 1)を選択した場合の例の結果です。
デフォルトのグローバルスコープの場合(すべてのストアビュー、ウェブサイトIDは0):
更新:
このようなメソッドをヘルパーに追加して、必要な場所で使用できます。
/**
* @var \Magento\Framework\App\State
*/
protected $state;
/**
* @var \Magento\Store\Model\StoreManagerInterface
*/
protected $storeManager;
/**
* Data constructor.
* @param Context $context
* @param \Magento\Framework\App\State $state
* @param \Magento\Store\Model\StoreManagerInterface $storeManager
*/
public function __construct(
Context $context,
\Magento\Framework\App\State $state,
\Magento\Store\Model\StoreManagerInterface $storeManager
) {
parent::__construct($context);
$this->state = $state;
$this->storeManager = $storeManager;
}
/**
* @return int
*/
public function resolveCurrentWebsiteId()
{
if ($this->state->getAreaCode() == \Magento\Framework\App\Area::AREA_ADMINHTML) {
// in admin area
/** @var \Magento\Framework\App\RequestInterface $request */
$request = $this->_request;
$storeId = (int) $request->getParam('store', 0);
} else {
// frontend area
$storeId = true; // get current store from the store resolver
}
$store = $this->storeManager->getStore($storeId);
$websiteId = $store->getWebsiteId();
return $websiteId;
}
結果は次のようになります。
スコープセレクターなしのバックエンド-0
スコープセレクターでサポート- 選択したWebサイトID、または何も選択されていない場合は0(すべてのストアビュー)
フロントエンド- 現在のウェブサイトID
フロントエンドで短い方法を探している場合:
Magento\Store\Model\StoreResolver
そのためにクラスを使用できます。
/**
* @var \Magento\Store\Model\StoreResolver
*/
private $storeResolver;
/**
* @param \Magento\Store\Model\StoreResolver $storeResolver
*/
public function __construct(
\Magento\Store\Model\StoreResolver $storeResolver
) {
$this->storeResolver = $storeResolver;
}
/**
* Returns the current store id, if it can be detected or default store id
*
* @return int|string
*/
public function getCurrentStoreId()
{
return $this->storeResolver->getCurrentStoreId();
}
フロントエンド領域で現在選択されているストアビューを正しく検出しますが、管理領域では役に立ちません。