UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

466 lines (423 loc) • 11.1 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([scale=s]) { block-size: 1.5rem; font-size: var(--calcite-font-size--2); --calcite-chip-spacing-s-internal: 0.25rem; --calcite-chip-spacing-l-internal: 0.5rem; } :host([scale=s]) .close, :host([scale=s]) .select-icon--active { block-size: 1rem; inline-size: 1rem; } :host([scale=s]) .image-container { block-size: 1.25rem; inline-size: 1.25rem; } :host([scale=s]) .container.is-circle { block-size: 1.5rem; inline-size: 1.5rem; } :host([scale=m]) { block-size: 2rem; font-size: var(--calcite-font-size--1); --calcite-chip-spacing-s-internal: 0.375rem; --calcite-chip-spacing-l-internal: 0.5rem; } :host([scale=m]) .close, :host([scale=m]) .image-container, :host([scale=m]) .select-icon--active { block-size: 1.5rem; inline-size: 1.5rem; } :host([scale=m]) .container.is-circle { block-size: 2rem; inline-size: 2rem; } :host([scale=l]) { block-size: 2.75rem; font-size: var(--calcite-font-size-0); --calcite-chip-spacing-s-internal: 0.5rem; --calcite-chip-spacing-l-internal: 0.75rem; } :host([scale=l]) .image-container, :host([scale=l]) .close, :host([scale=l]) .select-icon--active { block-size: 2rem; inline-size: 2rem; } :host([scale=l]) .container.is-circle { block-size: 2.75rem; inline-size: 2.75rem; } :host { display: inline-flex; cursor: default; border-radius: 9999px; } .container { box-sizing: border-box; display: inline-flex; block-size: 100%; max-inline-size: 100%; align-items: center; justify-content: center; border-radius: 9999px; border-width: 1px; border-style: solid; border-color: var(--calcite-ui-border-1); font-weight: var(--calcite-font-weight-medium); outline-color: transparent; } .container:not(.is-circle) { padding-inline: var(--calcite-chip-spacing-s-internal); } .container.selectable { cursor: pointer; } .container:not(.non-interactive):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 ) ) ); } :host([scale=s]) .container.image--slotted { padding-inline-start: calc(0.125rem / 2); } :host([scale=s]) .container.is-circle { padding-inline: 0; } .container.text--slotted .title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; padding-inline: var(--calcite-chip-spacing-s-internal); } .container:not(.text--slotted) .title { display: none; } .container:not(.image--slotted) .image-container { display: none; } .container.closable { padding-inline-end: calc(var(--calcite-chip-spacing-l-internal) / 2); } .container:not(.is-circle).image--slotted { padding-inline-start: calc(var(--calcite-chip-spacing-l-internal) / 2); } .container:not(.is-circle).image--slotted .image-container { margin-inline-end: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle).image--slotted .image-container ~ .chip-icon { margin-inline-start: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle).selectable:not(.text--slotted) .chip-icon { margin-inline-end: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle):not(.selectable):not(.text--slotted) .chip-icon { margin-inline-start: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle):not(.text--slotted) .chip-icon { margin-inline-end: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle):not(.text-slotted).image--slotted .image-container { margin-inline-end: var(--calcite-chip-spacing-s-internal); } .container:not(.is-circle):not(.closable):not(.text--slotted).image--slotted.selectable .image-container { margin-inline-end: 0; } .container:not(.is-circle):not(.closable):not(.text--slotted).image--slotted.selectable .image-container ~ .chip-icon { margin-inline-start: calc(var(--calcite-chip-spacing-s-internal) * 2); } .chip-icon { position: relative; margin-block: 0px; display: inline-flex; transition-duration: 150ms; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); margin-inline: var(--calcite-chip-spacing-s-internal); } .image-container { display: inline-flex; overflow: hidden; align-items: center; justify-content: center; pointer-events: none; } .close { margin: 0px; cursor: pointer; align-items: center; border-style: none; background-color: transparent; color: var(--calcite-ui-text-1); outline-color: transparent; transition: all var(--calcite-animation-timing) ease-in-out 0s, outline 0s, outline-offset 0s; -webkit-appearance: none; display: flex; border-radius: 50%; align-content: center; justify-content: center; --calcite-chip-transparent-hover: var(--calcite-button-transparent-hover); --calcite-chip-transparent-press: var(--calcite-button-transparent-press); } .close:hover { background-color: var(--calcite-chip-transparent-hover); } .close:focus { background-color: var(--calcite-chip-transparent-hover); 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 ) ) ); } .close:active { background-color: var(--calcite-chip-transparent-press); } .close calcite-icon { color: inherit; } .select-icon { align-self: center; justify-content: center; align-items: center; display: flex; inset-block-start: -1px; position: relative; visibility: hidden; inline-size: 0; opacity: 0; transition: opacity 0.15s ease-in-out, inline-size 0.15s ease-in-out; } .select-icon.select-icon--active { visibility: visible; opacity: 0.5; } .container:not(.is-circle).image--slotted .select-icon.select-icon--active { margin-inline-end: var(--calcite-chip-spacing-s-internal); } :host([selected]) .select-icon { opacity: 1; } .container:hover .select-icon--active { opacity: 1; } slot[name=image]::slotted(*) { display: flex; block-size: 100%; inline-size: 100%; overflow: hidden; border-radius: 50%; } :host([kind=neutral]) { background-color: var(--calcite-ui-foreground-2); color: var(--calcite-ui-text-1); } :host([kind=neutral]) .container { border-color: transparent; } :host([kind=neutral]) .close { color: var(--calcite-ui-text-3); } :host([kind=neutral]) .chip-icon { color: var(--calcite-ui-icon-color, var(--calcite-ui-text-3)); } :host([kind=inverse]) { background-color: var(--calcite-ui-inverse); color: var(--calcite-ui-text-inverse); } :host([kind=inverse]) .container { border-color: transparent; } :host([kind=inverse]) .close { color: var(--calcite-ui-text-inverse); } :host([kind=inverse]) .chip-icon { color: var(--calcite-ui-icon-color, var(--calcite-ui-text-inverse)); } :host([kind=brand]) { background-color: var(--calcite-ui-brand); color: var(--calcite-ui-text-inverse); } :host([kind=brand]) .container { border-color: transparent; } :host([kind=brand]) .close { color: var(--calcite-ui-text-inverse); } :host([kind=brand]) .chip-icon { color: var(--calcite-ui-icon-color, var(--calcite-ui-text-inverse)); } :host([appearance=outline-fill]), :host([appearance=outline]) { background-color: var(--calcite-ui-foreground-1); color: var(--calcite-ui-text-1); } :host([appearance=outline-fill]) .close, :host([appearance=outline]) .close { color: var(--calcite-ui-text-3); } :host([appearance=outline-fill]) .chip-icon, :host([appearance=outline]) .chip-icon { color: var(--calcite-ui-icon-color, var(--calcite-ui-text-3)); } :host([appearance=outline-fill]) { background-color: var(--calcite-ui-foreground-1); } :host([appearance=outline]) { background-color: transparent; } :host([kind=neutral][appearance=outline-fill]) .container, :host([kind=neutral][appearance=outline]) .container { border-color: var(--calcite-ui-border-1); } :host([kind=inverse][appearance=outline-fill]) .container, :host([kind=inverse][appearance=outline]) .container { border-color: var(--calcite-ui-border-inverse); } :host([kind=brand][appearance=outline-fill]) .container, :host([kind=brand][appearance=outline]) .container { border-color: var(--calcite-ui-brand); } :host([kind=brand][appearance=solid]) button, :host([kind=inverse][appearance=solid]) button { outline-color: var(--calcite-ui-text-inverse); } :host([closed]) { display: none; } :host([disabled]) ::slotted([calcite-hydrated][disabled]), :host([disabled]) [calcite-hydrated][disabled] { /* prevent opacity stacking */ opacity: 1; }