rdrew
2 months ago
commit
265d98be39
134 changed files with 31742 additions and 0 deletions
@ -0,0 +1,6 @@
|
||||
*.swp |
||||
*.swo |
||||
node_modules |
||||
do-not-upload |
||||
.tmp.drivedownload |
||||
.tmp.driveupload |
@ -0,0 +1 @@
|
||||
islandscholar theme, generated from vre2024. Additional information on generating themes can be found in the [Starterkit documentation](https://www.drupal.org/docs/core-modules-and-themes/core-themes/starterkit-theme). |
@ -0,0 +1,21 @@
|
||||
var browserSync = require('browser-sync'); |
||||
var themeName = 'vre2024'; |
||||
var siteUrl = 'https://library_local.lndo.site'; |
||||
var cssWatchDir = 'css/**/*.css'; |
||||
var themePath = '/themes/custom/vre2024'; |
||||
var filesToServe = '.'; |
||||
|
||||
browserSync({ |
||||
proxy: siteUrl, |
||||
files: cssWatchDir, |
||||
plugins: ['bs-rewrite-rules'], |
||||
serveStatic: [filesToServe], |
||||
rewriteRules: [ |
||||
{ |
||||
match: themePath, |
||||
replace: '' |
||||
//match: /\/themes\/custom\/vre2024/g,
|
||||
//replace: ''
|
||||
} |
||||
] |
||||
}); |
@ -0,0 +1,77 @@
|
||||
version 9.1.0 |
||||
15 Dec 2021 |
||||
+-----------------------------+ |
||||
# Initial release of series 9.x.x |
||||
|
||||
|
||||
version 9.1.1 |
||||
15 Dec 2021 |
||||
+-----------------------------+ |
||||
# Minor improvements |
||||
|
||||
|
||||
version 9.1.2 |
||||
23 Dec 2021 |
||||
+-----------------------------+ |
||||
# Fixed minor known bugs. |
||||
|
||||
|
||||
version 9.1.3 |
||||
08 Feb 2022 |
||||
+-----------------------------+ |
||||
- Added two new css variables --color-text, --color-heading |
||||
- Added new shortcode for light background "bg-light" |
||||
- Changed scroll to top arrow icon path. |
||||
|
||||
|
||||
version 9.2.0 |
||||
29 August 2022 |
||||
+-----------------------------+ |
||||
- Theme now supports Drupal 10 |
||||
- Added shortcode for text color - dark, light |
||||
- Added shortcode section-small |
||||
- Other minor changes and improvements. |
||||
|
||||
|
||||
version 10.0.0 |
||||
30 August 2023 |
||||
+-----------------------------+ |
||||
- Initial release of 10.x.x series |
||||
- Minor improvements. |
||||
|
||||
|
||||
version 10.0.1 |
||||
30 August 2023 |
||||
+-----------------------------+ |
||||
- Add custom font icon library. https://drupar.com/node/2875/ |
||||
- Updated Bootstrap Font Icons to version 1.10.5 |
||||
- Updated FontAwesome 5 Font Icons to version 5.15.4 |
||||
- Added styling for EU Cookie Compliance module. |
||||
- Minor improvements. |
||||
|
||||
|
||||
version 10.0.2 |
||||
31 August 2023 |
||||
+-----------------------------+ |
||||
- Removed menu--main.html.twig template file. |
||||
- Theme now uses menu.html.twig |
||||
- New animated mobile menu icon. |
||||
- Minor improvements. |
||||
|
||||
|
||||
version 10.0.3 |
||||
01 September 2023 |
||||
+-----------------------------+ |
||||
- New template file: header-primary-menu.html.twig |
||||
- Minor improvements of main menu. |
||||
|
||||
|
||||
version 10.0.4 |
||||
05 September 2023 |
||||
+-----------------------------+ |
||||
- Removed padding from sidebar. |
||||
- Removed margin-bottom from sidebar block. |
||||
- Removed margin bottom from main. |
||||
- Fixed display of contextual-links in header-top region. |
||||
- Added a default background color for footer. |
||||
- Added a default background color for sidebar blocks. |
@ -0,0 +1,24 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
config: |
||||
- system.menu.account |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_account_menu |
||||
theme: vre2024 |
||||
region: header_top_right |
||||
weight: -7 |
||||
provider: null |
||||
plugin: 'system_menu_block:account' |
||||
settings: |
||||
id: 'system_menu_block:account' |
||||
label: 'User account menu' |
||||
provider: system |
||||
label_display: '0' |
||||
level: 1 |
||||
depth: 1 |
||||
expand_all_items: false |
||||
visibility: { } |
@ -0,0 +1,22 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_branding |
||||
theme: vre2024 |
||||
region: header |
||||
weight: 0 |
||||
provider: null |
||||
plugin: system_branding_block |
||||
settings: |
||||
id: system_branding_block |
||||
label: 'Site branding' |
||||
provider: system |
||||
label_display: '0' |
||||
use_site_logo: true |
||||
use_site_name: true |
||||
use_site_slogan: true |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_breadcrumbs |
||||
theme: vre2024 |
||||
region: page_header |
||||
weight: -7 |
||||
provider: null |
||||
plugin: system_breadcrumb_block |
||||
settings: |
||||
id: system_breadcrumb_block |
||||
label: Breadcrumbs |
||||
provider: system |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_content |
||||
theme: vre2024 |
||||
region: content |
||||
weight: 0 |
||||
provider: null |
||||
plugin: system_main_block |
||||
settings: |
||||
id: system_main_block |
||||
label: 'Main page content' |
||||
provider: system |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,24 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
config: |
||||
- system.menu.footer |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_footer |
||||
theme: vre2024 |
||||
region: footer_four |
||||
weight: -11 |
||||
provider: null |
||||
plugin: 'system_menu_block:footer' |
||||
settings: |
||||
id: 'system_menu_block:footer' |
||||
label: 'Footer menu' |
||||
provider: system |
||||
label_display: '0' |
||||
level: 1 |
||||
depth: 0 |
||||
expand_all_items: false |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- help |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_help |
||||
theme: vre2024 |
||||
region: content |
||||
weight: -30 |
||||
provider: null |
||||
plugin: help_block |
||||
settings: |
||||
id: help_block |
||||
label: Help |
||||
provider: help |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,17 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_local_actions |
||||
theme: vre2024 |
||||
region: content |
||||
weight: -20 |
||||
provider: null |
||||
plugin: local_actions_block |
||||
settings: |
||||
id: local_actions_block |
||||
label: 'Primary admin actions' |
||||
provider: core |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_local_tasks |
||||
theme: vre2024 |
||||
region: content |
||||
weight: -40 |
||||
provider: null |
||||
plugin: local_tasks_block |
||||
settings: |
||||
id: local_tasks_block |
||||
label: Tabs |
||||
provider: core |
||||
label_display: '0' |
||||
primary: true |
||||
secondary: true |
||||
visibility: { } |
@ -0,0 +1,24 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
config: |
||||
- system.menu.main |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_main_menu |
||||
theme: vre2024 |
||||
region: primary_menu |
||||
weight: -8 |
||||
provider: null |
||||
plugin: 'system_menu_block:main' |
||||
settings: |
||||
id: 'system_menu_block:main' |
||||
label: 'Main navigation' |
||||
provider: system |
||||
label_display: '0' |
||||
level: 1 |
||||
depth: 1 |
||||
expand_all_items: false |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_messages |
||||
theme: vre2024 |
||||
region: highlighted |
||||
weight: 0 |
||||
provider: null |
||||
plugin: system_messages_block |
||||
settings: |
||||
id: system_messages_block |
||||
label: 'Status messages' |
||||
provider: system |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,17 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_page_title |
||||
theme: vre2024 |
||||
region: page_header |
||||
weight: -6 |
||||
provider: null |
||||
plugin: page_title_block |
||||
settings: |
||||
id: page_title_block |
||||
label: 'Page title' |
||||
provider: core |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,19 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_powered |
||||
theme: vre2024 |
||||
region: footer_bottom_left |
||||
weight: -7 |
||||
provider: null |
||||
plugin: system_powered_by_block |
||||
settings: |
||||
id: system_powered_by_block |
||||
label: 'Powered by Drupal' |
||||
provider: system |
||||
label_display: '0' |
||||
visibility: { } |
@ -0,0 +1,20 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
module: |
||||
- search |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_search |
||||
theme: vre2024 |
||||
region: search_box |
||||
weight: -8 |
||||
provider: null |
||||
plugin: search_form_block |
||||
settings: |
||||
id: search_form_block |
||||
label: Search |
||||
provider: search |
||||
label_display: visible |
||||
page_id: node_search |
||||
visibility: { } |
@ -0,0 +1,24 @@
|
||||
langcode: en |
||||
status: true |
||||
dependencies: |
||||
config: |
||||
- system.menu.tools |
||||
module: |
||||
- system |
||||
theme: |
||||
- vre2024 |
||||
id: vre2024_tools |
||||
theme: vre2024 |
||||
region: hidden |
||||
weight: -6 |
||||
provider: null |
||||
plugin: 'system_menu_block:tools' |
||||
settings: |
||||
id: 'system_menu_block:tools' |
||||
label: Tools |
||||
provider: system |
||||
label_display: visible |
||||
level: 1 |
||||
depth: 0 |
||||
expand_all_items: false |
||||
visibility: { } |
@ -0,0 +1,5 @@
|
||||
# Schema for the configuration files of vre2024 theme. |
||||
|
||||
vre2024.settings: |
||||
type: theme_settings |
||||
label: 'vre2024 Settings' |
@ -0,0 +1,549 @@
|
||||
/* Default box sizing. |
||||
---------------------------------------- */ |
||||
*, |
||||
*::before, |
||||
*::after { |
||||
box-sizing: border-box; |
||||
} |
||||
|
||||
/* Remove default margin */ |
||||
body, |
||||
h1, |
||||
h2, |
||||
h3, |
||||
h4, |
||||
h5, |
||||
h6, |
||||
figure, |
||||
blockquote, |
||||
dl, |
||||
dd { |
||||
margin: 0; |
||||
} |
||||
|
||||
/* HTML and Body |
||||
---------------------------------------- */ |
||||
html:focus-within { |
||||
scroll-behavior: smooth; |
||||
} |
||||
html { |
||||
font-size: 16px; |
||||
scroll-behavior: smooth; |
||||
} |
||||
html, |
||||
body { |
||||
height: 100%; |
||||
} |
||||
body { |
||||
color: var(--color-text); |
||||
background-color: var(--body-bg-color); |
||||
font-family: var(--body-font); |
||||
/*system-ui,*/ |
||||
/*-apple-system,*/ |
||||
/*BlinkMacSystemFont,*/ |
||||
/*'Segoe UI',*/ |
||||
/*Roboto,*/ |
||||
/*Oxygen,*/ |
||||
/*Ubuntu,*/ |
||||
/*Cantarell,*/ |
||||
/*'Open Sans',*/ |
||||
/*'Helvetica Neue',*/ |
||||
/*sans-serif;*/ |
||||
font-size: 1rem; |
||||
font-weight: 400; |
||||
min-height: 100vh; |
||||
margin: 0; |
||||
padding: 0; |
||||
line-height: 1.6; |
||||
text-rendering: optimizeSpeed; |
||||
overflow-x: hidden; |
||||
-webkit-font-smoothing: subpixel-antialiased; |
||||
-webkit-text-size-adjust: 100%; |
||||
-ms-text-size-adjust: 100%; |
||||
} |
||||
/* Regions |
||||
---------------------------------------- */ |
||||
article, |
||||
aside, |
||||
details, |
||||
figcaption, |
||||
figure, |
||||
footer, |
||||
header, |
||||
hgroup, |
||||
main, |
||||
menu, |
||||
nav, |
||||
section { |
||||
display: block; |
||||
} |
||||
summary { |
||||
display: list-item; |
||||
cursor: pointer; |
||||
} |
||||
details { |
||||
padding: 1rem; |
||||
margin-bottom: 1rem; |
||||
border: 1px solid var(--border); |
||||
} |
||||
template, |
||||
[hidden] { |
||||
display: none; |
||||
} |
||||
|
||||
/* Typography |
||||
---------------------------------------- */ |
||||
h1, |
||||
h2, |
||||
h3, |
||||
h4, |
||||
h5, |
||||
h6 { |
||||
font-family: var(--heading-font); |
||||
color: var(--color-heading); |
||||
font-weight: 700; |
||||
font-style: normal; |
||||
line-height: 1.6; |
||||
} |
||||
h1 { |
||||
font-size: var(--h1-size); |
||||
} |
||||
h2 { |
||||
font-size: var(--h2-size); |
||||
} |
||||
h3 { |
||||
font-size: var(--h3-size); |
||||
} |
||||
h4 { |
||||
font-size: var(--h4-size); |
||||
} |
||||
h5 { |
||||
font-size: var(--h5-size); |
||||
} |
||||
h6 { |
||||
font-size: var(--h6-size); |
||||
} |
||||
p { |
||||
margin: 0 0 1.2rem 0; |
||||
} |
||||
b, |
||||
strong { |
||||
font-weight: bolder; |
||||
} |
||||
dfn, |
||||
cite { |
||||
font-style: italic; |
||||
} |
||||
del { |
||||
text-decoration: line-through; |
||||
} |
||||
small { |
||||
font-size: 80%; |
||||
} |
||||
big { |
||||
font-size: 125%; |
||||
} |
||||
em { |
||||
font-style: normal; |
||||
} |
||||
a { |
||||
background-color: transparent; |
||||
text-decoration: none; |
||||
color: var(--primary); |
||||
} |
||||
a:active, |
||||
a:focus { |
||||
text-decoration: none; |
||||
border: 0; |
||||
outline: 0; |
||||
} |
||||
a:hover { |
||||
color: var(--secondary); |
||||
} |
||||
a:not([class]) { |
||||
text-decoration-skip-ink: auto; |
||||
} |
||||
/* Typography-> code tags */ |
||||
code, |
||||
kbd, |
||||
pre, |
||||
samp { |
||||
font-family: monospace, monospace; |
||||
font-size: 1rem; |
||||
} |
||||
kbd, |
||||
samp { |
||||
display: inline-block; |
||||
margin: 0; |
||||
padding: 0 5px; |
||||
} |
||||
pre { |
||||
overflow: auto; |
||||
margin: 1rem 0; |
||||
padding: 1rem; |
||||
tab-size: 2; |
||||
} |
||||
sub, |
||||
sup { |
||||
position: relative; |
||||
font-size: 75%; |
||||
line-height: 0; |
||||
vertical-align: baseline; |
||||
} |
||||
sub { |
||||
bottom: -0.25em; |
||||
} |
||||
sup { |
||||
top: -0.5em; |
||||
} |
||||
tt, |
||||
var { |
||||
font-family: monospace, monospace; |
||||
font-style: italic; |
||||
} |
||||
mark { |
||||
background: var(--primary); |
||||
} |
||||
acronym[title], |
||||
abbr[title] { |
||||
border-bottom: none; |
||||
text-decoration: underline; |
||||
-webkit-text-decoration: underline dotted; |
||||
text-decoration: underline dotted; |
||||
} |
||||
abbr, |
||||
acronym { |
||||
cursor: help; |
||||
} |
||||
|
||||
/* Media |
||||
---------------------------------------- */ |
||||
audio, |
||||
canvas, |
||||
progress, |
||||
video { |
||||
vertical-align: baseline; |
||||
max-width: 100%; |
||||
} |
||||
audio:not([controls]) { |
||||
display: none; |
||||
height: 0; |
||||
} |
||||
img, |
||||
picture, |
||||
svg { |
||||
max-width: 100% !important; |
||||
height: auto; |
||||
margin: 0; |
||||
padding: 0; |
||||
border: 0; |
||||
border-style: none; |
||||
vertical-align: middle; |
||||
} |
||||
svg:not(:root) { |
||||
overflow: hidden; |
||||
} |
||||
figure { |
||||
max-width: 100%; |
||||
height: auto; |
||||
margin: 1rem 0; |
||||
border: 0; |
||||
} |
||||
.align-left { |
||||
margin: 0 1rem 0 0; |
||||
} |
||||
.align-right { |
||||
margin: 0 0 0 1rem; |
||||
} |
||||
.align-center { |
||||
margin-top: 1rem; |
||||
margin-bottom: 1rem; |
||||
} |
||||
figcaption { |
||||
padding: 4px; |
||||
font-size: 0.8rem; |
||||
text-align: center; |
||||
} |
||||
.image-field { |
||||
margin: 0 0 1rem 0; |
||||
} |
||||
|
||||
/* Form |
||||
---------------------------------------- */ |
||||
form { |
||||
margin-bottom: 1rem; |
||||
} |
||||
button, |
||||
input, |
||||
optgroup, |
||||
select, |
||||
textarea { |
||||
font-family: inherit; |
||||
font-size: 100%; |
||||
line-height: 1.6; |
||||
margin: 0; |
||||
} |
||||
button, |
||||
input { |
||||
overflow: visible; |
||||
} |
||||
button, |
||||
select { |
||||
text-transform: none; |
||||
} |
||||
.button { |
||||
display: inline-block; |
||||
} |
||||
.button, |
||||
button, |
||||
[type="button"], |
||||
[type="reset"], |
||||
[type="submit"] { |
||||
position: relative; |
||||
cursor: pointer; |
||||
border: 0; |
||||
padding: 8px 10px; |
||||
line-height: 1.6; |
||||
-webkit-appearance: button; |
||||
background: var(--upei-green); |
||||
color: #fff; |
||||
border-radius: 4px; |
||||
font-family: var(--tabs-font); |
||||
font-optical-sizing: auto; |
||||
font-weight: 300; |
||||
font-style: normal; |
||||
/*font-variation-settings: "wdth" 75;*/ |
||||
} |
||||
button::-moz-focus-inner, |
||||
[type="button"]::-moz-focus-inner, |
||||
[type="reset"]::-moz-focus-inner, |
||||
[type="submit"]::-moz-focus-inner { |
||||
border-style: none; |
||||
padding: 0; |
||||
} |
||||
button:-moz-focusring, |
||||
[type="button"]:-moz-focusring, |
||||
[type="reset"]:-moz-focusring, |
||||
[type="submit"]:-moz-focusring { |
||||
outline: 0; |
||||
} |
||||
button[disabled], |
||||
html input[disabled] { |
||||
cursor: not-allowed; |
||||
opacity: 0.7; |
||||
} |
||||
::-webkit-file-upload-button { |
||||
-webkit-appearance: button; |
||||
font: inherit; |
||||
} |
||||
input, |
||||
button, |
||||
textarea, |
||||
select { |
||||
font: inherit; |
||||
} |
||||
input { |
||||
line-height: normal; |
||||
} |
||||
input, |
||||
textarea { |
||||
max-width: 100%; |
||||
} |
||||
input[type="text"], |
||||
input[type="email"], |
||||
input[type="url"], |
||||
input[type="password"], |
||||
input[type="search"], |
||||
textarea { |
||||
padding: 10px; |
||||
} |
||||
input[type="text"]:focus, |
||||
input[type="email"]:focus, |
||||
input[type="url"]:focus, |
||||
input[type="password"]:focus, |
||||
input[type="search"]:focus, |
||||
textarea:focus { |
||||
outline: 0; |
||||
} |
||||
textarea { |
||||
width: 100%; |
||||
overflow: auto; |
||||
} |
||||
[type="checkbox"], |
||||
[type="radio"] { |
||||
padding: 0; |
||||
cursor: pointer; |
||||
-webkit-box-sizing: border-box; |
||||
-moz-box-sizing: border-box; |
||||
box-sizing: border-box; |
||||
} |
||||
[type="number"]::-webkit-inner-spin-button, |
||||
[type="number"]::-webkit-outer-spin-button { |
||||
height: auto; |
||||
} |
||||
[type="search"] { |
||||
-webkit-appearance: textfield; |
||||
outline-offset: -2px; |
||||
-webkit-appearance: textfield; |
||||
-moz-appearance: textfield; |
||||
} |
||||
[type="search"]::-webkit-search-decoration { |
||||
-webkit-appearance: none; |
||||
} |
||||
[type="file"] { |
||||
cursor: pointer; |
||||
} |
||||
fieldset { |
||||
margin: 0 0 20px 0; |
||||
padding: 1rem; |
||||
} |
||||
fieldset > :last-child { |
||||
margin-bottom: 0; |
||||
} |
||||
legend { |
||||
box-sizing: border-box; |
||||
color: inherit; |
||||
display: table; |
||||
max-width: 100%; |
||||
padding: 0; |
||||
white-space: normal; |
||||
} |
||||
optgroup { |
||||
font-weight: bold; |
||||
} |
||||
select { |
||||
padding: 6px; |
||||
cursor: pointer; |
||||
} |
||||
label[for] { |
||||
cursor: pointer; |
||||
} |
||||
/* Form */ |
||||
.form-item { |
||||
margin-bottom: 1rem; |
||||
} |
||||
.form-required:after { |
||||
content: "*"; |
||||
display: inline-block; |
||||
padding-left: 4px; |
||||
color: red; |
||||
} |
||||
.form-item label { |
||||
display: block; |
||||
} |
||||
label.option { |
||||
display: inline; |
||||
font-weight: normal; |
||||
} |
||||
::-webkit-input-placeholder { |
||||
color: var(--border); |
||||
} |
||||
:-moz-placeholder { |
||||
color: var(--border); |
||||
} |
||||
::-moz-placeholder { |
||||
color: var(--border); |
||||
opacity: 1; |
||||
} |
||||
:-ms-input-placeholder { |
||||
color: var(--border); |
||||
} |
||||
.field--name-body input[type="text"], |
||||
.field--name-body input[type="email"], |
||||
.field--name-body input[type="url"], |
||||
.field--name-body input[type="password"], |
||||
.field--name-body input[type="search"], |
||||
.field--name-body textarea { |
||||
display: block; |
||||
margin-bottom: 0.8rem; |
||||
} |
||||
/* Common HTML Elements |
||||
---------------------------------------- */ |
||||
hr { |
||||
background-color: var(--border); |
||||
clear: both; |
||||
width: 100%; |
||||
max-width: 100%; |
||||
height: 2px; |
||||
border: 0; |
||||
-webkit-box-sizing: content-box; |
||||
box-sizing: content-box; |
||||
overflow: visible; |
||||
} |
||||
address { |
||||
margin: 0 0 1rem 0; |
||||
font-style: italic; |
||||
} |
||||
/* Definition Lists */ |
||||
dt { |
||||
font-weight: 700; |
||||
} |
||||
dd { |
||||
margin: 0 0 1.2rem 0; |
||||
} |
||||
blockquote { |
||||
position: relative; |
||||
background-color: var(--light); |
||||
margin: 1rem 0; |
||||
padding: 1rem; |
||||
} |
||||
blockquote > :last-child { |
||||
margin-bottom: 0; |
||||
} |
||||
|
||||
/* List |
||||
---------------------------------------- */ |
||||
ul, |
||||
ol { |
||||
margin: 0; |
||||
padding: 0 0 0.25rem 1rem; |
||||
} |
||||
[dir="rtl"] ul, |
||||
[dir="rtl"] ol { |
||||
padding: 0 1rem 0.25rem 0; |
||||
} |
||||
ol ol, |
||||
ul ul { |
||||
margin: 0; |
||||
padding: 0 0 0.25rem 1rem; |
||||
} |
||||
[dir="rtl"] ol ol, |
||||
[dir="rtl"] ul ul { |
||||
padding: 0 1rem 0.25rem 0; |
||||
} |
||||
ul { |
||||
list-style: disc; |
||||
} |
||||
li > ul, |
||||
li > ol { |
||||
margin-bottom: 0; |
||||
} |
||||
[dir="rtl"] ul, |
||||
[dir="rtl"] ol { |
||||
padding: 0 1rem 0.25rem 0; |
||||
} |
||||
li { |
||||
padding: 4px 0; |
||||
} |
||||
|
||||
/* Table |
||||
---------------------------------------- */ |
||||
table { |
||||
width: 100%; |
||||
margin-bottom: 1.2rem; |
||||
border-spacing: 0; |
||||
border-collapse: collapse; |
||||
} |
||||
th, |
||||
tr, |
||||
td { |
||||
vertical-align: middle; |
||||
} |
||||
th { |
||||
margin: 0; |
||||
padding: 5px; |
||||
text-align: left; |
||||
} |
||||
td { |
||||
padding: 5px; |
||||
} |
@ -0,0 +1,17 @@
|
||||
/* Common for all blocks */ |
||||
.block, |
||||
.block-title, |
||||
.block-content { |
||||
position: relative; |
||||
} |
||||
|
||||
.block-title { |
||||
/*font-size: var(--sidebar-block-title-font-size);*/ |
||||
/*font-family: var(--sidebar-block-title-font-family);*/ |
||||
/*color: var(--sidebar-block-title-font-color);*/ |
||||
} |
||||
.block-content { |
||||
/*font-size: var(--sidebar-block-font-size);*/ |
||||
/*font-family: var(--sidebar-block-font-family);*/ |
||||
/*color: var(--sidebar-block-font-color);*/ |
||||
} |
File diff suppressed because one or more lines are too long
@ -0,0 +1,11 @@
|
||||
/* Clearing |
||||
--------------------------------------*/ |
||||
.clear { |
||||
position: relative; |
||||
} |
||||
.clear::before, |
||||
.clear::after { |
||||
content: ''; |
||||
display: table; |
||||
clear: both; |
||||
} |
@ -0,0 +1,83 @@
|
||||
#comments { |
||||
position: relative; |
||||
margin: 0; |
||||
} |
||||
.comments-title i, |
||||
.add-comment-title i { |
||||
font-size: 1em; |
||||
} |
||||
/* Comment -> comment form */ |
||||
.comment-form-wrap { |
||||
position: relative; |
||||
margin: 2rem 0 1rem 0; |
||||
} |
||||
.add-comment-title { |
||||
margin: 0; |
||||
} |
||||
.comment-form label { |
||||
display: block; |
||||
} |
||||
/* Comments -> single comment */ |
||||
.comment { |
||||
position: relative; |
||||
background-color: var(--light); |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
flex-direction: column; |
||||
width: 100%; |
||||
margin-bottom: 1rem; |
||||
padding: 1rem; |
||||
} |
||||
.comment-header { |
||||
position: relative; |
||||
display: flex; |
||||
width: 100%; |
||||
border-bottom: 2px solid var(--border); |
||||
padding: 1rem; |
||||
margin-bottom: 1rem; |
||||
} |
||||
.comment-user-picture { |
||||
position: relative; |
||||
text-align: center; |
||||
align-self: center; |
||||
} |
||||
.comment-user-picture img { |
||||
max-width: 100px; |
||||
height: auto; |
||||
} |
||||
.comment-user-picture .image-field { |
||||
margin: 0; |
||||
} |
||||
.comment-meta { |
||||
padding-left: 1rem; |
||||
} |
||||
h3.comment-title { |
||||
font-size: 1.2rem; |
||||
margin: 0.1rem 0; |
||||
} |
||||
.comment-meta p { |
||||
margin: 0 |
||||
} |
||||
.comment-body { |
||||
position: relative; |
||||
width: 100%; |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1; |
||||
flex: 1 1; |
||||
} |
||||
#comments .indented { |
||||
margin-left: 3rem; |
||||
} |
||||
.comment-body .links { |
||||
display: flex; |
||||
gap: 1rem; |
||||
} |
||||
.comment-body .links a { |
||||
padding: 4px 12px; |
||||
border: 2px solid var(--border); |
||||
border-radius: 4px; |
||||
} |
||||
.comment-body .links a:hover { |
||||
background-color: #ffffff; |
||||
} |
@ -0,0 +1,224 @@
|
||||
/* Admin Toolbar */ |
||||
button.toolbar-item, |
||||
button.toolbar-icon { |
||||
background: none; |
||||
} |
||||
|
||||
/* Drupal system message */ |
||||
.message { |
||||
position: relative; |
||||
margin: 1rem 0; |
||||
padding: 1rem 1rem 1rem 4rem; |
||||
color: #ffffff; |
||||
} |
||||
.message a, |
||||
.message a:visited { |
||||
color: #ffffff; |
||||
text-decoration: underline; |
||||
} |
||||
.message p:last-child { |
||||
margin: 0; |
||||
} |
||||
.message em { |
||||
font-style: italic; |
||||
} |
||||
.message-status { |
||||
background: #89ad32; |
||||
} |
||||
.message-status::before { |
||||
content: url(../images/icons/message/success.svg); |
||||
background: #759625; |
||||
} |
||||
.message-error { |
||||
background: #c94d1c; |
||||
} |
||||
.message-error::before { |
||||
content: url(../images/icons/message/error.svg); |
||||
background-color: #b3461b; |
||||
} |
||||
.message-warning { |
||||
background: #cd5a0a; |
||||
} |
||||
.message-warning::before { |
||||
content: url(../images/icons/message/warning.svg); |
||||
background-color: #a44707; |
||||
} |
||||
.message::before { |
||||
position: absolute; |
||||
top: 0; |
||||
left: 0; |
||||
width: 3.6rem; |
||||
height: 100%; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
line-height: 0; |
||||
} |
||||
|
||||
/* Main -> Admin Tabs */ |
||||
ul.page-tabs { |
||||
margin: 0 0 0.6rem 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
border-bottom: 2px solid var(--primary); |
||||
} |
||||
.page-tabs li { |
||||
display: -webkit-inline-box; |
||||
display: -ms-inline-flexbox; |
||||
display: inline-flex; |
||||
padding: 0; |
||||
} |
||||
|
||||
.page-tabs li a { |
||||
font-family: var(--tabs-font); |
||||
font-optical-sizing: auto; |
||||
font-weight: 400; |
||||
font-style: normal; |
||||
font-variation-settings: |
||||
"wdth" 75; |
||||
background-color: var(--page-tab-bg-color); |
||||
color: var(--page-tab-text-color); |
||||
padding: 0.5rem 1rem; |
||||
border-right: 2px solid var(--page-tab-border-color); |
||||
} |
||||
.page-tabs li.active-page-tab a, |
||||
.page-tabs li a:hover { |
||||
color: var(--page-tab-text-color-active); |
||||
} |
||||
/* Node submitted details */ |
||||
.node-submitted-details { |
||||
position: relative; |
||||
display: flex; |
||||
justify-content: space-between; |
||||
align-items: center; |
||||
flex-wrap: wrap; |
||||
} |
||||
.node-submitted-details { |
||||
-webkit-flex: 1 1 auto; |
||||
-ms-flex: 1 1 auto; |
||||
flex: 1 1 auto; |
||||
} |
||||
/* Entity reference */ |
||||
.node-taxonomy-container, |
||||
.node-links-container { |
||||
position: relative; |
||||
display: block; |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 1rem 0; |
||||
} |
||||
h3.term-title { |
||||
font-size: 1.2em; |
||||
} |
||||
ul.taxonomy-terms { |
||||
margin: 10px 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
li.taxonomy-term { |
||||
position: relative; |
||||
display: inline-block; |
||||
padding: 0; |
||||
word-break: break-all; |
||||
} |
||||
li.taxonomy-term:not(:last-child) { |
||||
margin-right: 1rem; |
||||
} |
||||
.taxonomy-term a { |
||||
padding: 6px 14px; |
||||
border: 2px solid var(--border); |
||||
} |
||||
/* Node Links */ |
||||
.node-links-container ul.links { |
||||
position: relative; |
||||
margin: 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
.node-links-container .links { |
||||
display: flex; |
||||
justify-content: space-between; |
||||
flex-wrap: wrap; |
||||
} |
||||
ul.inline, |
||||
ul.links.inline { |
||||
padding-left: 0; |
||||
} |
||||
ul.inline li { |
||||
position: relative; |
||||
display: inline-block; |
||||
list-style-type: none; |
||||
} |
||||
ul.inline li a { |
||||
display: inline-block; |
||||
} |
||||
/* Pager */ |
||||
.pager { |
||||
position: relative; |
||||
} |
||||
.pager ul.pager__items { |
||||
position: relative; |
||||
margin: 0; |
||||
padding: 1rem 0; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
.pager__items { |
||||
clear: both; |
||||
text-align: center; |
||||
} |
||||
.pager__item { |
||||
display: inline-block; |
||||
padding: 12px 0; |
||||
} |
||||
.pager__item a { |
||||
padding: 8px 14px; |
||||
color: #fff; |
||||
background: var(--dark); |
||||
} |
||||
.pager__item a:hover, |
||||
.pager__item.is-active a { |
||||
background: var(--primary); |
||||
color: #fff; |
||||
} |
||||
/* vertical Tabs */ |
||||
.vertical-tabs__panes { |
||||
padding: 1rem; |
||||
} |
||||
/* components -> Scroll To Top. */ |
||||
.scrolltop { |
||||
position: fixed; |
||||
display: none; |
||||
bottom: 10px; |
||||
right: 10px; |
||||
width: 50px; |
||||
height: 50px; |
||||
border-radius: 50%; |
||||
background: var(--primary); |
||||
color: #ffffff; |
||||
font-size: 20px; |
||||
z-index: 20; |
||||
cursor: pointer; |
||||
text-align: center; |
||||
padding: 4px; |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
} |
||||
.scrolltop:hover { |
||||
background: var(--secondary); |
||||
} |
@ -0,0 +1,32 @@
|
||||
/** |
||||
* Drupal core |
||||
*/ |
||||
/* Core -> contextual-links */ |
||||
.header-top .contextual-links { |
||||
display: none; |
||||
} |
||||
/* Core -> Fields */ |
||||
[dir] .field:not(:last-child){ |
||||
margin-bottom:36px; |
||||
} |
||||
|
||||
.field__label { |
||||
font-weight: bold; |
||||
} |
||||
.field--label-inline .field__label, |
||||
.field--label-inline .field__items { |
||||
float: left; /* LTR */ |
||||
} |
||||
.field--label-inline .field__label, |
||||
.field--label-inline > .field__item, |
||||
.field--label-inline .field__items { |
||||
padding-right: 0.5rem; |
||||
} |
||||
[dir="rtl"] .field--label-inline .field__label, |
||||
[dir="rtl"] .field--label-inline .field__items { |
||||
padding-right: 0; |
||||
padding-left: 0.5rem; |
||||
} |
||||
.field--label-inline .field__label::after { |
||||
content: ":"; |
||||
} |
@ -0,0 +1,70 @@
|
||||
/* EU Cookie Compliance module */ |
||||
div#sliding-popup, div#sliding-popup .eu-cookie-withdraw-banner, .eu-cookie-withdraw-tab { |
||||
background-color: #ffffff; |
||||
box-shadow: 0 0 6px 2px var(--border); |
||||
left: 0; |
||||
} |
||||
#sliding-popup { |
||||
padding: 2rem; |
||||
max-width: 540px; |
||||
} |
||||
#sliding-popup .popup-content { |
||||
display: flex; |
||||
flex-direction: column; |
||||
gap: 1rem; |
||||
} |
||||
.eu-cookie-compliance-content { |
||||
max-width: 100%; |
||||
} |
||||
.eu-cookie-compliance-message { |
||||
float: none; |
||||
margin: 0; |
||||
max-width: 100%; |
||||
} |
||||
#sliding-popup div, |
||||
#sliding-popup h2 { |
||||
color: var( --color-heading); |
||||
} |
||||
#sliding-popup h2 { |
||||
font-size: 1.2rem; |
||||
} |
||||
#sliding-popup p { |
||||
display: block; |
||||
color: var(--color-text); |
||||
font-size: 1rem; |
||||
font-weight: 400; |
||||
} |
||||
.eu-cookie-compliance-message button { |
||||
background-color: transparent; |
||||
color: var(--primary); |
||||
margin: 0; |
||||
padding: 0; |
||||
border: 0; |
||||
} |
||||
.eu-cookie-compliance-message button:hover { |
||||
background-color: transparent; |
||||
color: var( --color-heading); |
||||
} |
||||
.eu-cookie-compliance-buttons { |
||||
display: flex; |
||||
gap: 1rem; |
||||
float: none; |
||||
margin: 0; |
||||
max-width: 100%; |
||||
} |
||||
.eu-cookie-compliance-buttons .button { |
||||
background-color: transparent; |
||||
background-image: none; |
||||
color: var(--primary); |
||||
font-weight: 400; |
||||
margin: 0; |
||||
padding: 8px 1rem; |
||||
border: 2px solid var( --color-heading); |
||||
text-shadow: none; |
||||
box-shadow: none; |
||||
border-radius: 0; |
||||
} |
||||
.eu-cookie-compliance-buttons .button:hover { |
||||
background-color: var( --color-heading); |
||||
color: #ffffff; |
||||
} |
@ -0,0 +1,166 @@
|
||||
/*! |
||||
* The-X icon font. Generated by Iconly: https://iconly.io/ |
||||
*/ |
||||
|
||||
@font-face { |
||||
font-display: auto; |
||||
font-family: "vre2024"; |
||||
font-style: normal; |
||||
font-weight: 400; |
||||
src: url("../fonts/vre2024.woff2") format("woff2"); |
||||
} |
||||
|
||||
[class="icon"], [class^="icon-"], [class*=" icon-"] { |
||||
display: inline-block; |
||||
font-family: "vre2024" !important; |
||||
font-weight: 400; |
||||
font-style: normal; |
||||
font-variant: normal; |
||||
text-rendering: auto; |
||||
line-height: 1; |
||||
-moz-osx-font-smoothing: grayscale; |
||||
-webkit-font-smoothing: antialiased; |
||||
} |
||||
.icon-close:before { |
||||
content: "\e000"; |
||||
} |
||||
|
||||
.icon-search:before { |
||||
content: "\e001"; |
||||
} |
||||
|
||||
.icon-user:before { |
||||
content: "\e002"; |
||||
} |
||||
|
||||
.icon-calendar:before { |
||||
content: "\e003"; |
||||
} |
||||
|
||||
.icon-twitter:before { |
||||
content: "\e004"; |
||||
} |
||||
|
||||
.icon-facebook:before { |
||||
content: "\e005"; |
||||
} |
||||
|
||||
.icon-github:before { |
||||
content: "\e006"; |
||||
} |
||||
|
||||
.icon-linkedin:before { |
||||
content: "\e007"; |
||||
} |
||||
|
||||
.icon-comments:before { |
||||
content: "\e008"; |
||||
} |
||||
|
||||
.icon-file:before { |
||||
content: "\e009"; |
||||
} |
||||
|
||||
.icon-youtube:before { |
||||
content: "\e00a"; |
||||
} |
||||
|
||||
.icon-instagram:before { |
||||
content: "\e00b"; |
||||
} |
||||
|
||||
.icon-vk:before { |
||||
content: "\e00c"; |
||||
} |
||||
|
||||
.icon-whatsapp:before { |
||||
content: "\e00d"; |
||||
} |
||||
|
||||
.icon-vimeo:before { |
||||
content: "\e00e"; |
||||
} |
||||
|
||||
.icon-hashtag:before { |
||||
content: "\e00f"; |
||||
} |
||||
|
||||
.icon-telegram:before { |
||||
content: "\e010"; |
||||
} |
||||
|
||||
.icon-share:before { |
||||
content: "\e011"; |
||||
} |
||||
|
||||
.icon-mail:before { |
||||
content: "\e012"; |
||||
} |
||||
|
||||
.icon-map:before { |
||||
content: "\e013"; |
||||
} |
||||
|
||||
.icon-phone:before { |
||||
content: "\e014"; |
||||
} |
||||
|
||||
.icon-arrow-up:before { |
||||
content: "\e015"; |
||||
} |
||||
|
||||
.icon-horn:before { |
||||
content: "\e016"; |
||||
} |
||||
|
||||
.icon-bell:before { |
||||
content: "\e017"; |
||||
} |
||||
|
||||
.icon-info:before { |
||||
content: "\e018"; |
||||
} |
||||
|
||||
.icon-comment:before { |
||||
content: "\e019"; |
||||
} |
||||
|
||||
.icon-angle-left:before { |
||||
content: "\e01a"; |
||||
} |
||||
|
||||
.icon-angle-right:before { |
||||
content: "\e01b"; |
||||
} |
||||
|
||||
.icon-arrow-right:before { |
||||
content: "\e01c"; |
||||
} |
||||
|
||||
.icon-arrow-left:before { |
||||
content: "\e01d"; |
||||
} |
||||
|
||||
.icon-quote:before { |
||||
content: "\e01e"; |
||||
} |
||||
|
||||
.icon-clock:before { |
||||
content: "\e01f"; |
||||
} |
||||
|
||||
.icon-alert-circle:before { |
||||
content: "\e020"; |
||||
} |
||||
|
||||
.icon-alert:before { |
||||
content: "\e021"; |
||||
} |
||||
|
||||
.icon-check:before { |
||||
content: "\e022"; |
||||
} |
||||
|
||||
.icon-comment-add:before { |
||||
content: "\e024"; |
||||
} |
@ -0,0 +1,88 @@
|
||||
/*@format*/ |
||||
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wdth,wght@0,62.5..100,100..900;1,62.5..100,100..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap'); |
||||
|
||||
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap'); |
||||
.roboto-condensed-normal { |
||||
font-family: 'Roboto Condensed', sans-serif; |
||||
font-optical-sizing: auto; |
||||
font-weight: 400; |
||||
font-style: normal; |
||||
} |
||||
.roboto-condensed-thin { |
||||
font-family: 'Roboto Condensed', sans-serif; |
||||
font-optical-sizing: auto; |
||||
font-weight: 200; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-thin { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 100; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-light { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 300; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-regular { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 400; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-medium { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 500; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-bold { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 700; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-black { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 900; |
||||
font-style: normal; |
||||
} |
||||
|
||||
.roboto-thin-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 100; |
||||
font-style: italic; |
||||
} |
||||
|
||||
.roboto-light-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 300; |
||||
font-style: italic; |
||||
} |
||||
|
||||
.roboto-regular-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 400; |
||||
font-style: italic; |
||||
} |
||||
|
||||
.roboto-medium-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 500; |
||||
font-style: italic; |
||||
} |
||||
|
||||
.roboto-bold-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 700; |
||||
font-style: italic; |
||||
} |
||||
|
||||
.roboto-black-italic { |
||||
font-family: 'Roboto', sans-serif; |
||||
font-weight: 900; |
||||
font-style: italic; |
||||
} |
@ -0,0 +1,91 @@
|
||||
/** |
||||
* footer |
||||
*/ |
||||
/* Footer */ |
||||
.footer { |
||||
position: relative; |
||||
background-color: var(--footer-bg-color); |
||||
color: var(--footer-text-color); |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 0; |
||||
a { |
||||
color: var(--footer-link-color); |
||||
} |
||||
} |
||||
.footer ul { |
||||
list-style: none; |
||||
padding: 0; |
||||
} |
||||
.footer .block p:last-of-type { |
||||
margin: 0; |
||||
} |
||||
/* Footer -> Footer Top */ |
||||
.footer-top-container { |
||||
position: relative; |
||||
padding: 1rem 0; |
||||
} |
||||
.region-footer-top { |
||||
display: flex; |
||||
flex-direction: column; |
||||
gap: 1.5rem; |
||||
} |
||||
/* Footer -> 4 Column blocks */ |
||||
.footer-blocks-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-ms-flex-wrap: wrap; |
||||
flex-wrap: wrap; |
||||
padding: 2rem 0; |
||||
gap: 1.5rem; |
||||
} |
||||
.footer-block { |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1 250px; |
||||
flex: 1 1 250px; |
||||
} |
||||
.footer-block li { |
||||
border-bottom: 1px solid var(--border); |
||||
} |
||||
/* Footer -> Footer Bottom */ |
||||
.footer-bottom-blocks-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
padding: 1rem 0; |
||||
gap: 2rem; |
||||
} |
||||
.footer-bottom-block { |
||||
flex: 1; |
||||
} |
||||
.footer-bottom-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
padding: 1rem 0; |
||||
gap: 2rem; |
||||
} |
||||
.footer-bottom-container p:last-child { |
||||
margin: 0; |
||||
} |
||||
.footer-bottom-last-menu { |
||||
margin: 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
} |
||||
.footer-bottom-last-menu li { |
||||
display: inline-block; |
||||
padding-left: 1rem; |
||||
} |
@ -0,0 +1,455 @@
|
||||
/* |
||||
* Header main |
||||
*/ |
||||
/* Header -> Header top */ |
||||
.header-top, |
||||
.header { |
||||
position: relative; |
||||
width: 100%; |
||||
margin: 0; |
||||
} |
||||
.header-top { |
||||
padding: 0.5rem 0; |
||||
} |
||||
.header { |
||||
padding: var(--header-padding) 0; |
||||
border-bottom: var(--header-bottom-border); |
||||
} |
||||
.header-top, |
||||
.header-top a { |
||||
font-weight: 300; |
||||
font-variation-settings: "wdth" 75; |
||||
background: var(--header-top-bg-color); |
||||
color: var(--header-top-text-color); |
||||
font-size: 0.8rem; |
||||
} |
||||
.header { |
||||
background: var(--header-bg-color); |
||||
color: var(--header-text-color); |
||||
} |
||||
.header-top-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
gap: 1rem; |
||||
flex-wrap: wrap; |
||||
} |
||||
.region-header-top-left, |
||||
.region-header-top-right { |
||||
display: flex; |
||||
gap: 1rem; |
||||
flex-wrap: wrap; |
||||
} |
||||
.header-top-block p:last-of-type { |
||||
margin: 0; |
||||
} |
||||
.header-top ul { |
||||
display: flex; |
||||
gap: 10px; |
||||
flex-wrap: wrap; |
||||
margin: 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
.header-top-block .block-title { |
||||
font-size: 1.2rem; |
||||
} |
||||
/* Header -> Header main */ |
||||
.header-main { |
||||
position: relative; |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
.header-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
gap: 1rem; |
||||
} |
||||
/* Header -> Site branding */ |
||||
.site-branding { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
padding-right: 1rem; |
||||
} |
||||
.site-logo { |
||||
padding-right: var(--branding-separator-padding); |
||||
margin-right: var(--branding-separator-padding); |
||||
width: var(--logo-width); |
||||
border-right: var(--branding-separator); |
||||
} |
||||
.site-logo img { |
||||
display: block; |
||||
} |
||||
.site-name-slogan { |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
} |
||||
.site-name, |
||||
.site-slogan { |
||||
line-height: 1.1; |
||||
} |
||||
.site-slogan { |
||||
font-family: var(--site-slogan-font-family); |
||||
font-size: var(--site-slogan-font-size); |
||||
color: var(--site-slogan-font-color); |
||||
} |
||||
.site-name { |
||||
a { |
||||
font-family: var(--heading-font); |
||||
font-size: var(--site-name-font-size); |
||||
color: var(--site-name-font-color); |
||||
} |
||||
} |
||||
|
||||
/* Header -> header right */ |
||||
.header-right { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
gap: 0.5rem; |
||||
} |
||||
.menu-wrap { |
||||
position: fixed; |
||||
background-color: var(--dark); |
||||
color: #ffffff; |
||||
top: 0; |
||||
bottom: 0; |
||||
left: 0; |
||||
margin: 0; |
||||
width: 100%; |
||||
max-width: 320px; |
||||
box-shadow: none; |
||||
z-index: 25; |
||||
-webkit-transform: translateX(-100%); |
||||
-ms-transform: translateX(-100%); |
||||
transform: translateX(-100%); |
||||
-webkit-transition: all 0.4s linear; |
||||
-o-transition: all 0.4s linear; |
||||
transition: all 0.4s linear; |
||||
} |
||||
.menu-wrap .menu { |
||||
position: relative; |
||||
display: flex; |
||||
flex-direction: column; |
||||
gap: 1rem; |
||||
flex-wrap: wrap; |
||||
margin: 0; |
||||
padding: 0; |
||||
font-size: 1rem; |
||||
font-weight: 400; |
||||
z-index: 30; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
.menu-wrap .menu li { |
||||
position: relative; |
||||
padding: 0; |
||||
} |
||||
.menu-wrap a { |
||||
display: block; |
||||
color: #ffffff; |
||||
padding: 0.5rem 0; |
||||
font-variation-settings: "wdth" var(--header-menu-font-width); |
||||
} |
||||
.menu-wrap .menu > li a::after { |
||||
content: none; |
||||
} |
||||
.menu-wrap .submenu { |
||||
position: relative; |
||||
display: flex; |
||||
flex-direction: column; |
||||
font-weight: 400; |
||||
margin: 0; |
||||
padding: 0; |
||||
z-index: 30; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
.menu-wrap .submenu li a, |
||||
.menu-wrap .submenu li > span { |
||||
display: flex; |
||||
width: 100%; |
||||
padding: 0.5rem; |
||||
} |
||||
.menu-wrap .menu-item a, |
||||
.menu-wrap .menu-item > span { |
||||
border-bottom: 1px solid var(--border); |
||||
} |
||||
.menu-wrap .submenu li > a, |
||||
.menu-wrap .submenu li > span { |
||||
padding-left: 1.5rem; |
||||
} |
||||
.menu-wrap .submenu .submenu .menu-item > a, |
||||
.menu-wrap .submenu .submenu .menu-item > span { |
||||
padding-left: 3rem; |
||||
} |
||||
/* Mobile Menu */ |
||||
.mobile-menu { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
justify-content: space-between; |
||||
width: 36px; |
||||
height: 28px; |
||||
overflow: hidden; |
||||
cursor: pointer; |
||||
} |
||||
.mobile-menu span { |
||||
width: 100%; |
||||
height: 2px; |
||||
background-color: var(--primary); |
||||
transform-origin: left; |
||||
transition: all 0.5s ease; |
||||
} |
||||
.mobile-menu span:nth-child(2) { |
||||
background-color: var(--secondary); |
||||
} |
||||
.menu-icon-active span:first-child { |
||||
transform: rotate(45deg); |
||||
} |
||||
.menu-icon-active span:last-child { |
||||
transform: rotate(-45deg); |
||||
} |
||||
.menu-icon-active span:nth-child(2) { |
||||
display: none; |
||||
} |
||||
.close-mobile-menu { |
||||
display: grid; |
||||
place-content: center; |
||||
position: absolute; |
||||
top: 4px; |
||||
right: 4px; |
||||
width: 34px; |
||||
height: 34px; |
||||
color: #ffffff; |
||||
border: 2px solid var(--primary); |
||||
border-radius: 50%; |
||||
z-index: 48; |
||||
cursor: pointer; |
||||
} |
||||
.active-menu .menu-wrap { |
||||
overflow-y: scroll; |
||||
-webkit-transform: translateX(0); |
||||
-ms-transform: translateX(0); |
||||
transform: translateX(0); |
||||
-webkit-transition: all 0.4s linear; |
||||
-o-transition: all 0.4s linear; |
||||
transition: all 0.4s linear; |
||||
padding: 1rem; |
||||
box-shadow: 6px 0 1rem #111111; |
||||
} |
||||
.active-menu .menu { |
||||
display: block; |
||||
} |
||||
/*slide up */ |
||||
@-webkit-keyframes slideUp { |
||||
0% { |
||||
-webkit-transform: translateY(20px); |
||||
transform: translateY(20px); |
||||
opacity: 0; |
||||
} |
||||
100% { |
||||
-webkit-transform: translateY(0px); |
||||
transform: translateY(0px); |
||||
opacity: 1; |
||||
} |
||||
} |
||||
@keyframes slideUp { |
||||
0% { |
||||
-webkit-transform: translateY(20px); |
||||
transform: translateY(20px); |
||||
opacity: 0; |
||||
} |
||||
100% { |
||||
-webkit-transform: translateY(0px); |
||||
transform: translateY(0px); |
||||
opacity: 1; |
||||
} |
||||
} |
||||
/* Header -> header search form */ |
||||
.full-page-search { |
||||
position: relative; |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
.search-icon { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
cursor: pointer; |
||||
width: 34px; |
||||
height: 34px; |
||||
border-radius: 50%; |
||||
} |
||||
.search-icon i { |
||||
font-size: 24px; |
||||
} |
||||
.search-box { |
||||
box-shadow: -1px 0 3px 1px rgba(0, 0, 0, 0.3333); |
||||
position: fixed; |
||||
background-color: var(--light); |
||||
top: 0; |
||||
right: 0; |
||||
left: 0; |
||||
width: 100%; |
||||
z-index: 50; |
||||
-webkit-transform: translate(0, -100%); |
||||
-ms-transform: translate(0, -100%); |
||||
transform: translate(0, -100%); |
||||
-webkit-transition: -webkit-transform 0.5s; |
||||
transition: -webkit-transform 0.5s; |
||||
-o-transition: transform 0.5s; |
||||
transition: transform 0.5s; |
||||
transition: |
||||
transform 0.5s, |
||||
-webkit-transform 0.5s; |
||||
} |
||||
.search-box.open { |
||||
-webkit-transform: translate(0, 0); |
||||
-ms-transform: translate(0, 0); |
||||
transform: translate(0, 0); |
||||
} |
||||
.search-box-content { |
||||
position: relative; |
||||
padding: 2rem 0; |
||||
text-align: center; |
||||
z-index: 60; |
||||
} |
||||
.search-box-content form { |
||||
margin: 0; |
||||
} |
||||
.header-search-close { |
||||
position: absolute; |
||||
top: 1rem; |
||||
right: 0; |
||||
width: 34px; |
||||
height: 34px; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
color: var(--dark); |
||||
border: 3px solid var(--dark); |
||||
border-radius: 50%; |
||||
cursor: pointer; |
||||
font-weight: 700; |
||||
line-height: 1; |
||||
} |
||||
.search-box-content .block { |
||||
width: 100%; |
||||
margin: 0; |
||||
} |
||||
.search-box-content .block-title, |
||||
.search-box-content form label { |
||||
display: none; |
||||
color: #000000; |
||||
} |
||||
.search-box-content input[type="search"] { |
||||
width: 100%; |
||||
margin: 2rem 0; |
||||
padding: 0 2rem 4px 0; |
||||
font-size: 1.4rem; |
||||
background: url("../images/icons/search.svg") center right no-repeat; |
||||
background-size: contain; |
||||
border: 0; |
||||
border-bottom: 2px solid var(--border); |
||||
border-radius: 0; |
||||
outline: 0; |
||||
} |
||||
.search-box-content input[type="submit"] { |
||||
display: block; |
||||
margin: 0 auto; |
||||
padding: 0.5rem 1.5rem; |
||||
border-radius: 50px; |
||||
} |
||||
/* Header -> Page Header */ |
||||
.page-header { |
||||
position: relative; |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 2rem 0 1rem 0; |
||||
} |
||||
.region-page-header { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
} |
||||
/* Header -> Page Header-> breadcrumb */ |
||||
.breadcrumb { |
||||
position: relative; |
||||
width: 100%; |
||||
} |
||||
.breadcrumb-items { |
||||
display: flex; |
||||
flex-wrap: wrap; |
||||
margin: 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
} |
||||
.breadcrumb-item { |
||||
padding: 0; |
||||
} |
||||
.breadcrumb-item span { |
||||
font-size: 14px; |
||||
margin: 0 5px; |
||||
} |
@ -0,0 +1,24 @@
|
||||
/* Highlighted Block Region */ |
||||
.highlighted { |
||||
position: relative; |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
.region-highlighted { |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
} |
||||
.highlighted .block { |
||||
position: relative; |
||||
margin: 0; |
||||
padding: 1em 0; |
||||
} |
||||
.highlighted p:last-child { |
||||
margin: 0; |
||||
} |
@ -0,0 +1,11 @@
|
||||
.region-content-home-top, |
||||
.region-content-home-bottom { |
||||
display: flex; |
||||
flex-direction: column; |
||||
width: 100%; |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
.region-content-home-top { |
||||
margin-bottom: 2rem; |
||||
} |
@ -0,0 +1,73 @@
|
||||
/* |
||||
* Layout |
||||
*/ |
||||
/* Layout -> containers */ |
||||
.container { |
||||
position: relative; |
||||
width: 100%; |
||||
max-width: var(--page-container-width); |
||||
margin: 0 auto; |
||||
padding: 0 10px; |
||||
} |
||||
/* Layout -> Main wrapper (Main + Sidebar) */ |
||||
.main-wrapper { |
||||
position: relative; |
||||
display: block; |
||||
padding: 2rem 0; |
||||
} |
||||
.main-container { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
gap: 1.5rem; |
||||
} |
||||
/* Main |
||||
--------------------------------*/ |
||||
#main { |
||||
position: relative; |
||||
-webkit-box-ordinal-group: 1; |
||||
-ms-flex-order: 0; |
||||
order: 0; |
||||
} |
||||
#sidebar-left { |
||||
-webkit-box-ordinal-group: 2; |
||||
-ms-flex-order: 1; |
||||
order: 1; |
||||
} |
||||
#sidebar-right { |
||||
-webkit-box-ordinal-group: 3; |
||||
-ms-flex-order: 2; |
||||
order: 2; |
||||
} |
||||
/* No sidebar + main */ |
||||
.no-sidebar #main, |
||||
.sidebar-left #main, |
||||
.sidebar-right #main, |
||||
.two-sidebar #main, |
||||
#sidebar-left, |
||||
#sidebar-right { |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1 100%; |
||||
flex: 1 1 100%; |
||||
width: 100%; |
||||
} |
||||
#front-main { |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1 100%; |
||||
flex: 1 1 100%; |
||||
width: 100%; |
||||
margin: 0; |
||||
} |
||||
|
||||
/* Frontpage with Sidebar |
||||
--------------------------------*/ |
||||
.front-content-with-sidebar { |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
} |
@ -0,0 +1,41 @@
|
||||
#maintenance-page { |
||||
position: relative; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
width: 100%; |
||||
min-height: 100vh; |
||||
background: #ffffff; |
||||
color: #2d3436; |
||||
} |
||||
.maintenance-header { |
||||
position: relative; |
||||
width: 100%; |
||||
padding: 1rem 0; |
||||
} |
||||
.site-name h4 { |
||||
color: #f0932b; |
||||
line-height: 1; |
||||
font-weight: 700; |
||||
} |
||||
#maintenance { |
||||
position: relative; |
||||
margin: 0 auto; |
||||
padding: 1rem 0; |
||||
} |
||||
.maintenance { |
||||
text-align: center; |
||||
} |
||||
.maintenance-title { |
||||
color: #fff; |
||||
} |
||||
.maintenance-icon { |
||||
padding: 2rem 0; |
||||
} |
||||
.maintenance-icon img { |
||||
max-height: 50vh; |
||||
} |
@ -0,0 +1,20 @@
|
||||
/* Nodes */ |
||||
.node, |
||||
.node-promoted, |
||||
.node-sticky, |
||||
.node-view-mode-full, |
||||
.node-unpublished { |
||||
position: relative; |
||||
} |
||||
.node-view-mode-teaser { |
||||
position: relative; |
||||
margin-bottom: 4rem; |
||||
border-bottom: 4px double var(--border); |
||||
} |
||||
.node-view-mode-teaser.node-sticky { |
||||
border: 2px solid var(--border); |
||||
padding: 1rem; |
||||
} |
||||
.node-view-mode-full .node-taxonomy-container { |
||||
margin: 0; |
||||
} |
@ -0,0 +1,272 @@
|
||||
@media (min-width: 576px) { |
||||
.w10, |
||||
.w20, |
||||
.w30, |
||||
.w40, |
||||
.w50, |
||||
.w60, |
||||
.w70, |
||||
.w80, |
||||
.w90 { |
||||
flex-basis: calc(50% - 5px); |
||||
} |
||||
} |
||||
|
||||
@media (min-width: 768px) { |
||||
html { |
||||
font-size: 18px; |
||||
} |
||||
/* Header */ |
||||
.header-top-container { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
gap: 1rem; |
||||
} |
||||
/* Header -> Search form */ |
||||
.header-search-close { |
||||
top: 2rem; |
||||
} |
||||
.search-box-content .block-title { |
||||
display: block; |
||||
} |
||||
.breadcrumb-item span { |
||||
margin: 0 10px; |
||||
} |
||||
/* Main */ |
||||
.main-container { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
} |
||||
#main { |
||||
-webkit-box-ordinal-group: 2; |
||||
-ms-flex-order: 1; |
||||
order: 1; |
||||
} |
||||
#sidebar-left { |
||||
-webkit-box-ordinal-group: 1; |
||||
-ms-flex-order: 0; |
||||
order: 0; |
||||
} |
||||
#sidebar-right { |
||||
-webkit-box-ordinal-group: 3; |
||||
-ms-flex-order: 2; |
||||
order: 2; |
||||
} |
||||
/* one sidebar + main */ |
||||
.sidebar-left #main, |
||||
.sidebar-right #main { |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1 70%; |
||||
flex: 1 1 70%; |
||||
} |
||||
/* Both sidebar + main */ |
||||
.two-sidebar #main { |
||||
-webkit-box-flex: 1; |
||||
-ms-flex: 1 1 40%; |
||||
flex: 1 1 40%; |
||||
} |
||||
/* Sidebar |
||||
--------------------------------*/ |
||||
#sidebar-left { |
||||
-webkit-box-flex: 0; |
||||
-ms-flex: 0 1 30%; |
||||
flex: 0 1 30%; |
||||
} |
||||
#sidebar-right { |
||||
-webkit-box-flex: 0; |
||||
-ms-flex: 0 1 30%; |
||||
flex: 0 1 30%; |
||||
} |
||||
/* Footer */ |
||||
.footer-container { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
} |
||||
.footer-bottom-blocks-container { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
} |
||||
|
||||
.footer-bottom-container { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
} |
||||
.footer-bottom-last { |
||||
-webkit-box-orient: horizontal; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: row; |
||||
flex-direction: row; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
} |
||||
.copyright { |
||||
margin-bottom: 0; |
||||
} |
||||
/* shortcodes -> content width */ |
||||
.width30 { |
||||
width: 30%; |
||||
} |
||||
.width40 { |
||||
width: 40%; |
||||
} |
||||
.width50 { |
||||
width: 50%; |
||||
} |
||||
.width60 { |
||||
width: 60%; |
||||
} |
||||
.width70 { |
||||
width: 70%; |
||||
} |
||||
.width80 { |
||||
width: 80%; |
||||
} |
||||
.width90 { |
||||
width: 90%; |
||||
} |
||||
/* shortcodes -> responsive column */ |
||||
.w10 { |
||||
flex-basis: calc(10% - 10px); |
||||
} |
||||
.w20 { |
||||
flex-basis: calc(20% - 10px); |
||||
} |
||||
.w30 { |
||||
flex-basis: calc(30% - 10px); |
||||
} |
||||
.w40 { |
||||
flex-basis: calc(40% - 10px); |
||||
} |
||||
.w50 { |
||||
flex-basis: calc(50% - 10px); |
||||
} |
||||
.w60 { |
||||
flex-basis: calc(60% - 10px); |
||||
} |
||||
.w70 { |
||||
flex-basis: calc(70% - 10px); |
||||
} |
||||
.w80 { |
||||
flex-basis: calc(80% - 10px); |
||||
} |
||||
.w90 { |
||||
flex-basis: calc(90% - 10px); |
||||
} |
||||
/* Shortcodes -> responsive view */ |
||||
.view-in-mobile { |
||||
display: none; |
||||
} |
||||
.view-in-desktop { |
||||
display: block; |
||||
} |
||||
} |
||||
@media (min-width: 992px) { |
||||
th { |
||||
padding: 10px; |
||||
} |
||||
td { |
||||
padding: 5px 10px; |
||||
} |
||||
/* Header */ |
||||
.header-right { |
||||
gap: 1rem; |
||||
} |
||||
.menu-wrap { |
||||
position: relative; |
||||
background-color: transparent; |
||||
max-width: 100%; |
||||
-webkit-transform: translateX(0); |
||||
-ms-transform: translateX(0); |
||||
transform: translateX(0); |
||||
-webkit-transition: none; |
||||
-o-transition: none; |
||||
transition: none; |
||||
} |
||||
.menu-wrap .menu { |
||||
flex-direction: row; |
||||
} |
||||
.menu-wrap .menu, |
||||
.menu-wrap .menu a { |
||||
color: var(--primary); |
||||
} |
||||
.menu-wrap .menu-item a, |
||||
.menu-wrap .menu-item > span { |
||||
border-bottom: 0; |
||||
} |
||||
.menu-wrap .menu > li, |
||||
.menu-wrap .collapsed, |
||||
.menu-wrap .expanded, |
||||
.menu-wrap .menu-item-has-children { |
||||
display: inline-flex; |
||||
align-items: center; |
||||
} |
||||
.menu-wrap .collapsed:hover, |
||||
.menu-wrap .expanded:hover, |
||||
.menu-wrap .menu-item-has-children:hover { |
||||
background-color: var(--light); |
||||
} |
||||
.menu-wrap .collapsed::after, |
||||
.menu-wrap .expanded::after, |
||||
.menu-wrap .menu-item-has-children::after { |
||||
content: '+'; |
||||
} |
||||
.menu-wrap .submenu { |
||||
position: absolute; |
||||
display: none; |
||||
background-color: var(--light); |
||||
font-size: 0.9rem; |
||||
top: 100%; |
||||
min-width: 180px; |
||||
max-width: 200px; |
||||
opacity: 0; |
||||
} |
||||
.collapsed:hover > .submenu, |
||||
.expanded:hover > .submenu, |
||||
.menu-item-has-children:hover > .submenu { |
||||
display: flex; |
||||
-webkit-animation: slideUp 0.5s forwards; |
||||
animation: slideUp 0.5s forwards; |
||||
} |
||||
.menu-wrap .submenu li { |
||||
border-bottom: 1px solid var(--border); |
||||
} |
||||
.menu-wrap .submenu .submenu { |
||||
top: 0; |
||||
left: 100%; |
||||
} |
||||
.menu-wrap .submenu li > a, |
||||
.menu-wrap .submenu li > span { |
||||
padding: 0.5rem; |
||||
} |
||||
.menu-wrap .submenu .submenu .menu-item > a, |
||||
.menu-wrap .submenu .submenu .menu-item > span { |
||||
padding: 0.5rem; |
||||
} |
||||
.mobile-menu, |
||||
.close-mobile-menu { |
||||
display: none; |
||||
} |
||||
} |
@ -0,0 +1,28 @@
|
||||
/* Search result page |
||||
--------------------------------------*/ |
||||
.page-content input[type="search"] { |
||||
width: 80%; |
||||
} |
||||
ol.search-results { |
||||
margin: 1em 0; |
||||
padding: 0; |
||||
list-style: none; |
||||
list-style-type: none; |
||||
} |
||||
ol.search-results li { |
||||
margin: 0 0 1em 0; |
||||
padding: 1rem; |
||||
background: var(--light); |
||||
} |
||||
.search-advanced summary { |
||||
margin: 10px 0; |
||||
cursor: pointer; |
||||
} |
||||
.search-advanced .form-details-wrapper { |
||||
padding: 0.5em 1.4em; |
||||
border: 1px solid var(--border); |
||||
} |
||||
.search-advanced .form-wrapper { |
||||
padding: 0.5em 1.4em; |
||||
border: 1px solid var(--border); |
||||
} |
@ -0,0 +1,330 @@
|
||||
/* Mobile and desktop display |
||||
================================= */ |
||||
.view-in-mobile { |
||||
display: block; |
||||
} |
||||
.view-in-desktop { |
||||
display: none; |
||||
} |
||||
/* Color and background |
||||
================================= */ |
||||
.primary { |
||||
color: var(--primary); |
||||
} |
||||
.secondary { |
||||
color: var(--secondary); |
||||
} |
||||
.dark { |
||||
color: var(--dark); |
||||
} |
||||
.light { |
||||
color: var(--light); |
||||
} |
||||
.bg-light { |
||||
background-color: var(--light); |
||||
} |
||||
/* Text Alignment |
||||
================================= */ |
||||
.text-left { |
||||
text-align: left; |
||||
} |
||||
.text-right { |
||||
text-align: right; |
||||
} |
||||
.text-center { |
||||
text-align: center; |
||||
} |
||||
.text-justify { |
||||
text-align: justify; |
||||
} |
||||
.center { |
||||
margin: 0 auto; |
||||
} |
||||
/* Inline content |
||||
================================= */ |
||||
.inline { |
||||
display: inline-block; |
||||
} |
||||
.inline:not(:last-child) { |
||||
padding-right: 1rem; |
||||
} |
||||
|
||||
/* Direction |
||||
================================= */ |
||||
.rtl { |
||||
direction: rtl; |
||||
} |
||||
.ltr { |
||||
direction: ltr; |
||||
} |
||||
|
||||
/* Font Size |
||||
================================= */ |
||||
.font-small { |
||||
font-size: 0.75rem; |
||||
} |
||||
.font-medium { |
||||
font-size: 1.25rem; |
||||
} |
||||
.font-large { |
||||
font-size: 1.5rem; |
||||
} |
||||
.font-2x { |
||||
font-size: 2rem; |
||||
} |
||||
.font-3x { |
||||
font-size: 2.5rem; |
||||
} |
||||
.font-4x { |
||||
font-size: 3rem; |
||||
} |
||||
.font-5x { |
||||
font-size: 4rem; |
||||
} |
||||
.font-6x { |
||||
font-size: 5rem; |
||||
} |
||||
.font-7x { |
||||
font-size: 6rem; |
||||
} |
||||
.font-8x { |
||||
font-size: 7rem; |
||||
} |
||||
|
||||
/* Font Icon Size |
||||
================================= */ |
||||
.size-xs { |
||||
font-size: 0.5em; |
||||
} |
||||
.size-small { |
||||
font-size: 0.75em; |
||||
} |
||||
.size-medium { |
||||
font-size: 1.25em; |
||||
} |
||||
.size-large { |
||||
font-size: 1.5em; |
||||
} |
||||
.size-2x { |
||||
font-size: 2em; |
||||
} |
||||
.size-3x { |
||||
font-size: 3em; |
||||
} |
||||
.size-4x { |
||||
font-size: 4em; |
||||
} |
||||
.size-5x { |
||||
font-size: 5em; |
||||
} |
||||
.size-6x { |
||||
font-size: 6em; |
||||
} |
||||
.size-7x { |
||||
font-size: 7em; |
||||
} |
||||
.size-8x { |
||||
font-size: 8em; |
||||
} |
||||
.size-9x { |
||||
font-size: 9em; |
||||
} |
||||
.size-10x { |
||||
font-size: 10em; |
||||
} |
||||
|
||||
/* image icons size |
||||
================================= */ |
||||
.icon-s { |
||||
max-height: 1rem; |
||||
} |
||||
.icon-m { |
||||
max-height: 1.5rem; |
||||
} |
||||
.icon-l { |
||||
max-height: 2rem; |
||||
} |
||||
.icon-xl { |
||||
max-height: 3rem; |
||||
} |
||||
.icon-x2 { |
||||
max-height: 4rem; |
||||
} |
||||
.icon-x3 { |
||||
max-height: 5rem; |
||||
} |
||||
.icon-x4 { |
||||
max-height: 6rem; |
||||
} |
||||
.icon-x5 { |
||||
max-height: 7rem; |
||||
} |
||||
.icon-x6 { |
||||
max-height: 8rem; |
||||
} |
||||
.icon-x7 { |
||||
max-height: 9rem; |
||||
} |
||||
.icon-x8 { |
||||
max-height: 10rem; |
||||
} |
||||
/* Content width |
||||
================================= */ |
||||
.width30, |
||||
.width40, |
||||
.width50, |
||||
.width60, |
||||
.width70, |
||||
.width80, |
||||
.width90 { |
||||
width: 100%; |
||||
clear: both; |
||||
display: block; |
||||
} |
||||
/* Empty width and height |
||||
================================= */ |
||||
.w20px { |
||||
display: inline-block; |
||||
width: 20px; |
||||
} |
||||
.w30px { |
||||
display: inline-block; |
||||
width: 30px; |
||||
} |
||||
.w40px { |
||||
display: inline-block; |
||||
width: 40px; |
||||
} |
||||
.w50px { |
||||
display: inline-block; |
||||
width: 50px; |
||||
} |
||||
.w70px { |
||||
display: inline-block; |
||||
width: 70px; |
||||
} |
||||
.w100px { |
||||
display: inline-block; |
||||
width: 100px; |
||||
} |
||||
.empty, |
||||
.spacer, |
||||
.spacer-x2, |
||||
.spacer-x3 { |
||||
width: 100%; |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-orient: vertical; |
||||
-webkit-box-direction: normal; |
||||
-ms-flex-direction: column; |
||||
flex-direction: column; |
||||
} |
||||
.empty, |
||||
.spacer { |
||||
padding: 1rem 0; |
||||
} |
||||
.spacer-x2 { |
||||
padding: 2rem 0; |
||||
} |
||||
.spacer-x3 { |
||||
padding: 3rem 0; |
||||
} |
||||
/* Responsive Columns |
||||
================================= */ |
||||
.section { |
||||
position: relative; |
||||
display: block; |
||||
width: 100%; |
||||
padding: 3rem 0; |
||||
} |
||||
.section-small { |
||||
position: relative; |
||||
display: block; |
||||
width: 100%; |
||||
padding: 1rem 0; |
||||
} |
||||
.items { |
||||
display: grid; |
||||
grid-template-columns: repeat(auto-fit, minmax(265px, 1fr)); |
||||
grid-gap: 1rem; |
||||
gap: 1rem; |
||||
} |
||||
.item img { |
||||
display: block; |
||||
} |
||||
.columns { |
||||
display: -webkit-box; |
||||
display: -ms-flexbox; |
||||
display: flex; |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
-ms-flex-wrap: wrap; |
||||
flex-wrap: wrap; |
||||
} |
||||
/* Create Equal width columns with no gap */ |
||||
.column { |
||||
flex: 1 1 230px; |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
/* flex-items width */ |
||||
.w10, |
||||
.w20, |
||||
.w30, |
||||
.w40, |
||||
.w50, |
||||
.w60, |
||||
.w70, |
||||
.w80, |
||||
.w90 { |
||||
flex-basis: 100%; |
||||
} |
||||
/* Flex - Common for all |
||||
================================= */ |
||||
.space-between { |
||||
-webkit-box-pack: justify; |
||||
-ms-flex-pack: justify; |
||||
justify-content: space-between; |
||||
} |
||||
.v-center { |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
} |
||||
.h-center { |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
} |
||||
.vh-center { |
||||
-webkit-box-pack: center; |
||||
-ms-flex-pack: center; |
||||
justify-content: center; |
||||
-webkit-box-align: center; |
||||
-ms-flex-align: center; |
||||
align-items: center; |
||||
} |
||||
|
||||
/* Shortcodes -> box, icon box |
||||
================================= */ |
||||
.box, |
||||
.icon-box { |
||||
position: relative; |
||||
display: block; |
||||
padding: 1rem; |
||||
margin-bottom: 1rem; |
||||
} |
||||
.box p:last-child, |
||||
.icon-box p:last-child { |
||||
margin: 0; |
||||
} |
||||
/* Shortcodes -> grid column |
||||
================================= */ |
||||
.grid-row { |
||||
display: grid; |
||||
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); |
||||
grid-gap: 1rem; |
||||
gap: 1rem; |
||||
} |
@ -0,0 +1,62 @@
|
||||
/* Sidebar |
||||
--------------------------------*/ |
||||
.sidebar { |
||||
position: relative; |
||||
width: 100%; |
||||
} |
||||
.region-sidebar-first, |
||||
.region-sidebar-second { |
||||
display: flex; |
||||
flex-direction: column; |
||||
gap: 2rem; |
||||
} |
||||
.sidebar .block { |
||||
background-color: var(--sidebar-block-background); |
||||
padding: 1rem; |
||||
border: var(--sidebar-block-border); |
||||
} |
||||
.sidebar .block-title { |
||||
background: var(--sidebar-block-title-background); |
||||
font-size: var(--sidebar-block-title-font-size); |
||||
font-family: var(--sidebar-block-title-font-family); |
||||
color: var(--sidebar-block-title-font-color); |
||||
} |
||||
.sidebar .block-content { |
||||
font-variation-settings: "wdth" 75; |
||||
font-size: var(--sidebar-block-font-size); |
||||
font-family: var(--sidebar-block-font-family); |
||||
color: var(--sidebar-block-font-color); |
||||
} |
||||
.sidebar .block a { |
||||
color: var(--sidebar-block-link-color); |
||||
} |
||||
.sidebar .block a:hover { |
||||
color: var(--sidebar-block-link-color-hover); |
||||
} |
||||
.sidebar ul, |
||||
.sidebar ol { |
||||
margin: 0; |
||||
padding: 0; |
||||
list-style-position: inside; |
||||
} |
||||
.sidebar ul { |
||||
list-style: none; |
||||
} |
||||
.sidebar li { |
||||
padding: 6px 0; |
||||
border-bottom: var(--sidebar-ul-separator-line); |
||||
} |
||||
.sidebar .block p:last-of-type { |
||||
margin: 0; |
||||
} |
||||
/* Sidebr -> Form */ |
||||
.sidebar input[type="text"], |
||||
.sidebar input[type="email"], |
||||
.sidebar input[type="url"], |
||||
.sidebar input[type="password"], |
||||
.sidebar input[type="search"], |
||||
.sidebar textarea { |
||||
width: 100%; |
||||
max-width: 100%; |
||||
border: 1px solid var(--border); |
||||
} |
@ -0,0 +1,100 @@
|
||||
/* Font info |
||||
---------------------------------------- */ |
||||
|
||||
/* Variables |
||||
---------------------------------------- */ |
||||
:root { |
||||
|
||||
/* |
||||
*colors |
||||
*/ |
||||
--upei-red: #8c2004; |
||||
--upei-green: #5c8727; |
||||
--upei-yellow: #fbb040; |
||||
|
||||
--primary: #365ab5; |
||||
--primary: var(--upei-red); |
||||
--secondary: #d05700; |
||||
--dark: #333; |
||||
--light: #eee; |
||||
--border: #a8a6a6; |
||||
|
||||
--color-text: #444444; |
||||
--color-heading: #333; |
||||
|
||||
--font-family-serif: 'Noto Serif', sans-serif; |
||||
--font-family-sans-serif: 'Noto Sans', sans-serif; |
||||
/* |
||||
*body |
||||
*/ |
||||
--body-bg-color: #fff; |
||||
--page-container-width: 1440px; |
||||
--body-font: var(--font-family-sans-serif); |
||||
--heading-font: var(--font-family-serif); |
||||
/* |
||||
*branding |
||||
*/ |
||||
/*--header-bg-color: #333;*/ |
||||
--header-top-bg-color: var(--dark); |
||||
--header-top-text-color: #fff; |
||||
--header-bg-color: none; |
||||
--header-text-color: var(--color-text); |
||||
--header-padding: 1rem; |
||||
--header-bottom-border: 1px solid #ddd; |
||||
--logo-width: 160px; |
||||
--site-name-font-family: var(--font-family-serif); |
||||
--site-name-font-size: 2em; |
||||
--site-name-font-color: var(--header-text-color); |
||||
--site-slogan-font-family: var(--font-family-sans-serif); |
||||
--site-slogan-font-size: inherit; |
||||
--site-slogan-font-color: var(--header-text-color); |
||||
--branding-separator: 2px solid #333; |
||||
--branding-separator-padding: .5rem; |
||||
--header-menu-font-width: 75 /*65-100*/; |
||||
/* |
||||
*tabs |
||||
*/ |
||||
--tabs-font: var(--font-family-sans-serif); |
||||
--page-tab-bg-color: var(--light); |
||||
--page-tab-text-color: #333; |
||||
--page-tab-text-color-active: var(--primary); |
||||
--page-tab-border-color: var(--border); |
||||
/* |
||||
*search button |
||||
*/ |
||||
--search-button-color: var(--upei-green); |
||||
--search-button-text-color: #fff; |
||||
|
||||
/* |
||||
*headings |
||||
*/ |
||||
--h1-size: 2.2rem; |
||||
--h2-size: 1.9rem; |
||||
--h3-size: 1.6rem; |
||||
--h4-size: 1.3rem; |
||||
--h5-size: 1.1rem; |
||||
--h6-size: 1.1rem; |
||||
/* |
||||
*block styles |
||||
*/ |
||||
--sidebar-block-title-font-size: var(--h3-size); |
||||
--sidebar-block-title-font-family: var(--font-family-serif); |
||||
--sidebar-block-title-font-color: var(--color-text); |
||||
--sidebar-block-title-background: inherit; |
||||
--sidebar-block-background: var(--light); |
||||
--sidebar-block-font-size: inherit; |
||||
--sidebar-block-font-family: var(--font-family-sans-serif); |
||||
--sidebar-block-font-color: var(--color-text); |
||||
--sidebar-block-border: 1px solid var(--light); |
||||
--sidebar-block-link-color: var(--color-text); |
||||
--sidebar-block-link-color-hover: var(--primary); |
||||
--sidebar-ul-separator-line: 2px solid var(--primary); |
||||
|
||||
|
||||
/* |
||||
*footer |
||||
*/ |
||||
--footer-bg-color: #ccc; |
||||
--footer-text-color: initial; |
||||
--footer-link-color: var(--upei-red); |
||||
} |
After Width: | Height: | Size: 32 KiB |
Binary file not shown.
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 434 KiB |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -0,0 +1,18 @@
|
||||
vre2024.mobile: |
||||
label: mobile |
||||
mediaQuery: '' |
||||
weight: 0 |
||||
multipliers: |
||||
- 1x |
||||
vre2024.narrow: |
||||
label: narrow |
||||
mediaQuery: 'all and (min-width: 560px) and (max-width: 850px)' |
||||
weight: 1 |
||||
multipliers: |
||||
- 1x |
||||
vre2024.wide: |
||||
label: wide |
||||
mediaQuery: 'all and (min-width: 851px)' |
||||
weight: 2 |
||||
multipliers: |
||||
- 1x |
@ -0,0 +1,36 @@
|
||||
name: islandscholar |
||||
type: theme |
||||
'base theme': stable9 |
||||
package: UPEI |
||||
starterkit: true |
||||
core_version_requirement: ^10 |
||||
libraries: |
||||
- islandscholar/global-styling |
||||
regions: |
||||
header_top_left: 'Header Top Left' |
||||
header_top_right: 'Header Top Right' |
||||
header: Header |
||||
primary_menu: 'Primary menu' |
||||
search_box: 'Search Box' |
||||
page_header: 'Page Header' |
||||
highlighted: Highlighted |
||||
content: Content |
||||
content_top: 'Content Top' |
||||
content_bottom: 'Content Bottom' |
||||
content_home_top: 'Homepage Content Top' |
||||
content_home_bottom: 'Homepage Content Bottom' |
||||
sidebar_first: 'Sidebar Left' |
||||
sidebar_second: 'Sidebar Right' |
||||
footer_top: 'Footer Top' |
||||
footer_one: 'Footer First Column' |
||||
footer_two: 'Footer Second Column' |
||||
footer_three: 'Footer Third Column' |
||||
footer_four: 'Footer Fourth Column' |
||||
footer_bottom_left: 'Footer Bottom Left' |
||||
footer_bottom_right: 'Footer Bottom Right' |
||||
footer_bottom_last: 'Footer Bottom Last' |
||||
hidden: 'Hidden Blocks' |
||||
version: 10.0.4 |
||||
project: vre2024 |
||||
datestamp: 1693915470 |
||||
generator: 'vre2024:10.0.4' |
@ -0,0 +1,57 @@
|
||||
global-styling: |
||||
version: VERSION |
||||
css: |
||||
base: |
||||
css/fonts.css: { } |
||||
css/site-variables.css: { } |
||||
css/base.css: { } |
||||
layout: |
||||
css/layout.css: { } |
||||
component: |
||||
css/core.css: { } |
||||
css/block.css: { } |
||||
css/font-icon.css: { } |
||||
css/header.css: { } |
||||
css/highlighted.css: { } |
||||
css/node.css: { } |
||||
css/search.css: { } |
||||
css/comments.css: { } |
||||
css/sidebar.css: { } |
||||
css/footer.css: { } |
||||
css/components.css: { } |
||||
css/elements.css: { } |
||||
css/shortcodes.css: { } |
||||
css/homepage.css: { } |
||||
css/clear.css: { } |
||||
css/extra.css: { } |
||||
css/responsive.css: { } |
||||
js: |
||||
js/vre2024.js: { } |
||||
dependencies: |
||||
- core/jquery |
||||
book: |
||||
version: VERSION |
||||
css: |
||||
component: |
||||
css/book.css: { } |
||||
fontawesome4: |
||||
version: 4.7.0 |
||||
css: |
||||
component: |
||||
css/font-awesome.css: { } |
||||
fontawesome5: |
||||
version: 5.15.4 |
||||
css: |
||||
component: |
||||
css/fontawesome5.css: |
||||
weight: -10 |
||||
bootstrap-icons: |
||||
version: 1.10.5 |
||||
css: |
||||
component: |
||||
css/bootstrap-icons.css: { } |
||||
maintenance: |
||||
version: VERSION |
||||
css: |
||||
theme: |
||||
css/maintenance.css: { } |
@ -0,0 +1,34 @@
|
||||
<?php |
||||
/** |
||||
* @file |
||||
* Extra Functions for vre2024 |
||||
*/ |
||||
function islandscholar_preprocess_page(array &$variables) { |
||||
$config = \Drupal::config('system.site'); |
||||
$variables['site_name'] = $config->get('name'); |
||||
$variables['site_slogan'] = $config->get('slogan'); |
||||
$variables['base_path'] = base_path(); |
||||
$variables['scrolltotop_on'] = 1; |
||||
} |
||||
/** |
||||
* Add current page to breadcrumb. |
||||
*/ |
||||
function islandscholar_preprocess_breadcrumb(&$variables) { |
||||
$request = \Drupal::request(); |
||||
$route_match = \Drupal::routeMatch(); |
||||
$page_title = \Drupal::service('title_resolver')->getTitle($request, $route_match->getRouteObject()); |
||||
if (!empty($page_title)) { |
||||
$variables['breadcrumb'][] = [ |
||||
'text' => $page_title, |
||||
]; |
||||
// Add cache context based on url. |
||||
$variables['#cache']['contexts'][] = 'url'; |
||||
} |
||||
$variables['breadcrumb_icon_style'] = '/'; |
||||
} |
||||
/** |
||||
* Html preprocess for the theme. |
||||
*/ |
||||
function islandscholar_preprocess_html(&$variables) { |
||||
$variables['is_front'] = \Drupal::service('path.matcher')->isFrontPage(); |
||||
} |
@ -0,0 +1,48 @@
|
||||
/* Load jQuery. |
||||
--------------------------*/ |
||||
jQuery(document).ready(function ($) { |
||||
// Mobile menu.
|
||||
$('.mobile-menu').click(function () { |
||||
$(this).toggleClass('menu-icon-active'); |
||||
$(this).next('.primary-menu-wrapper').toggleClass('active-menu'); |
||||
}); |
||||
$('.close-mobile-menu').click(function () { |
||||
$(this).closest('.primary-menu-wrapper').toggleClass('active-menu'); |
||||
$('.mobile-menu').removeClass('menu-icon-active'); |
||||
}); |
||||
// Header search form
|
||||
$('.search-icon').on('click', function() { |
||||
$('.search-box').toggleClass('open'); |
||||
$('.search-box-content .form-search').focus(); |
||||
return false; |
||||
}); |
||||
$('.search-box-content input[type="search"]').attr("placeholder", "Type your search"); |
||||
|
||||
$('.header-search-close').on('click', function() { |
||||
$('.search-box').removeClass('open'); |
||||
return false; |
||||
}); |
||||
$('.search-box').on( 'keydown', function(e) { |
||||
if ( e.keyCode === 27 ) { |
||||
$('.search-box.open').removeClass('open'); |
||||
} |
||||
}); |
||||
$(document).on('click', function(event) { |
||||
if(!$(event.target).closest(".search-box-content").length) { |
||||
$('.search-box').removeClass('open'); |
||||
} |
||||
}) |
||||
// Scroll To Top.
|
||||
$(window).scroll(function () { |
||||
if ($(this).scrollTop() > 80) { |
||||
$('.scrolltop').css('display', 'flex'); |
||||
} else { |
||||
$('.scrolltop').fadeOut('slow'); |
||||
} |
||||
}); |
||||
$('.scrolltop').click(function () { |
||||
$('html, body').scrollTop(0); |
||||
}); |
||||
/* End document |
||||
--------------------------*/ |
||||
}); |
After Width: | Height: | Size: 51 KiB |
@ -0,0 +1,17 @@
|
||||
{ |
||||
"name": "vre2024", |
||||
"version": "1.0.0", |
||||
"description": "vre2024 - Drupal 8 and 9 Base Theme.", |
||||
"main": "bs.js", |
||||
"scripts": { |
||||
"test": "echo \"Error: no test specified\" && exit 1", |
||||
"bs": "node bs.js" |
||||
}, |
||||
"author": "", |
||||
"license": "ISC", |
||||
"devDependencies": { |
||||
"browser-sync": "^3.0.2", |
||||
"bs-rewrite-rules": "^2.1.2", |
||||
"prettier": "3.2.5" |
||||
} |
||||
} |
After Width: | Height: | Size: 41 KiB |
@ -0,0 +1,38 @@
|
||||
{% extends "block.html.twig" %} |
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a branding block. |
||||
* |
||||
* Each branding element variable (logo, name, slogan) is only available if |
||||
* enabled in the block configuration. |
||||
* |
||||
* Available variables: |
||||
* - site_logo: Logo for site as defined in Appearance or theme settings. |
||||
* - site_name: Name for site as defined in Site information settings. |
||||
* - site_slogan: Slogan for site as defined in Site information settings. |
||||
*/ |
||||
#} |
||||
{% block content %} |
||||
<div class="site-branding"> |
||||
{% if site_logo %} |
||||
<div class="site-logo"> |
||||
<a href="{{ path('<front>') }}" rel="home"> |
||||
<img src="{{ site_logo }}" alt="{{ 'Home'|t }}" /> |
||||
</a> |
||||
</div><!-- site-logo --> |
||||
{% endif %} |
||||
{% if site_name or site_slogan %} |
||||
<div class="site-name-slogan"> |
||||
{% if site_name %} |
||||
<div class="site-name"> |
||||
<a href="{{ path('<front>') }}" title="{{ 'Home'|t }}" rel="home">{{ site_name }}</a> |
||||
</div> |
||||
{% endif %} |
||||
{% if site_slogan %} |
||||
<div class="site-slogan">{{ site_slogan }}</div> |
||||
{% endif %} |
||||
</div><!-- site-name-slogan --> |
||||
{% endif %} |
||||
</div><!-- site-branding --> |
||||
{% endblock %} |
@ -0,0 +1,48 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a menu block. |
||||
* |
||||
* Available variables: |
||||
* - plugin_id: The ID of the block implementation. |
||||
* - label: The configured label of the block if visible. |
||||
* - configuration: A list of the block's configuration values. |
||||
* - label: The configured label for the block. |
||||
* - label_display: The display settings for the label. |
||||
* - provider: The module or other provider that provided this block plugin. |
||||
* - Block plugin specific settings will also be stored here. |
||||
* - content: The content of this block. |
||||
* - attributes: HTML attributes for the containing element. |
||||
* - id: A valid HTML ID and guaranteed unique. |
||||
* - title_attributes: HTML attributes for the title element. |
||||
* - content_attributes: HTML attributes for the content element. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title_suffix: Additional output populated by modules, intended to be |
||||
* displayed after the main title tag that appears in the template. |
||||
* |
||||
* Headings should be used on navigation menus that consistently appear on |
||||
* multiple pages. When this menu block's label is configured to not be |
||||
* displayed, it is automatically made invisible using the 'visually-hidden' CSS |
||||
* class, which still keeps it visible for screen-readers and assistive |
||||
* technology. Headings allow screen-reader and keyboard only users to navigate |
||||
* to or skip the links. |
||||
* See http://juicystudio.com/article/screen-readers-display-none.php and |
||||
* http://www.w3.org/TR/WCAG-TECHS/H42.html for more information. |
||||
*/ |
||||
#} |
||||
{% set heading_id = attributes.id ~ '-menu'|clean_id %} |
||||
<nav role="navigation" aria-labelledby="{{ heading_id }}"{{ attributes.addClass('block block-menu')|without('role', 'aria-labelledby') }}> |
||||
{# Label. If not displayed, we still provide it for screen readers. #} |
||||
{% if not configuration.label_display %} |
||||
{% set title_attributes = title_attributes.addClass('visually-hidden') %} |
||||
{% endif %} |
||||
{{ title_prefix }} |
||||
<h2{{ title_attributes.addClass('block-title').setAttribute('id', heading_id) }}>{{ configuration.label }}</h2> |
||||
{{ title_suffix }} |
||||
|
||||
{# Menu. #} |
||||
{% block content %} |
||||
{{ content }} |
||||
{% endblock %} |
||||
</nav> |
@ -0,0 +1,39 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to display a block. |
||||
* |
||||
* Available variables: |
||||
* - plugin_id: The ID of the block implementation. |
||||
* - label: The configured label of the block if visible. |
||||
* - configuration: A list of the block's configuration values. |
||||
* - label: The configured label for the block. |
||||
* - label_display: The display settings for the label. |
||||
* - provider: The module or other provider that provided this block plugin. |
||||
* - Block plugin specific settings will also be stored here. |
||||
* - content: The content of this block. |
||||
* - attributes: array of HTML attributes populated by modules, intended to |
||||
* be added to the main container tag of this template. |
||||
* - id: A valid HTML ID and guaranteed unique. |
||||
* - title_attributes: Same as attributes, except applied to the main title |
||||
* tag that appears in the template. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title_suffix: Additional output populated by modules, intended to be |
||||
* displayed after the main title tag that appears in the template. |
||||
* |
||||
* @see template_preprocess_block() |
||||
*/ |
||||
#} |
||||
<div{{ attributes.addClass('block') }}> |
||||
{{ title_prefix }} |
||||
{% if label %} |
||||
<h2{{ title_attributes.addClass('block-title') }}>{{ label }}</h2> |
||||
{% endif %} |
||||
{{ title_suffix }} |
||||
<div class="block-content"> |
||||
{% block content %} |
||||
{{ content }} |
||||
{% endblock %} |
||||
</div><!--/.block-content --> |
||||
</div><!--/.block --> |
@ -0,0 +1,18 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a filter caption. |
||||
* |
||||
* Returns HTML for a captioned image, audio, video or other tag. |
||||
* |
||||
* Available variables |
||||
* - string node: The complete HTML tag whose contents are being captioned. |
||||
* - string tag: The name of the HTML tag whose contents are being captioned. |
||||
* - string caption: The caption text. |
||||
* - string classes: The classes of the captioned HTML tag. |
||||
*/ |
||||
#} |
||||
<figure role="group" class="caption {%- if classes %} {{ classes }}{%- endif %}"> |
||||
{{ node }} |
||||
<figcaption>{{ caption }}</figcaption> |
||||
</figure> |
@ -0,0 +1,99 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme implementation for comments. |
||||
* |
||||
* Available variables: |
||||
* - author: Comment author. Can be a link or plain text. |
||||
* - content: The content-related items for the comment display. Use |
||||
* {{ content }} to print them all, or print a subset such as |
||||
* {{ content.field_example }}. Use the following code to temporarily suppress |
||||
* the printing of a given child element: |
||||
* @code |
||||
* {{ content|without('field_example') }} |
||||
* @endcode |
||||
* - created: Formatted date and time for when the comment was created. |
||||
* Preprocess functions can reformat it by calling format_date() with the |
||||
* desired parameters on the 'comment.created' variable. |
||||
* - changed: Formatted date and time for when the comment was last changed. |
||||
* Preprocess functions can reformat it by calling format_date() with the |
||||
* desired parameters on the 'comment.changed' variable. |
||||
* - permalink: Comment permalink. |
||||
* - submitted: Submission information created from author and created |
||||
* during template_preprocess_comment(). |
||||
* - user_picture: The comment author's profile picture. |
||||
* - status: Comment status. Possible values are: |
||||
* unpublished, published, or preview. |
||||
* - title: Comment title, linked to the comment. |
||||
* - attributes: HTML attributes for the containing element. |
||||
* The attributes.class may contain one or more of the following classes: |
||||
* - comment: The current template type; e.g., 'theming hook'. |
||||
* - by-anonymous: Comment by an unregistered user. |
||||
* - by-{entity-type}-author: Comment by the author of the parent entity, |
||||
* eg. by-node-author. |
||||
* - preview: When previewing a new or edited comment. |
||||
* The following applies only to viewers who are registered users: |
||||
* - unpublished: An unpublished comment visible only to administrators. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title_suffix: Additional output populated by modules, intended to be |
||||
* displayed after the main title tag that appears in the template. |
||||
* - content_attributes: List of classes for the styling of the comment content. |
||||
* - title_attributes: Same as attributes, except applied to the main title |
||||
* tag that appears in the template. |
||||
* - threaded: A flag indicating whether the comments are threaded or not. |
||||
* |
||||
* These variables are provided to give context about the parent comment (if |
||||
* any): |
||||
* - comment_parent: Full parent comment entity (if any). |
||||
* - parent_author: Equivalent to author for the parent comment. |
||||
* - parent_created: Equivalent to created for the parent comment. |
||||
* - parent_changed: Equivalent to changed for the parent comment. |
||||
* - parent_title: Equivalent to title for the parent comment. |
||||
* - parent_permalink: Equivalent to permalink for the parent comment. |
||||
* - parent: A text string of parent comment submission information created from |
||||
* 'parent_author' and 'parent_created' during template_preprocess_comment(). |
||||
* This information is presented to help screen readers follow lengthy |
||||
* discussion threads. You can hide this from sighted users using the class |
||||
* visually-hidden. |
||||
* |
||||
* These two variables are provided for context: |
||||
* - comment: Full comment object. |
||||
* - entity: Entity the comments are attached to. |
||||
* |
||||
* @see template_preprocess_comment() |
||||
*/ |
||||
#} |
||||
{% |
||||
set classes = [ |
||||
status != 'published' ? status, |
||||
comment.owner.anonymous ? 'comment-by-anonymous', |
||||
author_id and author_id == commented_entity.getOwnerId() ? 'comment-by-author', |
||||
] |
||||
%} |
||||
<article{{ attributes.addClass('js-comment comment', classes) }}> |
||||
{# |
||||
Hide the "new" indicator by default, let a piece of JavaScript ask the |
||||
server which comments are new for the user. Rendering the final "new" |
||||
indicator here would break the render cache. |
||||
#} |
||||
<header class="comment-header"> |
||||
<div class="comment-user-picture"> |
||||
{{ user_picture }} |
||||
</div><!-- /comment-user-picture --> |
||||
<div class="comment-meta"> |
||||
{% if title %} |
||||
{{ title_prefix }} |
||||
<h3{{ title_attributes.addClass('comment-title') }}>{{ title }}</h3> |
||||
{{ title_suffix }} |
||||
{% endif %} |
||||
<p>{{ author }} {{ created }} <mark class="hidden" data-comment-timestamp="{{ new_indicator_timestamp }}"></mark></p> |
||||
{% if parent %} |
||||
<p class="visually-hidden">{{ parent }}</p> |
||||
{% endif %} |
||||
</div><!-- /comment-meta --> |
||||
</header> |
||||
<div{{ content_attributes.addClass('comment-body') }}> |
||||
{{ content }} |
||||
</div> <!-- /.comment-body --> |
||||
</article> |
@ -0,0 +1,103 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme implementation to display a node. |
||||
* |
||||
* Available variables: |
||||
* - node: The node entity with limited access to object properties and methods. |
||||
* Only method names starting with "get", "has", or "is" and a few common |
||||
* methods such as "id", "label", and "bundle" are available. For example: |
||||
* - node.getCreatedTime() will return the node creation timestamp. |
||||
* - node.hasField('field_example') returns TRUE if the node bundle includes |
||||
* field_example. (This does not indicate the presence of a value in this |
||||
* field.) |
||||
* - node.isPublished() will return whether the node is published or not. |
||||
* Calling other methods, such as node.delete(), will result in an exception. |
||||
* See \Drupal\node\Entity\Node for a full list of public properties and |
||||
* methods for the node object. |
||||
* - label: The title of the node. |
||||
* - content: All node items. Use {{ content }} to print them all, |
||||
* or print a subset such as {{ content.field_example }}. Use |
||||
* {{ content|without('field_example') }} to temporarily suppress the printing |
||||
* of a given child element. |
||||
* - author_picture: The node author user entity, rendered using the "compact" |
||||
* view mode. |
||||
* - metadata: Metadata for this node. |
||||
* - date: Themed creation date field. |
||||
* - author_name: Themed author name field. |
||||
* - url: Direct URL of the current node. |
||||
* - display_submitted: Whether submission information should be displayed. |
||||
* - attributes: HTML attributes for the containing element. |
||||
* The attributes.class element may contain one or more of the following |
||||
* classes: |
||||
* - node: The current template type (also known as a "theming hook"). |
||||
* - node--type-[type]: The current node type. For example, if the node is an |
||||
* "Article" it would result in "node--type-article". Note that the machine |
||||
* name will often be in a short form of the human readable label. |
||||
* - node--view-mode-[view_mode]: The View Mode of the node; for example, a |
||||
* teaser would result in: "node--view-mode-teaser", and |
||||
* full: "node--view-mode-full". |
||||
* The following are controlled through the node publishing options. |
||||
* - node--promoted: Appears on nodes promoted to the front page. |
||||
* - node--sticky: Appears on nodes ordered above other non-sticky nodes in |
||||
* teaser listings. |
||||
* - node--unpublished: Appears on unpublished nodes visible only to site |
||||
* admins. |
||||
* - title_attributes: Same as attributes, except applied to the main title |
||||
* tag that appears in the template. |
||||
* - content_attributes: Same as attributes, except applied to the main |
||||
* content tag that appears in the template. |
||||
* - author_attributes: Same as attributes, except applied to the author of |
||||
* the node tag that appears in the template. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title_suffix: Additional output populated by modules, intended to be |
||||
* displayed after the main title tag that appears in the template. |
||||
* - view_mode: View mode; for example, "teaser" or "full". |
||||
* - teaser: Flag for the teaser state. Will be true if view_mode is 'teaser'. |
||||
* - page: Flag for the full page state. Will be true if view_mode is 'full'. |
||||
* - readmore: Flag for more state. Will be true if the teaser content of the |
||||
* node cannot hold the main body content. |
||||
* - logged_in: Flag for authenticated user status. Will be true when the |
||||
* current user is a logged-in member. |
||||
* - is_admin: Flag for admin user status. Will be true when the current user |
||||
* is an administrator. |
||||
* |
||||
* @see template_preprocess_node() |
||||
*/ |
||||
#} |
||||
{% |
||||
set node_classes = [ |
||||
'node', |
||||
'node-type-' ~ node.bundle|clean_class, |
||||
node.isPromoted() ? 'node-promoted', |
||||
node.isSticky() ? 'node-sticky', |
||||
not node.isPublished() ? 'node-unpublished', |
||||
view_mode ? 'node-view-mode-' ~ view_mode|clean_class, |
||||
] |
||||
%} |
||||
<article{{ attributes.addClass(node_classes) }}> |
||||
{{ title_prefix }} |
||||
{% if not page %} |
||||
<h2{{ title_attributes.addClass('node-title') }}> |
||||
<a href="{{ url }}" rel="bookmark">{{ label }}</a> |
||||
</h2> |
||||
{% endif %} |
||||
{{ title_suffix }} |
||||
|
||||
{% if display_submitted %} |
||||
<header class="node-header clear"> |
||||
{% if node_author_pic %} |
||||
<div class="author-picture">{{ author_picture }}</div> |
||||
{% endif %} |
||||
<div{{ author_attributes.addClass('node-submitted-details') }}> |
||||
{% set createdDate = node.getCreatedTime|date('j F Y') %} |
||||
{% trans %}<span>{{ author_name }}</span> <span>{{ createdDate }}</span>{% endtrans %} |
||||
{{ metadata }} |
||||
</div> |
||||
</header> |
||||
{% endif %} |
||||
<div{{ content_attributes.addClass('node-content clear') }}> |
||||
{{ content }} |
||||
</div> |
||||
</article> |
@ -0,0 +1,21 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for page titles. |
||||
* |
||||
* Available variables: |
||||
* - title_attributes: HTML attributes for the page title element. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title: The page title, for use in the actual content. |
||||
* - title_suffix: Additional output populated by modules, intended to be |
||||
* displayed after the main title tag that appears in the template. |
||||
*/ |
||||
#} |
||||
<div class="page-title-wrap"> |
||||
{{ title_prefix }} |
||||
{% if title %} |
||||
<h1{{ title_attributes.addClass('page-title') }}>{{ title }}</h1> |
||||
{% endif %} |
||||
{{ title_suffix }} |
||||
</div> <!--/.page-title-wrap --> |
@ -0,0 +1,29 @@
|
||||
{% extends "item-list.html.twig" %} |
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for an item list of search results. |
||||
* |
||||
* Available variables: |
||||
* - items: A list of items. Each item contains: |
||||
* - attributes: HTML attributes to be applied to each list item. |
||||
* - value: The content of the list element. |
||||
* - title: The title of the list. |
||||
* - list_type: The tag for list element ("ul" or "ol"). |
||||
* - attributes: HTML attributes to be applied to the list. |
||||
* - empty: A message to display when there are no items. Allowed value is a |
||||
* string or render array. |
||||
* - context: An list of contextual data associated with the list. For search |
||||
* results, the following data is set: |
||||
* - plugin: The search plugin ID, for example "node_search". |
||||
* |
||||
* @see template_preprocess_item_list() |
||||
*/ |
||||
#} |
||||
{% |
||||
set classes = [ |
||||
'search-results', |
||||
context.plugin ~ '-results', |
||||
] |
||||
%} |
||||
{% set attributes = attributes.addClass(classes) %} |
@ -0,0 +1,44 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for comment fields. |
||||
* |
||||
* Available variables: |
||||
* - attributes: HTML attributes for the containing element. |
||||
* - label_hidden: Whether to show the field label or not. |
||||
* - title_attributes: HTML attributes for the title. |
||||
* - label: The label for the field. |
||||
* - title_prefix: Additional output populated by modules, intended to be |
||||
* displayed in front of the main title tag that appears in the template. |
||||
* - title_suffix: Additional title output populated by modules, intended to |
||||
* be displayed after the main title tag that appears in the template. |
||||
* - comments: List of comments rendered through comment.html.twig. |
||||
* - content_attributes: HTML attributes for the form title. |
||||
* - comment_form: The 'Add new comment' form. |
||||
* - comment_display_mode: Is the comments are threaded. |
||||
* - comment_type: The comment type bundle ID for the comment field. |
||||
* - entity_type: The entity type to which the field belongs. |
||||
* - field_name: The name of the field. |
||||
* - field_type: The type of the field. |
||||
* - label_display: The display settings for the label. |
||||
* |
||||
* @see template_preprocess_field() |
||||
* @see comment_preprocess_field() |
||||
*/ |
||||
#} |
||||
<section{{ attributes }} id="comments"> |
||||
{% if comments and not label_hidden %} |
||||
{{ title_prefix }} |
||||
<h2{{ title_attributes.addClass('comments-title') }}>{{ label }}</h2> |
||||
{{ title_suffix }} |
||||
{% endif %} |
||||
|
||||
{{ comments }} |
||||
|
||||
{% if comment_form %} |
||||
<div class="comment-form-wrap"> |
||||
<h2{{ content_attributes.addClass('add-comment-title') }}>{{ 'Add new comment'|t }}</h2> |
||||
{{ comment_form }} |
||||
</div> <!--/.comment-form --> |
||||
{% endif %} |
||||
</section> |
@ -0,0 +1,32 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for term fields. |
||||
* |
||||
* Available variables: |
||||
* - attributes: HTML attributes for the containing element. |
||||
* - label_hidden: Whether to show the field label or not. |
||||
* - title_attributes: HTML attributes for the label. |
||||
* - label: The label for the field. |
||||
* - content_attributes: HTML attributes for the content. |
||||
* - items: List of all the field items. Each item contains: |
||||
* - attributes: List of HTML attributes for each item. |
||||
* - content: The field item's content. |
||||
* - entity_type: The entity type to which the field belongs. |
||||
* - field_name: The name of the field. |
||||
* - field_type: The type of the field. |
||||
* - label_display: The display settings for the label. |
||||
* |
||||
* @see template_preprocess_field() |
||||
*/ |
||||
#} |
||||
<div class="node-taxonomy-container"> |
||||
{% if not label_hidden %} |
||||
<h3{{ title_attributes.addClass('term-title') }}>{{ label }}</h3> |
||||
{% endif %} |
||||
<ul class="taxonomy-terms"> |
||||
{% for item in items %} |
||||
<li{{ item.attributes.addClass('taxonomy-term') }}>{{ item.content }}</li> |
||||
{% endfor %} |
||||
</ul> |
||||
</div> <!--/.node-taxonomy-container --> |
@ -0,0 +1,80 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a field. |
||||
* |
||||
* To override output, copy the "field.html.twig" from the templates directory |
||||
* to your theme's directory and customize it, just like customizing other |
||||
* Drupal templates such as page.html.twig or node.html.twig. |
||||
* |
||||
* Instead of overriding the theming for all fields, you can also just override |
||||
* theming for a subset of fields using |
||||
* @link themeable Theme hook suggestions. @endlink For example, |
||||
* here are some theme hook suggestions that can be used for a field_foo field |
||||
* on an article node type: |
||||
* - field--node--field-foo--article.html.twig |
||||
* - field--node--field-foo.html.twig |
||||
* - field--node--article.html.twig |
||||
* - field--field-foo.html.twig |
||||
* - field--text-with-summary.html.twig |
||||
* - field.html.twig |
||||
* |
||||
* Available variables: |
||||
* - attributes: HTML attributes for the containing element. |
||||
* - label_hidden: Whether to show the field label or not. |
||||
* - title_attributes: HTML attributes for the title. |
||||
* - label: The label for the field. |
||||
* - multiple: TRUE if a field can contain multiple items. |
||||
* - items: List of all the field items. Each item contains: |
||||
* - attributes: List of HTML attributes for each item. |
||||
* - content: The field item's content. |
||||
* - entity_type: The entity type to which the field belongs. |
||||
* - field_name: The name of the field. |
||||
* - field_type: The type of the field. |
||||
* - label_display: The display settings for the label. |
||||
* |
||||
* |
||||
* @see template_preprocess_field() |
||||
*/ |
||||
#} |
||||
{% |
||||
set classes = [ |
||||
'field', |
||||
'field--name-' ~ field_name|clean_class, |
||||
'field--type-' ~ field_type|clean_class, |
||||
'field--label-' ~ label_display, |
||||
] |
||||
%} |
||||
{% |
||||
set title_classes = [ |
||||
'field__label', |
||||
label_display == 'visually_hidden' ? 'visually-hidden', |
||||
] |
||||
%} |
||||
|
||||
{% if label_hidden %} |
||||
{% if multiple %} |
||||
<div{{ attributes }}> |
||||
{% for item in items %} |
||||
<div{{ item.attributes.addClass('field-item') }}>{{ item.content }}</div> |
||||
{% endfor %} |
||||
</div> |
||||
{% else %} |
||||
{% for item in items %} |
||||
<div{{ attributes.addClass(classes, 'field-item') }}>{{ item.content }}</div> |
||||
{% endfor %} |
||||
{% endif %} |
||||
{% else %} |
||||
<div{{ attributes.addClass(classes) }}> |
||||
<div{{ title_attributes.addClass(title_classes) }}>{{ label }}</div> |
||||
{% if multiple %} |
||||
<div class="field__items"> |
||||
{% endif %} |
||||
{% for item in items %} |
||||
<div{{ item.attributes.addClass('field-item') }}>{{ item.content }}</div> |
||||
{% endfor %} |
||||
{% if multiple %} |
||||
</div> |
||||
{% endif %} |
||||
</div> |
||||
{% endif %} |
@ -0,0 +1,13 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override of an image. |
||||
* |
||||
* Available variables: |
||||
* - attributes: HTML attributes for the img tag. |
||||
* - style_name: (optional) The name of the image style applied. |
||||
* |
||||
* @see template_preprocess_image() |
||||
*/ |
||||
#} |
||||
<img{{ attributes.addClass('image-field') }} /> |
@ -0,0 +1,43 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a details element. |
||||
* |
||||
* Available variables |
||||
* - attributes: A list of HTML attributes for the details element. |
||||
* - errors: (optional) Any errors for this details element, may not be set. |
||||
* - title: (optional) The title of the element, may not be set. |
||||
* - description: (optional) The description of the element, may not be set. |
||||
* - children: (optional) The children of the element, may not be set. |
||||
* - value: (optional) The value of the element, may not be set. |
||||
* |
||||
* @see template_preprocess_details() |
||||
*/ |
||||
#} |
||||
<details{{ attributes }}> |
||||
{%- if title -%} |
||||
{% |
||||
set summary_classes = [ |
||||
required ? 'js-form-required', |
||||
required ? 'form-required', |
||||
] |
||||
%} |
||||
<summary{{ summary_attributes.addClass(summary_classes) }}>{{ title }}</summary> |
||||
{%- endif -%} |
||||
<div class="form-details-wrapper"> |
||||
{% if errors %} |
||||
<div class="form-item--error-message"> |
||||
<strong>{{ errors }}</strong> |
||||
</div> |
||||
{% endif %} |
||||
{%- if description -%} |
||||
<div class="details-description">{{ description }}</div> |
||||
{%- endif -%} |
||||
{%- if children -%} |
||||
{{ children }} |
||||
{%- endif -%} |
||||
{%- if value -%} |
||||
{{ value }} |
||||
{%- endif -%} |
||||
</div> |
||||
</details> |
@ -0,0 +1,59 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for the basic structure of a single Drupal page. |
||||
* |
||||
* Variables: |
||||
* - logged_in: A flag indicating if user is logged in. |
||||
* - root_path: The root path of the current page (e.g., node, admin, user). |
||||
* - node_type: The content type for the current node, if the page is a node. |
||||
* - head_title: List of text elements that make up the head_title variable. |
||||
* May contain one or more of the following: |
||||
* - title: The title of the page. |
||||
* - name: The name of the site. |
||||
* - slogan: The slogan of the site. |
||||
* - page_top: Initial rendered markup. This should be printed before 'page'. |
||||
* - page: The rendered page markup. |
||||
* - page_bottom: Closing rendered markup. This variable should be printed after |
||||
* 'page'. |
||||
* - db_offline: A flag indicating if the database is offline. |
||||
* - placeholder_token: The token for generating head, css, js and js-bottom |
||||
* placeholders. |
||||
* |
||||
* @see template_preprocess_html() |
||||
*/ |
||||
#} |
||||
{# Add class to body #} |
||||
{% |
||||
set body_classes = [ |
||||
not root_path ? 'homepage' : 'site-page', |
||||
node_type ? 'page-type-' ~ node_type|clean_class, |
||||
logged_in ? 'user-logged-in' : 'user-guest', |
||||
not page.sidebar_first and not page.sidebar_second ? 'no-sidebar', |
||||
page.sidebar_first and not page.sidebar_second ? 'one-sidebar sidebar-left', |
||||
page.sidebar_second and not page.sidebar_first ? 'one-sidebar sidebar-right', |
||||
page.sidebar_first and page.sidebar_second ? 'two-sidebar' |
||||
] |
||||
%} |
||||
<!DOCTYPE html> |
||||
<html{{ html_attributes }}> |
||||
<head> |
||||
<head-placeholder token="{{ placeholder_token }}"> |
||||
<title>{{ head_title|safe_join(' | ') }}</title> |
||||
<css-placeholder token="{{ placeholder_token }}"> |
||||
<js-placeholder token="{{ placeholder_token }}"> |
||||
</head> |
||||
<body{{ attributes.addClass(body_classes) }}> |
||||
{# |
||||
Keyboard navigation/accessibility link to main content section in |
||||
page.html.twig. |
||||
#} |
||||
<a href="#main-content" class="visually-hidden focusable"> |
||||
{{ 'Skip to main content'|t }} |
||||
</a> |
||||
{{ page_top }} |
||||
{{ page }} |
||||
{{ page_bottom }} |
||||
<js-bottom-placeholder token="{{ placeholder_token }}"> |
||||
</body> |
||||
</html> |
@ -0,0 +1,46 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme implementation to display a single Drupal page while offline. |
||||
* |
||||
* All available variables are mirrored in page.html.twig. |
||||
* |
||||
* @see template_preprocess_maintenance_page() |
||||
*/ |
||||
#} |
||||
<div id="maintenance-page"> |
||||
<header class="maintenance-header" role="banner"> |
||||
<div class="container"> |
||||
<div class="site-branding"> |
||||
{% if site_name or site_slogan %} |
||||
<div class="site-name-slogan"> |
||||
{% if site_name %} |
||||
<div class="site-name"> |
||||
<a href="{{ front_page }}" title="{{ 'Home'|t }}" rel="home"><h4>{{ site_name }}</h4></a> |
||||
</div> |
||||
{% endif %} |
||||
{% if site_slogan %} |
||||
<div class="site-slogan">{{ site_slogan }}</div> |
||||
{% endif %} |
||||
</div> <!--/.site-name-slogan --> |
||||
{% endif %} |
||||
</div> <!-- /.site-branding --> |
||||
</div> <!--/.container --> |
||||
</header> |
||||
<main id="maintenance"> |
||||
<div class="container maintenance"> |
||||
<a id="main-content" tabindex="-1"></a> |
||||
{% if title %} |
||||
<h1 class="maintenance-title">{{ title }}</h1> |
||||
{% endif %} |
||||
<div class="maintenance-icon"> |
||||
{{ source('@vre2024/../images/maintenance.svg') }} |
||||
</div> |
||||
<div class="maintenance-message"> |
||||
{{ page.content }} |
||||
</div> |
||||
</div> <!-- /.container --> |
||||
</main> <!-- /#maintenance --> |
||||
</div><!-- /#maintenance-page --> |
||||
<!-- Zuvi has custom styling for the maintenance page. --> |
||||
{{ attach_library('islandscholar/maintenance') }} |
@ -0,0 +1,41 @@
|
||||
{% if page.header_top_left or page.header_top_right %} |
||||
{% include '@vre2024/template-parts/header/header-top.html.twig' %} |
||||
{% endif %} |
||||
{% include '@vre2024/template-parts/header/header.html.twig' %} |
||||
{% if not is_front and page.page_header %} |
||||
{% include '@vre2024/template-parts/header/header-page.html.twig' %} |
||||
{% endif %} |
||||
{% if page.highlighted %} |
||||
{% include '@vre2024/template-parts/highlighted.html.twig' %} |
||||
{% endif %} |
||||
<div class="main-wrapper"> |
||||
<div class="container"> |
||||
<a id="main-content" tabindex="-1"></a> |
||||
<div class="main-container"> |
||||
<main id="main" class="main-content"> |
||||
{% if page.content_home_top %} |
||||
{% include '@vre2024/template-parts/content-parts/content_home_top.html.twig' %} |
||||
{% endif %} |
||||
{% if page.content_top %} |
||||
{% include '@vre2024/template-parts/content-parts/content_top.html.twig' %} |
||||
{% endif %} |
||||
<div class="node-content"> |
||||
{{ page.content }} |
||||
</div> |
||||
{% if page.content_bottom %} |
||||
{% include '@vre2024/template-parts/content-parts/content_bottom.html.twig' %} |
||||
{% endif %} |
||||
{% if page.content_home_bottom %} |
||||
{% include '@vre2024/template-parts/content-parts/content_home_bottom.html.twig' %} |
||||
{% endif %} |
||||
</main> |
||||
{% if page.sidebar_first %} |
||||
{% include '@vre2024/template-parts/sidebar/sidebar_left.html.twig' %} |
||||
{% endif %} |
||||
{% if page.sidebar_second %} |
||||
{% include '@vre2024/template-parts/sidebar/sidebar_right.html.twig' %} |
||||
{% endif %} |
||||
</div><!--/main-container --> |
||||
</div><!--/container --> |
||||
</div><!--/main-wrapper --> |
||||
{% include '@vre2024/template-parts/footer/footer.html.twig' %} |
@ -0,0 +1,35 @@
|
||||
{% if page.header_top_left or page.header_top_right %} |
||||
{% include '@vre2024/template-parts/header/header-top.html.twig' %} |
||||
{% endif %} |
||||
{% include '@vre2024/template-parts/header/header.html.twig' %} |
||||
{% if not is_front and page.page_header %} |
||||
{% include '@vre2024/template-parts/header/header-page.html.twig' %} |
||||
{% endif %} |
||||
{% if page.highlighted %} |
||||
{% include '@vre2024/template-parts/highlighted.html.twig' %} |
||||
{% endif %} |
||||
<div class="main-wrapper"> |
||||
<div class="container"> |
||||
<a id="main-content" tabindex="-1"></a> |
||||
<div class="main-container"> |
||||
<main id="main" class="main-content"> |
||||
{% if page.content_top %} |
||||
{% include '@vre2024/template-parts/content-parts/content_top.html.twig' %} |
||||
{% endif %} |
||||
<div class="node-content"> |
||||
{{ page.content }} |
||||
</div> |
||||
{% if page.content_bottom %} |
||||
{% include '@vre2024/template-parts/content-parts/content_bottom.html.twig' %} |
||||
{% endif %} |
||||
</main> |
||||
{% if page.sidebar_first %} |
||||
{% include '@vre2024/template-parts/sidebar/sidebar_left.html.twig' %} |
||||
{% endif %} |
||||
{% if page.sidebar_second %} |
||||
{% include '@vre2024/template-parts/sidebar/sidebar_right.html.twig' %} |
||||
{% endif %} |
||||
</div><!--/main-container --> |
||||
</div><!--/container --> |
||||
</div><!--/main-wrapper --> |
||||
{% include '@vre2024/template-parts/footer/footer.html.twig' %} |
@ -0,0 +1,25 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to display a region. |
||||
* |
||||
* Available variables: |
||||
* - content: The content for this region, typically blocks. |
||||
* - attributes: HTML attributes for the region div. |
||||
* - region: The name of the region variable as defined in the theme's |
||||
* .info.yml file. |
||||
* |
||||
* @see template_preprocess_region() |
||||
*/ |
||||
#} |
||||
{% |
||||
set classes = [ |
||||
'block-region', |
||||
'region-' ~ region|clean_class, |
||||
] |
||||
%} |
||||
{% if content %} |
||||
<div{{ attributes.addClass(classes) }}> |
||||
{{ content }} |
||||
</div> |
||||
{% endif %} |
@ -0,0 +1,53 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for status messages. |
||||
* |
||||
* Displays status, error, and warning messages, grouped by type. |
||||
* |
||||
* An invisible heading identifies the messages for assistive technology. |
||||
* Sighted users see a colored box. See http://www.w3.org/TR/WCAG-TECHS/H69.html |
||||
* for info. |
||||
* |
||||
* Add an ARIA label to the contentinfo area so that assistive technology |
||||
* user agents will better describe this landmark. |
||||
* |
||||
* Available variables: |
||||
* - message_list: List of messages to be displayed, grouped by type. |
||||
* - status_headings: List of all status types. |
||||
* - display: (optional) May have a value of 'status' or 'error' when only |
||||
* displaying messages of that specific type. |
||||
* - attributes: HTML attributes for the element, including: |
||||
* - class: HTML classes. |
||||
*/ |
||||
#} |
||||
<div data-drupal-messages class="messages-list"> |
||||
{% for type, messages in message_list %} |
||||
{% |
||||
set classes = [ |
||||
'message', |
||||
'message-' ~ type, |
||||
] |
||||
%} |
||||
<div role="contentinfo" aria-label="{{ status_headings[type] }}"{{ attributes.addClass(classes)|without('role', 'aria-label') }}> |
||||
{% if type == 'error' %} |
||||
<div role="alert" class="status-error"> |
||||
{% endif %} |
||||
{% if status_headings[type] %} |
||||
<h2 class="visually-hidden">{{ status_headings[type] }}</h2> |
||||
{% endif %} |
||||
{% if messages|length > 1 %} |
||||
<ul class="status-message-list"> |
||||
{% for message in messages %} |
||||
<li>{{ message }}</li> |
||||
{% endfor %} |
||||
</ul> |
||||
{% else %} |
||||
{{ messages|first }} |
||||
{% endif %} |
||||
{% if type == 'error' %} |
||||
</div> |
||||
{% endif %} |
||||
</div> |
||||
{% endfor %} |
||||
</div>{# messages-list #} |
@ -0,0 +1,56 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to navigate books. |
||||
* |
||||
* Presented under nodes that are a part of book outlines. |
||||
* |
||||
* Available variables: |
||||
* - tree: The immediate children of the current node rendered as an unordered |
||||
* list. |
||||
* - current_depth: Depth of the current node within the book outline. Provided |
||||
* for context. |
||||
* - prev_url: URL to the previous node. |
||||
* - prev_title: Title of the previous node. |
||||
* - parent_url: URL to the parent node. |
||||
* - parent_title: Title of the parent node. Not printed by default. Provided |
||||
* as an option. |
||||
* - next_url: URL to the next node. |
||||
* - next_title: Title of the next node. |
||||
* - has_links: Flags TRUE whenever the previous, parent or next data has a |
||||
* value. |
||||
* - book_id: The book ID of the current outline being viewed. Same as the node |
||||
* ID containing the entire outline. Provided for context. |
||||
* - book_url: The book/node URL of the current outline being viewed. Provided |
||||
* as an option. Not used by default. |
||||
* - book_title: The book/node title of the current outline being viewed. |
||||
* |
||||
* @see template_preprocess_book_navigation() |
||||
*/ |
||||
#} |
||||
{{ attach_library('islandscholar/book') }} |
||||
{% if tree or has_links %} |
||||
<nav class="book-navigation" role="navigation" aria-labelledby="book-label-{{ book_id }}"> |
||||
{{ tree }} |
||||
{% if has_links %} |
||||
<h2 class="visually-hidden">{{ 'Book traversal links for'|t }} {{ book_title }}</h2> |
||||
<ul class="book-pager"> |
||||
{% if prev_url %} |
||||
<li class="book-pager-item book-pager-item-previous"> |
||||
<a href="{{ prev_url }}" rel="prev" title="{{ 'Go to previous page'|t }}"><span class="white-color">←</span> {{ prev_title }}</a> |
||||
</li> |
||||
{% endif %} |
||||
{% if parent_url %} |
||||
<li class="book-pager-item book-pager-item-center"> |
||||
<a href="{{ parent_url }}" title="{{ 'Go to parent page'|t }}"><span class="white-color">⤊</span> {{ 'Up'|t }}</a> |
||||
</li> |
||||
{% endif %} |
||||
{% if next_url %} |
||||
<li class="book-pager-item book-pager-item-next"> |
||||
<a href="{{ next_url }}" rel="next" title="{{ 'Go to next page'|t }}">{{ next_title }} <span class="white-color">→</span></a> |
||||
</li> |
||||
{% endif %} |
||||
</ul> |
||||
{% endif %} |
||||
</nav> |
||||
{% endif %} |
@ -0,0 +1,47 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to display a book tree. |
||||
* |
||||
* Returns HTML for a wrapper for a book sub-tree. |
||||
* |
||||
* Available variables: |
||||
* - items: A nested list of book items. Each book item contains: |
||||
* - attributes: HTML attributes for the book item. |
||||
* - below: The book item child items. |
||||
* - title: The book link title. |
||||
* - url: The book link URL, instance of \Drupal\Core\Url. |
||||
* - is_expanded: TRUE if the link has visible children within the current |
||||
* book tree. |
||||
* - is_collapsed: TRUE if the link has children within the current book tree |
||||
* that are not currently visible. |
||||
* - in_active_trail: TRUE if the link is in the active trail. |
||||
*/ |
||||
#} |
||||
{% import _self as book_tree %} |
||||
|
||||
{# |
||||
We call a macro which calls itself to render the full tree. |
||||
@see http://twig.sensiolabs.org/doc/tags/macro.html |
||||
#} |
||||
{{ book_tree.book_links(items, attributes, 0) }} |
||||
|
||||
{% macro book_links(items, attributes, menu_level) %} |
||||
{% import _self as book_tree %} |
||||
{% if items %} |
||||
{% if menu_level == 0 %} |
||||
<ul{{ attributes.addClass('menu') }}> |
||||
{% else %} |
||||
<ul class="menu"> |
||||
{% endif %} |
||||
{% for item in items %} |
||||
<li{{ item.attributes.addClass('menu-book-item') }}> |
||||
{{ link(item.title, item.url) }} |
||||
{% if item.below %} |
||||
{{ book_tree.book_links(item.below, attributes, menu_level + 1) }} |
||||
{% endif %} |
||||
</li> |
||||
{% endfor %} |
||||
</ul> |
||||
{% endif %} |
||||
{% endmacro %} |
@ -0,0 +1,24 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a breadcrumb trail. |
||||
* |
||||
* Available variables: |
||||
* - breadcrumb: Breadcrumb trail items. |
||||
*/ |
||||
#} |
||||
{% if breadcrumb %} |
||||
<nav class="breadcrumb" role="navigation" aria-labelledby="system-breadcrumb"> |
||||
<ol class="breadcrumb-items"> |
||||
{% for item in breadcrumb %} |
||||
<li class="breadcrumb-item"> |
||||
{% if item.url %} |
||||
<a href="{{ item.url }}">{{ item.text }}</a><span><i class="icon-angle-right"></i></span> |
||||
{% else %} |
||||
{{ item.text }} |
||||
{% endif %} |
||||
</li> |
||||
{% endfor %} |
||||
</ol> |
||||
</nav> |
||||
{% endif %} |
@ -0,0 +1,57 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a set of links. |
||||
* |
||||
* Available variables: |
||||
* - attributes: Attributes for the UL containing the list of links. |
||||
* - links: Links to be output. |
||||
* Each link will have the following elements: |
||||
* - title: The link text. |
||||
* - href: The link URL. If omitted, the 'title' is shown as a plain text |
||||
* item in the links list. If 'href' is supplied, the entire link is passed |
||||
* to l() as its $options parameter. |
||||
* - attributes: (optional) HTML attributes for the anchor, or for the <span> |
||||
* tag if no 'href' is supplied. |
||||
* - heading: (optional) A heading to precede the links. |
||||
* - text: The heading text. |
||||
* - level: The heading level (e.g. 'h2', 'h3'). |
||||
* - attributes: (optional) A keyed list of attributes for the heading. |
||||
* If the heading is a string, it will be used as the text of the heading and |
||||
* the level will default to 'h2'. |
||||
* |
||||
* Headings should be used on navigation menus and any list of links that |
||||
* consistently appears on multiple pages. To make the heading invisible use |
||||
* the 'visually-hidden' CSS class. Do not use 'display:none', which |
||||
* removes it from screen readers and assistive technology. Headings allow |
||||
* screen reader and keyboard only users to navigate to or skip the links. |
||||
* See http://juicystudio.com/article/screen-readers-display-none.php and |
||||
* http://www.w3.org/TR/WCAG-TECHS/H42.html for more information. |
||||
* |
||||
* @see template_preprocess_links() |
||||
*/ |
||||
#} |
||||
{% if links -%} |
||||
<div class="node-links-container"> |
||||
{%- if heading -%} |
||||
{%- if heading.level -%} |
||||
<{{ heading.level }}{{ heading.attributes }}>{{ heading.text }}</{{ heading.level }}> |
||||
{%- else -%} |
||||
<h2{{ heading.attributes }}>{{ heading.text }}</h2> |
||||
{%- endif -%} |
||||
{%- endif -%} |
||||
<ul{{ attributes }}> |
||||
{%- for item in links -%} |
||||
<li{{ item.attributes }}> |
||||
{%- if item.link -%} |
||||
{{ item.link }} |
||||
{%- elseif item.text_attributes -%} |
||||
<span{{ item.text_attributes }}>{{ item.text }}</span> |
||||
{%- else -%} |
||||
{{ item.text }} |
||||
{%- endif -%} |
||||
</li> |
||||
{%- endfor -%} |
||||
</ul> |
||||
</div> <!--/.node-links-container --> |
||||
{%- endif %} |
@ -0,0 +1,17 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override for a local task link. |
||||
* |
||||
* Available variables: |
||||
* - attributes: HTML attributes for the wrapper element. |
||||
* - is_active: Whether the task item is an active tab. |
||||
* - link: A rendered link element. |
||||
* |
||||
* Note: This template renders the content for each task item in |
||||
* menu-local-tasks.html.twig. |
||||
* |
||||
* @see template_preprocess_menu_local_task() |
||||
*/ |
||||
#} |
||||
<li{{ attributes.addClass(is_active ? 'active-page-tab') }}>{{ link }}</li> |
@ -0,0 +1,21 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to display primary and secondary local tasks. |
||||
* |
||||
* Available variables: |
||||
* - primary: HTML list items representing primary tasks. |
||||
* - secondary: HTML list items representing primary tasks. |
||||
* |
||||
* Each item in these variables (primary and secondary) can be individually |
||||
* themed in menu-local-task.html.twig. |
||||
*/ |
||||
#} |
||||
{% if primary %} |
||||
<h2 class="visually-hidden">{{ 'Primary tabs'|t }}</h2> |
||||
<ul class="page-tabs primary-tab">{{ primary }}</ul> |
||||
{% endif %} |
||||
{% if secondary %} |
||||
<h2 class="visually-hidden">{{ 'Secondary tabs'|t }}</h2> |
||||
<ul class="page-tabs secondary-tab">{{ secondary }}</ul> |
||||
{% endif %} |
@ -0,0 +1,57 @@
|
||||
{# |
||||
/** |
||||
* @file |
||||
* Theme override to display main menu. |
||||
* |
||||
* Available variables: |
||||
* - menu_name: The machine name of the menu. |
||||
* - items: A nested list of menu items. Each menu item contains: |
||||
* - attributes: HTML attributes for the menu item. |
||||
* - below: The menu item child items. |
||||
* - title: The menu link title. |
||||
* - url: The menu link url, instance of \Drupal\Core\Url |
||||
* - localized_options: Menu link localized options. |
||||
* - is_expanded: TRUE if the link has visible children within the current |
||||
* menu tree. |
||||
* - is_collapsed: TRUE if the link has children within the current menu tree |
||||
* that are not currently visible. |
||||
* - in_active_trail: TRUE if the link is in the active trail. |
||||
*/ |
||||
#} |
||||
{% import _self as menus %} |
||||
|
||||
{# |
||||
We call a macro which calls itself to render the full tree. |
||||
@see http://twig.sensiolabs.org/doc/tags/macro.html |
||||
#} |
||||
{{ menus.menu_links(items, attributes, 0) }} |
||||
|
||||
{% macro menu_links(items, attributes, menu_level) %} |
||||
{% import _self as menus %} |
||||
{% if items %} |
||||
{% if menu_level == 0 %} |
||||
<ul{{ attributes.addClass('menu') }}> |
||||
{% else %} |
||||
<ul class="submenu"> |
||||
{% endif %} |
||||
{% for item in items %} |
||||
{% |
||||
set item_classes = [ |
||||
'menu-item', |
||||
'menu-item-level-' ~ (menu_level + 1), |
||||
item.is_expanded ? 'expanded', |
||||
item.is_collapsed ? 'collapsed', |
||||
item.below ? 'menu-item-has-children', |
||||
item.in_active_trail ? 'active', |
||||
] |
||||
%} |
||||
<li{{ item.attributes.addClass(item_classes) }}> |
||||
{{ link(item.title, item.url) }} |
||||
{% if item.below %} |
||||
{{ menus.menu_links(item.below, attributes, menu_level + 1) }} |
||||
{% endif %} |
||||
</li> |
||||
{% endfor %} |
||||
</ul> |
||||
{% endif %} |
||||
{% endmacro %} |
@ -0,0 +1 @@
|
||||
<div class="scrolltop"><i class="icon-arrow-up"></i></div> |
@ -0,0 +1,3 @@
|
||||
<div class="content-bottom"> |
||||
{{ page.content_bottom }} |
||||
</div><!--/.content bottom --> |
@ -0,0 +1,3 @@
|
||||
<div class="homepage-content homepage-content-bottom"> |
||||
{{ page.content_home_bottom }} |
||||
</div><!--/.homepage-content --> |
@ -0,0 +1,3 @@
|
||||
<div class="homepage-content homepage-content-top"> |
||||
{{ page.content_home_top }} |
||||
</div><!--/.homepage-content --> |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue