@nysds/nys-table 1.13.1 → 1.14.0

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.
@@ -0,0 +1 @@
1
+ export * from "./nys-table";
@@ -0,0 +1,39 @@
1
+ import { LitElement } from "lit";
2
+ /**
3
+ * `<nys-table>` is a responsive table component that can display native HTML tables,
4
+ * supports striped and bordered styling, sortable columns, and CSV download.
5
+ *
6
+ * @slot - Accepts a `<table>` element. Only the first table is rendered.
7
+ *
8
+ * @fires nys-click - Fired when the download button or sortable headers are clicked.
9
+ *
10
+ * @method downloadFile - Triggers download of the CSV file if `download` is set.
11
+ */
12
+ export declare class NysTable extends LitElement {
13
+ static styles: import("lit").CSSResult;
14
+ id: string;
15
+ name: string;
16
+ striped: boolean;
17
+ sortable: boolean;
18
+ bordered: boolean;
19
+ download: string;
20
+ private _sortColumn;
21
+ private _sortDirection;
22
+ private _captionText;
23
+ /**************** Lifecycle Methods ****************/
24
+ constructor();
25
+ connectedCallback(): void;
26
+ /******************** Functions ********************/
27
+ firstUpdated(): void;
28
+ _handleSlotChange(): void;
29
+ _normalizeTableDOM(table: HTMLTableElement): void;
30
+ willUpdate(): void;
31
+ _addSortIcons(table: HTMLTableElement): void;
32
+ _updateSortIcons(table: HTMLTableElement): void;
33
+ _onSortClick(columnIndex: number, table: HTMLTableElement): void;
34
+ _sortTable(table: HTMLTableElement, columnIndex: number, direction: "asc" | "desc"): void;
35
+ _updateSortedColumnStyles(table: HTMLTableElement): void;
36
+ downloadFile(): void;
37
+ /****************** Event Handlers ******************/
38
+ render(): import("lit-html").TemplateResult<1>;
39
+ }
@@ -0,0 +1 @@
1
+ export {};
package/dist/nys-table.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { LitElement as v, unsafeCSS as g, html as _ } from "lit";
2
- import { property as h, state as u } from "lit/decorators.js";
3
- const w = ':host{--_nys-table-width: 100%;--_nys-table-radius: var(--nys-radius-xl, 12px);--_nys-table-padding: var(--nys-space-100, 8px);--_nys-table-border-color: transparent;--_nys-table-border-width: 0;--_nys-table-font-family: var(--nys-font-family-ui, var(--nys-font-family-sans, "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans-serif));--_nys-table-font-size: var(--nys-font-size-ui-md, 16px);--_nys-table-font-weight: var(--nys-font-weight-regular, 400);--_nys-table-line-height: 16px;--_nys-table-padding--caption: var(--nys-space-250, 20px) var(--nys-space-150, 12px);--_nys-table-font-size--caption: var(--nys-font-size-ui-lg, 18px);--_nys-table-font-weight--caption: var(--nys-font-weight-bold, 700);--_nys-table-padding--cell--x: var(--nys-space-150, 12px);--_nys-table-padding--cell--y: var(--nys-space-200, 16px);--_nys-table-background-color: var(--nys-color-ink-reverse, #fff);--_nys-table-background-color--striped: var(--nys-color-neutral-10, #f6f6f6)}:host([bordered]){--_nys-table-border-color: var(--nys-color-neutral-100, #d0d0ce);--_nys-table-border-width: var(--nys-space-1px, 1px)}:host([download]){display:flex;flex-direction:column;gap:var(--nys-space-150, 12px)}.nys-table{width:var(--_nys-table-width);font:var(--_nys-table-font-weight) var(--_nys-table-font-size)/var(--_nys-table-line-height) var(--_nys-table-font-family)}.nys-table table{width:var(--_nys-table-width);border-collapse:collapse;background-color:var(--_nys-table-background-color)}.nys-table caption{padding:var(--_nys-table-padding--caption);font-size:var(--_nys-table-font-size--caption);font-weight:var(--_nys-table-font-weight--caption);text-align:start}.nys-table caption div{display:flex;justify-content:space-between;align-items:center}.nys-table td{padding:var(--_nys-table-padding--cell--y) var(--_nys-table-padding--cell--x);border:var(--_nys-table-border-width) solid var(--_nys-table-border-color)}.nys-table th{border:var(--_nys-table-border-width) solid var(--_nys-table-border-color);overflow:hidden;text-overflow:ellipsis;padding:var(--_nys-table-padding--cell--y) var(--_nys-table-padding--cell--x)}.nys-table th:has(nys-button){padding:0}.nys-table th p{margin:0}.nys-table th nys-button{margin:0;width:-moz-available;width:-webkit-fill-available;width:fill-available;justify-content:space-between;--_nys-button-border-width: 0;--_nys-button-border-radius--start: 0;--_nys-button-border-radius--end: 0;--_nys-button-padding--x: var(--_nys-table-padding--cell--x);--_nys-button-justify-content: space-between;--_nys-button-outline-offset: -2px}.nys-table th.nys-table__sortedcolumn{background-color:var(--nys-color-theme-weak, #cddde9)}.nys-table td.nys-table__sortedcolumn{position:relative;z-index:0}.nys-table td.nys-table__sortedcolumn:after{content:"";position:absolute;inset:0;background-color:var(--nys-color-theme, #154973);opacity:.1;pointer-events:none;z-index:-1}:host([striped]) .nys-table tbody tr:nth-child(odd){background-color:var(--_nys-table-background-color--striped)}:host([sortable]) .nys-table th{cursor:pointer}.sr-only{border:0!important;clip:rect(1px,1px,1px,1px)!important;-webkit-clip-path:inset(50%)!important;clip-path:inset(50%)!important;height:1px!important;overflow:hidden!important;margin:-1px!important;padding:0!important;position:absolute!important;width:1px!important;white-space:nowrap!important}';
4
- var x = Object.defineProperty, p = (m, t, s, r) => {
2
+ import { property as u, state as h } from "lit/decorators.js";
3
+ const w = ':host{--_nys-table-width: 100%;--_nys-table-radius: var(--nys-radius-xl, 12px);--_nys-table-padding: var(--nys-space-100, 8px);--_nys-table-border-color: transparent;--_nys-table-border-width: 0;--_nys-table-font-family: var(--nys-font-family-ui, var(--nys-font-family-sans, "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans-serif));--_nys-table-font-size: var(--nys-font-size-ui-md, 16px);--_nys-table-font-weight: var(--nys-font-weight-regular, 400);--_nys-table-line-height: var(--nys-font-line-height-ui, 24px);--_nys-table-padding--caption: var(--nys-space-250, 20px) var(--nys-space-150, 12px);--_nys-table-font-size--caption: var(--nys-font-size-ui-lg, 18px);--_nys-table-font-weight--caption: var(--nys-font-weight-bold, 700);--_nys-table-padding--cell--x: var(--nys-space-150, 12px);--_nys-table-padding--cell--y: var(--nys-space-200, 16px);--_nys-table-background-color: var(--nys-color-ink-reverse, #ffffff);--_nys-table-background-color--striped: var(--nys-color-neutral-10, #f6f6f6);--_nys-table-color--code: var(--nys-color-red-600, #b52c2c);--_nys-table-background-color--code: var(--nys-color-neutral-10, #f6f6f6)}:host([bordered]){--_nys-table-border-color: var(--nys-color-neutral-100, #d0d0ce);--_nys-table-border-width: var(--nys-space-1px, 1px)}:host([download]){display:flex;flex-direction:column;gap:var(--nys-space-150, 12px)}.nys-table{width:var(--_nys-table-width);font:var(--_nys-table-font-weight) var(--_nys-table-font-size)/var(--_nys-table-line-height) var(--_nys-table-font-family)}.nys-table table{width:var(--_nys-table-width);border-collapse:collapse;background-color:var(--_nys-table-background-color)}.nys-table caption{padding:var(--_nys-table-padding--caption);font-size:var(--_nys-table-font-size--caption);font-weight:var(--_nys-table-font-weight--caption);text-align:start}.nys-table caption div{display:flex;justify-content:space-between;align-items:center}.nys-table td{padding:var(--_nys-table-padding--cell--y) var(--_nys-table-padding--cell--x);border:var(--_nys-table-border-width) solid var(--_nys-table-border-color)}.nys-table td code{color:var(--_nys-table-color--code);background-color:var(--_nys-table-background-color--code);padding:var(--nys-space-1px) var(--nys-space-2px);border-radius:var(--nys-radius-md)}.nys-table th{border:var(--_nys-table-border-width) solid var(--_nys-table-border-color);overflow:hidden;text-overflow:ellipsis;padding:var(--_nys-table-padding--cell--y) var(--_nys-table-padding--cell--x);text-align:left}.nys-table th:has(nys-button){padding:0}.nys-table th p{margin:0}.nys-table th nys-button{margin:0;width:-moz-available;width:-webkit-fill-available;width:fill-available;justify-content:space-between;--_nys-button-border-width: 0;--_nys-button-border-radius--start: 0;--_nys-button-border-radius--end: 0;--_nys-button-padding--x: var(--_nys-table-padding--cell--x);--_nys-button-justify-content: space-between;--_nys-button-outline-offset: -2px}.nys-table th.nys-table__sortedcolumn{background-color:var(--nys-color-theme-weak, #cddde9)}.nys-table td.nys-table__sortedcolumn{position:relative;z-index:0}.nys-table td.nys-table__sortedcolumn:after{content:"";position:absolute;inset:0;background-color:var(--nys-color-theme, #154973);opacity:.1;pointer-events:none;z-index:-1}:host([striped]) .nys-table tbody tr:nth-child(odd){background-color:var(--_nys-table-background-color--striped)}:host([sortable]) .nys-table th{cursor:pointer}.sr-only{border:0!important;clip-path:inset(50%)!important;height:1px!important;overflow:hidden!important;margin:-1px!important;padding:0!important;position:absolute!important;width:1px!important;white-space:nowrap!important}';
4
+ var x = Object.defineProperty, y = (m, t, s, r) => {
5
5
  for (var o = void 0, n = m.length - 1, e; n >= 0; n--)
6
6
  (e = m[n]) && (o = e(t, s, o) || o);
7
7
  return o && x(t, s, o), o;
@@ -41,11 +41,11 @@ const f = class f extends v {
41
41
  "caption"
42
42
  ), n = Array.from(t.querySelectorAll("tr"));
43
43
  if (n.length === 0) return;
44
- const e = document.createElement("thead"), l = document.createElement("tbody"), y = n.findIndex((a) => a.querySelector("th"));
45
- if (y === -1)
44
+ const e = document.createElement("thead"), l = document.createElement("tbody"), p = n.findIndex((a) => a.querySelector("th"));
45
+ if (p === -1)
46
46
  n.forEach((a) => l.appendChild(a));
47
47
  else {
48
- const a = n[y];
48
+ const a = n[p];
49
49
  a.querySelectorAll("th").forEach((d) => {
50
50
  Array.from(d.childNodes).forEach((c) => {
51
51
  if (c.nodeType === Node.TEXT_NODE && c.textContent?.trim()) {
@@ -54,7 +54,7 @@ const f = class f extends v {
54
54
  }
55
55
  });
56
56
  }), e.appendChild(a), n.forEach((d, c) => {
57
- c !== y && l.appendChild(d);
57
+ c !== p && l.appendChild(d);
58
58
  });
59
59
  }
60
60
  if (t.innerHTML = "", o && t.appendChild(o), this.sortable) {
@@ -86,8 +86,8 @@ const f = class f extends v {
86
86
  const e = document.createElement("nys-button");
87
87
  e.setAttribute("part", "sort-button"), e.setAttribute("variant", "ghost"), e.setAttribute("label", n), e.setAttribute("suffixIcon", "slotted"), e.setAttribute("fullWidth", "true");
88
88
  const l = document.createElement("nys-icon");
89
- l.setAttribute("slot", "suffix-icon"), l.setAttribute("name", "height"), l.setAttribute("size", "24"), l.setAttribute("color", "var(--nys-color-text-weak, #4a4d4f)"), e.appendChild(l), e.addEventListener("nys-click", (y) => {
90
- y.stopPropagation(), this._onSortClick(o, t);
89
+ l.setAttribute("slot", "suffix-icon"), l.setAttribute("name", "height"), l.setAttribute("size", "24"), l.setAttribute("color", "var(--nys-color-text-weak, #4a4d4f)"), e.appendChild(l), e.addEventListener("nys-click", (p) => {
90
+ p.stopPropagation(), this._onSortClick(o, t);
91
91
  }), r.appendChild(e);
92
92
  });
93
93
  }
@@ -118,9 +118,9 @@ const f = class f extends v {
118
118
  if (!o) return;
119
119
  const n = Array.from(o.querySelectorAll("tr"));
120
120
  n.sort((e, l) => {
121
- const y = e.children[s]?.textContent?.trim() ?? "", a = l.children[s]?.textContent?.trim() ?? "", d = Number(y), c = Number(a);
121
+ const p = e.children[s]?.textContent?.trim() ?? "", a = l.children[s]?.textContent?.trim() ?? "", d = Number(p), c = Number(a);
122
122
  let b;
123
- return !isNaN(d) && !isNaN(c) ? b = d - c : b = y.localeCompare(a), r === "asc" ? b : -b;
123
+ return !isNaN(d) && !isNaN(c) ? b = d - c : b = p.localeCompare(a), r === "asc" ? b : -b;
124
124
  }), n.forEach((e) => o.appendChild(e)), this._updateSortedColumnStyles(t);
125
125
  }
126
126
  _updateSortedColumnStyles(t) {
@@ -156,32 +156,32 @@ const f = class f extends v {
156
156
  };
157
157
  f.styles = g(w);
158
158
  let i = f;
159
- p([
160
- h({ type: String, reflect: !0 })
159
+ y([
160
+ u({ type: String, reflect: !0 })
161
161
  ], i.prototype, "id");
162
- p([
163
- h({ type: String, reflect: !0 })
162
+ y([
163
+ u({ type: String, reflect: !0 })
164
164
  ], i.prototype, "name");
165
- p([
166
- h({ type: Boolean, reflect: !0 })
165
+ y([
166
+ u({ type: Boolean, reflect: !0 })
167
167
  ], i.prototype, "striped");
168
- p([
169
- h({ type: Boolean, reflect: !0 })
168
+ y([
169
+ u({ type: Boolean, reflect: !0 })
170
170
  ], i.prototype, "sortable");
171
- p([
172
- h({ type: Boolean, reflect: !0 })
171
+ y([
172
+ u({ type: Boolean, reflect: !0 })
173
173
  ], i.prototype, "bordered");
174
- p([
175
- h({ type: String, reflect: !0 })
174
+ y([
175
+ u({ type: String, reflect: !0 })
176
176
  ], i.prototype, "download");
177
- p([
178
- u()
177
+ y([
178
+ h()
179
179
  ], i.prototype, "_sortColumn");
180
- p([
181
- u()
180
+ y([
181
+ h()
182
182
  ], i.prototype, "_sortDirection");
183
- p([
184
- u()
183
+ y([
184
+ h()
185
185
  ], i.prototype, "_captionText");
186
186
  customElements.get("nys-table") || customElements.define("nys-table", i);
187
187
  export {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nysds/nys-table",
3
- "version": "1.13.1",
3
+ "version": "1.14.0",
4
4
  "description": "The Table component from the NYS Design System.",
5
5
  "module": "dist/nys-table.js",
6
6
  "types": "dist/index.d.ts",
@@ -22,12 +22,14 @@
22
22
  "test:watch": "vite build && wtr --watch",
23
23
  "lit-analyze": "lit-analyzer '*.ts'"
24
24
  },
25
+ "dependencies": {
26
+ "@nysds/nys-icon": "^1.14.0",
27
+ "@nysds/nys-button": "^1.14.0"
28
+ },
25
29
  "devDependencies": {
26
30
  "lit": "^3.3.1",
27
31
  "typescript": "^5.9.3",
28
- "vite": "^7.1.12",
29
- "@nysds/nys-button": "^1.13.1",
30
- "@nysds/nys-icon": "^1.13.1"
32
+ "vite": "^7.3.1"
31
33
  },
32
34
  "keywords": [
33
35
  "new-york-state",