@arcgis/common-components 4.29.0-beta.5 → 4.29.0-beta.51

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 (137) hide show
  1. package/README.md +1 -1
  2. package/dist/arcgis-common-components/arcgis-common-components.esm.js +1 -1
  3. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ar.json +78 -0
  4. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.bg.json +78 -0
  5. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.bs.json +78 -0
  6. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ca.json +78 -0
  7. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.cs.json +78 -0
  8. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.da.json +78 -0
  9. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.de.json +78 -0
  10. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.el.json +78 -0
  11. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.en.json +78 -0
  12. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.es.json +78 -0
  13. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.et.json +78 -0
  14. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.fi.json +78 -0
  15. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.fr.json +78 -0
  16. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.he.json +78 -0
  17. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.hr.json +78 -0
  18. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.hu.json +78 -0
  19. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.id.json +78 -0
  20. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.it.json +78 -0
  21. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ja.json +78 -0
  22. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ko.json +78 -0
  23. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.lt.json +78 -0
  24. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.lv.json +78 -0
  25. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.nb.json +78 -0
  26. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.nl.json +78 -0
  27. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.pl.json +78 -0
  28. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.pt-BR.json +78 -0
  29. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.pt-PT.json +78 -0
  30. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ro.json +78 -0
  31. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.ru.json +78 -0
  32. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.sk.json +78 -0
  33. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.sl.json +78 -0
  34. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.sr.json +78 -0
  35. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.sv.json +78 -0
  36. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.th.json +78 -0
  37. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.tr.json +78 -0
  38. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.uk.json +78 -0
  39. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.vi.json +78 -0
  40. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.zh-CN.json +78 -0
  41. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.zh-HK.json +78 -0
  42. package/dist/arcgis-common-components/assets/field-info/t9n/field-info.t9n.zh-TW.json +78 -0
  43. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ar.json +17 -0
  44. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.bg.json +17 -0
  45. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.bs.json +17 -0
  46. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ca.json +17 -0
  47. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.cs.json +17 -0
  48. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.da.json +17 -0
  49. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.de.json +17 -0
  50. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.el.json +17 -0
  51. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.en.json +17 -0
  52. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.es.json +17 -0
  53. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.et.json +17 -0
  54. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.fi.json +17 -0
  55. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.fr.json +17 -0
  56. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.he.json +17 -0
  57. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.hr.json +17 -0
  58. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.hu.json +17 -0
  59. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.id.json +17 -0
  60. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.it.json +17 -0
  61. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ja.json +17 -0
  62. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ko.json +17 -0
  63. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.lt.json +17 -0
  64. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.lv.json +17 -0
  65. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.nb.json +17 -0
  66. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.nl.json +17 -0
  67. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.pl.json +17 -0
  68. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.pt-BR.json +17 -0
  69. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.pt-PT.json +17 -0
  70. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ro.json +17 -0
  71. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.ru.json +17 -0
  72. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.sk.json +17 -0
  73. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.sl.json +17 -0
  74. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.sr.json +17 -0
  75. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.sv.json +17 -0
  76. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.th.json +17 -0
  77. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.tr.json +17 -0
  78. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.uk.json +17 -0
  79. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.vi.json +17 -0
  80. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.zh-CN.json +17 -0
  81. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.zh-HK.json +17 -0
  82. package/dist/arcgis-common-components/assets/field-pick-list/t9n/field-pick-list.t9n.zh-TW.json +17 -0
  83. package/dist/arcgis-common-components/p-6c7d2684.js +1 -0
  84. package/dist/arcgis-common-components/p-7318a1d1.entry.js +1 -0
  85. package/dist/arcgis-common-components/p-a91ab432.js +2 -0
  86. package/dist/arcgis-common-components/p-efab92a8.entry.js +1 -0
  87. package/dist/cjs/arcgis-common-components.cjs.js +3 -3
  88. package/dist/cjs/arcgis-field-info.cjs.entry.js +1025 -0
  89. package/dist/cjs/arcgis-field-pick-list.cjs.entry.js +245 -0
  90. package/dist/cjs/index-5ec7f592.js +90 -0
  91. package/dist/cjs/index-e0422bc8.js +1887 -0
  92. package/dist/cjs/loader.cjs.js +3 -12
  93. package/dist/components/{arcgis-api-key.d.ts → arcgis-field-info.d.ts} +4 -4
  94. package/dist/components/arcgis-field-info.js +6 -0
  95. package/dist/components/{arcgis-identity.d.ts → arcgis-field-pick-list.d.ts} +4 -4
  96. package/dist/components/arcgis-field-pick-list.js +301 -0
  97. package/dist/components/field-info.js +1108 -0
  98. package/dist/components/index.d.ts +5 -4
  99. package/dist/components/index.js +1 -3
  100. package/dist/esm/arcgis-common-components.js +4 -4
  101. package/dist/esm/arcgis-field-info.entry.js +1021 -0
  102. package/dist/esm/arcgis-field-pick-list.entry.js +241 -0
  103. package/dist/esm/index-0c129ec4.js +1856 -0
  104. package/dist/esm/index-ba4fe890.js +59 -0
  105. package/dist/esm/loader.js +4 -13
  106. package/dist/loader/index.d.ts +2 -2
  107. package/dist/types/components/field-info/field-info.d.ts +68 -0
  108. package/dist/types/components/field-info/t9n-types.d.ts +82 -0
  109. package/dist/types/components/field-info/utils/basic.d.ts +44 -0
  110. package/dist/types/components/field-info/utils/feature.d.ts +17 -0
  111. package/dist/types/components/field-info/utils/field.d.ts +25 -0
  112. package/dist/types/components/field-info/utils/index.d.ts +3 -0
  113. package/dist/types/components/field-pick-list/field-pick-list.d.ts +122 -0
  114. package/dist/types/components/field-pick-list/t9n-types.d.ts +17 -0
  115. package/dist/types/components/field-pick-list/utils/types.d.ts +25 -0
  116. package/dist/types/components.d.ts +258 -49
  117. package/dist/types/stencil-public-runtime.d.ts +61 -17
  118. package/package.json +24 -26
  119. package/dist/arcgis-common-components/p-3768a3bb.entry.js +0 -1
  120. package/dist/arcgis-common-components/p-84fccaad.entry.js +0 -1
  121. package/dist/arcgis-common-components/p-9625972e.js +0 -1
  122. package/dist/arcgis-common-components/p-b0c98bba.js +0 -2
  123. package/dist/cjs/arcgis-api-key.cjs.entry.js +0 -51
  124. package/dist/cjs/arcgis-identity.cjs.entry.js +0 -139
  125. package/dist/cjs/index-e8c59179.js +0 -858
  126. package/dist/cjs/index-f1a937af.js +0 -65
  127. package/dist/components/arcgis-api-key.js +0 -67
  128. package/dist/components/arcgis-identity.js +0 -165
  129. package/dist/components/index2.js +0 -40
  130. package/dist/esm/arcgis-api-key.entry.js +0 -47
  131. package/dist/esm/arcgis-identity.entry.js +0 -135
  132. package/dist/esm/index-1f7e8e45.js +0 -831
  133. package/dist/esm/index-71b437b1.js +0 -40
  134. package/dist/esm/polyfills/css-shim.js +0 -1
  135. package/dist/types/components/arcgis-api-key/arcgis-api-key.d.ts +0 -9
  136. package/dist/types/components/arcgis-identity/arcgis-identity.d.ts +0 -31
  137. package/dist/types/components/types.d.ts +0 -10
@@ -0,0 +1,241 @@
1
+ import { r as registerInstance, c as createEvent, h, g as getAssetPath, H as Host, a as getElement } from './index-0c129ec4.js';
2
+ import { F, i as importIntl, U, C } from './index-ba4fe890.js';
3
+
4
+ const fieldPickListScss = ".popover{z-index:100}.panel{min-height:300px}.content{max-height:60vh}.selection-button-div{padding:4px 10px}";
5
+
6
+ var FieldInfoPrefix;
7
+ (function (FieldInfoPrefix) {
8
+ FieldInfoPrefix["expression"] = "expression/";
9
+ FieldInfoPrefix["relationship"] = "relationships/";
10
+ FieldInfoPrefix["raster"] = "Raster.";
11
+ })(FieldInfoPrefix || (FieldInfoPrefix = {}));
12
+ var LastSortyBy;
13
+ (function (LastSortyBy) {
14
+ LastSortyBy["default"] = "default";
15
+ LastSortyBy["display"] = "display";
16
+ LastSortyBy["type"] = "type";
17
+ LastSortyBy["field"] = "field";
18
+ })(LastSortyBy || (LastSortyBy = {}));
19
+ const ArcgisFieldPickList = class {
20
+ constructor(hostRef) {
21
+ registerInstance(this, hostRef);
22
+ this.arcgisFieldPickListDismissed = createEvent(this, "arcgisFieldPickListDismissed", 7);
23
+ this.arcgisFieldPickListChange = createEvent(this, "arcgisFieldPickListChange", 7);
24
+ this.arcgisFieldPickListSortByChange = createEvent(this, "arcgisFieldPickListSortByChange", 7);
25
+ this.calciteValueList = (field) => (h("calcite-pick-list-item", { key: field.name, label: field.alias || field.name, description: (() => {
26
+ if (this.showFieldName) {
27
+ return `{${field.name}}`;
28
+ }
29
+ if (this.showDescription && field.description) {
30
+ return field.description;
31
+ }
32
+ return null;
33
+ })(), value: field.name, selected: (!this.multiple && field.name === this.selectedFields[0]) ||
34
+ (this.multiple && this.selectedFields.indexOf(field.name) > -1), metadata: {
35
+ label: field.alias,
36
+ fieldName: field.name
37
+ } }, this.showFieldInfoCheck(field) && (h("calcite-action", { slot: "actions-end", text: this._t9nStrings.info, title: this._t9nStrings.info, scale: "s", icon: "information", onClick: (event) => {
38
+ event.stopPropagation();
39
+ const action = event.target;
40
+ const fieldInfoFlowItem = document.createElement("calcite-flow-item");
41
+ fieldInfoFlowItem.heading = field.alias ?? field.name;
42
+ fieldInfoFlowItem.description = field.name;
43
+ fieldInfoFlowItem.className = "panel";
44
+ const fieldInfo = document.createElement("arcgis-field-info");
45
+ fieldInfo.lang = this._lang;
46
+ fieldInfo.fieldName = field.name;
47
+ fieldInfo.layer = this.layer;
48
+ fieldInfo.view = this.mapView;
49
+ fieldInfo.classList.add("content");
50
+ fieldInfoFlowItem.appendChild(fieldInfo);
51
+ fieldInfoFlowItem.addEventListener("calciteFlowItemBack", () => setTimeout(() => requestAnimationFrame(() => action.setFocus()), 200));
52
+ this.flowElement.appendChild(fieldInfoFlowItem);
53
+ setTimeout(() => requestAnimationFrame(() => fieldInfoFlowItem.setFocus()), 200);
54
+ } }))));
55
+ this.selectedFields = [];
56
+ this.fields = undefined;
57
+ this.popoverProps = undefined;
58
+ this.layer = undefined;
59
+ this.mapView = undefined;
60
+ this.showFieldInfo = false;
61
+ this.showFieldName = false;
62
+ this.showDescription = false;
63
+ this.showSelectionAll = false;
64
+ this.showCancel = true;
65
+ this.showSort = true;
66
+ this.showFilterLength = 10;
67
+ this.multiple = false;
68
+ this.heading = undefined;
69
+ this.okBtnText = undefined;
70
+ this.filterPlaceholderText = undefined;
71
+ this.sortBy = undefined;
72
+ this.lastSortyBy = LastSortyBy.default;
73
+ this.filterFields = null;
74
+ this._lang = "";
75
+ this._t9nLocale = "";
76
+ this._t9nStrings = undefined;
77
+ }
78
+ // --------------------------------------------------------------------------
79
+ //
80
+ // Lifecycle
81
+ //
82
+ // --------------------------------------------------------------------------
83
+ async componentWillLoad() {
84
+ await F(this, getAssetPath("./assets"));
85
+ // in case more than 1 selected field and multiple is set to false
86
+ if (!this.multiple && this.selectedFields.length > 1) {
87
+ this.selectedFields = [this.selectedFields[0]];
88
+ }
89
+ this.lastSortyBy = this.sortBy || this.lastSortyBy;
90
+ }
91
+ async componentDidLoad() {
92
+ const intl = await importIntl();
93
+ intl.setLocale(this._lang);
94
+ this.setUpObserver();
95
+ this.popoverNode.open = true;
96
+ // need timeout because of re-render
97
+ setTimeout(() => requestAnimationFrame(() => this.panelElement.setFocus()), 200);
98
+ }
99
+ disconnectedCallback() {
100
+ U(this);
101
+ this.observer?.disconnect();
102
+ }
103
+ // --------------------------------------------------------------------------
104
+ //
105
+ // Public Methods
106
+ //
107
+ // --------------------------------------------------------------------------
108
+ async setFocus() {
109
+ setTimeout(() => requestAnimationFrame(() => this.panelElement.setFocus()), 1);
110
+ }
111
+ async reposition() {
112
+ this.popoverNode?.reposition();
113
+ }
114
+ // --------------------------------------------------------------------------
115
+ //
116
+ // Private Methods
117
+ //
118
+ // --------------------------------------------------------------------------
119
+ getSortedList() {
120
+ const tempSorted = [...this.fields];
121
+ if (this.lastSortyBy === LastSortyBy.display) {
122
+ tempSorted.sort((a, b) => a.alias.localeCompare(b.alias));
123
+ }
124
+ else if (this.lastSortyBy === LastSortyBy.field) {
125
+ tempSorted.sort((a, b) => a.name.localeCompare(b.name));
126
+ }
127
+ else if (this.lastSortyBy === LastSortyBy.type) {
128
+ tempSorted.sort((a, b) => a.type.localeCompare(b.type));
129
+ }
130
+ return tempSorted;
131
+ }
132
+ showFieldInfoCheck(field) {
133
+ if (this.showFieldInfo) {
134
+ // dont want info for arcade and relation fields
135
+ if (field.name.includes(FieldInfoPrefix.expression) || field.name.includes(FieldInfoPrefix.relationship)) {
136
+ return false;
137
+ }
138
+ else {
139
+ return true;
140
+ }
141
+ }
142
+ else {
143
+ return false;
144
+ }
145
+ }
146
+ // return true for deselect all, false for select all
147
+ selectDeselect() {
148
+ return this.filterFields?.length ? this.filterContainsAll() : this.selectedFields.length === this.fields.length;
149
+ }
150
+ // check if filter has all current field info
151
+ filterContainsAll() {
152
+ return !!this.filterFields?.every((filter) => this.selectedFields.some((curr) => curr === filter));
153
+ }
154
+ // --------------------------------------------------------------------------
155
+ //
156
+ // Rendor Methods
157
+ //
158
+ // --------------------------------------------------------------------------
159
+ render() {
160
+ const addBtn = (h("calcite-button", { slot: "footer", appearance: this.showCancel ? "solid" : "outline-fill", width: this.showCancel ? "half" : "full", scale: "m", onClick: () => {
161
+ this.arcgisFieldPickListDismissed.emit({ selectedFields: this.selectedFields });
162
+ } }, this.okBtnText || (this.multiple ? this._t9nStrings.done : this._t9nStrings.ok)));
163
+ const cancelBtn = (h("calcite-button", { slot: "footer", appearance: "outline-fill", width: this.multiple ? "half" : "full", scale: "m", onClick: () => this.arcgisFieldPickListDismissed.emit() }, this._t9nStrings.cancel));
164
+ const hasType = this.fields.every((field) => !!field.type);
165
+ const sort = (h("calcite-dropdown", { slot: "menu-actions", placement: "bottom-end", overlayPositioning: "fixed", ref: (node) => (this.dropdownNode = node), onCalciteDropdownOpen: () => {
166
+ this.observer?.disconnect();
167
+ this.observer?.observe(this.popoverNode, { attributes: true });
168
+ }, onCalciteDropdownClose: () => this.observer?.disconnect() }, h("calcite-action", { slot: "trigger", text: this._t9nStrings.sort, title: this._t9nStrings.sort }, h("calcite-icon", { scale: "s", icon: "sortDescending" })), h("calcite-dropdown-group", null, h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.default, onClick: () => {
169
+ this.lastSortyBy = LastSortyBy.default;
170
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
171
+ } }, this._t9nStrings.default), h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.display, onClick: () => {
172
+ this.lastSortyBy = LastSortyBy.display;
173
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
174
+ } }, this._t9nStrings.displayName), hasType && (h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.type, onClick: () => {
175
+ this.lastSortyBy = LastSortyBy.type;
176
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
177
+ } }, this._t9nStrings.type)), h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.field, onClick: () => {
178
+ this.lastSortyBy = LastSortyBy.field;
179
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
180
+ } }, this._t9nStrings.fieldName))));
181
+ const selectionBtn = (h("div", { class: "selection-button-div" }, h("calcite-button", { appearance: "transparent", scale: "s", width: "full", onClick: () => {
182
+ if (this.selectDeselect()) {
183
+ //deselect all
184
+ this.selectedFields = this.filterFields?.length
185
+ ? this.selectedFields.filter((item) => !this.filterFields?.includes(item))
186
+ : [];
187
+ }
188
+ else {
189
+ //select all
190
+ this.selectedFields = this.filterFields?.length
191
+ ? [...new Set([...this.selectedFields, ...this.filterFields])]
192
+ : this.fields.map((field) => field.name);
193
+ }
194
+ } }, this.selectDeselect() ? this._t9nStrings.deselectAll : this._t9nStrings.selectAll)));
195
+ return (h(Host, { class: "js-app-flyout" }, h("calcite-popover", { dir: C(this._hostElement), class: "popover", placement: this.popoverProps.placement || "leading-start", open: false, pointerDisabled: true, referenceElement: this.popoverProps.refElement, offsetDistance: this.popoverProps.offsetDistance || -Math.round(this.popoverProps.refElement.getBoundingClientRect().width), offsetSkidding: this.popoverProps.offsetSkidding || 0, overlayPositioning: this.popoverProps.overlayPositioning, triggerDisabled: this.popoverProps.triggerDisabled, autoClose: this.popoverProps.autoClose, label: this.heading || (this.multiple ? this._t9nStrings.headerSelect : this._t9nStrings.header), onCalcitePopoverClose: () => this.arcgisFieldPickListDismissed.emit(), ref: (node) => (this.popoverNode = node) }, h("calcite-flow", { ref: (node) => {
196
+ this.flowElement = node;
197
+ }, style: {
198
+ width: `${this.popoverProps.popoverWidth || this.popoverProps.refElement.getBoundingClientRect().width}px`
199
+ } }, h("calcite-flow-item", { ref: (el) => (this.panelElement = el), class: "panel", heading: this.heading || (this.multiple ? this._t9nStrings.headerSelect : this._t9nStrings.header), closable: true, onCalciteFlowItemClose: () => this.arcgisFieldPickListDismissed.emit() }, this.multiple && addBtn, this.showCancel && cancelBtn, h("calcite-pick-list", { multiple: this.multiple, ref: (node) => {
200
+ this.pickListNode = node;
201
+ }, class: "content", filterEnabled: this.fields.length >= this.showFilterLength, filterPlaceholder: this.filterPlaceholderText ?? this._t9nStrings.filter, onCalciteListChange: async () => {
202
+ // keep original order. Add addional values at the end
203
+ const tempSelectedFields = await this.pickListNode.getSelectedItems();
204
+ this.selectedFields = [
205
+ ...new Set([
206
+ ...this.selectedFields.filter((item) => tempSelectedFields.has(item)),
207
+ ...tempSelectedFields.keys()
208
+ ])
209
+ ];
210
+ this.arcgisFieldPickListChange.emit({ selectedFields: this.selectedFields });
211
+ if (!this.multiple) {
212
+ this.arcgisFieldPickListDismissed.emit({ selectedFields: this.selectedFields });
213
+ }
214
+ }, onCalciteListFilter: (event) => {
215
+ event.stopPropagation();
216
+ const node = event.target;
217
+ this.filterFields = node.filteredItems?.map((item) => item.value);
218
+ } }, this.fields.length >= this.showFilterLength && this.showSort && sort, this.multiple && this.showSelectionAll && selectionBtn, [...this.getSortedList()].map((field) => this.calciteValueList(field))))))));
219
+ }
220
+ // --------------------------------------------------------------------------
221
+ //
222
+ // Private Methods
223
+ //
224
+ // --------------------------------------------------------------------------
225
+ setUpObserver() {
226
+ this.observer = new MutationObserver((mutationList /* , observer */) => {
227
+ for (const mutation of mutationList) {
228
+ if (mutation.attributeName === "style") {
229
+ if (this.popoverNode.style.visibility === "hidden") {
230
+ this.dropdownNode.open = false;
231
+ }
232
+ }
233
+ }
234
+ });
235
+ }
236
+ static get assetsDirs() { return ["assets"]; }
237
+ get _hostElement() { return getElement(this); }
238
+ };
239
+ ArcgisFieldPickList.style = fieldPickListScss;
240
+
241
+ export { ArcgisFieldPickList as arcgis_field_pick_list };