@web-atoms/core 2.6.24 → 2.6.25

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 (120) hide show
  1. package/dist-esm/App.js +231 -235
  2. package/dist-esm/Atom.js +93 -96
  3. package/dist-esm/MockApp.js +17 -18
  4. package/dist-esm/Pack.js +1 -3
  5. package/dist-esm/core/AtomBinder.js +189 -187
  6. package/dist-esm/core/AtomComponent.js +479 -502
  7. package/dist-esm/core/AtomDispatcher.js +46 -48
  8. package/dist-esm/core/AtomDisposableList.js +24 -25
  9. package/dist-esm/core/AtomEnumerator.js +15 -16
  10. package/dist-esm/core/AtomList.js +193 -192
  11. package/dist-esm/core/AtomLoader.js +229 -215
  12. package/dist-esm/core/AtomMap.js +7 -8
  13. package/dist-esm/core/AtomOnce.js +22 -24
  14. package/dist-esm/core/AtomSelectableList.js +240 -243
  15. package/dist-esm/core/AtomUri.js +70 -72
  16. package/dist-esm/core/AtomWatcher.js +105 -111
  17. package/dist-esm/core/Bind.js +271 -269
  18. package/dist-esm/core/BindableProperty.js +26 -27
  19. package/dist-esm/core/CancelTokenFactory.js +21 -24
  20. package/dist-esm/core/Color.js +1 -2
  21. package/dist-esm/core/Colors.js +545 -231
  22. package/dist-esm/core/Command.js +236 -223
  23. package/dist-esm/core/Defer.js +21 -22
  24. package/dist-esm/core/EventScope.js +96 -88
  25. package/dist-esm/core/ExpressionParser.js +132 -144
  26. package/dist-esm/core/ExtendControl.js +7 -8
  27. package/dist-esm/core/FormattedError.js +7 -8
  28. package/dist-esm/core/FormattedString.js +4 -5
  29. package/dist-esm/core/Hacks.js +41 -42
  30. package/dist-esm/core/IFetchEvent.js +1 -2
  31. package/dist-esm/core/IScreen.js +1 -2
  32. package/dist-esm/core/IValueConverter.js +1 -2
  33. package/dist-esm/core/InheritedProperty.js +61 -63
  34. package/dist-esm/core/InjectProperty.js +12 -13
  35. package/dist-esm/core/KeyValuePairs.js +1 -2
  36. package/dist-esm/core/Markdown.js +14 -17
  37. package/dist-esm/core/MarkdownError.js +6 -7
  38. package/dist-esm/core/PropertyBinding.js +1 -2
  39. package/dist-esm/core/PropertyMap.js +28 -27
  40. package/dist-esm/core/Route.js +149 -148
  41. package/dist-esm/core/SingleInvoker.js +32 -35
  42. package/dist-esm/core/StringHelper.js +49 -51
  43. package/dist-esm/core/TransientDisposable.js +14 -16
  44. package/dist-esm/core/WatchProperty.js +18 -17
  45. package/dist-esm/core/WebImage.js +7 -8
  46. package/dist-esm/core/XNode.js +134 -117
  47. package/dist-esm/core/sleep.js +21 -24
  48. package/dist-esm/core/types.js +102 -103
  49. package/dist-esm/di/DISingleton.js +7 -5
  50. package/dist-esm/di/DITransient.js +7 -5
  51. package/dist-esm/di/IMockOrInject.js +1 -2
  52. package/dist-esm/di/IServiceProvider.js +1 -2
  53. package/dist-esm/di/Inject.js +67 -67
  54. package/dist-esm/di/Register.js +25 -26
  55. package/dist-esm/di/RegisterScoped.js +4 -3
  56. package/dist-esm/di/RegisterSingleton.js +4 -3
  57. package/dist-esm/di/ServiceCollection.js +38 -37
  58. package/dist-esm/di/ServiceProvider.js +94 -94
  59. package/dist-esm/di/TypeKey.js +13 -12
  60. package/dist-esm/services/BusyIndicatorService.js +7 -11
  61. package/dist-esm/services/CacheService.js +54 -62
  62. package/dist-esm/services/FetchBuilder.js +327 -278
  63. package/dist-esm/services/JsonService.js +118 -116
  64. package/dist-esm/services/MockNavigationService.js +127 -126
  65. package/dist-esm/services/NavigationService.js +95 -102
  66. package/dist-esm/services/ReferenceService.js +30 -33
  67. package/dist-esm/services/http/AjaxOptions.js +1 -3
  68. package/dist-esm/services/http/JsonError.js +16 -15
  69. package/dist-esm/services/http/RestService.js +314 -323
  70. package/dist-esm/style/StyleRule.js +1 -2
  71. package/dist-esm/test.js +0 -1
  72. package/dist-esm/unit/AtomTest.js +10 -11
  73. package/dist-esm/view-model/Action.js +258 -223
  74. package/dist-esm/view-model/AtomViewModel.js +234 -232
  75. package/dist-esm/view-model/AtomWindowViewModel.js +13 -14
  76. package/dist-esm/view-model/BindableUrlParameter.js +7 -8
  77. package/dist-esm/view-model/Delay.js +21 -25
  78. package/dist-esm/view-model/Disposable.js +28 -29
  79. package/dist-esm/view-model/Load.js +72 -73
  80. package/dist-esm/view-model/Once.js +33 -35
  81. package/dist-esm/view-model/baseTypes.js +4 -5
  82. package/dist-esm/view-model/bindPromise.js +24 -27
  83. package/dist-esm/view-model/bindProperty.js +3 -4
  84. package/dist-esm/view-model/bindUrlParameter.js +39 -43
  85. package/dist-esm/web/controls/AtomComboBox.js +56 -63
  86. package/dist-esm/web/controls/AtomControl.js +485 -490
  87. package/dist-esm/web/controls/AtomGridSplitter.js +57 -50
  88. package/dist-esm/web/controls/AtomGridView.js +230 -222
  89. package/dist-esm/web/controls/AtomItemsControl.js +677 -688
  90. package/dist-esm/web/controls/AtomPage.js +6 -7
  91. package/dist-esm/web/controls/AtomTemplate.js +1 -3
  92. package/dist-esm/web/controls/AtomTemplateControl.js +28 -29
  93. package/dist-esm/web/controls/AtomViewStack.js +19 -20
  94. package/dist-esm/web/core/AtomUI.js +200 -200
  95. package/dist-esm/web/core/Encoder.js +142 -152
  96. package/dist-esm/web/core/HtmlNode.js +141 -139
  97. package/dist-esm/web/images/Busy.js +1 -2
  98. package/dist-esm/web/images/BusyDataUrl.js +2 -869
  99. package/dist-esm/web/images/Button.js +1 -2
  100. package/dist-esm/web/images/ButtonDataUrl.js +2 -30
  101. package/dist-esm/web/images/CloseButton.js +1 -2
  102. package/dist-esm/web/images/CloseButtonDataUrl.js +2 -30
  103. package/dist-esm/web/images/CloseButtonHover.js +1 -2
  104. package/dist-esm/web/images/CloseButtonHoverDataUrl.js +2 -24
  105. package/dist-esm/web/services/LastTarget.js +31 -29
  106. package/dist-esm/web/services/MarkdownService.js +19 -31
  107. package/dist-esm/web/services/NotificationPopup.js +28 -21
  108. package/dist-esm/web/services/PopupService.js +512 -478
  109. package/dist-esm/web/services/PopupWindow.js +266 -247
  110. package/dist-esm/web/styles/AtomAlertWindowStyle.js +39 -40
  111. package/dist-esm/web/styles/AtomFrameStyle.js +15 -16
  112. package/dist-esm/web/styles/AtomNotificationStyle.js +19 -20
  113. package/dist-esm/web/styles/AtomPageLinkStyle.js +11 -12
  114. package/dist-esm/web/styles/AtomPopupStyle.js +9 -10
  115. package/dist-esm/web/styles/AtomStyle.js +61 -64
  116. package/dist-esm/web/styles/AtomStyleSheet.js +50 -51
  117. package/dist-esm/web/styles/AtomWindowStyle.js +116 -117
  118. package/dist-esm/web/styles/IStyleDeclaration.js +1 -2
  119. package/dist-esm/web/styles/StyleBuilder.js +79 -80
  120. package/package.json +1 -1
@@ -5,702 +5,691 @@ import XNode from "../../core/XNode.js";
5
5
  import { AtomUI, ChildEnumerator } from "../../web/core/AtomUI.js";
6
6
  import { AtomControl } from "./AtomControl.js";
7
7
  export class AtomItemsControl extends AtomControl {
8
- constructor() {
9
- super(...arguments);
10
- this.mValue = undefined;
11
- this.mFilter = undefined;
12
- this.mFirstChild = null;
13
- this.mLastChild = null;
14
- this.mScrollerSetup = false;
15
- this.mScopes = null;
16
- this.mItemsDisposable = null;
17
- this.isUpdating = false;
18
- }
19
- static { this.itemTemplate = XNode.prepare("itemTemplate", true, true); }
20
- get itemsPresenter() {
21
- return this.mItemsPresenter || (this.mItemsPresenter = this.element);
22
- }
23
- set itemsPresenter(v) {
24
- this.mItemsPresenter = v;
25
- AtomBinder.refreshValue(this, "itemsPresenter");
26
- }
27
- get value() {
28
- if (this.allowMultipleSelection) {
29
- let items = this.mSelectedItems;
30
- if (items.length === 0) {
31
- if (this.mValue !== undefined) {
32
- return this.mValue;
33
- }
34
- return null;
35
- }
36
- items = items.map((m) => m[this.valuePath]);
37
- if (this.valueSeparator) {
38
- items = items.join(this.valueSeparator);
39
- }
40
- return items;
41
- }
42
- let s = this.selectedItem;
43
- if (!s) {
44
- if (this.mValue !== undefined) {
45
- return this.mValue;
46
- }
47
- return null;
48
- }
49
- if (this.valuePath) {
50
- s = s[this.valuePath];
51
- }
52
- return s;
53
- }
54
- set value(v) {
55
- this.mValue = v;
56
- const dataItems = this.items;
57
- if (!dataItems) {
58
- return;
59
- }
60
- const sItems = this.selectedItems;
61
- if (v === undefined || v === null) {
62
- AtomBinder.clear(sItems);
63
- return;
64
- }
65
- if (this.allowMultipleSelection && this.valueSeparator) {
66
- if (typeof v !== "string") {
67
- v = "" + v;
68
- }
69
- v = v.split(this.valueSeparator);
70
- }
71
- else {
72
- v = [v];
73
- }
74
- sItems.length = 0;
75
- const vp = this.valuePath;
76
- for (const item of v) {
77
- const dataItem = dataItems.find((i) => i[vp] == v);
78
- if (dataItem) {
79
- sItems.push(dataItem);
80
- }
81
- }
82
- AtomBinder.refreshItems(sItems);
83
- }
84
- get items() {
85
- return this.mItems;
86
- }
87
- set items(v) {
88
- if (this.mItemsDisposable) {
89
- this.mItemsDisposable.dispose();
90
- this.mItemsDisposable = null;
91
- }
92
- this.mItems = v;
93
- if (v != null) {
94
- this.mItemsDisposable = this.registerDisposable(AtomBinder.add_CollectionChanged(v, (target, key, index, item) => {
95
- this.onCollectionChangedInternal(key, index, item);
96
- }));
97
- }
98
- AtomBinder.refreshValue(this, "items");
99
- }
100
- get selectedItem() {
101
- if (this.selectedItems.length > 0) {
102
- return this.selectedItems[0];
8
+ constructor() {
9
+ super(...arguments);
10
+ this.mValue = undefined;
11
+ this.mFilter = undefined;
12
+ this.mFirstChild = null;
13
+ this.mLastChild = null;
14
+ this.mScrollerSetup = false;
15
+ this.mScopes = null;
16
+ this.mItemsDisposable = null;
17
+ this.isUpdating = false;
18
+ }
19
+ static {
20
+ this.itemTemplate = XNode.prepare("itemTemplate", true, true);
21
+ }
22
+ get itemsPresenter() {
23
+ return this.mItemsPresenter || (this.mItemsPresenter = this.element);
24
+ }
25
+ set itemsPresenter(v) {
26
+ this.mItemsPresenter = v;
27
+ AtomBinder.refreshValue(this, "itemsPresenter");
28
+ }
29
+ get value() {
30
+ if (this.allowMultipleSelection) {
31
+ let items = this.mSelectedItems;
32
+ if (items.length === 0) {
33
+ if (this.mValue !== undefined) {
34
+ return this.mValue;
103
35
  }
104
36
  return null;
105
- }
106
- set selectedItem(value) {
107
- if (value !== undefined && value !== null) {
108
- this.mSelectedItems.length = 1;
109
- this.mSelectedItems[0] = value;
110
- }
111
- else {
112
- this.mSelectedItems.length = 0;
113
- }
114
- AtomBinder.refreshItems(this.mSelectedItems);
115
- }
116
- get selectedItems() {
117
- return this.mSelectedItems || (this.selectedItems = []);
118
- }
119
- set selectedItems(v) {
120
- if (this.mSelectedItemsWatcher) {
121
- this.mSelectedItemsWatcher.dispose();
122
- this.mSelectedItemsWatcher = null;
123
- }
124
- this.mSelectedItems = v;
125
- if (v) {
126
- this.mSelectedItemsWatcher = this.registerDisposable(AtomBinder.add_CollectionChanged(v, (t, k, i, item) => {
127
- this.onSelectedItemsChanged(k, i, item);
128
- }));
129
- }
130
- }
131
- get selectedIndex() {
132
- if (!this.mItems) {
133
- return -1;
134
- }
135
- const item = this.selectedItem;
136
- return this.mItems.indexOf(item);
137
- }
138
- set selectedIndex(n) {
139
- if (!this.mItems) {
140
- return;
141
- }
142
- if (n <= -1 || n >= this.mItems.length) {
143
- this.selectedItem = null;
144
- return;
145
- }
146
- this.selectedItem = this.mItems[n];
147
- }
148
- hasProperty(name) {
149
- if (/^(items|itemsPresenter|value|valuePath|valueSeparator|label|labelPath|selectedItems|selectedItem|selectedIndex|uiVirtualize|viewModel|localViewModel|data)$/.test(name)) {
150
- return true;
151
- }
152
- return super.hasProperty(name);
153
- }
154
- dispose(e) {
155
- this.items = null;
156
- this.selectedItems = null;
157
- super.dispose(e);
158
- }
159
- onPropertyChanged(name) {
160
- switch (name) {
161
- case "itemsPresenter":
162
- case "itemTemplate":
163
- case "labelPath":
164
- case "valuePath":
165
- case "items":
166
- case "filter":
167
- case "sort":
168
- if (this.mItems) {
169
- this.invalidateItems();
170
- }
171
- break;
172
- }
173
- }
174
- set selectAll(v) {
175
- if (v === undefined || v === null) {
176
- return;
177
- }
178
- this.mSelectedItems.length = 0;
179
- const items = this.mItems;
180
- if (v && items) {
181
- for (const itm of items) {
182
- this.mSelectedItems.push(itm);
183
- }
184
- }
185
- this.mSelectAll = true;
186
- AtomBinder.refreshItems(this.mSelectedItems);
187
- }
188
- resetVirtualContainer() {
189
- const ip = this.itemsPresenter;
190
- if (ip) {
191
- this.disposeChildren(ip);
192
- }
193
- this.mFirstChild = null;
194
- this.mLastChild = null;
195
- this.mScrollerSetup = false;
196
- this.mScopes = null;
197
- this.unbindEvent(this.mVirtualContainer, "scroll");
198
- }
199
- postVirtualCollectionChanged() {
200
- this.app.callLater(() => {
201
- this.onVirtualCollectionChanged();
202
- });
203
- }
204
- onVirtualCollectionChanged() {
205
- const ip = this.itemsPresenter;
206
- const items = this.items;
207
- if (!items.length) {
208
- this.resetVirtualContainer();
209
- return;
210
- }
211
- this.validateScroller();
212
- const fc = this.mFirstChild;
213
- const lc = this.mLastChild;
214
- const vc = this.mVirtualContainer;
215
- const vcHeight = AtomUI.innerHeight(vc);
216
- const vcScrollHeight = vc.scrollHeight;
217
- if (isNaN(vcHeight) || vcHeight <= 0 || vcScrollHeight <= 0) {
218
- setTimeout(() => {
219
- this.onVirtualCollectionChanged();
220
- }, 1000);
221
- return;
222
- }
223
- const vcWidth = AtomUI.innerWidth(vc);
224
- let avgHeight = this.mAvgHeight;
225
- let avgWidth = this.mAvgWidth;
226
- const itemsHeight = vc.scrollHeight - AtomUI.outerHeight(fc) - AtomUI.outerHeight(lc);
227
- const itemsWidth = AtomUI.innerWidth(ip);
228
- const element = this.element;
229
- let ce;
230
- let ae = new AtomEnumerator(items);
231
- if (this.mTraining) {
232
- if (vcHeight >= itemsHeight) {
233
- ce = lc.previousElementSibling;
234
- if (ce !== fc) {
235
- const data = ce.atomControl.data;
236
- while (ae.next()) {
237
- if (ae.current === data) {
238
- break;
239
- }
240
- }
241
- }
242
- if (ae.next()) {
243
- const data = ae.current;
244
- const elementChild = this.createChild(null, data);
245
- ip.insertBefore(elementChild.element, lc);
246
- this.postVirtualCollectionChanged();
247
- }
37
+ }
38
+ items = items.map(m => m[this.valuePath]);
39
+ if (this.valueSeparator) {
40
+ items = items.join(this.valueSeparator);
41
+ }
42
+ return items;
43
+ }
44
+ let s = this.selectedItem;
45
+ if (!s) {
46
+ if (this.mValue !== undefined) {
47
+ return this.mValue;
48
+ }
49
+ return null;
50
+ }
51
+ if (this.valuePath) {
52
+ s = s[this.valuePath];
53
+ }
54
+ return s;
55
+ }
56
+ set value(v) {
57
+ this.mValue = v;
58
+ const dataItems = this.items;
59
+ if (!dataItems) {
60
+ return;
61
+ }
62
+ const sItems = this.selectedItems;
63
+ if (v === undefined || v === null) {
64
+ AtomBinder.clear(sItems);
65
+ return;
66
+ }
67
+ if (this.allowMultipleSelection && this.valueSeparator) {
68
+ if (typeof v !== "string") {
69
+ v = "" + v;
70
+ }
71
+ v = v.split(this.valueSeparator);
72
+ } else {
73
+ v = [v];
74
+ }
75
+ sItems.length = 0;
76
+ const vp = this.valuePath;
77
+ for (const item of v) {
78
+ const dataItem = dataItems.find(i => i[vp] == v);
79
+ if (dataItem) {
80
+ sItems.push(dataItem);
81
+ }
82
+ }
83
+ AtomBinder.refreshItems(sItems);
84
+ }
85
+ get items() {
86
+ return this.mItems;
87
+ }
88
+ set items(v) {
89
+ if (this.mItemsDisposable) {
90
+ this.mItemsDisposable.dispose();
91
+ this.mItemsDisposable = null;
92
+ }
93
+ this.mItems = v;
94
+ if (v != null) {
95
+ this.mItemsDisposable = this.registerDisposable(AtomBinder.add_CollectionChanged(v, (target, key, index, item) => {
96
+ this.onCollectionChangedInternal(key, index, item);
97
+ }));
98
+ }
99
+ AtomBinder.refreshValue(this, "items");
100
+ }
101
+ get selectedItem() {
102
+ if (this.selectedItems.length > 0) {
103
+ return this.selectedItems[0];
104
+ }
105
+ return null;
106
+ }
107
+ set selectedItem(value) {
108
+ if (value !== undefined && value !== null) {
109
+ this.mSelectedItems.length = 1;
110
+ this.mSelectedItems[0] = value;
111
+ } else {
112
+ this.mSelectedItems.length = 0;
113
+ }
114
+ AtomBinder.refreshItems(this.mSelectedItems);
115
+ }
116
+ get selectedItems() {
117
+ return this.mSelectedItems || (this.selectedItems = []);
118
+ }
119
+ set selectedItems(v) {
120
+ if (this.mSelectedItemsWatcher) {
121
+ this.mSelectedItemsWatcher.dispose();
122
+ this.mSelectedItemsWatcher = null;
123
+ }
124
+ this.mSelectedItems = v;
125
+ if (v) {
126
+ this.mSelectedItemsWatcher = this.registerDisposable(AtomBinder.add_CollectionChanged(v, (t, k, i, item) => {
127
+ this.onSelectedItemsChanged(k, i, item);
128
+ }));
129
+ }
130
+ }
131
+ get selectedIndex() {
132
+ if (!this.mItems) {
133
+ return -1;
134
+ }
135
+ const item = this.selectedItem;
136
+ return this.mItems.indexOf(item);
137
+ }
138
+ set selectedIndex(n) {
139
+ if (!this.mItems) {
140
+ return;
141
+ }
142
+ if (n <= -1 || n >= this.mItems.length) {
143
+ this.selectedItem = null;
144
+ return;
145
+ }
146
+ this.selectedItem = this.mItems[n];
147
+ }
148
+ hasProperty(name) {
149
+ if (/^(items|itemsPresenter|value|valuePath|valueSeparator|label|labelPath|selectedItems|selectedItem|selectedIndex|uiVirtualize|viewModel|localViewModel|data)$/.test(name)) {
150
+ return true;
151
+ }
152
+ return super.hasProperty(name);
153
+ }
154
+ dispose(e) {
155
+ this.items = null;
156
+ this.selectedItems = null;
157
+ super.dispose(e);
158
+ }
159
+ onPropertyChanged(name) {
160
+ switch (name) {
161
+ case "itemsPresenter":
162
+ case "itemTemplate":
163
+ case "labelPath":
164
+ case "valuePath":
165
+ case "items":
166
+ case "filter":
167
+ case "sort":
168
+ if (this.mItems) {
169
+ this.invalidateItems();
170
+ }
171
+ break;
172
+ }
173
+ }
174
+ set selectAll(v) {
175
+ if (v === undefined || v === null) {
176
+ return;
177
+ }
178
+ this.mSelectedItems.length = 0;
179
+ const items = this.mItems;
180
+ if (v && items) {
181
+ for (const itm of items) {
182
+ this.mSelectedItems.push(itm);
183
+ }
184
+ }
185
+ this.mSelectAll = true;
186
+ AtomBinder.refreshItems(this.mSelectedItems);
187
+ }
188
+ resetVirtualContainer() {
189
+ const ip = this.itemsPresenter;
190
+ if (ip) {
191
+ this.disposeChildren(ip);
192
+ }
193
+ this.mFirstChild = null;
194
+ this.mLastChild = null;
195
+ this.mScrollerSetup = false;
196
+ this.mScopes = null;
197
+ this.unbindEvent(this.mVirtualContainer, "scroll");
198
+ }
199
+ postVirtualCollectionChanged() {
200
+ this.app.callLater(() => {
201
+ this.onVirtualCollectionChanged();
202
+ });
203
+ }
204
+ onVirtualCollectionChanged() {
205
+ const ip = this.itemsPresenter;
206
+ const items = this.items;
207
+ if (!items.length) {
208
+ this.resetVirtualContainer();
209
+ return;
210
+ }
211
+ this.validateScroller();
212
+ const fc = this.mFirstChild;
213
+ const lc = this.mLastChild;
214
+ const vc = this.mVirtualContainer;
215
+ const vcHeight = AtomUI.innerHeight(vc);
216
+ const vcScrollHeight = vc.scrollHeight;
217
+ if (isNaN(vcHeight) || vcHeight <= 0 || vcScrollHeight <= 0) {
218
+ setTimeout(() => {
219
+ this.onVirtualCollectionChanged();
220
+ }, 1000);
221
+ return;
222
+ }
223
+ const vcWidth = AtomUI.innerWidth(vc);
224
+ let avgHeight = this.mAvgHeight;
225
+ let avgWidth = this.mAvgWidth;
226
+ const itemsHeight = vc.scrollHeight - AtomUI.outerHeight(fc) - AtomUI.outerHeight(lc);
227
+ const itemsWidth = AtomUI.innerWidth(ip);
228
+ const element = this.element;
229
+ let ce;
230
+ let ae = new AtomEnumerator(items);
231
+ if (this.mTraining) {
232
+ if (vcHeight >= itemsHeight) {
233
+ ce = lc.previousElementSibling;
234
+ if (ce !== fc) {
235
+ const data = ce.atomControl.data;
236
+ while (ae.next()) {
237
+ if (ae.current === data) {
238
+ break;
248
239
  }
249
- else {
250
- let totalVisibleItems = 0;
251
- ce = fc.nextElementSibling;
252
- let allHeight = 0;
253
- let allWidth = 0;
254
- while (ce !== lc) {
255
- totalVisibleItems++;
256
- allHeight += AtomUI.outerHeight(ce);
257
- allWidth += AtomUI.outerWidth(ce);
258
- ce = ce.nextElementSibling;
259
- }
260
- avgHeight = allHeight / totalVisibleItems;
261
- avgWidth = allWidth / totalVisibleItems;
262
- totalVisibleItems--;
263
- this.mAvgHeight = avgHeight;
264
- this.mAvgWidth = avgWidth;
265
- const columns = Math.floor(vcWidth / avgWidth);
266
- const allRows = Math.ceil(items.length / columns);
267
- const visibleRows = Math.ceil(totalVisibleItems / columns);
268
- console.log({
269
- avgWidth,
270
- avgHeight,
271
- totalVisibleItems,
272
- allRows,
273
- columns
274
- });
275
- this.mAllRows = allRows;
276
- this.mColumns = columns;
277
- this.mVisibleRows = visibleRows;
278
- this.mVisibleHeight = visibleRows * avgHeight;
279
- lc.style.height = ((allRows - visibleRows + 1) * avgHeight) + "px";
280
- this.mTraining = false;
281
- this.mReady = true;
282
- this.postVirtualCollectionChanged();
283
- }
284
- return;
285
- }
286
- const self = this;
287
- this.lastScrollTop = vc.scrollTop;
288
- if (this.mIsChanging) {
289
- return;
240
+ }
290
241
  }
291
- this.mIsChanging = true;
292
- const block = Math.floor(this.mVisibleHeight / avgHeight);
293
- const itemsInBlock = this.mVisibleRows * this.mColumns;
294
- const index = Math.floor(vc.scrollTop / this.mVisibleHeight);
295
- const itemIndex = index * itemsInBlock;
296
- if (itemIndex >= items.length) {
297
- this.mIsChanging = false;
298
- return;
242
+ if (ae.next()) {
243
+ const data = ae.current;
244
+ const elementChild = this.createChild(null, data);
245
+ ip.insertBefore(elementChild.element, lc);
246
+ this.postVirtualCollectionChanged();
299
247
  }
300
- const lastIndex = Math.min((Math.max(index, 0) + 3) * itemsInBlock - 1, items.length - 1);
301
- const firstIndex = Math.max(0, (index) * itemsInBlock);
248
+ } else {
249
+ let totalVisibleItems = 0;
302
250
  ce = fc.nextElementSibling;
303
- const firstItem = fc.nextElementSibling;
304
- const lastItem = lc.previousElementSibling;
305
- if (firstItem !== lastItem) {
306
- const firstVisibleIndex = items.indexOf(firstItem.atomControl.data);
307
- const lastVisibleIndex = items.indexOf(lastItem.atomControl.data);
308
- console.log({
309
- firstVisibleIndex,
310
- firstIndex,
311
- lastVisibleIndex,
312
- lastIndex
313
- });
314
- if (firstIndex >= firstVisibleIndex && lastIndex <= lastVisibleIndex) {
315
- console.log("All items are visible...");
316
- this.mIsChanging = false;
317
- return;
318
- }
319
- }
320
- const remove = [];
321
- const cache = {};
251
+ let allHeight = 0;
252
+ let allWidth = 0;
322
253
  while (ce !== lc) {
323
- const c = ce;
324
- ce = ce.nextElementSibling;
325
- const s = items.indexOf(c.atomControl.data);
326
- cache[s] = c;
327
- remove.push(c);
328
- }
329
- this.app.dispatcher.pause();
330
- ae = new AtomEnumerator(items);
331
- for (let i = 0; i < firstIndex; i++) {
332
- ae.next();
333
- }
334
- let after = fc;
335
- let last = null;
336
- const add = [];
337
- for (let i = firstIndex; i <= lastIndex; i++) {
338
- if (!ae.next()) {
339
- break;
340
- }
341
- const index2 = ae.currentIndex;
342
- const data = ae.current;
343
- let elementChild = cache[index2];
344
- if (elementChild && element.atomControl.data === data) {
345
- cache[index2] = null;
346
- }
347
- else {
348
- elementChild = this.createChild(null, data).element;
349
- }
350
- elementChild.before = after;
351
- add.push(elementChild);
352
- after = elementChild;
353
- last = index2;
354
- }
355
- const h = (this.mAllRows - block * 3) * avgHeight - index * this.mVisibleHeight;
356
- console.log("last child height = " + h);
357
- this.app.callLater(() => {
358
- const oldHeight = AtomUI.outerHeight(fc);
359
- const newHeight = index * this.mVisibleHeight;
360
- const diff = newHeight - oldHeight;
361
- const oldScrollTop = vc.scrollTop;
362
- const a = new AtomEnumerator(add);
363
- while (a.next()) {
364
- const ec = a.current;
365
- ip.insertBefore(ec, ec.before.nextElementSibling);
366
- ec.before = null;
367
- }
368
- fc.style.height = newHeight + "px";
369
- for (const iterator of remove) {
370
- if (!iterator.before) {
371
- iterator.atomControl.dispose();
372
- }
373
- iterator.remove();
374
- }
375
- lc.style.height = h + "px";
376
- console.log(`Old: ${oldScrollTop} Diff: ${diff} Old Height: ${oldHeight} Height: ${newHeight}`);
377
- this.mIsChanging = false;
254
+ totalVisibleItems++;
255
+ allHeight += AtomUI.outerHeight(ce);
256
+ allWidth += AtomUI.outerWidth(ce);
257
+ ce = ce.nextElementSibling;
258
+ }
259
+ avgHeight = allHeight / totalVisibleItems;
260
+ avgWidth = allWidth / totalVisibleItems;
261
+ totalVisibleItems--;
262
+ this.mAvgHeight = avgHeight;
263
+ this.mAvgWidth = avgWidth;
264
+ const columns = Math.floor(vcWidth / avgWidth);
265
+ const allRows = Math.ceil(items.length / columns);
266
+ const visibleRows = Math.ceil(totalVisibleItems / columns);
267
+ console.log({
268
+ avgWidth,
269
+ avgHeight,
270
+ totalVisibleItems,
271
+ allRows,
272
+ columns
378
273
  });
379
- this.app.dispatcher.start();
380
- AtomBinder.refreshValue(this, "childAtomControls");
381
- }
382
- isSelected(item) {
383
- let selectedItem = null;
384
- for (const iterator of this.mSelectedItems) {
385
- selectedItem = iterator;
386
- if (selectedItem === item) {
387
- return true;
388
- }
389
- }
390
- return false;
391
- }
392
- bringIntoView(data) {
393
- this.app.callLater(() => {
394
- for (let item of ChildEnumerator.enumerate(this.itemsPresenter || this.element)) {
395
- const dataItem = item.atomControl ? item.atomControl.data : item;
396
- if (dataItem === data) {
397
- item.scrollIntoView();
398
- return;
399
- }
400
- }
401
- });
402
- }
403
- bringSelectionIntoView() {
404
- if (this.uiVirtualize) {
405
- const index = this.selectedIndex;
406
- if (!this.mReady) {
407
- setTimeout(() => {
408
- this.bringSelectionIntoView();
409
- }, 1000);
410
- return;
411
- }
412
- const avgHeight = this.mAvgHeight;
413
- const vcHeight = AtomUI.innerHeight(this.mVirtualContainer);
414
- const block = Math.ceil(vcHeight / avgHeight);
415
- const itemsInBlock = block * this.mColumns;
416
- const scrollTop = Math.floor(index / itemsInBlock);
417
- AtomUI.scrollTop(this.mVirtualContainer, scrollTop * vcHeight);
418
- return;
419
- }
420
- for (let item of ChildEnumerator.enumerate(this.itemsPresenter || this.element)) {
421
- const dataItem = item.atomControl ? item.atomControl.data : item;
422
- if (this.isSelected(dataItem)) {
423
- setTimeout(() => {
424
- item.scrollIntoView();
425
- }, 1000);
426
- return;
427
- }
428
- }
429
- }
430
- updateSelectionBindings() {
431
- this.version = this.version + 1;
432
- if (this.mSelectedItems && this.mSelectedItems.length) {
433
- this.mValue = undefined;
434
- }
435
- AtomBinder.refreshValue(this, "value");
436
- AtomBinder.refreshValue(this, "selectedItem");
437
- AtomBinder.refreshValue(this, "selectedItems");
438
- AtomBinder.refreshValue(this, "selectedIndex");
439
- if (!this.mSelectedItems.length) {
440
- if (this.mSelectAll === true) {
441
- this.mSelectAll = false;
442
- AtomBinder.refreshValue(this, "selectAll");
443
- }
444
- }
445
- }
446
- onSelectedItemsChanged(type, index, item) {
447
- if (!this.mOnUIChanged) {
448
- if (this.autoScrollToSelection) {
449
- this.bringSelectionIntoView();
450
- }
451
- }
452
- this.updateSelectionBindings();
453
- }
454
- hasItems() {
455
- return this.mItems !== undefined && this.mItems !== null;
456
- }
457
- invalidateItems() {
458
- if (this.pendingInits || this.isUpdating) {
459
- setTimeout(() => {
460
- this.invalidateItems();
461
- }, 5);
462
- return;
463
- }
464
- if (this.itemsInvalidated) {
465
- clearTimeout(this.itemsInvalidated);
466
- this.itemsInvalidated = 0;
467
- }
468
- this.itemsInvalidated = setTimeout(() => {
469
- this.itemsInvalidated = 0;
470
- this.onCollectionChangedInternal("refresh", -1, null);
471
- }, 5);
472
- }
473
- onCollectionChanged(key, index, item) {
474
- if (!this.mItems) {
475
- return;
476
- }
477
- if (!this.itemTemplate) {
478
- return;
479
- }
480
- if (!this.itemsPresenter) {
481
- this.itemsPresenter = this.element;
482
- }
483
- this.version = this.version + 1;
484
- if (/reset|refresh/i.test(key)) {
485
- this.resetVirtualContainer();
486
- }
487
- if (/remove/gi.test(key)) {
488
- const ip = this.itemsPresenter || this.element;
489
- for (let ce of ChildEnumerator.enumerate(ip)) {
490
- const c = ce;
491
- if (c.atomControl && c.atomControl.data === item) {
492
- c.atomControl.dispose();
493
- ce.remove();
494
- break;
495
- }
496
- }
497
- return;
498
- }
499
- if (this.uiVirtualize) {
500
- this.onVirtualCollectionChanged();
501
- return;
502
- }
503
- const parentScope = undefined;
504
- let items = this.mFilter ? this.mItems.filter(this.mFilter) : this.mItems;
505
- let s = this.sort;
506
- if (s) {
507
- if (typeof s === "string") {
508
- const sp = s;
509
- s = (l, r) => {
510
- const lv = (l[sp] || "").toString();
511
- const rv = (r[sp] || "").toString();
512
- return lv.toLowerCase().localeCompare(rv.toLowerCase());
513
- };
514
- }
515
- items = items.sort(s);
516
- }
517
- if (/add/gi.test(key)) {
518
- const lastItem = items[index];
519
- let last = this.itemsPresenter.children.item(index);
520
- const df2 = document.createDocumentFragment();
521
- this.createChild(df2, lastItem);
522
- if (last) {
523
- this.itemsPresenter.insertBefore(df2, last);
524
- }
525
- else {
526
- this.itemsPresenter.appendChild(df2);
527
- }
528
- return;
529
- }
530
- const element = this.itemsPresenter;
531
- this.disposeChildren(this.itemsPresenter);
532
- const added = [];
533
- const ip = this.itemsPresenter || this.element;
534
- for (const mItem of items) {
535
- const data = mItem;
536
- const ac = this.createChild(null, data);
537
- ip.appendChild(ac.element);
538
- }
539
- }
540
- preCreate() {
541
- this.mAllowSelectFirst = false;
542
- this.allowMultipleSelection = false;
543
- this.valuePath = "value";
544
- this.labelPath = "label";
545
- this.version = 1;
546
- this.autoScrollToSelection = false;
547
- this.sort = null;
548
- this.valueSeparator = ", ";
549
- this.uiVirtualize = false;
274
+ this.mAllRows = allRows;
275
+ this.mColumns = columns;
276
+ this.mVisibleRows = visibleRows;
277
+ this.mVisibleHeight = visibleRows * avgHeight;
278
+ lc.style.height = (allRows - visibleRows + 1) * avgHeight + "px";
279
+ this.mTraining = false;
280
+ this.mReady = true;
281
+ this.postVirtualCollectionChanged();
282
+ }
283
+ return;
284
+ }
285
+ const self = this;
286
+ this.lastScrollTop = vc.scrollTop;
287
+ if (this.mIsChanging) {
288
+ return;
289
+ }
290
+ this.mIsChanging = true;
291
+ const block = Math.floor(this.mVisibleHeight / avgHeight);
292
+ const itemsInBlock = this.mVisibleRows * this.mColumns;
293
+ const index = Math.floor(vc.scrollTop / this.mVisibleHeight);
294
+ const itemIndex = index * itemsInBlock;
295
+ if (itemIndex >= items.length) {
296
+ this.mIsChanging = false;
297
+ return;
298
+ }
299
+ const lastIndex = Math.min((Math.max(index, 0) + 3) * itemsInBlock - 1, items.length - 1);
300
+ const firstIndex = Math.max(0, index * itemsInBlock);
301
+ ce = fc.nextElementSibling;
302
+ const firstItem = fc.nextElementSibling;
303
+ const lastItem = lc.previousElementSibling;
304
+ if (firstItem !== lastItem) {
305
+ const firstVisibleIndex = items.indexOf(firstItem.atomControl.data);
306
+ const lastVisibleIndex = items.indexOf(lastItem.atomControl.data);
307
+ console.log({
308
+ firstVisibleIndex,
309
+ firstIndex,
310
+ lastVisibleIndex,
311
+ lastIndex
312
+ });
313
+ if (firstIndex >= firstVisibleIndex && lastIndex <= lastVisibleIndex) {
314
+ console.log("All items are visible...");
315
+ this.mIsChanging = false;
316
+ return;
317
+ }
318
+ }
319
+ const remove = [];
320
+ const cache = {};
321
+ while (ce !== lc) {
322
+ const c = ce;
323
+ ce = ce.nextElementSibling;
324
+ const s = items.indexOf(c.atomControl.data);
325
+ cache[s] = c;
326
+ remove.push(c);
327
+ }
328
+ this.app.dispatcher.pause();
329
+ ae = new AtomEnumerator(items);
330
+ for (let i = 0; i < firstIndex; i++) {
331
+ ae.next();
332
+ }
333
+ let after = fc;
334
+ let last = null;
335
+ const add = [];
336
+ for (let i = firstIndex; i <= lastIndex; i++) {
337
+ if (!ae.next()) {
338
+ break;
339
+ }
340
+ const index2 = ae.currentIndex;
341
+ const data = ae.current;
342
+ let elementChild = cache[index2];
343
+ if (elementChild && element.atomControl.data === data) {
344
+ cache[index2] = null;
345
+ } else {
346
+ elementChild = this.createChild(null, data).element;
347
+ }
348
+ elementChild.before = after;
349
+ add.push(elementChild);
350
+ after = elementChild;
351
+ last = index2;
352
+ }
353
+ const h = (this.mAllRows - block * 3) * avgHeight - index * this.mVisibleHeight;
354
+ console.log("last child height = " + h);
355
+ this.app.callLater(() => {
356
+ const oldHeight = AtomUI.outerHeight(fc);
357
+ const newHeight = index * this.mVisibleHeight;
358
+ const diff = newHeight - oldHeight;
359
+ const oldScrollTop = vc.scrollTop;
360
+ const a = new AtomEnumerator(add);
361
+ while (a.next()) {
362
+ const ec = a.current;
363
+ ip.insertBefore(ec, ec.before.nextElementSibling);
364
+ ec.before = null;
365
+ }
366
+ fc.style.height = newHeight + "px";
367
+ for (const iterator of remove) {
368
+ if (!iterator.before) {
369
+ iterator.atomControl.dispose();
370
+ }
371
+ iterator.remove();
372
+ }
373
+ lc.style.height = h + "px";
374
+ console.log(`Old: ${oldScrollTop} Diff: ${diff} Old Height: ${oldHeight} Height: ${newHeight}`);
375
+ this.mIsChanging = false;
376
+ });
377
+ this.app.dispatcher.start();
378
+ AtomBinder.refreshValue(this, "childAtomControls");
379
+ }
380
+ isSelected(item) {
381
+ let selectedItem = null;
382
+ for (const iterator of this.mSelectedItems) {
383
+ selectedItem = iterator;
384
+ if (selectedItem === item) {
385
+ return true;
386
+ }
387
+ }
388
+ return false;
389
+ }
390
+ bringIntoView(data) {
391
+ this.app.callLater(() => {
392
+ for (let item of ChildEnumerator.enumerate(this.itemsPresenter || this.element)) {
393
+ const dataItem = item.atomControl ? item.atomControl.data : item;
394
+ if (dataItem === data) {
395
+ item.scrollIntoView();
396
+ return;
397
+ }
398
+ }
399
+ });
400
+ }
401
+ bringSelectionIntoView() {
402
+ if (this.uiVirtualize) {
403
+ const index = this.selectedIndex;
404
+ if (!this.mReady) {
405
+ setTimeout(() => {
406
+ this.bringSelectionIntoView();
407
+ }, 1000);
408
+ return;
409
+ }
410
+ const avgHeight = this.mAvgHeight;
411
+ const vcHeight = AtomUI.innerHeight(this.mVirtualContainer);
412
+ const block = Math.ceil(vcHeight / avgHeight);
413
+ const itemsInBlock = block * this.mColumns;
414
+ const scrollTop = Math.floor(index / itemsInBlock);
415
+ AtomUI.scrollTop(this.mVirtualContainer, scrollTop * vcHeight);
416
+ return;
417
+ }
418
+ for (let item of ChildEnumerator.enumerate(this.itemsPresenter || this.element)) {
419
+ const dataItem = item.atomControl ? item.atomControl.data : item;
420
+ if (this.isSelected(dataItem)) {
421
+ setTimeout(() => {
422
+ item.scrollIntoView();
423
+ }, 1000);
424
+ return;
425
+ }
426
+ }
427
+ }
428
+ updateSelectionBindings() {
429
+ this.version = this.version + 1;
430
+ if (this.mSelectedItems && this.mSelectedItems.length) {
431
+ this.mValue = undefined;
432
+ }
433
+ AtomBinder.refreshValue(this, "value");
434
+ AtomBinder.refreshValue(this, "selectedItem");
435
+ AtomBinder.refreshValue(this, "selectedItems");
436
+ AtomBinder.refreshValue(this, "selectedIndex");
437
+ if (!this.mSelectedItems.length) {
438
+ if (this.mSelectAll === true) {
550
439
  this.mSelectAll = false;
551
- this.mItems = null;
552
- this.selectedItems = [];
553
- this.itemTemplate = AtomItemsControlItemTemplate;
554
- super.preCreate();
555
- }
556
- onCollectionChangedInternal(key, index, item) {
557
- const value = this.value;
558
- try {
559
- this.isUpdating = true;
560
- this.onCollectionChanged(key, index, item);
561
- if (value) {
562
- if (!(value || this.mAllowSelectFirst)) {
563
- AtomBinder.clear(this.mSelectedItems);
564
- }
565
- }
566
- if (value != null) {
567
- this.value = value;
568
- if (this.selectedIndex !== -1) {
569
- return;
570
- }
571
- else {
572
- this.mValue = undefined;
573
- }
574
- }
575
- }
576
- finally {
577
- this.app.callLater(() => {
578
- this.isUpdating = false;
579
- });
580
- }
581
- }
582
- set allowSelectFirst(b) {
583
- b = b ? b !== "false" : b;
584
- this.mAllowSelectFirst = b;
585
- }
586
- set filter(f) {
587
- if (f === this.mFilter) {
588
- return;
589
- }
590
- this.mFilter = f;
591
- AtomBinder.refreshValue(this, "filter");
592
- }
593
- onScroll() {
594
- if (this.scrollTimeout) {
595
- clearTimeout(this.scrollTimeout);
596
- }
597
- this.scrollTimeout = setTimeout(() => {
598
- this.scrollTimeout = 0;
599
- this.onVirtualCollectionChanged();
600
- }, 10);
601
- }
602
- toggleSelection(data) {
603
- this.mOnUIChanged = true;
604
- this.mValue = undefined;
605
- if (this.allowMultipleSelection) {
606
- if (this.mSelectedItems.indexOf(data) !== -1) {
607
- AtomBinder.removeItem(this.mSelectedItems, data);
608
- }
609
- else {
610
- AtomBinder.addItem(this.mSelectedItems, data);
611
- }
612
- }
613
- else {
614
- this.mSelectedItems.length = 1;
615
- this.mSelectedItems[0] = data;
616
- AtomBinder.refreshItems(this.mSelectedItems);
617
- }
618
- this.mOnUIChanged = false;
619
- }
620
- validateScroller() {
621
- if (this.mScrollerSetup) {
622
- return;
623
- }
624
- const ip = this.itemsPresenter;
625
- const e = this.element;
626
- let vc = this.mVirtualContainer;
627
- if (!vc) {
628
- if (ip === e && !/table/i.test(e.nodeName)) {
629
- throw new Error("virtualContainer presenter not found,"
630
- + "you must put itemsPresenter inside a virtualContainer in order for Virtualization to work");
631
- }
632
- else {
633
- vc = this.mVirtualContainer = this.element;
634
- }
635
- }
636
- vc.style.overflow = "auto";
637
- this.bindEvent(vc, "scroll", () => {
638
- this.onScroll();
639
- });
640
- ip.style.overflow = "hidden";
641
- const isTable = /tbody/i.test(ip.nodeName);
642
- let fc;
643
- let lc;
644
- if (isTable) {
645
- fc = document.createElement("TR");
646
- lc = document.createElement("TR");
647
- }
648
- else {
649
- fc = document.createElement("DIV");
650
- lc = document.createElement("DIV");
651
- }
652
- fc.classList.add("sticky");
653
- fc.classList.add("first-child");
654
- lc.classList.add("sticky");
655
- lc.classList.add("last-child");
656
- fc.style.position = "relative";
657
- fc.style.height = "0";
658
- fc.style.width = "100%";
659
- fc.style.clear = "both";
660
- lc.style.position = "relative";
661
- lc.style.height = "0";
662
- lc.style.width = "100%";
663
- lc.style.clear = "both";
664
- this.mFirstChild = fc;
665
- this.mLastChild = lc;
666
- ip.appendChild(fc);
667
- ip.appendChild(lc);
668
- this.mTraining = true;
669
- this.mScrollerSetup = true;
670
- }
671
- createChild(df, data) {
672
- const t = this.itemTemplate;
673
- const ac = this.app.resolve(t, true);
674
- const e = ac.element;
675
- e._logicalParent = this.element;
676
- e._templateParent = this;
677
- if (df) {
678
- df.appendChild(ac.element);
679
- }
680
- ac.data = data;
681
- this.element.dispatchEvent(new CustomEvent("item-created", {
682
- bubbles: false,
683
- cancelable: false,
684
- detail: data
685
- }));
686
- return ac;
687
- }
688
- disposeChildren(e) {
689
- for (let iterator of ChildEnumerator.enumerate(e)) {
690
- const ac = iterator.atomControl;
691
- if (ac) {
692
- ac.dispose();
693
- }
694
- }
695
- e.innerHTML = "";
696
- }
440
+ AtomBinder.refreshValue(this, "selectAll");
441
+ }
442
+ }
443
+ }
444
+ onSelectedItemsChanged(type, index, item) {
445
+ if (!this.mOnUIChanged) {
446
+ if (this.autoScrollToSelection) {
447
+ this.bringSelectionIntoView();
448
+ }
449
+ }
450
+ this.updateSelectionBindings();
451
+ }
452
+ hasItems() {
453
+ return this.mItems !== undefined && this.mItems !== null;
454
+ }
455
+ invalidateItems() {
456
+ if (this.pendingInits || this.isUpdating) {
457
+ setTimeout(() => {
458
+ this.invalidateItems();
459
+ }, 5);
460
+ return;
461
+ }
462
+ if (this.itemsInvalidated) {
463
+ clearTimeout(this.itemsInvalidated);
464
+ this.itemsInvalidated = 0;
465
+ }
466
+ this.itemsInvalidated = setTimeout(() => {
467
+ this.itemsInvalidated = 0;
468
+ this.onCollectionChangedInternal("refresh", -1, null);
469
+ }, 5);
470
+ }
471
+ onCollectionChanged(key, index, item) {
472
+ if (!this.mItems) {
473
+ return;
474
+ }
475
+ if (!this.itemTemplate) {
476
+ return;
477
+ }
478
+ if (!this.itemsPresenter) {
479
+ this.itemsPresenter = this.element;
480
+ }
481
+ this.version = this.version + 1;
482
+ if (/reset|refresh/i.test(key)) {
483
+ this.resetVirtualContainer();
484
+ }
485
+ if (/remove/gi.test(key)) {
486
+ const ip = this.itemsPresenter || this.element;
487
+ for (let ce of ChildEnumerator.enumerate(ip)) {
488
+ const c = ce;
489
+ if (c.atomControl && c.atomControl.data === item) {
490
+ c.atomControl.dispose();
491
+ ce.remove();
492
+ break;
493
+ }
494
+ }
495
+ return;
496
+ }
497
+ if (this.uiVirtualize) {
498
+ this.onVirtualCollectionChanged();
499
+ return;
500
+ }
501
+ const parentScope = undefined;
502
+ let items = this.mFilter ? this.mItems.filter(this.mFilter) : this.mItems;
503
+ let s = this.sort;
504
+ if (s) {
505
+ if (typeof s === "string") {
506
+ const sp = s;
507
+ s = (l, r) => {
508
+ const lv = (l[sp] || "").toString();
509
+ const rv = (r[sp] || "").toString();
510
+ return lv.toLowerCase().localeCompare(rv.toLowerCase());
511
+ };
512
+ }
513
+ items = items.sort(s);
514
+ }
515
+ if (/add/gi.test(key)) {
516
+ const lastItem = items[index];
517
+ let last = this.itemsPresenter.children.item(index);
518
+ const df2 = document.createDocumentFragment();
519
+ this.createChild(df2, lastItem);
520
+ if (last) {
521
+ this.itemsPresenter.insertBefore(df2, last);
522
+ } else {
523
+ this.itemsPresenter.appendChild(df2);
524
+ }
525
+ return;
526
+ }
527
+ const element = this.itemsPresenter;
528
+ this.disposeChildren(this.itemsPresenter);
529
+ const added = [];
530
+ const ip = this.itemsPresenter || this.element;
531
+ for (const mItem of items) {
532
+ const data = mItem;
533
+ const ac = this.createChild(null, data);
534
+ ip.appendChild(ac.element);
535
+ }
536
+ }
537
+ preCreate() {
538
+ this.mAllowSelectFirst = false;
539
+ this.allowMultipleSelection = false;
540
+ this.valuePath = "value";
541
+ this.labelPath = "label";
542
+ this.version = 1;
543
+ this.autoScrollToSelection = false;
544
+ this.sort = null;
545
+ this.valueSeparator = ", ";
546
+ this.uiVirtualize = false;
547
+ this.mSelectAll = false;
548
+ this.mItems = null;
549
+ this.selectedItems = [];
550
+ this.itemTemplate = AtomItemsControlItemTemplate;
551
+ super.preCreate();
552
+ }
553
+ onCollectionChangedInternal(key, index, item) {
554
+ const value = this.value;
555
+ try {
556
+ this.isUpdating = true;
557
+ this.onCollectionChanged(key, index, item);
558
+ if (value) {
559
+ if (!(value || this.mAllowSelectFirst)) {
560
+ AtomBinder.clear(this.mSelectedItems);
561
+ }
562
+ }
563
+ if (value != null) {
564
+ this.value = value;
565
+ if (this.selectedIndex !== -1) {
566
+ return;
567
+ } else {
568
+ this.mValue = undefined;
569
+ }
570
+ }
571
+ } finally {
572
+ this.app.callLater(() => {
573
+ this.isUpdating = false;
574
+ });
575
+ }
576
+ }
577
+ set allowSelectFirst(b) {
578
+ b = b ? b !== "false" : b;
579
+ this.mAllowSelectFirst = b;
580
+ }
581
+ set filter(f) {
582
+ if (f === this.mFilter) {
583
+ return;
584
+ }
585
+ this.mFilter = f;
586
+ AtomBinder.refreshValue(this, "filter");
587
+ }
588
+ onScroll() {
589
+ if (this.scrollTimeout) {
590
+ clearTimeout(this.scrollTimeout);
591
+ }
592
+ this.scrollTimeout = setTimeout(() => {
593
+ this.scrollTimeout = 0;
594
+ this.onVirtualCollectionChanged();
595
+ }, 10);
596
+ }
597
+ toggleSelection(data) {
598
+ this.mOnUIChanged = true;
599
+ this.mValue = undefined;
600
+ if (this.allowMultipleSelection) {
601
+ if (this.mSelectedItems.indexOf(data) !== -1) {
602
+ AtomBinder.removeItem(this.mSelectedItems, data);
603
+ } else {
604
+ AtomBinder.addItem(this.mSelectedItems, data);
605
+ }
606
+ } else {
607
+ this.mSelectedItems.length = 1;
608
+ this.mSelectedItems[0] = data;
609
+ AtomBinder.refreshItems(this.mSelectedItems);
610
+ }
611
+ this.mOnUIChanged = false;
612
+ }
613
+ validateScroller() {
614
+ if (this.mScrollerSetup) {
615
+ return;
616
+ }
617
+ const ip = this.itemsPresenter;
618
+ const e = this.element;
619
+ let vc = this.mVirtualContainer;
620
+ if (!vc) {
621
+ if (ip === e && !/table/i.test(e.nodeName)) {
622
+ throw new Error("virtualContainer presenter not found," + "you must put itemsPresenter inside a virtualContainer in order for Virtualization to work");
623
+ } else {
624
+ vc = this.mVirtualContainer = this.element;
625
+ }
626
+ }
627
+ vc.style.overflow = "auto";
628
+ this.bindEvent(vc, "scroll", () => {
629
+ this.onScroll();
630
+ });
631
+ ip.style.overflow = "hidden";
632
+ const isTable = /tbody/i.test(ip.nodeName);
633
+ let fc;
634
+ let lc;
635
+ if (isTable) {
636
+ fc = document.createElement("TR");
637
+ lc = document.createElement("TR");
638
+ } else {
639
+ fc = document.createElement("DIV");
640
+ lc = document.createElement("DIV");
641
+ }
642
+ fc.classList.add("sticky");
643
+ fc.classList.add("first-child");
644
+ lc.classList.add("sticky");
645
+ lc.classList.add("last-child");
646
+ fc.style.position = "relative";
647
+ fc.style.height = "0";
648
+ fc.style.width = "100%";
649
+ fc.style.clear = "both";
650
+ lc.style.position = "relative";
651
+ lc.style.height = "0";
652
+ lc.style.width = "100%";
653
+ lc.style.clear = "both";
654
+ this.mFirstChild = fc;
655
+ this.mLastChild = lc;
656
+ ip.appendChild(fc);
657
+ ip.appendChild(lc);
658
+ this.mTraining = true;
659
+ this.mScrollerSetup = true;
660
+ }
661
+ createChild(df, data) {
662
+ const t = this.itemTemplate;
663
+ const ac = this.app.resolve(t, true);
664
+ const e = ac.element;
665
+ e._logicalParent = this.element;
666
+ e._templateParent = this;
667
+ if (df) {
668
+ df.appendChild(ac.element);
669
+ }
670
+ ac.data = data;
671
+ this.element.dispatchEvent(new CustomEvent("item-created", {
672
+ bubbles: false,
673
+ cancelable: false,
674
+ detail: data
675
+ }));
676
+ return ac;
677
+ }
678
+ disposeChildren(e) {
679
+ for (let iterator of ChildEnumerator.enumerate(e)) {
680
+ const ac = iterator.atomControl;
681
+ if (ac) {
682
+ ac.dispose();
683
+ }
684
+ }
685
+ e.innerHTML = "";
686
+ }
697
687
  }
698
688
  class AtomItemsControlItemTemplate extends AtomControl {
699
- create() {
700
- this.runAfterInit(() => {
701
- const tp = this.element._templateParent;
702
- this.element.textContent = this.data[tp.valuePath];
703
- });
704
- }
705
- }
706
- //# sourceMappingURL=AtomItemsControl.js.map
689
+ create() {
690
+ this.runAfterInit(() => {
691
+ const tp = this.element._templateParent;
692
+ this.element.textContent = this.data[tp.valuePath];
693
+ });
694
+ }
695
+ }