@universal-ember/table 3.6.0 → 3.6.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.
Files changed (224) hide show
  1. package/package.json +1 -1
  2. package/src/plugins/column-reordering/plugin.ts +4 -6
  3. package/declarations/-private/-type-tests/plugin-properties.test.d.ts +0 -2
  4. package/declarations/-private/-type-tests/plugin-properties.test.d.ts.map +0 -1
  5. package/declarations/-private/-type-tests/plugin-with.test.d.ts +0 -2
  6. package/declarations/-private/-type-tests/plugin-with.test.d.ts.map +0 -1
  7. package/declarations/-private/-type-tests/plugins-accessors.test.d.ts +0 -2
  8. package/declarations/-private/-type-tests/plugins-accessors.test.d.ts.map +0 -1
  9. package/declarations/-private/-type-tests/plugins-signature-from.test.d.ts +0 -2
  10. package/declarations/-private/-type-tests/plugins-signature-from.test.d.ts.map +0 -1
  11. package/declarations/-private/-type-tests/plugins-signature-utils.test.d.ts +0 -2
  12. package/declarations/-private/-type-tests/plugins-signature-utils.test.d.ts.map +0 -1
  13. package/declarations/-private/-type-tests/table-api.test.d.ts +0 -2
  14. package/declarations/-private/-type-tests/table-api.test.d.ts.map +0 -1
  15. package/declarations/-private/-type-tests/table-config.test.d.ts +0 -2
  16. package/declarations/-private/-type-tests/table-config.test.d.ts.map +0 -1
  17. package/declarations/-private/column.d.ts +0 -18
  18. package/declarations/-private/column.d.ts.map +0 -1
  19. package/declarations/-private/ember-compat.d.ts +0 -8
  20. package/declarations/-private/ember-compat.d.ts.map +0 -1
  21. package/declarations/-private/interfaces/column.d.ts +0 -63
  22. package/declarations/-private/interfaces/column.d.ts.map +0 -1
  23. package/declarations/-private/interfaces/index.d.ts +0 -8
  24. package/declarations/-private/interfaces/index.d.ts.map +0 -1
  25. package/declarations/-private/interfaces/modifier.d.ts +0 -7
  26. package/declarations/-private/interfaces/modifier.d.ts.map +0 -1
  27. package/declarations/-private/interfaces/pagination.d.ts +0 -17
  28. package/declarations/-private/interfaces/pagination.d.ts.map +0 -1
  29. package/declarations/-private/interfaces/plugins.d.ts +0 -315
  30. package/declarations/-private/interfaces/plugins.d.ts.map +0 -1
  31. package/declarations/-private/interfaces/preferences.d.ts +0 -74
  32. package/declarations/-private/interfaces/preferences.d.ts.map +0 -1
  33. package/declarations/-private/interfaces/selection.d.ts +0 -36
  34. package/declarations/-private/interfaces/selection.d.ts.map +0 -1
  35. package/declarations/-private/interfaces/table.d.ts +0 -127
  36. package/declarations/-private/interfaces/table.d.ts.map +0 -1
  37. package/declarations/-private/js-helper.d.ts +0 -39
  38. package/declarations/-private/js-helper.d.ts.map +0 -1
  39. package/declarations/-private/preferences.d.ts +0 -47
  40. package/declarations/-private/preferences.d.ts.map +0 -1
  41. package/declarations/-private/private-types.d.ts +0 -6
  42. package/declarations/-private/private-types.d.ts.map +0 -1
  43. package/declarations/-private/row.d.ts +0 -12
  44. package/declarations/-private/row.d.ts.map +0 -1
  45. package/declarations/-private/table.d.ts +0 -136
  46. package/declarations/-private/table.d.ts.map +0 -1
  47. package/declarations/-private/utils.d.ts +0 -3
  48. package/declarations/-private/utils.d.ts.map +0 -1
  49. package/declarations/index.d.ts +0 -14
  50. package/declarations/index.d.ts.map +0 -1
  51. package/declarations/plugins/-private/base.d.ts +0 -281
  52. package/declarations/plugins/-private/base.d.ts.map +0 -1
  53. package/declarations/plugins/-private/utils.d.ts +0 -22
  54. package/declarations/plugins/-private/utils.d.ts.map +0 -1
  55. package/declarations/plugins/column-reordering/helpers.d.ts +0 -54
  56. package/declarations/plugins/column-reordering/helpers.d.ts.map +0 -1
  57. package/declarations/plugins/column-reordering/index.d.ts +0 -5
  58. package/declarations/plugins/column-reordering/index.d.ts.map +0 -1
  59. package/declarations/plugins/column-reordering/plugin.d.ts +0 -196
  60. package/declarations/plugins/column-reordering/plugin.d.ts.map +0 -1
  61. package/declarations/plugins/column-reordering/utils.d.ts +0 -8
  62. package/declarations/plugins/column-reordering/utils.d.ts.map +0 -1
  63. package/declarations/plugins/column-resizing/handle.d.ts +0 -128
  64. package/declarations/plugins/column-resizing/handle.d.ts.map +0 -1
  65. package/declarations/plugins/column-resizing/helpers.d.ts +0 -40
  66. package/declarations/plugins/column-resizing/helpers.d.ts.map +0 -1
  67. package/declarations/plugins/column-resizing/index.d.ts +0 -6
  68. package/declarations/plugins/column-resizing/index.d.ts.map +0 -1
  69. package/declarations/plugins/column-resizing/plugin.d.ts +0 -172
  70. package/declarations/plugins/column-resizing/plugin.d.ts.map +0 -1
  71. package/declarations/plugins/column-resizing/resize-observer.d.ts +0 -14
  72. package/declarations/plugins/column-resizing/resize-observer.d.ts.map +0 -1
  73. package/declarations/plugins/column-resizing/utils.d.ts +0 -22
  74. package/declarations/plugins/column-resizing/utils.d.ts.map +0 -1
  75. package/declarations/plugins/column-visibility/helpers.d.ts +0 -18
  76. package/declarations/plugins/column-visibility/helpers.d.ts.map +0 -1
  77. package/declarations/plugins/column-visibility/index.d.ts +0 -5
  78. package/declarations/plugins/column-visibility/index.d.ts.map +0 -1
  79. package/declarations/plugins/column-visibility/plugin.d.ts +0 -64
  80. package/declarations/plugins/column-visibility/plugin.d.ts.map +0 -1
  81. package/declarations/plugins/data-sorting/helpers.d.ts +0 -38
  82. package/declarations/plugins/data-sorting/helpers.d.ts.map +0 -1
  83. package/declarations/plugins/data-sorting/index.d.ts +0 -7
  84. package/declarations/plugins/data-sorting/index.d.ts.map +0 -1
  85. package/declarations/plugins/data-sorting/plugin.d.ts +0 -102
  86. package/declarations/plugins/data-sorting/plugin.d.ts.map +0 -1
  87. package/declarations/plugins/data-sorting/types.d.ts +0 -23
  88. package/declarations/plugins/data-sorting/types.d.ts.map +0 -1
  89. package/declarations/plugins/index.d.ts +0 -6
  90. package/declarations/plugins/index.d.ts.map +0 -1
  91. package/declarations/plugins/metadata/helpers.d.ts +0 -4
  92. package/declarations/plugins/metadata/helpers.d.ts.map +0 -1
  93. package/declarations/plugins/metadata/index.d.ts +0 -5
  94. package/declarations/plugins/metadata/index.d.ts.map +0 -1
  95. package/declarations/plugins/metadata/plugin.d.ts +0 -25
  96. package/declarations/plugins/metadata/plugin.d.ts.map +0 -1
  97. package/declarations/plugins/row-selection/helpers.d.ts +0 -6
  98. package/declarations/plugins/row-selection/helpers.d.ts.map +0 -1
  99. package/declarations/plugins/row-selection/index.d.ts +0 -5
  100. package/declarations/plugins/row-selection/index.d.ts.map +0 -1
  101. package/declarations/plugins/row-selection/plugin.d.ts +0 -80
  102. package/declarations/plugins/row-selection/plugin.d.ts.map +0 -1
  103. package/declarations/plugins/sticky-columns/helpers.d.ts +0 -17
  104. package/declarations/plugins/sticky-columns/helpers.d.ts.map +0 -1
  105. package/declarations/plugins/sticky-columns/index.d.ts +0 -5
  106. package/declarations/plugins/sticky-columns/index.d.ts.map +0 -1
  107. package/declarations/plugins/sticky-columns/plugin.d.ts +0 -70
  108. package/declarations/plugins/sticky-columns/plugin.d.ts.map +0 -1
  109. package/declarations/test-support/index.d.ts +0 -15
  110. package/declarations/test-support/index.d.ts.map +0 -1
  111. package/declarations/utils.d.ts +0 -26
  112. package/declarations/utils.d.ts.map +0 -1
  113. package/dist/-private/-type-tests/plugin-properties.test.js +0 -27
  114. package/dist/-private/-type-tests/plugin-properties.test.js.map +0 -1
  115. package/dist/-private/-type-tests/plugin-with.test.js +0 -20
  116. package/dist/-private/-type-tests/plugin-with.test.js.map +0 -1
  117. package/dist/-private/-type-tests/plugins-accessors.test.js +0 -36
  118. package/dist/-private/-type-tests/plugins-accessors.test.js.map +0 -1
  119. package/dist/-private/-type-tests/plugins-signature-from.test.js +0 -15
  120. package/dist/-private/-type-tests/plugins-signature-from.test.js.map +0 -1
  121. package/dist/-private/-type-tests/plugins-signature-utils.test.js +0 -36
  122. package/dist/-private/-type-tests/plugins-signature-utils.test.js.map +0 -1
  123. package/dist/-private/-type-tests/table-api.test.js +0 -17
  124. package/dist/-private/-type-tests/table-api.test.js.map +0 -1
  125. package/dist/-private/-type-tests/table-config.test.js +0 -55
  126. package/dist/-private/-type-tests/table-config.test.js.map +0 -1
  127. package/dist/-private/column.js +0 -62
  128. package/dist/-private/column.js.map +0 -1
  129. package/dist/-private/ember-compat.js +0 -17
  130. package/dist/-private/ember-compat.js.map +0 -1
  131. package/dist/-private/interfaces/column.js +0 -2
  132. package/dist/-private/interfaces/column.js.map +0 -1
  133. package/dist/-private/interfaces/index.js +0 -2
  134. package/dist/-private/interfaces/index.js.map +0 -1
  135. package/dist/-private/interfaces/modifier.js +0 -2
  136. package/dist/-private/interfaces/modifier.js.map +0 -1
  137. package/dist/-private/interfaces/pagination.js +0 -2
  138. package/dist/-private/interfaces/pagination.js.map +0 -1
  139. package/dist/-private/interfaces/plugins.js +0 -2
  140. package/dist/-private/interfaces/plugins.js.map +0 -1
  141. package/dist/-private/interfaces/preferences.js +0 -2
  142. package/dist/-private/interfaces/preferences.js.map +0 -1
  143. package/dist/-private/interfaces/selection.js +0 -2
  144. package/dist/-private/interfaces/selection.js.map +0 -1
  145. package/dist/-private/interfaces/table.js +0 -2
  146. package/dist/-private/interfaces/table.js.map +0 -1
  147. package/dist/-private/js-helper.js +0 -55
  148. package/dist/-private/js-helper.js.map +0 -1
  149. package/dist/-private/preferences.js +0 -149
  150. package/dist/-private/preferences.js.map +0 -1
  151. package/dist/-private/private-types.js +0 -2
  152. package/dist/-private/private-types.js.map +0 -1
  153. package/dist/-private/row.js +0 -51
  154. package/dist/-private/row.js.map +0 -1
  155. package/dist/-private/table.js +0 -276
  156. package/dist/-private/table.js.map +0 -1
  157. package/dist/-private/utils.js +0 -15
  158. package/dist/-private/utils.js.map +0 -1
  159. package/dist/_rollupPluginBabelHelpers-CjaRjJZX.js +0 -63
  160. package/dist/_rollupPluginBabelHelpers-CjaRjJZX.js.map +0 -1
  161. package/dist/index.js +0 -4
  162. package/dist/index.js.map +0 -1
  163. package/dist/plugins/-private/base.js +0 -532
  164. package/dist/plugins/-private/base.js.map +0 -1
  165. package/dist/plugins/-private/utils.js +0 -103
  166. package/dist/plugins/-private/utils.js.map +0 -1
  167. package/dist/plugins/column-reordering/helpers.js +0 -81
  168. package/dist/plugins/column-reordering/helpers.js.map +0 -1
  169. package/dist/plugins/column-reordering/index.js +0 -3
  170. package/dist/plugins/column-reordering/index.js.map +0 -1
  171. package/dist/plugins/column-reordering/plugin.js +0 -453
  172. package/dist/plugins/column-reordering/plugin.js.map +0 -1
  173. package/dist/plugins/column-reordering/utils.js +0 -34
  174. package/dist/plugins/column-reordering/utils.js.map +0 -1
  175. package/dist/plugins/column-resizing/handle.js +0 -243
  176. package/dist/plugins/column-resizing/handle.js.map +0 -1
  177. package/dist/plugins/column-resizing/helpers.js +0 -77
  178. package/dist/plugins/column-resizing/helpers.js.map +0 -1
  179. package/dist/plugins/column-resizing/index.js +0 -4
  180. package/dist/plugins/column-resizing/index.js.map +0 -1
  181. package/dist/plugins/column-resizing/plugin.js +0 -365
  182. package/dist/plugins/column-resizing/plugin.js.map +0 -1
  183. package/dist/plugins/column-resizing/resize-observer.js +0 -44
  184. package/dist/plugins/column-resizing/resize-observer.js.map +0 -1
  185. package/dist/plugins/column-resizing/utils.js +0 -44
  186. package/dist/plugins/column-resizing/utils.js.map +0 -1
  187. package/dist/plugins/column-visibility/helpers.js +0 -25
  188. package/dist/plugins/column-visibility/helpers.js.map +0 -1
  189. package/dist/plugins/column-visibility/index.js +0 -3
  190. package/dist/plugins/column-visibility/index.js.map +0 -1
  191. package/dist/plugins/column-visibility/plugin.js +0 -92
  192. package/dist/plugins/column-visibility/plugin.js.map +0 -1
  193. package/dist/plugins/data-sorting/helpers.js +0 -49
  194. package/dist/plugins/data-sorting/helpers.js.map +0 -1
  195. package/dist/plugins/data-sorting/index.js +0 -4
  196. package/dist/plugins/data-sorting/index.js.map +0 -1
  197. package/dist/plugins/data-sorting/plugin.js +0 -132
  198. package/dist/plugins/data-sorting/plugin.js.map +0 -1
  199. package/dist/plugins/data-sorting/types.js +0 -14
  200. package/dist/plugins/data-sorting/types.js.map +0 -1
  201. package/dist/plugins/index.js +0 -3
  202. package/dist/plugins/index.js.map +0 -1
  203. package/dist/plugins/metadata/helpers.js +0 -12
  204. package/dist/plugins/metadata/helpers.js.map +0 -1
  205. package/dist/plugins/metadata/index.js +0 -3
  206. package/dist/plugins/metadata/index.js.map +0 -1
  207. package/dist/plugins/metadata/plugin.js +0 -25
  208. package/dist/plugins/metadata/plugin.js.map +0 -1
  209. package/dist/plugins/row-selection/helpers.js +0 -10
  210. package/dist/plugins/row-selection/helpers.js.map +0 -1
  211. package/dist/plugins/row-selection/index.js +0 -3
  212. package/dist/plugins/row-selection/index.js.map +0 -1
  213. package/dist/plugins/row-selection/plugin.js +0 -118
  214. package/dist/plugins/row-selection/plugin.js.map +0 -1
  215. package/dist/plugins/sticky-columns/helpers.js +0 -49
  216. package/dist/plugins/sticky-columns/helpers.js.map +0 -1
  217. package/dist/plugins/sticky-columns/index.js +0 -3
  218. package/dist/plugins/sticky-columns/index.js.map +0 -1
  219. package/dist/plugins/sticky-columns/plugin.js +0 -139
  220. package/dist/plugins/sticky-columns/plugin.js.map +0 -1
  221. package/dist/test-support/index.js +0 -62
  222. package/dist/test-support/index.js.map +0 -1
  223. package/dist/utils.js +0 -77
  224. package/dist/utils.js.map +0 -1
@@ -1,365 +0,0 @@
1
- import { _ as _defineProperty, a as _applyDecoratedDescriptor, c as _classPrivateMethodInitSpec, b as _initializerDefineProperty, d as _classPrivateGetter, h as _assertClassBrand } from '../../_rollupPluginBabelHelpers-CjaRjJZX.js';
2
- import { tracked, cached } from '@glimmer/tracking';
3
- import { assert } from '@ember/debug';
4
- import { isDestroyed, isDestroying } from '@ember/destroyable';
5
- import { action } from '@ember/object';
6
- import { BasePlugin, meta, preferences, options, columns } from '../-private/base.js';
7
- import { applyStyles } from '../-private/utils.js';
8
- import { getAccurateClientWidth, getAccurateClientHeight, totalGapOf } from './utils.js';
9
-
10
- var _class, _descriptor, _descriptor2, _class2, _descriptor3, _descriptor4, _TableMeta_brand;
11
- /**
12
- * One instance of a plugin exists per table
13
- * but a plugin can have a "Meta" for each column
14
- */
15
- class ColumnResizing extends BasePlugin {
16
- constructor(...args) {
17
- super(...args);
18
- _defineProperty(this, "name", 'column-resizing');
19
- _defineProperty(this, "meta", {
20
- column: ColumnMeta,
21
- table: TableMeta
22
- });
23
- _defineProperty(this, "headerCellModifier", (element, {
24
- column
25
- }) => {
26
- const columnMeta = meta.forColumn(column, ColumnResizing);
27
- element.setAttribute('data-test-is-resizable', `${columnMeta.isResizable}`);
28
- applyStyles(element, columnMeta.style);
29
- });
30
- /**
31
- * This is what ends up calling resize when the browser changes
32
- * (assuming that the containing element's styles stretch to fill the space)
33
- *
34
- * Later, when container queries are more broadly supported, we'll want to watch
35
- * the container instead of the window to prevent unneeded updates (as a window can change
36
- * size without the container changing size)
37
- */
38
- _defineProperty(this, "containerModifier", resizeObserver);
39
- }
40
- reset() {
41
- preferences.forAllColumns(this.table, ColumnResizing).delete('width');
42
- }
43
- }
44
- _defineProperty(ColumnResizing, "features", ['columnWidth']);
45
- const DEFAULT_COLUMN_OPTIONS = {
46
- minWidth: 128
47
- };
48
- const ALLOWED_COLUMN_OPTIONS = ['minWidth', 'width', 'isResizable'];
49
-
50
- /**
51
- * @private
52
- *
53
- * Contains resizable information for a particular column
54
- */
55
- let ColumnMeta = (_class = class ColumnMeta {
56
- constructor(column) {
57
- _initializerDefineProperty(this, "_width", _descriptor, this);
58
- _initializerDefineProperty(this, "isResizing", _descriptor2, this);
59
- this.column = column;
60
- }
61
- get tableMeta() {
62
- return meta.forTable(this.column.table, ColumnResizing);
63
- }
64
- get options() {
65
- const columnOptions = options.forColumn(this.column, ColumnResizing);
66
- const filteredOptions = Object.entries(columnOptions || {}).reduce((result, [k, v]) => {
67
- if (ALLOWED_COLUMN_OPTIONS.includes(k)) {
68
- result[k] = v;
69
- }
70
- return result;
71
- }, {});
72
- return {
73
- ...DEFAULT_COLUMN_OPTIONS,
74
- ...filteredOptions
75
- };
76
- }
77
- get key() {
78
- return this.column.key;
79
- }
80
- get minWidth() {
81
- return this.options.minWidth;
82
- }
83
- get initialWidth() {
84
- const savedWidth = preferences.forColumn(this.column, ColumnResizing).get('width');
85
- if (!savedWidth) {
86
- return this.options.width;
87
- }
88
- if (typeof savedWidth !== 'string') {
89
- assert('saved width must be a number or string', typeof savedWidth === 'number');
90
- return savedWidth;
91
- }
92
- return parseInt(savedWidth, 10);
93
- }
94
- get canShrink() {
95
- return this.width && this.width > this.minWidth;
96
- }
97
- get roomToShrink() {
98
- return this.width ? this.width - this.minWidth : 0;
99
- }
100
- get isResizable() {
101
- return this.options.isResizable ?? this.tableMeta.isResizable;
102
- }
103
- get hasResizeHandle() {
104
- const position = this.tableMeta.options?.handlePosition ?? 'left';
105
- if (position === 'right') {
106
- const next = columns.next(this.column);
107
- if (!next) return false;
108
- return this.isResizable && meta.forColumn(next, ColumnResizing).isResizable;
109
- } else {
110
- const previous = columns.previous(this.column);
111
- if (!previous) return false;
112
- return this.isResizable && meta.forColumn(previous, ColumnResizing).isResizable;
113
- }
114
- }
115
- get width() {
116
- let width = this._width ?? this.initialWidth;
117
- if (!width) {
118
- const {
119
- defaultColumnWidth
120
- } = this.tableMeta;
121
- width = defaultColumnWidth ? Math.max(defaultColumnWidth, this.minWidth) : this.minWidth;
122
- }
123
- return width;
124
- }
125
- set width(value) {
126
- this._width = value;
127
- }
128
- get style() {
129
- const styles = {};
130
- if (this.width) styles.width = `${this.width}px`;
131
- if (this.minWidth) styles.minWidth = `${this.minWidth}px`;
132
- return styles;
133
- }
134
- resize(delta) {
135
- this.tableMeta.resizeColumn(this.column, delta);
136
- }
137
- save() {
138
- this.tableMeta.saveColWidths(this.tableMeta.visibleColumnMetas);
139
- }
140
- }, _descriptor = _applyDecoratedDescriptor(_class.prototype, "_width", [tracked], {
141
- configurable: true,
142
- enumerable: true,
143
- writable: true,
144
- initializer: null
145
- }), _descriptor2 = _applyDecoratedDescriptor(_class.prototype, "isResizing", [tracked], {
146
- configurable: true,
147
- enumerable: true,
148
- writable: true,
149
- initializer: function () {
150
- return false;
151
- }
152
- }), _applyDecoratedDescriptor(_class.prototype, "options", [cached], Object.getOwnPropertyDescriptor(_class.prototype, "options"), _class.prototype), _applyDecoratedDescriptor(_class.prototype, "resize", [action], Object.getOwnPropertyDescriptor(_class.prototype, "resize"), _class.prototype), _applyDecoratedDescriptor(_class.prototype, "save", [action], Object.getOwnPropertyDescriptor(_class.prototype, "save"), _class.prototype), _class);
153
-
154
- /**
155
- * @private
156
- *
157
- * individual column width must exclude:
158
- * - padding
159
- * - margin
160
- * - gap (partial)
161
- * - any other positioning offsets
162
- *
163
- * Otherwise the table will infinitely resize itself
164
- */
165
- function distributeDelta(delta, visibleColumns) {
166
- // Use a tolerance threshold to prevent infinite resize loops from subpixel rounding
167
- // at different zoom levels. Treat deltas smaller than 0.5px as zero.
168
- if (Math.abs(delta) < 0.5) return;
169
- const metas = visibleColumns.map(column => meta.forColumn(column, ColumnResizing));
170
- const resizableMetas = metas.filter(meta => meta.isResizable && (delta < 0 ? meta.canShrink : true));
171
- const columnDelta = delta / resizableMetas.length;
172
- for (const meta of resizableMetas) {
173
- assert('cannot resize a column that does not have a width', meta.width);
174
- meta.width = Math.max(meta.width + columnDelta, meta.minWidth);
175
- }
176
- }
177
-
178
- /**
179
- * @private
180
- *
181
- * Contains resizable and width information regarding the table as a whole
182
- */
183
- let TableMeta = (_class2 = (_TableMeta_brand = /*#__PURE__*/new WeakSet(), class TableMeta {
184
- constructor(table) {
185
- _classPrivateMethodInitSpec(this, _TableMeta_brand);
186
- _initializerDefineProperty(this, "scrollContainerHeight", _descriptor3, this);
187
- _initializerDefineProperty(this, "scrollContainerWidth", _descriptor4, this);
188
- this.table = table;
189
- }
190
- get options() {
191
- return options.forTable(this.table, ColumnResizing);
192
- }
193
- get isResizable() {
194
- return this.options?.enabled ?? true;
195
- }
196
- get defaultColumnWidth() {
197
- if (!this.scrollContainerWidth) return;
198
- return (this.scrollContainerWidth - this.totalInitialColumnWidths) / this.columnsWithoutInitialWidth.length;
199
- }
200
- get visibleColumnMetas() {
201
- return _classPrivateGetter(_TableMeta_brand, this, _get_availableColumns).map(column => meta.forColumn(column, ColumnResizing));
202
- }
203
- get totalInitialColumnWidths() {
204
- return this.visibleColumnMetas.reduce((acc, meta) => acc += meta.initialWidth ?? 0, 0);
205
- }
206
- get columnsWithoutInitialWidth() {
207
- return this.visibleColumnMetas.filter(meta => !meta.initialWidth);
208
- }
209
- get totalVisibleColumnsWidth() {
210
- return this.visibleColumnMetas.reduce((acc, column) => acc += column.width ?? 0, 0);
211
- }
212
- saveColWidths(visibleColumnMetas) {
213
- const tablePrefs = this.table.preferences;
214
- for (const column of visibleColumnMetas) {
215
- const existing = tablePrefs.storage.forPlugin(ColumnResizing.name);
216
- const columnPrefs = existing.forColumn(column.key);
217
- columnPrefs.set('width', column.width.toString());
218
- }
219
- tablePrefs.persist();
220
- }
221
- reset() {
222
- if (!this.scrollContainerWidth) return;
223
- for (const column of this.visibleColumnMetas) {
224
- column._width = undefined;
225
- }
226
- }
227
- onTableResize(entry) {
228
- assert('scroll container element must be an HTMLElement', entry.target instanceof HTMLElement);
229
-
230
- // For fixed layout, columns have explicit widths and should not be auto-redistributed
231
- if (this.options?.tableLayout === 'fixed') {
232
- return;
233
- }
234
- this.scrollContainerWidth = getAccurateClientWidth(entry.target);
235
- this.scrollContainerHeight = getAccurateClientHeight(entry.target);
236
-
237
- // TODO: extract this to card-list and remove it from the plugin
238
- // card-list will provide its own column-resizing plugin
239
- // by sub-classing this one, and defining its own way of calculating the "diff"
240
- const totalGap = totalGapOf(entry.target.querySelector('[role="row"]'));
241
- const diff = this.scrollContainerWidth - this.totalVisibleColumnsWidth - totalGap;
242
- distributeDelta(diff, _classPrivateGetter(_TableMeta_brand, this, _get_availableColumns));
243
- }
244
- resizeColumn(column, delta) {
245
- if (delta === 0) return;
246
- const tableLayout = this.options?.tableLayout ?? 'auto';
247
- if (tableLayout === 'fixed') {
248
- _assertClassBrand(_TableMeta_brand, this, _resizeColumnFixed).call(this, column, delta);
249
- } else {
250
- _assertClassBrand(_TableMeta_brand, this, _resizeColumnAuto).call(this, column, delta);
251
- }
252
- }
253
-
254
- /**
255
- * Simple column resizing for table-layout: fixed
256
- * Only affects the target column and respects minimum width
257
- */
258
- }), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, "scrollContainerHeight", [tracked], {
259
- configurable: true,
260
- enumerable: true,
261
- writable: true,
262
- initializer: null
263
- }), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, "scrollContainerWidth", [tracked], {
264
- configurable: true,
265
- enumerable: true,
266
- writable: true,
267
- initializer: null
268
- }), _applyDecoratedDescriptor(_class2.prototype, "saveColWidths", [action], Object.getOwnPropertyDescriptor(_class2.prototype, "saveColWidths"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "reset", [action], Object.getOwnPropertyDescriptor(_class2.prototype, "reset"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onTableResize", [action], Object.getOwnPropertyDescriptor(_class2.prototype, "onTableResize"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "resizeColumn", [action], Object.getOwnPropertyDescriptor(_class2.prototype, "resizeColumn"), _class2.prototype), _class2);
269
-
270
- /**
271
- * @private
272
- * included in the same file as the plugin due to circular dependency
273
- *
274
- * This goes on the containing element
275
- *
276
- * @example
277
- * ```hbs
278
- * <div {{resizeObserver @table}}>
279
- * <table>
280
- * ```
281
- */
282
- function _get_availableColumns(_this) {
283
- return columns.for(_this.table, ColumnResizing);
284
- }
285
- function _resizeColumnFixed(column, delta) {
286
- const columnMeta = meta.forColumn(column, ColumnResizing);
287
- const newWidth = columnMeta.width + delta;
288
- if (newWidth >= columnMeta.minWidth) {
289
- columnMeta.width = newWidth;
290
- }
291
- }
292
- /**
293
- * Complex column resizing with redistribution logic
294
- * Preserves existing behavior for table-layout: auto
295
- */
296
- function _resizeColumnAuto(column, delta) {
297
- /**
298
- * When the delta is negative, we are dragging to the next
299
- * when positive, we are dragging to the right
300
- * when dragging to the right, we want to grow the column
301
- * when dragging to the left, we grow the "next" column,
302
- * which shrinks the column we're dragging
303
- *
304
- * This assumes the resize handle for any column is on the right-hand
305
- * side of the column header
306
- *
307
- * If the resize handle were on the left-hand side of the column header
308
- * we'd want the column.next to be column.previous
309
- *
310
- * This is CSS dependent, and can be configured in plugin
311
- * options
312
- */
313
- const isDraggingRight = delta > 0;
314
- const position = this.options?.handlePosition ?? 'left';
315
- let growingColumn;
316
- if (position === 'right') {
317
- growingColumn = isDraggingRight ? column : columns.next(column);
318
- } else {
319
- growingColumn = isDraggingRight ? columns.previous(column) : column;
320
- }
321
- if (!growingColumn) return;
322
- const growingColumnMeta = meta.forColumn(growingColumn, ColumnResizing);
323
- assert('cannot resize a column that does not have a width', growingColumnMeta.width);
324
- const shrinkableColumns = delta > 0 ? columns.after(growingColumn) : columns.before(growingColumn).reverse();
325
- const shrinkableColumnsMetas = shrinkableColumns.map(column => meta.forColumn(column, ColumnResizing)).filter(meta => meta.canShrink);
326
- let remainder = Math.abs(delta);
327
- while (shrinkableColumnsMetas.length > 0) {
328
- const shrinkingColumnMeta = shrinkableColumnsMetas.shift();
329
- assert('cannot resize a column that does not have a width', shrinkingColumnMeta?.width);
330
- const actualDelta = Math.min(remainder, shrinkingColumnMeta.roomToShrink);
331
- growingColumnMeta.width += actualDelta;
332
- shrinkingColumnMeta.width -= actualDelta;
333
- remainder -= actualDelta;
334
- }
335
- }
336
- function resizeObserver(element, table) {
337
- const observer = getObserver(element, table);
338
- observer.observe(element);
339
- return () => {
340
- observer.unobserve(element);
341
- };
342
- }
343
- const CACHE = new WeakMap();
344
-
345
- /**
346
- * This is technically "inefficient" as you don't want too many resize
347
- * observers on a page, but tables are so big, that I don't see too many use cases
348
- * where you'd have 10+ tables on a page
349
- */
350
- function getObserver(element, table) {
351
- let existing = CACHE.get(element);
352
- if (existing) return existing;
353
- existing = new ResizeObserver(entries => {
354
- if (isDestroyed(table) || isDestroying(table)) {
355
- return;
356
- }
357
- for (const entry of entries) {
358
- meta.forTable(table, ColumnResizing).onTableResize(entry);
359
- }
360
- });
361
- return existing;
362
- }
363
-
364
- export { ColumnMeta, ColumnResizing, TableMeta };
365
- //# sourceMappingURL=plugin.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"plugin.js","sources":["../../../src/plugins/column-resizing/plugin.ts"],"sourcesContent":["import { cached, tracked } from '@glimmer/tracking';\nimport { assert } from '@ember/debug';\nimport { isDestroyed, isDestroying } from '@ember/destroyable';\nimport { action } from '@ember/object';\n\nimport { preferences } from '../../plugins/index.ts';\n\nimport { BasePlugin, columns, meta, options } from '../-private/base.ts';\nimport { applyStyles } from '../-private/utils.ts';\nimport {\n getAccurateClientHeight,\n getAccurateClientWidth,\n totalGapOf,\n} from './utils.ts';\n\nimport type { ColumnApi, PluginPreferences } from '../../plugins/index.ts';\nimport type { Column, Table } from '../../index.ts';\n\ninterface ColumnResizePreferences extends PluginPreferences {\n columns: {\n [columnKey: string]: {\n width?: number;\n };\n };\n}\n\ndeclare module '@universal-ember/table/plugins' {\n interface Registry {\n ColumnResizing?: ColumnResizePreferences;\n }\n}\n\nexport interface ColumnOptions {\n /**\n * Force a starting width\n * This may not be less than the minWidth\n */\n width?: number;\n /**\n * Default: 128px\n */\n minWidth?: number;\n /**\n * Flip if the column is resizable or not.\n * The default is whatever the table's plugin option is set to\n * (and then yet again true, if not set at all)\n */\n isResizable?: boolean;\n}\n\nexport interface TableOptions {\n /**\n * Toggle whether the table is able to be resized at all\n *\n * default :true\n */\n enabled?: boolean;\n\n /**\n * By default, each column's \"handle\" position is on the\n * left-hand side of the column.\n *\n * If, for style-reasons, you want to move it to the right,\n * this option should reflect that so that the calculations can be\n * updated to match the expected behavior of which column(s) grow/shrink\n *\n * Valid values are 'left' or 'right'\n */\n handlePosition?: string;\n\n /**\n * Specify the table layout strategy for column resizing.\n *\n * - 'auto': Uses complex redistribution logic where resizing one column\n * affects neighboring columns (default, preserves existing behavior)\n * - 'fixed': Simple per-column resizing suitable for CSS table-layout: fixed\n *\n * Valid values are 'auto' or 'fixed'\n *\n * default: 'auto'\n */\n tableLayout?: string;\n}\n\ninterface Signature {\n Meta: {\n Column: ColumnMeta;\n Table: TableMeta;\n };\n Options: {\n Plugin: TableOptions;\n Column: ColumnOptions;\n };\n}\n\n/**\n * One instance of a plugin exists per table\n * but a plugin can have a \"Meta\" for each column\n */\nexport class ColumnResizing extends BasePlugin<Signature> {\n name = 'column-resizing';\n static features = ['columnWidth'];\n\n meta = {\n column: ColumnMeta,\n table: TableMeta,\n };\n\n headerCellModifier = (element: HTMLElement, { column }: ColumnApi) => {\n const columnMeta = meta.forColumn(column, ColumnResizing);\n\n element.setAttribute('data-test-is-resizable', `${columnMeta.isResizable}`);\n\n applyStyles(element, columnMeta.style);\n };\n\n /**\n * This is what ends up calling resize when the browser changes\n * (assuming that the containing element's styles stretch to fill the space)\n *\n * Later, when container queries are more broadly supported, we'll want to watch\n * the container instead of the window to prevent unneeded updates (as a window can change\n * size without the container changing size)\n */\n containerModifier = resizeObserver;\n\n reset() {\n preferences.forAllColumns(this.table, ColumnResizing).delete('width');\n }\n}\n\nconst DEFAULT_COLUMN_OPTIONS = {\n minWidth: 128,\n};\n\nconst ALLOWED_COLUMN_OPTIONS = ['minWidth', 'width', 'isResizable'];\n\n/**\n * @private\n *\n * Contains resizable information for a particular column\n */\nexport class ColumnMeta {\n constructor(private column: Column) {}\n\n @tracked _width?: number;\n @tracked isResizing = false;\n\n get tableMeta() {\n return meta.forTable(this.column.table, ColumnResizing);\n }\n\n @cached\n get options() {\n const columnOptions = options.forColumn(this.column, ColumnResizing);\n const filteredOptions = Object.entries(columnOptions || {}).reduce(\n (result, [k, v]) => {\n if (ALLOWED_COLUMN_OPTIONS.includes(k)) {\n result[k] = v;\n }\n\n return result;\n },\n {} as Record<string, unknown>,\n ) as ColumnOptions;\n\n return {\n ...DEFAULT_COLUMN_OPTIONS,\n ...filteredOptions,\n };\n }\n\n get key() {\n return this.column.key;\n }\n\n get minWidth() {\n return this.options.minWidth;\n }\n\n get initialWidth() {\n const savedWidth = preferences\n .forColumn(this.column, ColumnResizing)\n .get('width');\n\n if (!savedWidth) {\n return this.options.width;\n }\n\n if (typeof savedWidth !== 'string') {\n assert(\n 'saved width must be a number or string',\n typeof savedWidth === 'number',\n );\n return savedWidth;\n }\n\n return parseInt(savedWidth, 10);\n }\n\n get canShrink() {\n return this.width && this.width > this.minWidth;\n }\n\n get roomToShrink() {\n return this.width ? this.width - this.minWidth : 0;\n }\n\n get isResizable() {\n return this.options.isResizable ?? this.tableMeta.isResizable;\n }\n\n get hasResizeHandle() {\n const position = this.tableMeta.options?.handlePosition ?? 'left';\n\n if (position === 'right') {\n const next = columns.next(this.column);\n if (!next) return false;\n return (\n this.isResizable && meta.forColumn(next, ColumnResizing).isResizable\n );\n } else {\n const previous = columns.previous(this.column);\n if (!previous) return false;\n return (\n this.isResizable && meta.forColumn(previous, ColumnResizing).isResizable\n );\n }\n }\n\n get width() {\n let width = this._width ?? this.initialWidth;\n\n if (!width) {\n const { defaultColumnWidth } = this.tableMeta;\n\n width = defaultColumnWidth\n ? Math.max(defaultColumnWidth, this.minWidth)\n : this.minWidth;\n }\n\n return width;\n }\n\n set width(value) {\n this._width = value;\n }\n\n get style() {\n const styles: Partial<Pick<CSSStyleDeclaration, 'width' | 'minWidth'>> = {};\n\n if (this.width) styles.width = `${this.width}px`;\n if (this.minWidth) styles.minWidth = `${this.minWidth}px`;\n\n return styles;\n }\n\n @action\n resize(delta: number) {\n this.tableMeta.resizeColumn(this.column, delta);\n }\n\n @action\n save() {\n this.tableMeta.saveColWidths(this.tableMeta.visibleColumnMetas);\n }\n}\n\n/**\n * @private\n *\n * individual column width must exclude:\n * - padding\n * - margin\n * - gap (partial)\n * - any other positioning offsets\n *\n * Otherwise the table will infinitely resize itself\n */\nfunction distributeDelta(delta: number, visibleColumns: Column[]) {\n // Use a tolerance threshold to prevent infinite resize loops from subpixel rounding\n // at different zoom levels. Treat deltas smaller than 0.5px as zero.\n if (Math.abs(delta) < 0.5) return;\n\n const metas = visibleColumns.map((column) =>\n meta.forColumn(column, ColumnResizing),\n );\n\n const resizableMetas = metas.filter(\n (meta) => meta.isResizable && (delta < 0 ? meta.canShrink : true),\n );\n\n const columnDelta = delta / resizableMetas.length;\n\n for (const meta of resizableMetas) {\n assert('cannot resize a column that does not have a width', meta.width);\n meta.width = Math.max(meta.width + columnDelta, meta.minWidth);\n }\n}\n\n/**\n * @private\n *\n * Contains resizable and width information regarding the table as a whole\n */\nexport class TableMeta {\n constructor(private table: Table) {}\n\n @tracked scrollContainerHeight?: number;\n @tracked scrollContainerWidth?: number;\n\n get options() {\n return options.forTable(this.table, ColumnResizing);\n }\n\n get isResizable() {\n return this.options?.enabled ?? true;\n }\n\n get defaultColumnWidth() {\n if (!this.scrollContainerWidth) return;\n\n return (\n (this.scrollContainerWidth - this.totalInitialColumnWidths) /\n this.columnsWithoutInitialWidth.length\n );\n }\n\n get #availableColumns() {\n return columns.for(this.table, ColumnResizing);\n }\n\n get visibleColumnMetas() {\n return this.#availableColumns.map((column) =>\n meta.forColumn(column, ColumnResizing),\n );\n }\n\n get totalInitialColumnWidths() {\n return this.visibleColumnMetas.reduce(\n (acc, meta) => (acc += meta.initialWidth ?? 0),\n 0,\n );\n }\n\n get columnsWithoutInitialWidth() {\n return this.visibleColumnMetas.filter((meta) => !meta.initialWidth);\n }\n\n get totalVisibleColumnsWidth() {\n return this.visibleColumnMetas.reduce(\n (acc, column) => (acc += column.width ?? 0),\n 0,\n );\n }\n\n @action\n saveColWidths(visibleColumnMetas: ColumnMeta[]) {\n const tablePrefs = this.table.preferences;\n\n for (const column of visibleColumnMetas) {\n const existing = tablePrefs.storage.forPlugin(ColumnResizing.name);\n const columnPrefs = existing.forColumn(column.key);\n\n columnPrefs.set('width', column.width.toString());\n }\n\n tablePrefs.persist();\n }\n\n @action\n reset() {\n if (!this.scrollContainerWidth) return;\n\n for (const column of this.visibleColumnMetas) {\n column._width = undefined;\n }\n }\n\n @action\n onTableResize(entry: ResizeObserverEntry) {\n assert(\n 'scroll container element must be an HTMLElement',\n entry.target instanceof HTMLElement,\n );\n\n // For fixed layout, columns have explicit widths and should not be auto-redistributed\n if (this.options?.tableLayout === 'fixed') {\n return;\n }\n\n this.scrollContainerWidth = getAccurateClientWidth(entry.target);\n this.scrollContainerHeight = getAccurateClientHeight(entry.target);\n\n // TODO: extract this to card-list and remove it from the plugin\n // card-list will provide its own column-resizing plugin\n // by sub-classing this one, and defining its own way of calculating the \"diff\"\n const totalGap = totalGapOf(entry.target.querySelector('[role=\"row\"]'));\n const diff =\n this.scrollContainerWidth - this.totalVisibleColumnsWidth - totalGap;\n\n distributeDelta(diff, this.#availableColumns);\n }\n\n @action\n resizeColumn<DataType = unknown>(column: Column<DataType>, delta: number) {\n if (delta === 0) return;\n\n const tableLayout = this.options?.tableLayout ?? 'auto';\n\n if (tableLayout === 'fixed') {\n this.#resizeColumnFixed(column, delta);\n } else {\n this.#resizeColumnAuto(column, delta);\n }\n }\n\n /**\n * Simple column resizing for table-layout: fixed\n * Only affects the target column and respects minimum width\n */\n #resizeColumnFixed<DataType = unknown>(\n column: Column<DataType>,\n delta: number,\n ) {\n const columnMeta = meta.forColumn(column, ColumnResizing);\n const newWidth = columnMeta.width + delta;\n\n if (newWidth >= columnMeta.minWidth) {\n columnMeta.width = newWidth;\n }\n }\n\n /**\n * Complex column resizing with redistribution logic\n * Preserves existing behavior for table-layout: auto\n */\n #resizeColumnAuto<DataType = unknown>(\n column: Column<DataType>,\n delta: number,\n ) {\n /**\n * When the delta is negative, we are dragging to the next\n * when positive, we are dragging to the right\n * when dragging to the right, we want to grow the column\n * when dragging to the left, we grow the \"next\" column,\n * which shrinks the column we're dragging\n *\n * This assumes the resize handle for any column is on the right-hand\n * side of the column header\n *\n * If the resize handle were on the left-hand side of the column header\n * we'd want the column.next to be column.previous\n *\n * This is CSS dependent, and can be configured in plugin\n * options\n */\n const isDraggingRight = delta > 0;\n const position = this.options?.handlePosition ?? 'left';\n\n let growingColumn: Column<DataType> | null | undefined;\n\n if (position === 'right') {\n growingColumn = isDraggingRight ? column : columns.next(column);\n } else {\n growingColumn = isDraggingRight ? columns.previous(column) : column;\n }\n\n if (!growingColumn) return;\n\n const growingColumnMeta = meta.forColumn(growingColumn, ColumnResizing);\n\n assert(\n 'cannot resize a column that does not have a width',\n growingColumnMeta.width,\n );\n\n const shrinkableColumns =\n delta > 0\n ? columns.after(growingColumn)\n : columns.before(growingColumn).reverse();\n\n const shrinkableColumnsMetas = shrinkableColumns\n .map((column) => meta.forColumn(column, ColumnResizing))\n .filter((meta) => meta.canShrink);\n\n let remainder = Math.abs(delta);\n\n while (shrinkableColumnsMetas.length > 0) {\n const shrinkingColumnMeta = shrinkableColumnsMetas.shift();\n\n assert(\n 'cannot resize a column that does not have a width',\n shrinkingColumnMeta?.width,\n );\n\n const actualDelta = Math.min(remainder, shrinkingColumnMeta.roomToShrink);\n\n growingColumnMeta.width += actualDelta;\n shrinkingColumnMeta.width -= actualDelta;\n remainder -= actualDelta;\n }\n }\n}\n\n/**\n * @private\n * included in the same file as the plugin due to circular dependency\n *\n * This goes on the containing element\n *\n * @example\n * ```hbs\n * <div {{resizeObserver @table}}>\n * <table>\n * ```\n */\nfunction resizeObserver(element: HTMLElement, table: Table) {\n const observer = getObserver(element, table);\n\n observer.observe(element);\n\n return () => {\n observer.unobserve(element);\n };\n}\n\nconst CACHE = new WeakMap<HTMLElement, ResizeObserver>();\n\n/**\n * This is technically \"inefficient\" as you don't want too many resize\n * observers on a page, but tables are so big, that I don't see too many use cases\n * where you'd have 10+ tables on a page\n */\nfunction getObserver(element: HTMLElement, table: Table): ResizeObserver {\n let existing = CACHE.get(element);\n\n if (existing) return existing;\n\n existing = new ResizeObserver((entries: ResizeObserverEntry[]) => {\n if (isDestroyed(table) || isDestroying(table)) {\n return;\n }\n\n for (const entry of entries) {\n meta.forTable(table, ColumnResizing).onTableResize(entry);\n }\n });\n\n return existing;\n}\n"],"names":["ColumnResizing","BasePlugin","constructor","args","_defineProperty","column","ColumnMeta","table","TableMeta","element","columnMeta","meta","forColumn","setAttribute","isResizable","applyStyles","style","resizeObserver","reset","preferences","forAllColumns","delete","DEFAULT_COLUMN_OPTIONS","minWidth","ALLOWED_COLUMN_OPTIONS","_class","_initializerDefineProperty","_descriptor","_descriptor2","tableMeta","forTable","options","columnOptions","filteredOptions","Object","entries","reduce","result","k","v","includes","key","initialWidth","savedWidth","get","width","assert","parseInt","canShrink","roomToShrink","hasResizeHandle","position","handlePosition","next","columns","previous","_width","defaultColumnWidth","Math","max","value","styles","resize","delta","resizeColumn","save","saveColWidths","visibleColumnMetas","_applyDecoratedDescriptor","prototype","tracked","configurable","enumerable","writable","initializer","cached","getOwnPropertyDescriptor","action","distributeDelta","visibleColumns","abs","metas","map","resizableMetas","filter","columnDelta","length","_class2","_TableMeta_brand","WeakSet","_classPrivateMethodInitSpec","_descriptor3","_descriptor4","enabled","scrollContainerWidth","totalInitialColumnWidths","columnsWithoutInitialWidth","_classPrivateGetter","_get_availableColumns","acc","totalVisibleColumnsWidth","tablePrefs","existing","storage","forPlugin","name","columnPrefs","set","toString","persist","undefined","onTableResize","entry","target","HTMLElement","tableLayout","getAccurateClientWidth","scrollContainerHeight","getAccurateClientHeight","totalGap","totalGapOf","querySelector","diff","_assertClassBrand","_resizeColumnFixed","call","_resizeColumnAuto","_this","for","newWidth","isDraggingRight","growingColumn","growingColumnMeta","shrinkableColumns","after","before","reverse","shrinkableColumnsMetas","remainder","shrinkingColumnMeta","shift","actualDelta","min","observer","getObserver","observe","unobserve","CACHE","WeakMap","ResizeObserver","isDestroyed","isDestroying"],"mappings":"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"}
@@ -1,44 +0,0 @@
1
- import { isDestroyed, isDestroying } from '@ember/destroyable';
2
-
3
- /**
4
- * @private
5
- * included in the same file as the plugin due to circular dependency
6
- *
7
- * This goes on the containing element
8
- *
9
- * @example
10
- * ```hbs
11
- * <div {{resizeObserver @table}}>
12
- * <table>
13
- * ```
14
- */
15
- function resizeObserver(element, table) {
16
- const observer = getObserver(element, table);
17
- observer.observe(element);
18
- return () => {
19
- observer.unobserve(element);
20
- };
21
- }
22
- const CACHE = new WeakMap();
23
-
24
- /**
25
- * This is technically "inefficient" as you don't want too many resize
26
- * observers on a page, but tables are so big, that I don't see too many use cases
27
- * where you'd have 10+ tables on a page
28
- */
29
- function getObserver(element, table) {
30
- let existing = CACHE.get(element);
31
- if (existing) return existing;
32
- existing = new ResizeObserver(entries => {
33
- if (isDestroyed(table) || isDestroying(table)) {
34
- return;
35
- }
36
- for (const entry of entries) {
37
- table.handleScrollContainerResize(entry);
38
- }
39
- });
40
- return existing;
41
- }
42
-
43
- export { resizeObserver };
44
- //# sourceMappingURL=resize-observer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"resize-observer.js","sources":["../../../src/plugins/column-resizing/resize-observer.ts"],"sourcesContent":["import { isDestroyed, isDestroying } from '@ember/destroyable';\n\n/**\n * @private\n * included in the same file as the plugin due to circular dependency\n *\n * This goes on the containing element\n *\n * @example\n * ```hbs\n * <div {{resizeObserver @table}}>\n * <table>\n * ```\n */\nexport function resizeObserver(element: HTMLElement, table: any) {\n const observer = getObserver(element, table);\n\n observer.observe(element);\n\n return () => {\n observer.unobserve(element);\n };\n}\n\nconst CACHE = new WeakMap<HTMLElement, ResizeObserver>();\n\n/**\n * This is technically \"inefficient\" as you don't want too many resize\n * observers on a page, but tables are so big, that I don't see too many use cases\n * where you'd have 10+ tables on a page\n */\nfunction getObserver(element: HTMLElement, table: any): ResizeObserver {\n let existing = CACHE.get(element);\n\n if (existing) return existing;\n\n existing = new ResizeObserver((entries: ResizeObserverEntry[]) => {\n if (isDestroyed(table) || isDestroying(table)) {\n return;\n }\n\n for (const entry of entries) {\n table.handleScrollContainerResize(entry);\n }\n });\n\n return existing;\n}\n"],"names":["resizeObserver","element","table","observer","getObserver","observe","unobserve","CACHE","WeakMap","existing","get","ResizeObserver","entries","isDestroyed","isDestroying","entry","handleScrollContainerResize"],"mappings":";;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASA,cAAcA,CAACC,OAAoB,EAAEC,KAAU,EAAE;AAC/D,EAAA,MAAMC,QAAQ,GAAGC,WAAW,CAACH,OAAO,EAAEC,KAAK,CAAC;AAE5CC,EAAAA,QAAQ,CAACE,OAAO,CAACJ,OAAO,CAAC;AAEzB,EAAA,OAAO,MAAM;AACXE,IAAAA,QAAQ,CAACG,SAAS,CAACL,OAAO,CAAC;GAC5B;AACH;AAEA,MAAMM,KAAK,GAAG,IAAIC,OAAO,EAA+B;;AAExD;AACA;AACA;AACA;AACA;AACA,SAASJ,WAAWA,CAACH,OAAoB,EAAEC,KAAU,EAAkB;AACrE,EAAA,IAAIO,QAAQ,GAAGF,KAAK,CAACG,GAAG,CAACT,OAAO,CAAC;EAEjC,IAAIQ,QAAQ,EAAE,OAAOA,QAAQ;AAE7BA,EAAAA,QAAQ,GAAG,IAAIE,cAAc,CAAEC,OAA8B,IAAK;IAChE,IAAIC,WAAW,CAACX,KAAK,CAAC,IAAIY,YAAY,CAACZ,KAAK,CAAC,EAAE;AAC7C,MAAA;AACF;AAEA,IAAA,KAAK,MAAMa,KAAK,IAAIH,OAAO,EAAE;AAC3BV,MAAAA,KAAK,CAACc,2BAA2B,CAACD,KAAK,CAAC;AAC1C;AACF,GAAC,CAAC;AAEF,EAAA,OAAON,QAAQ;AACjB;;;;"}
@@ -1,44 +0,0 @@
1
- /**
2
- We want to make sure we get the clientWidth rather than the
3
- offsetWidth so that the width of the scrollbar is not included when we're
4
- resizing the columns in the table so that they fit within the scroll
5
- container
6
-
7
- Ideally we would just use `entry.contentRect.width`, which we can access
8
- without triggering any reflows. Unfortunately there are differences in the
9
- way that this works in Chrome vs Firefox. In Chrome, the
10
- `entry.contentRect.width` works the same as `entry.target.clientWidth`,
11
- which does not include the width that is taken up by the vertical scrollbar
12
- if the element overflows. In Firefox the `entry.contentRect.width` is the
13
- same as `entry.target.offsetWidth`, which does include the width taken up by
14
- the scrollbar.
15
-
16
- We use `getBoundingClientRect()` because it does not round the value to an
17
- integer, which can sometimes cause subpixel gaps.
18
- **/
19
- const getAccurateClientWidth = element => {
20
- const style = getComputedStyle(element);
21
- const padding = parseFloat(style.paddingLeft) + parseFloat(style.paddingRight);
22
- const scrollbarWidth = element.offsetWidth - element.clientWidth;
23
- return element.getBoundingClientRect().width - padding - scrollbarWidth;
24
- };
25
- const totalGapOf = element => {
26
- if (!element) return 0;
27
- const style = getComputedStyle(element);
28
- const gapSize = parseFloat(style.columnGap);
29
- const cells = element.querySelectorAll('[role="cell"], [role="columnheader"]');
30
- let totalCellPadding = 0;
31
- for (const cell of cells) {
32
- const style = getComputedStyle(cell);
33
- const padding = parseFloat(style.paddingLeft) + parseFloat(style.paddingRight);
34
- totalCellPadding += padding;
35
- }
36
- return gapSize * (element.children.length - 1) + totalCellPadding;
37
- };
38
- const getAccurateClientHeight = element => {
39
- const scrollbarHeight = element.offsetHeight - element.clientHeight;
40
- return element.getBoundingClientRect().height - scrollbarHeight;
41
- };
42
-
43
- export { getAccurateClientHeight, getAccurateClientWidth, totalGapOf };
44
- //# sourceMappingURL=utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sources":["../../../src/plugins/column-resizing/utils.ts"],"sourcesContent":["/**\n We want to make sure we get the clientWidth rather than the\n offsetWidth so that the width of the scrollbar is not included when we're\n resizing the columns in the table so that they fit within the scroll\n container\n\n Ideally we would just use `entry.contentRect.width`, which we can access\n without triggering any reflows. Unfortunately there are differences in the\n way that this works in Chrome vs Firefox. In Chrome, the\n `entry.contentRect.width` works the same as `entry.target.clientWidth`,\n which does not include the width that is taken up by the vertical scrollbar\n if the element overflows. In Firefox the `entry.contentRect.width` is the\n same as `entry.target.offsetWidth`, which does include the width taken up by\n the scrollbar.\n\n We use `getBoundingClientRect()` because it does not round the value to an\n integer, which can sometimes cause subpixel gaps.\n**/\nexport const getAccurateClientWidth = (element: HTMLElement) => {\n const style = getComputedStyle(element);\n const padding =\n parseFloat(style.paddingLeft) + parseFloat(style.paddingRight);\n const scrollbarWidth = element.offsetWidth - element.clientWidth;\n\n return element.getBoundingClientRect().width - padding - scrollbarWidth;\n};\n\nexport const totalGapOf = (element?: Element | null) => {\n if (!element) return 0;\n\n const style = getComputedStyle(element);\n const gapSize = parseFloat(style.columnGap);\n const cells = element.querySelectorAll(\n '[role=\"cell\"], [role=\"columnheader\"]',\n );\n\n let totalCellPadding = 0;\n\n for (const cell of cells) {\n const style = getComputedStyle(cell);\n const padding =\n parseFloat(style.paddingLeft) + parseFloat(style.paddingRight);\n\n totalCellPadding += padding;\n }\n\n return gapSize * (element.children.length - 1) + totalCellPadding;\n};\n\nexport const getAccurateClientHeight = (element: HTMLElement) => {\n const scrollbarHeight = element.offsetHeight - element.clientHeight;\n\n return element.getBoundingClientRect().height - scrollbarHeight;\n};\n"],"names":["getAccurateClientWidth","element","style","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","scrollbarWidth","offsetWidth","clientWidth","getBoundingClientRect","width","totalGapOf","gapSize","columnGap","cells","querySelectorAll","totalCellPadding","cell","children","length","getAccurateClientHeight","scrollbarHeight","offsetHeight","clientHeight","height"],"mappings":"AAAA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACaA,MAAAA,sBAAsB,GAAIC,OAAoB,IAAK;AAC9D,EAAA,MAAMC,KAAK,GAAGC,gBAAgB,CAACF,OAAO,CAAC;AACvC,EAAA,MAAMG,OAAO,GACXC,UAAU,CAACH,KAAK,CAACI,WAAW,CAAC,GAAGD,UAAU,CAACH,KAAK,CAACK,YAAY,CAAC;EAChE,MAAMC,cAAc,GAAGP,OAAO,CAACQ,WAAW,GAAGR,OAAO,CAACS,WAAW;EAEhE,OAAOT,OAAO,CAACU,qBAAqB,EAAE,CAACC,KAAK,GAAGR,OAAO,GAAGI,cAAc;AACzE;AAEaK,MAAAA,UAAU,GAAIZ,OAAwB,IAAK;AACtD,EAAA,IAAI,CAACA,OAAO,EAAE,OAAO,CAAC;AAEtB,EAAA,MAAMC,KAAK,GAAGC,gBAAgB,CAACF,OAAO,CAAC;AACvC,EAAA,MAAMa,OAAO,GAAGT,UAAU,CAACH,KAAK,CAACa,SAAS,CAAC;AAC3C,EAAA,MAAMC,KAAK,GAAGf,OAAO,CAACgB,gBAAgB,CACpC,sCACF,CAAC;EAED,IAAIC,gBAAgB,GAAG,CAAC;AAExB,EAAA,KAAK,MAAMC,IAAI,IAAIH,KAAK,EAAE;AACxB,IAAA,MAAMd,KAAK,GAAGC,gBAAgB,CAACgB,IAAI,CAAC;AACpC,IAAA,MAAMf,OAAO,GACXC,UAAU,CAACH,KAAK,CAACI,WAAW,CAAC,GAAGD,UAAU,CAACH,KAAK,CAACK,YAAY,CAAC;AAEhEW,IAAAA,gBAAgB,IAAId,OAAO;AAC7B;EAEA,OAAOU,OAAO,IAAIb,OAAO,CAACmB,QAAQ,CAACC,MAAM,GAAG,CAAC,CAAC,GAAGH,gBAAgB;AACnE;AAEaI,MAAAA,uBAAuB,GAAIrB,OAAoB,IAAK;EAC/D,MAAMsB,eAAe,GAAGtB,OAAO,CAACuB,YAAY,GAAGvB,OAAO,CAACwB,YAAY;EAEnE,OAAOxB,OAAO,CAACU,qBAAqB,EAAE,CAACe,MAAM,GAAGH,eAAe;AACjE;;;;"}
@@ -1,25 +0,0 @@
1
- import { meta } from '../-private/base.js';
2
- import { ColumnVisibility } from './plugin.js';
3
-
4
- /**
5
- * Hide a column
6
- */
7
- const hide = column => meta.forColumn(column, ColumnVisibility).hide();
8
-
9
- /**
10
- * Show a column
11
- */
12
- const show = column => meta.forColumn(column, ColumnVisibility).show();
13
-
14
- /**
15
- * Ask if a column is presently supposed to be visible
16
- */
17
- const isVisible = column => meta.forColumn(column, ColumnVisibility).isVisible;
18
-
19
- /**
20
- * Ask if a column is presently supposed to be hidden
21
- */
22
- const isHidden = column => meta.forColumn(column, ColumnVisibility).isHidden;
23
-
24
- export { hide, isHidden, isVisible, show };
25
- //# sourceMappingURL=helpers.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"helpers.js","sources":["../../../src/plugins/column-visibility/helpers.ts"],"sourcesContent":["import { meta } from '../-private/base.ts';\nimport { ColumnVisibility } from './plugin.ts';\n\nimport type { Column } from '../../index.ts';\n\n/**\n * Hide a column\n */\nexport const hide = <DataType = unknown>(column: Column<DataType>) =>\n meta.forColumn(column, ColumnVisibility).hide();\n\n/**\n * Show a column\n */\nexport const show = <DataType = unknown>(column: Column<DataType>) =>\n meta.forColumn(column, ColumnVisibility).show();\n\n/**\n * Ask if a column is presently supposed to be visible\n */\nexport const isVisible = <DataType = unknown>(column: Column<DataType>) =>\n meta.forColumn(column, ColumnVisibility).isVisible;\n\n/**\n * Ask if a column is presently supposed to be hidden\n */\nexport const isHidden = <DataType = unknown>(column: Column<DataType>) =>\n meta.forColumn(column, ColumnVisibility).isHidden;\n"],"names":["hide","column","meta","forColumn","ColumnVisibility","show","isVisible","isHidden"],"mappings":";;;AAKA;AACA;AACA;MACaA,IAAI,GAAwBC,MAAwB,IAC/DC,IAAI,CAACC,SAAS,CAACF,MAAM,EAAEG,gBAAgB,CAAC,CAACJ,IAAI;;AAE/C;AACA;AACA;MACaK,IAAI,GAAwBJ,MAAwB,IAC/DC,IAAI,CAACC,SAAS,CAACF,MAAM,EAAEG,gBAAgB,CAAC,CAACC,IAAI;;AAE/C;AACA;AACA;AACaC,MAAAA,SAAS,GAAwBL,MAAwB,IACpEC,IAAI,CAACC,SAAS,CAACF,MAAM,EAAEG,gBAAgB,CAAC,CAACE;;AAE3C;AACA;AACA;AACaC,MAAAA,QAAQ,GAAwBN,MAAwB,IACnEC,IAAI,CAACC,SAAS,CAACF,MAAM,EAAEG,gBAAgB,CAAC,CAACG;;;;"}
@@ -1,3 +0,0 @@
1
- export { hide, isHidden, isVisible, show } from './helpers.js';
2
- export { ColumnVisibility, ColumnVisibility as Plugin } from './plugin.js';
3
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}