@web-atoms/core 2.6.24 → 2.6.26

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 (130) hide show
  1. package/dist/core/XNode.d.ts +1 -13
  2. package/dist/core/XNode.d.ts.map +1 -1
  3. package/dist/core/XNode.js +2 -24
  4. package/dist/core/XNode.js.map +1 -1
  5. package/dist/tsconfig.tsbuildinfo +1 -1
  6. package/dist-esm/App.js +231 -235
  7. package/dist-esm/Atom.js +93 -96
  8. package/dist-esm/MockApp.js +17 -18
  9. package/dist-esm/Pack.js +1 -3
  10. package/dist-esm/core/AtomBinder.js +189 -187
  11. package/dist-esm/core/AtomComponent.js +479 -502
  12. package/dist-esm/core/AtomDispatcher.js +46 -48
  13. package/dist-esm/core/AtomDisposableList.js +24 -25
  14. package/dist-esm/core/AtomEnumerator.js +15 -16
  15. package/dist-esm/core/AtomList.js +193 -192
  16. package/dist-esm/core/AtomLoader.js +229 -215
  17. package/dist-esm/core/AtomMap.js +7 -8
  18. package/dist-esm/core/AtomOnce.js +22 -24
  19. package/dist-esm/core/AtomSelectableList.js +240 -243
  20. package/dist-esm/core/AtomUri.js +70 -72
  21. package/dist-esm/core/AtomWatcher.js +105 -111
  22. package/dist-esm/core/Bind.js +271 -269
  23. package/dist-esm/core/BindableProperty.js +26 -27
  24. package/dist-esm/core/CancelTokenFactory.js +21 -24
  25. package/dist-esm/core/Color.js +1 -2
  26. package/dist-esm/core/Colors.js +545 -231
  27. package/dist-esm/core/Command.js +236 -223
  28. package/dist-esm/core/Defer.js +21 -22
  29. package/dist-esm/core/EventScope.js +96 -88
  30. package/dist-esm/core/ExpressionParser.js +132 -144
  31. package/dist-esm/core/ExtendControl.js +7 -8
  32. package/dist-esm/core/FormattedError.js +7 -8
  33. package/dist-esm/core/FormattedString.js +4 -5
  34. package/dist-esm/core/Hacks.js +41 -42
  35. package/dist-esm/core/IFetchEvent.js +1 -2
  36. package/dist-esm/core/IScreen.js +1 -2
  37. package/dist-esm/core/IValueConverter.js +1 -2
  38. package/dist-esm/core/InheritedProperty.js +61 -63
  39. package/dist-esm/core/InjectProperty.js +12 -13
  40. package/dist-esm/core/KeyValuePairs.js +1 -2
  41. package/dist-esm/core/Markdown.js +14 -17
  42. package/dist-esm/core/MarkdownError.js +6 -7
  43. package/dist-esm/core/PropertyBinding.js +1 -2
  44. package/dist-esm/core/PropertyMap.js +28 -27
  45. package/dist-esm/core/Route.js +149 -148
  46. package/dist-esm/core/SingleInvoker.js +32 -35
  47. package/dist-esm/core/StringHelper.js +49 -51
  48. package/dist-esm/core/TransientDisposable.js +14 -16
  49. package/dist-esm/core/WatchProperty.js +18 -17
  50. package/dist-esm/core/WebImage.js +7 -8
  51. package/dist-esm/core/XNode.d.ts +1 -13
  52. package/dist-esm/core/XNode.d.ts.map +1 -1
  53. package/dist-esm/core/XNode.js +116 -120
  54. package/dist-esm/core/XNode.js.map +1 -1
  55. package/dist-esm/core/sleep.js +21 -24
  56. package/dist-esm/core/types.js +102 -103
  57. package/dist-esm/di/DISingleton.js +7 -5
  58. package/dist-esm/di/DITransient.js +7 -5
  59. package/dist-esm/di/IMockOrInject.js +1 -2
  60. package/dist-esm/di/IServiceProvider.js +1 -2
  61. package/dist-esm/di/Inject.js +67 -67
  62. package/dist-esm/di/Register.js +25 -26
  63. package/dist-esm/di/RegisterScoped.js +4 -3
  64. package/dist-esm/di/RegisterSingleton.js +4 -3
  65. package/dist-esm/di/ServiceCollection.js +38 -37
  66. package/dist-esm/di/ServiceProvider.js +94 -94
  67. package/dist-esm/di/TypeKey.js +13 -12
  68. package/dist-esm/services/BusyIndicatorService.js +7 -11
  69. package/dist-esm/services/CacheService.js +54 -62
  70. package/dist-esm/services/FetchBuilder.js +327 -278
  71. package/dist-esm/services/JsonService.js +118 -116
  72. package/dist-esm/services/MockNavigationService.js +127 -126
  73. package/dist-esm/services/NavigationService.js +95 -102
  74. package/dist-esm/services/ReferenceService.js +30 -33
  75. package/dist-esm/services/http/AjaxOptions.js +1 -3
  76. package/dist-esm/services/http/JsonError.js +16 -15
  77. package/dist-esm/services/http/RestService.js +314 -323
  78. package/dist-esm/style/StyleRule.js +1 -2
  79. package/dist-esm/test.js +0 -1
  80. package/dist-esm/tsconfig.esm.tsbuildinfo +1 -1
  81. package/dist-esm/unit/AtomTest.js +10 -11
  82. package/dist-esm/view-model/Action.js +258 -223
  83. package/dist-esm/view-model/AtomViewModel.js +234 -232
  84. package/dist-esm/view-model/AtomWindowViewModel.js +13 -14
  85. package/dist-esm/view-model/BindableUrlParameter.js +7 -8
  86. package/dist-esm/view-model/Delay.js +21 -25
  87. package/dist-esm/view-model/Disposable.js +28 -29
  88. package/dist-esm/view-model/Load.js +72 -73
  89. package/dist-esm/view-model/Once.js +33 -35
  90. package/dist-esm/view-model/baseTypes.js +4 -5
  91. package/dist-esm/view-model/bindPromise.js +24 -27
  92. package/dist-esm/view-model/bindProperty.js +3 -4
  93. package/dist-esm/view-model/bindUrlParameter.js +39 -43
  94. package/dist-esm/web/controls/AtomComboBox.js +56 -63
  95. package/dist-esm/web/controls/AtomControl.js +485 -490
  96. package/dist-esm/web/controls/AtomGridSplitter.js +57 -50
  97. package/dist-esm/web/controls/AtomGridView.js +230 -222
  98. package/dist-esm/web/controls/AtomItemsControl.js +677 -688
  99. package/dist-esm/web/controls/AtomPage.js +6 -7
  100. package/dist-esm/web/controls/AtomTemplate.js +1 -3
  101. package/dist-esm/web/controls/AtomTemplateControl.js +28 -29
  102. package/dist-esm/web/controls/AtomViewStack.js +19 -20
  103. package/dist-esm/web/core/AtomUI.js +200 -200
  104. package/dist-esm/web/core/Encoder.js +142 -152
  105. package/dist-esm/web/core/HtmlNode.js +141 -139
  106. package/dist-esm/web/images/Busy.js +1 -2
  107. package/dist-esm/web/images/BusyDataUrl.js +2 -869
  108. package/dist-esm/web/images/Button.js +1 -2
  109. package/dist-esm/web/images/ButtonDataUrl.js +2 -30
  110. package/dist-esm/web/images/CloseButton.js +1 -2
  111. package/dist-esm/web/images/CloseButtonDataUrl.js +2 -30
  112. package/dist-esm/web/images/CloseButtonHover.js +1 -2
  113. package/dist-esm/web/images/CloseButtonHoverDataUrl.js +2 -24
  114. package/dist-esm/web/services/LastTarget.js +31 -29
  115. package/dist-esm/web/services/MarkdownService.js +19 -31
  116. package/dist-esm/web/services/NotificationPopup.js +28 -21
  117. package/dist-esm/web/services/PopupService.js +512 -478
  118. package/dist-esm/web/services/PopupWindow.js +266 -247
  119. package/dist-esm/web/styles/AtomAlertWindowStyle.js +39 -40
  120. package/dist-esm/web/styles/AtomFrameStyle.js +15 -16
  121. package/dist-esm/web/styles/AtomNotificationStyle.js +19 -20
  122. package/dist-esm/web/styles/AtomPageLinkStyle.js +11 -12
  123. package/dist-esm/web/styles/AtomPopupStyle.js +9 -10
  124. package/dist-esm/web/styles/AtomStyle.js +61 -64
  125. package/dist-esm/web/styles/AtomStyleSheet.js +50 -51
  126. package/dist-esm/web/styles/AtomWindowStyle.js +116 -117
  127. package/dist-esm/web/styles/IStyleDeclaration.js +1 -2
  128. package/dist-esm/web/styles/StyleBuilder.js +79 -80
  129. package/package.json +1 -1
  130. package/src/core/XNode.ts +12 -38
@@ -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
+ }