87 lines
2.4 KiB
SCSS

@use "theme/globals" as *;
:host {
display: inline-block;
--size: var(--module-icon-size, 32px);
--padding-start: var(--module-icon-padding, 4px);
--padding-top: var(--module-icon-padding, 4px);
--padding-end: var(--module-icon-padding, 4px);
--padding-bottom: var(--module-icon-padding, 4px);
--icon-radius: var(--module-icon-radius, var(--radius-xs));
--margin-end: 0px;
--margin-vertical: 0px;
min-width: calc(var(--size) + var(--padding-start) + var(--padding-end));
min-height: calc(var(--size) + var(--padding-top) + var(--padding-bottom));
margin-top: var(--margin-vertical);
margin-bottom: var(--margin-vertical);
@include margin-horizontal(null, var(--margin-end));
border-radius: var(--icon-radius);
@include padding(var(--padding-top), var(--padding-end), var(--padding-bottom), var(--padding-start));
background-color: transparent;
line-height: var(--size);
--color: var(--text-color);
&.colorize {
&.version_current {
@each $type, $value in $activity-icon-colors {
&.#{$type} {
--color: var(--activity#{$type});
}
}
}
&.version_40 {
background-color: var(--gray-100);
--color: white;
@each $type, $value in $activity-icon-background-colors {
&.#{$type}:not(.branded) {
background-color: var(--activity-40-#{$type});
}
}
}
}
&.version_40,
&.version_legacy {
--size: var(--module-legacy-icon-size, 24px);
--padding-start: var(--module-legacy-icon-padding, 8px);
--padding-top: var(--module-legacy-icon-padding, 8px);
--padding-end: var(--module-legacy-icon-padding, 8px);
--padding-bottom: var(--module-legacy-icon-padding, 8px);
}
&:not(.branded) {
::ng-deep svg,
::ng-deep svg * {
fill: var(--color);
}
}
img,
::ng-deep svg {
width: var(--size);
height: var(--size);
max-width: var(--size);
max-height: var(--size);
min-width: var(--size);
min-height: var(--size);
vertical-align: top;
}
}
:host-context(ion-item) {
--margin-vertical: 12px;
--margin-end: 1rem;
}
:host-context(ion-card ion-item) {
--margin-vertical: 12px;
--margin-end: 12px;
}