@melodicdev/components 1.6.1 → 1.6.3
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/README.md +6 -0
- package/assets/melodic-components.js +21 -6
- package/assets/melodic-components.js.map +1 -1
- package/assets/melodic-components.min.js +21 -6
- package/lib/components/data-display/table/table.styles.d.ts.map +1 -1
- package/lib/components/data-display/table/table.styles.js +14 -4
- package/lib/components/data-display/table/table.template.d.ts.map +1 -1
- package/lib/components/data-display/table/table.template.js +7 -2
- package/lib/components/forms/date-time-picker/date-time-picker.component.d.ts +81 -9
- package/lib/components/forms/date-time-picker/date-time-picker.component.d.ts.map +1 -1
- package/lib/components/forms/date-time-picker/date-time-picker.component.js +163 -26
- package/lib/components/forms/date-time-picker/date-time-picker.styles.d.ts.map +1 -1
- package/lib/components/forms/date-time-picker/date-time-picker.styles.js +32 -0
- package/lib/components/forms/date-time-picker/date-time-picker.template.d.ts.map +1 -1
- package/lib/components/forms/date-time-picker/date-time-picker.template.js +8 -0
- package/lib/components/forms/date-time-picker/tz-utils.d.ts +61 -0
- package/lib/components/forms/date-time-picker/tz-utils.d.ts.map +1 -0
- package/lib/components/forms/date-time-picker/tz-utils.js +145 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -231,6 +231,12 @@ type ThemeMode = 'light' | 'dark' | 'system';
|
|
|
231
231
|
|
|
232
232
|
---
|
|
233
233
|
|
|
234
|
+
## Working with timezones
|
|
235
|
+
|
|
236
|
+
For datetime fields that need to round-trip a real UTC instant — multi-tenant SaaS, calendar/scheduling apps, anything stored as UTC server-side — use [`<ml-date-time-picker>`](./docs/components/forms.md#ml-date-time-picker) with its `timezone` attribute. The picker anchors the wall-clock the user types to the named IANA zone, surfaces a `valueUtc` field on the `ml:change` event detail, and renders a trailing zone label so users know what zone they're entering. Without `timezone`, the component is a plain naive datetime input — no behavior change for existing consumers. Elsewhere in the app, the right primitive for displaying the same instant in another zone is `Intl.DateTimeFormat(..., { timeZone })`.
|
|
237
|
+
|
|
238
|
+
---
|
|
239
|
+
|
|
234
240
|
## Theme System
|
|
235
241
|
|
|
236
242
|
Override tokens globally via CSS:
|
|
@@ -13593,6 +13593,7 @@ function tableTemplate(c) {
|
|
|
13593
13593
|
`)}
|
|
13594
13594
|
${repeat(c.columns, (col) => col.key, (col) => html`
|
|
13595
13595
|
<th
|
|
13596
|
+
part="header-cell"
|
|
13596
13597
|
class=${classMap({
|
|
13597
13598
|
"ml-table__th": true,
|
|
13598
13599
|
"ml-table__th--sortable": !!col.sortable,
|
|
@@ -13625,6 +13626,7 @@ function tableTemplate(c) {
|
|
|
13625
13626
|
const absoluteIndex = c.startIndex + i;
|
|
13626
13627
|
return html`
|
|
13627
13628
|
<tr
|
|
13629
|
+
part="row"
|
|
13628
13630
|
class=${classMap({
|
|
13629
13631
|
"ml-table__row": true,
|
|
13630
13632
|
"ml-table__row--selected": c.isRowSelected(absoluteIndex)
|
|
@@ -13644,10 +13646,13 @@ function tableTemplate(c) {
|
|
|
13644
13646
|
</td>
|
|
13645
13647
|
`)}
|
|
13646
13648
|
${repeat(c.columns, (col) => col.key, (col) => html`
|
|
13647
|
-
<td
|
|
13649
|
+
<td
|
|
13650
|
+
part="cell"
|
|
13651
|
+
class=${classMap({
|
|
13648
13652
|
"ml-table__td": true,
|
|
13649
13653
|
[`ml-table__td--${col.align ?? "left"}`]: true
|
|
13650
|
-
})}
|
|
13654
|
+
})}
|
|
13655
|
+
>
|
|
13651
13656
|
${renderCell$1(col, row, absoluteIndex)}
|
|
13652
13657
|
</td>
|
|
13653
13658
|
`)}
|
|
@@ -13720,6 +13725,16 @@ const tableStyles = () => css`
|
|
|
13720
13725
|
|
|
13721
13726
|
/* ── Table: cells ── */
|
|
13722
13727
|
--ml-table-cell-color: var(--ml-color-text);
|
|
13728
|
+
--ml-table-cell-padding-y: var(--ml-space-4);
|
|
13729
|
+
--ml-table-cell-padding-x: var(--ml-space-6);
|
|
13730
|
+
--ml-table-cell-padding-y-sm: var(--ml-space-2-5);
|
|
13731
|
+
--ml-table-cell-padding-x-sm: var(--ml-space-4);
|
|
13732
|
+
|
|
13733
|
+
/* ── Table: header cells ── */
|
|
13734
|
+
--ml-table-header-padding-y: var(--ml-space-3);
|
|
13735
|
+
--ml-table-header-padding-x: var(--ml-space-6);
|
|
13736
|
+
--ml-table-header-padding-y-sm: var(--ml-space-2);
|
|
13737
|
+
--ml-table-header-padding-x-sm: var(--ml-space-4);
|
|
13723
13738
|
|
|
13724
13739
|
/* ── Table: checkbox ── */
|
|
13725
13740
|
--ml-table-checkbox-accent: var(--ml-color-primary);
|
|
@@ -13791,7 +13806,7 @@ const tableStyles = () => css`
|
|
|
13791
13806
|
}
|
|
13792
13807
|
|
|
13793
13808
|
.ml-table__th {
|
|
13794
|
-
padding: var(--ml-
|
|
13809
|
+
padding: var(--ml-table-header-padding-y) var(--ml-table-header-padding-x);
|
|
13795
13810
|
font-size: var(--ml-text-xs);
|
|
13796
13811
|
font-weight: var(--ml-font-medium);
|
|
13797
13812
|
color: var(--ml-table-header-color);
|
|
@@ -13803,7 +13818,7 @@ const tableStyles = () => css`
|
|
|
13803
13818
|
}
|
|
13804
13819
|
|
|
13805
13820
|
.ml-table--sm .ml-table__th {
|
|
13806
|
-
padding: var(--ml-
|
|
13821
|
+
padding: var(--ml-table-header-padding-y-sm) var(--ml-table-header-padding-x-sm);
|
|
13807
13822
|
}
|
|
13808
13823
|
|
|
13809
13824
|
.ml-table__th--center { text-align: center; }
|
|
@@ -13881,14 +13896,14 @@ const tableStyles = () => css`
|
|
|
13881
13896
|
|
|
13882
13897
|
/* ── Body cells ── */
|
|
13883
13898
|
.ml-table__td {
|
|
13884
|
-
padding: var(--ml-
|
|
13899
|
+
padding: var(--ml-table-cell-padding-y) var(--ml-table-cell-padding-x);
|
|
13885
13900
|
font-size: var(--ml-text-sm);
|
|
13886
13901
|
color: var(--ml-table-cell-color);
|
|
13887
13902
|
vertical-align: middle;
|
|
13888
13903
|
}
|
|
13889
13904
|
|
|
13890
13905
|
.ml-table--sm .ml-table__td {
|
|
13891
|
-
padding: var(--ml-
|
|
13906
|
+
padding: var(--ml-table-cell-padding-y-sm) var(--ml-table-cell-padding-x-sm);
|
|
13892
13907
|
font-size: var(--ml-text-xs);
|
|
13893
13908
|
}
|
|
13894
13909
|
|