app/Customize/Controller/PageController.php line 186

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of EC-CUBE
  4.  *
  5.  * Copyright(c) EC-CUBE CO.,LTD. All Rights Reserved.
  6.  *
  7.  * http://www.ec-cube.co.jp/
  8.  *
  9.  * For the full copyright and license information, please view the LICENSE
  10.  * file that was distributed with this source code.
  11.  */
  12. namespace Customize\Controller;
  13. use Customize\Controller\LM\LmAbstractController;
  14. use Customize\Entity\CacheTrait;
  15. use Customize\Service\CategoryService;
  16. use Customize\Service\GoodsService;
  17. use Customize\Service\LmHelper;
  18. use Customize\Service\PageService;
  19. use Eccube\Common\Constant;
  20. use Lm\Engine\EC\Entity\CategoryWithRelated;
  21. use Customize\Service\MobileDetector as LmMobileDetector;
  22. use Symfony\Component\Cache\CacheItem;
  23. use Symfony\Component\HttpFoundation\Request;
  24. use Symfony\Component\HttpFoundation\Response;
  25. use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
  26. use Symfony\Component\Routing\Annotation\Route;
  27. use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
  28. use Lm\Service\Db\SqlService;
  29. use Customize\Service\CommonService;
  30. use Customize\Converter\DynamicConverter;
  31. use Symfony\Component\HttpFoundation\Session\SessionInterface;
  32. use Eccube\Common\EccubeConfig;
  33. class PageController extends LmAbstractController
  34. {
  35.     use CacheTrait;
  36.     const PREFIX_CACHE "PAGE_CONTROLLER_";
  37.     const MAIN_CATEGORY_GROUPS_UNABLE_SHOW = [7,8];
  38.     /**
  39.      * @var LmMobileDetector $MobileDetector
  40.      */
  41.     protected $MobileDetector;
  42.     protected $dynamicConverter;
  43.     protected $session;
  44.     protected $CategoryService;
  45.     protected $GoodsService;
  46.     /**
  47.      * @var EccubeConfig
  48.      */
  49.     protected $eccubeConfig;
  50.     private $cacheLifeTime;
  51.     public function __construct(CommonService    $commonService,
  52.                                 LmHelper         $lmHelper,
  53.                                 LmMobileDetector $mobileDetector,
  54.                                 DynamicConverter $dynamicConverter,
  55.                                 SessionInterface $session,
  56.                                 EccubeConfig     $eccubeConfig,
  57.                                 CategoryService  $categoryService,
  58.                                 GoodsService     $goodService
  59.     ) {
  60.         //
  61.         parent::__construct($commonService$lmHelper);
  62.         //
  63.         $this->MobileDetector $mobileDetector;
  64.         $this->dynamicConverter $dynamicConverter;
  65.         $this->session $session;
  66.         $this->eccubeConfig $eccubeConfig;
  67.         $this->CategoryService $categoryService;
  68.         $this->GoodsService $goodService;
  69.         $this->cacheLifeTime $this->eccubeConfig->get("eccube_result_cache_lifetime") ?? Constant::ONE_HOUR;
  70.     }
  71.     /**
  72.      * @param Request $request
  73.      * #Route("/page/{mc}", requirements={"mc" = "\w+"}, name="page/main-category", methods={"GET"})
  74.      * @Template("Page/sub-category.twig")
  75.      */
  76.     protected function _mainCategory(Request $request$mc$mcMc null)
  77.     {
  78.         //
  79.         $request->attributes->set('_route''page/main-category');
  80.         $request->attributes->set('mc'$mc);
  81.         $request->attributes->set('mcMc'$mcMc);
  82.         //
  83.         return $this->newCategory($request$mcnull$mcMc, function ($category) use ($request$mc$mcMc) {
  84.             //
  85.             return $this->__mainCategory($request$category$mc$mcMc);
  86.         });
  87.     }
  88.     protected function __mainCategory(Request $requestCategoryWithRelated $category$mc$mcMc null)
  89.     {
  90.         //
  91.         $sql = new SqlService();
  92.         //
  93.         $data $sql->Table('landmark01.main_category_table')
  94.             ->Set('main_category_webname'$mc)
  95.             ->Find();
  96.         // モバイルの判定
  97.         $isMobile $this->MobileDetector->isMobile();
  98.         # Author Description Keyword Robots MetaTags
  99.         $Metatage = ['Author' => 'ああああ''Description' => 'いいい'];
  100.         // $this->CommonService->WriteYml(['hoge' => 'piyo'], 'hogehoge.yml');
  101.         //
  102.         $review $this->dynamicConverter->getReview(nullfalse$data['main_category_id']);
  103.         $columnList = [
  104.             [
  105.                 'uri' => '/',
  106.                 'column_custom_url' => '/custom_url',
  107.                 'main_category_webname' => 'work',
  108.                 'column_webname' => 'sagyogi-fashionable',
  109.                 'column_related_image_filename' => 'kanren.jpg  ',
  110.                 'column_related_image_alt' => 'ユニフォーム通販TOP',
  111.                 'column_name' => 'ユニフォーム通販TOP',
  112.                 'column_related_link_text' => 'ユニフォーム通販TOP',
  113.                 'column_h1_tag' => 'ユニフォーム通販TOP'
  114.             ],
  115.             [
  116.                 'uri' => '/',
  117.                 'column_custom_url' => '/custom_url',
  118.                 'main_category_webname' => 'work',
  119.                 'column_webname' => 'sagyogi-fashionable',
  120.                 'column_related_image_filename' => 'kanren.jpg  ',
  121.                 'column_related_image_alt' => 'ユニフォーム通販TOP',
  122.                 'column_name' => 'ユニフォーム通販TOP',
  123.                 'column_related_link_text' => 'ユニフォーム通販TOP',
  124.                 'column_h1_tag' => 'ユニフォーム通販TOP'
  125.             ]
  126.         ];
  127.         $upperColumnData $this->dynamicConverter->getByCategoryWebName(1$mc);
  128.         // TODO: canonicalMcDataを取得
  129.         $canonicalMcData null;
  130.         $categoryData $this->dynamicConverter->getMainCategoryName($mc);
  131.         $categoryData['main_category'] = $data;
  132.         $categoryData $this->dynamicConverter->getMainCategoryName($mc);
  133.         if (!empty($data['main_category_main_category'])) {
  134.             $subCategoryList $this->dynamicConverter->getSubCategoryList($data['main_category_main_category']);
  135.         } else if (isset($categoryData) && intval($categoryData['category_group_only_main']) == 1) {
  136.             $subCategoryList = [];
  137.         } else {
  138.             $subCategoryList $this->dynamicConverter->getSubCategoryList($data['main_category_id']);
  139.         }
  140.         $BreadCrumbs = [
  141. //            [
  142. //                'label' => $data['main_category_main_category_name'],
  143. //                'href' => "/{$data['main_category_main_category_webname']}",
  144. //            ],
  145.             [
  146.                 'label' => $data['main_category_name'],
  147.                 'href' => "{$data['main_category_main_category_webname']}/{$data['main_category_webname']}",
  148.             ],
  149. //            [
  150. //                'label' => $categoryData['category_name'],
  151. //                'href' => "/{$data['main_category_main_category_webname']}/{$data['main_category_webname']}/{$categoryData['category_webname']}",
  152. //            ],
  153.         ];
  154.         $mcMcName $mc;
  155.         $mcName $mc;
  156.         $ctName 'allItem';
  157.         $ctId 'allitem';
  158.         $mcId $data['main_category_id'];
  159.         $orderType $this->session->has('order_type') ? $this->session->get('order_type') : $request->get('type');
  160.         $display_item_count_list $this->CommonService->GetYaml('DisplayItem.yaml');
  161.         $displayMax $this->session->has('display_max') ? intval($this->session->get('display_max')) : intval($request->get('disp'));
  162.         if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT']['LOW']) {
  163.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT']['LOW'];
  164.         } else if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT']['HIGH']) {
  165.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT']['HIGH'];
  166.         } else if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT']) {
  167.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT'];
  168.         } else {
  169.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT'];
  170.         }
  171.         $dataItem "";
  172.         $dataItem $this->_getDataItem($request$mcId$ctId$mcName$ctName$max_display_cnt$item_count); // data['item']
  173.         $detailData = array();
  174.         $detailData['item_count'] = $item_count;
  175. //        $detailData['item_count'] = count($dataItem);
  176.         $detailData['item'] = $dataItem;
  177.         //var_dump($detailData['item']);
  178.         $detailData['pager_pages_current_num'] = 0;
  179.         $detailData['col_count'] = $isMobile 3;
  180.         $detailData['max_display_cnt'] = $max_display_cnt;
  181.         if (!empty($request->get('no')) && intval($request->get('no')) > 0) {
  182.             $detailData['min_cnt'] = min((intval($request->get('no')) + 1), $detailData['item_count']);
  183.         } else {
  184.             $detailData['min_cnt'] = min(1$detailData['item_count']);
  185.         }
  186.         $detailData['max_cnt'] = min($detailData['min_cnt'] + $detailData['max_display_cnt'] - 1$detailData['item_count']);
  187.         for ($i 1$i <= $detailData['item_count']; $i += $detailData['max_display_cnt']) {
  188.             if ($detailData['min_cnt'] >= $i and $detailData['max_cnt'] <= ($i $detailData['max_display_cnt'])) {
  189.                 $detailData['pager_pages_current_num'] = intval($i $detailData['max_display_cnt']) + 1;
  190.             }
  191.         }
  192.         $an_sort = array();
  193.         for ($i 0$i $detailData['item_count']; $i++) {
  194.             $an_sort["$i"] = $i;
  195.         }
  196.         $i 0;
  197.         foreach ($an_sort as $k => $v) {
  198.             // $an_v[$i] = $k;
  199.             $an_v[$i] = $i;
  200.             $i++;
  201.         }
  202.         $detailData['an_v'] = $an_sort;
  203.         $main_category_url2_content $isMobile && $data['main_category_url2_sp_content'] != '' $data['main_category_url2_sp_content'] : ($data['main_category_url2_content'] ?? '');
  204.         $main_category_url2_content2 $isMobile && $data['main_category_url2_sp_content2'] != '' $data['main_category_url2_sp_content2'] : ($data['main_category_url2_content2'] ?? '');
  205.         $main_category_url2_content3 $isMobile && $data['main_category_url2_sp_content3'] != '' $data['main_category_url2_sp_content3'] : ($data['main_category_url2_content3'] ?? '');
  206.         $main_category_url2_content4 $isMobile && $data['main_category_url2_sp_content4'] != '' $data['main_category_url2_sp_content4'] : ($data['main_category_url2_content4'] ?? '');
  207.         $main_category_url2_content5 $isMobile && $data['main_category_url2_sp_content5'] != '' $data['main_category_url2_sp_content5'] : ($data['main_category_url2_content5'] ?? '');
  208.         $main_category_url2_content6 $isMobile && $data['main_category_url2_sp_content6'] != '' $data['main_category_url2_sp_content6'] : ($data['main_category_url2_content6'] ?? '');
  209.         $main_category_url2_content7 $isMobile && $data['main_category_url2_sp_content7'] != '' $data['main_category_url2_sp_content7'] : ($data['main_category_url2_content7'] ?? '');
  210.         $main_category_url2_content8 $isMobile && $data['main_category_url2_sp_content8'] != '' $data['main_category_url2_sp_content8'] : ($data['main_category_url2_content8'] ?? '');
  211.         $main_category_url2_content9 $isMobile && $data['main_category_url2_sp_content9'] != '' $data['main_category_url2_sp_content9'] : ($data['main_category_url2_content9'] ?? '');
  212.         $main_category_url2_content10 $isMobile && $data['main_category_url2_sp_content10'] != '' $data['main_category_url2_sp_content10'] : ($data['main_category_url2_content10'] ?? '');
  213.         $main_category_url2_content11 $isMobile && $data['main_category_url2_sp_content11'] != '' $data['main_category_url2_sp_content11'] : ($data['main_category_url2_content11'] ?? '');
  214.         $main_category_url2_content12 $isMobile && $data['main_category_url2_sp_content12'] != '' $data['main_category_url2_sp_content12'] : ($data['main_category_url2_content12'] ?? '');
  215.         // TODO: content2を取得
  216.         $content2 '';
  217.         // TODO: content3を取得
  218.         $content3 '';
  219.         //TODO: 「関連するページ」リンクの表示
  220.         $isItemSeriesCategory 1;
  221.         $isNoDisplayDbCategory 0;
  222.         $detailItemCount 1;
  223.         $categoryGroupNoshowdb 0;
  224.         $breakCountForRankLabel 1;
  225.         $useItemUrlDuplicated false;
  226.         $mainCategoryData = array();
  227.         $main_h3 $data['main_h3_tag'];
  228.         $main_breadcrumb $data['main_breadcrumb'];
  229.         // TODO: category_h3を取得
  230.         $category_h3 '';
  231.         // TODO: category_h1を取得
  232.         $category_h1 '';
  233.         if ($categoryData['category_name'] == "全商品") {
  234.             $seoKeyword $seoKeywordTDK $categoryData['main_category_name'] . " " $categoryData['category_name'];
  235.         } elseif (in_array($data['main_category_name'], array("メディカルウェア""エステユニフォーム"))) { // パターンA
  236.             $seoKeyword $categoryData['category_name'];
  237.             $seoKeywordTDK $categoryData['category_name'] . "(" $data['main_category_name'] . ")";
  238.         } elseif (in_array($data['main_category_name'], array("作業服・作業着""作業服バートル""医療白衣""エプロン""防寒服""スタッフジャンパー""シャツ""ポロシャツ"))) { // パターンB
  239.             $seoKeyword $seoKeywordTDK $categoryData['category_name'];
  240.         } else { // パターンC
  241.             $seoKeyword $seoKeywordTDK $data['main_category_name'] . " " $categoryData['category_name'];
  242.         }
  243.         $useRecommendedItemOrder $this->dynamicConverter->useUnItemOrder($data['main_category_id']);
  244.         if ($mcMc) {
  245.             $custom_menu $this->dynamicConverter->getMainCategoryMenu($mcMc);
  246.         } else {
  247.             $custom_menu $this->dynamicConverter->getMainCategoryMenu($mc);
  248.         }
  249.         $custom_frequently_searched_word $this->dynamicConverter->getSearchWordGroup($this->eccubeConfig['EditSpMenu']['MENU_NAME_COMMON'], $this->eccubeConfig['EditSpMenu']['BOOL_TRUE']);
  250.         $common_header_contents null;
  251.         $recentviews = [];
  252.         $isMainCategory true;
  253.         // TODO: ⑧【LM】商品一覧
  254.         $is_no_display_db_category false;
  255.         $showItemDb true;
  256.         $useCache false;
  257.         $canonical_category_name '';
  258.         $average = array();
  259.         $pager_data $this->CategoryService->getPagerData(
  260.             $category->getCanonicalMainCategoryWebname(),
  261.             $ctName,
  262.             $detailData['max_display_cnt'],
  263.             $detailData['item_count'],
  264.             $detailData['min_cnt'],
  265.             $detailData['max_cnt'],
  266.             $displayMax,
  267.             $orderType,
  268.             $isMobile
  269.         );
  270.         // TODO: ⑨【LM】カテゴリ絞り込み(SP)
  271.         $isMainOnly false;
  272.         $canonicalSubCategoryList = [];
  273.         $leftmenuForCategoryData = [];
  274.         $canonicalMcName $mcName;
  275.         $items array_values(array_map(function($subCategory) {
  276.            return [
  277.                'category_id' => $subCategory['category_id'] ?? null,
  278.                'category_name' => $subCategory['category_name'] ?? null,
  279.                'category_main_category' => $subCategory['category_main_category'] ?? null,
  280.                'category_category' => $subCategory['category_category'] ?? null,
  281.                'category_main' => $subCategory['category_main'] ?? null,
  282.                'cnt' => $subCategory['cnt'] ?? null,
  283.                'image' => $this->CategoryService->getCategoryImageUrl($subCategory['category_id']),
  284.                'goods_image' => $this->CategoryService->getGoodsImageUrlByCatetoryId($subCategory['category_id']),
  285.            ];
  286.         }, $subCategoryList ?? []));
  287.         // TODO: ③【LM】共用コンテンツ(SP)のデータ取得
  288.         $common_header_contents_all '<div>
  289.         <a style="display: block; width: 100%;" href="/cart/add_catalog">
  290.         <picture><source media="(max-width: 320px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_320/smartphone/smp-catalog-2020aw-486x60.webp"><source media="(max-width: 640px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_640/smartphone/smp-catalog-2020aw-486x60.webp"><source type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images/smartphone/smp-catalog-2020aw-486x60.webp"><source media="(max-width: 320px)" srcset="https://img0.land-mark.biz/ut_img/public_images_320/smartphone/smp-catalog-2020aw-486x60.jpg"><source media="(max-width: 640px)" srcset="https://img0.land-mark.biz/ut_img/public_images_640/smartphone/smp-catalog-2020aw-486x60.jpg"><img style="width: 100%;" src="https://img0.land-mark.biz/ut_img/public_images/smartphone/smp-catalog-2020aw-486x60.jpg"></picture></a>
  291.         </div>
  292.         <div>
  293.         <a style="display: block; width: 100%;" href="/amazonpay/">
  294.         <picture><source media="(max-width: 320px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_320/categorypage/amazonpay/smp-486x60.webp"><source media="(max-width: 640px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_640/categorypage/amazonpay/smp-486x60.webp"><source type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images/categorypage/amazonpay/smp-486x60.webp"><source media="(max-width: 320px)" srcset="https://img0.land-mark.biz/ut_img/public_images_320/categorypage/amazonpay/smp-486x60.jpg"><source media="(max-width: 640px)" srcset="https://img0.land-mark.biz/ut_img/public_images_640/categorypage/amazonpay/smp-486x60.jpg"><img style="width: 100%;" src="https://img0.land-mark.biz/ut_img/public_images/categorypage/amazonpay/smp-486x60.jpg"></picture></a>
  295.         </div>';
  296.         $main_category_name $data['main_category_name'];
  297.         $back_to_top_link = !empty($categoryData['main_bottomlink']) ? $categoryData['main_bottomlink'] : $categoryData['main_category_name'];
  298.         $category_bottom_text $categoryData['main_pagebottom'] ?? null;
  299.         $mainCategoryGroup $this->CategoryService->getMainCategoryGroupById($mc);
  300.         $mainCategoryData $this->CategoryService->getMainCategory($mcId);
  301.         $isShowCategoryData false;
  302.         if (
  303.             !empty($mainCategoryData['category_group_noshowdb']) && !$mainCategoryData['category_group_noshowdb'] &&
  304.             (
  305.                 (!empty($mainCategoryData['main_category_group']) && !in_array($mainCategoryData['main_category_group'], self::MAIN_CATEGORY_GROUPS_UNABLE_SHOW)) ||
  306.                 $detailData['item_count'] > 0
  307.             )
  308.         ) {
  309.             $isShowCategoryData true;
  310.         }
  311.         if(!empty($mainCategoryGroup['category_group_only_main']) && $mainCategoryGroup['category_group_only_main']){
  312.             $isMainOnly true;
  313.         }
  314.         $vendingStatusMap $this->GoodsService->getGoodsVendingStatusMap();
  315.         return [
  316.             'data' => $data,
  317.             'review' => $review,
  318.             'BreadCrumbs' => $BreadCrumbs,
  319.             'pager_pages_current_num' => $detailData['pager_pages_current_num'],
  320.             'upperColumnData' => $upperColumnData,
  321.             'columnList' => $columnList,
  322.             'canonicalMcData' => $canonicalMcData,
  323.             'categoryData' => $categoryData,
  324.             'dataItem' => $dataItem,
  325.             'subCategoryList' => $subCategoryList,
  326.             'ctName' => $ctName,
  327.             'mcName' => $mcName,
  328.             'mcMcName' => $mcMcName,
  329.             'content2' => $content2,
  330.             'content3' => $content3,
  331.             'isItemSeriesCategory' => $isItemSeriesCategory,
  332.             'isNoDisplayDbCategory' => $isNoDisplayDbCategory,
  333.             'detailItemCount' => $detailItemCount,
  334.             'categoryGroupNoshowdb' => $categoryGroupNoshowdb,
  335.             'detailData' => $detailData,
  336.             'main_h3' => $main_h3,
  337.             'main_breadcrumb' => $main_breadcrumb,
  338.             'seoKeywordTDK' => $seoKeywordTDK,
  339.             'category_h3' => $category_h3,
  340.             'category_h1' => $category_h1,
  341.             'useRecommendedItemOrder' => $useRecommendedItemOrder,
  342.             'breakCountForRankLabel' => $breakCountForRankLabel,
  343.             'useItemUrlDuplicated' => $useItemUrlDuplicated,
  344.             'mainCategoryData' => $mainCategoryData,
  345.             'common_header_contents_all' => $common_header_contents_all,
  346.             'common_header_contents' => $common_header_contents,
  347.             'recentviews' => $recentviews,
  348.             'custom_menu' => $custom_menu,
  349.             'custom_frequently_searched_word' => $custom_frequently_searched_word,
  350.             'isMainCategory' => $isMainCategory,
  351.             'is_no_display_db_category' => $is_no_display_db_category,
  352.             'showItemDb' => $showItemDb,
  353.             'useCache' => $useCache,
  354.             'pager_data' => $pager_data,
  355.             'max_display_cnt' => $max_display_cnt,
  356.             'canonical_category_name' => $canonical_category_name,
  357.             'average' => $average,
  358.             'isMainOnly' => $isMainOnly,
  359.             'isShowCategoryData' => $isShowCategoryData,
  360.             'items' => $items,
  361.             'canonicalSubCategoryList' => $canonicalSubCategoryList,
  362.             'leftmenuForCategoryData' => $leftmenuForCategoryData,
  363.             'canonicalMcName' => $canonicalMcName,
  364.             'ctId' => $ctId,
  365.             'main_category_name' => $main_category_name,
  366.             'MetaTags' => ['Category'=> $data ], # 2022/08/03 #kawai
  367.             'SubCate' => 0,
  368.             'back_to_top_link' => $back_to_top_link,
  369.             'category_bottom_text' => $category_bottom_text,
  370.             'vendingStatusMap' => $vendingStatusMap,
  371.         ];
  372.     }
  373.     /**
  374.      * @param Request $request
  375.      * @param string $ct
  376.      * @param string $mc
  377.      * @param string|null $mcMc
  378.      * #Route("/page/{mc}/{ct}", requirements={"mc" = "\w+", "ct" = "\w+"}, name="page/sub-category", methods={"GET"})
  379.      * @Template("Page/sub-category.twig")
  380.      * @return array|\Symfony\Component\HttpFoundation\Response
  381.      */
  382.     protected function _subCategory(Request $request$ct$mc$mcMc null)
  383.     {
  384.         //
  385.         $request->attributes->set('_route''page/sub-category');
  386.         $request->attributes->set('ct'$ct);
  387.         $request->attributes->set('mc'$mc);
  388.         $request->attributes->set('mcMc'$mcMc);
  389.         //
  390.         return $this->newCategory($request$mc$ct$mcMc, function ($category) use ($request$ct$mc$mcMc) {
  391.             //
  392.             return $this->__subCategory($request$category$ct$mc$mcMc);
  393.         });
  394.     }
  395.     protected function __subCategory(Request $requestCategoryWithRelated $category$ct$mc$mcMc null)
  396.     {
  397.         $data $this->dynamicConverter->getMainCategoryName($mc);
  398.         $data['mcId'] = $data['main_category_id'];
  399.         $data['mcName'] = $mc;
  400.         if ($ct != 'allitem') {
  401.             $subCategoryData $this->dynamicConverter->getSubCategoryName($data['main_category_id'], $ct);
  402.             $data['ctId'] = $subCategoryData['category_id'];
  403.             $data['ctName'] = $ct;
  404.         } else {
  405.             $data['ctId'] = 'allitem';
  406.             $data['ctName'] = 'allitem';
  407.         }
  408.         // モバイルの判定
  409.         $isMobile $this->MobileDetector->isMobile();
  410.         # Author Description Keyword Robots MetaTags
  411.         $Metatage = ['Author' => 'ああああ''Description' => 'いいい'];
  412.         $review = isset($data['main_category_id']) ? $this->dynamicConverter->getReview(nullfalse$data['main_category_id'], $data['ctId']) : [];
  413.         $columnList = [
  414.             [
  415.                 'uri' => '/',
  416.                 'column_custom_url' => '/custom_url',
  417.                 'main_category_webname' => 'work',
  418.                 'column_webname' => 'sagyogi-fashionable',
  419.                 'column_related_image_filename' => 'kanren.jpg  ',
  420.                 'column_related_image_alt' => 'ユニフォーム通販TOP',
  421.                 'column_name' => 'ユニフォーム通販TOP',
  422.                 'column_related_link_text' => 'ユニフォーム通販TOP',
  423.                 'column_h1_tag' => 'ユニフォーム通販TOP'
  424.             ],
  425.             [
  426.                 'uri' => '/',
  427.                 'column_custom_url' => '/custom_url',
  428.                 'main_category_webname' => 'work',
  429.                 'column_webname' => 'sagyogi-fashionable',
  430.                 'column_related_image_filename' => 'kanren.jpg  ',
  431.                 'column_related_image_alt' => 'ユニフォーム通販TOP',
  432.                 'column_name' => 'ユニフォーム通販TOP',
  433.                 'column_related_link_text' => 'ユニフォーム通販TOP',
  434.                 'column_h1_tag' => 'ユニフォーム通販TOP'
  435.             ]
  436.         ];
  437.         $upperColumnData $this->dynamicConverter->getByCategoryWebName(1$mc);
  438.         // TODO: canonicalMcDataを取得
  439.         $canonicalMcData null;
  440.         $categoryData $this->dynamicConverter->getCategoryData($data['main_category_id'], $data['category_id']);
  441.         $categoryData['main_category'] = $this->dynamicConverter->getMainCategoryData($data['main_category_id']);
  442.         $subCategoryList $this->dynamicConverter->getSubCategoryList($data['main_category_id']);
  443.         $canonicalSubCategoryList $this->dynamicConverter->getSubCategoryList($data['mcId']);
  444.         $BreadCrumbs = [
  445. //                        [
  446. //                            'label' => $categoryData['main_category_main_category_name'],
  447. //                            'href' => "/{$categoryData['main_category_main_category_webname']}",
  448. //                        ],
  449.                         [
  450.                             'label' => $categoryData['main_category_name'],
  451.                             'href' => "{$categoryData['main_category_main_category_webname']}/{$categoryData['main_category_webname']}",
  452.                         ],
  453.                         [
  454.                             'label' => $categoryData['category_name'],
  455.                             'href' => "{$categoryData['main_category_main_category_webname']}/{$categoryData['main_category_webname']}/{$categoryData['category_webname']}",
  456.                         ],
  457.                     ];
  458.         $mcMcName $mc;
  459.         $mcName $mc;
  460.         $ctName $data['ctName'];
  461.         $ctId $data['ctId'];
  462.         $mcId $data['main_category_id'];
  463.         $orderType $this->session->has('order_type') ? $this->session->get('order_type') : $request->get('type');
  464.         $display_item_count_list $this->CommonService->GetYaml('DisplayItem.yaml');
  465.         $displayMax $this->session->has('display_max') ? intval($this->session->get('display_max')) : intval($request->get('disp'));
  466.         if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT']['LOW']) {
  467.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT']['LOW'];
  468.         } else if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT']['HIGH']) {
  469.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT']['HIGH'];
  470.         } else if ($displayMax == $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT']) {
  471.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT'];
  472.         } else {
  473.             $max_display_cnt $display_item_count_list['DISPLAY_ITEM_COUNT_DEFAULT'];
  474.         }
  475.         $dataItem "";
  476.         $dataItem $this->_getDataItem($request$mcId$ctId$mcName$ctName$max_display_cnt$item_count);
  477.         $detailData = array();
  478.         $detailData['item_count'] = $item_count;
  479. //        $detailData['item_count'] = count($dataItem);
  480.         $detailData['item'] = $dataItem;
  481.         $detailData['pager_pages_current_num'] = 0;
  482.         $detailData['col_count'] = $isMobile 3;
  483.         $detailData['max_display_cnt'] = $max_display_cnt;
  484.         if (!empty($request->get('no')) && intval($request->get('no')) > 0) {
  485.             $detailData['min_cnt'] = min((intval($request->get('no')) + 1), $detailData['item_count']);
  486.         } else {
  487.             $detailData['min_cnt'] = min(1$detailData['item_count']);
  488.         }
  489.         $detailData['max_cnt'] = min($detailData['min_cnt'] + $detailData['max_display_cnt'] - 1$detailData['item_count']);
  490.         for ($i 1$i <= $detailData['item_count']; $i += $detailData['max_display_cnt']) {
  491.             if ($detailData['min_cnt'] >= $i and $detailData['max_cnt'] <= ($i $detailData['max_display_cnt'])) {
  492.                 $detailData['pager_pages_current_num'] = intval($i $detailData['max_display_cnt']) + 1;
  493.             }
  494.         }
  495.         $an_sort = array();
  496.         for ($i 0$i $detailData['item_count']; $i++) {
  497.             $an_sort["$i"] = $i;
  498.         }
  499.         $i 0;
  500.         foreach ($an_sort as $k => $v) {
  501.             // $an_v[$i] = $k;
  502.             $an_v[$i] = $i;
  503.             $i++;
  504.         }
  505.         $detailData['an_v'] = $an_sort;
  506.         $main_category_url2_content $isMobile && $categoryData['main_category']['main_category_url2_sp_content'] != '' $categoryData['main_category']['main_category_url2_sp_content'] : ($categoryData['main_category']['main_category_url2_content'] ?? '');
  507.         $main_category_url2_content2 $isMobile && $categoryData['main_category']['main_category_url2_sp_content2'] != '' $categoryData['main_category']['main_category_url2_sp_content2'] : ($categoryData['main_category']['main_category_url2_content2'] ?? '');
  508.         $main_category_url2_content3 $isMobile && $categoryData['main_category']['main_category_url2_sp_content3'] != '' $categoryData['main_category']['main_category_url2_sp_content3'] : ($categoryData['main_category']['main_category_url2_content3'] ?? '');
  509.         $main_category_url2_content4 $isMobile && $categoryData['main_category']['main_category_url2_sp_content4'] != '' $categoryData['main_category']['main_category_url2_sp_content4'] : ($categoryData['main_category']['main_category_url2_content4'] ?? '');
  510.         $main_category_url2_content5 $isMobile && $categoryData['main_category']['main_category_url2_sp_content5'] != '' $categoryData['main_category']['main_category_url2_sp_content5'] : ($categoryData['main_category']['main_category_url2_content5'] ?? '');
  511.         $main_category_url2_content6 $isMobile && $categoryData['main_category']['main_category_url2_sp_content6'] != '' $categoryData['main_category']['main_category_url2_sp_content6'] : ($categoryData['main_category']['main_category_url2_content6'] ?? '');
  512.         $main_category_url2_content7 $isMobile && $categoryData['main_category']['main_category_url2_sp_content7'] != '' $categoryData['main_category']['main_category_url2_sp_content7'] : ($categoryData['main_category']['main_category_url2_content7'] ?? '');
  513.         $main_category_url2_content8 $isMobile && $categoryData['main_category']['main_category_url2_sp_content8'] != '' $categoryData['main_category']['main_category_url2_sp_content8'] : ($categoryData['main_category']['main_category_url2_content8'] ?? '');
  514.         $main_category_url2_content9 $isMobile && $categoryData['main_category']['main_category_url2_sp_content9'] != '' $categoryData['main_category']['main_category_url2_sp_content9'] : ($categoryData['main_category']['main_category_url2_content9'] ?? '');
  515.         $main_category_url2_content10 $isMobile && $categoryData['main_category']['main_category_url2_sp_content10'] != '' $categoryData['main_category']['main_category_url2_sp_content10'] : ($categoryData['main_category']['main_category_url2_content10'] ?? '');
  516.         $main_category_url2_content11 $isMobile && $categoryData['main_category']['main_category_url2_sp_content11'] != '' $categoryData['main_category']['main_category_url2_sp_content11'] : ($categoryData['main_category']['main_category_url2_content11'] ?? '');
  517.         $main_category_url2_content12 $isMobile && $categoryData['main_category']['main_category_url2_sp_content12'] != '' $categoryData['main_category']['main_category_url2_sp_content12'] : ($categoryData['main_category']['main_category_url2_content12'] ?? '');
  518.         // TODO: content2を取得
  519.         $content2 '';
  520.         // TODO: content3を取得
  521.         $content3 '';
  522.         //TODO: 「関連するページ」リンクの表示
  523.         $isItemSeriesCategory 1;
  524.         $isNoDisplayDbCategory 0;
  525.         $detailItemCount 1;
  526.         $categoryGroupNoshowdb 0;
  527.         $breakCountForRankLabel 1;
  528.         $useItemUrlDuplicated false;
  529.         $mainCategoryData = array();
  530.         $main_h3 $categoryData['main_category']['main_h3_tag'];
  531.         $main_breadcrumb $categoryData['main_category']['main_breadcrumb'];
  532.         // TODO: category_h3を取得
  533.         $category_h3 '';
  534.         // TODO: category_h1を取得
  535.         $category_h1 '';
  536.         $seoKeywordTDK '';
  537.         if ($categoryData['category_name'] == "全商品") {
  538.             $seoKeyword $seoKeywordTDK $categoryData['main_category_name'] . " " $categoryData['category_name'];
  539.         } elseif (in_array($data['main_category_name'], array("メディカルウェア""エステユニフォーム"))) { // パターンA
  540.             $seoKeyword $categoryData['category_name'];
  541.             $seoKeywordTDK $categoryData['category_name'] . "(" $data['main_category_name'] . ")";
  542.         } elseif (in_array($data['main_category_name'], array("作業服・作業着""作業服バートル""医療白衣""エプロン""防寒服""スタッフジャンパー""シャツ""ポロシャツ"))) { // パターンB
  543.             $seoKeyword $seoKeywordTDK $categoryData['category_name'];
  544.         } else { // パターンC
  545.             $seoKeyword $seoKeywordTDK $data['main_category_name'] . " " $categoryData['category_name'];
  546.         }
  547.         $useRecommendedItemOrder $this->dynamicConverter->useUnItemOrder($data['mcId'], $data['ctId']);
  548.         if ($mcMc) {
  549.             $custom_menu $this->dynamicConverter->getMainCategoryMenu($mcMc);
  550.         } else {
  551.             $custom_menu $this->dynamicConverter->getMainCategoryMenu($mc);
  552.         }
  553.         $custom_frequently_searched_word $this->dynamicConverter->getSearchWordGroup($this->eccubeConfig['EditSpMenu']['MENU_NAME_COMMON'], $this->eccubeConfig['EditSpMenu']['BOOL_TRUE']);
  554.         $recentviews = [];
  555.         $common_header_contents null;
  556.         $isMainCategory false;
  557.         // TODO: ⑧【LM】商品一覧
  558.         $category = new CategoryWithRelated($mc$ct$mcMc$isMobile);
  559.         $is_no_display_db_category $category->isNoDisplayDbCategory();
  560.         $showItemDb false;
  561.         $useCache false;
  562.         $max_display_cnt 10;
  563.         $canonical_category_name '';
  564.         $average = array();
  565.         if ( !$data['category_group_noshowdb'] &&
  566.             // array(7, 8) 7:説明別, 8: メーカー別
  567.             ( !in_array($data['main_category_group'], array(78)) || $detailData['item_count'] > 0) ) {
  568.                 $showItemDb true;
  569.         }
  570.         $pager_data $this->CategoryService->getPagerData(
  571.             $category->getCanonicalMainCategoryWebname(),
  572.             $ct,
  573.             $detailData['max_display_cnt'],
  574.             $detailData['item_count'],
  575.             $detailData['min_cnt'],
  576.             $detailData['max_cnt'],
  577.             $displayMax,
  578.             $orderType,
  579.             $isMobile
  580.         );
  581.         // TODO: ⑨【LM】カテゴリ絞り込み(SP)
  582.         $isMainOnly false;
  583.         $leftmenuForCategoryData = [];
  584.         $canonicalMcName $mcName;
  585.         $items array_values(array_map(function($subCategory) {
  586.             return [
  587.                 'category_id' => $subCategory['category_id'] ?? null,
  588.                 'category_name' => $subCategory['category_name'] ?? null,
  589.                 'category_main_category' => $subCategory['category_main_category'] ?? null,
  590.                 'category_category' => $subCategory['category_category'] ?? null,
  591.                 'category_main' => $subCategory['category_main'] ?? null,
  592.                 'cnt' => $subCategory['cnt'] ?? null,
  593.                 'image' => $this->CategoryService->getCategoryImageUrl($subCategory['category_id']),
  594.                 'goods_image' => $this->CategoryService->getGoodsImageUrlByCatetoryId($subCategory['category_id']),
  595.             ];
  596.         }, $subCategoryList ?? []));
  597.         // TODO: ③【LM】共用コンテンツ(SP)のデータ取得
  598.         $common_header_contents_all '<div>
  599.         <a style="display: block; width: 100%;" href="/cart/add_catalog">
  600.         <picture><source media="(max-width: 320px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_320/smartphone/smp-catalog-2020aw-486x60.webp"><source media="(max-width: 640px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_640/smartphone/smp-catalog-2020aw-486x60.webp"><source type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images/smartphone/smp-catalog-2020aw-486x60.webp"><source media="(max-width: 320px)" srcset="https://img0.land-mark.biz/ut_img/public_images_320/smartphone/smp-catalog-2020aw-486x60.jpg"><source media="(max-width: 640px)" srcset="https://img0.land-mark.biz/ut_img/public_images_640/smartphone/smp-catalog-2020aw-486x60.jpg"><img style="width: 100%;" src="https://img0.land-mark.biz/ut_img/public_images/smartphone/smp-catalog-2020aw-486x60.jpg"></picture></a>
  601.         </div>
  602.         <div>
  603.         <a style="display: block; width: 100%;" href="/amazonpay/">
  604.         <picture><source media="(max-width: 320px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_320/categorypage/amazonpay/smp-486x60.webp"><source media="(max-width: 640px)" type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images_640/categorypage/amazonpay/smp-486x60.webp"><source type="image/webp" srcset="https://img0.land-mark.biz/ut_img/public_images/categorypage/amazonpay/smp-486x60.webp"><source media="(max-width: 320px)" srcset="https://img0.land-mark.biz/ut_img/public_images_320/categorypage/amazonpay/smp-486x60.jpg"><source media="(max-width: 640px)" srcset="https://img0.land-mark.biz/ut_img/public_images_640/categorypage/amazonpay/smp-486x60.jpg"><img style="width: 100%;" src="https://img0.land-mark.biz/ut_img/public_images/categorypage/amazonpay/smp-486x60.jpg"></picture></a>
  605.         </div>';
  606.         $main_category_name $data['category_name'];
  607.         $back_to_top_link = !empty($subCategoryList[$ctId]['category_bottomlink']) ? $subCategoryList[$ctId]['category_bottomlink'] : $subCategoryList[$ctId]['category_name'];
  608.         $category_bottom_text $subCategoryList[$ctId]['category_pagebottom'] ?? null;
  609.         // TODO: ⑨【LM】カテゴリ(子)_H1タグ
  610.         $addToHeadTitle '';
  611.         $mainCategoryGroup $this->CategoryService->getMainCategoryGroupById($mc);
  612.         $mainCategoryData $this->CategoryService->getMainCategory($mcId);
  613.         $isShowCategoryData false;
  614.         if (
  615.             !empty($mainCategoryData['category_group_noshowdb']) && !$mainCategoryData['category_group_noshowdb'] &&
  616.             (
  617.                 (!empty($mainCategoryData['main_category_group']) && !in_array($mainCategoryData['main_category_group'], self::MAIN_CATEGORY_GROUPS_UNABLE_SHOW)) ||
  618.                 $detailData['item_count'] > 0
  619.             )
  620.         ) {
  621.             $isShowCategoryData true;
  622.         }
  623.         if(!empty($mainCategoryGroup['category_group_only_main']) && $mainCategoryGroup['category_group_only_main']){
  624.             $isMainOnly true;
  625.         }
  626.         $vendingStatusMap $this->GoodsService->getGoodsVendingStatusMap();
  627.         return [
  628.             'data' => $data,
  629.             'review' => $review,
  630.             'pager_pages_current_num' => $detailData['pager_pages_current_num'],
  631.             'upperColumnData' => $upperColumnData,
  632.             'columnList' => $columnList,
  633.             'canonicalMcData' => $canonicalMcData,
  634.             'categoryData' => $categoryData,
  635.             'dataItem' => $dataItem,
  636.             'subCategoryList' => $subCategoryList,
  637.             'ctName' => $ctName,
  638.             'mcName' => $mcName,
  639.             'mcMcName' => $mcMcName,
  640.             'main_category_url2_content' => $main_category_url2_content,
  641.             'main_category_url2_content2' => $main_category_url2_content2,
  642.             'main_category_url2_content3' => $main_category_url2_content3,
  643.             'main_category_url2_content4' => $main_category_url2_content4,
  644.             'main_category_url2_content5' => $main_category_url2_content5,
  645.             'main_category_url2_content6' => $main_category_url2_content6,
  646.             'main_category_url2_content7' => $main_category_url2_content7,
  647.             'main_category_url2_content8' => $main_category_url2_content8,
  648.             'main_category_url2_content9' => $main_category_url2_content9,
  649.             'main_category_url2_content10' => $main_category_url2_content10,
  650.             'main_category_url2_content11' => $main_category_url2_content11,
  651.             'main_category_url2_content12' => $main_category_url2_content12,
  652.             'content2' => $content2,
  653.             'content3' => $content3,
  654.             'isItemSeriesCategory' => $isItemSeriesCategory,
  655.             'isNoDisplayDbCategory' => $isNoDisplayDbCategory,
  656.             'detailItemCount' => $detailItemCount,
  657.             'categoryGroupNoshowdb' => $categoryGroupNoshowdb,
  658.             'detailData' => $detailData,
  659.             'main_h3' => $main_h3,
  660.             'main_breadcrumb' => $main_breadcrumb,
  661.             'category_h3' => $category_h3,
  662.             'category_h1' => $category_h1,
  663.             'useRecommendedItemOrder' => $useRecommendedItemOrder,
  664.             'breakCountForRankLabel' => $breakCountForRankLabel,
  665.             'useItemUrlDuplicated' => $useItemUrlDuplicated,
  666.             'mainCategoryData' => $mainCategoryData,
  667.             'common_header_contents_all' => $common_header_contents_all,
  668.             'common_header_contents' => $common_header_contents,
  669.             'recentviews' => $recentviews,
  670.             'custom_menu' => $custom_menu,
  671.             'custom_frequently_searched_word' => $custom_frequently_searched_word,
  672.             'isMainCategory' => $isMainCategory,
  673.             'is_no_display_db_category' => $is_no_display_db_category,
  674.             'showItemDb' => $showItemDb,
  675.             'useCache' => $useCache,
  676.             'pager_data' => $pager_data,
  677.             'max_display_cnt' => $max_display_cnt,
  678.             'canonical_category_name' => $canonical_category_name,
  679.             'average' => $average,
  680.             'isMainOnly' => $isMainOnly,
  681.             'isShowCategoryData' => $isShowCategoryData,
  682.             'items' => $items,
  683.             'canonicalSubCategoryList' => $canonicalSubCategoryList,
  684.             'leftmenuForCategoryData' => $leftmenuForCategoryData,
  685.             'canonicalMcName' => $canonicalMcName,
  686.             'ctId' => $ctId,
  687.             'main_category_name' => $main_category_name,
  688.             'BreadCrumbs' => $BreadCrumbs,
  689.             'seoKeywordTDK' => $seoKeywordTDK,
  690.             'addToHeadTitle' => $addToHeadTitle,
  691.             'MetaTags' => ['SubCategory'=> $data ], # 2022/08/03 #kawai
  692.             'SubCate' => 1,
  693.             'back_to_top_link' => $back_to_top_link,
  694.             'category_bottom_text' => $category_bottom_text,
  695.             'vendingStatusMap' => $vendingStatusMap,
  696.         ];
  697.     }
  698.     /**
  699.      * @param Request $request
  700.      * @param CategoryWithRelated $category
  701.      * @param string $mc
  702.      * @param string $ct
  703.      * @param string $mcMc
  704.      * @param array|callable $parameters
  705.      * @return mixed|null
  706.      * @throws \ErrorException
  707.      * @throws \Psr\Cache\InvalidArgumentException
  708.      */
  709.     public function newCategory(Request $request$mc$ct null$mcMc null$parameters = [])
  710.     {
  711.         //
  712.         $isMobile $this->MobileDetector->isMobile();
  713.         //
  714.         $device $isMobile 'sp' 'pc';
  715.         //
  716.         $layoutId $isMobile null 24;  // TODO: マジックナンバー: 24
  717.         // レイアウトの指定
  718.         $this->CommonService->SetPageLayout('page/sub-category'$isMobile, [], $layoutId);
  719.         //
  720.         $masterCacheKey self::getMasterCacheKey($mc$ct);
  721.         // 絞込み対応(SESSION内の検索条件をキャッシュIDのサフィックス生成要素に加える)
  722.         $suffix = (function(array $_get, array $_session) {
  723.             //
  724.             $_params array_merge(array_intersect_key($_getarray_flip([
  725.                 'no',
  726.                 'disp',
  727.                 'type',
  728.             ])), array_intersect_key($_sessionarray_flip([
  729.                 'display_max',
  730.                 'order_type',
  731.                 'price_range_end',
  732.                 'price_range_start',
  733.                 'search_base_color_list',
  734.                 'search_size_list',
  735.                 'search_type_list',
  736.             ])));
  737.             //
  738.             return !empty($_params) ? hash('sha256'base64_encode(serialize($_params))) : '';
  739.         })($request->query->all(), $this->session->all());
  740.         //
  741.         $viewCacheKey "{$masterCacheKey}__{$device}_view__{$suffix}";
  742.         //
  743.         $masterCache $this->handleMasterCache($masterCacheKey$device, [
  744.             $viewCacheKey,
  745.         ]);
  746.         return $this->getCacheByKey($viewCacheKey, function () use ($request$isMobile$mc$ct$mcMc$parameters) {
  747.             /**
  748.              * ページング関連のセッションを設定(表示順など)
  749.              */
  750.             $this->setCategoryPagingSession($request);
  751.             // レイアウトの指定
  752.             try {
  753.                 // 親・子・祖父
  754.                 $category = new CategoryWithRelated($mc$ct$mcMc$isMobile);
  755.             } catch (\Exception $e) {
  756.                 // カテゴリデータの取得に失敗した場合「404 Not Found」とする
  757.                 throw new NotFoundHttpException("指定されたカテゴリのデータが取得出来ませんでした({$e->getMessage()})"$e);
  758.             }
  759.             return $this->_newCategory($category$isMobile$mc$ct$mcMc$parameters);
  760.         });
  761.     }
  762.     /**
  763.      * @param bool $isMobile
  764.      * @param string $mc
  765.      * @param string $ct
  766.      * @param string $mcMc
  767.      * @param array|callable $parameters
  768.      * @return array
  769.      */
  770.     public function _newCategory(CategoryWithRelated $category$isMobile$mc$ct null$mcMc null$parameters = [])
  771.     {
  772.         //
  773.         if (is_callable($parameters)) {
  774.             //
  775.             $parameters $parameters($category);
  776.         }
  777.         //
  778.         $BreadCrumbs $category->getBreadCrumbs();
  779.         // TODO: ビューからの呼出しのみに統合
  780.         $contents_block_map $category->getContentsBlockMap();
  781.         $metaTags = [
  782.             $category->getMetaTags(),
  783.         ];
  784.         //
  785.         $main_h1 null;
  786.         $category_h1 null;
  787.         $h1_comment $category->getH1Content();
  788.         //
  789.         $this->dataLayer['gdn']['items'] = array_map(function ($id) {
  790.             return $this->CommonService->get_google_retargeting_item($id);
  791.         }, array_column(array_slice($parameters['detailData']['item'], 03), 'goods_id'));
  792.         $this->dataLayer['ydn']['yahoo_retargeting_items'] = array_map(function ($id) {
  793.             return $this->CommonService->get_yahoo_retargeting_item($id);
  794.         }, array_column(array_slice($parameters['detailData']['item'], 03), 'goods_id'));
  795.         $this->dataLayer['criteo']['item'] = array_column(array_slice($parameters['detailData']['item'], 03), 'goods_id');
  796.         //
  797.         $parameters array_merge($parameters, [
  798.             'mcMcName' => $mcMc,
  799.             'mcName' => $mc,
  800.             'BreadCrumbs' => $BreadCrumbs,
  801.             'breadCrumb' => $BreadCrumbs,
  802.             'category' => $category,
  803.             'contents_block_map' => $contents_block_map,    // TODO: ビューからの呼出しのみに統合
  804.             'MetaTags' => $metaTags,                        // TODO: ビューからの呼出しのみに統合
  805.             'sashikomiTitleHtml' => $category->getTitleContent(),
  806.             'dataLayer' => $this->dataLayer,
  807.             'main_h1' => $main_h1,
  808.             'category_h1' => $category_h1,
  809.             'h1_comment' => $h1_comment,
  810.             'ct' => $ct,
  811.             'isMobile' => $isMobile
  812.         ]);
  813.         //
  814.         // return $this->render('Page/sub-category.twig', $parameters);
  815.         return $parameters;
  816.     }
  817.     /**
  818.      * @param Request $request
  819.      * @param null $cd
  820.      * @Template("Page/sub-category.twig")
  821.      */
  822.     public function mainCategory(Request $request)
  823.     {
  824.         //
  825.         $Uri $request->server->get('REQUEST_URI');
  826.         list($mc) = explode('/'trim(str_replace($request->getBasePath(), ''$Uri), '/'));
  827.         //
  828.         return $this->_mainCategory($request$mc);
  829.     }
  830.     /**
  831.      * @param Request $request
  832.      * @param null $cd
  833.      * @Template("Page/sub-category.twig")
  834.      */
  835.     public function mainCategoryMainCategory(Request $request$mc null$mcMc null)
  836.     {
  837.         //
  838.         $uri $request->getRequestUri();
  839.         $paths explode('/'trim($uri'/'));
  840.         //
  841.         if ($paths[0] !== $mcMc) {
  842.             // //
  843.             // error_log('[PageController::mainCategoryMainCategory] '.json_encode(compact('uri', 'paths', 'mc', 'mcMc')));
  844.             //
  845.             $queries $request->query->all();
  846.             $parameters array_merge($queries, [
  847.             ]);
  848.             //
  849.             $route "ct1_{$mcMc}__ct2_{$mc}";
  850.             $route str_replace('-''_'$route);
  851.             //
  852.             return $this->redirectToRoute($route$parameters301);
  853.         }
  854.         //
  855.         return $this->_mainCategory($request$mc$mcMc);
  856.     }
  857.     /**
  858.      * @param Request $request
  859.      * @param null $cd
  860.      * @Template("Page/sub-category.twig")
  861.      */
  862.     public function subCategory(Request $request$ct3 null)
  863.     {
  864.         //
  865.         $Uri $request->server->get('REQUEST_URI');
  866.         list($mc) = explode('/'trim(str_replace($request->getBasePath(), ''$Uri), '/'));
  867.         $ct $ct3;
  868.         //
  869.         return $this->_subCategory($request$ct$mc);
  870.     }
  871.     /**
  872.      * @param Request $request
  873.      * @param null $cd
  874.      * @Template("Page/sub-category.twig")
  875.      */
  876.     public function mainCategorySubCategory(Request $request$ct1 null$ct2 null$ct3 null)
  877.     {
  878.         //
  879.         $uri $request->getRequestUri();
  880.         $paths explode('/'trim($uri'/'));
  881.         //
  882.         if ($paths[0] !== $ct1) {
  883.             // //
  884.             // error_log('[PageController::mainCategoryMainCategory] '.json_encode(compact('uri', 'paths', 'mc', 'mcMc')));
  885.             //
  886.             $queries $request->query->all();
  887.             $parameters array_merge($queries, [
  888.                 'ct3' => $ct3,
  889.             ]);
  890.             //
  891.             $route "ct1_{$ct1}__ct2_{$ct2}__ct3_";
  892.             $route str_replace('-''_'$route);
  893.             //
  894.             return $this->redirectToRoute($route$parameters301);
  895.         }
  896.         $mcMc $ct1;
  897.         $mc $ct2;
  898.         $ct $ct3;
  899.         //
  900.         return $this->_subCategory($request$ct$mc$mcMc);
  901.     }
  902.     private function _getDataItem($request$mcId$ctId$mcName$ctName$max_display_cnt, &$item_count null)
  903.     {
  904.         $an_search_base_color_list = array();
  905.         //$FRONT_PATH = $this->eccubeConfig['FRONT_PATH'];
  906.         $FRONT_PATH "";
  907.         if ($this->session->has('search_base_color_list') && $this->session->get('search_base_color_list') != '') {
  908.             $k 0;
  909.             $basename $FRONT_PATH "an_ct/" $mcName "/" $ctName;
  910.         }
  911.         // サイズで選ぶ
  912.         $an_search_size_list = array();
  913.         if ($this->session->has('search_size_list') && $this->session->get('search_size_list') != '') {
  914.             $k 0;
  915.             $basename $FRONT_PATH "an_ct/" $mcName "/" $ctName;
  916.         }
  917.         // 種類で選ぶ
  918.         $an_search_type_list = array();
  919.         if ($this->session->has('search_type_list') && $this->session->get('search_type_list') != '') {
  920.             $k 0;
  921.             $basename $FRONT_PATH "an_ct/" $mcName "/" $ctName;
  922.         }
  923.         $strSQLWhere '';
  924.         $search_goods_id array_unique($an_search_base_color_list $an_search_size_list $an_search_type_list);
  925.         if (is_array($search_goods_id) && $search_goods_id) {
  926.             $strSQLWhere .= ' AND goods_id in (' implode(','$search_goods_id) . ')';
  927.         }
  928.         $strSQLGroup " group by goods_id";
  929.         // 金額で選ぶ
  930.         $strSQLHaving '';
  931.         if (($this->session->has('price_range_start') && $this->session->get('price_range_start') != '') || ($this->session->has('price_range_end') && $this->session->get('price_range_end') != '')) {
  932.             $price_range_start $this->session->get('price_range_start');
  933.             $price_range_end $this->session->get('price_range_end');
  934.             $strSQLHaving ' HAVING ';
  935.             // 「範囲」検索
  936.             if ($price_range_start != "" && $price_range_end != "") {
  937.                 $strSQLHaving .= ' price >= ' $price_range_start ' AND price <= ' $price_range_end;
  938.             } else if ($price_range_start != "") {
  939.                 $strSQLHaving .= ' price >= ' $price_range_start;
  940.             } else if ($price_range_end != "") {
  941.                 $strSQLHaving .= ' price <= ' $price_range_end;
  942.             }
  943.         }
  944.         if ($ctId != "allitem") {
  945.             $search_category $this->dynamicConverter->_getOriginalCategory($ctId);
  946.         } else {
  947.             $search_category $this->dynamicConverter->_getOriginalCategory_Main($mcId);
  948.         }
  949.         $mcConditions '';
  950.         $ctConditions '';
  951.         if (!empty($mcId)) {
  952.             $mcConditions " AND main_category_id = {$mcId}";
  953.         }
  954.         if (!empty($ctId) && $ctId !== 'allitem') {
  955.             $ctConditions " AND category_id IN ({$search_category})";
  956.         }
  957.         elseif (!empty($search_category)) {
  958.             $ctConditions " AND category_id IN ({$search_category})";
  959.         }
  960.         // ユニフォームネクストの商品掲載順を使用(おすすめとして扱う)
  961.         $use_recommended_order $this->dynamicConverter->useUnItemOrder($mcId$ctId);
  962.         $join_item_recommended_order '';
  963.         $orderType $this->session->has('order_type') ? $this->session->get('order_type') : $request->get('type');
  964.         if( $use_recommended_order && (int)$orderType === ){
  965.             $recommended_order_where_clause 'main_category_id = %d';
  966.             if( !empty($ctId) && strtolower($ctId) !== 'allitem' ){
  967.                 $recommended_order_where_clause .= ' AND category_id = %d';
  968.             }
  969.             else{
  970.                 $recommended_order_where_clause .= ' AND category_id IS NULL';
  971.             }
  972.             $join_item_recommended_order sprintf("
  973.                     LEFT JOIN(
  974.                         SELECT
  975.                             goods_id,
  976.                             is_un_order,
  977.                             display_order
  978.                         FROM
  979.                             goods_recommended_order_table
  980.                         WHERE
  981.                             {$recommended_order_where_clause}
  982.                     ) AS recommended_order
  983.                     USING(goods_id)
  984.                 ",
  985.                 $mcId,
  986.                 $ctId
  987.             );
  988.         }
  989.         /***** 商品情報取得(メイン) *****/
  990.         $strSQL "select SQL_CALC_FOUND_ROWS goods_id, goods_canonical_hinban, goods_recommend, goods_name, goods_sub_name, goods_caption, goods_display, goods_cdate, goods_udate, price2_min as price, kataban, NULL AS category_id, COALESCE(cra_average_points, 0) AS average, cra_target_count as review_count, goods_target_gender, goods_category_list_icon_id
  991.             from (
  992.                 select goods_id, goods_canonical_hinban, goods_recommend, goods_name, goods_sub_name, goods_caption, goods_display, goods_cdate, goods_udate, goods_target_gender, goods_category_list_icon_id,
  993.                 main_category_id, category_id
  994.                 from main_category_table
  995.                 inner join category_table on main_category_id = category_main_category
  996.                 inner join goods_category_table on category_id = gc_category
  997.                 inner join goods_table on goods_id = gc_goods
  998.                 where 1 = 1{$mcConditions}{$ctConditions} AND goods_ddate is null and goods_status = 1
  999.                 union
  1000.                 select goods_id, goods_canonical_hinban, goods_recommend, goods_name, goods_sub_name, goods_caption, goods_display, goods_cdate, goods_udate, goods_target_gender, goods_category_list_icon_id,
  1001.                 main_category_id, null as category_id
  1002.                 from main_category_table
  1003.                 inner join goods_main_category_table on main_category_id = gmc_main_category
  1004.                 inner join goods_table on goods_id = gmc_goods
  1005.                 where 1 = 1{$mcConditions} AND goods_ddate is null and goods_status = 1
  1006.             ) AS goods
  1007.             inner join goods_price_summary USING( goods_id )
  1008.             left join sales_volume_rank_table USING( goods_id )
  1009.             left join customer_review_average_table on cra_goods_id = goods_id
  1010.             {$join_item_recommended_order}
  1011.             WHERE 1 = 1{$mcConditions}";
  1012.         if( strtolower($ctId) !== 'allitem' $strSQL .= $ctConditions;
  1013.         $strSQL .= $strSQLWhere $strSQLGroup $strSQLHaving;
  1014.         if ($orderType == "1" ) {
  1015.             //安い順
  1016.             $strSQL .= " order by price, goods_recommend desc ";
  1017.         } elseif ($orderType == "3" ) {
  1018.             //高い順
  1019.             $strSQL .= " order by price desc, goods_recommend desc ";
  1020.         } elseif ($orderType == "4" ) {
  1021.             //品名順
  1022.             // $strSQL .= " order by cast( goods_name as binary ), goods_recommend desc ";
  1023.             $strSQL .= " order by goods_recommend desc ";
  1024.         } elseif ($orderType == "2" ) {
  1025.             //品番順
  1026.             $strSQL .= " order by kataban, goods_recommend desc ";
  1027.         } elseif ($orderType == "5" ) {
  1028.             // 評価順
  1029.             $strSQL .= " order by average desc, review_count desc,goods_recommend desc ";
  1030.         } elseif ($orderType == "6" and $use_recommended_order) {
  1031.             // おすすめ順(ユニフォームネクストの商品掲載順)
  1032.             // ユニフォームネクストと紐付きのない商品は、「ウェブスクレイピング画面で設定した順 > goods_id順’で表示
  1033.             $strSQL .= " order by is_un_order DESC, display_order IS NULL ASC, display_order ASC, goods_id";
  1034.         } else {
  1035.             $strSQL .= " order by isnull( quantities ), quantities DESC, goods_recommend desc, price, isnull( goods_display ), goods_display, goods_udate desc, goods_cdate desc ";
  1036.         }
  1037.         // Note. no に意図せずマイナス数値が与えられてしまった場合の保全対応として、limit に与える数値を判定する
  1038.         $start intval($request->get('no'));
  1039.         $start = ($start 0) ? $start;
  1040.         $strSQL .= ' limit ' $start ',' $max_display_cnt;
  1041.         $tempRow $this->dynamicConverter->getDataBySql($strSQL);
  1042.         if (empty($tempRow)) return [];
  1043.         $tmp_row 0;
  1044.         foreach ($tempRow as $row) {
  1045.             $tmp_row++;
  1046.             $ret['item'][$tmp_row-1] = $row;
  1047.         }
  1048.         /***** 商品数を取得 *****/
  1049.         $tempRow $this->dynamicConverter->getDataBySql("SELECT FOUND_ROWS()""{$mcId}_{$ctId}");
  1050.         $item_count $tempRow[0]['FOUND_ROWS()'];
  1051.         $ret['item_count'] = 0;
  1052.         $ret['style'] = "columnProduct3";
  1053.         $ret['search_area'] = "";
  1054.         $ret['col_count'] = 3;
  1055.         $ret['max_display_cnt'] = 30;
  1056.         $ret['item_count'] = $item_count;
  1057.         $data['item_count'] = $ret['item_count'];
  1058.         $data['style'] = $ret['style'];
  1059.         $data['search_area'] = $ret['search_area'];
  1060.         $data['col_count'] = $ret['col_count'];
  1061.         $data['item'] = $ret['item'];
  1062.         $an_search_base_color_list = array();
  1063.         $an_search_type_list = array();
  1064.         $an_search_size_list = array();
  1065.         for ($i 0$i count($data['item']); $i++) {
  1066.             $item_price_list[] = $data["item"][$i]["price"];
  1067.         }
  1068.         $data['max_price'] = max($item_price_list);
  1069.         $data['min_price'] = min($item_price_list);
  1070.         $data['style'] = "columnCoordinate0";
  1071.         $data['search_area'] = " style=\"display:none;\"";
  1072.         // $data['col_count'] = $sp == 1 ? 2 : 3;
  1073.         // 表示数チェック
  1074.         if (isset($_GET['no']) and intval($_GET['no']) > 0) {
  1075.             $data['min_cnt'] = min((intval($_GET['no']) + 1), $data['item_count']);
  1076.         } else {
  1077.             $data['min_cnt'] = min(1$data['item_count']);
  1078.         }
  1079.         $data['max_cnt'] = min($data['min_cnt'] + $max_display_cnt 1$data['item_count']);
  1080.         // クロスサイトスクリプティング対策
  1081.         if (isset($_GET['type']) and $_GET['type'] != "" and !preg_match("/^[0-9]+$/"$_GET['type'])) $_GET['type'] = "";
  1082.         if (isset($_GET['disp']) and $_GET['disp'] != "" and !preg_match("/^[0-9]+$/"$_GET['disp'])) $_GET['disp'] = "";
  1083.         /**
  1084.          * 「800-541……カテゴリページDB部分を変更したい-PC・スマホ両方」でページャーが刷新されたため、ここでのページャー生成はなくなったが、
  1085.          *
  1086.          */
  1087.         for ($i 1$i <= $data['item_count']; $i += $max_display_cnt) {
  1088.             if ($data['min_cnt'] >= $i and $data['max_cnt'] <= ($i $max_display_cnt)) {
  1089.                 $data['pager_pages_current_num'] = intval($i $max_display_cnt) + 1;
  1090.             }
  1091.         }
  1092.         // ソート用テーブル準備
  1093.         if (isset($_SESSION['order_type']) and $_SESSION['order_type'] == "1") {
  1094.             // 安い順
  1095.             for ($i 0$i $data['item_count']; $i++) {
  1096.                 $an_sort["$i"] = $data['item'][$i]['price'];
  1097.             }
  1098.             asort($an_sortSORT_NUMERIC);
  1099.         } elseif (isset($_SESSION['order_type']) and $_SESSION['order_type'] == "3") {
  1100.             // 高い順
  1101.             for ($i 0$i $data['item_count']; $i++) {
  1102.                 $an_sort["$i"] = $data['item'][$i]['price'];
  1103.             }
  1104.             arsort($an_sortSORT_NUMERIC);
  1105.         } elseif (isset($_SESSION['order_type']) and $_SESSION['order_type'] == "5") {
  1106.             // 評価・評価数の高い順
  1107.             for ($i 0$i $data['item_count']; $i++) {
  1108.                 $an_sort_tmp["$i"]['average'] = $data['item'][$i]['average'];
  1109.                 $an_sort_tmp["$i"]['review_count'] = $data['item'][$i]['review_count'];
  1110.                 $an_sort_tmp["$i"]['count'] = $i;
  1111.             }
  1112.             // 列方向の配列を得る
  1113.             foreach ($an_sort_tmp as $key => $row) {
  1114.                 $average[$key]  = $row['average'];
  1115.                 $review_count[$key] = $row['review_count'];
  1116.             }
  1117.             array_multisort($averageSORT_DESC$review_countSORT_DESC$an_sort_tmp);
  1118.             foreach($an_sort_tmp as $average_data){
  1119.                 $an_sort[$average_data['count']] = $average_data['count'];
  1120.             }
  1121.         } else {
  1122.             // 指定なし
  1123.             for ($i 0$i $data['item_count']; $i++) {
  1124.                 $an_sort["$i"] = $i;
  1125.             }
  1126.         }
  1127.         $i 0;
  1128.         foreach ($an_sort as $k => $v) {
  1129.             $an_v[$i] = $i;
  1130.             $i++;
  1131.         }
  1132.         $goodsIdList = array();
  1133.         for ($i 0$n count($data['item']); $i $n$i++) {
  1134.             $item $data['item'][$i];
  1135.             $goodsIdList[$item['goods_id']] = $item['goods_id'];
  1136.         }
  1137.         if (empty($goodsIdList)) {
  1138.             return array();
  1139.         }
  1140.         $goodsIdIn implode(','$goodsIdList);
  1141.         $res $this->GoodsService->getGoodsListByIds($goodsIdIn$data$an_v);
  1142.         return $res;
  1143.     }
  1144.     /**
  1145.      * @param string $mcName
  1146.      * @param string $ctName
  1147.      * @return string
  1148.      */
  1149.     public static function getMasterCacheKey($mcName$ctName null)
  1150.     {
  1151.         //
  1152.         if ($ctName === null) {
  1153.             //
  1154.             $masterCacheKey "main_category_index_mc_{$mcName}";
  1155.         } else {
  1156.                 //
  1157.                 $masterCacheKey "main_category_sub_mc_{$mcName}_ct_{$ctName}";
  1158.             }
  1159.         //
  1160.         $masterCacheKey str_replace('-''_'$masterCacheKey);
  1161.         //
  1162.         return $masterCacheKey;
  1163.     }
  1164.     /**
  1165.      * カテゴリページのページングに関する情報をセッションに保存する。
  1166.      *
  1167.      * @param Request $request リクエスト
  1168.      * 補足
  1169.      * CategoryService への実装を検討したが、getMainCategoryName や useUnItemOrder が
  1170.      * dynamicConverter に実装されているためここに実装。
  1171.      */
  1172.     private function setCategoryPagingSession(Request $request){
  1173.         $mc $request->attributes->get('mc');
  1174.         $ct $request->attributes->get('ct');
  1175.         /**
  1176.          * カテゴリ取得
  1177.          * カテゴリが見つからない場合はセッションをクリアして抜ける
  1178.          */
  1179.         $mainCategoryData $this->dynamicConverter->getMainCategoryName($mc);
  1180.         $isSubCategory = !is_null($ct) && $ct !== 'allitem';
  1181.         $subCategoryData $isSubCategory
  1182.             $this->dynamicConverter->getSubCategoryName($mainCategoryData['main_category_id'], $ct)
  1183.             : null
  1184.         ;
  1185.         /**
  1186.          * カテゴリが見つからない場合はセッションをクリアして抜ける
  1187.          */
  1188.         if( empty($mainCategoryData) || ($isSubCategory && empty($subCategoryData)) ){
  1189.             $this->session->remove('order_type');    // 「表示順」セッション
  1190.             return;
  1191.         }
  1192.         $mcId = (int)$mainCategoryData['main_category_id'];
  1193.         $ctId = isset($subCategoryData['category_id']) ? (int)$subCategoryData['category_id'] : null;
  1194.         // 「表示順」セッション
  1195.         $this->setCategoryOrderTypeSession($request$mcId$ctId);
  1196.     }
  1197.     /**
  1198.      * 「表示順」のセッションを設定する。
  1199.      *
  1200.      * ウェブスクレイピング(管理画面)でユニフォームネクストの商品掲載順をコピーしたカテゴリでは
  1201.      * 商品一覧を「オススメ順」として goods_recommended_order_table.display_order 順に並べる。
  1202.      * この時、フロント「表示順」に「オススメ順」が追加表示されデフォルトの並び順となる。
  1203.      * 初期表示では order_type パラメータが付かないため、order_type = 6 をセッションに保存しておく必要がある。
  1204.      *
  1205.      * ウェブスクレイピングでの掲載順コピーはカテゴリIDと商品掲載順しか管理していない(する必要がない)ため、
  1206.      * 配下カテゴリを考慮する必要はない。
  1207.      *
  1208.      * @param Request $request リクエスト
  1209.      * @param int $mcId メインカテゴリID
  1210.      * @param int|null $ctId サブカテゴリID
  1211.      */
  1212.     private function setCategoryOrderTypeSession(Request $request$mcId$ctId){
  1213.         // 「オススメ順」対応カテゴリか
  1214.         $useRecommendedOrder $this->dynamicConverter->useUnItemOrder($mcId$ctId);
  1215.         // カテゴリが「オススメ順」対応ではない場合
  1216.         if( !$useRecommendedOrder ){
  1217.             if( $this->session->has('order_type') ){
  1218.                 $this->session->remove('order_type');
  1219.             }
  1220.         }
  1221.         // カテゴリが「オススメ順」対応の場合
  1222.         else {
  1223.             // 「オススメ順」対応カテゴリで type の指定がない場合は「オススメ順」をデフォルトの表示順にする。
  1224.             if( is_null$request->get('type') ) ){
  1225.                 $this->session->set('order_type'6);
  1226.             }
  1227.             // type の指定がある場合は type を優先するためセッションをクリアする。
  1228.             else{
  1229.                 $this->session->remove('order_type');
  1230.             }
  1231.         }
  1232.     }
  1233. }