@onereach/ui-components-vue2 26.4.1-beta.5879.0 → 26.4.1-beta.5881.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.
@@ -206,6 +206,8 @@ const DataGridTableContentCell = [
206
206
  'theme-border-transparent border-1', 'dark:theme-border-transparent-dark', 'theme-outline-transparent outline-2 -outline-offset-1', 'dark:theme-outline-transparent-dark',
207
207
  // Theme (focus)
208
208
  'focus-within:theme-border-primary', 'dark:focus-within:theme-border-primary-dark', 'focus-within:theme-outline-primary', 'dark:focus-within:theme-outline-primary-dark',
209
+ // Theme (Stacking)
210
+ 'relative',
209
211
  // Theme (.sticky-start)
210
212
  '[&.sticky-start]:theme-background-default [&.sticky-start]:border-e-disabled [&.sticky-start]:border-solid', 'dark:[&.sticky-start]:theme-background-default-dark dark:[&.sticky-start]:border-e-disabled-dark', 'hover:[&.sticky-start]:theme-background-surface-1 dark:hover:[&.sticky-start]:theme-background-surface-1-dark', 'selected:[&.sticky-start]:theme-background-surface-2 dark:selected:[&.sticky-start]:theme-background-surface-2-dark', 'hover:selected:[&.sticky-start]:theme-background-surface-3 dark:hover:selected:[&.sticky-start]:theme-background-surface-3-dark',
211
213
  // Theme (.sticky-end)
@@ -256,6 +258,10 @@ var script$e = defineComponent({
256
258
  override: {
257
259
  type: Boolean,
258
260
  default: false
261
+ },
262
+ stickyOffset: {
263
+ type: Number,
264
+ default: 0
259
265
  }
260
266
  },
261
267
  emits: ['input'],
@@ -265,7 +271,7 @@ var script$e = defineComponent({
265
271
  const root = ref();
266
272
  const rootStyles = computed(() => {
267
273
  var _a, _b, _c, _d;
268
- return ['or-data-grid-table-content-cell-v3', ...DataGridTableContentCell, ...(((_a = props.column) === null || _a === void 0 ? void 0 : _a.stickiness) ? [`sticky-${props.column.stickiness}`] : []), ...(!!((_b = props.features) === null || _b === void 0 ? void 0 : _b.resizing) && !!((_c = props.column) === null || _c === void 0 ? void 0 : _c.name) && ((_d = props.column) === null || _d === void 0 ? void 0 : _d.resizing) !== false ? ['resizable'] : [])];
274
+ return ['or-data-grid-table-content-cell-v3', ...DataGridTableContentCell, ...(((_a = props.column) === null || _a === void 0 ? void 0 : _a.stickiness) ? [`sticky-${props.column.stickiness}`, 'overflow-hidden'] : []), ...(!!((_b = props.features) === null || _b === void 0 ? void 0 : _b.resizing) && !!((_c = props.column) === null || _c === void 0 ? void 0 : _c.name) && ((_d = props.column) === null || _d === void 0 ? void 0 : _d.resizing) !== false ? ['resizable'] : [])];
269
275
  });
270
276
  const rootInlineStyles = computed(() => {
271
277
  if (props.column) {
@@ -273,14 +279,16 @@ var script$e = defineComponent({
273
279
  case 'start':
274
280
  return {
275
281
  position: 'sticky',
276
- insetInlineStart: '0',
282
+ insetInlineStart: `${props.stickyOffset}px`,
283
+ zIndex: '30',
277
284
  flexDirection: props.column.alignment === 'end' ? 'row-reverse' : undefined,
278
285
  justifyContent: props.column.alignment
279
286
  };
280
287
  case 'end':
281
288
  return {
282
289
  position: 'sticky',
283
- insetInlineEnd: '0',
290
+ insetInlineEnd: `${props.stickyOffset}px`,
291
+ zIndex: '30',
284
292
  flexDirection: props.column.alignment === 'end' ? 'row-reverse' : undefined,
285
293
  justifyContent: props.column.alignment
286
294
  };
@@ -296,9 +304,11 @@ var script$e = defineComponent({
296
304
  };
297
305
  });
298
306
  const contentStyles = computed(() => {
299
- var _a, _b, _c;
307
+ var _a, _b, _c, _d, _e, _f;
300
308
  const isWrapping = (_b = (_a = props.column) === null || _a === void 0 ? void 0 : _a.wrapping) !== null && _b !== void 0 ? _b : props.variant === DataGridVariant.Dynamic && !((_c = props.column) === null || _c === void 0 ? void 0 : _c.control);
301
- return [...DataGridTableContentCellContent.filter(style => style !== 'truncate'), ...(isWrapping ? ['whitespace-pre-wrap break-words'] : ['truncate'])];
309
+ const isSticky = !!((_d = props.column) === null || _d === void 0 ? void 0 : _d.stickiness);
310
+ const isTags = ((_f = (_e = props.column) === null || _e === void 0 ? void 0 : _e.control) === null || _f === void 0 ? void 0 : _f.type) === 'tags';
311
+ return ['layout-row items-center w-full min-w-0', ...(isSticky || isTags ? ['overflow-hidden'] : []), ...DataGridTableContentCellContent.filter(style => style !== 'truncate'), ...(isWrapping ? ['whitespace-pre-wrap break-words'] : ['truncate'])];
302
312
  });
303
313
  const contentInlineStyles = computed(() => ({
304
314
  minWidth: props.column && props.column.minWidth || DATA_GRID_DEFAULT_MIN_WIDTH,
@@ -340,7 +350,10 @@ var __vue_render__$e = function () {
340
350
  ref: 'root',
341
351
  class: _vm.rootStyles,
342
352
  style: _vm.rootInlineStyles
343
- }, [_vm.override ? [_vm._t("default")] : _vm.control ? [_vm.control.type === 'text' ? [_c('OrInput', {
353
+ }, [_vm.override ? [_vm._t("default")] : _vm.control ? [_c('div', {
354
+ class: _vm.contentStyles,
355
+ style: _vm.contentInlineStyles
356
+ }, [_vm.control.type === 'text' ? [_c('OrInput', {
344
357
  attrs: {
345
358
  "type": 'text',
346
359
  "variant": 'embedded'
@@ -438,6 +451,7 @@ var __vue_render__$e = function () {
438
451
  expression: "model"
439
452
  }
440
453
  })] : _vm._e(), _vm._v(" "), _vm.control.type === 'tags' ? [_c('OrTagInput', {
454
+ class: ['grow min-w-0'],
441
455
  attrs: {
442
456
  "variant": 'embedded'
443
457
  },
@@ -448,7 +462,7 @@ var __vue_render__$e = function () {
448
462
  },
449
463
  expression: "model"
450
464
  }
451
- })] : _vm._e()] : [_c('div', {
465
+ })] : _vm._e()], 2)] : [_c('div', {
452
466
  class: _vm.contentStyles,
453
467
  style: _vm.contentInlineStyles
454
468
  }, [_vm._t("default")], 2)]], 2);
@@ -478,6 +492,8 @@ var __vue_component__$t = __vue_component__$s;
478
492
  const DataGridTableContentRow = [
479
493
  // Layout
480
494
  'grid grid-cols-[subgrid] col-span-full',
495
+ // Stacking context
496
+ 'relative z-[1]',
481
497
  // Typography
482
498
  'typography-body-2-regular',
483
499
  // Theme
@@ -821,11 +837,11 @@ const DataGridTableHeaderCell = [
821
837
  // Theme
822
838
  'theme-border-transparent border-1', 'dark:theme-border-transparent-dark', 'theme-outline-transparent outline-2 -outline-offset-1', 'dark:theme-outline-transparent-dark',
823
839
  // Theme (Stacking)
824
- 'relative z-1 hover:z-2',
840
+ 'relative hover:z-[2]',
825
841
  // Theme (.sticky-start)
826
- '[&.sticky-start]:theme-background-surface-variant-1 [&.sticky-start]:border-e-disabled [&.sticky-start]:border-solid z-20 hover:z-30', 'dark:[&.sticky-start]:theme-background-surface-variant-1-dark dark:[&.sticky-start]:border-e-disabled-dark',
842
+ '[&.sticky-start]:theme-background-surface-variant-1 [&.sticky-start]:border-e-disabled [&.sticky-start]:border-solid', 'dark:[&.sticky-start]:theme-background-surface-variant-1-dark dark:[&.sticky-start]:border-e-disabled-dark',
827
843
  // Theme (.sticky-end)
828
- '[&.sticky-end]:theme-background-surface-variant-1 [&.sticky-end]:border-s-disabled [&.sticky-end]:border-solid z-20 hover:z-30', 'dark:[&.sticky-end]:theme-background-surface-variant-1-dark dark:[&.sticky-end]:border-s-disabled-dark',
844
+ '[&.sticky-end]:theme-background-surface-variant-1 [&.sticky-end]:border-s-disabled [&.sticky-end]:border-solid', 'dark:[&.sticky-end]:theme-background-surface-variant-1-dark dark:[&.sticky-end]:border-s-disabled-dark',
829
845
  // Theme (.resizable)
830
846
  '[&.resizable]:border-e-disabled [&.resizable]:border-solid', 'dark:[&.resizable]:border-e-disabled-dark'];
831
847
  const DataGridTableHeaderCellResizeHandle = [
@@ -857,6 +873,10 @@ var script$8 = defineComponent({
857
873
  features: {
858
874
  type: Object,
859
875
  default: undefined
876
+ },
877
+ stickyOffset: {
878
+ type: Number,
879
+ default: 0
860
880
  }
861
881
  },
862
882
  emits: ['update:modelValue', 'update:scrollOffset', 'remove:scrollOffset', 'update:column-width'],
@@ -875,7 +895,7 @@ var script$8 = defineComponent({
875
895
  });
876
896
  const rootStyles = computed(() => {
877
897
  var _a;
878
- return ['or-data-grid-table-header-cell-v3', 'relative', ...DataGridTableHeaderCell, ...(((_a = props.column) === null || _a === void 0 ? void 0 : _a.stickiness) ? [`sticky-${props.column.stickiness}`] : []), ...(isResizable.value ? ['resizable'] : []), ...(isSortable.value ? ['interactivity-click'] : [])];
898
+ return ['or-data-grid-table-header-cell-v3', 'relative', ...DataGridTableHeaderCell, ...(((_a = props.column) === null || _a === void 0 ? void 0 : _a.stickiness) ? [`sticky-${props.column.stickiness}`, 'overflow-hidden'] : []), ...(isResizable.value ? ['resizable'] : []), ...(isSortable.value ? ['interactivity-click'] : [])];
879
899
  });
880
900
  const resizeHandleStyles = computed(() => ['or-data-grid-table-header-cell-resize-handle-v3', ...DataGridTableHeaderCellResizeHandle]);
881
901
  const wrapInlineStyle = computed(() => {
@@ -891,14 +911,16 @@ var script$8 = defineComponent({
891
911
  case 'start':
892
912
  return {
893
913
  position: 'sticky',
894
- insetInlineStart: '0',
914
+ insetInlineStart: `${props.stickyOffset}px`,
915
+ zIndex: '120',
895
916
  flexDirection: props.column.alignment === 'end' ? 'row-reverse' : undefined,
896
917
  justifyContent: props.column.alignment
897
918
  };
898
919
  case 'end':
899
920
  return {
900
921
  position: 'sticky',
901
- insetInlineEnd: '0',
922
+ insetInlineEnd: `${props.stickyOffset}px`,
923
+ zIndex: '120',
902
924
  flexDirection: props.column.alignment === 'end' ? 'row-reverse' : undefined,
903
925
  justifyContent: props.column.alignment
904
926
  };
@@ -1066,7 +1088,7 @@ var __vue_component__$h = __vue_component__$g;
1066
1088
 
1067
1089
  const DataGridTableHeaderRow = [
1068
1090
  // Position
1069
- 'sticky top-0 z-10',
1091
+ 'sticky top-0 z-[110]',
1070
1092
  // Layout
1071
1093
  'grid grid-cols-[subgrid] col-span-full',
1072
1094
  // Typography
@@ -1775,8 +1797,6 @@ var script = defineComponent({
1775
1797
  });
1776
1798
  }
1777
1799
  });
1778
- const scrollOffsetStart = ref(new Map());
1779
- const scrollOffsetEnd = ref(new Map());
1780
1800
  const showSelectingCouter = computed(() => {
1781
1801
  return props.features.selecting && (typeof props.features.selecting === 'object' ? props.features.selecting.showCounter !== false : true);
1782
1802
  });
@@ -1794,6 +1814,42 @@ var script = defineComponent({
1794
1814
  width: columnWidths.value[column.name] || column.width
1795
1815
  }));
1796
1816
  });
1817
+ const scrollOffsetStart = ref(new Map());
1818
+ const scrollOffsetEnd = ref(new Map());
1819
+ const stickyOffsets = computed(() => {
1820
+ const start = new Map();
1821
+ const end = new Map();
1822
+ const startColumns = [];
1823
+ const endColumns = [];
1824
+ if (props.features.selecting) {
1825
+ startColumns.push({
1826
+ name: '_check',
1827
+ stickiness: 'start'
1828
+ });
1829
+ }
1830
+ actualColumns.value.forEach(column => {
1831
+ if (column.stickiness === 'start') {
1832
+ startColumns.push(column);
1833
+ } else if (column.stickiness === 'end') {
1834
+ endColumns.push(column);
1835
+ }
1836
+ });
1837
+ let currentStartOffset = 0;
1838
+ startColumns.forEach(column => {
1839
+ start.set(column.name, currentStartOffset);
1840
+ currentStartOffset += scrollOffsetStart.value.get(column.name) || 0;
1841
+ });
1842
+ let currentEndOffset = 0;
1843
+ // End columns are stacked from right to left
1844
+ [...endColumns].reverse().forEach(column => {
1845
+ end.set(column.name, currentEndOffset);
1846
+ currentEndOffset += scrollOffsetEnd.value.get(column.name) || 0;
1847
+ });
1848
+ return {
1849
+ start,
1850
+ end
1851
+ };
1852
+ });
1797
1853
  // Methods
1798
1854
  function updateSearchingModel(value) {
1799
1855
  searchingModel.value = value;
@@ -1801,19 +1857,19 @@ var script = defineComponent({
1801
1857
  function updateScrollOffset(header, offset, column) {
1802
1858
  switch (column.stickiness) {
1803
1859
  case 'start':
1804
- scrollOffsetStart.value.set(header, offset);
1860
+ scrollOffsetStart.value.set(column.name, offset);
1805
1861
  scrollOffsetStart.value = new Map(scrollOffsetStart.value);
1806
- scrollOffsetEnd.value.delete(header);
1862
+ scrollOffsetEnd.value.delete(column.name);
1807
1863
  scrollOffsetEnd.value = new Map(scrollOffsetEnd.value);
1808
1864
  break;
1809
1865
  case 'end':
1810
- scrollOffsetStart.value.delete(header);
1866
+ scrollOffsetStart.value.delete(column.name);
1811
1867
  scrollOffsetStart.value = new Map(scrollOffsetStart.value);
1812
- scrollOffsetEnd.value.set(header, offset);
1868
+ scrollOffsetEnd.value.set(column.name, offset);
1813
1869
  scrollOffsetEnd.value = new Map(scrollOffsetEnd.value);
1814
1870
  break;
1815
1871
  default:
1816
- removeScrollOffset(header);
1872
+ removeScrollOffset(column.name);
1817
1873
  break;
1818
1874
  }
1819
1875
  }
@@ -1883,10 +1939,10 @@ var script = defineComponent({
1883
1939
  // if (!props.interactiveRows) return;
1884
1940
  // context.emit('click:cell', { item, columnName, value });
1885
1941
  // }
1886
- function removeScrollOffset(header) {
1887
- scrollOffsetStart.value.delete(header);
1942
+ function removeScrollOffset(name) {
1943
+ scrollOffsetStart.value.delete(name);
1888
1944
  scrollOffsetStart.value = new Map(scrollOffsetStart.value);
1889
- scrollOffsetEnd.value.delete(header);
1945
+ scrollOffsetEnd.value.delete(name);
1890
1946
  scrollOffsetEnd.value = new Map(scrollOffsetEnd.value);
1891
1947
  }
1892
1948
  // Helpers
@@ -1916,6 +1972,7 @@ var script = defineComponent({
1916
1972
  searchingModel,
1917
1973
  sortingModel,
1918
1974
  pagingModel,
1975
+ stickyOffsets,
1919
1976
  updateScrollOffset,
1920
1977
  removeScrollOffset,
1921
1978
  updateSearchingModel,
@@ -2002,8 +2059,10 @@ var __vue_render__ = function () {
2002
2059
  staticClass: "md:!py-none",
2003
2060
  attrs: {
2004
2061
  "column": {
2062
+ name: '_check',
2005
2063
  stickiness: 'start'
2006
- }
2064
+ },
2065
+ "sticky-offset": _vm.stickyOffsets.start.get('_check')
2007
2066
  },
2008
2067
  on: {
2009
2068
  "update:scroll-offset": _vm.updateScrollOffset,
@@ -2026,7 +2085,8 @@ var __vue_render__ = function () {
2026
2085
  key: column.name,
2027
2086
  attrs: {
2028
2087
  "column": column,
2029
- "features": _vm.features
2088
+ "features": _vm.features,
2089
+ "sticky-offset": column.stickiness === 'start' ? _vm.stickyOffsets.start.get(column.name) : column.stickiness === 'end' ? _vm.stickyOffsets.end.get(column.name) : undefined
2030
2090
  },
2031
2091
  on: {
2032
2092
  "update:scroll-offset": _vm.updateScrollOffset,
@@ -2075,8 +2135,10 @@ var __vue_render__ = function () {
2075
2135
  }, [_vm.features.selecting ? [_c('OrDataGridTableContentCell', {
2076
2136
  attrs: {
2077
2137
  "column": {
2138
+ name: '_check',
2078
2139
  stickiness: 'start'
2079
2140
  },
2141
+ "sticky-offset": _vm.stickyOffsets.start.get('_check'),
2080
2142
  "variant": _vm.variant,
2081
2143
  "override": true
2082
2144
  }
@@ -2086,6 +2148,7 @@ var __vue_render__ = function () {
2086
2148
  attrs: {
2087
2149
  "column": column,
2088
2150
  "features": _vm.features,
2151
+ "sticky-offset": column.stickiness === 'start' ? _vm.stickyOffsets.start.get(column.name) : column.stickiness === 'end' ? _vm.stickyOffsets.end.get(column.name) : undefined,
2089
2152
  "variant": _vm.variant,
2090
2153
  "override": true
2091
2154
  }
@@ -2118,8 +2181,10 @@ var __vue_render__ = function () {
2118
2181
  staticClass: "md:!py-none",
2119
2182
  attrs: {
2120
2183
  "column": {
2184
+ name: '_check',
2121
2185
  stickiness: 'start'
2122
2186
  },
2187
+ "sticky-offset": _vm.stickyOffsets.start.get('_check'),
2123
2188
  "variant": _vm.variant,
2124
2189
  "override": true,
2125
2190
  "force-state": 'none'
@@ -2151,6 +2216,7 @@ var __vue_render__ = function () {
2151
2216
  "model-value": item[column.name],
2152
2217
  "column": column,
2153
2218
  "features": _vm.features,
2219
+ "sticky-offset": column.stickiness === 'start' ? _vm.stickyOffsets.start.get(column.name) : column.stickiness === 'end' ? _vm.stickyOffsets.end.get(column.name) : undefined,
2154
2220
  "variant": _vm.variant
2155
2221
  },
2156
2222
  on: {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onereach/ui-components-vue2",
3
- "version": "26.4.1-beta.5879.0",
3
+ "version": "26.4.1-beta.5881.0",
4
4
  "description": "Vue components library for v2",
5
5
  "license": "Apache-2.0",
6
6
  "sideEffects": false,
@@ -40,8 +40,8 @@
40
40
  "@codemirror/view": "^6",
41
41
  "@floating-ui/dom": "1.5.3",
42
42
  "@lezer/highlight": "*",
43
- "@onereach/styles": "^26.4.1-beta.5879.0",
44
- "@onereach/ui-components-common": "^26.4.1-beta.5879.0",
43
+ "@onereach/styles": "^26.4.1-beta.5881.0",
44
+ "@onereach/ui-components-common": "^26.4.1-beta.5881.0",
45
45
  "@splidejs/splide": "4.0.6",
46
46
  "@tiptap/core": "2.27.1",
47
47
  "@tiptap/extension-blockquote": "2.27.1",