reke-ui 0.1.2 → 0.2.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.
Files changed (78) hide show
  1. package/README.md +21 -0
  2. package/cli/install-skills.mjs +169 -0
  3. package/custom-elements.json +405 -161
  4. package/dist/__type-checks__/no-lit-in-public-types.d.ts +2 -0
  5. package/dist/__type-checks__/no-lit-in-public-types.d.ts.map +1 -0
  6. package/dist/_virtual/_@oxc-project_runtime@0.137.0/helpers/esm/decorate.js +9 -0
  7. package/dist/components/reke-alert/reke-alert.d.ts.map +1 -1
  8. package/dist/components/reke-alert/reke-alert.js +32 -40
  9. package/dist/components/reke-alert/reke-alert.styles.js +7 -10
  10. package/dist/components/reke-badge/reke-badge.js +26 -40
  11. package/dist/components/reke-badge/reke-badge.styles.js +7 -10
  12. package/dist/components/reke-button/reke-button.d.ts.map +1 -1
  13. package/dist/components/reke-button/reke-button.js +41 -52
  14. package/dist/components/reke-button/reke-button.styles.js +7 -10
  15. package/dist/components/reke-card/reke-card.d.ts.map +1 -1
  16. package/dist/components/reke-card/reke-card.js +38 -58
  17. package/dist/components/reke-card/reke-card.styles.js +7 -10
  18. package/dist/components/reke-checkbox/reke-checkbox.js +40 -47
  19. package/dist/components/reke-checkbox/reke-checkbox.styles.d.ts.map +1 -1
  20. package/dist/components/reke-checkbox/reke-checkbox.styles.js +7 -9
  21. package/dist/components/reke-chip/reke-chip.d.ts.map +1 -1
  22. package/dist/components/reke-chip/reke-chip.js +42 -50
  23. package/dist/components/reke-chip/reke-chip.styles.d.ts.map +1 -1
  24. package/dist/components/reke-chip/reke-chip.styles.js +16 -13
  25. package/dist/components/reke-date-range/reke-date-range.d.ts.map +1 -1
  26. package/dist/components/reke-date-range/reke-date-range.js +240 -260
  27. package/dist/components/reke-date-range/reke-date-range.styles.d.ts.map +1 -1
  28. package/dist/components/reke-date-range/reke-date-range.styles.js +29 -16
  29. package/dist/components/reke-dialog/reke-dialog.d.ts.map +1 -1
  30. package/dist/components/reke-dialog/reke-dialog.js +52 -65
  31. package/dist/components/reke-dialog/reke-dialog.styles.d.ts.map +1 -1
  32. package/dist/components/reke-dialog/reke-dialog.styles.js +8 -10
  33. package/dist/components/reke-file-upload/reke-file-upload.d.ts.map +1 -1
  34. package/dist/components/reke-file-upload/reke-file-upload.js +62 -86
  35. package/dist/components/reke-file-upload/reke-file-upload.styles.js +7 -10
  36. package/dist/components/reke-input/reke-input.js +42 -61
  37. package/dist/components/reke-input/reke-input.styles.d.ts.map +1 -1
  38. package/dist/components/reke-input/reke-input.styles.js +8 -10
  39. package/dist/components/reke-select/reke-select.d.ts.map +1 -1
  40. package/dist/components/reke-select/reke-select.js +66 -89
  41. package/dist/components/reke-select/reke-select.styles.d.ts.map +1 -1
  42. package/dist/components/reke-select/reke-select.styles.js +9 -11
  43. package/dist/components/reke-table/reke-table.d.ts +134 -23
  44. package/dist/components/reke-table/reke-table.d.ts.map +1 -1
  45. package/dist/components/reke-table/reke-table.js +243 -143
  46. package/dist/components/reke-table/reke-table.styles.d.ts.map +1 -1
  47. package/dist/components/reke-table/reke-table.styles.js +67 -9
  48. package/dist/components/reke-textarea/reke-textarea.js +42 -61
  49. package/dist/components/reke-textarea/reke-textarea.styles.js +6 -9
  50. package/dist/components/reke-toast/reke-toast.d.ts.map +1 -1
  51. package/dist/components/reke-toast/reke-toast.js +50 -68
  52. package/dist/components/reke-toast/reke-toast.styles.d.ts.map +1 -1
  53. package/dist/components/reke-toast/reke-toast.styles.js +13 -12
  54. package/dist/components/reke-toggle/reke-toggle.js +36 -43
  55. package/dist/components/reke-toggle/reke-toggle.styles.js +7 -10
  56. package/dist/components/reke-tooltip/reke-tooltip.js +31 -47
  57. package/dist/components/reke-tooltip/reke-tooltip.styles.js +6 -9
  58. package/dist/index.d.ts +23 -23
  59. package/dist/index.d.ts.map +1 -1
  60. package/dist/index.js +15 -33
  61. package/dist/node_modules/lit/directives/ref.js +1 -0
  62. package/dist/node_modules/lit-html/async-directive.js +55 -0
  63. package/dist/node_modules/lit-html/directive-helpers.js +5 -0
  64. package/dist/node_modules/lit-html/directive.js +28 -0
  65. package/dist/node_modules/lit-html/directives/ref.js +30 -0
  66. package/dist/node_modules/lit-html/lit-html.js +234 -0
  67. package/dist/react-bridge/table.d.ts +58 -0
  68. package/dist/react-bridge/table.d.ts.map +1 -0
  69. package/dist/react-bridge/table.js +115 -0
  70. package/dist/react.d.ts +12 -26
  71. package/dist/react.d.ts.map +1 -1
  72. package/dist/react.js +110 -146
  73. package/dist/shared/base-element.js +13 -15
  74. package/dist/shared/tailwind-styles.js +6 -6
  75. package/dist/shared/tailwind.js +4 -0
  76. package/dist/tokens/reke-tokens.css +47 -0
  77. package/package.json +40 -20
  78. package/dist/shared/tailwind.css.js +0 -4
@@ -0,0 +1,55 @@
1
+ import { r as e } from "./directive-helpers.js";
2
+ import { i as t, t as n } from "./directive.js";
3
+ //#region node_modules/lit-html/async-directive.js
4
+ var r = (e, t) => {
5
+ let n = e._$AN;
6
+ if (n === void 0) return !1;
7
+ for (let e of n) e._$AO?.(t, !1), r(e, t);
8
+ return !0;
9
+ }, i = (e) => {
10
+ let t, n;
11
+ do {
12
+ if ((t = e._$AM) === void 0) break;
13
+ n = t._$AN, n.delete(e), e = t;
14
+ } while (n?.size === 0);
15
+ }, a = (e) => {
16
+ for (let t; t = e._$AM; e = t) {
17
+ let n = t._$AN;
18
+ if (n === void 0) t._$AN = n = /* @__PURE__ */ new Set();
19
+ else if (n.has(e)) break;
20
+ n.add(e), c(t);
21
+ }
22
+ };
23
+ function o(e) {
24
+ this._$AN === void 0 ? this._$AM = e : (i(this), this._$AM = e, a(this));
25
+ }
26
+ function s(e, t = !1, n = 0) {
27
+ let a = this._$AH, o = this._$AN;
28
+ if (o !== void 0 && o.size !== 0) if (t) if (Array.isArray(a)) for (let e = n; e < a.length; e++) r(a[e], !1), i(a[e]);
29
+ else a != null && (r(a, !1), i(a));
30
+ else r(this, e);
31
+ }
32
+ var c = (e) => {
33
+ e.type == n.CHILD && (e._$AP ??= s, e._$AQ ??= o);
34
+ }, l = class extends t {
35
+ constructor() {
36
+ super(...arguments), this._$AN = void 0;
37
+ }
38
+ _$AT(e, t, n) {
39
+ super._$AT(e, t, n), a(this), this.isConnected = e._$AU;
40
+ }
41
+ _$AO(e, t = !0) {
42
+ e !== this.isConnected && (this.isConnected = e, e ? this.reconnected?.() : this.disconnected?.()), t && (r(this, e), i(this));
43
+ }
44
+ setValue(t) {
45
+ if (e(this._$Ct)) this._$Ct._$AI(t, this);
46
+ else {
47
+ let e = [...this._$Ct._$AH];
48
+ e[this._$Ci] = t, this._$Ct._$AI(e, this, 0);
49
+ }
50
+ }
51
+ disconnected() {}
52
+ reconnected() {}
53
+ };
54
+ //#endregion
55
+ export { l as f };
@@ -0,0 +1,5 @@
1
+ import { j as e } from "./lit-html.js";
2
+ //#region node_modules/lit-html/directive-helpers.js
3
+ var { I: t } = e, n = (e) => e.strings === void 0;
4
+ //#endregion
5
+ export { n as r };
@@ -0,0 +1,28 @@
1
+ //#region node_modules/lit-html/directive.js
2
+ var e = {
3
+ ATTRIBUTE: 1,
4
+ CHILD: 2,
5
+ PROPERTY: 3,
6
+ BOOLEAN_ATTRIBUTE: 4,
7
+ EVENT: 5,
8
+ ELEMENT: 6
9
+ }, t = (e) => (...t) => ({
10
+ _$litDirective$: e,
11
+ values: t
12
+ }), n = class {
13
+ constructor(e) {}
14
+ get _$AU() {
15
+ return this._$AM._$AU;
16
+ }
17
+ _$AT(e, t, n) {
18
+ this._$Ct = e, this._$AM = t, this._$Ci = n;
19
+ }
20
+ _$AS(e, t) {
21
+ return this.update(e, t);
22
+ }
23
+ update(e, t) {
24
+ return this.render(...t);
25
+ }
26
+ };
27
+ //#endregion
28
+ export { t as e, n as i, e as t };
@@ -0,0 +1,30 @@
1
+ import { A as e } from "../lit-html.js";
2
+ import { e as t } from "../directive.js";
3
+ import { f as n } from "../async-directive.js";
4
+ //#region node_modules/lit-html/directives/ref.js
5
+ var r = /* @__PURE__ */ new WeakMap(), i = t(class extends n {
6
+ render(t) {
7
+ return e;
8
+ }
9
+ update(t, [n]) {
10
+ let r = n !== this.G;
11
+ return r && this.rt(void 0), (r || this.lt !== this.ct) && (this.G = n, this.ht = t.options?.host, this.rt(this.ct = t.element)), e;
12
+ }
13
+ rt(e) {
14
+ if (this.G !== void 0) if (this.isConnected || (e = void 0), typeof this.G == "function") {
15
+ let t = this.ht ?? globalThis, n = r.get(t);
16
+ n === void 0 && (n = /* @__PURE__ */ new WeakMap(), r.set(t, n)), n.get(this.G) !== void 0 && this.G.call(this.ht, void 0), n.set(this.G, e), e !== void 0 && this.G.call(this.ht, e);
17
+ } else this.G.value = e;
18
+ }
19
+ get lt() {
20
+ return typeof this.G == "function" ? r.get(this.ht ?? globalThis)?.get(this.G) : this.G?.value;
21
+ }
22
+ disconnected() {
23
+ this.lt === this.ct && this.rt(void 0);
24
+ }
25
+ reconnected() {
26
+ this.rt(this.ct);
27
+ }
28
+ });
29
+ //#endregion
30
+ export { i as n };
@@ -0,0 +1,234 @@
1
+ //#region node_modules/lit-html/lit-html.js
2
+ var e = globalThis, t = (e) => e, n = e.trustedTypes, r = n ? n.createPolicy("lit-html", { createHTML: (e) => e }) : void 0, i = "$lit$", a = `lit$${Math.random().toFixed(9).slice(2)}$`, o = "?" + a, s = `<${o}>`, c = document, l = () => c.createComment(""), u = (e) => e === null || typeof e != "object" && typeof e != "function", d = Array.isArray, f = (e) => d(e) || typeof e?.[Symbol.iterator] == "function", p = "[ \n\f\r]", m = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g, h = /-->/g, g = />/g, _ = RegExp(`>|${p}(?:([^\\s"'>=/]+)(${p}*=${p}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`, "g"), v = /'/g, y = /"/g, b = /^(?:script|style|textarea|title)$/i, x = Symbol.for("lit-noChange"), S = Symbol.for("lit-nothing"), C = /* @__PURE__ */ new WeakMap(), w = c.createTreeWalker(c, 129);
3
+ function T(e, t) {
4
+ if (!d(e) || !e.hasOwnProperty("raw")) throw Error("invalid template strings array");
5
+ return r === void 0 ? t : r.createHTML(t);
6
+ }
7
+ var E = (e, t) => {
8
+ let n = e.length - 1, r = [], o, c = t === 2 ? "<svg>" : t === 3 ? "<math>" : "", l = m;
9
+ for (let t = 0; t < n; t++) {
10
+ let n = e[t], u, d, f = -1, p = 0;
11
+ for (; p < n.length && (l.lastIndex = p, d = l.exec(n), d !== null);) p = l.lastIndex, l === m ? d[1] === "!--" ? l = h : d[1] === void 0 ? d[2] === void 0 ? d[3] !== void 0 && (l = _) : (b.test(d[2]) && (o = RegExp("</" + d[2], "g")), l = _) : l = g : l === _ ? d[0] === ">" ? (l = o ?? m, f = -1) : d[1] === void 0 ? f = -2 : (f = l.lastIndex - d[2].length, u = d[1], l = d[3] === void 0 ? _ : d[3] === "\"" ? y : v) : l === y || l === v ? l = _ : l === h || l === g ? l = m : (l = _, o = void 0);
12
+ let x = l === _ && e[t + 1].startsWith("/>") ? " " : "";
13
+ c += l === m ? n + s : f >= 0 ? (r.push(u), n.slice(0, f) + i + n.slice(f) + a + x) : n + a + (f === -2 ? t : x);
14
+ }
15
+ return [T(e, c + (e[n] || "<?>") + (t === 2 ? "</svg>" : t === 3 ? "</math>" : "")), r];
16
+ }, D = class e {
17
+ constructor({ strings: t, _$litType$: r }, s) {
18
+ let c;
19
+ this.parts = [];
20
+ let u = 0, d = 0, f = t.length - 1, p = this.parts, [m, h] = E(t, r);
21
+ if (this.el = e.createElement(m, s), w.currentNode = this.el.content, r === 2 || r === 3) {
22
+ let e = this.el.content.firstChild;
23
+ e.replaceWith(...e.childNodes);
24
+ }
25
+ for (; (c = w.nextNode()) !== null && p.length < f;) {
26
+ if (c.nodeType === 1) {
27
+ if (c.hasAttributes()) for (let e of c.getAttributeNames()) if (e.endsWith(i)) {
28
+ let t = h[d++], n = c.getAttribute(e).split(a), r = /([.?@])?(.*)/.exec(t);
29
+ p.push({
30
+ type: 1,
31
+ index: u,
32
+ name: r[2],
33
+ strings: n,
34
+ ctor: r[1] === "." ? M : r[1] === "?" ? N : r[1] === "@" ? P : j
35
+ }), c.removeAttribute(e);
36
+ } else e.startsWith(a) && (p.push({
37
+ type: 6,
38
+ index: u
39
+ }), c.removeAttribute(e));
40
+ if (b.test(c.tagName)) {
41
+ let e = c.textContent.split(a), t = e.length - 1;
42
+ if (t > 0) {
43
+ c.textContent = n ? n.emptyScript : "";
44
+ for (let n = 0; n < t; n++) c.append(e[n], l()), w.nextNode(), p.push({
45
+ type: 2,
46
+ index: ++u
47
+ });
48
+ c.append(e[t], l());
49
+ }
50
+ }
51
+ } else if (c.nodeType === 8) if (c.data === o) p.push({
52
+ type: 2,
53
+ index: u
54
+ });
55
+ else {
56
+ let e = -1;
57
+ for (; (e = c.data.indexOf(a, e + 1)) !== -1;) p.push({
58
+ type: 7,
59
+ index: u
60
+ }), e += a.length - 1;
61
+ }
62
+ u++;
63
+ }
64
+ }
65
+ static createElement(e, t) {
66
+ let n = c.createElement("template");
67
+ return n.innerHTML = e, n;
68
+ }
69
+ };
70
+ function O(e, t, n = e, r) {
71
+ if (t === x) return t;
72
+ let i = r === void 0 ? n._$Cl : n._$Co?.[r], a = u(t) ? void 0 : t._$litDirective$;
73
+ return i?.constructor !== a && (i?._$AO?.(!1), a === void 0 ? i = void 0 : (i = new a(e), i._$AT(e, n, r)), r === void 0 ? n._$Cl = i : (n._$Co ??= [])[r] = i), i !== void 0 && (t = O(e, i._$AS(e, t.values), i, r)), t;
74
+ }
75
+ var k = class {
76
+ constructor(e, t) {
77
+ this._$AV = [], this._$AN = void 0, this._$AD = e, this._$AM = t;
78
+ }
79
+ get parentNode() {
80
+ return this._$AM.parentNode;
81
+ }
82
+ get _$AU() {
83
+ return this._$AM._$AU;
84
+ }
85
+ u(e) {
86
+ let { el: { content: t }, parts: n } = this._$AD, r = (e?.creationScope ?? c).importNode(t, !0);
87
+ w.currentNode = r;
88
+ let i = w.nextNode(), a = 0, o = 0, s = n[0];
89
+ for (; s !== void 0;) {
90
+ if (a === s.index) {
91
+ let t;
92
+ s.type === 2 ? t = new A(i, i.nextSibling, this, e) : s.type === 1 ? t = new s.ctor(i, s.name, s.strings, this, e) : s.type === 6 && (t = new F(i, this, e)), this._$AV.push(t), s = n[++o];
93
+ }
94
+ a !== s?.index && (i = w.nextNode(), a++);
95
+ }
96
+ return w.currentNode = c, r;
97
+ }
98
+ p(e) {
99
+ let t = 0;
100
+ for (let n of this._$AV) n !== void 0 && (n.strings === void 0 ? n._$AI(e[t]) : (n._$AI(e, n, t), t += n.strings.length - 2)), t++;
101
+ }
102
+ }, A = class e {
103
+ get _$AU() {
104
+ return this._$AM?._$AU ?? this._$Cv;
105
+ }
106
+ constructor(e, t, n, r) {
107
+ this.type = 2, this._$AH = S, this._$AN = void 0, this._$AA = e, this._$AB = t, this._$AM = n, this.options = r, this._$Cv = r?.isConnected ?? !0;
108
+ }
109
+ get parentNode() {
110
+ let e = this._$AA.parentNode, t = this._$AM;
111
+ return t !== void 0 && e?.nodeType === 11 && (e = t.parentNode), e;
112
+ }
113
+ get startNode() {
114
+ return this._$AA;
115
+ }
116
+ get endNode() {
117
+ return this._$AB;
118
+ }
119
+ _$AI(e, t = this) {
120
+ e = O(this, e, t), u(e) ? e === S || e == null || e === "" ? (this._$AH !== S && this._$AR(), this._$AH = S) : e !== this._$AH && e !== x && this._(e) : e._$litType$ === void 0 ? e.nodeType === void 0 ? f(e) ? this.k(e) : this._(e) : this.T(e) : this.$(e);
121
+ }
122
+ O(e) {
123
+ return this._$AA.parentNode.insertBefore(e, this._$AB);
124
+ }
125
+ T(e) {
126
+ this._$AH !== e && (this._$AR(), this._$AH = this.O(e));
127
+ }
128
+ _(e) {
129
+ this._$AH !== S && u(this._$AH) ? this._$AA.nextSibling.data = e : this.T(c.createTextNode(e)), this._$AH = e;
130
+ }
131
+ $(e) {
132
+ let { values: t, _$litType$: n } = e, r = typeof n == "number" ? this._$AC(e) : (n.el === void 0 && (n.el = D.createElement(T(n.h, n.h[0]), this.options)), n);
133
+ if (this._$AH?._$AD === r) this._$AH.p(t);
134
+ else {
135
+ let e = new k(r, this), n = e.u(this.options);
136
+ e.p(t), this.T(n), this._$AH = e;
137
+ }
138
+ }
139
+ _$AC(e) {
140
+ let t = C.get(e.strings);
141
+ return t === void 0 && C.set(e.strings, t = new D(e)), t;
142
+ }
143
+ k(t) {
144
+ d(this._$AH) || (this._$AH = [], this._$AR());
145
+ let n = this._$AH, r, i = 0;
146
+ for (let a of t) i === n.length ? n.push(r = new e(this.O(l()), this.O(l()), this, this.options)) : r = n[i], r._$AI(a), i++;
147
+ i < n.length && (this._$AR(r && r._$AB.nextSibling, i), n.length = i);
148
+ }
149
+ _$AR(e = this._$AA.nextSibling, n) {
150
+ for (this._$AP?.(!1, !0, n); e !== this._$AB;) {
151
+ let n = t(e).nextSibling;
152
+ t(e).remove(), e = n;
153
+ }
154
+ }
155
+ setConnected(e) {
156
+ this._$AM === void 0 && (this._$Cv = e, this._$AP?.(e));
157
+ }
158
+ }, j = class {
159
+ get tagName() {
160
+ return this.element.tagName;
161
+ }
162
+ get _$AU() {
163
+ return this._$AM._$AU;
164
+ }
165
+ constructor(e, t, n, r, i) {
166
+ this.type = 1, this._$AH = S, this._$AN = void 0, this.element = e, this.name = t, this._$AM = r, this.options = i, n.length > 2 || n[0] !== "" || n[1] !== "" ? (this._$AH = Array(n.length - 1).fill(/* @__PURE__ */ new String()), this.strings = n) : this._$AH = S;
167
+ }
168
+ _$AI(e, t = this, n, r) {
169
+ let i = this.strings, a = !1;
170
+ if (i === void 0) e = O(this, e, t, 0), a = !u(e) || e !== this._$AH && e !== x, a && (this._$AH = e);
171
+ else {
172
+ let r = e, o, s;
173
+ for (e = i[0], o = 0; o < i.length - 1; o++) s = O(this, r[n + o], t, o), s === x && (s = this._$AH[o]), a ||= !u(s) || s !== this._$AH[o], s === S ? e = S : e !== S && (e += (s ?? "") + i[o + 1]), this._$AH[o] = s;
174
+ }
175
+ a && !r && this.j(e);
176
+ }
177
+ j(e) {
178
+ e === S ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, e ?? "");
179
+ }
180
+ }, M = class extends j {
181
+ constructor() {
182
+ super(...arguments), this.type = 3;
183
+ }
184
+ j(e) {
185
+ this.element[this.name] = e === S ? void 0 : e;
186
+ }
187
+ }, N = class extends j {
188
+ constructor() {
189
+ super(...arguments), this.type = 4;
190
+ }
191
+ j(e) {
192
+ this.element.toggleAttribute(this.name, !!e && e !== S);
193
+ }
194
+ }, P = class extends j {
195
+ constructor(e, t, n, r, i) {
196
+ super(e, t, n, r, i), this.type = 5;
197
+ }
198
+ _$AI(e, t = this) {
199
+ if ((e = O(this, e, t, 0) ?? S) === x) return;
200
+ let n = this._$AH, r = e === S && n !== S || e.capture !== n.capture || e.once !== n.once || e.passive !== n.passive, i = e !== S && (n === S || r);
201
+ r && this.element.removeEventListener(this.name, this, n), i && this.element.addEventListener(this.name, this, e), this._$AH = e;
202
+ }
203
+ handleEvent(e) {
204
+ typeof this._$AH == "function" ? this._$AH.call(this.options?.host ?? this.element, e) : this._$AH.handleEvent(e);
205
+ }
206
+ }, F = class {
207
+ constructor(e, t, n) {
208
+ this.element = e, this.type = 6, this._$AN = void 0, this._$AM = t, this.options = n;
209
+ }
210
+ get _$AU() {
211
+ return this._$AM._$AU;
212
+ }
213
+ _$AI(e) {
214
+ O(this, e);
215
+ }
216
+ }, I = {
217
+ M: i,
218
+ P: a,
219
+ A: o,
220
+ C: 1,
221
+ L: E,
222
+ R: k,
223
+ D: f,
224
+ V: O,
225
+ I: A,
226
+ H: j,
227
+ N,
228
+ U: P,
229
+ B: M,
230
+ F
231
+ }, L = e.litHtmlPolyfillSupport;
232
+ L?.(D, A), (e.litHtmlVersions ??= []).push("3.3.3");
233
+ //#endregion
234
+ export { S as A, I as j };
@@ -0,0 +1,58 @@
1
+ import type { TemplateResult } from 'lit';
2
+ import React from 'react';
3
+ import { type RekeTable, type RowKey, type TableColumn, type TableRow } from '../components/reke-table/reke-table.js';
4
+ export interface ReactTableColumn<TRow extends TableRow = TableRow> extends Omit<TableColumn, 'render'> {
5
+ /**
6
+ * Cell renderer. Return any of:
7
+ * - `ReactNode` (JSX) — bridged via React root, returned to Lit as a raw DOM node
8
+ * - `Node` / `HTMLElement` — passed through (escape hatch for hand-built DOM)
9
+ * - `string` / `TemplateResult` — passed through (Lit-native)
10
+ */
11
+ render?: (value: unknown, row: TRow, index: number) => React.ReactNode | TemplateResult | string | Node;
12
+ }
13
+ /** Expanded-row renderer. Return any `React.ReactNode`. */
14
+ export type ReactExpandedRowRenderer<TRow extends TableRow = TableRow> = (row: TRow, key: RowKey) => React.ReactNode;
15
+ export interface TableProps<TRow extends TableRow = TableRow> {
16
+ columns: ReactTableColumn<TRow>[];
17
+ rows: TRow[];
18
+ striped?: boolean;
19
+ dense?: boolean;
20
+ hoverable?: boolean;
21
+ bordered?: boolean;
22
+ borderless?: boolean;
23
+ /** Opt-in: render a leading chevron column with built-in a11y + keyboard activation. */
24
+ expandable?: boolean;
25
+ /** Opt-in: clicking a row toggles expand. The chevron, if present, calls `stopPropagation()`. */
26
+ expandOnRowClick?: boolean;
27
+ sortKey?: string;
28
+ sortDirection?: 'asc' | 'desc';
29
+ expandedRowRender?: ReactExpandedRowRenderer<TRow>;
30
+ expandedRows?: Set<RowKey>;
31
+ /**
32
+ * Returns a stable identifier for a row. Defaults to the row index (which
33
+ * causes remounts on sort). Prefer a domain id (e.g. `r => r.id`) so the
34
+ * expanded React root survives sorts, filters, and unrelated re-renders.
35
+ */
36
+ getRowKey?: (row: TRow, index: number) => RowKey;
37
+ onRekeRowClick?: (e: CustomEvent<{
38
+ row: unknown;
39
+ index: number;
40
+ }>) => void;
41
+ onRekeSort?: (e: CustomEvent<{
42
+ key: string;
43
+ direction: 'asc' | 'desc';
44
+ }>) => void;
45
+ onRekeRowExpand?: (e: CustomEvent<{
46
+ row: unknown;
47
+ index: number;
48
+ key: RowKey;
49
+ expanded: boolean;
50
+ }>) => void;
51
+ children?: React.ReactNode;
52
+ }
53
+ export declare const Table: <TRow extends TableRow = TableRow>(props: TableProps<TRow> & {
54
+ ref?: React.Ref<RekeTable>;
55
+ }) => React.ReactElement;
56
+ export type { Cleanup, ExpandedRowElement, GetRowKey, RowKey, TableColumn, TableRow, } from '../components/reke-table/reke-table.js';
57
+ export { RekeTable } from '../components/reke-table/reke-table.js';
58
+ //# sourceMappingURL=table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table.d.ts","sourceRoot":"","sources":["../../src/react-bridge/table.ts"],"names":[],"mappings":"AAYA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1C,OAAO,KAAqC,MAAM,OAAO,CAAC;AAG1D,OAAO,EAEL,KAAK,SAAS,EAEd,KAAK,MAAM,EACX,KAAK,WAAW,EAChB,KAAK,QAAQ,EACd,MAAM,wCAAwC,CAAC;AAehD,MAAM,WAAW,gBAAgB,CAAC,IAAI,SAAS,QAAQ,GAAG,QAAQ,CAChE,SAAQ,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC;IACnC;;;;;OAKG;IACH,MAAM,CAAC,EAAE,CACP,KAAK,EAAE,OAAO,EACd,GAAG,EAAE,IAAI,EACT,KAAK,EAAE,MAAM,KACV,KAAK,CAAC,SAAS,GAAG,cAAc,GAAG,MAAM,GAAG,IAAI,CAAC;CACvD;AAED,2DAA2D;AAC3D,MAAM,MAAM,wBAAwB,CAAC,IAAI,SAAS,QAAQ,GAAG,QAAQ,IAAI,CACvE,GAAG,EAAE,IAAI,EACT,GAAG,EAAE,MAAM,KACR,KAAK,CAAC,SAAS,CAAC;AAErB,MAAM,WAAW,UAAU,CAAC,IAAI,SAAS,QAAQ,GAAG,QAAQ;IAC1D,OAAO,EAAE,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC;IAClC,IAAI,EAAE,IAAI,EAAE,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,wFAAwF;IACxF,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iGAAiG;IACjG,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC;IAC/B,iBAAiB,CAAC,EAAE,wBAAwB,CAAC,IAAI,CAAC,CAAC;IACnD,YAAY,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAC3B;;;;OAIG;IACH,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACjD,cAAc,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,CAAC;QAAE,GAAG,EAAE,OAAO,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,KAAK,IAAI,CAAC;IAC3E,UAAU,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,CAAC;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,KAAK,GAAG,MAAM,CAAA;KAAE,CAAC,KAAK,IAAI,CAAC;IAClF,eAAe,CAAC,EAAE,CAChB,CAAC,EAAE,WAAW,CAAC;QAAE,GAAG,EAAE,OAAO,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE,CAAC,KAC5E,IAAI,CAAC;IACV,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B;AAuMD,eAAO,MAAM,KAAK,EAAmC,CAAC,IAAI,SAAS,QAAQ,GAAG,QAAQ,EACpF,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,GAAG;IAAE,GAAG,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;CAAE,KACrD,KAAK,CAAC,YAAY,CAAC;AAExB,YAAY,EACV,OAAO,EACP,kBAAkB,EAClB,SAAS,EACT,MAAM,EACN,WAAW,EACX,QAAQ,GACT,MAAM,wCAAwC,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,wCAAwC,CAAC"}
@@ -0,0 +1,115 @@
1
+ import { RekeTable as e } from "../components/reke-table/reke-table.js";
2
+ import { createComponent as t } from "@lit/react";
3
+ import n, { useEffect as r, useMemo as i, useRef as a } from "react";
4
+ import { flushSync as o } from "react-dom";
5
+ import { createRoot as s } from "react-dom/client";
6
+ //#region src/react-bridge/table.ts
7
+ var c = t({
8
+ tagName: "reke-table",
9
+ elementClass: e,
10
+ react: n,
11
+ events: {
12
+ onRekeRowClick: "reke-row-click",
13
+ onRekeSort: "reke-sort",
14
+ onRekeRowExpand: "reke-row-expand"
15
+ }
16
+ });
17
+ function l(e) {
18
+ return e == null || typeof e == "string" || typeof e == "number" || e instanceof Node;
19
+ }
20
+ function u(e, t) {
21
+ try {
22
+ o(() => {
23
+ e.render(t);
24
+ });
25
+ } catch {
26
+ e.render(t);
27
+ }
28
+ }
29
+ function d(e) {
30
+ try {
31
+ e.unmount();
32
+ } catch {}
33
+ }
34
+ function f(e, t) {
35
+ let { columns: o, rows: f, expandedRowRender: p, getRowKey: m, children: h, ...g } = e, _ = a(/* @__PURE__ */ new Map()), v = a(/* @__PURE__ */ new Set()), y = a(/* @__PURE__ */ new Map()), b = a(p);
36
+ b.current = p, r(() => {
37
+ if (!p) return;
38
+ let e = y.current;
39
+ for (let [t, n] of e) {
40
+ let e;
41
+ for (let n = 0; n < f.length; n += 1) {
42
+ let r = f[n];
43
+ if (String(m ? m(r, n) : n) === t) {
44
+ e = r;
45
+ break;
46
+ }
47
+ }
48
+ if (!e) continue;
49
+ let r = p(e, t);
50
+ l(r) || u(n, r);
51
+ }
52
+ }), r(() => {
53
+ let e = _.current, t = y.current;
54
+ return () => {
55
+ for (let { root: t } of e.values()) d(t);
56
+ e.clear();
57
+ for (let e of t.values()) d(e);
58
+ t.clear();
59
+ };
60
+ }, []);
61
+ let x = (e, t) => String(m ? m(e, t) : t), S = (e) => {
62
+ let t = _.current.get(e);
63
+ if (!t) {
64
+ let n = document.createElement("div");
65
+ n.style.cssText = "display: contents;", t = {
66
+ root: s(n),
67
+ host: n
68
+ }, _.current.set(e, t);
69
+ }
70
+ return v.current.add(e), t;
71
+ };
72
+ v.current = /* @__PURE__ */ new Set();
73
+ let C = i(() => o.map((e) => e.render ? {
74
+ ...e,
75
+ render: (t, n, r) => {
76
+ let i = e.render?.(t, n, r);
77
+ if (l(i)) return i ?? "";
78
+ let a = S(`${x(n, r)}::cell::${e.key}`);
79
+ return u(a.root, i), a.host;
80
+ }
81
+ } : e), [o, m]), w = i(() => {
82
+ if (p) return (e, t, n) => {
83
+ let r = b.current;
84
+ if (!r) return;
85
+ let i = String(n), a = y.current.get(i);
86
+ a || (a = s(e), y.current.set(i, a));
87
+ let o = r(t, n);
88
+ if (!l(o)) u(a, o);
89
+ else if (o instanceof Node) return e.appendChild(o), () => {
90
+ o.parentNode === e && e.removeChild(o);
91
+ };
92
+ else if (typeof o == "string" || typeof o == "number") return e.textContent = String(o), () => {
93
+ e.textContent = "";
94
+ };
95
+ return () => {
96
+ let e = y.current.get(i);
97
+ e && (d(e), y.current.delete(i));
98
+ };
99
+ };
100
+ }, [!!p]);
101
+ return r(() => {
102
+ let e = v.current, t = _.current;
103
+ for (let [n, r] of t) e.has(n) || (d(r.root), t.delete(n));
104
+ }), n.createElement(c, {
105
+ ...g,
106
+ ref: t,
107
+ columns: C,
108
+ rows: f,
109
+ expandedRowElement: w,
110
+ getRowKey: m
111
+ }, h);
112
+ }
113
+ var p = n.forwardRef(f);
114
+ //#endregion
115
+ export { p as Table };
package/dist/react.d.ts CHANGED
@@ -1,20 +1,19 @@
1
1
  import { type EventName } from '@lit/react';
2
- import { RekeButton } from './components/reke-button/reke-button.js';
3
- import { RekeInput } from './components/reke-input/reke-input.js';
4
- import { RekeTextarea } from './components/reke-textarea/reke-textarea.js';
5
- import { RekeCheckbox } from './components/reke-checkbox/reke-checkbox.js';
6
- import { RekeToggle } from './components/reke-toggle/reke-toggle.js';
2
+ import { RekeAlert } from './components/reke-alert/reke-alert.js';
7
3
  import { RekeBadge } from './components/reke-badge/reke-badge.js';
4
+ import { RekeButton } from './components/reke-button/reke-button.js';
8
5
  import { RekeCard } from './components/reke-card/reke-card.js';
9
- import { RekeTooltip } from './components/reke-tooltip/reke-tooltip.js';
10
- import { RekeDialog } from './components/reke-dialog/reke-dialog.js';
11
- import { RekeSelect } from './components/reke-select/reke-select.js';
12
- import { RekeTable } from './components/reke-table/reke-table.js';
6
+ import { RekeCheckbox } from './components/reke-checkbox/reke-checkbox.js';
7
+ import { RekeChip } from './components/reke-chip/reke-chip.js';
13
8
  import { RekeDateRange } from './components/reke-date-range/reke-date-range.js';
9
+ import { RekeDialog } from './components/reke-dialog/reke-dialog.js';
14
10
  import { RekeFileUpload } from './components/reke-file-upload/reke-file-upload.js';
15
- import { RekeAlert } from './components/reke-alert/reke-alert.js';
11
+ import { RekeInput } from './components/reke-input/reke-input.js';
12
+ import { RekeSelect } from './components/reke-select/reke-select.js';
13
+ import { RekeTextarea } from './components/reke-textarea/reke-textarea.js';
16
14
  import { RekeToast } from './components/reke-toast/reke-toast.js';
17
- import { RekeChip } from './components/reke-chip/reke-chip.js';
15
+ import { RekeToggle } from './components/reke-toggle/reke-toggle.js';
16
+ import { RekeTooltip } from './components/reke-tooltip/reke-tooltip.js';
18
17
  export declare const Button: import("@lit/react").ReactWebComponent<RekeButton, {
19
18
  onRekeClick: EventName<CustomEvent>;
20
19
  }>;
@@ -55,21 +54,8 @@ export declare const Select: import("@lit/react").ReactWebComponent<RekeSelect,
55
54
  value: string;
56
55
  }>>;
57
56
  }>;
58
- export declare const Table: import("@lit/react").ReactWebComponent<RekeTable, {
59
- onRekeRowClick: EventName<CustomEvent<{
60
- row: unknown;
61
- index: number;
62
- }>>;
63
- onRekeSort: EventName<CustomEvent<{
64
- key: string;
65
- direction: "asc" | "desc";
66
- }>>;
67
- onRekeRowExpand: EventName<CustomEvent<{
68
- row: unknown;
69
- index: number;
70
- expanded: boolean;
71
- }>>;
72
- }>;
57
+ export type { ReactExpandedRowRenderer, ReactTableColumn, TableColumn, TableProps, TableRow, } from './react-bridge/table.js';
58
+ export { Table } from './react-bridge/table.js';
73
59
  export declare const DateRange: import("@lit/react").ReactWebComponent<RekeDateRange, {
74
60
  onRekeChange: EventName<CustomEvent<{
75
61
  from: string;
@@ -1 +1 @@
1
- {"version":3,"file":"react.d.ts","sourceRoot":"","sources":["../src/react.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"react.d.ts","sourceRoot":"","sources":["../src/react.ts"],"names":[],"mappings":"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"}