@esri/calcite-components
Version:
Web Components for Esri's Calcite Design System.
151 lines (147 loc) • 9.42 kB
JavaScript
import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-8fd57462.js';
import { g as getElementDir } from './dom-d9ba1da4.js';
const calciteLabelCss = "@-webkit-keyframes in{0%{opacity:0}100%{opacity:1}}@keyframes in{0%{opacity:0}100%{opacity:1}}@-webkit-keyframes in-down{0%{opacity:0;-webkit-transform:translate3D(0, -5px, 0);transform:translate3D(0, -5px, 0)}100%{opacity:1;-webkit-transform:translate3D(0, 0, 0);transform:translate3D(0, 0, 0)}}@keyframes in-down{0%{opacity:0;-webkit-transform:translate3D(0, -5px, 0);transform:translate3D(0, -5px, 0)}100%{opacity:1;-webkit-transform:translate3D(0, 0, 0);transform:translate3D(0, 0, 0)}}@-webkit-keyframes in-up{0%{opacity:0;-webkit-transform:translate3D(0, 5px, 0);transform:translate3D(0, 5px, 0)}100%{opacity:1;-webkit-transform:translate3D(0, 0, 0);transform:translate3D(0, 0, 0)}}@keyframes in-up{0%{opacity:0;-webkit-transform:translate3D(0, 5px, 0);transform:translate3D(0, 5px, 0)}100%{opacity:1;-webkit-transform:translate3D(0, 0, 0);transform:translate3D(0, 0, 0)}}@-webkit-keyframes in-scale{0%{opacity:0;-webkit-transform:scale3D(0.95, 0.95, 1);transform:scale3D(0.95, 0.95, 1)}100%{opacity:1;-webkit-transform:scale3D(1, 1, 1);transform:scale3D(1, 1, 1)}}@keyframes in-scale{0%{opacity:0;-webkit-transform:scale3D(0.95, 0.95, 1);transform:scale3D(0.95, 0.95, 1)}100%{opacity:1;-webkit-transform:scale3D(1, 1, 1);transform:scale3D(1, 1, 1)}}.sc-calcite-label:root{--calcite-popper-transition:150ms ease-in-out}[hidden].sc-calcite-label-h{display:none}[theme=dark].sc-calcite-label-h,[theme=dark] .sc-calcite-label-h{--calcite-ui-blue-1:#00A0FF;--calcite-ui-blue-2:#0087D7;--calcite-ui-blue-3:#47BBFF;--calcite-ui-green-1:#36DA43;--calcite-ui-green-2:#11AD1D;--calcite-ui-green-3:#44ED51;--calcite-ui-yellow-1:#FFC900;--calcite-ui-yellow-2:#F4B000;--calcite-ui-yellow-3:#FFE24D;--calcite-ui-red-1:#FE583E;--calcite-ui-red-2:#F3381B;--calcite-ui-red-3:#FF7465;--calcite-ui-background:#202020;--calcite-ui-foreground-1:#2b2b2b;--calcite-ui-foreground-2:#353535;--calcite-ui-foreground-3:#404040;--calcite-ui-text-1:#ffffff;--calcite-ui-text-2:#bfbfbf;--calcite-ui-text-3:#9f9f9f;--calcite-ui-border-1:#4a4a4a;--calcite-ui-border-2:#404040;--calcite-ui-border-3:#353535;--calcite-ui-border-4:#757575;--calcite-ui-border-5:#9f9f9f}[alignment=start].sc-calcite-label-h,[alignment=end][dir=rtl].sc-calcite-label-h{text-align:left}[alignment=end].sc-calcite-label-h,[alignment=start][dir=rtl].sc-calcite-label-h{text-align:right}[alignment=center].sc-calcite-label-h{text-align:center}[scale=s].sc-calcite-label-h{--calcite-label-margin-bottom:12px}[scale=s].sc-calcite-label-h label.sc-calcite-label{font-size:var(--calcite-font-size--2)}[scale=m].sc-calcite-label-h{--calcite-label-margin-bottom:14px}[scale=m].sc-calcite-label-h label.sc-calcite-label{font-size:var(--calcite-font-size--1)}[scale=l].sc-calcite-label-h{--calcite-label-margin-bottom:18px}[scale=l].sc-calcite-label-h label.sc-calcite-label{font-size:var(--calcite-font-size-1)}.sc-calcite-label-h label.sc-calcite-label{cursor:pointer;width:100%;margin:0 0 var(--calcite-label-margin-bottom, 1.5rem) 0;line-height:1.3}[layout=default].sc-calcite-label-h label.sc-calcite-label{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:4px}[layout=inline].sc-calcite-label-h label.sc-calcite-label,[layout=inline-space-between].sc-calcite-label-h label.sc-calcite-label{-ms-flex-align:center;align-items:center;display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;gap:0.75rem}[layout=inline-space-between].sc-calcite-label-h label.sc-calcite-label{-ms-flex-pack:justify;justify-content:space-between}[disabled].sc-calcite-label-h>label.sc-calcite-label{pointer-events:none;opacity:var(--calcite-ui-opacity-disabled)}.sc-calcite-label-h[disabled] .sc-calcite-label-s>*{pointer-events:none}.sc-calcite-label-h[disabled] .sc-calcite-label-s>*[disabled],.sc-calcite-label-h[disabled] .sc-calcite-label-s>*[disabled] *{opacity:1}.sc-calcite-label-h[disabled] .sc-calcite-label-s>calcite-input-message:not([active]){opacity:0}[status=invalid].sc-calcite-label-h label.sc-calcite-label{color:var(--calcite-ui-red-1)}[status=valid].sc-calcite-label-h label.sc-calcite-label{color:var(--calcite-ui-text-2)}[status=idle].sc-calcite-label-h label.sc-calcite-label{color:var(--calcite-ui-text-2)}[disable-spacing].sc-calcite-label-h label.sc-calcite-label{gap:0;margin:0}";
const CalciteLabel = class {
constructor(hostRef) {
registerInstance(this, hostRef);
this.calciteLabelFocus = createEvent(this, "calciteLabelFocus", 7);
//--------------------------------------------------------------------------
//
// Properties
//
//--------------------------------------------------------------------------
/** specify the text alignment of the label */
this.alignment = "start";
/** specify the status of the label and any child input / input messages */
this.status = "idle";
/** specify the scale of the input, defaults to m */
this.scale = "m";
/** is the wrapped element positioned inline with the label slotted text */
this.layout = "default";
this.handleCalciteHtmlForClicks = (target) => {
// 1. has htmlFor
if (!this.for)
return;
// 2. htmlFor matches a calcite component
const inputForThisLabel = document.getElementById(this.for);
if (!inputForThisLabel)
return;
if (!inputForThisLabel.localName.startsWith("calcite"))
return;
// 5. target is NOT the calcite component that this label matches
if (target === inputForThisLabel)
return;
// 3. target is not a labelable native form element
const labelableNativeElements = [
"button",
"input",
"meter",
"output",
"progress",
"select",
"textarea"
];
if (labelableNativeElements.includes(target.localName))
return;
// 4. target is not a labelable calcite form element
const labelableCalciteElements = [
"calcite-button",
"calcite-checkbox",
"calcite-date",
"calcite-inline-editable",
"calcite-input",
"calcite-radio",
"calcite-radio-button",
"calcite-radio-button-group",
"calcite-radio-group",
"calcite-rating",
"calcite-select",
"calcite-slider",
"calcite-switch"
];
if (labelableCalciteElements.includes(target.localName))
return;
// 5. target is not a child of a labelable calcite form element
for (let i = 0; i < labelableCalciteElements.length; i++) {
if (target.closest(labelableCalciteElements[i])) {
return;
}
}
inputForThisLabel.click();
};
}
disabledWatcher() {
if (this.disabled)
this.setDisabledControls();
}
//--------------------------------------------------------------------------
//
// Event Listeners
//
//--------------------------------------------------------------------------
onClick(event) {
const target = event.target;
this.calciteLabelFocus.emit({
labelEl: this.el,
interactedEl: target,
requestedInput: this.for
});
this.handleCalciteHtmlForClicks(target);
}
//--------------------------------------------------------------------------
//
// Private Methods
//
//--------------------------------------------------------------------------
getAttributes() {
// spread attributes from the component to rendered child, filtering out props
const props = ["disabled", "id", "layout", "scale", "status", "theme"];
return Array.from(this.el.attributes)
.filter((a) => a && !props.includes(a.name))
.reduce((acc, { name, value }) => (Object.assign(Object.assign({}, acc), { [name]: value })), {});
}
//--------------------------------------------------------------------------
//
// Lifecycle
//
//--------------------------------------------------------------------------
connectedCallback() {
const status = ["invalid", "valid", "idle"];
if (!status.includes(this.status))
this.status = "idle";
const layout = ["inline", "inline-space-between", "default"];
if (!layout.includes(this.layout))
this.layout = "default";
const scale = ["s", "m", "l"];
if (!scale.includes(this.scale))
this.scale = "m";
}
componentDidLoad() {
if (this.disabled)
this.setDisabledControls();
}
render() {
const attributes = this.getAttributes();
const dir = getElementDir(this.el);
return (h(Host, { dir: dir }, h("label", Object.assign({}, attributes, { ref: (el) => (this.labelEl = el) }), h("slot", null))));
}
//--------------------------------------------------------------------------
//
// Private Methods
//
//--------------------------------------------------------------------------
setDisabledControls() {
var _a;
(_a = this.labelEl) === null || _a === void 0 ? void 0 : _a.childNodes.forEach((item) => {
if (item.nodeName.includes("CALCITE")) {
item.setAttribute("disabled", "");
}
});
}
get el() { return getElement(this); }
static get watchers() { return {
"disabled": ["disabledWatcher"]
}; }
};
CalciteLabel.style = calciteLabelCss;
export { CalciteLabel as calcite_label };