-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcomponent.php
210 lines (196 loc) · 13.6 KB
/
component.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
<?php
/**
* @package Allrounder
* @subpackage Template
* @author Thomas Hunziker <[email protected]>
* @copyright (C) 2023 - Thomas Hunziker
* @license GNU/GPLv3 http://www.gnu.org/licenses/gpl-3.0.html
**/
defined('_JEXEC') or die();
use Joomla\CMS\Factory;
use Joomla\CMS\Helper\MediaHelper as MediaHelperAlias;
use Joomla\CMS\HTML\HTMLHelper;
use Joomla\CMS\Uri\Uri;
require_once 'helper/allrounder.php';
// Shortcuts
$app = Factory::getApplication();
$wa = $this->getWebAssetManager();
// Enable assets
$wa->usePreset('template.allrounder.' . ($this->direction === 'rtl' ? 'rtl' : 'ltr'))
->useStyle('template.active.language')
->useStyle('template.user')
->useScript('template.user');
// Override 'template.active' asset to set correct ltr/rtl dependency
$wa->registerStyle('template.active', '', [], [], ['template.allrounder.' . ($this->direction === 'rtl' ? 'rtl' : 'ltr')]);
// Browsers support SVG favicons
$this->addHeadLink(HTMLHelper::_('image', 'joomla-favicon.svg', '', [], true, 1), 'icon', 'rel', ['type' => 'image/svg+xml']);
$this->addHeadLink(HTMLHelper::_('image', 'favicon.ico', '', [], true, 1), 'alternate icon', 'rel', ['type' => 'image/vnd.microsoft.icon']);
$this->addHeadLink(HTMLHelper::_('image', 'joomla-favicon-pinned.svg', '', [], true, 1), 'mask-icon', 'rel', ['color' => '#000']);
$modules = JPATH_ROOT . '/templates/' . $this->template . '/modules/';
$params = $this->params;
// Get values from template style.
$bodyBackground = $params->get('bodyBackground', 'rgb(162, 205, 253)');
$bodyBackgroundImage = MediaHelperAlias::getCleanMediaFieldValue($params->get('bodyBackgroundImage', 'media/templates/site/allrounder/images/background.png'));
$bodyBackgroundImageRepeat = $params->get('bodyBackgroundImageRepeat', 1) ? 'repeat' : 'no-repeat';
$textColor = $params->get('textColor', 'rgb(33, 37, 41)');
$sansFontFamily = ($sansFontFamily = $params->get('sansFontFamily')) ? '--bs-font-sans-serif: ' . $sansFontFamily : '';
$contentHeadingImage = $params->get('contentheadingImage', 1);
$ribbon = $params->get('ribbonsOnOff', 1);
if ($contentHeadingImage == 1)
{
$contentHeadingImageValue = 'url(' . HTMLHelper::_('image', 'balloon.png', '', null, true, 1) . ')';
}
elseif ($contentHeadingImage == 2)
{
$contentHeadingImageValue = 'url(' . Uri::root() . MediaHelperAlias::getCleanMediaFieldValue($params->get('contentheadingImageMedia')) . ')';
}
else
{
$contentHeadingImageValue = '';
}
$wa->addInlineStyle(':root {
--bs-body-bg: ' . $bodyBackground . ';
--bs-body-bg-rgb: ' . str_replace(['rgb(', ')'], '', $bodyBackground) . ';
--bs-body-color: ' . $textColor . ';
--bs-body-color-rgb: ' . str_replace(['rgb(', ')'], '', $textColor) . ';
--bs-body-font-size: ' . $params->get('baseFontSize', '1rem') . ';
--bs-body-line-height: ' . $params->get('baseLineHeight', '1.5') . ';
' . $sansFontFamily . ';
--allrounder-link-color: ' . $params->get('linkColor', '#a52a2a') . ';
--allrounder-logo-color: ' . $params->get('logoColor', '#0299DC') . ';
--allrounder-slogan-color: ' . $params->get('sloganColor', '#FF2402') . ';
--allrounder-wrapper-bg-color: ' . $params->get('wrapperBgColor', 'rgba(239, 239, 239, 1)') . ';
--allrounder-wrapper-bg-opacity: ' . $params->get('wrapperBgOpacity', '100') / 100 . ';
--allrounder-wrapper-border-color: ' . $params->get('wrapperBorderColor', '#FFFFFF') . ';
--allrounder-header-bg-color: ' . $params->get('headBgColor', '#383838') . ';
--allrounder-header-bg-color-light: ' . AllrounderHelper::luminance($params->get('headBgColor', '#383838'), 0.4) . ';
--allrounder-header-border-color: ' . $params->get('headBorderColor', '#000000') . ';
--allrounder-header-ribbon-color: ' . $params->get('headRibbonColor', '#222222') . ';
--allrounder-subhead-bg-color: ' . $params->get('subheadBgColor', '#f9f9f9') . ';
--allrounder-subhead-bg-color-dark: ' . AllrounderHelper::luminance($params->get('subheadBgColor', '#f9f9f9'), -0.15) . ';
--allrounder-subhead-border-color: ' . $params->get('subheadBorderColor', '#ffffff') . ';
--allrounder-subhead-font-color: ' . $params->get('subheadFontColor', '#555555') . ';
--allrounder-content-bg-color: ' . $params->get('contentBgColor', '#f9f9f9') . ';
--allrounder-content-border-color: ' . $params->get('contentBorderColor', '#E9E9E9') . ';
--allrounder-article-bg-color: ' . $params->get('articleBgColor', '#ffffff') . ';
--allrounder-article-border-color: ' . $params->get('articleBorderColor', '#e9e9e9') . ';
--allrounder-article-font-color: ' . $params->get('articleTitleColor', '#484848') . ';
--allrounder-left-sidebar-width: ' . $params->get('leftcolWidth', '20%') . ';
--allrounder-right-sidebar-width: ' . $params->get('rightcolWidth', '20%') . ';
--allrounder-margin-top: ' . $params->get('wrapperMarginTop', '10px') . ';
--allrounder-margin-bottom: ' . $params->get('wrapperMarginBottom', '5px') . ';
--allrounder-padding-top: ' . $params->get('wrapperPaddingTop', '15px') . ';
--allrounder-padding-bottom: ' . $params->get('wrapperPaddingBottom', '10px') . ';
--allrounder-subfoot-bg-color: ' . $params->get('subfootBgColor', '#313131') . ';
--allrounder-subfoot-font-color: ' . $params->get('subfootColor', '#5b6c71') . ';
--allrounder-subfoot-border-top-color: ' . $params->get('subfootBorderTopColor', '#ffffff') . ';
--allrounder-subfoot-border-bottom-color: ' . $params->get('subfootBorderBottomColor', '#222222') . ';
--allrounder-footer-bg-color: ' . $params->get('footBgColor', '#222222') . ';
--allrounder-footer-bg-color-light: ' . AllrounderHelper::luminance($params->get('footBgColor', '#222222'), 0.4) . ';
--allrounder-footer-font-color: ' . $params->get('footColor', '#5B6C71') . ';
--allrounder-footer-border-color: ' . $params->get('footBorderColor', '#444444') . ';
--allrounder-footer-ribbon-color: ' . $params->get('footCornerColor', '#222222') . ';
--allrounder-footer-gotop-color: ' . $params->get('gotopLinkColor', '#ffffff') . ';
--allrounder-sidebar-module-title-bg-color: ' . $params->get('moduleh3BgColor', '#383838') . ';
--allrounder-sidebar-module-title-bg-color-light: ' . AllrounderHelper::luminance($params->get('moduleh3BgColor', '#383838'), 0.15) . ';
--allrounder-sidebar-module-title-border-color-top: ' . $params->get('moduleh3BorderTopColor', '#555555') . ';
--allrounder-sidebar-module-title-border-color-inner: ' . $params->get('moduleh3BorderInnerColor', '#555555') . ';
--allrounder-sidebar-module-title-border-color-outer: ' . $params->get('moduleh3BorderOuterColor', '#999999') . ';
--allrounder-sidebar-module-title-font-color: ' . $params->get('moduleh3Color', '#dddddd') . ';
--allrounder-sidebar-module-title-ribbon-color: ' . $params->get('moduleh3CornerColor', '#222222') . ';
--allrounder-sidebar-module-content-bg-color: ' . $params->get('moduleBgColor', '#f9f9f9') . ';
--allrounder-sidebar-module-content-border-color-inner: ' . $params->get('moduleBorderInnerColor', '#dddddd') . ';
--allrounder-sidebar-module-content-border-color-outer: ' . $params->get('moduleBorderOuterColor', '#ffffff') . ';
--allrounder-sidebar-module-content-font-color: ' . $params->get('moduleColor', '#505050') . ';
--allrounder-module-font-color: ' . $params->get('moduletableFont', '#505050') . ';
--allrounder-module-bg-color: ' . $params->get('moduletableBg', '#ffffff') . ';
--allrounder-module-border-color: ' . $params->get('moduletableBorder', '#dddddd') . ';
--allrounder-module-title-bg-color: ' . $params->get('moduletableh3Bg', '#efefef') . ';
--allrounder-module-title-bg-color-light: ' . AllrounderHelper::luminance($params->get('moduletableh3Bg', '#efefef'), 0.15) . ';
--allrounder-module-title-border-color: ' . $params->get('moduletableh3Border', '#dddddd') . ';
--allrounder-menu-font-color: ' . $params->get('mainMenuFont', '#333333') . ';
--allrounder-menu-border-bottom-color: ' . $params->get('mainMenuBorderBottom', '#cccccc') . ';
--allrounder-menu-font-hover-color: ' . $params->get('mainMenuFontHover', '#000000') . ';
--allrounder-menu-font-current-color: ' . $params->get('mainMenuFontCurrent', '#000000') . ';
--allrounder-menu-font-submenu-color: ' . $params->get('mainMenuLiLiFont', '#000000') . ';
--allrounder-input-font-color: ' . $params->get('inputFontColor', '#555555') . ';
--allrounder-input-bg-color: ' . $params->get('inputBackground', '#efefef') . ';
--allrounder-input-font-hover-color: ' . $params->get('inputHoverFontColor', '#555555') . ';
--allrounder-input-bg-hover-color: ' . $params->get('inputHoverBgColor', '#f9f9f9') . ';
--allrounder-input-border-left-color: ' . $params->get('inputBorderLeftColor', '#cccccc') . ';
--allrounder-input-border-top-color: ' . $params->get('inputBorderTopColor', '#cccccc') . ';
--allrounder-input-border-right-color: ' . $params->get('inputBorderRightColor', '#ffffff') . ';
--allrounder-input-border-bottom-color: ' . $params->get('inputBorderBottomColor', '#ffffff') . ';
--allrounder-button-font-color: ' . $params->get('buttonColor', '#555555') . ';
--allrounder-button-bg-color: ' . $params->get('buttonBgColor', '#efefef') . ';
--allrounder-button-bg-color-light: ' . AllrounderHelper::luminance($params->get('buttonBgColor', '#efefef'), .3) . ';
--allrounder-button-font-hover-color: ' . $params->get('buttonHoverColor', '#555555') . ';
--allrounder-button-bg-hover-color: ' . $params->get('buttonBgHoverColor', '#efefef') . ';
--allrounder-button-bg-hover-color-light: ' . AllrounderHelper::luminance($params->get('buttonBgHoverColor', '#efefef'), .3) . ';
--allrounder-button-border-left-color: ' . $params->get('buttonBorderLeft', '#cccccc') . ';
--allrounder-button-border-top-color: ' . $params->get('buttonBorderTop', '#cccccc') . ';
--allrounder-button-border-right-color: ' . $params->get('buttonBorderRight', '#ffffff') . ';
--allrounder-button-border-bottom-color: ' . $params->get('buttonBorderBottom', '#ffffff') . ';
--allrounder-tooltip-font-color: ' . $params->get('tooltipFont', '#800000') . ';
--allrounder-tooltip-bg-color: ' . $params->get('tooltipBg', '#F2F3F5') . ';
--allrounder-tooltip-border-color: ' . $params->get('tooltipBorder', '#A6A7AB') . ';
--allrounder-dropdown-bg-image: url(../images/menu/dropdown-' . $params->get('dropdownImage', 'smooth') . '.png);
--allrounder-dropdown-bg-image-parent: url(../images/menu/menu-parent-' . $params->get('dropdownImage', 'smooth') . '.png);
--allrounder-dropdown-bg-image-parent-hover: url(../images/menu/menu-parent-hover-' . $params->get('dropdownImage', 'smooth') . '.png);
--allrounder-dropdown-bg-color: ' . $params->get('ddBackground', '#222222') . ';
--allrounder-dropdown-border-top-color: ' . $params->get('ddBorderTop', '#ffffff') . ';
--allrounder-dropdown-border-bottom-color: ' . $params->get('ddBorderBottom', '#ffffff') . ';
--allrounder-dropdown-li-border-right-color: ' . $params->get('ulLiBorderRight', '#555555') . ';
--allrounder-dropdown-li-a-border-left-color: ' . $params->get('ulLiaBorderLeft', '#000000') . ';
--allrounder-dropdown-li-a-border-top-color: ' . $params->get('ulLiaBorderTop', '#000000') . ';
--allrounder-dropdown-li-a-border-right-color: ' . $params->get('ulLiaBorderRight', '#222222') . ';
--allrounder-dropdown-li-a-border-bottom-color: ' . $params->get('ulLiaBorderBottom', '#333333') . ';
--allrounder-dropdown-li-a-font-color: ' . $params->get('ulLiaColor', '#cccccc') . ';
--allrounder-dropdown-li-a-bg-color: ' . $params->get('ulLiaBackground', '#222222') . ';
--allrounder-dropdown-li-a-font-hover-color: ' . $params->get('ulLiaHoverColor', '#ffffff') . ';
--allrounder-dropdown-li-a-font-hover-color: ' . $params->get('ulLiaHoverColor', '#ffffff') . ';
--allrounder-dropdown-l2-ul-bg-color: ' . $params->get('ululBackground', '#222222') . ';
--allrounder-dropdown-l2-ul-border-color: ' . $params->get('ululBorder', '#000000') . ';
--allrounder-dropdown-l2-ul-li-a-border-left-color: ' . $params->get('ulLiliaBorderLeft', '#333333') . ';
--allrounder-dropdown-l2-ul-li-a-border-top-color: ' . $params->get('ulLiliaBorderTop', '#000000') . ';
--allrounder-dropdown-l2-ul-li-a-border-right-color: ' . $params->get('ulLiliaBorderRight', '#333333') . ';
--allrounder-dropdown-l2-ul-li-a-border-bottom-color: ' . $params->get('ulLiliaBorderBottom', '#333333') . ';
--allrounder-dropdown-l2-ul-li-a-font-color: ' . $params->get('ulLiliaColor', '#999999') . ';
--allrounder-dropdown-l2-ul-li-a-font-hover-color: ' . $params->get('ulLiliaHoverColor', '#ffffff') . ';
--allrounder-dropdown-l2-ul-li-a-bg-color: ' . $params->get('ulLiliBackground', '#171717') . ';
--allrounder-dropdown-l2-ul-li-a-bg-hover-color: ' . $params->get('ulLiliHoverBackground', '#212121') . ';
}
body {
background-image: url(' . MediaHelperAlias::getCleanMediaFieldValue($bodyBackgroundImage) . ');
background-repeat: ' . $bodyBackgroundImageRepeat . ';
}'
);
if ($contentHeadingImageValue)
{
$this->addStyleDeclaration('
.page-header h2,
h2.item-title {
background-image: ' . $contentHeadingImageValue . ';
background-repeat: no-repeat;
padding-left: 40px;
}');
}
?>
<!DOCTYPE html>
<html lang="<?php echo $this->language; ?>" dir="<?php echo $this->direction; ?>">
<head>
<meta name="viewport" content="width=device-width, initial-scale=1">
<jdoc:include type="metas"/>
<jdoc:include type="styles"/>
<jdoc:include type="scripts"/>
<?php if ($customCssCode = $params->get('customCssCode')) : ?>
<style><?php echo htmlspecialchars($customCssCode); ?></style>
<?php endif; ?>
</head>
<body class="<?php echo $this->direction === 'rtl' ? 'rtl' : ''; ?> component">
<div id="maincontent" class="row">
<jdoc:include type="message" />
<jdoc:include type="component" />
</div>
</body>
</html>