201 lines
6.5 KiB
PHP
201 lines
6.5 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace App\Core\Bootstraps;
|
||
|
|
||
|
use App\Core\Adapters\BootstrapBase;
|
||
|
use App\Core\Adapters\Menu;
|
||
|
use App\Core\Adapters\Theme;
|
||
|
|
||
|
class BootstrapDemo1 extends BootstrapBase
|
||
|
{
|
||
|
// Private Properties
|
||
|
private static $asideMenu;
|
||
|
|
||
|
private static $horizontalMenu;
|
||
|
|
||
|
// Private Methods
|
||
|
private static function initHeader()
|
||
|
{
|
||
|
if (Theme::getOption('layout', 'header/width') == 'fluid') {
|
||
|
Theme::addHtmlClass('header-container', 'container-fluid');
|
||
|
} else {
|
||
|
Theme::addHtmlClass('header-container', 'container');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'header/fixed/desktop') === true) {
|
||
|
Theme::addHtmlClass('body', 'header-fixed');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'header/fixed/tablet-and-mobile') === true) {
|
||
|
Theme::addHtmlClass('body', 'header-tablet-and-mobile-fixed');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static function initToolbar()
|
||
|
{
|
||
|
if (Theme::getOption('layout', 'toolbar/display') === false) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
Theme::addHtmlClass('body', 'toolbar-enabled');
|
||
|
|
||
|
if (Theme::getOption('layout', 'toolbar/width') == 'fluid') {
|
||
|
Theme::addHtmlClass('toolbar-container', 'container-fluid');
|
||
|
} else {
|
||
|
Theme::addHtmlClass('toolbar-container', 'container');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'toolbar/fixed/desktop') === true) {
|
||
|
Theme::addHtmlClass('body', 'toolbar-fixed');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'toolbar/fixed/tablet-and-mobile') === true) {
|
||
|
Theme::addHtmlClass('body', 'toolbar-tablet-and-mobile-fixed');
|
||
|
}
|
||
|
|
||
|
// Height setup
|
||
|
$type = Theme::getOption('layout', 'toolbar/layout');
|
||
|
$typeOptions = Theme::getOption('layout', 'toolbar/layouts/' . $type);
|
||
|
|
||
|
if ($typeOptions) {
|
||
|
if (isset($typeOptions['height'])) {
|
||
|
Theme::addCssVariable('body', '--kt-toolbar-height', $typeOptions['height']);
|
||
|
}
|
||
|
|
||
|
if (isset($typeOptions['height-tablet-and-mobile'])) {
|
||
|
Theme::addCssVariable('body', '--kt-toolbar-height-tablet-and-mobile', $typeOptions['height-tablet-and-mobile']);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static function initPageTitle()
|
||
|
{
|
||
|
if (Theme::getOption('layout', 'page-title/display') === false) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'page-title/direction') == 'column') {
|
||
|
Theme::addHtmlClass('page-title', 'flex-column align-items-start me-3');
|
||
|
} else {
|
||
|
Theme::addHtmlClass('page-title', 'align-items-center flex-wrap me-3');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'header/left') === 'page-title') {
|
||
|
Theme::setOption('layout', 'page-title/responsive-target', '#kt_header_nav');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'page-title/responsive') === true) {
|
||
|
Theme::addHtmlClass('page-title', 'mb-5 mb-lg-0');
|
||
|
|
||
|
$attr = array();
|
||
|
$attr['data-kt-swapper'] = 'true';
|
||
|
$attr['data-kt-swapper-mode'] = 'prepend';
|
||
|
$attr['data-kt-swapper-parent'] = "{default: '#kt_content_container', '" . Theme::getOption('layout', 'page-title/responsive-breakpoint') . "': '" . Theme::getOption('layout', 'page-title/responsive-target') . "'}";
|
||
|
|
||
|
Theme::addHtmlAttributes('page-title', $attr);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static function initContent()
|
||
|
{
|
||
|
if (Theme::getOption('layout', 'content/width') == 'fluid') {
|
||
|
Theme::addHtmlClass('content-container', 'container-fluid');
|
||
|
} elseif (Theme::getOption('layout', 'content/width') == 'fixed') {
|
||
|
Theme::addHtmlClass('content-container', 'container-xxl');
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'content/class')) {
|
||
|
Theme::addHtmlClass('content', Theme::getOption('layout', 'content/class'));
|
||
|
}
|
||
|
|
||
|
if (Theme::getOption('layout', 'content/container-class')) {
|
||
|
Theme::addHtmlClass('content-container', Theme::getOption('layout', 'content/container-class'));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static function initAside()
|
||
|
{
|
||
|
// Check if aside is displayed
|
||
|
if (Theme::getOption('layout', 'aside/display') != true) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
Theme::addHtmlClass('body', 'aside-enabled');
|
||
|
Theme::addHtmlClass('aside', 'aside-' . Theme::getOption('layout', 'aside/theme'));
|
||
|
|
||
|
// Fixed aside
|
||
|
if (Theme::getOption('layout', 'aside/fixed')) {
|
||
|
Theme::addHtmlClass('body', 'aside-fixed');
|
||
|
}
|
||
|
|
||
|
// Default minimized
|
||
|
if (Theme::getOption('layout', 'aside/minimized')) {
|
||
|
Theme::addHtmlAttribute('body', 'data-kt-aside-minimize', 'on');
|
||
|
}
|
||
|
|
||
|
// Hoverable on minimize
|
||
|
if (Theme::getOption('layout', 'aside/hoverable')) {
|
||
|
Theme::addHtmlClass('aside', 'aside-hoverable');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private static function initAsideMenu()
|
||
|
{
|
||
|
self::$asideMenu = new Menu(Theme::getOption('menu', 'main'), Theme::getPagePath());
|
||
|
|
||
|
if (Theme::getOption('layout', 'aside/menu-icons-display') === false) {
|
||
|
self::$asideMenu->displayIcons(false);
|
||
|
}
|
||
|
|
||
|
self::$asideMenu->setIconType(Theme::getOption('layout', 'aside/menu-icon'));
|
||
|
}
|
||
|
|
||
|
private static function initHorizontalMenu()
|
||
|
{
|
||
|
self::$horizontalMenu = new Menu(Theme::getOption('menu', 'horizontal'), Theme::getPagePath());
|
||
|
self::$horizontalMenu->setItemLinkClass('py-3');
|
||
|
self::$horizontalMenu->setIconType(Theme::getOption('layout', 'header/menu-icon', 'svg'));
|
||
|
}
|
||
|
|
||
|
private static function initFooter()
|
||
|
{
|
||
|
if (Theme::getOption('layout', 'footer/width') == 'fluid') {
|
||
|
Theme::addHtmlClass('footer-container', 'container-fluid');
|
||
|
} else {
|
||
|
Theme::addHtmlClass('footer-container', 'container-xxl');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Public Methods
|
||
|
public static function initLayout()
|
||
|
{
|
||
|
self::initHeader();
|
||
|
self::initPageTitle();
|
||
|
self::initToolbar();
|
||
|
self::initContent();
|
||
|
self::initAside();
|
||
|
self::initFooter();
|
||
|
self::initAsideMenu();
|
||
|
self::initHorizontalMenu();
|
||
|
}
|
||
|
|
||
|
public static function getAsideMenu()
|
||
|
{
|
||
|
return self::$asideMenu;
|
||
|
}
|
||
|
|
||
|
public static function getHorizontalMenu()
|
||
|
{
|
||
|
return self::$horizontalMenu;
|
||
|
}
|
||
|
|
||
|
public static function getBreadcrumb()
|
||
|
{
|
||
|
$options = array(
|
||
|
'skip-active' => false
|
||
|
);
|
||
|
|
||
|
return self::getAsideMenu()->getBreadcrumb($options);
|
||
|
}
|
||
|
}
|