2020-12-14 16:30:13 +01:00

275 lines
6.1 KiB
SCSS

// Correctly inherit ion-text-wrap onto labels.
ion-item.ion-text-wrap ion-label {
white-space: normal !important;
}
// Ionic toolbar.
ion-toolbar ion-back-button,
ion-toolbar .in-toolbar.button-clear {
--color: var(--ion-color-primary-contrast);
}
ion-toolbar .core-navbar-button-hidden {
display: none !important;
}
// 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;
}
}
// Ionic alert.
ion-alert.core-alert-network-error .alert-head {
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 {
right: unset;
left: -15%;
}
ion-alert.core-nohead {
.alert-head {
padding-bottom: 0;
}
}
// Ionic item divider.
ion-item-divider {
--background: var(--gray-lighter);
.item-detail-icon {
font-size: 20px;
opacity: 0.25;
padding-inline-end: 16px;
}
}
// Ionic list.
ion-list.list-md {
padding-bottom: 0;
}
// Header.
ion-tabs.hide-header ion-header {
display: none;
}
ion-toolbar {
ion-spinner {
margin: 10px;
}
}
// Modals.
.core-modal-fullscreen .modal-wrapper {
position: absolute;
// @todo @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;
}
// 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;
}
// Item styles
.item.core-selected-item {
// TODO: Add safe are to border and RTL
border-inline-start: var(--selected-item-border-width) solid var(--selected-item-color);
--ion-safe-area-left: calc(-1 * var(--selected-item-border-width));
}
.item.item-file {
ion-thumbnail {
--size: 32px;
width: var(--size);
height: var(--size);
}
}
.item.core-primary-item,
.item.core-info-item,
.item.core-secondary-item,
.item.core-tertiary-item,
.item.core-success-item,
.item.core-warning-item,
.item.core-danger-item {
--inner-border-width: 0 0 3px 0;
}
.item.core-primary-item {
--border-color: var(--ion-color-primary);
}
.item.core-info-item,
.item.core-secondary-item {
--border-color: var(--ion-color-secondary);
}
.item.core-tertiary-item {
--border-color: var(--ion-color-tertiary);
}
.item.core-success-item {
--border-color: var(--ion-color-success);
}
.item.core-warning-item {
--border-color: var(--ion-color-warning);
}
.item.core-danger-item {
--border-color: var(--ion-color-danger);
}
// Card styles
// Message cards.
ion-card.core-primary-card,
ion-card.core-info-card,
ion-card.core-secondary-card,
ion-card.core-tertiary-card,
ion-card.core-success-card,
ion-card.core-warning-card,
ion-card.core-danger-card {
border-bottom: 3px solid transparent;
}
ion-card.core-primary-card {
border-bottom-color: var(--ion-color-primary);
}
ion-card.core-info-card,
ion-card.core-secondary-card {
border-bottom-color: var(--ion-color-secondary);
}
ion-card.core-tertiary-card {
border-bottom-color: var(--ion-color-tertiary);
}
ion-card.core-success-card {
border-bottom-color: var(--ion-color-success);
}
ion-card.core-warning-card {
border-bottom-color: var(--ion-color-warning);
}
ion-card.core-danger-card {
border-bottom-color: var(--ion-color-danger);
}
// Avatar
// -------------------------
// Large centered avatar
img.large-avatar,
.large-avatar img {
display: block;
margin: auto;
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);
margin-bottom: 10px;
border-radius : 50%;
padding: 4px;
border: 1px solid #ddd;
background-color: transparent;
}
ion-avatar.large-avatar {
width: var(--core-large-avatar-size);
height: var(--core-large-avatar-size);
}
ion-avatar ion-img, ion-avatar img {
text-indent: -99999px;
background-color: var(--gray-light);
}
// 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.
ion-select.core-button-select,
.core-button-select {
background-color: var(--ion-color-primary-contrast);
color: var(--ion-color-primary);
white-space: normal;
min-height: 45px;
}
// 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;
}
.core-anchor, core-format-text a {
color: -webkit-link;
cursor: pointer;
text-decoration: underline;
}