@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
@@ -2,20 +2,11 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const index = require('./index-e8c59179.js');
6
-
7
- /*
8
- Stencil Client Patch Esm v2.22.3 | MIT Licensed | https://stenciljs.com
9
- */
10
- const patchEsm = () => {
11
- return index.promiseResolve();
12
- };
5
+ const index = require('./index-e0422bc8.js');
13
6
 
14
7
  const defineCustomElements = (win, options) => {
15
- if (typeof window === 'undefined') return Promise.resolve();
16
- return patchEsm().then(() => {
17
- return index.bootstrapLazy([["arcgis-api-key.cjs",[[0,"arcgis-api-key",{"apiKey":[1,"api-key"]}]]],["arcgis-identity.cjs",[[0,"arcgis-identity",{"identity":[1040],"appId":[1,"app-id"],"credential":[1040],"expiration":[1026],"locale":[1],"usePopup":[4,"use-popup"],"popupCallbackUrl":[1,"popup-callback-url"],"portalUrl":[1,"portal-url"],"preserveUrlHash":[4,"preserve-url-hash"],"signIn":[64],"signOut":[64]}]]]], options);
18
- });
8
+ if (typeof window === 'undefined') return undefined;
9
+ return index.bootstrapLazy([["arcgis-field-info.cjs",[[1,"arcgis-field-info",{"view":[16],"layer":[16],"fieldName":[1,"field-name"],"hideStatistics":[4,"hide-statistics"],"oneFeatureResponse":[32],"oneFeatureResponseStatus":[32],"statistics":[32],"statisticsStatus":[32],"uniqueValues":[32],"uniqueValuesStatus":[32],"_lang":[32],"_t9nLocale":[32],"_t9nStrings":[32]}]]],["arcgis-field-pick-list.cjs",[[1,"arcgis-field-pick-list",{"selectedFields":[1040],"fields":[16],"popoverProps":[16],"layer":[16],"mapView":[16],"showFieldInfo":[4,"show-field-info"],"showFieldName":[4,"show-field-name"],"showDescription":[4,"show-description"],"showSelectionAll":[4,"show-selection-all"],"showCancel":[4,"show-cancel"],"showSort":[4,"show-sort"],"showFilterLength":[2,"show-filter-length"],"multiple":[4],"heading":[1],"okBtnText":[1,"ok-btn-text"],"filterPlaceholderText":[1,"filter-placeholder-text"],"sortBy":[1,"sort-by"],"lastSortyBy":[32],"filterFields":[32],"_lang":[32],"_t9nLocale":[32],"_t9nStrings":[32],"setFocus":[64],"reposition":[64]}]]]], options);
19
10
  };
20
11
 
21
12
  exports.setNonce = index.setNonce;
@@ -1,9 +1,9 @@
1
1
  import type { Components, JSX } from "../types/components";
2
2
 
3
- interface ArcgisApiKey extends Components.ArcgisApiKey, HTMLElement {}
4
- export const ArcgisApiKey: {
5
- prototype: ArcgisApiKey;
6
- new (): ArcgisApiKey;
3
+ interface ArcgisFieldInfo extends Components.ArcgisFieldInfo, HTMLElement {}
4
+ export const ArcgisFieldInfo: {
5
+ prototype: ArcgisFieldInfo;
6
+ new (): ArcgisFieldInfo;
7
7
  };
8
8
  /**
9
9
  * Used to define this component and all nested components recursively.
@@ -0,0 +1,6 @@
1
+ import { A as ArcgisFieldInfo$1, d as defineCustomElement$1 } from './field-info.js';
2
+
3
+ const ArcgisFieldInfo = ArcgisFieldInfo$1;
4
+ const defineCustomElement = defineCustomElement$1;
5
+
6
+ export { ArcgisFieldInfo, defineCustomElement };
@@ -1,9 +1,9 @@
1
1
  import type { Components, JSX } from "../types/components";
2
2
 
3
- interface ArcgisIdentity extends Components.ArcgisIdentity, HTMLElement {}
4
- export const ArcgisIdentity: {
5
- prototype: ArcgisIdentity;
6
- new (): ArcgisIdentity;
3
+ interface ArcgisFieldPickList extends Components.ArcgisFieldPickList, HTMLElement {}
4
+ export const ArcgisFieldPickList: {
5
+ prototype: ArcgisFieldPickList;
6
+ new (): ArcgisFieldPickList;
7
7
  };
8
8
  /**
9
9
  * Used to define this component and all nested components recursively.
@@ -0,0 +1,301 @@
1
+ import { proxyCustomElement, HTMLElement, createEvent, h, getAssetPath, Host } from '@stencil/core/internal/client';
2
+ import { F, i as importIntl, U, C, d as defineCustomElement$2 } from './field-info.js';
3
+ import '@esri/calcite-components/dist/components/calcite-pick-list-item.js';
4
+ import '@esri/calcite-components/dist/components/calcite-action.js';
5
+ import '@esri/calcite-components/dist/components/calcite-button.js';
6
+ import '@esri/calcite-components/dist/components/calcite-dropdown.js';
7
+ import '@esri/calcite-components/dist/components/calcite-icon.js';
8
+ import '@esri/calcite-components/dist/components/calcite-dropdown-group.js';
9
+ import '@esri/calcite-components/dist/components/calcite-dropdown-item.js';
10
+ import '@esri/calcite-components/dist/components/calcite-popover.js';
11
+ import '@esri/calcite-components/dist/components/calcite-flow.js';
12
+ import '@esri/calcite-components/dist/components/calcite-flow-item.js';
13
+ import '@esri/calcite-components/dist/components/calcite-pick-list.js';
14
+
15
+ const fieldPickListScss = ".popover{z-index:100}.panel{min-height:300px}.content{max-height:60vh}.selection-button-div{padding:4px 10px}";
16
+
17
+ var FieldInfoPrefix;
18
+ (function (FieldInfoPrefix) {
19
+ FieldInfoPrefix["expression"] = "expression/";
20
+ FieldInfoPrefix["relationship"] = "relationships/";
21
+ FieldInfoPrefix["raster"] = "Raster.";
22
+ })(FieldInfoPrefix || (FieldInfoPrefix = {}));
23
+ var LastSortyBy;
24
+ (function (LastSortyBy) {
25
+ LastSortyBy["default"] = "default";
26
+ LastSortyBy["display"] = "display";
27
+ LastSortyBy["type"] = "type";
28
+ LastSortyBy["field"] = "field";
29
+ })(LastSortyBy || (LastSortyBy = {}));
30
+ const ArcgisFieldPickList$1 = /*@__PURE__*/ proxyCustomElement(class ArcgisFieldPickList extends HTMLElement {
31
+ constructor() {
32
+ super();
33
+ this.__registerHost();
34
+ this.__attachShadow();
35
+ this.arcgisFieldPickListDismissed = createEvent(this, "arcgisFieldPickListDismissed", 7);
36
+ this.arcgisFieldPickListChange = createEvent(this, "arcgisFieldPickListChange", 7);
37
+ this.arcgisFieldPickListSortByChange = createEvent(this, "arcgisFieldPickListSortByChange", 7);
38
+ this.calciteValueList = (field) => (h("calcite-pick-list-item", { key: field.name, label: field.alias || field.name, description: (() => {
39
+ if (this.showFieldName) {
40
+ return `{${field.name}}`;
41
+ }
42
+ if (this.showDescription && field.description) {
43
+ return field.description;
44
+ }
45
+ return null;
46
+ })(), value: field.name, selected: (!this.multiple && field.name === this.selectedFields[0]) ||
47
+ (this.multiple && this.selectedFields.indexOf(field.name) > -1), metadata: {
48
+ label: field.alias,
49
+ fieldName: field.name
50
+ } }, this.showFieldInfoCheck(field) && (h("calcite-action", { slot: "actions-end", text: this._t9nStrings.info, title: this._t9nStrings.info, scale: "s", icon: "information", onClick: (event) => {
51
+ event.stopPropagation();
52
+ const action = event.target;
53
+ const fieldInfoFlowItem = document.createElement("calcite-flow-item");
54
+ fieldInfoFlowItem.heading = field.alias ?? field.name;
55
+ fieldInfoFlowItem.description = field.name;
56
+ fieldInfoFlowItem.className = "panel";
57
+ const fieldInfo = document.createElement("arcgis-field-info");
58
+ fieldInfo.lang = this._lang;
59
+ fieldInfo.fieldName = field.name;
60
+ fieldInfo.layer = this.layer;
61
+ fieldInfo.view = this.mapView;
62
+ fieldInfo.classList.add("content");
63
+ fieldInfoFlowItem.appendChild(fieldInfo);
64
+ fieldInfoFlowItem.addEventListener("calciteFlowItemBack", () => setTimeout(() => requestAnimationFrame(() => action.setFocus()), 200));
65
+ this.flowElement.appendChild(fieldInfoFlowItem);
66
+ setTimeout(() => requestAnimationFrame(() => fieldInfoFlowItem.setFocus()), 200);
67
+ } }))));
68
+ this.selectedFields = [];
69
+ this.fields = undefined;
70
+ this.popoverProps = undefined;
71
+ this.layer = undefined;
72
+ this.mapView = undefined;
73
+ this.showFieldInfo = false;
74
+ this.showFieldName = false;
75
+ this.showDescription = false;
76
+ this.showSelectionAll = false;
77
+ this.showCancel = true;
78
+ this.showSort = true;
79
+ this.showFilterLength = 10;
80
+ this.multiple = false;
81
+ this.heading = undefined;
82
+ this.okBtnText = undefined;
83
+ this.filterPlaceholderText = undefined;
84
+ this.sortBy = undefined;
85
+ this.lastSortyBy = LastSortyBy.default;
86
+ this.filterFields = null;
87
+ this._lang = "";
88
+ this._t9nLocale = "";
89
+ this._t9nStrings = undefined;
90
+ }
91
+ // --------------------------------------------------------------------------
92
+ //
93
+ // Lifecycle
94
+ //
95
+ // --------------------------------------------------------------------------
96
+ async componentWillLoad() {
97
+ await F(this, getAssetPath("./assets"));
98
+ // in case more than 1 selected field and multiple is set to false
99
+ if (!this.multiple && this.selectedFields.length > 1) {
100
+ this.selectedFields = [this.selectedFields[0]];
101
+ }
102
+ this.lastSortyBy = this.sortBy || this.lastSortyBy;
103
+ }
104
+ async componentDidLoad() {
105
+ const intl = await importIntl();
106
+ intl.setLocale(this._lang);
107
+ this.setUpObserver();
108
+ this.popoverNode.open = true;
109
+ // need timeout because of re-render
110
+ setTimeout(() => requestAnimationFrame(() => this.panelElement.setFocus()), 200);
111
+ }
112
+ disconnectedCallback() {
113
+ U(this);
114
+ this.observer?.disconnect();
115
+ }
116
+ // --------------------------------------------------------------------------
117
+ //
118
+ // Public Methods
119
+ //
120
+ // --------------------------------------------------------------------------
121
+ async setFocus() {
122
+ setTimeout(() => requestAnimationFrame(() => this.panelElement.setFocus()), 1);
123
+ }
124
+ async reposition() {
125
+ this.popoverNode?.reposition();
126
+ }
127
+ // --------------------------------------------------------------------------
128
+ //
129
+ // Private Methods
130
+ //
131
+ // --------------------------------------------------------------------------
132
+ getSortedList() {
133
+ const tempSorted = [...this.fields];
134
+ if (this.lastSortyBy === LastSortyBy.display) {
135
+ tempSorted.sort((a, b) => a.alias.localeCompare(b.alias));
136
+ }
137
+ else if (this.lastSortyBy === LastSortyBy.field) {
138
+ tempSorted.sort((a, b) => a.name.localeCompare(b.name));
139
+ }
140
+ else if (this.lastSortyBy === LastSortyBy.type) {
141
+ tempSorted.sort((a, b) => a.type.localeCompare(b.type));
142
+ }
143
+ return tempSorted;
144
+ }
145
+ showFieldInfoCheck(field) {
146
+ if (this.showFieldInfo) {
147
+ // dont want info for arcade and relation fields
148
+ if (field.name.includes(FieldInfoPrefix.expression) || field.name.includes(FieldInfoPrefix.relationship)) {
149
+ return false;
150
+ }
151
+ else {
152
+ return true;
153
+ }
154
+ }
155
+ else {
156
+ return false;
157
+ }
158
+ }
159
+ // return true for deselect all, false for select all
160
+ selectDeselect() {
161
+ return this.filterFields?.length ? this.filterContainsAll() : this.selectedFields.length === this.fields.length;
162
+ }
163
+ // check if filter has all current field info
164
+ filterContainsAll() {
165
+ return !!this.filterFields?.every((filter) => this.selectedFields.some((curr) => curr === filter));
166
+ }
167
+ // --------------------------------------------------------------------------
168
+ //
169
+ // Rendor Methods
170
+ //
171
+ // --------------------------------------------------------------------------
172
+ render() {
173
+ const addBtn = (h("calcite-button", { slot: "footer", appearance: this.showCancel ? "solid" : "outline-fill", width: this.showCancel ? "half" : "full", scale: "m", onClick: () => {
174
+ this.arcgisFieldPickListDismissed.emit({ selectedFields: this.selectedFields });
175
+ } }, this.okBtnText || (this.multiple ? this._t9nStrings.done : this._t9nStrings.ok)));
176
+ const cancelBtn = (h("calcite-button", { slot: "footer", appearance: "outline-fill", width: this.multiple ? "half" : "full", scale: "m", onClick: () => this.arcgisFieldPickListDismissed.emit() }, this._t9nStrings.cancel));
177
+ const hasType = this.fields.every((field) => !!field.type);
178
+ const sort = (h("calcite-dropdown", { slot: "menu-actions", placement: "bottom-end", overlayPositioning: "fixed", ref: (node) => (this.dropdownNode = node), onCalciteDropdownOpen: () => {
179
+ this.observer?.disconnect();
180
+ this.observer?.observe(this.popoverNode, { attributes: true });
181
+ }, 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: () => {
182
+ this.lastSortyBy = LastSortyBy.default;
183
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
184
+ } }, this._t9nStrings.default), h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.display, onClick: () => {
185
+ this.lastSortyBy = LastSortyBy.display;
186
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
187
+ } }, this._t9nStrings.displayName), hasType && (h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.type, onClick: () => {
188
+ this.lastSortyBy = LastSortyBy.type;
189
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
190
+ } }, this._t9nStrings.type)), h("calcite-dropdown-item", { selected: this.lastSortyBy === LastSortyBy.field, onClick: () => {
191
+ this.lastSortyBy = LastSortyBy.field;
192
+ this.arcgisFieldPickListSortByChange.emit(this.lastSortyBy);
193
+ } }, this._t9nStrings.fieldName))));
194
+ const selectionBtn = (h("div", { class: "selection-button-div" }, h("calcite-button", { appearance: "transparent", scale: "s", width: "full", onClick: () => {
195
+ if (this.selectDeselect()) {
196
+ //deselect all
197
+ this.selectedFields = this.filterFields?.length
198
+ ? this.selectedFields.filter((item) => !this.filterFields?.includes(item))
199
+ : [];
200
+ }
201
+ else {
202
+ //select all
203
+ this.selectedFields = this.filterFields?.length
204
+ ? [...new Set([...this.selectedFields, ...this.filterFields])]
205
+ : this.fields.map((field) => field.name);
206
+ }
207
+ } }, this.selectDeselect() ? this._t9nStrings.deselectAll : this._t9nStrings.selectAll)));
208
+ 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) => {
209
+ this.flowElement = node;
210
+ }, style: {
211
+ width: `${this.popoverProps.popoverWidth || this.popoverProps.refElement.getBoundingClientRect().width}px`
212
+ } }, 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) => {
213
+ this.pickListNode = node;
214
+ }, class: "content", filterEnabled: this.fields.length >= this.showFilterLength, filterPlaceholder: this.filterPlaceholderText ?? this._t9nStrings.filter, onCalciteListChange: async () => {
215
+ // keep original order. Add addional values at the end
216
+ const tempSelectedFields = await this.pickListNode.getSelectedItems();
217
+ this.selectedFields = [
218
+ ...new Set([
219
+ ...this.selectedFields.filter((item) => tempSelectedFields.has(item)),
220
+ ...tempSelectedFields.keys()
221
+ ])
222
+ ];
223
+ this.arcgisFieldPickListChange.emit({ selectedFields: this.selectedFields });
224
+ if (!this.multiple) {
225
+ this.arcgisFieldPickListDismissed.emit({ selectedFields: this.selectedFields });
226
+ }
227
+ }, onCalciteListFilter: (event) => {
228
+ event.stopPropagation();
229
+ const node = event.target;
230
+ this.filterFields = node.filteredItems?.map((item) => item.value);
231
+ } }, this.fields.length >= this.showFilterLength && this.showSort && sort, this.multiple && this.showSelectionAll && selectionBtn, [...this.getSortedList()].map((field) => this.calciteValueList(field))))))));
232
+ }
233
+ // --------------------------------------------------------------------------
234
+ //
235
+ // Private Methods
236
+ //
237
+ // --------------------------------------------------------------------------
238
+ setUpObserver() {
239
+ this.observer = new MutationObserver((mutationList /* , observer */) => {
240
+ for (const mutation of mutationList) {
241
+ if (mutation.attributeName === "style") {
242
+ if (this.popoverNode.style.visibility === "hidden") {
243
+ this.dropdownNode.open = false;
244
+ }
245
+ }
246
+ }
247
+ });
248
+ }
249
+ static get assetsDirs() { return ["assets"]; }
250
+ get _hostElement() { return this; }
251
+ static get style() { return fieldPickListScss; }
252
+ }, [1, "arcgis-field-pick-list", {
253
+ "selectedFields": [1040],
254
+ "fields": [16],
255
+ "popoverProps": [16],
256
+ "layer": [16],
257
+ "mapView": [16],
258
+ "showFieldInfo": [4, "show-field-info"],
259
+ "showFieldName": [4, "show-field-name"],
260
+ "showDescription": [4, "show-description"],
261
+ "showSelectionAll": [4, "show-selection-all"],
262
+ "showCancel": [4, "show-cancel"],
263
+ "showSort": [4, "show-sort"],
264
+ "showFilterLength": [2, "show-filter-length"],
265
+ "multiple": [4],
266
+ "heading": [1],
267
+ "okBtnText": [1, "ok-btn-text"],
268
+ "filterPlaceholderText": [1, "filter-placeholder-text"],
269
+ "sortBy": [1, "sort-by"],
270
+ "lastSortyBy": [32],
271
+ "filterFields": [32],
272
+ "_lang": [32],
273
+ "_t9nLocale": [32],
274
+ "_t9nStrings": [32],
275
+ "setFocus": [64],
276
+ "reposition": [64]
277
+ }]);
278
+ function defineCustomElement$1() {
279
+ if (typeof customElements === "undefined") {
280
+ return;
281
+ }
282
+ const components = ["arcgis-field-pick-list", "arcgis-field-info"];
283
+ components.forEach(tagName => { switch (tagName) {
284
+ case "arcgis-field-pick-list":
285
+ if (!customElements.get(tagName)) {
286
+ customElements.define(tagName, ArcgisFieldPickList$1);
287
+ }
288
+ break;
289
+ case "arcgis-field-info":
290
+ if (!customElements.get(tagName)) {
291
+ defineCustomElement$2();
292
+ }
293
+ break;
294
+ } });
295
+ }
296
+ defineCustomElement$1();
297
+
298
+ const ArcgisFieldPickList = ArcgisFieldPickList$1;
299
+ const defineCustomElement = defineCustomElement$1;
300
+
301
+ export { ArcgisFieldPickList, defineCustomElement };