/* mixins & extensions */ @keyframes in { 0% { opacity: 0; } 100% { opacity: 1; } } @keyframes in-down { 0% { opacity: 0; transform: translate3D(0, -5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-up { 0% { opacity: 0; transform: translate3D(0, 5px, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-scale { 0% { opacity: 0; transform: scale3D(0.95, 0.95, 1); } 100% { opacity: 1; transform: scale3D(1, 1, 1); } } :root { --calcite-animation-timing: calc(150ms * var(--calcite-internal-duration-factor)); --calcite-internal-duration-factor: var(--calcite-duration-factor, 1); --calcite-internal-animation-timing-fast: calc(100ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-medium: calc(200ms * var(--calcite-internal-duration-factor)); --calcite-internal-animation-timing-slow: calc(300ms * var(--calcite-internal-duration-factor)); } .calcite-animate { opacity: 0; animation-fill-mode: both; animation-duration: var(--calcite-animation-timing); } .calcite-animate__in { animation-name: in; } .calcite-animate__in-down { animation-name: in-down; } .calcite-animate__in-up { animation-name: in-up; } .calcite-animate__in-scale { animation-name: in-scale; } @media (prefers-reduced-motion: reduce) { :root { --calcite-internal-duration-factor: 0.01; } } /** * Currently only used in Checkbox. */ :host { /* Base ":host" styles for the component */ box-sizing: border-box; background-color: var(--calcite-ui-foreground-1); color: var(--calcite-ui-text-2); font-size: var(--calcite-font-size--1); } :host * { box-sizing: border-box; } :root { --calcite-floating-ui-transition: var(--calcite-animation-timing); } :host([hidden]) { display: none; } :host([disabled]) { pointer-events: none; cursor: default; -webkit-user-select: none; user-select: none; opacity: var(--calcite-ui-opacity-disabled); } /** * CSS Custom Properties * * These properties can be overridden using the component's tag as selector. * * @prop --calcite-panel-max-height: The maximum height of the component. * @prop --calcite-panel-max-width: The maximum width of the component. * @prop --calcite-panel-min-width: The minimum width of the component. */ :host { position: relative; display: flex; inline-size: 100%; flex: 1 1 auto; overflow: hidden; --calcite-min-header-height: calc(var(--calcite-icon-size) * 3); --calcite-panel-max-height: unset; --calcite-panel-width: 100%; --calcite-panel-min-width: unset; --calcite-panel-max-width: unset; } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; } /* Shared styles for header elements */ .header { margin: 0px; display: flex; align-content: space-between; align-items: center; fill: var(--calcite-ui-text-2); color: var(--calcite-ui-text-2); } .heading { margin: 0px; padding: 0px; font-weight: var(--calcite-font-weight-medium); } .header .heading { flex: 1 1 auto; padding: 0.5rem; } .container { margin: 0px; display: flex; inline-size: 100%; flex: 1 1 auto; flex-direction: column; align-items: stretch; background-color: var(--calcite-ui-background); padding: 0px; max-block-size: var(--calcite-panel-max-height); inline-size: var(--calcite-panel-width); max-inline-size: var(--calcite-panel-max-width); min-inline-size: var(--calcite-panel-min-width); transition: max-block-size var(--calcite-animation-timing), inline-size var(--calcite-animation-timing); } :host([height-scale=s]) { --calcite-panel-max-height: 40vh; } :host([height-scale=m]) { --calcite-panel-max-height: 60vh; } :host([height-scale=l]) { --calcite-panel-max-height: 80vh; } :host([width-scale=s]) { --calcite-panel-width: calc(var(--calcite-panel-width-multiplier) * 12vw); --calcite-panel-max-width: calc(var(--calcite-panel-width-multiplier) * 300px); --calcite-panel-min-width: calc(var(--calcite-panel-width-multiplier) * 150px); } :host([width-scale=m]) { --calcite-panel-width: calc(var(--calcite-panel-width-multiplier) * 20vw); --calcite-panel-max-width: calc(var(--calcite-panel-width-multiplier) * 420px); --calcite-panel-min-width: calc(var(--calcite-panel-width-multiplier) * 240px); } :host([width-scale=l]) { --calcite-panel-width: calc(var(--calcite-panel-width-multiplier) * 45vw); --calcite-panel-max-width: calc(var(--calcite-panel-width-multiplier) * 680px); --calcite-panel-min-width: calc(var(--calcite-panel-width-multiplier) * 340px); } .container[hidden] { display: none; } .header { border-block-end: 1px solid; position: sticky; inset-block-start: 0px; z-index: 400; inline-size: 100%; align-items: stretch; justify-content: flex-start; background-color: var(--calcite-ui-foreground-1); border-block-end-color: var(--calcite-ui-border-3); flex: 0 0 auto; } .header-content { display: flex; flex-direction: column; overflow: hidden; padding-inline: 0.75rem; padding-block: 0.875rem; margin-inline-end: auto; } .header-content .heading, .header-content .description { display: block; overflow-wrap: break-word; padding: 0px; } .header-content .heading { margin-inline: 0px; margin-block: 0px 0.25rem; font-size: var(--calcite-font-size-0); line-height: 1.25rem; font-weight: var(--calcite-font-weight-medium); } .header-content .heading:only-child { margin-block-end: 0px; } .header-content .description { font-size: var(--calcite-font-size--1); line-height: 1rem; color: var(--calcite-ui-text-2); } .back-button { border-width: 0px; border-style: solid; border-color: var(--calcite-ui-border-3); border-inline-end-width: 1px; } .header-actions { display: flex; flex-direction: row; flex-wrap: nowrap; align-items: stretch; } .header-actions--end { margin-inline-start: auto; } .content-wrapper { overflow: auto; } .content-height { block-size: 100%; } .content-container { display: flex; flex: 1 1 auto; flex-direction: column; flex-wrap: nowrap; align-items: stretch; background-color: var(--calcite-ui-background); } .footer { border-block-start: 1px solid; position: sticky; inset-block-end: 0px; display: flex; inline-size: 100%; justify-content: space-evenly; background-color: var(--calcite-ui-foreground-1); border-block-start-color: var(--calcite-ui-border-3); flex: 0 0 auto; min-block-size: 3rem; padding: 0.5rem; } .fab-container { position: sticky; inset-block-end: 0px; z-index: 300; margin-block: 0px; margin-inline: auto; display: block; padding: 0.5rem; inset-inline: 0; inline-size: -moz-fit-content; inline-size: fit-content; } [hidden] { display: none; }