@esri/solutions-components 0.6.6 → 0.6.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 (197) hide show
  1. package/dist/cjs/basemap-gallery_4.cjs.entry.js +622 -0
  2. package/dist/cjs/card-manager_4.cjs.entry.js +91 -37
  3. package/dist/cjs/crowdsource-manager.cjs.entry.js +4 -2
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/solutions-components.cjs.js +2 -2
  6. package/dist/collection/collection-manifest.json +3 -1
  7. package/dist/collection/components/basemap-gallery/basemap-gallery.css +19 -0
  8. package/dist/collection/components/basemap-gallery/basemap-gallery.js +166 -0
  9. package/dist/collection/components/basemap-gallery/test/basemap-gallery.e2e.js +29 -0
  10. package/dist/collection/components/basemap-gallery/test/basemap-gallery.spec.js +37 -0
  11. package/dist/collection/components/crowdsource-manager/crowdsource-manager.js +43 -2
  12. package/dist/collection/components/layer-table/layer-table.js +99 -30
  13. package/dist/collection/components/map-card/map-card.css +0 -7
  14. package/dist/collection/components/map-card/map-card.js +12 -7
  15. package/dist/collection/components/map-search/map-search.css +24 -0
  16. package/dist/collection/components/map-search/map-search.js +321 -0
  17. package/dist/collection/components/map-search/test/map-search.e2e.js +29 -0
  18. package/dist/collection/components/map-search/test/map-search.spec.js +37 -0
  19. package/dist/collection/components/map-tools/map-tools.js +139 -14
  20. package/dist/collection/demos/crowdsource-manager.html +3 -3
  21. package/dist/collection/utils/interfaces.ts +2 -0
  22. package/dist/components/action-bar.js +1 -0
  23. package/dist/components/action-group.js +1 -0
  24. package/dist/components/action-menu.js +1 -0
  25. package/dist/components/action.js +1 -0
  26. package/dist/components/alert.js +1 -0
  27. package/dist/components/avatar.js +1 -0
  28. package/dist/components/basemap-gallery.d.ts +11 -0
  29. package/dist/components/basemap-gallery.js +11 -0
  30. package/dist/components/basemap-gallery2.js +118 -0
  31. package/dist/components/buffer-tools2.js +1 -0
  32. package/dist/components/button.js +1 -0
  33. package/dist/components/calcite-accordion-item.js +1 -0
  34. package/dist/components/calcite-accordion.js +1 -0
  35. package/dist/components/calcite-action-pad.js +1 -0
  36. package/dist/components/calcite-block-section.js +1 -0
  37. package/dist/components/calcite-block.js +1 -0
  38. package/dist/components/calcite-card.js +1 -0
  39. package/dist/components/calcite-chip-group.js +1 -0
  40. package/dist/components/calcite-color-picker.js +1 -0
  41. package/dist/components/calcite-combobox-item-group.js +1 -0
  42. package/dist/components/calcite-fab.js +1 -0
  43. package/dist/components/calcite-flow-item.js +1 -0
  44. package/dist/components/calcite-flow.js +1 -0
  45. package/dist/components/calcite-inline-editable.js +1 -0
  46. package/dist/components/calcite-input-date-picker.js +1 -0
  47. package/dist/components/calcite-input-time-picker.js +1 -0
  48. package/dist/components/calcite-input-time-zone.js +1 -0
  49. package/dist/components/calcite-list-item-group.js +1 -0
  50. package/dist/components/calcite-menu-item.js +1 -0
  51. package/dist/components/calcite-modal.js +1 -0
  52. package/dist/components/calcite-navigation-logo.js +1 -0
  53. package/dist/components/calcite-navigation-user.js +1 -0
  54. package/dist/components/calcite-navigation.js +1 -0
  55. package/dist/components/calcite-option-group.js +1 -0
  56. package/dist/components/calcite-pagination.js +1 -0
  57. package/dist/components/calcite-pick-list-group.js +1 -0
  58. package/dist/components/calcite-pick-list.js +1 -0
  59. package/dist/components/calcite-radio-button-group.js +1 -0
  60. package/dist/components/calcite-radio-button.js +1 -0
  61. package/dist/components/calcite-rating.js +1 -0
  62. package/dist/components/calcite-shell-center-row.js +1 -0
  63. package/dist/components/calcite-sortable-list.js +1 -0
  64. package/dist/components/calcite-split-button.js +1 -0
  65. package/dist/components/calcite-stepper-item.js +1 -0
  66. package/dist/components/calcite-stepper.js +1 -0
  67. package/dist/components/calcite-text-area.js +1 -0
  68. package/dist/components/calcite-tile-select-group.js +1 -0
  69. package/dist/components/calcite-tile-select.js +1 -0
  70. package/dist/components/calcite-tip-group.js +1 -0
  71. package/dist/components/calcite-tip-manager.js +1 -0
  72. package/dist/components/calcite-tip.js +1 -0
  73. package/dist/components/card-manager2.js +1 -0
  74. package/dist/components/checkbox.js +1 -0
  75. package/dist/components/chip.js +1 -0
  76. package/dist/components/color-picker-hex-input.js +1 -0
  77. package/dist/components/color-picker-swatch.js +1 -0
  78. package/dist/components/combobox-item.js +1 -0
  79. package/dist/components/combobox.js +1 -0
  80. package/dist/components/crowdsource-manager.js +95 -78
  81. package/dist/components/crowdsource-reporter.js +1 -0
  82. package/dist/components/date-picker-day.js +1 -0
  83. package/dist/components/date-picker-month-header.js +1 -0
  84. package/dist/components/date-picker-month.js +1 -0
  85. package/dist/components/date-picker.js +1 -0
  86. package/dist/components/deduct-calculator2.js +1 -0
  87. package/dist/components/dropdown-group.js +1 -0
  88. package/dist/components/dropdown-item.js +1 -0
  89. package/dist/components/dropdown.js +1 -0
  90. package/dist/components/edit-card2.js +1 -0
  91. package/dist/components/esri-loader.js +301 -0
  92. package/dist/components/filter2.js +1 -0
  93. package/dist/components/graph.js +1 -0
  94. package/dist/components/handle.js +1 -0
  95. package/dist/components/icon.js +1 -0
  96. package/dist/components/index.d.ts +6 -0
  97. package/dist/components/index.js +1 -1
  98. package/dist/components/info-card2.js +1 -0
  99. package/dist/components/input-message.js +1 -0
  100. package/dist/components/input-number.js +1 -0
  101. package/dist/components/input-text.js +1 -0
  102. package/dist/components/input.js +1 -0
  103. package/dist/components/json-editor2.js +1 -0
  104. package/dist/components/label2.js +1 -0
  105. package/dist/components/layer-table2.js +83 -31
  106. package/dist/components/layout-manager2.js +1 -0
  107. package/dist/components/link.js +1 -0
  108. package/dist/components/list-item.js +1 -0
  109. package/dist/components/list-item2.js +1 -0
  110. package/dist/components/list.js +1 -0
  111. package/dist/components/loadModules.js +1 -1
  112. package/dist/components/loader.js +1 -0
  113. package/dist/components/locale.js +2 -295
  114. package/dist/components/map-card2.js +61 -42
  115. package/dist/components/map-draw-tools2.js +1 -0
  116. package/dist/components/map-layer-picker2.js +1 -0
  117. package/dist/components/map-picker2.js +1 -0
  118. package/dist/components/map-search.d.ts +11 -0
  119. package/dist/components/map-search.js +11 -0
  120. package/dist/components/map-search2.js +201 -0
  121. package/dist/components/map-select-tools2.js +1 -0
  122. package/dist/components/map-tools2.js +141 -30
  123. package/dist/components/menu.js +1 -0
  124. package/dist/components/notice.js +1 -0
  125. package/dist/components/option.js +1 -0
  126. package/dist/components/panel.js +1 -0
  127. package/dist/components/pci-calculator.js +1 -0
  128. package/dist/components/pdf-download2.js +1 -0
  129. package/dist/components/pick-list-item.js +1 -0
  130. package/dist/components/popover.js +1 -0
  131. package/dist/components/progress.js +1 -0
  132. package/dist/components/public-notification.js +1 -0
  133. package/dist/components/refine-selection2.js +1 -0
  134. package/dist/components/scrim.js +1 -0
  135. package/dist/components/segmented-control-item.js +1 -0
  136. package/dist/components/segmented-control.js +1 -0
  137. package/dist/components/select.js +1 -0
  138. package/dist/components/shell-panel.js +1 -0
  139. package/dist/components/shell.js +1 -0
  140. package/dist/components/slider.js +1 -0
  141. package/dist/components/solution-configuration.js +1 -0
  142. package/dist/components/solution-contents2.js +1 -0
  143. package/dist/components/solution-item-details2.js +1 -0
  144. package/dist/components/solution-item-icon2.js +1 -0
  145. package/dist/components/solution-item-sharing2.js +1 -0
  146. package/dist/components/solution-item2.js +1 -0
  147. package/dist/components/solution-organization-variables2.js +1 -0
  148. package/dist/components/solution-resource-item2.js +1 -0
  149. package/dist/components/solution-spatial-ref2.js +1 -0
  150. package/dist/components/solution-template-data2.js +1 -0
  151. package/dist/components/solution-variables2.js +1 -0
  152. package/dist/components/stack.js +1 -0
  153. package/dist/components/store-manager.js +1 -0
  154. package/dist/components/switch.js +1 -0
  155. package/dist/components/tab-nav.js +1 -0
  156. package/dist/components/tab-title.js +1 -0
  157. package/dist/components/tab.js +1 -0
  158. package/dist/components/tabs.js +1 -0
  159. package/dist/components/tile.js +1 -0
  160. package/dist/components/time-picker.js +1 -0
  161. package/dist/components/tooltip.js +1 -0
  162. package/dist/components/tree-item.js +1 -0
  163. package/dist/components/tree.js +1 -0
  164. package/dist/components/value-list-item.js +1 -0
  165. package/dist/components/value-list.js +1 -0
  166. package/dist/esm/basemap-gallery_4.entry.js +615 -0
  167. package/dist/esm/card-manager_4.entry.js +91 -37
  168. package/dist/esm/crowdsource-manager.entry.js +4 -2
  169. package/dist/esm/loader.js +1 -1
  170. package/dist/esm/polyfills/core-js.js +11 -0
  171. package/dist/esm/polyfills/dom.js +79 -0
  172. package/dist/esm/polyfills/es5-html-element.js +1 -0
  173. package/dist/esm/polyfills/index.js +34 -0
  174. package/dist/esm/polyfills/system.js +6 -0
  175. package/dist/esm/solutions-components.js +2 -2
  176. package/dist/solutions-components/demos/crowdsource-manager.html +3 -3
  177. package/dist/solutions-components/p-55aefaa8.entry.js +6 -0
  178. package/dist/solutions-components/p-5b5a6ac8.entry.js +6 -0
  179. package/dist/solutions-components/p-a6c85bd7.entry.js +6 -0
  180. package/dist/solutions-components/solutions-components.esm.js +1 -1
  181. package/dist/solutions-components/utils/interfaces.ts +2 -0
  182. package/dist/types/components/basemap-gallery/basemap-gallery.d.ts +64 -0
  183. package/dist/types/components/crowdsource-manager/crowdsource-manager.d.ts +9 -1
  184. package/dist/types/components/layer-table/layer-table.d.ts +24 -2
  185. package/dist/types/components/map-card/map-card.d.ts +10 -2
  186. package/dist/types/components/map-search/map-search.d.ts +107 -0
  187. package/dist/types/components/map-tools/map-tools.d.ts +68 -5
  188. package/dist/types/components.d.ts +122 -0
  189. package/dist/types/preact.d.ts +4 -0
  190. package/dist/types/stencil-public-runtime.d.ts +2 -0
  191. package/dist/types/utils/interfaces.d.ts +2 -0
  192. package/package.json +1 -1
  193. package/dist/cjs/map-picker_2.cjs.entry.js +0 -264
  194. package/dist/esm/map-picker_2.entry.js +0 -259
  195. package/dist/solutions-components/p-1990d9c8.entry.js +0 -6
  196. package/dist/solutions-components/p-40bde8b2.entry.js +0 -6
  197. package/dist/solutions-components/p-b921aa1a.entry.js +0 -6
@@ -1,264 +0,0 @@
1
- /*!
2
- * Copyright 2022 Esri
3
- * Licensed under the Apache License, Version 2.0
4
- * http://www.apache.org/licenses/LICENSE-2.0
5
- */
6
- 'use strict';
7
-
8
- Object.defineProperty(exports, '__esModule', { value: true });
9
-
10
- const index = require('./index-0e50040c.js');
11
- const locale = require('./locale-d15cd743.js');
12
- const interfaces = require('./interfaces-d539e30c.js');
13
- require('./_commonjsHelpers-384729db.js');
14
-
15
- const mapPickerCss = ":host{display:block}.width-full{width:100%}.height-full{height:100%}.display-flex{display:flex}.border-bottom-1{border-width:0px;border-bottom-width:1px;border-style:solid;border-color:var(--calcite-ui-border-3)}.action-bar-size{height:51px;width:100%}.map-list{position:absolute;display:flex;flex-direction:column;overflow:hidden;animation:calcite-scrim-fade-in var(--calcite-internal-animation-timing-medium) ease-in-out;background-color:var(--calcite-scrim-background);z-index:1;width:100%;height:-moz-fit-content;height:fit-content}.display-none{display:none}";
16
-
17
- const MapPicker = class {
18
- constructor(hostRef) {
19
- index.registerInstance(this, hostRef);
20
- this.mapInfoChange = index.createEvent(this, "mapInfoChange", 7);
21
- /**
22
- * string: the id of map currently displayed
23
- */
24
- this._loadedId = "";
25
- this.mapInfos = [];
26
- this._mapListExpanded = false;
27
- this._webMapInfo = undefined;
28
- }
29
- //--------------------------------------------------------------------------
30
- //
31
- // Watch handlers
32
- //
33
- //--------------------------------------------------------------------------
34
- /**
35
- * Called each time the _webMapInfo prop is changed.
36
- */
37
- _webMapInfoWatchHandler(v, oldV) {
38
- if (v && JSON.stringify(v) !== JSON.stringify(oldV)) {
39
- this._loadedId = v === null || v === void 0 ? void 0 : v.id;
40
- this.mapInfoChange.emit(v);
41
- }
42
- }
43
- /**
44
- * Called each time the mapInfos prop is changed.
45
- */
46
- mapInfosWatchHandler(v, oldV) {
47
- if (v && JSON.stringify(v) !== JSON.stringify(oldV)) {
48
- this.mapInfoChange.emit(v[0]);
49
- }
50
- }
51
- //--------------------------------------------------------------------------
52
- //
53
- // Functions (lifecycle)
54
- //
55
- //--------------------------------------------------------------------------
56
- /**
57
- * Renders the component.
58
- */
59
- render() {
60
- return (index.h(index.Host, null, this._getToolbar(), this._getMapNameList(this._mapListExpanded)));
61
- }
62
- /**
63
- * Called after each render
64
- */
65
- async componentDidRender() {
66
- if (this._mapListExpanded) {
67
- await this._list.setFocus();
68
- }
69
- }
70
- /**
71
- * Called once after the component has loaded
72
- */
73
- componentDidLoad() {
74
- const webMapInfo = this.mapInfos && this.mapInfos.length > 0 ? this.mapInfos[0] : undefined;
75
- if (webMapInfo) {
76
- this._webMapSelected(webMapInfo);
77
- }
78
- }
79
- //--------------------------------------------------------------------------
80
- //
81
- // Functions (protected)
82
- //
83
- //--------------------------------------------------------------------------
84
- /**
85
- * Get a calcite action group for the map list
86
- * Actions do not support multiple icons so this uses a block
87
- *
88
- * @returns the dom node for the action group
89
- *
90
- * @protected
91
- */
92
- _getMapPicker() {
93
- var _a;
94
- const mapListIcon = this._mapListExpanded ? "chevron-up" : "chevron-down";
95
- return (index.h("calcite-button", { alignment: "icon-end-space-between", appearance: "solid", class: "width-full height-full", iconEnd: mapListIcon, kind: "neutral", onClick: () => this._chooseMap(), width: "full" }, (_a = this._webMapInfo) === null || _a === void 0 ? void 0 : _a.name));
96
- }
97
- /**
98
- * Create the toolbar (controls used for map and app interactions)
99
- *
100
- * @returns The dom node with the toolbar
101
- *
102
- * @protected
103
- */
104
- _getToolbar() {
105
- return (index.h("div", { class: "display-flex" }, index.h("calcite-action-bar", { class: "border-bottom-1 action-bar-size", "expand-disabled": true, layout: "horizontal", slot: "header" }, this._getMapPicker())));
106
- }
107
- /**
108
- * Get a pick list for all maps in mapInfos
109
- *
110
- * @param show boolean to indicate if the list should be shown or hidden
111
- *
112
- * @returns the dom node for the list of maps
113
- *
114
- * @protected
115
- */
116
- _getMapNameList(show) {
117
- const listClass = show ? "map-list" : "display-none";
118
- return (index.h("div", { class: listClass }, index.h("calcite-list", { id: "mapList", ref: (el) => this._list = el, selectionAppearance: "border" }, this.mapInfos.map(mapInfo => {
119
- return (index.h("calcite-list-item", { label: mapInfo.name, onClick: () => this._webMapSelected(mapInfo), selected: mapInfo.id === this._loadedId, value: mapInfo.id }));
120
- }))));
121
- }
122
- /**
123
- * Fired when the user clicks on the map list
124
- *
125
- * @param webMapInfo the web map id and name selected from the list
126
- *
127
- * @returns void
128
- *
129
- * @protected
130
- */
131
- _webMapSelected(webMapInfo) {
132
- this._mapListExpanded = false;
133
- this._webMapInfo = webMapInfo;
134
- }
135
- /**
136
- * Toggles the open/close state of the map list
137
- *
138
- * @returns the dom node for the action group
139
- *
140
- * @protected
141
- */
142
- _chooseMap() {
143
- this._mapListExpanded = !this._mapListExpanded;
144
- }
145
- get el() { return index.getElement(this); }
146
- static get watchers() { return {
147
- "_webMapInfo": ["_webMapInfoWatchHandler"],
148
- "mapInfos": ["mapInfosWatchHandler"]
149
- }; }
150
- };
151
- MapPicker.style = mapPickerCss;
152
-
153
- const mapToolsCss = ":host{display:block}.display-none{display:none}.border{border:1px solid var(--calcite-ui-border-3)}.margin-top-1-2{margin-top:0.5rem}";
154
-
155
- const MapTools = class {
156
- constructor(hostRef) {
157
- index.registerInstance(this, hostRef);
158
- this.expandMap = index.createEvent(this, "expandMap", 7);
159
- this.layout = "vertical";
160
- this.mapView = undefined;
161
- this._translations = undefined;
162
- this._showTools = true;
163
- this._showBasemapPicker = false;
164
- }
165
- //--------------------------------------------------------------------------
166
- //
167
- // Functions (lifecycle)
168
- //
169
- //--------------------------------------------------------------------------
170
- /**
171
- * StencilJS: Called once just after the component is first connected to the DOM.
172
- */
173
- async componentWillLoad() {
174
- await this._getTranslations();
175
- }
176
- /**
177
- * StencilJS: Renders the component.
178
- */
179
- render() {
180
- const toggleIcon = this._showTools ? "chevrons-up" : "chevrons-down";
181
- const toolsClass = this._showTools ? "" : "display-none";
182
- return (index.h(index.Host, null, index.h("div", { class: "display-flex" }, index.h("calcite-action", { alignment: "center", class: "border", compact: false, icon: toggleIcon, onClick: () => { this._toggleTools(); }, text: "" }), index.h("calcite-action-bar", { class: `border margin-top-1-2 ${toolsClass}`, "expand-disabled": true, layout: this.layout }, this._getActionGroup("home", false, this._translations.home, () => this._goHome()), this._getActionGroup("plus", false, this._translations.zoomIn, () => this._zoomIn()), this._getActionGroup("minus", false, this._translations.zoomOut, () => this._zoomOut()), this._getActionGroup("list", false, this._translations.list, () => this._showList()), this._getActionGroup("magnifying-glass", false, this._translations.search, () => this._search()), this._getActionGroup("expand", false, this._translations.expand, () => this._expand()), this._getActionGroup("basemap", false, this._translations.basemap, () => this._toggleBasemapPicker())))));
183
- }
184
- /**
185
- * Get a calcite action group for the current action
186
- *
187
- * @param icon the icon to display for the current action
188
- * @param disabled should the action be disabled
189
- * @param tip information tip to display helpful details to end user
190
- * @param func the associated onClick function to execute
191
- *
192
- * @returns the dom node for the action group
193
- *
194
- * @protected
195
- */
196
- _getActionGroup(icon, disabled, tip, func) {
197
- return (index.h("calcite-action-group", null, index.h("calcite-action", { alignment: "center", compact: false, disabled: disabled, icon: icon, id: icon, onClick: func, text: "" }, index.h("calcite-icon", { icon: "cheveron-up", scale: "s", slot: "icon" })), index.h("calcite-tooltip", { label: "", placement: "bottom", "reference-element": icon }, index.h("span", null, tip))));
198
- }
199
- // Need to discuss this with the team
200
- _goHome() {
201
- alert("go home");
202
- }
203
- // need to discuss this with the team
204
- _showList() {
205
- alert("show list");
206
- }
207
- // Need to discuss this with the team
208
- _search() {
209
- alert("search");
210
- }
211
- // Need to explore map fixed zoom in considerations
212
- _zoomIn() {
213
- alert("zoom in");
214
- }
215
- // Need to explore map fixed zoom out considerations
216
- _zoomOut() {
217
- alert("zoom out");
218
- }
219
- /**
220
- * Show/Hide the basemap picker
221
- *
222
- * @returns void
223
- *
224
- * @protected
225
- */
226
- _toggleBasemapPicker() {
227
- this._showBasemapPicker = !this._showBasemapPicker;
228
- }
229
- /**
230
- * Emit the expand map event
231
- *
232
- * @returns void
233
- *
234
- * @protected
235
- */
236
- _expand() {
237
- this.expandMap.emit(interfaces.EExpandType.EXPAND);
238
- }
239
- /**
240
- * Show/Hide the map tools
241
- *
242
- * @returns void
243
- *
244
- * @protected
245
- */
246
- _toggleTools() {
247
- this._showTools = !this._showTools;
248
- }
249
- /**
250
- * Fetches the component's translations
251
- *
252
- * @returns Promise when complete
253
- * @protected
254
- */
255
- async _getTranslations() {
256
- const messages = await locale.getLocaleComponentStrings(this.el);
257
- this._translations = messages[0];
258
- }
259
- get el() { return index.getElement(this); }
260
- };
261
- MapTools.style = mapToolsCss;
262
-
263
- exports.map_picker = MapPicker;
264
- exports.map_tools = MapTools;
@@ -1,259 +0,0 @@
1
- /*!
2
- * Copyright 2022 Esri
3
- * Licensed under the Apache License, Version 2.0
4
- * http://www.apache.org/licenses/LICENSE-2.0
5
- */
6
- import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-b5d9d795.js';
7
- import { g as getLocaleComponentStrings } from './locale-aa3de591.js';
8
- import { g as EExpandType } from './interfaces-5a2fe8b4.js';
9
- import './_commonjsHelpers-d5f9d613.js';
10
-
11
- const mapPickerCss = ":host{display:block}.width-full{width:100%}.height-full{height:100%}.display-flex{display:flex}.border-bottom-1{border-width:0px;border-bottom-width:1px;border-style:solid;border-color:var(--calcite-ui-border-3)}.action-bar-size{height:51px;width:100%}.map-list{position:absolute;display:flex;flex-direction:column;overflow:hidden;animation:calcite-scrim-fade-in var(--calcite-internal-animation-timing-medium) ease-in-out;background-color:var(--calcite-scrim-background);z-index:1;width:100%;height:-moz-fit-content;height:fit-content}.display-none{display:none}";
12
-
13
- const MapPicker = class {
14
- constructor(hostRef) {
15
- registerInstance(this, hostRef);
16
- this.mapInfoChange = createEvent(this, "mapInfoChange", 7);
17
- /**
18
- * string: the id of map currently displayed
19
- */
20
- this._loadedId = "";
21
- this.mapInfos = [];
22
- this._mapListExpanded = false;
23
- this._webMapInfo = undefined;
24
- }
25
- //--------------------------------------------------------------------------
26
- //
27
- // Watch handlers
28
- //
29
- //--------------------------------------------------------------------------
30
- /**
31
- * Called each time the _webMapInfo prop is changed.
32
- */
33
- _webMapInfoWatchHandler(v, oldV) {
34
- if (v && JSON.stringify(v) !== JSON.stringify(oldV)) {
35
- this._loadedId = v === null || v === void 0 ? void 0 : v.id;
36
- this.mapInfoChange.emit(v);
37
- }
38
- }
39
- /**
40
- * Called each time the mapInfos prop is changed.
41
- */
42
- mapInfosWatchHandler(v, oldV) {
43
- if (v && JSON.stringify(v) !== JSON.stringify(oldV)) {
44
- this.mapInfoChange.emit(v[0]);
45
- }
46
- }
47
- //--------------------------------------------------------------------------
48
- //
49
- // Functions (lifecycle)
50
- //
51
- //--------------------------------------------------------------------------
52
- /**
53
- * Renders the component.
54
- */
55
- render() {
56
- return (h(Host, null, this._getToolbar(), this._getMapNameList(this._mapListExpanded)));
57
- }
58
- /**
59
- * Called after each render
60
- */
61
- async componentDidRender() {
62
- if (this._mapListExpanded) {
63
- await this._list.setFocus();
64
- }
65
- }
66
- /**
67
- * Called once after the component has loaded
68
- */
69
- componentDidLoad() {
70
- const webMapInfo = this.mapInfos && this.mapInfos.length > 0 ? this.mapInfos[0] : undefined;
71
- if (webMapInfo) {
72
- this._webMapSelected(webMapInfo);
73
- }
74
- }
75
- //--------------------------------------------------------------------------
76
- //
77
- // Functions (protected)
78
- //
79
- //--------------------------------------------------------------------------
80
- /**
81
- * Get a calcite action group for the map list
82
- * Actions do not support multiple icons so this uses a block
83
- *
84
- * @returns the dom node for the action group
85
- *
86
- * @protected
87
- */
88
- _getMapPicker() {
89
- var _a;
90
- const mapListIcon = this._mapListExpanded ? "chevron-up" : "chevron-down";
91
- return (h("calcite-button", { alignment: "icon-end-space-between", appearance: "solid", class: "width-full height-full", iconEnd: mapListIcon, kind: "neutral", onClick: () => this._chooseMap(), width: "full" }, (_a = this._webMapInfo) === null || _a === void 0 ? void 0 : _a.name));
92
- }
93
- /**
94
- * Create the toolbar (controls used for map and app interactions)
95
- *
96
- * @returns The dom node with the toolbar
97
- *
98
- * @protected
99
- */
100
- _getToolbar() {
101
- return (h("div", { class: "display-flex" }, h("calcite-action-bar", { class: "border-bottom-1 action-bar-size", "expand-disabled": true, layout: "horizontal", slot: "header" }, this._getMapPicker())));
102
- }
103
- /**
104
- * Get a pick list for all maps in mapInfos
105
- *
106
- * @param show boolean to indicate if the list should be shown or hidden
107
- *
108
- * @returns the dom node for the list of maps
109
- *
110
- * @protected
111
- */
112
- _getMapNameList(show) {
113
- const listClass = show ? "map-list" : "display-none";
114
- return (h("div", { class: listClass }, h("calcite-list", { id: "mapList", ref: (el) => this._list = el, selectionAppearance: "border" }, this.mapInfos.map(mapInfo => {
115
- return (h("calcite-list-item", { label: mapInfo.name, onClick: () => this._webMapSelected(mapInfo), selected: mapInfo.id === this._loadedId, value: mapInfo.id }));
116
- }))));
117
- }
118
- /**
119
- * Fired when the user clicks on the map list
120
- *
121
- * @param webMapInfo the web map id and name selected from the list
122
- *
123
- * @returns void
124
- *
125
- * @protected
126
- */
127
- _webMapSelected(webMapInfo) {
128
- this._mapListExpanded = false;
129
- this._webMapInfo = webMapInfo;
130
- }
131
- /**
132
- * Toggles the open/close state of the map list
133
- *
134
- * @returns the dom node for the action group
135
- *
136
- * @protected
137
- */
138
- _chooseMap() {
139
- this._mapListExpanded = !this._mapListExpanded;
140
- }
141
- get el() { return getElement(this); }
142
- static get watchers() { return {
143
- "_webMapInfo": ["_webMapInfoWatchHandler"],
144
- "mapInfos": ["mapInfosWatchHandler"]
145
- }; }
146
- };
147
- MapPicker.style = mapPickerCss;
148
-
149
- const mapToolsCss = ":host{display:block}.display-none{display:none}.border{border:1px solid var(--calcite-ui-border-3)}.margin-top-1-2{margin-top:0.5rem}";
150
-
151
- const MapTools = class {
152
- constructor(hostRef) {
153
- registerInstance(this, hostRef);
154
- this.expandMap = createEvent(this, "expandMap", 7);
155
- this.layout = "vertical";
156
- this.mapView = undefined;
157
- this._translations = undefined;
158
- this._showTools = true;
159
- this._showBasemapPicker = false;
160
- }
161
- //--------------------------------------------------------------------------
162
- //
163
- // Functions (lifecycle)
164
- //
165
- //--------------------------------------------------------------------------
166
- /**
167
- * StencilJS: Called once just after the component is first connected to the DOM.
168
- */
169
- async componentWillLoad() {
170
- await this._getTranslations();
171
- }
172
- /**
173
- * StencilJS: Renders the component.
174
- */
175
- render() {
176
- const toggleIcon = this._showTools ? "chevrons-up" : "chevrons-down";
177
- const toolsClass = this._showTools ? "" : "display-none";
178
- return (h(Host, null, h("div", { class: "display-flex" }, h("calcite-action", { alignment: "center", class: "border", compact: false, icon: toggleIcon, onClick: () => { this._toggleTools(); }, text: "" }), h("calcite-action-bar", { class: `border margin-top-1-2 ${toolsClass}`, "expand-disabled": true, layout: this.layout }, this._getActionGroup("home", false, this._translations.home, () => this._goHome()), this._getActionGroup("plus", false, this._translations.zoomIn, () => this._zoomIn()), this._getActionGroup("minus", false, this._translations.zoomOut, () => this._zoomOut()), this._getActionGroup("list", false, this._translations.list, () => this._showList()), this._getActionGroup("magnifying-glass", false, this._translations.search, () => this._search()), this._getActionGroup("expand", false, this._translations.expand, () => this._expand()), this._getActionGroup("basemap", false, this._translations.basemap, () => this._toggleBasemapPicker())))));
179
- }
180
- /**
181
- * Get a calcite action group for the current action
182
- *
183
- * @param icon the icon to display for the current action
184
- * @param disabled should the action be disabled
185
- * @param tip information tip to display helpful details to end user
186
- * @param func the associated onClick function to execute
187
- *
188
- * @returns the dom node for the action group
189
- *
190
- * @protected
191
- */
192
- _getActionGroup(icon, disabled, tip, func) {
193
- return (h("calcite-action-group", null, h("calcite-action", { alignment: "center", compact: false, disabled: disabled, icon: icon, id: icon, onClick: func, text: "" }, h("calcite-icon", { icon: "cheveron-up", scale: "s", slot: "icon" })), h("calcite-tooltip", { label: "", placement: "bottom", "reference-element": icon }, h("span", null, tip))));
194
- }
195
- // Need to discuss this with the team
196
- _goHome() {
197
- alert("go home");
198
- }
199
- // need to discuss this with the team
200
- _showList() {
201
- alert("show list");
202
- }
203
- // Need to discuss this with the team
204
- _search() {
205
- alert("search");
206
- }
207
- // Need to explore map fixed zoom in considerations
208
- _zoomIn() {
209
- alert("zoom in");
210
- }
211
- // Need to explore map fixed zoom out considerations
212
- _zoomOut() {
213
- alert("zoom out");
214
- }
215
- /**
216
- * Show/Hide the basemap picker
217
- *
218
- * @returns void
219
- *
220
- * @protected
221
- */
222
- _toggleBasemapPicker() {
223
- this._showBasemapPicker = !this._showBasemapPicker;
224
- }
225
- /**
226
- * Emit the expand map event
227
- *
228
- * @returns void
229
- *
230
- * @protected
231
- */
232
- _expand() {
233
- this.expandMap.emit(EExpandType.EXPAND);
234
- }
235
- /**
236
- * Show/Hide the map tools
237
- *
238
- * @returns void
239
- *
240
- * @protected
241
- */
242
- _toggleTools() {
243
- this._showTools = !this._showTools;
244
- }
245
- /**
246
- * Fetches the component's translations
247
- *
248
- * @returns Promise when complete
249
- * @protected
250
- */
251
- async _getTranslations() {
252
- const messages = await getLocaleComponentStrings(this.el);
253
- this._translations = messages[0];
254
- }
255
- get el() { return getElement(this); }
256
- };
257
- MapTools.style = mapToolsCss;
258
-
259
- export { MapPicker as map_picker, MapTools as map_tools };
@@ -1,6 +0,0 @@
1
- /*!
2
- * Copyright 2022 Esri
3
- * Licensed under the Apache License, Version 2.0
4
- * http://www.apache.org/licenses/LICENSE-2.0
5
- */
6
- import{r as t,h as i,H as e,g as l}from"./p-9310b882.js";import{g as h}from"./p-a0a2c53d.js";import{E as s}from"./p-868df4a0.js";import"./p-e1a4994d.js";const a=class{constructor(i){t(this,i),this.classicGrid=!1,this.hideHeader=!0,this.hideMap=!1,this.mapInfos=[],this.zoomAndScrollToSelected=!1,this._translations=void 0,this._layoutMode=s.GRID,this._mapView=void 0,this._panelOpen=!0}async layoutChanged(t){this._layoutMode=t.detail}async mapChanged(t){this._mapView=t.detail,this._mapView.popupEnabled=!1}async componentWillLoad(){await this._getTranslations()}render(){return i(e,null,i("calcite-shell",null,i("calcite-panel",{class:"width-full height-full",heading:this.hideHeader?void 0:this._translations.header},this.hideHeader?void 0:i("layout-manager",{slot:"header-actions-end"}),this._getBody(this._layoutMode,this._panelOpen,this.hideMap))))}_getDividerIcon(t,i){let e="";switch(t){case s.HORIZONTAL:e=this.classicGrid?i?"chevrons-down":"chevrons-up":i?"chevrons-up":"chevrons-down";break;case s.VERTICAL:e=this.classicGrid?i?"chevrons-right":"chevrons-left":i?"chevrons-left":"chevrons-right";break;case s.GRID:e=this.classicGrid?i?"chevrons-up":"chevrons-down":i?"chevrons-left":"chevrons-right"}return e}_getMapSizeClass(t,i){let e="";switch(t){case s.HORIZONTAL:e=(i?"height-1-2":"height-0")+" width-full position-relative";break;case s.GRID:e=this.classicGrid?(i?"position-relative":"position-absolute-53")+" height-full width-full display-flex":"height-full position-relative "+(i?"width-1-3":"width-0");break;case s.VERTICAL:e="height-full position-relative "+(i?"width-1-2":"width-0")}return e}_getTableSizeClass(t,i){let e="";switch(t){case s.HORIZONTAL:e=(i?"height-1-2":"height-full")+" width-full display-flex flex-column";break;case s.GRID:e=this.classicGrid?(i?"height-full":"height-53")+" position-relative width-full display-flex":(i?"width-2-3":"width-full")+" height-full display-flex";break;case s.VERTICAL:e=(i?"width-1-2":"width-full")+" height-full display-flex"}return e}_getBody(t,e,l){const h=this.classicGrid&&t===s.GRID&&e?"display-grid":t===s.HORIZONTAL?"":"display-flex";return i("calcite-panel",{class:"width-full height-full"},this.classicGrid?i("div",{class:`width-full height-full ${h}`},this._getTable(t,e),this._getMapAndCard(t,e,l)):i("div",{class:`width-full height-full ${h}`},this._getMapAndCard(t,e,l),this._getTable(t,e)))}_getMapAndCard(t,e,l){const h=this._getMapSizeClass(t,e);return this.classicGrid?i("div",{class:`${h} overflow-hidden`},this._getCardNode(t,l),this._getMapNode(t,l)):i("div",{class:`${h} overflow-hidden`},this._getMapNode(t,l),this._getCardNode(t,l))}_getMapNode(t,e){return i("div",{class:`${this.classicGrid&&t===s.GRID?"width-full":"adjusted-height-50"} overflow-hidden ${this.classicGrid&&t===s.GRID?"display-flex height-full width-1-2":t!==s.GRID||e?"display-none":""}`},i("map-card",{class:"width-full",mapInfos:this.mapInfos}))}_getCardNode(t,e){return i("div",{class:"padding-1-2 "+(this.classicGrid&&t===s.GRID?"width-full adjusted-height-100":"width-50 height-full")},i("card-manager",{class:(this.classicGrid&&t===s.GRID?"":t!==s.GRID||e?"adjusted-height-100":"adjusted-height-50")+" width-full",mapView:null==this?void 0:this._mapView,zoomAndScrollToSelected:this.zoomAndScrollToSelected}))}_getTable(t,e){const l=this._getTableSizeClass(t,e),h=this._getDividerIcon(t,e),a=e?this._translations.close:this._translations.open,o="toggle-layout";return i("calcite-shell",{class:l+" border-bottom"},i("calcite-action-bar",{class:"border",expandDisabled:!0,layout:t===s.HORIZONTAL||this.classicGrid?"horizontal":"vertical",slot:this.classicGrid&&t!==s.VERTICAL?"footer":this.classicGrid&&t===s.VERTICAL?"panel-end":t===s.HORIZONTAL?"header":"panel-start"},i("calcite-action",{class:"toggle-node",icon:h,id:o,onClick:()=>this._toggleLayout(),text:""}),i("calcite-tooltip",{label:a,placement:"bottom","reference-element":o},i("span",null,a))),i("div",{class:"width-full height-full position-relative"},i("layer-table",{mapView:null==this?void 0:this._mapView,zoomAndScrollToSelected:this.zoomAndScrollToSelected})))}_toggleLayout(){this._panelOpen=!this._panelOpen}async _getTranslations(){const t=await h(this.el);this._translations=t[0]}get el(){return l(this)}};a.style=":host{display:block;--calcite-label-margin-bottom:0px}.padding-1-2{padding:0.5rem}.display-flex{display:flex}.width-full{width:100%}.width-1-2{position:relative;width:50%}.width-1-3{position:relative;width:33.33%}.width-2-3{position:relative;width:66.66%}.width-0{width:0}.height-full{height:100%}.height-1-2{position:relative;height:50%}.height-0{height:0}.toggle-node{width:51px;height:51px}.overflow-hidden{overflow:hidden}.flex-column{flex-direction:column}.border{border:1px solid var(--calcite-ui-border-3)}.border-bottom{border-bottom:1px solid var(--calcite-ui-border-3)}.position-relative{position:relative}.height-50{height:50%}.adjusted-height-50{height:calc(50% - 0.5rem)}.adjusted-height-100{height:calc(100% - 1rem)}.display-none{display:none}.height-53{height:53px}.position-absolute-53{position:absolute;top:53px}.display-grid{display:grid}";export{a as crowdsource_manager}
@@ -1,6 +0,0 @@
1
- /*!
2
- * Copyright 2022 Esri
3
- * Licensed under the Apache License, Version 2.0
4
- * http://www.apache.org/licenses/LICENSE-2.0
5
- */
6
- import{r as t,h as i,H as e,g as s,c as a}from"./p-9310b882.js";import{g as l}from"./p-a0a2c53d.js";import{q as n,a as o,b as h,g as c,c as r}from"./p-f8dd2784.js";import{l as d}from"./p-6de98c51.js";import{d as p}from"./p-75f26870.js";import{E as g}from"./p-868df4a0.js";import"./p-e1a4994d.js";const m=class{constructor(i){t(this,i),this.layer=void 0,this.mapView=void 0,this.zoomAndScrollToSelected=void 0,this._cardLoading=!1,this._graphics=void 0,this._translations=void 0}async featureSelectionChange(t){const i=t.detail;this._cardLoading=!0;const e=i.length>0?await n(i,this.layer,[],!1,this.mapView.spatialReference):[];this._graphics=e,this._cardLoading=!1}async layerSelectionChange(t){const i=t.detail[0];this.layer=await o(this.mapView,i)}async componentWillLoad(){await this._getTranslations()}render(){var t,s;const a=(null===(t=this._graphics)||void 0===t?void 0:t.length)>0?"":"display-none",l=(null===(s=this._graphics)||void 0===s?void 0:s.length)>0?"display-none":"";return i(e,null,i("div",{class:"border-rounded overflow-auto height-full"},i("calcite-shell",{class:"position-relative padding-1 "+a},i("div",null,i("info-card",{graphics:this._graphics,isLoading:this._cardLoading,mapView:this.mapView,zoomAndScrollToSelected:this.zoomAndScrollToSelected}))),i("div",{class:"padding-1 "+l},i("calcite-notice",{icon:"table",open:!0},i("div",{slot:"message"},this._translations.selectFeaturesToStart)))))}async _getTranslations(){const t=await l(this.el);this._translations=t[0]}get el(){return s(this)}};m.style=":host{display:block !important}.display-flex{display:flex}.display-none{display:none}.w-100{width:100%}.padding-bottom-1{padding-bottom:1rem}.padding-1{padding:1rem}.position-relative{position:relative}.focus-margin{margin:1px 1px 0px 1px}.overflow-auto{overflow:auto}.border-rounded{border:1px solid var(--calcite-ui-border-2);border-radius:5px}.height-full{height:100%}card-manager{display:block}";const u=class{constructor(i){t(this,i),this.featureSelectionChange=a(this,"featureSelectionChange",7),this._allIds=[],this.onTableNodeCreate=t=>{this._tableNode=t,this._getTable(t)},this.mapView=void 0,this.zoomAndScrollToSelected=void 0,this._alertOpen=!1,this._fetchingData=!1,this._layer=void 0,this._selectedIndexes=[],this._showOnlySelected=!1,this._translations=void 0}async mapViewWatchHandler(){this._fetchingData=!0;const t=await h(this.mapView);this._layer=await o(this.mapView,t[0]),this._resetTable(),this.reactiveUtils.on((()=>this.mapView),"click",(t=>{this._mapClicked(t)})),this._fetchingData=!1}async _layerWatchHandler(){this._fetchingData=!0,this._resetTable(),this._fetchingData=!1}async getSelectedGraphics(){return this._selectedIndexes.length>0?await this._getGraphics(this._selectedIndexes):[]}async selectionChanged(t){if(this.zoomAndScrollToSelected){const i=t.detail,e=i.getObjectId(),s=this._table.viewModel.getObjectIdIndex(e);this._table.scrollToIndex(s);const a=i.layer;let l;this.mapView.allLayerViews.toArray().some((t=>{if(t.layer.title===a.title&&"feature"===t.layer.type)return l=t,!0})),l&&await c([e],l,this.mapView,!0)}}async componentWillLoad(){await this._getTranslations(),await this._initModules()}render(){if(!this._layer)return null;const t=this._fetchingData?"display-none":"",s=this._fetchingData?"":"display-none",a=this._alertShowAction?"":"display-none";return i(e,null,i("calcite-shell",null,this._getTableControlRow("header"),i("div",{class:"height-full width-full"},i("calcite-panel",{class:"height-full width-full"},i("calcite-loader",{class:s,label:this._translations.fetchingData,scale:"l"}),i("div",{class:t,ref:this.onTableNodeCreate}))),i("calcite-alert",{icon:this._alertIcon,kind:this._alertKind,label:"",onCalciteAlertClose:()=>this._alertClosed(),open:this._alertOpen,placement:"top"},i("div",{slot:"title"},this._alertTitle),i("div",{slot:"message"},this._alertMessage),i("calcite-link",{class:a,onClick:this._alertActionFunction,slot:"link"},this._alertActionText))))}async _initModules(){const[t,i]=await d(["esri/widgets/FeatureTable","esri/core/reactiveUtils"]);this.FeatureTable=t,this.reactiveUtils=i}_getTableControlRow(t){const e=this._selectedIndexes.length>0;return i("div",{class:"display-flex table-border height-51",slot:t},i("calcite-action-bar",{expandDisabled:!0,expanded:!0,layout:"horizontal"},i("div",{class:"border-end"},i("map-layer-picker",{appearance:"transparent",mapView:this.mapView,onLayerSelectionChange:t=>this._layerSelectionChanged(t),placeholderIcon:"layers",scale:"l",type:"dropdown"})),i("calcite-action",{appearance:"solid",disabled:!e,icon:"magnifying-glass",id:"magnifying-glass",label:this._translations.zoom,onClick:()=>this._zoom(),text:this._translations.zoom,textEnabled:!0}),i("calcite-tooltip",{label:"",placement:"bottom","reference-element":"magnifying-glass"},i("span",null,this._translations.zoom)),i("calcite-action",{appearance:"solid",icon:"filter",id:"filter",onClick:()=>this._filter(),text:this._translations.filters,"text-enabled":"true",textEnabled:!0}),i("calcite-tooltip",{label:"",placement:"bottom","reference-element":"filter"},i("span",null,this._translations.filters)),i("calcite-action",{appearance:"solid",disabled:!e,id:"trash",onClick:()=>this._delete(),text:""},i("calcite-button",{appearance:"transparent",iconStart:"trash",kind:"danger"},this._translations.delete)),i("calcite-tooltip",{label:"",placement:"bottom","reference-element":"trash"},i("span",null,this._translations.delete)),i("calcite-action",{appearance:"solid",disabled:!e,icon:"erase",id:"erase",onClick:()=>this._clearSelection(),text:this._translations.clearSelection,"text-enabled":"true",textEnabled:!0}),i("calcite-tooltip",{label:"",placement:"bottom","reference-element":"erase"},i("span",null,this._translations.clearSelection))),i("calcite-dropdown",null,i("calcite-action",{appearance:"solid",label:"",slot:"trigger",text:""},i("calcite-button",{appearance:"transparent",iconEnd:"chevron-down",kind:"neutral"},this._translations.more)),i("calcite-dropdown-group",{"selection-mode":"none"},i("calcite-dropdown-item",{iconStart:"list-check-all",onClick:()=>this._selectAll()},this._translations.selectAll),i("calcite-dropdown-item",{iconStart:"selected-items-filter",onClick:()=>this._toggleShowSelected()},this._showOnlySelected?this._translations.showAll:this._translations.showSelected),i("calcite-dropdown-item",{iconStart:"refresh",onClick:()=>this._switchSelected()},this._translations.switchSelected),i("calcite-dropdown-item",{iconStart:"refresh",onClick:()=>this._refresh()},this._translations.refresh),i("calcite-dropdown-item",{iconStart:"export",onClick:()=>{this._exportToCSV()}},this._translations.exportCSV))))}_getTable(t){this._layer&&(this._table=new this.FeatureTable({layer:this._layer,view:this.mapView,highlightEnabled:!0,multiSortEnabled:!1,visibleElements:{header:!1,menu:!1},container:t}),this._table.highlightIds.on("change",(()=>{this._selectedIndexes=this._table.highlightIds.toArray(),this._showOnlySelected&&(this._selectedIndexes.length>0?this._table.filterBySelection():this._toggleShowSelected()),this.featureSelectionChange.emit(this._selectedIndexes)})))}_resetTable(){this._layer&&this._table&&(this._clearSelection(),this.featureSelectionChange.emit(this._selectedIndexes),this._table.layer=this._layer,this._editEnabled=this._layer.editingEnabled,this._table.view=this.mapView,this._table.editingEnabled=this._editEnabled,this._table.clearSelectionFilter(),this._showOnlySelected=!1)}async _mapClicked(t){const i={include:this._layer},e=await this.mapView.hitTest(t.screenPoint,i);e.results.length>0&&(e.results.forEach((t=>{const i=t.graphic.getObjectId(),e=this._table.highlightIds.indexOf(i);e>-1?this._table.highlightIds.removeAt(e):this._table.highlightIds.add(i)})),this._showOnlySelected&&this._table.filterBySelection())}_alertClosed(){this._alertOpen=!1}_selectAll(){const t=this._allIds;this._table.highlightIds.addMany(t),this._selectedIndexes=t}_toggleShowSelected(){this._showOnlySelected=!this._showOnlySelected,this._showOnlySelected?this._table.filterBySelection():this._table.clearSelectionFilter()}_clearSelection(){this._selectedIndexes=[],this._table.highlightIds.removeAll()}_filter(){alert("do whatever this button is supposed to do")}_switchSelected(){const t=[...this._selectedIndexes];this._selectedIndexes=this._allIds.reduce(((i,e,s)=>(t.indexOf(s)<0&&i.push(s),i)),[]),this._table.highlightIds.removeAll(),this._table.highlightIds.addMany(this._selectedIndexes)}async _exportToCSV(){const t={},i=this._table.highlightIds.toArray();t[this._layer.id]={selectionSetNames:[],ids:i,layer:this._layer},p(t,!1,!0)}_refresh(){this._table.refresh()}_zoom(){this._table.zoomToSelection()}_delete(){this._editEnabled?(this._alertIcon="trash",this._alertTitle=this._translations.deleteRows,this._alertActionText=this._translations.delete,this._alertShowAction=!0,this._alertMessage=this._translations.confirm,this._alertKind="danger",this._alertActionFunction=()=>{this._layer.applyEdits({deleteFeatures:this._table.highlightIds.toArray()}),this._alertOpen=!1}):(this._alertIcon="layer-broken",this._alertTitle=this._translations.deleteDisabled,this._alertShowAction=!1,this._alertMessage=this._translations.enableEditing,this._alertKind="warning"),this._alertOpen=!0}async _getGraphics(t){return t.length>0?n(t,this._table.layer,[],!1,this.mapView.spatialReference):[]}async _layerSelectionChanged(t){const i=t.detail[0];i===this._layer.id&&0!==this._allIds.length||(this._fetchingData=!0,this._table.highlightIds.removeAll(),this._layer=await o(this.mapView,i),this._allIds=await r(this._layer),this._selectedIndexes=[],this._table.layer=this._layer,this._table.render(),this._fetchingData=!1)}async _getTranslations(){const t=await l(this.el);this._translations=t[0]}get el(){return s(this)}static get watchers(){return{mapView:["mapViewWatchHandler"],_layer:["_layerWatchHandler"]}}};u.style=":host{display:block}.height-full{height:100%}.width-full{width:100%}.display-flex{display:flex}.table-border{border:1px solid var(--calcite-ui-border-2)}.border-end{border-inline-end:1px solid var(--calcite-ui-border-2)}.padding-5{padding:5px}.height-51{height:51px}";const b=class{constructor(i){t(this,i),this.layoutChanged=a(this,"layoutChanged",7),this._layoutMode=g.GRID,this._translations=void 0}async componentWillLoad(){await this._getTranslations()}render(){return i(e,null,i("div",{class:"display-flex"},i("div",{class:"display-flex action-center"},i("calcite-icon",{class:"icon icon-color",icon:"information",id:"app-information-icon",scale:"s"}),i("calcite-popover",{closable:!0,label:"",referenceElement:"app-information-icon"},i("span",{class:"tooltip-message"},this._translations.appInfo))),i("div",{class:"header-text"},this._translations.layout),this._getAction("grid-background",g.GRID,this._translations.grid),this._getAction("vertical-background",g.VERTICAL,this._translations.vertical),this._getAction("horizontal-background",g.HORIZONTAL,this._translations.horizontal)))}_getAction(t,e,s){return i("div",null,i("calcite-action",{alignment:"center",appearance:"transparent",compact:!1,id:t,indicator:e===this._layoutMode,onClick:()=>{this._setLayoutMode(e)},text:""},i("div",{class:t+" img-background"})),i("calcite-tooltip",{label:"",placement:"bottom","reference-element":t},i("span",null,s)))}_setLayoutMode(t){this._layoutMode=t,this.layoutChanged.emit(this._layoutMode)}async _getTranslations(){const t=await l(this.el);this._translations=t[0]}get el(){return s(this)}};b.style=":host{display:block}.action-center{-webkit-box-align:center;-webkit-align-items:center;-ms-grid-row-align:center;align-items:center;align-content:center;justify-content:center}.display-flex{display:flex}.icon-color{--calcite-ui-icon-color:var(--calcite-ui-brand)}.icon{cursor:pointer}.tooltip-message{padding:5px 8px;font-weight:var(--calcite-font-weight-normal);color:var(--calcite-ui-text-2)}.header-text{font-size:var(--calcite-font-size-0);font-weight:var(--calcite-font-weight-medium);padding-inline:0.75rem;padding-block:0.875rem;line-height:1.25rem}.img-background{background-repeat:no-repeat;background-size:100% 100%;width:38px;height:26px}.grid-background{background-image:url('../../assets/data/images/grid.png')}.horizontal-background{background-image:url('../../assets/data/images/horizontal.png')}.vertical-background{background-image:url('../../assets/data/images/vertical.png')}";const f=class{constructor(i){t(this,i),this.mapChanged=a(this,"mapChanged",7),this._loadedId="",this.mapInfos=[],this.mapView=void 0,this._webMapInfo=void 0}async mapInfoChange(t){this._loadMap(t.detail)}async componentWillLoad(){await this._initModules()}render(){return i(e,null,i("map-picker",{mapInfos:this.mapInfos}),i("div",{class:"map-height",ref:t=>this._mapDiv=t}),i("map-tools",{class:"map-tools"}))}async _initModules(){const[t,i]=await d(["esri/WebMap","esri/views/MapView"]);this.WebMap=t,this.MapView=i}_loadMap(t){let i=null==t?void 0:t.id;if(this._webMapInfo=(""===i||!i)&&this.mapInfos.length>0?this.mapInfos[0]:t,i=this._webMapInfo.id,this._loadedId!==i){const t=new this.WebMap({portalItem:{id:i}});this.mapView=new this.MapView({container:this._mapDiv,map:t,resizeAlign:"top-left"}),this._loadedId=i,this.mapChanged.emit(this.mapView)}}get el(){return s(this)}};f.style=":host{display:block;--calcite-label-margin-bottom:0;--calcite-block-padding:0}.map-height{height:calc(100% - 58px)}.esri-zoom{display:none !important}.map-tools{position:absolute;top:40px;right:0px;padding:1rem}";export{m as card_manager,u as layer_table,b as layout_manager,f as map_card}
@@ -1,6 +0,0 @@
1
- /*!
2
- * Copyright 2022 Esri
3
- * Licensed under the Apache License, Version 2.0
4
- * http://www.apache.org/licenses/LICENSE-2.0
5
- */
6
- import{r as t,c as i,h as s,H as e,g as a}from"./p-9310b882.js";import{g as o}from"./p-a0a2c53d.js";import{g as n}from"./p-868df4a0.js";import"./p-e1a4994d.js";const l=class{constructor(s){t(this,s),this.mapInfoChange=i(this,"mapInfoChange",7),this._loadedId="",this.mapInfos=[],this._mapListExpanded=!1,this._webMapInfo=void 0}_webMapInfoWatchHandler(t,i){t&&JSON.stringify(t)!==JSON.stringify(i)&&(this._loadedId=null==t?void 0:t.id,this.mapInfoChange.emit(t))}mapInfosWatchHandler(t,i){t&&JSON.stringify(t)!==JSON.stringify(i)&&this.mapInfoChange.emit(t[0])}render(){return s(e,null,this._getToolbar(),this._getMapNameList(this._mapListExpanded))}async componentDidRender(){this._mapListExpanded&&await this._list.setFocus()}componentDidLoad(){const t=this.mapInfos&&this.mapInfos.length>0?this.mapInfos[0]:void 0;t&&this._webMapSelected(t)}_getMapPicker(){var t;return s("calcite-button",{alignment:"icon-end-space-between",appearance:"solid",class:"width-full height-full",iconEnd:this._mapListExpanded?"chevron-up":"chevron-down",kind:"neutral",onClick:()=>this._chooseMap(),width:"full"},null===(t=this._webMapInfo)||void 0===t?void 0:t.name)}_getToolbar(){return s("div",{class:"display-flex"},s("calcite-action-bar",{class:"border-bottom-1 action-bar-size","expand-disabled":!0,layout:"horizontal",slot:"header"},this._getMapPicker()))}_getMapNameList(t){return s("div",{class:t?"map-list":"display-none"},s("calcite-list",{id:"mapList",ref:t=>this._list=t,selectionAppearance:"border"},this.mapInfos.map((t=>s("calcite-list-item",{label:t.name,onClick:()=>this._webMapSelected(t),selected:t.id===this._loadedId,value:t.id})))))}_webMapSelected(t){this._mapListExpanded=!1,this._webMapInfo=t}_chooseMap(){this._mapListExpanded=!this._mapListExpanded}get el(){return a(this)}static get watchers(){return{_webMapInfo:["_webMapInfoWatchHandler"],mapInfos:["mapInfosWatchHandler"]}}};l.style=":host{display:block}.width-full{width:100%}.height-full{height:100%}.display-flex{display:flex}.border-bottom-1{border-width:0px;border-bottom-width:1px;border-style:solid;border-color:var(--calcite-ui-border-3)}.action-bar-size{height:51px;width:100%}.map-list{position:absolute;display:flex;flex-direction:column;overflow:hidden;animation:calcite-scrim-fade-in var(--calcite-internal-animation-timing-medium) ease-in-out;background-color:var(--calcite-scrim-background);z-index:1;width:100%;height:-moz-fit-content;height:fit-content}.display-none{display:none}";const c=class{constructor(s){t(this,s),this.expandMap=i(this,"expandMap",7),this.layout="vertical",this.mapView=void 0,this._translations=void 0,this._showTools=!0,this._showBasemapPicker=!1}async componentWillLoad(){await this._getTranslations()}render(){const t=this._showTools?"":"display-none";return s(e,null,s("div",{class:"display-flex"},s("calcite-action",{alignment:"center",class:"border",compact:!1,icon:this._showTools?"chevrons-up":"chevrons-down",onClick:()=>{this._toggleTools()},text:""}),s("calcite-action-bar",{class:`border margin-top-1-2 ${t}`,"expand-disabled":!0,layout:this.layout},this._getActionGroup("home",!1,this._translations.home,(()=>this._goHome())),this._getActionGroup("plus",!1,this._translations.zoomIn,(()=>this._zoomIn())),this._getActionGroup("minus",!1,this._translations.zoomOut,(()=>this._zoomOut())),this._getActionGroup("list",!1,this._translations.list,(()=>this._showList())),this._getActionGroup("magnifying-glass",!1,this._translations.search,(()=>this._search())),this._getActionGroup("expand",!1,this._translations.expand,(()=>this._expand())),this._getActionGroup("basemap",!1,this._translations.basemap,(()=>this._toggleBasemapPicker())))))}_getActionGroup(t,i,e,a){return s("calcite-action-group",null,s("calcite-action",{alignment:"center",compact:!1,disabled:i,icon:t,id:t,onClick:a,text:""},s("calcite-icon",{icon:"cheveron-up",scale:"s",slot:"icon"})),s("calcite-tooltip",{label:"",placement:"bottom","reference-element":t},s("span",null,e)))}_goHome(){alert("go home")}_showList(){alert("show list")}_search(){alert("search")}_zoomIn(){alert("zoom in")}_zoomOut(){alert("zoom out")}_toggleBasemapPicker(){this._showBasemapPicker=!this._showBasemapPicker}_expand(){this.expandMap.emit(n.EXPAND)}_toggleTools(){this._showTools=!this._showTools}async _getTranslations(){const t=await o(this.el);this._translations=t[0]}get el(){return a(this)}};c.style=":host{display:block}.display-none{display:none}.border{border:1px solid var(--calcite-ui-border-3)}.margin-top-1-2{margin-top:0.5rem}";export{l as map_picker,c as map_tools}