From 63b64631bbe51f011f03c7fa87a69aae3e3d333c Mon Sep 17 00:00:00 2001 From: Sajeeb Ahamed Date: Fri, 16 Jul 2021 17:03:55 +0600 Subject: [PATCH] :bug: fix the menu assigned template design not working issue --- .../system/helixultimate/helixultimate.php | 18 ++-- .../helixultimate/src/Platform/Helper.php | 89 ++++++++++++------- 2 files changed, 69 insertions(+), 38 deletions(-) diff --git a/plugins/system/helixultimate/helixultimate.php b/plugins/system/helixultimate/helixultimate.php index 016a0687..b5a94d9a 100644 --- a/plugins/system/helixultimate/helixultimate.php +++ b/plugins/system/helixultimate/helixultimate.php @@ -70,17 +70,21 @@ class PlgSystemHelixultimate extends JPlugin public function onAfterInitialise() { $template = Helper::loadTemplateData(); - $bootstrapPath = JPATH_ROOT . '/templates/' . $template->template . '/html/layouts/libraries/cms/html/bootstrap.php'; - if ($this->app->isClient('site') && \file_exists($bootstrapPath)) + if (isset($template->template) && !empty($template->template)) { - if (!class_exists('HelixBootstrap')) + $bootstrapPath = JPATH_ROOT . '/templates/' . $template->template . '/html/layouts/libraries/cms/html/bootstrap.php'; + + if ($this->app->isClient('site') && \file_exists($bootstrapPath)) { - require_once $bootstrapPath; - } + if (!class_exists('HelixBootstrap')) + { + require_once $bootstrapPath; + } - HTMLHelper::register('bootstrap.tooltip', ['HelixBootstrap', 'tooltip']); - HTMLHelper::register('bootstrap.popover', ['HelixBootstrap', 'popover']); + HTMLHelper::register('bootstrap.tooltip', ['HelixBootstrap', 'tooltip']); + HTMLHelper::register('bootstrap.popover', ['HelixBootstrap', 'popover']); + } } } diff --git a/plugins/system/helixultimate/src/Platform/Helper.php b/plugins/system/helixultimate/src/Platform/Helper.php index 717a2538..78ac8ceb 100644 --- a/plugins/system/helixultimate/src/Platform/Helper.php +++ b/plugins/system/helixultimate/src/Platform/Helper.php @@ -248,10 +248,22 @@ public static function loadTemplateData() { $templateId = 0; $app = Factory::getApplication(); + if ($app->isClient('site')) { $currentTemplate = $app->getTemplate(true); $templateId = $currentTemplate->id ?? 0; + + /** + * If a page/menu is assigned to a specific template + * then get the template ID. + */ + $activeMenu = $app->getMenu()->getActive(); + + if (!empty($activeMenu)) + { + $templateId = $activeMenu->template_style_id; + } } else { @@ -260,20 +272,26 @@ public static function loadTemplateData() $templateId = $app->input->get('id', 0, 'INT'); } } + + if (empty($templateId)) + { + $templateId = $app->input->get('helix_id', 0, 'INT'); + } + if($templateId) { $template = []; - + $draftKeyOptions = [ 'option' => 'com_ajax', 'helix' => 'ultimate', 'status' => 'draft', 'id' => $templateId ]; - + $draftKey = self::generateKey($draftKeyOptions); $cache = new HelixCache($draftKey); - + /** * Check the fetch destination. If it is iframe then load the settings * from draft, otherwise if it is document that means this request @@ -306,36 +324,45 @@ public static function loadTemplateData() $template = self::getTemplateStyle($templateId); } } - - if (!empty($template->params) && \is_string($template->params)) - { - $template->params = new Registry($template->params); - } - /** - * If params field is found empty in the database or cache then - * read the default options.json file from the template and assign - * the options as template params. - */ - elseif (empty($template->params)) - { - $filePath = JPATH_ROOT . '/templates/' . $template->template . '/' . 'options.json'; - - if (\file_exists($filePath)) - { - $defaultParams = \file_get_contents($filePath); - $template->params = new Registry($defaultParams); - } - else - { - $template->params = new Registry; - } - } - - return $template; + + // echo ''; + // print_r($template); + // echo ''; + + if (isset($template->template) && !empty($template->template)) + { + if (!empty($template->params) && \is_string($template->params)) + { + $template->params = new Registry($template->params); + } + /** + * If params field is found empty in the database or cache then + * read the default options.json file from the template and assign + * the options as template params. + */ + elseif (empty($template->params)) + { + $filePath = JPATH_ROOT . '/templates/' . $template->template . '/' . 'options.json'; + + if (\file_exists($filePath)) + { + $defaultParams = \file_get_contents($filePath); + $template->params = new Registry($defaultParams); + } + else + { + $template->params = new Registry; + } + } + + return $template; + } } - $template = new \stdClass(); - $template->template = ''; + + $template = new \stdClass; + $template->template = 'system'; $template->params = new Registry; + return $template; }