Vmeda.Online/src/theme/theme.base.scss

613 lines
13 KiB
SCSS
Raw Normal View History

@import "./globals.scss";
// Common styles.
.text-left { text-align: left; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.text-justify { text-align: justify; }
.clearfix {
2021-01-27 16:04:21 +00:00
&:after {
content: "";
display: table;
clear: both;
2021-01-27 16:04:21 +00:00
}
}
.core-bold {
font-weight: bold;
}
.img-responsive {
2021-01-27 16:04:21 +00:00
display: block;
max-width: 100%;
&[height] {
height: auto;
2021-01-27 16:04:21 +00:00
}
}
2021-01-27 16:04:21 +00:00
.opacity-hide { opacity: 0; }
.core-big { font-size: 115%; }
.invisible { visibility: hidden; }
2021-01-27 16:04:21 +00:00
.button-no-uppercase {
2021-01-27 16:04:21 +00:00
text-transform: none;
}
2021-01-27 16:04:21 +00:00
.flex { display: flex; }
.inline-block { display: inline-block; }
.block { display: block; }
.flex-row {
display: flex;
flex-direction: row;
}
.margin-bottom-sm { margin-bottom: 8px; }
.margin-bottom-md { margin-bottom: 12px; }
.font-bold { font-weight: bold; }
.font-italic { font-style: italic; }
.font-lg { font-size: 1.7rem; }
.font-sm { font-size: 1.2rem; }
2020-11-04 15:16:57 +00:00
// Correctly inherit ion-text-wrap onto labels.
ion-item.ion-text-wrap ion-label {
white-space: normal !important;
}
2021-02-05 14:08:21 +00:00
// It fixes the click on links where ion-ripple-effect is present.
.ion-activatable ion-label,
.item-multiple-items ion-label {
z-index: 3;
pointer-events: none;
ion-anchor, ion-button, a, button {
pointer-events: visible;
}
}
@each $color-name, $value in $colors {
$value: map-get($colors, $color-name);
$base: map-get($value, base);
.text-#{$color-name},
p.text-#{$color-name} {
color: $base;
}
}
2020-10-29 10:42:50 +00:00
// Ionic toolbar.
ion-toolbar ion-back-button,
ion-toolbar .in-toolbar.button-clear {
--color: var(--core-header-toolbar-color);
--ion-toolbar-color: var(--core-header-toolbar-color);
}
ion-header ion-toolbar .button.button-clear,
ion-header ion-toolbar .button.button-solid {
--background: transparent;
--color: var(--core-header-toolbar-color);
--ion-color-primary: var(--core-header-toolbar-color);
}
ion-header ion-toolbar .button.button-clear.button-has-icon-only,
ion-header ion-toolbar .button.button-solid.button-has-icon-only {
--border-radius: 50%;
width: 48px;
height: 48px;
}
ion-toolbar .core-navbar-button-hidden {
display: none !important;
}
2020-10-29 10:42:50 +00:00
// Ionic icon.
ion-icon {
&.icon-slash::after,
&.icon-backslash::after {
content: " ";
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
background-color: var(--ion-color-danger);
-webkit-mask: url("/assets/fonts/font-awesome/solid/slash.svg") no-repeat 50% 50%;
mask: url("/assets/fonts/font-awesome/solid/slash.svg") no-repeat 50% 50%;
}
&.icon-slash::after {
-webkit-transform: scale(-1, 1);
transform: scale(-1, 1);
}
&.fa-fw {
text-align: center;
width: 1.25em;
}
}
ion-button.button-small ion-icon.faicon[slot] {
font-size: 1.5em !important;
}
[dir=rtl] ion-icon.icon-flip-rtl,
[dir=rtl] ion-item::part(detail-icon),
[dir=rtl] ion-icon.item-detail-icon {
transform: scaleX(-1);
}
// Buttons.
ion-button,
ion-fab-button,
button,
[role="button"] {
min-height: var(--a11y-min-target-size);
min-width: var(--a11y-min-target-size);
}
[role="button"] {
cursor: pointer;
[disabled],
[aria-disabled="true"] {
cursor: auto;
}
}
ion-button.core-button-as-link {
text-transform: none;
text-decoration: underline;
font-size: inherit;
font-weight: normal;
letter-spacing: normal;
white-space: break-spaces;
}
2020-10-29 10:42:50 +00:00
// Ionic alert.
ion-alert.core-alert-network-error .alert-head,
div.core-iframe-network-error {
2020-10-29 10:42:50 +00:00
position: relative;
content: " ";
background: url("/assets/fonts/font-awesome/solid/wifi.svg") no-repeat 50% 50%;
margin: 25px auto;
&::after {
content: " ";
position: absolute;
top: -20%;
right: -15%;
width: 50%;
height: 50%;
background-color: var(--ion-color-danger);
-webkit-mask: url("/assets/fonts/font-awesome/solid/exclamation-triangle.svg") no-repeat 50% 50%;
mask: url("/assets/fonts/font-awesome/solid/exclamation-triangle.svg") no-repeat 50% 50%;
}
}
[dir=rtl] ion-alert.core-alert-network-error .alert-head::after,
[dir=rtl] div.core-iframe-network-error::after {
2020-10-29 10:42:50 +00:00
right: unset;
left: -15%;
}
ion-alert.core-nohead {
.alert-head {
padding-bottom: 0;
}
}
2020-10-29 10:42:50 +00:00
// Ionic list.
ion-list.list-md {
padding: 0;
2020-10-29 10:42:50 +00:00
}
// Header.
ion-tabs.hide-header ion-header {
display: none;
}
ion-toolbar {
ion-spinner {
margin: 10px;
}
}
// Modals.
.core-modal-fullscreen .modal-wrapper {
position: absolute;
@include position(0 !important, null, null, 0 !important);
display: block;
width: 100% !important;
height: 100% !important;
}
.core-modal-force-on-top {
z-index: 100000 !important;
}
@media only screen and (min-height: 400px) and (min-width: 300px) {
.core-modal-lateral {
.modal-wrapper {
position: absolute;
@include position(0 !important, 0 !important, 0 !important, unset !important);
display: block;
height: 100% !important;
width: auto;
min-width: 300px;
box-shadow: 0 28px 48px rgba(0, 0, 0, 0.4);
}
ion-backdrop {
visibility: visible;
}
}
}
// Hidden submit button.
.core-submit-hidden-enter {
position: absolute;
visibility: hidden;
left: -1000px;
}
// Note on foot of ion-input.
.item .core-input-footnote {
width: 100%;
font-style: italic;
margin-top: 0;
margin-bottom: 10px;
font-size: 14px;
}
2020-11-04 15:16:57 +00:00
// Item styles
[aria-current="page"] {
2021-01-26 17:30:00 +00:00
// TODO: Add safe area to border and RTL
--ion-safe-area-left: calc(-1 * var(--selected-item-border-width));
border-inline-start: var(--selected-item-border-width) solid var(--selected-item-color);
}
.item.item-file {
ion-thumbnail {
--size: 32px;
width: var(--size);
height: var(--size);
}
}
.item-dimmed {
2021-01-27 16:04:21 +00:00
opacity: 0.7;
--background: var(--gray-lighter);
}
// Extra text colors.
.text-gray {
color: var(--gray-dark);
}
// Card styles
@each $color-name, $value in $colors {
$value: map-get($colors, $color-name);
$base: map-get($value, base);
$contrast: map-get($value, contrast);
$shade: map-get($value, shade);
$tint: map-get($value, tint);
// Message cards.
ion-card.core-#{$color-name}-card {
border-bottom: 3px solid $base;
ion-item::part(native) {
--inner-border-width: 0;
}
ion-label {
white-space: normal !important;
}
ion-icon {
color: $base;
}
}
.item.core-#{$color-name}-item {
--inner-border-width: 0 0 3px 0;
--border-width: 0;
border-bottom: 3px solid $base !important;
ion-icon {
color: $base;
}
}
2021-04-23 11:24:48 +00:00
ion-icon.ion-color-#{$color-name} {
color: $base;
--ion-color-base: #{$base};
}
}
2020-11-04 15:16:57 +00:00
// Avatar
// -------------------------
// Large centered avatar
2020-12-04 14:23:00 +00:00
img.large-avatar,
.large-avatar img {
2020-11-04 15:16:57 +00:00
display: block;
margin: 8px auto;
2020-12-04 14:23:00 +00:00
width: var(--core-large-avatar-size);
height: var(--core-large-avatar-size);
max-width: var(--core-large-avatar-size);
max-height: var(--core-large-avatar-size);
2020-11-04 15:16:57 +00:00
margin-bottom: 10px;
border-radius : 50%;
padding: 4px;
border: 1px solid #ddd;
background-color: transparent;
}
2020-12-04 14:23:00 +00:00
ion-avatar.large-avatar {
width: var(--core-large-avatar-size);
height: var(--core-large-avatar-size);
}
2020-11-04 15:16:57 +00:00
ion-avatar ion-img, ion-avatar img {
text-indent: -99999px;
background-color: var(--gray-light);
2020-11-04 15:16:57 +00:00
}
// Wait to load before showing the image.
img[core-external-content]:not([src]) {
visibility: hidden;
}
img[alt] {
text-indent: -999999px;
white-space: nowrap;
overflow: hidden;
}
// Activity modules
2021-01-26 17:30:00 +00:00
.core-module-icon {
--size: var(--module-icon-size);
width: var(--size);
height: var(--size);
max-width: var(--size);
max-height: var(--size);
2021-01-26 17:30:00 +00:00
}
ion-item img.core-module-icon[slot="start"] {
margin-top: 12px;
margin-bottom: 12px;
margin-right: 32px;
}
2021-01-26 17:30:00 +00:00
[dir=rtl] ion-item img.core-module-icon[slot="start"] {
margin-right: unset;
margin-left: 32px;
}
ion-toolbar ion-title img.core-bar-button-image,
ion-toolbar ion-title .core-bar-button-image img {
padding: 0;
width: var(--core-header-toolbar-button-image-size);
height: var(--core-header-toolbar-button-image-size);
max-width: var(--core-header-toolbar-button-image-size);
max-height: var(--core-header-toolbar-button-image-size);
border-radius: 50%;
}
// Action sheet.
.md ion-action-sheet {
.action-sheet-group-cancel {
-webkit-filter: drop-shadow(0px 3px 3px rgba(var(--action-sheet-shadow-color)));
filter: drop-shadow(0px 3px 3px rgba(var(--action-sheet-shadow-color)));
}
.action-sheet-title {
border-bottom: 1px solid var(--title-border-color);
}
}
.ios ion-action-sheet {
.action-sheet-title {
font-size: 16px;
}
}
// Select.
2021-02-05 14:08:21 +00:00
ion-select::part(text) {
white-space: normal;
}
// File uploader.
.action-sheet-button input.core-fileuploader-file-handler-input {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
min-width: 100%;
opacity: 0;
z-index: 100;
cursor: pointer;
}
2020-11-17 10:00:46 +00:00
.core-anchor, core-format-text a {
color: var(--core-link-color);
2020-11-17 10:00:46 +00:00
cursor: pointer;
text-decoration: underline;
}
core-block ion-item-divider .core-button-spinner {
display: flex;
align-items: center;
@include margin-horizontal(10px);
ion-badge.core-course-download-courses-progress {
@include margin(null, 12px, null, null);
}
}
// Horizontal scrolling elements
.core-horizontal-scroll {
display: flex;
flex-flow: nowrap;
overflow-x: scroll;
flex-direction: row;
}
2021-01-21 14:00:38 +00:00
// Text formats.
// Highlight text.
.matchtext {
background-color: var(--text-hightlight-background-color);
2021-01-21 14:00:38 +00:00
}
// Monospaced font.
.core-monospaced {
font-family: Andale Mono,Monaco,Courier New,DejaVu Sans Mono,monospace;
}
.core-iframe-offline-disabled {
display: none !important;
}
.core-scanning-qr {
.ion-page, .modal-wrapper {
background-color: transparent !important;
--background: transparent;
}
ion-content, ion-backdrop, ion-modal:not(.core-modal-fullscreen), ion-tabs {
display: none !important;
}
}
// Hide virtual utilities.
.core-browser-copy-area {
display: none;
}
// Different levels of padding.
@for $i from 0 through 15 {
.core-padding-#{$i} {
@include padding(null, null, null, 15px * $i + 16px);
}
}
textarea {
min-height: var(--a11y-min-target-size);
}
textarea:not([core-auto-rows]) {
height: 200px;
}
ion-fab[core-fab] {
position: fixed;
}
ion-content > ion-fab[core-fab] {
position: absolute;
}
ion-back-button.md::part(text) {
display: none;
}
.core-media-adapt-width {
max-width: 100%;
}
img.core-media-adapt-width {
height: auto;
}
audio.core-media-adapt-width {
width: 100%;
}
// Make links clickable when inside radio or checkbox items. Style part.
@media (any-hover: hover) {
ion-item.item-multiple-inputs:hover::part(native) {
color: var(--color-hover);
&::after {
background: var(--background-hover);
opacity: var(--background-hover-opacity);
}
}
ion-item.ion-color.item-multiple-inputs:hover::part(native) {
color: #{current-color(contrast)};
&::after {
background: #{current-color(contrast)};
}
}
}
// Make links clickable when inside radio or checkbox items. Pointer and cursor part.
ion-item.item-multiple-inputs {
cursor: pointer;
ion-label {
z-index: 3;
pointer-events: none;
ion-anchor, a,
ion-button, button,
audio, video {
pointer-events: visible;
}
}
ion-checkbox, ion-datetime, ion-radio, ion-select{
position: static;
}
}
// Focus highlight for accessibility.
2021-05-13 14:39:16 +00:00
ion-item.item-input.ion-focused:not(:focus),
.ion-focused,
2021-05-13 14:39:16 +00:00
ion-item.ion-activatable.ion-focused:not(:focus),
ion-input.has-focus,
.ion-focused ion-toggle:focus-within,
.ion-focused ion-select:focus-within,
.ion-focused ion-checkbox:focus-within,
.ion-focused ion-radio:focus-within {
2021-05-13 14:39:16 +00:00
@include core-focus();
}
// Treat cases where there's a focusable element inside an item, like a button.
2021-05-13 14:39:16 +00:00
ion-item.ion-focused:not(:focus),
ion-item.item-input ion-input.has-focus {
position: relative;
&::after {
box-shadow: revert;
opacity: revert;
z-index: revert;
}
.item-highlight, .item-inner-highlight {
position: unset;
}
}
// Change default outline.
:focus-visible {
@include core-focus-style();
outline: none;
}
textarea, button, select, input, a {
&:focus {
@include core-focus-style();
outline: none;
}
}
ion-loading:focus-visible,
ion-alert:focus-visible,
ion-popover:focus-visible,
ion-modal:focus-visible {
box-shadow: none;
}
2021-05-13 14:39:16 +00:00
ion-input .native-input{
&:focus, &:focus-visible {
box-shadow: none;
outline: none;
}
}