UNPKG

@esri/calcite-components

Version:

Web Components for Esri's Calcite Design System.

327 lines (295 loc) • 6.77 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 { position: relative; box-sizing: border-box; display: flex; align-items: center; flex-shrink: 0; } :host .container, :host .item-content, :host .content { min-block-size: 3rem; } :host([layout=vertical]) { inline-size: 100%; } :host(:not([layout=vertical])) { block-size: 100%; } .container, .item-content { display: flex; block-size: 100%; inline-size: 100%; flex-direction: row; align-items: stretch; } .content { position: relative; box-sizing: border-box; display: flex; block-size: 100%; inline-size: 100%; cursor: pointer; align-items: center; justify-content: center; background-color: var(--calcite-ui-foreground-1); padding-inline: 1rem; font-size: var(--calcite-font-size-0); color: var(--calcite-ui-text-2); outline: 2px solid transparent; outline-offset: 2px; text-decoration: none; border-block-end: 0.125rem solid transparent; padding-block-start: 0.125rem; } .content:hover { background-color: var(--calcite-ui-foreground-2); color: var(--calcite-ui-text-2); } .content:focus { background-color: var(--calcite-ui-foreground-2); color: var(--calcite-ui-text-2); 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 ) ) ); } .content:active { background-color: var(--calcite-ui-foreground-3); color: var(--calcite-ui-text-1); } .content span { display: inline-flex; } .content.layout--vertical { display: flex; inline-size: 100%; justify-content: flex-start; padding-block: 1rem; border-block-end: 0; border-inline-end: 0.25rem solid transparent; } :host([active]) .content { color: var(--calcite-ui-text-1); border-color: var(--calcite-ui-brand); } :host([active]) .content .icon { --calcite-ui-icon-color: var(--calcite-ui-brand); } .icon--start { margin-inline-end: 0.75rem; } .icon--end { margin-inline-start: 0.75rem; } .icon--dropdown { position: relative; margin-inline-start: auto; margin-inline-end: 0px; padding-inline-start: 0.5rem; --calcite-ui-icon-color: var(--calcite-ui-text-3); } :host([layout=vertical]) .icon--dropdown { inset-inline-start: 0.25rem; } .icon--breadcrumb { margin-inline-end: 0px; padding-inline-start: 0.5rem; --calcite-ui-icon-color: var(--calcite-ui-text-3); } :host([breadcrumb]) .content { padding-inline-end: 0.75rem; } calcite-action { position: relative; block-size: auto; border-inline-start: 1px solid var(--calcite-ui-foreground-1); } calcite-action:after { position: absolute; inset-inline-start: -1px; display: block; inline-size: 1px; content: ""; inset-block: 0.75rem; background-color: var(--calcite-ui-border-3); } calcite-action:hover:after { block-size: 100%; inset-block: 0; } .content:focus ~ calcite-action, .content:hover ~ calcite-action { color: var(--calcite-ui-text-1); border-inline-start: 1px solid var(--calcite-ui-border-3); } .container:hover .dropdown-action { background-color: var(--calcite-ui-foreground-2); } .dropdown-menu-items { position: absolute; display: none; block-size: auto; min-inline-size: 100%; flex-direction: column; overflow: visible; border: 1px solid var(--calcite-ui-border-3); background: var(--calcite-ui-foreground-1); inset-block-start: 100%; z-index: var(--calcite-app-z-index-dropdown); } .dropdown-menu-items.open { display: block; } .dropdown-menu-items.nested { position: absolute; inset-block-start: -1px; transform: translateX(calc(100% - 2px)); } .parent--vertical { flex-direction: column; } .dropdown--vertical.dropdown-menu-items { position: relative; border-radius: 0px; box-shadow: none; inset-block-start: 0; transform: none; } .dropdown--vertical.dropdown-menu-items:last-of-type { border-inline: 0; } :host([slot=submenu-item]) .parent--vertical { padding-inline-start: 1.75rem; } .dropdown-menu-items.nested.calcite--rtl { transform: translateX(calc(-100% + 2px)); } .dropdown--vertical.dropdown-menu-items.nested.calcite--rtl { transform: none; } .hover-href-icon { position: relative; inset-inline-end: 0.25rem; margin-inline-start: auto; padding-inline-start: 2rem; opacity: 0; transition: all var(--calcite-internal-animation-timing-medium) ease-in-out; } .content:focus .hover-href-icon, .content:hover .hover-href-icon { inset-inline-end: -0.25rem; opacity: 1; }