UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

320 lines (286 loc) • 6.34 kB
/* 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-right { 0% { opacity: 0; transform: translate3D(-5px, 0, 0); } 100% { opacity: 1; transform: translate3D(0, 0, 0); } } @keyframes in-left { 0% { opacity: 0; transform: translate3D(5px, 0, 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-right { animation-name: in-right; } .calcite-animate__in-left { animation-name: in-left; } .calcite-animate__in-scale { animation-name: in-scale; } @media (prefers-reduced-motion: reduce) { :root { --calcite-internal-duration-factor: 0.01; } } /* helper to properly scale internal durations */ /** * Currently only used in Checkbox. */ :root { --calcite-floating-ui-transition: var(--calcite-animation-timing); --calcite-floating-ui-z-index: var(--calcite-app-z-index-dropdown); } :host([hidden]) { display: none; } :host([disabled]) { cursor: default; -webkit-user-select: none; user-select: none; opacity: var(--calcite-ui-opacity-disabled); } :host([disabled]) *, :host([disabled]) ::slotted(*) { pointer-events: none; } :host { display: inline-block; font-size: var(--calcite-font-size--2); line-height: 1rem; font-weight: var(--calcite-font-weight-normal); } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; } :host([scale=s]) { --calcite-color-picker-spacing: 8px; } :host([scale=s]) .container { inline-size: 160px; } :host([scale=s]) .saved-colors { gap: 0.25rem; grid-template-columns: repeat(auto-fill, 20px); } :host([scale=m]) { --calcite-color-picker-spacing: 12px; } :host([scale=m]) .container { inline-size: 272px; } :host([scale=l]) { --calcite-color-picker-spacing: 16px; font-size: var(--calcite-font-size--1); line-height: 1rem; } :host([scale=l]) .container { inline-size: 464px; } :host([scale=l]) .section:first-of-type { padding-block-start: var(--calcite-color-picker-spacing); } :host([scale=l]) .saved-colors { grid-template-columns: repeat(auto-fill, 32px); } :host([scale=l]) .control-section { flex-wrap: nowrap; align-items: baseline; flex-wrap: wrap; } :host([scale=l]) .color-hex-options { display: flex; flex-shrink: 1; flex-direction: column; justify-content: space-around; } :host([scale=l]) .color-mode-container { flex-shrink: 3; } .container { background-color: var(--calcite-ui-foreground-1); display: inline-block; border: 1px solid var(--calcite-ui-border-1); } .control-and-scope { position: relative; display: flex; cursor: pointer; touch-action: none; } .scope { position: absolute; z-index: var(--calcite-app-z-index); font-size: var(--calcite-font-size--1); outline-color: transparent; } .scope:focus { outline: 2px solid var(--calcite-ui-focus-color, var(--calcite-ui-brand)); outline-offset: calc( 2px * calc( 1 - 2 * clamp( 0, var(--calcite-ui-focus-offset-invert), 1 ) ) ); outline-offset: 16px; } .hex-and-channels-group { inline-size: 100%; } .hex-and-channels-group, .control-section { display: flex; flex-direction: row; flex-wrap: wrap; } .section { padding-block: 0 var(--calcite-color-picker-spacing); padding-inline: var(--calcite-color-picker-spacing); } .section:first-of-type { padding-block-start: var(--calcite-color-picker-spacing); } .sliders { display: flex; flex-direction: column; justify-content: space-between; margin-inline-start: var(--calcite-color-picker-spacing); } .preview-and-sliders { display: flex; align-items: center; padding: var(--calcite-color-picker-spacing); } .color-hex-options, .section--split { flex-grow: 1; } .header { display: flex; align-items: center; justify-content: space-between; color: var(--calcite-ui-text-1); } .color-mode-container { padding-block-start: var(--calcite-color-picker-spacing); } .channels { display: flex; row-gap: 0.125rem; } .channel[data-channel-index="3"] { inline-size: 159px; } :host([scale=s]) .channels { flex-wrap: wrap; } :host([scale=s]) .channel { flex-basis: 30%; flex-grow: 1; } :host([scale=s]) .channel[data-channel-index="3"] { inline-size: unset; margin-inline-start: unset; } :host([scale=l]) .channel[data-channel-index="3"] { inline-size: 131px; } .saved-colors { display: grid; gap: 0.5rem; padding-block-start: var(--calcite-color-picker-spacing); grid-template-columns: repeat(auto-fill, 24px); } .saved-colors-buttons { display: flex; } .saved-color { outline-offset: 0; outline-color: transparent; cursor: pointer; } .saved-color:focus { outline: 2px solid var(--calcite-ui-brand); outline-offset: 2px; } .saved-color:hover { transition: outline-color var(--calcite-internal-animation-timing-fast) ease-in-out; outline: 2px solid var(--calcite-ui-border-2); outline-offset: 2px; }