UNPKG

zenkit-ui

Version:

Zen UI Components

591 lines (574 loc) 17.3 kB
import { LitElement as $, css as E, html as u } from "lit"; /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ const A = (r) => (t, e) => { e !== void 0 ? e.addInitializer(() => { customElements.define(r, t); }) : customElements.define(r, t); }; /** * @license * Copyright 2019 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ const p = globalThis, S = p.ShadowRoot && (p.ShadyCSS === void 0 || p.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype, z = Symbol(), U = /* @__PURE__ */ new WeakMap(); let R = class { constructor(t, e, s) { if (this._$cssResult$ = !0, s !== z) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead."); this.cssText = t, this.t = e; } get styleSheet() { let t = this.o; const e = this.t; if (S && t === void 0) { const s = e !== void 0 && e.length === 1; s && (t = U.get(e)), t === void 0 && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), s && U.set(e, t)); } return t; } toString() { return this.cssText; } }; const M = (r) => new R(typeof r == "string" ? r : r + "", void 0, z), j = (r, t) => { if (S) r.adoptedStyleSheets = t.map((e) => e instanceof CSSStyleSheet ? e : e.styleSheet); else for (const e of t) { const s = document.createElement("style"), i = p.litNonce; i !== void 0 && s.setAttribute("nonce", i), s.textContent = e.cssText, r.appendChild(s); } }, C = S ? (r) => r : (r) => r instanceof CSSStyleSheet ? ((t) => { let e = ""; for (const s of t.cssRules) e += s.cssText; return M(e); })(r) : r; /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ const { is: T, defineProperty: L, getOwnPropertyDescriptor: q, getOwnPropertyNames: D, getOwnPropertySymbols: N, getPrototypeOf: B } = Object, d = globalThis, k = d.trustedTypes, V = k ? k.emptyScript : "", g = d.reactiveElementPolyfillSupport, h = (r, t) => r, f = { toAttribute(r, t) { switch (t) { case Boolean: r = r ? V : null; break; case Object: case Array: r = r == null ? r : JSON.stringify(r); } return r; }, fromAttribute(r, t) { let e = r; switch (t) { case Boolean: e = r !== null; break; case Number: e = r === null ? null : Number(r); break; case Object: case Array: try { e = JSON.parse(r); } catch { e = null; } } return e; } }, w = (r, t) => !T(r, t), O = { attribute: !0, type: String, converter: f, reflect: !1, hasChanged: w }; Symbol.metadata ?? (Symbol.metadata = Symbol("metadata")), d.litPropertyMetadata ?? (d.litPropertyMetadata = /* @__PURE__ */ new WeakMap()); class c extends HTMLElement { static addInitializer(t) { this._$Ei(), (this.l ?? (this.l = [])).push(t); } static get observedAttributes() { return this.finalize(), this._$Eh && [...this._$Eh.keys()]; } static createProperty(t, e = O) { if (e.state && (e.attribute = !1), this._$Ei(), this.elementProperties.set(t, e), !e.noAccessor) { const s = Symbol(), i = this.getPropertyDescriptor(t, s, e); i !== void 0 && L(this.prototype, t, i); } } static getPropertyDescriptor(t, e, s) { const { get: i, set: o } = q(this.prototype, t) ?? { get() { return this[e]; }, set(n) { this[e] = n; } }; return { get() { return i == null ? void 0 : i.call(this); }, set(n) { const a = i == null ? void 0 : i.call(this); o.call(this, n), this.requestUpdate(t, a, s); }, configurable: !0, enumerable: !0 }; } static getPropertyOptions(t) { return this.elementProperties.get(t) ?? O; } static _$Ei() { if (this.hasOwnProperty(h("elementProperties"))) return; const t = B(this); t.finalize(), t.l !== void 0 && (this.l = [...t.l]), this.elementProperties = new Map(t.elementProperties); } static finalize() { if (this.hasOwnProperty(h("finalized"))) return; if (this.finalized = !0, this._$Ei(), this.hasOwnProperty(h("properties"))) { const e = this.properties, s = [...D(e), ...N(e)]; for (const i of s) this.createProperty(i, e[i]); } const t = this[Symbol.metadata]; if (t !== null) { const e = litPropertyMetadata.get(t); if (e !== void 0) for (const [s, i] of e) this.elementProperties.set(s, i); } this._$Eh = /* @__PURE__ */ new Map(); for (const [e, s] of this.elementProperties) { const i = this._$Eu(e, s); i !== void 0 && this._$Eh.set(i, e); } this.elementStyles = this.finalizeStyles(this.styles); } static finalizeStyles(t) { const e = []; if (Array.isArray(t)) { const s = new Set(t.flat(1 / 0).reverse()); for (const i of s) e.unshift(C(i)); } else t !== void 0 && e.push(C(t)); return e; } static _$Eu(t, e) { const s = e.attribute; return s === !1 ? void 0 : typeof s == "string" ? s : typeof t == "string" ? t.toLowerCase() : void 0; } constructor() { super(), this._$Ep = void 0, this.isUpdatePending = !1, this.hasUpdated = !1, this._$Em = null, this._$Ev(); } _$Ev() { var t; this._$ES = new Promise((e) => this.enableUpdating = e), this._$AL = /* @__PURE__ */ new Map(), this._$E_(), this.requestUpdate(), (t = this.constructor.l) == null || t.forEach((e) => e(this)); } addController(t) { var e; (this._$EO ?? (this._$EO = /* @__PURE__ */ new Set())).add(t), this.renderRoot !== void 0 && this.isConnected && ((e = t.hostConnected) == null || e.call(t)); } removeController(t) { var e; (e = this._$EO) == null || e.delete(t); } _$E_() { const t = /* @__PURE__ */ new Map(), e = this.constructor.elementProperties; for (const s of e.keys()) this.hasOwnProperty(s) && (t.set(s, this[s]), delete this[s]); t.size > 0 && (this._$Ep = t); } createRenderRoot() { const t = this.shadowRoot ?? this.attachShadow(this.constructor.shadowRootOptions); return j(t, this.constructor.elementStyles), t; } connectedCallback() { var t; this.renderRoot ?? (this.renderRoot = this.createRenderRoot()), this.enableUpdating(!0), (t = this._$EO) == null || t.forEach((e) => { var s; return (s = e.hostConnected) == null ? void 0 : s.call(e); }); } enableUpdating(t) { } disconnectedCallback() { var t; (t = this._$EO) == null || t.forEach((e) => { var s; return (s = e.hostDisconnected) == null ? void 0 : s.call(e); }); } attributeChangedCallback(t, e, s) { this._$AK(t, s); } _$EC(t, e) { var o; const s = this.constructor.elementProperties.get(t), i = this.constructor._$Eu(t, s); if (i !== void 0 && s.reflect === !0) { const n = (((o = s.converter) == null ? void 0 : o.toAttribute) !== void 0 ? s.converter : f).toAttribute(e, s.type); this._$Em = t, n == null ? this.removeAttribute(i) : this.setAttribute(i, n), this._$Em = null; } } _$AK(t, e) { var o; const s = this.constructor, i = s._$Eh.get(t); if (i !== void 0 && this._$Em !== i) { const n = s.getPropertyOptions(i), a = typeof n.converter == "function" ? { fromAttribute: n.converter } : ((o = n.converter) == null ? void 0 : o.fromAttribute) !== void 0 ? n.converter : f; this._$Em = i, this[i] = a.fromAttribute(e, n.type), this._$Em = null; } } requestUpdate(t, e, s) { if (t !== void 0) { if (s ?? (s = this.constructor.getPropertyOptions(t)), !(s.hasChanged ?? w)(this[t], e)) return; this.P(t, e, s); } this.isUpdatePending === !1 && (this._$ES = this._$ET()); } P(t, e, s) { this._$AL.has(t) || this._$AL.set(t, e), s.reflect === !0 && this._$Em !== t && (this._$Ej ?? (this._$Ej = /* @__PURE__ */ new Set())).add(t); } async _$ET() { this.isUpdatePending = !0; try { await this._$ES; } catch (e) { Promise.reject(e); } const t = this.scheduleUpdate(); return t != null && await t, !this.isUpdatePending; } scheduleUpdate() { return this.performUpdate(); } performUpdate() { var s; if (!this.isUpdatePending) return; if (!this.hasUpdated) { if (this.renderRoot ?? (this.renderRoot = this.createRenderRoot()), this._$Ep) { for (const [o, n] of this._$Ep) this[o] = n; this._$Ep = void 0; } const i = this.constructor.elementProperties; if (i.size > 0) for (const [o, n] of i) n.wrapped !== !0 || this._$AL.has(o) || this[o] === void 0 || this.P(o, this[o], n); } let t = !1; const e = this._$AL; try { t = this.shouldUpdate(e), t ? (this.willUpdate(e), (s = this._$EO) == null || s.forEach((i) => { var o; return (o = i.hostUpdate) == null ? void 0 : o.call(i); }), this.update(e)) : this._$EU(); } catch (i) { throw t = !1, this._$EU(), i; } t && this._$AE(e); } willUpdate(t) { } _$AE(t) { var e; (e = this._$EO) == null || e.forEach((s) => { var i; return (i = s.hostUpdated) == null ? void 0 : i.call(s); }), this.hasUpdated || (this.hasUpdated = !0, this.firstUpdated(t)), this.updated(t); } _$EU() { this._$AL = /* @__PURE__ */ new Map(), this.isUpdatePending = !1; } get updateComplete() { return this.getUpdateComplete(); } getUpdateComplete() { return this._$ES; } shouldUpdate(t) { return !0; } update(t) { this._$Ej && (this._$Ej = this._$Ej.forEach((e) => this._$EC(e, this[e]))), this._$EU(); } updated(t) { } firstUpdated(t) { } } c.elementStyles = [], c.shadowRootOptions = { mode: "open" }, c[h("elementProperties")] = /* @__PURE__ */ new Map(), c[h("finalized")] = /* @__PURE__ */ new Map(), g == null || g({ ReactiveElement: c }), (d.reactiveElementVersions ?? (d.reactiveElementVersions = [])).push("2.0.4"); /** * @license * Copyright 2017 Google LLC * SPDX-License-Identifier: BSD-3-Clause */ const I = { attribute: !0, type: String, converter: f, reflect: !1, hasChanged: w }, J = (r = I, t, e) => { const { kind: s, metadata: i } = e; let o = globalThis.litPropertyMetadata.get(i); if (o === void 0 && globalThis.litPropertyMetadata.set(i, o = /* @__PURE__ */ new Map()), o.set(e.name, r), s === "accessor") { const { name: n } = e; return { set(a) { const v = t.get.call(this); t.set.call(this, a), this.requestUpdate(n, v, r); }, init(a) { return a !== void 0 && this.P(n, void 0, r), a; } }; } if (s === "setter") { const { name: n } = e; return function(a) { const v = this[n]; t.call(this, a), this.requestUpdate(n, v, r); }; } throw Error("Unsupported decorator location: " + s); }; function m(r) { return (t, e) => typeof e == "object" ? J(r, t, e) : ((s, i, o) => { const n = i.hasOwnProperty(o); return i.constructor.createProperty(o, n ? { ...s, wrapped: !0 } : s), n ? Object.getOwnPropertyDescriptor(i, o) : void 0; })(r, t, e); } const P = class P extends $ { constructor() { super(...arguments), this._variant = "primary", this._size = "medium", this._disabled = !1; } static get properties() { return { variant: { type: String }, size: { type: String }, disabled: { type: Boolean } }; } get variant() { return this._variant; } set variant(t) { const e = this._variant; this._variant = t, this.requestUpdate("variant", e); } get size() { return this._size; } set size(t) { const e = this._size; this._size = t, this.requestUpdate("size", e); } get disabled() { return this._disabled; } set disabled(t) { const e = this._disabled; this._disabled = t, this.requestUpdate("disabled", e); } render() { return u` <button class="${this.size} ${this.variant}" ?disabled="${this.disabled}" @click="${this._handleClick}" > <slot></slot> </button> `; } _handleClick(t) { this.disabled || this.dispatchEvent(new CustomEvent("zen-click", { bubbles: !0, composed: !0, detail: { originalEvent: t } })); } }; P.styles = E` :host { display: inline-block; } button { font-family: system-ui, sans-serif; border-radius: 6px; border: 1px solid transparent; cursor: pointer; transition: all 0.2s ease-in-out; font-weight: 500; } button:disabled { opacity: 0.5; cursor: not-allowed; } /* Size variants */ .small { padding: 6px 12px; font-size: 14px; } .medium { padding: 8px 16px; font-size: 16px; } .large { padding: 12px 24px; font-size: 18px; } /* Style variants */ .primary { background: #1b263b; color: white; border-color: #1b263b; } .primary:hover:not(:disabled) { background: #2a3b59; border-color: #2a3b59; } .secondary { background: #e2e8f0; color: #1b263b; border-color: #e2e8f0; } .secondary:hover:not(:disabled) { background: #cbd5e1; border-color: #cbd5e1; } .outline { background: transparent; color: #1b263b; border-color: #1b263b; } .outline:hover:not(:disabled) { background: #f8fafc; } `; let _ = P; customElements.define("zen-button", _); var K = Object.defineProperty, W = (r, t, e, s) => { for (var i = void 0, o = r.length - 1, n; o >= 0; o--) (n = r[o]) && (i = n(t, e, i) || i); return i && K(t, e, i), i; }; const x = class x extends $ { constructor() { super(...arguments), this.interactive = !1; } render() { return u` <div class="card"> <slot name="header"></slot> <slot></slot> <slot name="footer"></slot> </div> `; } connectedCallback() { super.connectedCallback(), this.interactive && this.addEventListener("click", this._handleClick); } disconnectedCallback() { super.disconnectedCallback(), this.interactive && this.removeEventListener("click", this._handleClick); } _handleClick(t) { this.dispatchEvent(new CustomEvent("zen-click", { bubbles: !0, composed: !0, detail: { originalEvent: t } })); } }; x.styles = E` :host { display: block; border-radius: 8px; overflow: hidden; transition: transform 0.2s ease; } .card { background: white; border: 1px solid #e2e8f0; padding: 1rem; height: 100%; box-sizing: border-box; } :host([interactive]) { cursor: pointer; } :host([interactive]:hover) { transform: translateY(-2px); } /* Slots */ ::slotted([slot="header"]) { margin: 0 0 1rem 0; padding: 0 0 1rem 0; border-bottom: 1px solid #e2e8f0; } ::slotted([slot="footer"]) { margin: 1rem 0 0 0; padding: 1rem 0 0 0; border-top: 1px solid #e2e8f0; } `; let b = x; W([ m({ type: Boolean, reflect: !0 }) ], b.prototype, "interactive"); customElements.define("zen-card", b); var H = Object.defineProperty, Y = Object.getOwnPropertyDescriptor, y = (r, t, e, s) => { for (var i = s > 1 ? void 0 : s ? Y(t, e) : t, o = r.length - 1, n; o >= 0; o--) (n = r[o]) && (i = (s ? n(t, e, i) : n(i)) || i); return s && i && H(t, e, i), i; }; let l = class extends $ { constructor() { super(...arguments), this.expanded = !1, this.multiple = !1, this.items = []; } toggleAccordion(r) { this.multiple ? this.items = this.items.map( (t, e) => e === r ? { ...t, expanded: !t.expanded } : t ) : this.items = this.items.map( (t, e) => e === r ? { ...t, expanded: !t.expanded } : { ...t, expanded: !1 } ); } render() { return u` ${this.items.map( (r, t) => u` <div class="accordion-item ${r.expanded ? "expanded" : ""}"> <div class="accordion-header" @click="${() => this.toggleAccordion(t)}"> <slot name="header">${r.header}</slot> <span>${r.expanded ? "▲" : "▼"}</span> </div> <div class="accordion-content"> <slot name="content">${r.content}</slot> </div> </div> ` )} `; } }; l.styles = E` :host { display: block; font-family: Arial, sans-serif; } .accordion-item { border: 1px solid #e2e8f0; border-radius: 8px; margin-bottom: 8px; overflow: hidden; transition: height 0.2s ease-in-out; } .accordion-header { background-color: #1b263b; color: #e2e8f0; padding: 12px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; } .accordion-header:hover { background-color: #2a3b59; } .accordion-content { padding: 12px; background-color: #f9fafb; display: none; } .accordion-item.expanded .accordion-content { display: block; } `; y([ m({ type: Boolean, reflect: !0 }) ], l.prototype, "expanded", 2); y([ m({ type: Boolean, reflect: !0 }) ], l.prototype, "multiple", 2); y([ m({ type: Array }) ], l.prototype, "items", 2); l = y([ A("zen-accordion") ], l); export { _ as Button, b as Card };