@esri/solutions-components 0.10.6 → 0.10.8

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 (157) hide show
  1. package/dist/cjs/basemap-gallery_7.cjs.entry.js +24 -8
  2. package/dist/cjs/buffer-tools_3.cjs.entry.js +1 -1
  3. package/dist/cjs/calcite-combobox_3.cjs.entry.js +354 -967
  4. package/dist/cjs/calcite-graph_2.cjs.entry.js +1082 -0
  5. package/dist/cjs/calcite-shell-panel_14.cjs.entry.js +6 -6
  6. package/dist/cjs/calcite-tree_3.cjs.entry.js +1 -1
  7. package/dist/cjs/card-manager_3.cjs.entry.js +246 -18
  8. package/dist/cjs/crowdsource-manager.cjs.entry.js +169 -49
  9. package/dist/cjs/instant-apps-control-panel.cjs.entry.js +2 -1
  10. package/dist/cjs/instant-apps-time-filter.cjs.entry.js +40 -21
  11. package/dist/cjs/loader.cjs.js +1 -1
  12. package/dist/cjs/map-select-tools_3.cjs.entry.js +3 -3
  13. package/dist/cjs/pci-calculator.cjs.entry.js +1 -1
  14. package/dist/cjs/public-notification.cjs.entry.js +1 -1
  15. package/dist/cjs/refine-results-flow-item.cjs.entry.js +1 -1
  16. package/dist/cjs/share-item.cjs.entry.js +1 -1
  17. package/dist/cjs/solution-configuration.cjs.entry.js +3 -3
  18. package/dist/cjs/solution-contents_3.cjs.entry.js +3 -3
  19. package/dist/cjs/solutions-components.cjs.js +1 -1
  20. package/dist/cjs/spatial-ref.cjs.entry.js +1 -1
  21. package/dist/collection/assets/t9n/crowdsource-manager/resources.json +5 -1
  22. package/dist/collection/assets/t9n/crowdsource-manager/resources_en.json +5 -1
  23. package/dist/collection/assets/t9n/layer-table/resources.json +1 -0
  24. package/dist/collection/assets/t9n/layer-table/resources_en.json +1 -0
  25. package/dist/collection/assets/t9n/map-card/resources.json +6 -1
  26. package/dist/collection/assets/t9n/map-card/resources_en.json +6 -1
  27. package/dist/collection/components/card-manager/card-manager.js +34 -8
  28. package/dist/collection/components/crowdsource-manager/crowdsource-manager.js +173 -65
  29. package/dist/collection/components/layer-table/layer-table.js +175 -8
  30. package/dist/collection/components/map-card/map-card.css +4 -0
  31. package/dist/collection/components/map-card/map-card.js +368 -3
  32. package/dist/collection/components/map-draw-tools/map-draw-tools.js +1 -1
  33. package/dist/collection/components/map-fullscreen/map-fullscreen.js +1 -1
  34. package/dist/collection/components/map-layer-picker/map-layer-picker.js +9 -3
  35. package/dist/collection/components/map-legend/map-legend.js +1 -1
  36. package/dist/collection/components/map-picker/map-picker.css +8 -0
  37. package/dist/collection/components/map-picker/map-picker.js +74 -3
  38. package/dist/collection/components/map-search/map-search.js +1 -1
  39. package/dist/collection/components/map-select-tools/map-select-tools.js +1 -1
  40. package/dist/collection/components/map-tools/map-tools.js +1 -1
  41. package/dist/collection/components/pci-calculator/pci-calculator.js +1 -1
  42. package/dist/collection/components/pdf-download/pdf-download.js +1 -1
  43. package/dist/collection/components/public-notification/public-notification.js +1 -1
  44. package/dist/collection/components/refine-results-flow-item/refine-results-flow-item.js +1 -1
  45. package/dist/collection/components/refine-selection/refine-selection.js +1 -1
  46. package/dist/collection/components/share-item/share-item.js +1 -1
  47. package/dist/collection/components/solution-configuration/solution-configuration.js +3 -3
  48. package/dist/collection/components/solution-contents/solution-contents.js +1 -1
  49. package/dist/collection/components/solution-item/solution-item.js +1 -1
  50. package/dist/collection/components/solution-item-details/solution-item-details.js +1 -1
  51. package/dist/collection/components/solution-item-icon/solution-item-icon.js +1 -1
  52. package/dist/collection/components/solution-item-sharing/solution-item-sharing.js +1 -1
  53. package/dist/collection/components/solution-organization-variables/solution-organization-variables.js +1 -1
  54. package/dist/collection/components/solution-resource-item/solution-resource-item.js +1 -1
  55. package/dist/collection/components/solution-spatial-ref/solution-spatial-ref.js +1 -1
  56. package/dist/collection/components/solution-template-data/solution-template-data.js +1 -1
  57. package/dist/collection/components/solution-variables/solution-variables.js +1 -1
  58. package/dist/collection/components/spatial-ref/spatial-ref.js +1 -1
  59. package/dist/collection/demos/crowdsource-manager.html +1 -0
  60. package/dist/components/card-manager2.js +20 -8
  61. package/dist/components/crowdsource-manager.js +172 -53
  62. package/dist/components/instant-apps-control-panel.js +2 -1
  63. package/dist/components/instant-apps-time-filter.js +46 -23
  64. package/dist/components/layer-table2.js +72 -10
  65. package/dist/components/map-card2.js +288 -47
  66. package/dist/components/map-draw-tools2.js +1 -1
  67. package/dist/components/map-fullscreen2.js +1 -1
  68. package/dist/components/map-layer-picker2.js +9 -3
  69. package/dist/components/map-legend2.js +1 -1
  70. package/dist/components/map-picker2.js +24 -5
  71. package/dist/components/map-search2.js +1 -1
  72. package/dist/components/map-select-tools2.js +1 -1
  73. package/dist/components/map-tools2.js +1 -1
  74. package/dist/components/pci-calculator.js +1 -1
  75. package/dist/components/pdf-download2.js +1 -1
  76. package/dist/components/public-notification.js +1 -1
  77. package/dist/components/refine-results-flow-item.js +1 -1
  78. package/dist/components/refine-selection2.js +1 -1
  79. package/dist/components/share-item.js +1 -1
  80. package/dist/components/solution-configuration.js +3 -3
  81. package/dist/components/solution-contents2.js +1 -1
  82. package/dist/components/solution-item-details2.js +1 -1
  83. package/dist/components/solution-item-icon2.js +1 -1
  84. package/dist/components/solution-item-sharing2.js +1 -1
  85. package/dist/components/solution-item2.js +1 -1
  86. package/dist/components/solution-organization-variables2.js +1 -1
  87. package/dist/components/solution-resource-item2.js +1 -1
  88. package/dist/components/solution-spatial-ref2.js +1 -1
  89. package/dist/components/solution-template-data2.js +1 -1
  90. package/dist/components/solution-variables2.js +1 -1
  91. package/dist/components/spatial-ref.js +1 -1
  92. package/dist/esm/basemap-gallery_7.entry.js +24 -8
  93. package/dist/esm/buffer-tools_3.entry.js +1 -1
  94. package/dist/esm/calcite-combobox_3.entry.js +369 -982
  95. package/dist/esm/calcite-graph_2.entry.js +1077 -0
  96. package/dist/esm/calcite-shell-panel_14.entry.js +6 -6
  97. package/dist/esm/calcite-tree_3.entry.js +1 -1
  98. package/dist/esm/card-manager_3.entry.js +248 -20
  99. package/dist/esm/crowdsource-manager.entry.js +170 -50
  100. package/dist/esm/instant-apps-control-panel.entry.js +2 -1
  101. package/dist/esm/instant-apps-time-filter.entry.js +41 -22
  102. package/dist/esm/loader.js +1 -1
  103. package/dist/esm/map-select-tools_3.entry.js +3 -3
  104. package/dist/esm/pci-calculator.entry.js +1 -1
  105. package/dist/esm/public-notification.entry.js +1 -1
  106. package/dist/esm/refine-results-flow-item.entry.js +1 -1
  107. package/dist/esm/share-item.entry.js +1 -1
  108. package/dist/esm/solution-configuration.entry.js +3 -3
  109. package/dist/esm/solution-contents_3.entry.js +3 -3
  110. package/dist/esm/solutions-components.js +1 -1
  111. package/dist/esm/spatial-ref.entry.js +1 -1
  112. package/dist/solutions-components/assets/t9n/crowdsource-manager/resources.json +5 -1
  113. package/dist/solutions-components/assets/t9n/crowdsource-manager/resources_en.json +5 -1
  114. package/dist/solutions-components/assets/t9n/layer-table/resources.json +1 -0
  115. package/dist/solutions-components/assets/t9n/layer-table/resources_en.json +1 -0
  116. package/dist/solutions-components/assets/t9n/map-card/resources.json +6 -1
  117. package/dist/solutions-components/assets/t9n/map-card/resources_en.json +6 -1
  118. package/dist/solutions-components/demos/crowdsource-manager.html +1 -0
  119. package/dist/solutions-components/p-0abc1354.entry.js +6 -0
  120. package/dist/solutions-components/p-0f7b5d36.entry.js +6 -0
  121. package/dist/solutions-components/p-1867168b.entry.js +6 -0
  122. package/dist/solutions-components/{p-a9818be2.entry.js → p-20c465e9.entry.js} +1 -1
  123. package/dist/solutions-components/{p-db18bce8.entry.js → p-36b50b5b.entry.js} +1 -1
  124. package/dist/solutions-components/{p-85512ae3.entry.js → p-445213cf.entry.js} +1 -1
  125. package/dist/solutions-components/{p-d49f895d.entry.js → p-4a5f0a97.entry.js} +1 -1
  126. package/dist/solutions-components/{p-002c97df.entry.js → p-5d201016.entry.js} +1 -1
  127. package/dist/solutions-components/{p-b7cec3bd.entry.js → p-618bafec.entry.js} +1 -1
  128. package/dist/solutions-components/p-6a66d5a9.entry.js +6 -0
  129. package/dist/solutions-components/p-71a2d5b8.entry.js +6 -0
  130. package/dist/solutions-components/p-7a64b026.entry.js +17 -0
  131. package/dist/solutions-components/p-85c25564.entry.js +6 -0
  132. package/dist/solutions-components/{p-235bf02e.entry.js → p-913413c3.entry.js} +1 -1
  133. package/dist/solutions-components/p-9af1cb14.entry.js +6 -0
  134. package/dist/solutions-components/{p-49aa2929.entry.js → p-bebd4646.entry.js} +1 -1
  135. package/dist/solutions-components/{p-ab2adcaf.entry.js → p-cc092b22.entry.js} +1 -1
  136. package/dist/solutions-components/p-ce454f5a.entry.js +11 -0
  137. package/dist/solutions-components/solutions-components.esm.js +1 -1
  138. package/dist/types/components/card-manager/card-manager.d.ts +11 -0
  139. package/dist/types/components/crowdsource-manager/crowdsource-manager.d.ts +86 -20
  140. package/dist/types/components/layer-table/layer-table.d.ts +30 -0
  141. package/dist/types/components/map-card/map-card.d.ts +124 -0
  142. package/dist/types/components/map-layer-picker/map-layer-picker.d.ts +4 -0
  143. package/dist/types/components/map-picker/map-picker.d.ts +12 -0
  144. package/dist/types/components.d.ts +130 -0
  145. package/dist/types/preact.d.ts +4 -2
  146. package/package.json +2 -2
  147. package/dist/cjs/calcite-dropdown-group_2.cjs.entry.js +0 -453
  148. package/dist/esm/calcite-dropdown-group_2.entry.js +0 -448
  149. package/dist/solutions-components/p-129fd80e.entry.js +0 -6
  150. package/dist/solutions-components/p-3b426576.entry.js +0 -6
  151. package/dist/solutions-components/p-72b217f2.entry.js +0 -6
  152. package/dist/solutions-components/p-72f01088.entry.js +0 -6
  153. package/dist/solutions-components/p-8b999a2b.entry.js +0 -6
  154. package/dist/solutions-components/p-973ff7b2.entry.js +0 -23
  155. package/dist/solutions-components/p-a001f9c9.entry.js +0 -6
  156. package/dist/solutions-components/p-c683b3fe.entry.js +0 -6
  157. package/dist/solutions-components/p-e9d049bd.entry.js +0 -6
@@ -21104,7 +21104,7 @@ const SpatialRef = class {
21104
21104
  * Renders the component.
21105
21105
  */
21106
21106
  render() {
21107
- return (index.h(index.Host, { key: '23f3f6ff3d7eeeaeb8fb916532302a241fdbc078' }, index.h("div", { key: 'ea7631c0c26d451a72bd68e24ccb3ac757cf73f3' }, index.h("calcite-input", { key: '32d27336b3bc34ee6cd0d3c7ac3e52de7ee8011e', disabled: this.disabled, id: "calcite-sr-search", onKeyUp: (evt) => this._searchInputKeyDown(evt), placeholder: this._translations.spatialReferencePlaceholder }), index.h("calcite-tree", { key: '927f03277a45d5cf256306a2246bccffc0d296cb', id: "calcite-sr-tree", slot: "children" }, this._getTreeContent()))));
21107
+ return (index.h(index.Host, { key: '1f9d7ad0fe2043b7e950a59e6b10e1380c218a11' }, index.h("div", { key: 'f9e14494a1d2783c2d80bbe94d355e397674951b' }, index.h("calcite-input", { key: '3c2565f0c1f0bf8d7a4051969ca3bcb68a9107ce', disabled: this.disabled, id: "calcite-sr-search", onKeyUp: (evt) => this._searchInputKeyDown(evt), placeholder: this._translations.spatialReferencePlaceholder }), index.h("calcite-tree", { key: '7657240c433836340bc0767bb7e9206b75d0691d', id: "calcite-sr-tree", slot: "children" }, this._getTreeContent()))));
21108
21108
  }
21109
21109
  _lastHighlightedSref;
21110
21110
  //--------------------------------------------------------------------------
@@ -4,5 +4,9 @@
4
4
  "information": "Information",
5
5
  "expandPopup": "Expand pop-up",
6
6
  "collapsePopup": "Collapse pop-up",
7
- "view": "View ({{n}})"
7
+ "view": "View ({{n}})",
8
+ "splitView": "Split view",
9
+ "tableView": "Table view",
10
+ "mapView": "Map view",
11
+ "filter": "Filter: {{title}}"
8
12
  }
@@ -4,5 +4,9 @@
4
4
  "information": "Information",
5
5
  "expandPopup": "Expand pop-up",
6
6
  "collapsePopup": "Collapse pop-up",
7
- "view": "View ({{n}})"
7
+ "view": "View ({{n}})",
8
+ "splitView": "Split view",
9
+ "tableView": "Table view",
10
+ "mapView": "Map view",
11
+ "filter": "Filter: {{title}}"
8
12
  }
@@ -10,6 +10,7 @@
10
10
  "showSelected": "Show selected",
11
11
  "switchSelected": "Switch selected",
12
12
  "zoom": "Zoom",
13
+ "editMultiple": "Edit multiple",
13
14
  "fetchingData": "Fetching Data",
14
15
  "refresh": "Refresh",
15
16
  "showAll": "Show all",
@@ -10,6 +10,7 @@
10
10
  "showSelected": "Show selected",
11
11
  "switchSelected": "Switch selected",
12
12
  "zoom": "Zoom",
13
+ "editMultiple": "Edit multiple",
13
14
  "fetchingData": "Fetching Data",
14
15
  "refresh": "Refresh",
15
16
  "showAll": "Show all",
@@ -1,3 +1,8 @@
1
1
  {
2
- "mapName": "Map Name"
2
+ "mapName": "Map Name",
3
+ "more": "More",
4
+ "filters": "Filters",
5
+ "zoom": "Zoom",
6
+ "refresh": "Refresh",
7
+ "editMultiple": "Edit multiple"
3
8
  }
@@ -1,3 +1,8 @@
1
1
  {
2
- "mapName": "Map Name"
2
+ "mapName": "Map Name",
3
+ "more": "More",
4
+ "filters": "Filters",
5
+ "zoom": "Zoom",
6
+ "refresh": "Refresh",
7
+ "editMultiple": "Edit multiple"
3
8
  }
@@ -29,6 +29,7 @@ export class CardManager {
29
29
  this.layer = undefined;
30
30
  this.mapView = undefined;
31
31
  this.zoomAndScrollToSelected = undefined;
32
+ this.selectedFeaturesIds = undefined;
32
33
  this._cardLoading = false;
33
34
  this._graphics = undefined;
34
35
  this._translations = undefined;
@@ -59,12 +60,7 @@ export class CardManager {
59
60
  */
60
61
  async featureSelectionChange(evt) {
61
62
  const ids = evt.detail;
62
- this._cardLoading = true;
63
- // only query if we have some ids...query with no ids will result in all features being returned
64
- const featureSet = ids.length > 0 ? await queryFeaturesByID(ids, this.layer, [], false, this.mapView.spatialReference) : [];
65
- // https://github.com/Esri/solutions-components/issues/365
66
- this._graphics = featureSet.sort((a, b) => ids.indexOf(a.getObjectId()) - ids.indexOf(b.getObjectId()));
67
- this._cardLoading = false;
63
+ this._graphics = await this._getFeaturesByIds(ids);
68
64
  }
69
65
  /**
70
66
  * Get the layer view for the provided layer id
@@ -85,6 +81,9 @@ export class CardManager {
85
81
  */
86
82
  async componentWillLoad() {
87
83
  await this._getTranslations();
84
+ if (this.selectedFeaturesIds?.length > 0) {
85
+ this._graphics = await this._getFeaturesByIds(this.selectedFeaturesIds);
86
+ }
88
87
  }
89
88
  /**
90
89
  * Renders the component.
@@ -92,13 +91,25 @@ export class CardManager {
92
91
  render() {
93
92
  const featuresClass = this._graphics?.length > 0 ? "" : "display-none";
94
93
  const messageClass = this._graphics?.length > 0 ? "display-none" : "";
95
- return (h(Host, { key: 'ff2b82f23cc912a79d4f2d04a3263215e54ff03d' }, h("div", { key: '64a96d7162508794b955dc4b557fa94d18f8ab53', class: "overflow-auto height-full" }, h("calcite-shell", { key: '77b8ad0b9a459d2fb9399ccfebc6d0211147bb01', class: "position-relative " + featuresClass }, h("div", { key: 'e0725835f5c1c32a9164e04d6321ba5853a3892c' }, h("info-card", { key: '6712a077c4746585e7b2474aedd14e1869b37c34', enableEditGeometry: this.enableEditGeometry, graphics: this._graphics, isLoading: this._cardLoading, isMobile: this.isMobile, mapView: this.mapView }))), h("calcite-shell", { key: '38c85dbb72df9b9b1225f1488c3bf384f67d7db4', class: "position-relative " + messageClass }, h("div", { key: '66386d1a0d19fb4a023515e5dc4b41ac73a8c257', class: "padding-1" }, h("calcite-notice", { key: '12a843bede7b688651b436bcb9b7ad9e7f6217e0', icon: "table", open: true }, h("div", { key: '28862f4aa25802ca6b2bdc0ef2af3bcb825267f9', slot: "message" }, this._translations.selectFeaturesToStart)))))));
94
+ return (h(Host, { key: '0309205d485d9c7a5c558b3619a6c5ac03fcb528' }, h("div", { key: 'a5d291f6073b0e0a918573549c6eb29fe1d892dd', class: "overflow-auto height-full" }, h("calcite-shell", { key: '572b9cdf002e0c8c46e6c4bc5e2f1f8494228e93', class: "position-relative " + featuresClass }, h("div", { key: 'f8ba07deb9786d64f3d25011ff66ead43d809bf1' }, h("info-card", { key: '6eda3ab2cfa2e5fb948f5a7ddaeb6b9022aa5543', enableEditGeometry: this.enableEditGeometry, graphics: this._graphics, isLoading: this._cardLoading, isMobile: this.isMobile, mapView: this.mapView }))), h("calcite-shell", { key: 'f32d9cfe3a41bbd7d58cdc732c8abe99b232beb7', class: "position-relative " + messageClass }, h("div", { key: 'b97eb023c5d57a4a8dda09467d8599166da40f3c', class: "padding-1" }, h("calcite-notice", { key: '23a204782bd254909e3ab803a944d10004e4954a', icon: "table", open: true }, h("div", { key: 'ea25078647612b8fa40e26b4474a91c853dae126', slot: "message" }, this._translations.selectFeaturesToStart)))))));
96
95
  }
97
96
  //--------------------------------------------------------------------------
98
97
  //
99
98
  // Functions (protected)
100
99
  //
101
100
  //--------------------------------------------------------------------------
101
+ /**
102
+ * Gets the Feature using its ids
103
+ *
104
+ * @returns Promise when complete
105
+ * @protected
106
+ */
107
+ async _getFeaturesByIds(ids) {
108
+ // only query if we have some ids...query with no ids will result in all features being returned
109
+ const featureSet = ids.length > 0 ? await queryFeaturesByID(ids, this.layer, [], false, this.mapView.spatialReference) : [];
110
+ // https://github.com/Esri/solutions-components/issues/365
111
+ return featureSet.sort((a, b) => ids.indexOf(a.getObjectId()) - ids.indexOf(b.getObjectId()));
112
+ }
102
113
  /**
103
114
  * Fetches the component's translations
104
115
  *
@@ -159,7 +170,7 @@ export class CardManager {
159
170
  },
160
171
  "layer": {
161
172
  "type": "unknown",
162
- "mutable": false,
173
+ "mutable": true,
163
174
  "complexType": {
164
175
  "original": "__esri.FeatureLayer",
165
176
  "resolved": "FeatureLayer",
@@ -213,6 +224,21 @@ export class CardManager {
213
224
  },
214
225
  "attribute": "zoom-and-scroll-to-selected",
215
226
  "reflect": false
227
+ },
228
+ "selectedFeaturesIds": {
229
+ "type": "unknown",
230
+ "mutable": false,
231
+ "complexType": {
232
+ "original": "number[]",
233
+ "resolved": "number[]",
234
+ "references": {}
235
+ },
236
+ "required": false,
237
+ "optional": false,
238
+ "docs": {
239
+ "tags": [],
240
+ "text": "A list of ids that are currently selected"
241
+ }
216
242
  }
217
243
  };
218
244
  }
@@ -18,13 +18,13 @@
18
18
  * See the License for the specific language governing permissions and
19
19
  * limitations under the License.
20
20
  */
21
- import { Host, h } from "@stencil/core";
21
+ import { Host, h, Fragment } from "@stencil/core";
22
22
  import { getLocaleComponentStrings } from "../../utils/locale";
23
23
  import { ELayoutMode } from "../../utils/interfaces";
24
24
  import { getLayerOrTable } from "../../utils/mapViewUtils";
25
25
  export class CrowdsourceManager {
26
26
  constructor() {
27
- this.appLayout = undefined;
27
+ this.appLayout = 'splitView';
28
28
  this.appProxies = undefined;
29
29
  this.basemapConfig = undefined;
30
30
  this.coverPageEnabled = undefined;
@@ -61,7 +61,6 @@ export class CrowdsourceManager {
61
61
  this.theme = "light";
62
62
  this.zoomAndScrollToSelected = false;
63
63
  this.zoomToScale = undefined;
64
- this._expandPopup = false;
65
64
  this._hideFooter = false;
66
65
  this._hideTable = false;
67
66
  this._isMobile = false;
@@ -72,7 +71,7 @@ export class CrowdsourceManager {
72
71
  this._mapView = undefined;
73
72
  this._panelOpen = true;
74
73
  this._numSelected = 0;
75
- this._tableOnly = false;
74
+ this._filterOpen = false;
76
75
  }
77
76
  //--------------------------------------------------------------------------
78
77
  //
@@ -116,6 +115,18 @@ export class CrowdsourceManager {
116
115
  * MapView.when is not fired when mapView is not currently visible
117
116
  */
118
117
  _shouldSetMapView = false;
118
+ /**
119
+ * LayerExpression[]: All layer expressions from the current filter config for the currently selected layer
120
+ */
121
+ _layerExpressions;
122
+ /**
123
+ * HTMLInstantAppsFilterListElement: Component from Instant Apps that supports interacting with the current filter config
124
+ */
125
+ _filterList;
126
+ /**
127
+ * boolean: True when app is directly rendered to map view layout
128
+ */
129
+ _isMapViewOnLoad = false;
119
130
  //--------------------------------------------------------------------------
120
131
  //
121
132
  // Watch handlers
@@ -132,7 +143,6 @@ export class CrowdsourceManager {
132
143
  */
133
144
  hideMapOnLoadWatchHandler() {
134
145
  this.showHideMapPopupAndTable(this.hideMapOnLoad && !this._isMobile);
135
- this._expandPopup = this.hideMapOnLoad && !this._isMobile;
136
146
  }
137
147
  //--------------------------------------------------------------------------
138
148
  //
@@ -166,16 +176,6 @@ export class CrowdsourceManager {
166
176
  this.showHideMapPopupAndTable(false);
167
177
  }
168
178
  }
169
- /**
170
- * Listen for idsFound event to be fired so we can know that all layer ids have been fetched
171
- */
172
- async idsFound(evt) {
173
- const ids = evt.detail;
174
- this._tableOnly = ids.tableIds.length > 0 && ids.layerIds.length === 0;
175
- if (this._tableOnly) {
176
- this._expandPopup = true;
177
- }
178
- }
179
179
  /**
180
180
  * Listen for layoutChanged event to be fired so we can adjust the layout
181
181
  */
@@ -191,14 +191,6 @@ export class CrowdsourceManager {
191
191
  await this._setMapView();
192
192
  });
193
193
  }
194
- /**
195
- * Listen for beforeMapChanged and minimize the popup if it's expanded
196
- */
197
- async beforeMapChanged() {
198
- if (this._expandPopup) {
199
- this._shouldSetMapView = true;
200
- }
201
- }
202
194
  /**
203
195
  * Get the layer for the provided layer id
204
196
  */
@@ -207,13 +199,13 @@ export class CrowdsourceManager {
207
199
  const layer = await getLayerOrTable(this._mapView, id);
208
200
  await layer.when(() => {
209
201
  this._layer = layer;
202
+ this._initLayerExpressions();
210
203
  });
211
204
  }
212
205
  /**
213
206
  * Update the state expandPopup when mapInfoChange event occurs
214
207
  */
215
208
  async mapInfoChange() {
216
- this._expandPopup = this.hideMapOnLoad && !this._isMobile;
217
209
  this._hideMapOnLoadHonored = false;
218
210
  }
219
211
  //--------------------------------------------------------------------------
@@ -236,7 +228,7 @@ export class CrowdsourceManager {
236
228
  render() {
237
229
  // only avoid border when we have a header color that is not white
238
230
  const borderClass = this.popupHeaderColor && this.popupHeaderColor !== "#FFFFFF" ? "border-width-0" : "";
239
- return (h(Host, { key: 'f434a8e24b111a32774e9d5683c2446ba35b504b' }, h("calcite-shell", { key: '017843c77fa2c52f0d957760ac3f57808d11d59f', class: "position-relative" }, h("calcite-panel", { key: 'bd8eeec3a013583789b9e1b251fed34e5896171e', class: `width-full height-full ${borderClass}` }, this._getBody(this._layoutMode, this._panelOpen, this._hideTable)), this._getFooter())));
231
+ return (h(Host, { key: 'bbe12b471976652c32fc0cb6277fdfc4171b2cd6' }, h("calcite-shell", { key: '00b85d8e681f5ab021e6efb63b603e3d2442f63c', class: "position-relative" }, h("calcite-panel", { key: 'f1a37f06f3023bb1c63b40eeca739e942c301e63', class: `width-full height-full ${borderClass}` }, this._getBody(this._layoutMode, this._panelOpen, this._hideTable)), this._getFooter()), this._filterModal()));
240
232
  }
241
233
  /**
242
234
  * Called after each render
@@ -255,6 +247,12 @@ export class CrowdsourceManager {
255
247
  */
256
248
  async componentDidLoad() {
257
249
  this._resizeObserver.observe(this.el);
250
+ // for backward compatibility if hidemaponload is true then render table layout as default
251
+ if (this.hideMapOnLoad) {
252
+ this.appLayout = 'tableView';
253
+ }
254
+ this._isMapViewOnLoad = this.appLayout === 'mapView';
255
+ this._setActiveLayout(this.appLayout);
258
256
  }
259
257
  //--------------------------------------------------------------------------
260
258
  //
@@ -272,6 +270,27 @@ export class CrowdsourceManager {
272
270
  const deleteEnabled = this._layer?.editingEnabled && this._layer?.capabilities?.operations?.supportsDelete;
273
271
  return this._isMobile && hasSelectedFeatures && !this._hideFooter ? (h("div", { class: `width-100`, slot: "footer" }, h("div", { class: "display-flex padding-1-2" }, h("calcite-button", { appearance: "solid", id: "solutions-show", onClick: () => this.showHideMapPopupAndTable(true), width: "full" }, this._translations.view.replace("{{n}}", this._numSelected.toString())), deleteEnabled ? (h("delete-button", { class: "padding-inline-start-1 width-full", id: "solutions-delete", ids: this._layerTable.selectedIds, layer: this._layer })) : undefined))) : undefined;
274
272
  }
273
+ /**
274
+ * sets the active layout to render
275
+ * @param appLayout new app layout
276
+ *
277
+ * @protected
278
+ */
279
+ _setActiveLayout(appLayout) {
280
+ //When going to splitView layout the panel should be open
281
+ if (appLayout === 'splitView' && !this._panelOpen) {
282
+ this._toggleLayout();
283
+ }
284
+ //Move the map node based on the selected layout
285
+ //for mapView layout show map in full view and or all other layout show in the card view
286
+ //for tableView the map will be hidden using css
287
+ if (appLayout === 'mapView') {
288
+ this._showMapInFullView();
289
+ }
290
+ else {
291
+ this._showMapInCardView();
292
+ }
293
+ }
275
294
  /**
276
295
  * Get the icon name to use for the divider icon based on the current layout
277
296
  *
@@ -397,8 +416,11 @@ export class CrowdsourceManager {
397
416
  * @protected
398
417
  */
399
418
  _getMapNode(panelOpen) {
400
- const mapContainerClass = this._layoutMode === ELayoutMode.HORIZONTAL && (!this._isMobile || panelOpen) ? "" : "adjusted-height-50";
401
- return (h("div", { class: `${mapContainerClass} overflow-hidden` }, h("map-card", { appProxies: this.appProxies, basemapConfig: this.basemapConfig, class: "width-full", defaultWebmapId: this.defaultWebmap, enableBasemap: this.enableBasemap, enableFloorFilter: this.enableFloorFilter, enableFullscreen: this.enableFullscreen, enableHome: this.enableHome, enableLegend: this.enableLegend, enableSearch: this.enableSearch, enableSingleExpand: true, hidden: this._expandPopup && !this._isMobile, homeZoomIndex: 3, homeZoomPosition: "top-left", homeZoomToolsSize: "s", mapInfos: this.mapInfos?.filter(mapInfo => mapInfo.visible !== false), mapWidgetsIndex: 0, mapWidgetsPosition: "top-right", mapWidgetsSize: "m", stackTools: true, theme: this.theme, toolOrder: ["legend", "search", "fullscreen", "basemap", "floorfilter"] })));
419
+ const isMapLayout = this.appLayout === 'mapView';
420
+ const isTableLayout = this.appLayout === 'tableView';
421
+ const mapContainerClass = (isMapLayout || isTableLayout) ? "position-absolute-0" : this._layoutMode === ELayoutMode.HORIZONTAL && (!this._isMobile || panelOpen) ? "" : "adjusted-height-50";
422
+ const hasMapAndLayer = this.defaultWebmap && this.defaultLayer;
423
+ return (h("div", { class: `${mapContainerClass} overflow-hidden`, id: "card-mapView" }, h("map-card", { appProxies: this.appProxies, basemapConfig: this.basemapConfig, class: "width-full", defaultLayerId: hasMapAndLayer ? this.defaultLayer : "", defaultWebmapId: this.defaultWebmap, enableBasemap: this.enableBasemap, enableFloorFilter: this.enableFloorFilter, enableFullscreen: this.enableFullscreen, enableHome: this.enableHome, enableLegend: this.enableLegend, enableSearch: this.enableSearch, enableSingleExpand: true, hidden: !this._isMobile && isTableLayout, homeZoomIndex: 3, homeZoomPosition: "top-left", homeZoomToolsSize: "s", isMapLayout: isMapLayout, isMobile: this._isMobile, mapInfo: this._mapInfo, mapInfos: this.mapInfos?.filter(mapInfo => mapInfo.visible !== false), mapWidgetsIndex: 0, mapWidgetsPosition: "top-right", mapWidgetsSize: "m", onToggleFilter: this._toggleFilter.bind(this), onlyShowUpdatableLayers: this.onlyShowUpdatableLayers, selectedFeaturesIds: this._layerTable?.selectedIds, selectedLayer: this._layer, stackTools: true, theme: this.theme, toolOrder: ["legend", "search", "fullscreen", "basemap", "floorfilter"], zoomToScale: this.zoomToScale })));
402
424
  }
403
425
  /**
404
426
  * Get the expand node for the popup information
@@ -407,11 +429,7 @@ export class CrowdsourceManager {
407
429
  * @protected
408
430
  */
409
431
  _getPopupExpandNode() {
410
- const icon = this._expandPopup ? "chevrons-down" : "chevrons-up";
411
- const id = "expand-popup";
412
- const tooltip = this._expandPopup ? this._translations.collapsePopup : this._translations.expandPopup;
413
- const themeClass = this.theme === "dark" ? "calcite-mode-dark" : "calcite-mode-light";
414
- const popupNodeClass = !this._expandPopup ? "height-full" : this.mapInfos?.length === 1 || this._isMobile ? "position-absolute-0" : "position-absolute-50";
432
+ const popupNodeClass = "height-full";
415
433
  const headerClass = this._isMobile ? "display-none height-0" : "";
416
434
  const headerTheme = this.popupHeaderColor ? "" : !this._isMobile ? "calcite-mode-dark" : "calcite-mode-light";
417
435
  const containerClass = this._isMobile && this._hideTable ? "position-absolute-0 width-full height-full" : this._isMobile ? "display-none height-0" : "";
@@ -420,16 +438,7 @@ export class CrowdsourceManager {
420
438
  '--calcite-color-foreground-2': this.popupHeaderHoverColor, /* background color that will be displayed on button when hovered */
421
439
  '--calcite-color-text-3': this.popupHeaderTextColor, /* font color that will be displayed on button */
422
440
  '--calcite-color-text-2': this.popupHeaderTextColor, /* font color that will be displayed on popup header text*/
423
- } }, h("calcite-panel", null, !this._isMobile ? (h("div", { class: `display-flex align-items-center ${headerClass}`, slot: "header-content" }, h("calcite-icon", { icon: "information", scale: "s" }), h("div", { class: "padding-inline-start-75" }, this._translations.information))) : undefined, h("calcite-action", { class: headerClass, disabled: this._tableOnly, icon: icon, id: id, onClick: () => this._togglePopup(), slot: "header-actions-end", text: "" }), !this._tableOnly ? h("calcite-tooltip", { class: themeClass, label: "", placement: "bottom", "reference-element": id }, h("span", null, tooltip)) : undefined, this._getCardNode())));
424
- }
425
- /**
426
- * Toggle the popup information
427
- *
428
- * @protected
429
- */
430
- _togglePopup() {
431
- this._expandPopup = !this._expandPopup;
432
- this._hideMapOnLoadHonored = true;
441
+ } }, h("calcite-panel", null, !this._isMobile ? (h("div", { class: `display-flex align-items-center ${headerClass}`, slot: "header-content" }, h("calcite-icon", { icon: "information", scale: "s" }), h("div", { class: "padding-inline-start-75" }, this._translations.information))) : undefined, this._getCardNode())));
433
442
  }
434
443
  /**
435
444
  * Get the card node
@@ -438,9 +447,11 @@ export class CrowdsourceManager {
438
447
  * @protected
439
448
  */
440
449
  _getCardNode() {
441
- const cardManagerHeight = !this._expandPopup && !this._isMobile ? "height-50" : "height-full";
450
+ const isMapLayout = this.appLayout === 'mapView';
451
+ const isTableLayout = this.appLayout === 'tableView';
452
+ const cardManagerHeight = (isMapLayout || isTableLayout) ? "height-full" : !this._isMobile ? "height-50" : "height-full";
442
453
  const themeClass = this.theme === "dark" ? "calcite-mode-dark" : "calcite-mode-light";
443
- return (h("div", { class: `width-50 height-full ${themeClass}` }, h("card-manager", { class: `${cardManagerHeight} width-full`, enableEditGeometry: this?._mapInfo?.enableEditGeometry, isMobile: this._isMobile, mapView: this?._mapView, zoomAndScrollToSelected: this.zoomAndScrollToSelected })));
454
+ return (h("div", { class: `width-50 height-full ${themeClass}` }, h("card-manager", { class: `${cardManagerHeight} width-full`, enableEditGeometry: this?._mapInfo?.enableEditGeometry, isMobile: this._isMobile, layer: this._layer, mapView: this?._mapView, selectedFeaturesIds: this._layerTable?.selectedIds, zoomAndScrollToSelected: this.zoomAndScrollToSelected })));
444
455
  }
445
456
  /**
446
457
  * Get the table node based for the current layout
@@ -452,11 +463,11 @@ export class CrowdsourceManager {
452
463
  * @protected
453
464
  */
454
465
  _getTable(layoutMode, panelOpen, hideTable) {
455
- const tableClass = hideTable && this._isMobile ? "visibility-hidden" : "";
466
+ const isMapLayout = this.appLayout === 'mapView';
467
+ const isTableLayout = this.appLayout === 'tableView';
468
+ const tableClass = hideTable && this._isMobile ? "visibility-hidden" : isMapLayout ? "display-none" : "";
469
+ const mapClass = isMapLayout ? "height-full width-full" : "display-none";
456
470
  const tableSizeClass = this._getTableSizeClass(layoutMode, panelOpen);
457
- const icon = this._getDividerIcon(layoutMode, panelOpen);
458
- const tooltip = panelOpen ? this._translations.close : this._translations.open;
459
- const id = "toggle-layout";
460
471
  const toggleLayout = layoutMode === ELayoutMode.HORIZONTAL ? "horizontal" : "vertical";
461
472
  const toggleSlot = layoutMode === ELayoutMode.HORIZONTAL ? "header" : "panel-start";
462
473
  const hasMapAndLayer = this.defaultWebmap && this.defaultLayer;
@@ -464,10 +475,74 @@ export class CrowdsourceManager {
464
475
  this.defaultGlobalId?.indexOf(",") > -1 ? this.defaultGlobalId.split(",") : [this.defaultGlobalId];
465
476
  const defaultOid = !this.defaultOid ? undefined :
466
477
  this.defaultOid?.indexOf(",") > -1 ? this.defaultOid.split(",").map(o => parseInt(o, 10)) : [parseInt(this.defaultOid, 10)];
467
- return (h("calcite-shell", { class: `${tableSizeClass} ${tableClass} border-bottom` }, !this._isMobile ? (h("calcite-action-bar", { class: "border-sides", expandDisabled: true, layout: toggleLayout, slot: toggleSlot }, h("calcite-action", { class: "toggle-node", icon: icon, id: id, onClick: () => this._toggleLayout(), text: "" }), h("calcite-tooltip", { label: tooltip, placement: "bottom", "reference-element": id }, h("span", null, tooltip)))) : undefined, h("div", { class: `width-full height-full position-relative` }, h("layer-table", { defaultGlobalId: hasMapAndLayer ? globalId : undefined, defaultLayerId: hasMapAndLayer ? this.defaultLayer : "", defaultOid: hasMapAndLayer && !globalId ? defaultOid : undefined, enableAutoRefresh: this.enableAutoRefresh, enableCSV: this.enableCSV, enableColumnReorder: this.enableColumnReorder, enableInlineEdit: this?._mapInfo?.enableInlineEdit, enableShare: this.enableShare, isMobile: this._isMobile, mapHidden: this._expandPopup, mapInfo: this._mapInfo, mapView: this?._mapView, onlyShowUpdatableLayers: this.onlyShowUpdatableLayers, ref: (el) => this._layerTable = el, shareIncludeEmbed: this.shareIncludeEmbed, shareIncludeSocial: this.shareIncludeSocial, showNewestFirst: this.showNewestFirst, zoomAndScrollToSelected: this.zoomAndScrollToSelected, zoomToScale: this.zoomToScale }))));
478
+ return (h("calcite-shell", { class: `${tableSizeClass} border-bottom` }, !this._isMobile ? (h("calcite-action-bar", { class: "border-sides", expandDisabled: true, layout: toggleLayout, slot: toggleSlot }, this.getActions(layoutMode, panelOpen))) : undefined, h("div", { class: `width-full height-full position-relative ${tableClass}` }, h("layer-table", { createFilterModal: false, defaultGlobalId: hasMapAndLayer ? globalId : undefined, defaultLayerId: hasMapAndLayer ? this.defaultLayer : "", defaultOid: hasMapAndLayer && !globalId ? defaultOid : undefined, enableAutoRefresh: this.enableAutoRefresh, enableCSV: this.enableCSV, enableColumnReorder: this.enableColumnReorder, enableInlineEdit: this?._mapInfo?.enableInlineEdit, enableShare: this.enableShare, isMobile: this._isMobile, mapHidden: isTableLayout, mapInfo: this._mapInfo, mapView: this?._mapView, onToggleFilter: this._toggleFilter.bind(this), onlyShowUpdatableLayers: this.onlyShowUpdatableLayers, ref: (el) => this._layerTable = el, shareIncludeEmbed: this.shareIncludeEmbed, shareIncludeSocial: this.shareIncludeSocial, showNewestFirst: this.showNewestFirst, zoomAndScrollToSelected: this.zoomAndScrollToSelected, zoomToScale: this.zoomToScale })), h("div", { class: mapClass, id: "full-map-view" })));
479
+ }
480
+ /**
481
+ * Returns the Actions for table's node
482
+ *
483
+ * @returns Node
484
+ * @protected
485
+ */
486
+ getActions(layoutMode, panelOpen) {
487
+ const icon = this._getDividerIcon(layoutMode, panelOpen);
488
+ const tooltip = panelOpen ? this._translations.close : this._translations.open;
489
+ const id = "toggle-layout";
490
+ return (h(Fragment, null, h("calcite-action", { active: this.appLayout === 'splitView', class: "toggle-node", icon: "browser", id: "browser-action", onClick: () => { this._changeLayout('splitView'); }, text: "" }), h("calcite-tooltip", { placement: "right", "reference-element": "browser-action" }, h("span", null, this._translations.splitView)), h("calcite-action", { active: this.appLayout === 'tableView', class: "toggle-node", icon: "dock-left", id: "dock-left-action", onClick: () => { this._changeLayout('tableView'); }, text: "" }), h("calcite-tooltip", { placement: "right", "reference-element": "dock-left-action" }, h("span", null, this._translations.tableView)), h("calcite-action", { active: this.appLayout === 'mapView', class: "toggle-node", icon: "browser-map", id: "browser-map-action", onClick: () => { this._changeLayout('mapView'); }, text: "" }), h("calcite-tooltip", { placement: "right", "reference-element": "browser-map-action" }, h("span", null, this._translations.mapView)), h("calcite-action", { class: "toggle-node", icon: icon, id: id, onClick: () => this._toggleLayout(), slot: "actions-end", text: "" }), h("calcite-tooltip", { placement: "bottom", "reference-element": id }, h("span", null, tooltip))));
491
+ }
492
+ /**
493
+ * Show filter component in modal
494
+ *
495
+ * @returns node to interact with any configured filters for the current layer
496
+ * @protected
497
+ */
498
+ _filterModal() {
499
+ return (h("calcite-modal", { "aria-labelledby": "modal-title", class: "modal", kind: "brand", onCalciteModalClose: () => void this._closeFilter(), open: this._filterOpen, widthScale: "s" }, h("div", { class: "display-flex align-center", id: "modal-title", slot: "header" }, this._translations?.filter?.replace("{{title}}", this._layer?.title)), h("div", { slot: "content" }, h("instant-apps-filter-list", { autoUpdateUrl: false, closeBtn: true, closeBtnOnClick: async () => this._closeFilter(), comboboxOverlayPositioning: "fixed", layerExpressions: this._layerExpressions, onFilterListReset: () => this._handleFilterListReset(), onFilterUpdate: () => void this._layerTable?.filterUpdate(), ref: (el) => this._filterList = el, view: this._mapView, zoomBtn: false }))));
500
+ }
501
+ /**
502
+ * Store any filters for the current layer.
503
+ * Should only occur on layer change
504
+ *
505
+ * @protected
506
+ */
507
+ _initLayerExpressions() {
508
+ const layerExpressions = this._mapInfo?.filterConfig?.layerExpressions;
509
+ this._layerExpressions = layerExpressions ? layerExpressions.filter((exp) => exp.id === this._layer?.id) : [];
510
+ this._filterList.layerExpressions = this._layerExpressions;
511
+ this._layerExpressions.filter(lyrExp => {
512
+ return lyrExp.expressions.filter(exp => exp.active).length > 0;
513
+ }).length > 0;
514
+ }
515
+ /**
516
+ * Toggle the filter modal
517
+ *
518
+ * @protected
519
+ */
520
+ _toggleFilter() {
521
+ this._filterOpen = !this._filterOpen;
522
+ }
523
+ /**
524
+ * Reset the filter active prop
525
+ *
526
+ * @protected
527
+ */
528
+ _handleFilterListReset() {
529
+ void this._layerTable.filterReset();
530
+ }
531
+ /**
532
+ * Close the filter modal
533
+ *
534
+ * @protected
535
+ */
536
+ async _closeFilter() {
537
+ if (this._filterOpen) {
538
+ this._filterOpen = false;
539
+ void this._layerTable.closeFilter();
540
+ }
468
541
  }
469
542
  /**
470
543
  * Update the component layout when its size changes
544
+ *
545
+ * @protected
471
546
  */
472
547
  _onResize() {
473
548
  const isMobile = this.el.offsetWidth < 1024;
@@ -484,22 +559,67 @@ export class CrowdsourceManager {
484
559
  /**
485
560
  * Open/Close the appropriate panel.
486
561
  * The panel that is toggled is dependent upon the layout mode and if using classic grid or not
562
+ *
563
+ * @protected
487
564
  */
488
565
  _toggleLayout() {
489
566
  this._panelOpen = !this._panelOpen;
490
567
  }
568
+ /**
569
+ * Changes the layout mode
570
+ * @param appLayout selected active app layout
571
+ *
572
+ * @protected
573
+ */
574
+ _changeLayout(appLayout) {
575
+ if (this.appLayout !== appLayout) {
576
+ this._setActiveLayout(appLayout);
577
+ this.appLayout = appLayout;
578
+ if (this._isMapViewOnLoad) {
579
+ void this._layerTable.refresh();
580
+ this._isMapViewOnLoad = false;
581
+ }
582
+ }
583
+ }
584
+ /**
585
+ * shows the map in card view
586
+ *
587
+ * @protected
588
+ */
589
+ _showMapInCardView() {
590
+ if (this.appLayout === 'mapView') {
591
+ const fullMapView = document.getElementById('full-map-view').childNodes[0];
592
+ const splitMapClass = document.getElementById('card-mapView');
593
+ if (fullMapView) {
594
+ splitMapClass.appendChild(fullMapView);
595
+ }
596
+ }
597
+ }
598
+ /**
599
+ * Shows the map in full view
600
+ *
601
+ * @protected
602
+ */
603
+ _showMapInFullView() {
604
+ const splitMap = document.getElementById('card-mapView').childNodes[0];
605
+ const fullMapViewClass = document.getElementById('full-map-view');
606
+ if (splitMap) {
607
+ fullMapViewClass.appendChild(splitMap);
608
+ }
609
+ }
491
610
  /**
492
611
  * Show/Hide the map, popup, and table
493
612
  *
494
613
  * @param show when true the map, popup, and table will be displayed
614
+ * @protected
495
615
  */
496
616
  showHideMapPopupAndTable(show) {
497
- this._expandPopup = false;
498
617
  this._hideTable = show;
499
618
  this._hideFooter = show;
500
619
  }
501
620
  /**
502
621
  * Get the current map info (configuration details) when maps change
622
+ * @param id map changed id
503
623
  *
504
624
  * @returns IMapInfo for the provided id
505
625
  * @protected
@@ -598,7 +718,8 @@ export class CrowdsourceManager {
598
718
  "text": "AppLayout: The type of layout the application should use.\r\nValid values: \"mapView\" or \"tableView\" or \"splitView\""
599
719
  },
600
720
  "attribute": "app-layout",
601
- "reflect": false
721
+ "reflect": false,
722
+ "defaultValue": "'splitView'"
602
723
  },
603
724
  "appProxies": {
604
725
  "type": "any",
@@ -1259,7 +1380,6 @@ export class CrowdsourceManager {
1259
1380
  }
1260
1381
  static get states() {
1261
1382
  return {
1262
- "_expandPopup": {},
1263
1383
  "_hideFooter": {},
1264
1384
  "_hideTable": {},
1265
1385
  "_isMobile": {},
@@ -1270,7 +1390,7 @@ export class CrowdsourceManager {
1270
1390
  "_mapView": {},
1271
1391
  "_panelOpen": {},
1272
1392
  "_numSelected": {},
1273
- "_tableOnly": {}
1393
+ "_filterOpen": {}
1274
1394
  };
1275
1395
  }
1276
1396
  static get events() {
@@ -1329,12 +1449,6 @@ export class CrowdsourceManager {
1329
1449
  "target": "window",
1330
1450
  "capture": false,
1331
1451
  "passive": false
1332
- }, {
1333
- "name": "idsFound",
1334
- "method": "idsFound",
1335
- "target": "window",
1336
- "capture": false,
1337
- "passive": false
1338
1452
  }, {
1339
1453
  "name": "layoutChanged",
1340
1454
  "method": "layoutChanged",
@@ -1347,12 +1461,6 @@ export class CrowdsourceManager {
1347
1461
  "target": "window",
1348
1462
  "capture": false,
1349
1463
  "passive": false
1350
- }, {
1351
- "name": "beforeMapChanged",
1352
- "method": "beforeMapChanged",
1353
- "target": "window",
1354
- "capture": false,
1355
- "passive": false
1356
1464
  }, {
1357
1465
  "name": "layerSelectionChange",
1358
1466
  "method": "layerSelectionChange",