@nysds/nys-badge 1.13.0 → 1.13.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/nys-badge.js CHANGED
@@ -1,14 +1,16 @@
1
- import { LitElement as l, unsafeCSS as d, html as f } from "lit";
2
- import { property as t } from "lit/decorators.js";
3
- const b = ':host{--_nys-badge-width: fit-content;--_nys-badge-height: var(--nys-size-600, 48px);--_nys-badge-radius: var(--nys-radius-round, 1776px);--_nys-badge-padding: var(--nys-space-2-px, 2px) var(--nys-space-100, 8px);--_nys-badge-gap: var(--nys-space-50, 4px);--_nys-badge-background-color: var(--nys-color-base-weak, #f6f6f6);--_nys-badge-border-color: var(--nys-color-base, #62666a);--_nys-badge-border-width: var(--nys-border-width-sm, 1px);--_nys-badge-font-size: var(--nys-font-size-ui-sm, 14px);--_nys-badge-font-weight: var(--nys-font-weight-semibold, 600);--_nys-badge-line-height: var(--nys-font-lineheight-ui-sm, 24px);--_nys-badge-font-family: var( --nys-font-family-ui, var( --nys-font-family-sans, "Proxima Nova", "Helvetica Neue", "Helvetica", "Arial", sans-serif ) );--_nys-badge-prefix-font-weight: var(--nys-font-weight-regular, 400)}:host([size=sm]){--_nys-badge-font-size: var(--nys-font-size-ui-xs, 12px);--_nys-badge-line-height: var(--nys-font-lineheight-ui-xs, 20px)}:host([intent=neutral]){--_nys-badge-background-color: var(--nys-color-base-weak, #f6f6f6);--_nys-badge-border-color: var(--nys-color-base, #62666a)}:host([intent=error]){--_nys-badge-background-color: var(--nys-color-error-weak, #f7eaea);--_nys-badge-border-color: var(--nys-color-error-strong, #721c1c)}:host([intent=success]){--_nys-badge-background-color: var(--nys-color-success-weak, #e8f1ea);--_nys-badge-border-color: var(--nys-color-success-strong, #0f3d18)}:host([intent=warning]){--_nys-badge-background-color: var(--nys-color-warning-weak, #fefae5);--_nys-badge-border-color: var(--nys-color-warning-strong, #6a5700)}.nys-badge{display:flex;width:fit-content;align-items:center;justify-content:center;gap:var(--_nys-badge-gap);padding:var(--_nys-badge-padding);border:var(--_nys-badge-border-width) solid var(--_nys-badge-border-color);background-color:var(--_nys-badge-background-color);border-radius:var(--_nys-badge-radius);font-family:var(--_nys-badge-font-family);font-size:var(--_nys-badge-font-size);font-weight:var(--_nys-badge-font-weight);line-height:var(--_nys-badge-line-height);cursor:default;--nys-icon-color: var(--_nys-badge-border-color)}.nys-badge__prefix{font-weight:var(--_nys-badge-prefix-font-weight)}';
4
- var p = Object.defineProperty, h = Object.getOwnPropertyDescriptor, i = (g, e, n, a) => {
5
- for (var o = a > 1 ? void 0 : a ? h(e, n) : e, c = g.length - 1, y; c >= 0; c--)
6
- (y = g[c]) && (o = (a ? y(e, n, o) : y(o)) || o);
7
- return a && o && p(e, n, o), o;
8
- }, r;
9
- const s = (r = class extends l {
1
+ import { LitElement as l, unsafeCSS as d, html as c } from "lit";
2
+ import { property as s } from "lit/decorators.js";
3
+ const b = ':host{--_nys-badge-width: fit-content;--_nys-badge-height: var(--nys-size-600, 48px);--_nys-badge-radius: var(--nys-radius-round, 1776px);--_nys-badge-padding: var(--nys-space-2-px, 2px) var(--nys-space-100, 8px);--_nys-badge-gap: var(--nys-space-50, 4px);--_nys-badge-color: var(--nys-color-ink, #000000);--_nys-badge-background-color: var(--nys-color-base-weak, #f6f6f6);--_nys-badge-border-color: var(--nys-color-base, #62666a);--_nys-badge-border-width: var(--nys-border-width-sm, 1px);--_nys-badge-font-size: var(--nys-font-size-ui-sm, 14px);--_nys-badge-font-weight: var(--nys-font-weight-semibold, 600);--_nys-badge-line-height: var(--nys-font-lineheight-ui-sm, 24px);--_nys-badge-font-family: var(--nys-font-family-ui, var(--nys-font-family-sans, "Proxima Nova", "Helvetica Neue", "Helvetica", "Arial", sans-serif));--_nys-badge-prefix-font-weight: var(--nys-font-weight-regular, 400)}:host([size=sm]){--_nys-badge-font-size: var(--nys-font-size-ui-xs, 12px);--_nys-badge-line-height: var(--nys-font-lineheight-ui-xs, 20px)}:host([intent=neutral]){--_nys-badge-background-color: var(--nys-color-base-weak, #f6f6f6);--_nys-badge-border-color: var(--nys-color-base, #62666a)}:host([intent=error]){--_nys-badge-background-color: var(--nys-color-error-weak, #f7eaea);--_nys-badge-border-color: var(--nys-color-error-strong, #721c1c)}:host([intent=success]){--_nys-badge-background-color: var(--nys-color-success-weak, #e8f1ea);--_nys-badge-border-color: var(--nys-color-success-strong, #0f3d18)}:host([intent=warning]){--_nys-badge-background-color: var(--nys-color-warning-weak, #fefae5);--_nys-badge-border-color: var(--nys-color-warning-strong, #6a5700)}:host([variant=strong]){--_nys-badge-background-color: var(--_nys-badge-border-color);--_nys-badge-color: var(--nys-color-white, #ffffff)}:host([variant=strong]) .nys-badge{--nys-icon-color: var(--nys-color-white, #ffffff)}:host([variant=strong][intent=success]){--_nys-badge-border-color: var(--nys-color-success, #1E752E)}:host([variant=strong][intent=warning]){--_nys-badge-border-color: var(--nys-color-warning, #FACE00);--_nys-badge-color: var(--nys-color-ink, #000000)}:host([variant=strong][intent=warning]) .nys-badge{--nys-icon-color: var(--nys-color-ink, #000000)}.nys-badge{display:flex;width:fit-content;align-items:center;justify-content:center;gap:var(--_nys-badge-gap);padding:var(--_nys-badge-padding);border:var(--_nys-badge-border-width) solid var(--_nys-badge-border-color);background-color:var(--_nys-badge-background-color);color:var(--_nys-badge-color);border-radius:var(--_nys-badge-radius);font-family:var(--_nys-badge-font-family);font-size:var(--_nys-badge-font-size);font-weight:var(--_nys-badge-font-weight);line-height:var(--_nys-badge-line-height);cursor:default;--nys-icon-color: var(--_nys-badge-border-color)}.nys-badge__prefix{font-weight:var(--_nys-badge-prefix-font-weight)}';
4
+ var p = Object.defineProperty, h = Object.getOwnPropertyDescriptor, t = (g, e, r, a) => {
5
+ for (var i = a > 1 ? void 0 : a ? h(e, r) : e, f = g.length - 1, y; f >= 0; f--)
6
+ (y = g[f]) && (i = (a ? y(e, r, i) : y(i)) || i);
7
+ return a && i && p(e, r, i), i;
8
+ };
9
+ let u = 0;
10
+ var o;
11
+ const n = (o = class extends l {
10
12
  constructor() {
11
- super(...arguments), this.id = "", this.name = "", this.size = "md", this.intent = "neutral", this.prefixLabel = "", this.label = "", this._prefixIcon = "", this._suffixIcon = "";
13
+ super(...arguments), this.id = "", this.name = "", this.size = "md", this.intent = "neutral", this.prefixLabel = "", this.label = "", this.variant = "", this._prefixIcon = "", this._suffixIcon = "";
12
14
  }
13
15
  get prefixIcon() {
14
16
  return this._prefixIcon;
@@ -27,11 +29,11 @@ const s = (r = class extends l {
27
29
  * --------------------------------------------------------------------------
28
30
  */
29
31
  connectedCallback() {
30
- super.connectedCallback();
32
+ super.connectedCallback(), this.id || (this.id = `nys-badge-${Date.now()}-${u++}`);
31
33
  const e = this.getAttribute("prefixicon");
32
34
  e !== null && this.prefixIcon === "" && (this.prefixIcon = e);
33
- const n = this.getAttribute("suffixicon");
34
- n !== null && this.suffixIcon === "" && (this.suffixIcon = n);
35
+ const r = this.getAttribute("suffixicon");
36
+ r !== null && this.suffixIcon === "" && (this.suffixIcon = r);
35
37
  }
36
38
  /**
37
39
  * Resolves which icon should be rendered.
@@ -39,52 +41,55 @@ const s = (r = class extends l {
39
41
  * @returns Icon name or null if no icon should be rendered
40
42
  */
41
43
  resolveIcon(e) {
42
- return e === !0 ? r.DEFAULT_ICONS[this.intent] ?? "info" : typeof e == "string" && e.trim() !== "" ? e : null;
44
+ return e === !0 ? o.DEFAULT_ICONS[this.intent] ?? "info" : typeof e == "string" && e.trim() !== "" ? e : null;
43
45
  }
44
46
  render() {
45
- const e = this.resolveIcon(this.prefixIcon), n = this.resolveIcon(this.suffixIcon);
46
- return f`
47
+ const e = this.resolveIcon(this.prefixIcon), r = this.resolveIcon(this.suffixIcon);
48
+ return c`
47
49
  <div class="nys-badge">
48
- ${e ? f`<nys-icon size="16" name=${e}></nys-icon>` : ""}
49
- ${this.prefixLabel ? f`<div class="nys-badge__prefix">${this.prefixLabel}</div>` : ""}
50
+ ${e ? c`<nys-icon size="16" name=${e}></nys-icon>` : ""}
51
+ ${this.prefixLabel ? c`<div class="nys-badge__prefix">${this.prefixLabel}</div>` : ""}
50
52
  <div class="nys-badge__label">${this.label}</div>
51
- ${n ? f`<nys-icon size="16" name=${n}></nys-icon>` : ""}
53
+ ${r ? c`<nys-icon size="16" name=${r}></nys-icon>` : ""}
52
54
  </div>
53
55
  `;
54
56
  }
55
- }, r.styles = d(b), r.DEFAULT_ICONS = {
57
+ }, o.styles = d(b), o.DEFAULT_ICONS = {
56
58
  neutral: "info",
57
59
  error: "emergency_home",
58
60
  success: "check_circle",
59
61
  warning: "warning"
60
- }, r);
61
- i([
62
- t({ type: String, reflect: !0 })
63
- ], s.prototype, "id", 2);
64
- i([
65
- t({ type: String, reflect: !0 })
66
- ], s.prototype, "name", 2);
67
- i([
68
- t({ type: String, reflect: !0 })
69
- ], s.prototype, "size", 2);
70
- i([
71
- t({ type: String, reflect: !0 })
72
- ], s.prototype, "intent", 2);
73
- i([
74
- t({ type: String })
75
- ], s.prototype, "prefixLabel", 2);
76
- i([
77
- t({ type: String })
78
- ], s.prototype, "label", 2);
79
- i([
80
- t({ type: String, attribute: "prefixicon" })
81
- ], s.prototype, "prefixIcon", 1);
82
- i([
83
- t({ type: String, attribute: "suffixicon" })
84
- ], s.prototype, "suffixIcon", 1);
85
- let u = s;
86
- customElements.get("nys-badge") || customElements.define("nys-badge", u);
62
+ }, o);
63
+ t([
64
+ s({ type: String, reflect: !0 })
65
+ ], n.prototype, "id", 2);
66
+ t([
67
+ s({ type: String, reflect: !0 })
68
+ ], n.prototype, "name", 2);
69
+ t([
70
+ s({ type: String, reflect: !0 })
71
+ ], n.prototype, "size", 2);
72
+ t([
73
+ s({ type: String, reflect: !0 })
74
+ ], n.prototype, "intent", 2);
75
+ t([
76
+ s({ type: String })
77
+ ], n.prototype, "prefixLabel", 2);
78
+ t([
79
+ s({ type: String })
80
+ ], n.prototype, "label", 2);
81
+ t([
82
+ s({ type: String, reflect: !0 })
83
+ ], n.prototype, "variant", 2);
84
+ t([
85
+ s({ type: String, attribute: "prefixicon" })
86
+ ], n.prototype, "prefixIcon", 1);
87
+ t([
88
+ s({ type: String, attribute: "suffixicon" })
89
+ ], n.prototype, "suffixIcon", 1);
90
+ let _ = n;
91
+ customElements.get("nys-badge") || customElements.define("nys-badge", _);
87
92
  export {
88
- u as NysBadge
93
+ _ as NysBadge
89
94
  };
90
95
  //# sourceMappingURL=nys-badge.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"nys-badge.js","sources":["../src/nys-badge.ts"],"sourcesContent":["import { LitElement, html, unsafeCSS } from \"lit\";\nimport { property } from \"lit/decorators.js\";\n// @ts-ignore: SCSS module imported via bundler as inline\nimport styles from \"./nys-badge.scss?inline\";\n\n/**\n * `<nys-badge>` displays a badge with optional prefix/suffix icons and labels.\n *\n * Features:\n * - Conveys an intent (`neutral`, `error`, `success`, `warning`) which affects default icons and styling.\n * - Supports custom prefix and suffix icons.\n */\n\nexport class NysBadge extends LitElement {\n static styles = unsafeCSS(styles);\n\n @property({ type: String, reflect: true }) id = \"\";\n @property({ type: String, reflect: true }) name = \"\";\n @property({ type: String, reflect: true }) size: \"sm\" | \"md\" = \"md\";\n @property({ type: String, reflect: true }) intent:\n | \"neutral\"\n | \"error\"\n | \"success\"\n | \"warning\" = \"neutral\";\n @property({ type: String }) prefixLabel = \"\";\n @property({ type: String }) label = \"\";\n\n // Icons (string or boolean)\n private _prefixIcon: string | boolean = \"\";\n @property({ type: String, attribute: \"prefixicon\" })\n get prefixIcon(): string | boolean {\n return this._prefixIcon;\n }\n set prefixIcon(value: string | boolean) {\n if (value === \"\" || value === null) {\n // boolean attribute without value → true\n this._prefixIcon = true;\n } else if (value === \"false\" || value === false) {\n this._prefixIcon = \"\";\n } else {\n this._prefixIcon = value;\n }\n }\n\n private _suffixIcon: string | boolean = \"\";\n @property({ type: String, attribute: \"suffixicon\" })\n get suffixIcon(): string | boolean {\n return this._suffixIcon;\n }\n set suffixIcon(value: string | boolean) {\n if (value === \"\" || value === null) {\n this._suffixIcon = true;\n } else if (value === \"false\" || value === false) {\n this._suffixIcon = \"\";\n } else {\n this._suffixIcon = value;\n }\n }\n\n /**\n * Lifecycle methods\n * --------------------------------------------------------------------------\n */\n\n connectedCallback() {\n super.connectedCallback();\n\n const attr = this.getAttribute(\"prefixicon\");\n if (attr !== null && this.prefixIcon === \"\") {\n this.prefixIcon = attr;\n }\n\n const suffixAttr = this.getAttribute(\"suffixicon\");\n if (suffixAttr !== null && this.suffixIcon === \"\") {\n this.suffixIcon = suffixAttr;\n }\n }\n\n /**\n * Functions\n * --------------------------------------------------------------------------\n */\n\n // Map of default icons by intent\n private static readonly DEFAULT_ICONS: Record<string, string> = {\n neutral: \"info\",\n error: \"emergency_home\",\n success: \"check_circle\",\n warning: \"warning\",\n };\n\n /**\n * Resolves which icon should be rendered.\n * @param icon The icon property value (string or boolean)\n * @returns Icon name or null if no icon should be rendered\n */\n private resolveIcon(icon: string | boolean): string | null {\n if (icon === true) {\n return NysBadge.DEFAULT_ICONS[this.intent] ?? \"info\";\n }\n if (typeof icon === \"string\" && icon.trim() !== \"\") {\n return icon;\n }\n return null;\n }\n\n render() {\n const prefixIconName = this.resolveIcon(this.prefixIcon);\n const suffixIconName = this.resolveIcon(this.suffixIcon);\n\n return html`\n <div class=\"nys-badge\">\n ${prefixIconName\n ? html`<nys-icon size=\"16\" name=${prefixIconName}></nys-icon>`\n : \"\"}\n ${this.prefixLabel\n ? html`<div class=\"nys-badge__prefix\">${this.prefixLabel}</div>`\n : \"\"}\n <div class=\"nys-badge__label\">${this.label}</div>\n ${suffixIconName\n ? html`<nys-icon size=\"16\" name=${suffixIconName}></nys-icon>`\n : \"\"}\n </div>\n `;\n }\n}\n\nif (!customElements.get(\"nys-badge\")) {\n customElements.define(\"nys-badge\", NysBadge);\n}\n"],"names":["_NysBadge","_a","LitElement","value","attr","suffixAttr","icon","prefixIconName","suffixIconName","html","unsafeCSS","styles","__decorateClass","property","NysBadge"],"mappings":";;;;;;;;AAaO,MAAMA,KAANC,IAAA,cAAuBC,EAAW;AAAA,EAAlC,cAAA;AAAA,UAAA,GAAA,SAAA,GAGsC,KAAA,KAAK,IACL,KAAA,OAAO,IACP,KAAA,OAAoB,MACpB,KAAA,SAI3B,WACY,KAAA,cAAc,IACd,KAAA,QAAQ,IAGpC,KAAQ,cAAgC,IAgBxC,KAAQ,cAAgC;AAAA,EAAA;AAAA,EAdxC,IAAI,aAA+B;AACjC,WAAO,KAAK;AAAA,EACd;AAAA,EACA,IAAI,WAAWC,GAAyB;AACtC,IAAIA,MAAU,MAAMA,MAAU,OAE5B,KAAK,cAAc,KACVA,MAAU,WAAWA,MAAU,KACxC,KAAK,cAAc,KAEnB,KAAK,cAAcA;AAAA,EAEvB;AAAA,EAIA,IAAI,aAA+B;AACjC,WAAO,KAAK;AAAA,EACd;AAAA,EACA,IAAI,WAAWA,GAAyB;AACtC,IAAIA,MAAU,MAAMA,MAAU,OAC5B,KAAK,cAAc,KACVA,MAAU,WAAWA,MAAU,KACxC,KAAK,cAAc,KAEnB,KAAK,cAAcA;AAAA,EAEvB;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,oBAAoB;AAClB,UAAM,kBAAA;AAEN,UAAMC,IAAO,KAAK,aAAa,YAAY;AAC3C,IAAIA,MAAS,QAAQ,KAAK,eAAe,OACvC,KAAK,aAAaA;AAGpB,UAAMC,IAAa,KAAK,aAAa,YAAY;AACjD,IAAIA,MAAe,QAAQ,KAAK,eAAe,OAC7C,KAAK,aAAaA;AAAA,EAEtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAoBQ,YAAYC,GAAuC;AACzD,WAAIA,MAAS,KACJL,EAAS,cAAc,KAAK,MAAM,KAAK,SAE5C,OAAOK,KAAS,YAAYA,EAAK,KAAA,MAAW,KACvCA,IAEF;AAAA,EACT;AAAA,EAEA,SAAS;AACP,UAAMC,IAAiB,KAAK,YAAY,KAAK,UAAU,GACjDC,IAAiB,KAAK,YAAY,KAAK,UAAU;AAEvD,WAAOC;AAAA;AAAA,UAEDF,IACEE,6BAAgCF,CAAc,iBAC9C,EAAE;AAAA,UACJ,KAAK,cACHE,mCAAsC,KAAK,WAAW,WACtD,EAAE;AAAA,wCAC0B,KAAK,KAAK;AAAA,UACxCD,IACEC,6BAAgCD,CAAc,iBAC9C,EAAE;AAAA;AAAA;AAAA,EAGZ;AACF,GA/GEP,EAAO,SAASS,EAAUC,CAAM,GAsEhCV,EAAwB,gBAAwC;AAAA,EAC9D,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,GA3ENA;AAGsCW,EAAA;AAAA,EAA1CC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAH9Bb,EAGgC,WAAA,MAAA,CAAA;AACAY,EAAA;AAAA,EAA1CC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAJ9Bb,EAIgC,WAAA,QAAA,CAAA;AACAY,EAAA;AAAA,EAA1CC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAL9Bb,EAKgC,WAAA,QAAA,CAAA;AACAY,EAAA;AAAA,EAA1CC,EAAS,EAAE,MAAM,QAAQ,SAAS,IAAM;AAAA,GAN9Bb,EAMgC,WAAA,UAAA,CAAA;AAKfY,EAAA;AAAA,EAA3BC,EAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAXfb,EAWiB,WAAA,eAAA,CAAA;AACAY,EAAA;AAAA,EAA3BC,EAAS,EAAE,MAAM,OAAA,CAAQ;AAAA,GAZfb,EAYiB,WAAA,SAAA,CAAA;AAKxBY,EAAA;AAAA,EADHC,EAAS,EAAE,MAAM,QAAQ,WAAW,cAAc;AAAA,GAhBxCb,EAiBP,WAAA,cAAA,CAAA;AAgBAY,EAAA;AAAA,EADHC,EAAS,EAAE,MAAM,QAAQ,WAAW,cAAc;AAAA,GAhCxCb,EAiCP,WAAA,cAAA,CAAA;AAjCC,IAAMc,IAANd;AAkHF,eAAe,IAAI,WAAW,KACjC,eAAe,OAAO,aAAac,CAAQ;"}
1
+ {"version":3,"file":"nys-badge.js","sources":["../src/nys-badge.ts"],"sourcesContent":["import { LitElement, html, unsafeCSS } from \"lit\";\nimport { property } from \"lit/decorators.js\";\n// @ts-ignore: SCSS module imported via bundler as inline\nimport styles from \"./nys-badge.scss?inline\";\n\nlet badgeIdCounter = 0;\n\n/**\n * A compact label for status, counts, or categorization. Supports semantic intents with auto-selected icons.\n *\n * Use badges to highlight metadata like status (\"Approved\"), counts (\"3 new\"), or categories.\n * Set `intent` to apply semantic meaning. Add `prefixIcon` or `suffixIcon` as boolean for default icons,\n * or pass icon name strings for custom icons.\n *\n * @summary Compact label for status, counts, or categorization with semantic styling.\n * @element nys-badge\n *\n * @example Status badge\n * ```html\n * <nys-badge intent=\"success\" label=\"Approved\" prefixIcon></nys-badge>\n * ```\n *\n * @example Count badge\n * ```html\n * <nys-badge prefixLabel=\"Messages\" label=\"12\"></nys-badge>\n * ```\n */\n\nexport class NysBadge extends LitElement {\n static styles = unsafeCSS(styles);\n\n /** Unique identifier. */\n @property({ type: String, reflect: true }) id = \"\";\n\n /** Name attribute for form association. */\n @property({ type: String, reflect: true }) name = \"\";\n\n /**\n * Badge size: `sm` (smaller text) or `md` (default).\n * @default \"md\"\n */\n @property({ type: String, reflect: true }) size: \"sm\" | \"md\" = \"md\";\n\n /**\n * Semantic intent affecting color: `neutral`, `error`, `success`, or `warning`.\n * @default \"neutral\"\n */\n @property({ type: String, reflect: true }) intent:\n | \"neutral\"\n | \"error\"\n | \"success\"\n | \"warning\" = \"neutral\";\n\n /** Secondary label displayed before the main label. */\n @property({ type: String }) prefixLabel = \"\";\n\n /** Primary label text displayed in the badge. */\n @property({ type: String }) label = \"\";\n\n @property({ type: String, reflect: true }) variant: \"strong\" | \"\" = \"\";\n\n // Icons (string or boolean)\n private _prefixIcon: string | boolean = \"\";\n @property({ type: String, attribute: \"prefixicon\" })\n get prefixIcon(): string | boolean {\n return this._prefixIcon;\n }\n set prefixIcon(value: string | boolean) {\n if (value === \"\" || value === null) {\n // boolean attribute without value → true\n this._prefixIcon = true;\n } else if (value === \"false\" || value === false) {\n this._prefixIcon = \"\";\n } else {\n this._prefixIcon = value;\n }\n }\n\n private _suffixIcon: string | boolean = \"\";\n @property({ type: String, attribute: \"suffixicon\" })\n get suffixIcon(): string | boolean {\n return this._suffixIcon;\n }\n set suffixIcon(value: string | boolean) {\n if (value === \"\" || value === null) {\n this._suffixIcon = true;\n } else if (value === \"false\" || value === false) {\n this._suffixIcon = \"\";\n } else {\n this._suffixIcon = value;\n }\n }\n\n /**\n * Lifecycle methods\n * --------------------------------------------------------------------------\n */\n\n connectedCallback() {\n super.connectedCallback();\n\n if (!this.id) {\n this.id = `nys-badge-${Date.now()}-${badgeIdCounter++}`;\n }\n\n const attr = this.getAttribute(\"prefixicon\");\n if (attr !== null && this.prefixIcon === \"\") {\n this.prefixIcon = attr;\n }\n\n const suffixAttr = this.getAttribute(\"suffixicon\");\n if (suffixAttr !== null && this.suffixIcon === \"\") {\n this.suffixIcon = suffixAttr;\n }\n }\n\n /**\n * Functions\n * --------------------------------------------------------------------------\n */\n\n // Map of default icons by intent\n private static readonly DEFAULT_ICONS: Record<string, string> = {\n neutral: \"info\",\n error: \"emergency_home\",\n success: \"check_circle\",\n warning: \"warning\",\n };\n\n /**\n * Resolves which icon should be rendered.\n * @param icon The icon property value (string or boolean)\n * @returns Icon name or null if no icon should be rendered\n */\n private resolveIcon(icon: string | boolean): string | null {\n if (icon === true) {\n return NysBadge.DEFAULT_ICONS[this.intent] ?? \"info\";\n }\n if (typeof icon === \"string\" && icon.trim() !== \"\") {\n return icon;\n }\n return null;\n }\n\n render() {\n const prefixIconName = this.resolveIcon(this.prefixIcon);\n const suffixIconName = this.resolveIcon(this.suffixIcon);\n\n return html`\n <div class=\"nys-badge\">\n ${prefixIconName\n ? html`<nys-icon size=\"16\" name=${prefixIconName}></nys-icon>`\n : \"\"}\n ${this.prefixLabel\n ? html`<div class=\"nys-badge__prefix\">${this.prefixLabel}</div>`\n : \"\"}\n <div class=\"nys-badge__label\">${this.label}</div>\n ${suffixIconName\n ? html`<nys-icon size=\"16\" name=${suffixIconName}></nys-icon>`\n : \"\"}\n </div>\n `;\n }\n}\n\nif (!customElements.get(\"nys-badge\")) {\n customElements.define(\"nys-badge\", NysBadge);\n}\n"],"names":["badgeIdCounter","_NysBadge","_a","LitElement","value","attr","suffixAttr","icon","prefixIconName","suffixIconName","html","unsafeCSS","styles","__decorateClass","property","NysBadge"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nysds/nys-badge",
3
- "version": "1.13.0",
3
+ "version": "1.13.1",
4
4
  "description": "The Badge component from the NYS Design System.",
5
5
  "module": "dist/nys-badge.js",
6
6
  "types": "dist/index.d.ts",
@@ -23,7 +23,7 @@
23
23
  "lit-analyze": "lit-analyzer '**/*.ts'"
24
24
  },
25
25
  "dependencies": {
26
- "@nysds/nys-icon": "^1.13.0"
26
+ "@nysds/nys-icon": "^1.13.1"
27
27
  },
28
28
  "devDependencies": {
29
29
  "lit": "^3.3.1",