@esri/solutions-components 0.6.6 → 0.6.7
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.
- package/dist/cjs/{ExpandToggle-e6a0d66e.js → ExpandToggle-70890ae0.js} +4 -4
- package/dist/cjs/{FloatingArrow-0119ec6e.js → FloatingArrow-4ca06439.js} +1 -1
- package/dist/cjs/{Heading-521f39ac.js → Heading-c5c71fc5.js} +1 -1
- package/dist/cjs/{app-globals-72576a1c.js → app-globals-a34c0991.js} +20 -25
- package/dist/cjs/{ar-1718ae57.js → ar-fa16156d.js} +15 -15
- package/dist/cjs/{bg-190a176c.js → bg-b39e773e.js} +15 -15
- package/dist/cjs/{bs-919e0de8.js → bs-4579ea2a.js} +15 -15
- package/dist/cjs/buffer-tools_4.cjs.entry.js +1437 -1437
- package/dist/cjs/{ca-94918e06.js → ca-f3f64686.js} +15 -15
- package/dist/cjs/calcite-accordion-item.cjs.entry.js +140 -140
- package/dist/cjs/calcite-accordion.cjs.entry.js +75 -75
- package/dist/cjs/calcite-action-bar.cjs.entry.js +216 -216
- package/dist/cjs/calcite-action-group_2.cjs.entry.js +365 -365
- package/dist/cjs/calcite-action-pad.cjs.entry.js +135 -135
- package/dist/cjs/calcite-action_2.cjs.entry.js +445 -445
- package/dist/cjs/calcite-alert.cjs.entry.js +247 -247
- package/dist/cjs/calcite-avatar.cjs.entry.js +73 -73
- package/dist/cjs/calcite-block-section.cjs.entry.js +122 -122
- package/dist/cjs/calcite-block.cjs.entry.js +131 -131
- package/dist/cjs/calcite-button.cjs.entry.js +182 -182
- package/dist/cjs/calcite-card.cjs.entry.js +99 -99
- package/dist/cjs/calcite-checkbox.cjs.entry.js +125 -125
- package/dist/cjs/calcite-chip-group.cjs.entry.js +164 -164
- package/dist/cjs/calcite-chip.cjs.entry.js +213 -213
- package/dist/cjs/calcite-color-picker-hex-input_2.cjs.entry.js +303 -303
- package/dist/cjs/calcite-color-picker.cjs.entry.js +886 -886
- package/dist/cjs/calcite-combobox-item-group.cjs.entry.js +35 -35
- package/dist/cjs/calcite-combobox_6.cjs.entry.js +1786 -1786
- package/dist/cjs/calcite-date-picker-day_3.cjs.entry.js +589 -589
- package/dist/cjs/calcite-date-picker.cjs.entry.js +434 -434
- package/dist/cjs/calcite-fab.cjs.entry.js +66 -66
- package/dist/cjs/calcite-filter_5.cjs.entry.js +1131 -1131
- package/dist/cjs/calcite-flow-item.cjs.entry.js +146 -146
- package/dist/cjs/calcite-flow.cjs.entry.js +117 -117
- package/dist/cjs/calcite-graph.cjs.entry.js +66 -66
- package/dist/cjs/calcite-icon.cjs.entry.js +80 -80
- package/dist/cjs/calcite-inline-editable.cjs.entry.js +225 -225
- package/dist/cjs/calcite-input-date-picker.cjs.entry.js +632 -632
- package/dist/cjs/calcite-input-number_2.cjs.entry.js +846 -846
- package/dist/cjs/{calcite-input-time-picker-b99baf7b.js → calcite-input-time-picker-6f38ef8c.js} +534 -534
- package/dist/cjs/calcite-input-time-picker.cjs.entry.js +15 -15
- package/dist/cjs/calcite-input-time-zone.cjs.entry.js +150 -150
- package/dist/cjs/calcite-input_2.cjs.entry.js +645 -645
- package/dist/cjs/calcite-label.cjs.entry.js +40 -40
- package/dist/cjs/calcite-link.cjs.entry.js +96 -96
- package/dist/cjs/calcite-list-item-group.cjs.entry.js +46 -46
- package/dist/cjs/calcite-loader.cjs.entry.js +65 -65
- package/dist/cjs/calcite-menu-item.cjs.entry.js +246 -246
- package/dist/cjs/calcite-menu.cjs.entry.js +161 -161
- package/dist/cjs/calcite-modal.cjs.entry.js +282 -282
- package/dist/cjs/calcite-navigation-logo.cjs.entry.js +52 -52
- package/dist/cjs/calcite-navigation-user.cjs.entry.js +45 -45
- package/dist/cjs/calcite-navigation.cjs.entry.js +126 -126
- package/dist/cjs/calcite-notice.cjs.entry.js +105 -105
- package/dist/cjs/calcite-option-group.cjs.entry.js +24 -24
- package/dist/cjs/calcite-option_2.cjs.entry.js +271 -271
- package/dist/cjs/calcite-pagination.cjs.entry.js +191 -191
- package/dist/cjs/calcite-panel_2.cjs.entry.js +346 -346
- package/dist/cjs/calcite-pick-list-group.cjs.entry.js +46 -46
- package/dist/cjs/calcite-pick-list-item.cjs.entry.js +181 -181
- package/dist/cjs/calcite-pick-list.cjs.entry.js +130 -130
- package/dist/cjs/calcite-radio-button-group.cjs.entry.js +118 -118
- package/dist/cjs/calcite-radio-button.cjs.entry.js +292 -292
- package/dist/cjs/calcite-rating.cjs.entry.js +245 -245
- package/dist/cjs/calcite-scrim.cjs.entry.js +93 -93
- package/dist/cjs/calcite-segmented-control_2.cjs.entry.js +225 -225
- package/dist/cjs/calcite-shell-center-row.cjs.entry.js +42 -42
- package/dist/cjs/calcite-shell-panel_14.cjs.entry.js +2604 -2604
- package/dist/cjs/calcite-sortable-list.cjs.entry.js +134 -134
- package/dist/cjs/calcite-split-button.cjs.entry.js +92 -92
- package/dist/cjs/calcite-stepper-item.cjs.entry.js +197 -197
- package/dist/cjs/calcite-stepper.cjs.entry.js +187 -187
- package/dist/cjs/calcite-switch.cjs.entry.js +100 -100
- package/dist/cjs/calcite-text-area.cjs.entry.js +235 -235
- package/dist/cjs/calcite-tile-select-group.cjs.entry.js +27 -27
- package/dist/cjs/calcite-tile-select.cjs.entry.js +180 -180
- package/dist/cjs/calcite-tile.cjs.entry.js +58 -58
- package/dist/cjs/calcite-time-picker.cjs.entry.js +619 -619
- package/dist/cjs/calcite-tip-group.cjs.entry.js +10 -10
- package/dist/cjs/calcite-tip-manager.cjs.entry.js +185 -185
- package/dist/cjs/calcite-tip.cjs.entry.js +94 -94
- package/dist/cjs/calcite-tooltip.cjs.entry.js +185 -185
- package/dist/cjs/calcite-tree_3.cjs.entry.js +821 -821
- package/dist/cjs/card-manager_4.cjs.entry.js +652 -652
- package/dist/cjs/{conditionalSlot-85b3a6b3.js → conditionalSlot-a51326e7.js} +2 -2
- package/dist/cjs/crowdsource-manager.cjs.entry.js +256 -256
- package/dist/cjs/crowdsource-reporter.cjs.entry.js +60 -60
- package/dist/cjs/{cs-fe27e732.js → cs-1bcd5b46.js} +15 -15
- package/dist/cjs/{da-1b7f3440.js → da-30ee21db.js} +15 -15
- package/dist/cjs/{date-cec32b0e.js → date-f6611a19.js} +1 -1
- package/dist/cjs/{de-0dc1effa.js → de-42aae5ad.js} +15 -15
- package/dist/cjs/{de-at-acdc4d01.js → de-at-a3a6f020.js} +15 -15
- package/dist/cjs/{de-ch-778a0d99.js → de-ch-36c13310.js} +15 -15
- package/dist/cjs/deduct-calculator.cjs.entry.js +90 -90
- package/dist/cjs/{dom-c1807fc1.js → dom-d529bae8.js} +2 -2
- package/dist/cjs/{downloadUtils-a8c530f7.js → downloadUtils-6eb59363.js} +660 -660
- package/dist/cjs/edit-card_2.cjs.entry.js +345 -345
- package/dist/cjs/{el-fdbc9bc1.js → el-90d066ae.js} +15 -15
- package/dist/cjs/{en-au-0ff50cdf.js → en-au-685b882b.js} +15 -15
- package/dist/cjs/{en-ca-284e9368.js → en-ca-ff4bc403.js} +15 -15
- package/dist/cjs/{en-gb-0fcae8ae.js → en-gb-2f5587ad.js} +15 -15
- package/dist/cjs/{es-cd54acba.js → es-e9183ca0.js} +15 -15
- package/dist/cjs/{es-mx-2078d50f.js → es-mx-dcc9afb2.js} +15 -15
- package/dist/cjs/{et-17f323f6.js → et-a18949ea.js} +15 -15
- package/dist/cjs/{fi-82f27397.js → fi-1ce00d38.js} +15 -15
- package/dist/cjs/{filter-bda212b4.js → filter-494bf35e.js} +1 -1
- package/dist/cjs/{floating-ui-8d10af88.js → floating-ui-7d6e57d3.js} +2 -2
- package/dist/cjs/{focusTrapComponent-a22fc6a8.js → focusTrapComponent-0c4d7671.js} +1 -1
- package/dist/cjs/{form-9d8ebf06.js → form-bcf49eae.js} +2 -2
- package/dist/cjs/{fr-af7e1192.js → fr-a9435a19.js} +15 -15
- package/dist/cjs/{fr-ch-5e1f2c28.js → fr-ch-51efa9bf.js} +15 -15
- package/dist/cjs/{he-ea851800.js → he-c5dccfa2.js} +15 -15
- package/dist/cjs/{hi-5212a21d.js → hi-0898e7f2.js} +15 -15
- package/dist/cjs/{hr-4eecb2ed.js → hr-68f7d8da.js} +15 -15
- package/dist/cjs/{hu-6b527d8e.js → hu-e494037d.js} +15 -15
- package/dist/cjs/{id-d78f12ec.js → id-bef40c1c.js} +15 -15
- package/dist/cjs/{index-0e50040c.js → index-6654298b.js} +38 -180
- package/dist/cjs/{index-2b60e135.js → index-e1b1954f.js} +1 -1
- package/dist/cjs/{index.es-4542630e.js → index.es-d9b5d3a5.js} +6 -6
- package/dist/cjs/{interfaces-d539e30c.js → interfaces-ad03ec39.js} +77 -77
- package/dist/cjs/{it-15242935.js → it-1144ca67.js} +15 -15
- package/dist/cjs/{it-ch-9dc21944.js → it-ch-2c14dca7.js} +15 -15
- package/dist/cjs/{ja-f702cfc2.js → ja-caad9809.js} +15 -15
- package/dist/cjs/{ko-aa9bde2c.js → ko-ddec9054.js} +15 -15
- package/dist/cjs/{label-6e33e971.js → label-215c4af3.js} +1 -1
- package/dist/cjs/list-item.cjs.entry.js +60 -60
- package/dist/cjs/{loadModules-31cab7ac.js → loadModules-ae7715f2.js} +19 -19
- package/dist/cjs/{loadable-bac9cdd6.js → loadable-6da743c6.js} +1 -1
- package/dist/cjs/loader.cjs.js +13 -4
- package/dist/cjs/{locale-c63a1b57.js → locale-477d8d51.js} +3 -3
- package/dist/cjs/{locale-d15cd743.js → locale-b113c6b2.js} +107 -107
- package/dist/cjs/{lt-e741ff2f.js → lt-205a1aa6.js} +15 -15
- package/dist/cjs/{lv-92d6768e.js → lv-3ba82f9b.js} +15 -15
- package/dist/cjs/map-picker_2.cjs.entry.js +243 -243
- package/dist/cjs/map-select-tools_3.cjs.entry.js +1285 -1285
- package/dist/cjs/{mapViewUtils-9da2dddd.js → mapViewUtils-77a1ff88.js} +384 -384
- package/dist/cjs/{mk-b209ac0d.js → mk-069ea86a.js} +15 -15
- package/dist/cjs/{nb-db13e666.js → nb-9e9c934f.js} +15 -15
- package/dist/cjs/{nl-fcd9e0c5.js → nl-5dd0116f.js} +15 -15
- package/dist/cjs/{openCloseComponent-5d70fcd8.js → openCloseComponent-3fa18210.js} +1 -1
- package/dist/cjs/pci-calculator.cjs.entry.js +102 -102
- package/dist/cjs/{pciUtils-e0ddeb7c.js → pciUtils-423cfc68.js} +836 -836
- package/dist/cjs/{pl-87c83322.js → pl-74e70b37.js} +15 -15
- package/dist/cjs/{pt-br-03333e90.js → pt-br-0f76e430.js} +15 -15
- package/dist/cjs/{pt-b0b5f472.js → pt-cc737fcc.js} +15 -15
- package/dist/cjs/public-notification.cjs.entry.js +844 -844
- package/dist/cjs/{publicNotificationStore-55edd658.js → publicNotificationStore-ec1bdd2d.js} +40 -40
- package/dist/cjs/{ro-c3661b73.js → ro-5e396753.js} +15 -15
- package/dist/cjs/{ru-8dd3fd58.js → ru-f7371aca.js} +15 -15
- package/dist/cjs/{shared-list-render-c0adb192.js → shared-list-render-76c5dc25.js} +6 -6
- package/dist/cjs/{sk-151d9acf.js → sk-ec02498f.js} +15 -15
- package/dist/cjs/{sl-9b45a152.js → sl-8363f4d7.js} +15 -15
- package/dist/cjs/solution-configuration.cjs.entry.js +888 -888
- package/dist/cjs/solution-contents_3.cjs.entry.js +21506 -21506
- package/dist/cjs/{solution-store-0004e4e6.js → solution-store-bd956f06.js} +577 -577
- package/dist/cjs/solutions-components.cjs.js +4 -4
- package/dist/cjs/{sortableComponent-58679f07.js → sortableComponent-8135ea87.js} +1 -1
- package/dist/cjs/{sr-186bf15c.js → sr-b0f92cb1.js} +15 -15
- package/dist/cjs/store-manager.cjs.entry.js +52 -52
- package/dist/cjs/{sv-a93fee0c.js → sv-e2c27fff.js} +15 -15
- package/dist/cjs/{t9n-1d032c30.js → t9n-8be30efb.js} +2 -2
- package/dist/cjs/{th-41680352.js → th-8a6dc2cc.js} +15 -15
- package/dist/cjs/{throttle-aeeb1b4d.js → throttle-8ee74c77.js} +1 -1
- package/dist/cjs/{time-5e450ec8.js → time-9004df7e.js} +1 -1
- package/dist/cjs/{tr-0bd886d6.js → tr-09137435.js} +15 -15
- package/dist/cjs/{uk-4fade133.js → uk-c30401f4.js} +15 -15
- package/dist/cjs/{utils-ae9bdd59.js → utils-ed4e5028.js} +1 -1
- package/dist/cjs/{utils-acfeed9d.js → utils-fb81c6b3.js} +3 -3
- package/dist/cjs/{vi-1c9fe343.js → vi-e069c9e4.js} +15 -15
- package/dist/cjs/{zh-cn-28fa1fe1.js → zh-cn-50f223a8.js} +15 -15
- package/dist/cjs/{zh-hk-5abf8eb5.js → zh-hk-5498073d.js} +15 -15
- package/dist/cjs/{zh-tw-07500357.js → zh-tw-dfdb0ae8.js} +15 -15
- package/dist/collection/collection-manifest.json +35 -35
- package/dist/collection/components/buffer-tools/buffer-tools.js +476 -481
- package/dist/collection/components/card-manager/card-manager.js +197 -199
- package/dist/collection/components/crowdsource-manager/crowdsource-manager.js +406 -407
- package/dist/collection/components/crowdsource-reporter/crowdsource-reporter.js +89 -89
- package/dist/collection/components/deduct-calculator/deduct-calculator.js +143 -143
- package/dist/collection/components/edit-card/edit-card.js +300 -302
- package/dist/collection/components/info-card/info-card.js +357 -361
- package/dist/collection/components/json-editor/json-editor.js +614 -618
- package/dist/collection/components/layer-table/layer-table.js +548 -551
- package/dist/collection/components/layout-manager/layout-manager.js +135 -136
- package/dist/collection/components/list-item/list-item.js +89 -89
- package/dist/collection/components/map-card/map-card.js +203 -206
- package/dist/collection/components/map-draw-tools/map-draw-tools.js +683 -692
- package/dist/collection/components/map-layer-picker/map-layer-picker.js +423 -424
- package/dist/collection/components/map-picker/map-picker.js +224 -226
- package/dist/collection/components/map-select-tools/map-select-tools.js +1229 -1242
- package/dist/collection/components/map-tools/map-tools.js +210 -212
- package/dist/collection/components/pci-calculator/pci-calculator.js +143 -143
- package/dist/collection/components/pdf-download/pdf-download.js +333 -338
- package/dist/collection/components/public-notification/public-notification.js +1287 -1295
- package/dist/collection/components/refine-selection/refine-selection.js +601 -608
- package/dist/collection/components/solution-configuration/solution-configuration.js +735 -739
- package/dist/collection/components/solution-contents/solution-contents.js +162 -163
- package/dist/collection/components/solution-item/solution-item.js +202 -203
- package/dist/collection/components/solution-item-details/solution-item-details.js +248 -248
- package/dist/collection/components/solution-item-icon/solution-item-icon.js +398 -398
- package/dist/collection/components/solution-item-sharing/solution-item-sharing.js +199 -200
- package/dist/collection/components/solution-organization-variables/solution-organization-variables.js +156 -156
- package/dist/collection/components/solution-resource-item/solution-resource-item.js +347 -348
- package/dist/collection/components/solution-spatial-ref/solution-spatial-ref.js +510 -515
- package/dist/collection/components/solution-spatial-ref/spatialreferences.js +21046 -21046
- package/dist/collection/components/solution-template-data/solution-template-data.js +230 -230
- package/dist/collection/components/solution-variables/solution-variables.js +168 -168
- package/dist/collection/components/store-manager/store-manager.js +127 -128
- package/dist/collection/index.js +1 -1
- package/dist/collection/utils/common.js +296 -296
- package/dist/collection/utils/csvDownload.js +41 -41
- package/dist/collection/utils/csvUtils.js +37 -37
- package/dist/collection/utils/downloadUtils.js +530 -530
- package/dist/collection/utils/interfaces.js +83 -83
- package/dist/collection/utils/languageUtil.js +90 -90
- package/dist/collection/utils/loadModules.js +25 -25
- package/dist/collection/utils/locale.js +61 -61
- package/dist/collection/utils/mapViewUtils.js +240 -240
- package/dist/collection/utils/pciUtils.js +842 -842
- package/dist/collection/utils/pdfUtils.js +87 -87
- package/dist/collection/utils/publicNotificationStore.js +47 -47
- package/dist/collection/utils/queryUtils.js +200 -200
- package/dist/collection/utils/solution-store.js +584 -584
- package/dist/collection/utils/templates.js +346 -346
- package/dist/collection/utils/test/mocks/jsApi.js +79 -79
- package/dist/collection/utils/test/testUtils.js +123 -123
- package/dist/collection/utils/types.js +1 -1
- package/dist/components/ExpandToggle.js +1 -1
- package/dist/components/action-bar.js +263 -262
- package/dist/components/action-group.js +145 -144
- package/dist/components/action-menu.js +311 -310
- package/dist/components/action.js +186 -185
- package/dist/components/alert.js +287 -286
- package/dist/components/avatar.js +100 -99
- package/dist/components/buffer-tools2.js +264 -263
- package/dist/components/button.js +226 -225
- package/dist/components/calcite-accordion-item.js +168 -168
- package/dist/components/calcite-accordion.js +96 -95
- package/dist/components/calcite-action-pad.js +181 -180
- package/dist/components/calcite-block-section.js +151 -150
- package/dist/components/calcite-block.js +187 -186
- package/dist/components/calcite-card.js +133 -132
- package/dist/components/calcite-chip-group.js +182 -181
- package/dist/components/calcite-color-picker.js +980 -979
- package/dist/components/calcite-combobox-item-group.js +53 -52
- package/dist/components/calcite-fab.js +105 -104
- package/dist/components/calcite-filter.js +1 -1
- package/dist/components/calcite-flow-item.js +205 -204
- package/dist/components/calcite-flow.js +137 -136
- package/dist/components/calcite-inline-editable.js +260 -259
- package/dist/components/calcite-input-date-picker.js +704 -703
- package/dist/components/calcite-input-time-picker.js +596 -595
- package/dist/components/calcite-input-time-zone.js +190 -189
- package/dist/components/calcite-label.js +1 -1
- package/dist/components/calcite-list-item-group.js +65 -64
- package/dist/components/calcite-menu-item.js +297 -297
- package/dist/components/calcite-modal.js +329 -328
- package/dist/components/calcite-navigation-logo.js +77 -76
- package/dist/components/calcite-navigation-user.js +79 -78
- package/dist/components/calcite-navigation.js +167 -166
- package/dist/components/calcite-option-group.js +43 -42
- package/dist/components/calcite-pagination.js +218 -217
- package/dist/components/calcite-pick-list-group.js +60 -59
- package/dist/components/calcite-pick-list.js +151 -150
- package/dist/components/calcite-radio-button-group.js +142 -141
- package/dist/components/calcite-radio-button.js +317 -316
- package/dist/components/calcite-rating.js +280 -279
- package/dist/components/calcite-shell-center-row.js +58 -57
- package/dist/components/calcite-sortable-list.js +154 -153
- package/dist/components/calcite-split-button.js +143 -142
- package/dist/components/calcite-stack.js +1 -1
- package/dist/components/calcite-stepper-item.js +226 -225
- package/dist/components/calcite-stepper.js +213 -212
- package/dist/components/calcite-text-area.js +267 -266
- package/dist/components/calcite-tile-select-group.js +45 -44
- package/dist/components/calcite-tile-select.js +224 -223
- package/dist/components/calcite-tip-group.js +28 -27
- package/dist/components/calcite-tip-manager.js +223 -222
- package/dist/components/calcite-tip.js +127 -126
- package/dist/components/card-manager2.js +156 -155
- package/dist/components/checkbox.js +147 -146
- package/dist/components/chip.js +246 -245
- package/dist/components/color-picker-hex-input.js +288 -287
- package/dist/components/color-picker-swatch.js +80 -79
- package/dist/components/combobox-item.js +136 -135
- package/dist/components/combobox.js +922 -921
- package/dist/components/crowdsource-manager.js +476 -475
- package/dist/components/crowdsource-reporter.js +76 -75
- package/dist/components/date-picker-day.js +110 -110
- package/dist/components/date-picker-month-header.js +198 -197
- package/dist/components/date-picker-month.js +373 -372
- package/dist/components/date-picker.js +493 -492
- package/dist/components/date.js +1 -1
- package/dist/components/deduct-calculator2.js +982 -981
- package/dist/components/dom.js +23 -2
- package/dist/components/downloadUtils.js +655 -655
- package/dist/components/dropdown-group.js +73 -72
- package/dist/components/dropdown-item.js +196 -195
- package/dist/components/dropdown.js +421 -420
- package/dist/components/edit-card2.js +192 -191
- package/dist/components/filter.js +202 -751
- package/dist/components/filter2.js +740 -190
- package/dist/components/floating-ui.js +2 -2
- package/dist/components/focusTrapComponent.js +1 -1
- package/dist/components/graph.js +87 -86
- package/dist/components/handle.js +166 -165
- package/dist/components/icon.js +100 -99
- package/dist/components/index.d.ts +36 -0
- package/dist/components/index.js +153 -25
- package/dist/components/info-card2.js +252 -251
- package/dist/components/input-message.js +67 -66
- package/dist/components/input-number.js +600 -600
- package/dist/components/input-text.js +368 -368
- package/dist/components/input.js +687 -687
- package/dist/components/interfaces.js +78 -78
- package/dist/components/json-editor2.js +426 -425
- package/dist/components/label.js +65 -117
- package/dist/components/label2.js +110 -57
- package/dist/components/layer-table2.js +548 -547
- package/dist/components/layout-manager2.js +119 -118
- package/dist/components/link.js +123 -123
- package/dist/components/list-item.js +76 -75
- package/dist/components/list-item2.js +432 -431
- package/dist/components/list.js +511 -510
- package/dist/components/loadModules.js +18 -18
- package/dist/components/loader.js +87 -86
- package/dist/components/locale.js +106 -106
- package/dist/components/locale2.js +2 -2
- package/dist/components/map-card2.js +201 -200
- package/dist/components/map-draw-tools2.js +384 -383
- package/dist/components/map-layer-picker2.js +292 -291
- package/dist/components/map-picker2.js +236 -235
- package/dist/components/map-select-tools2.js +917 -916
- package/dist/components/map-tools2.js +170 -169
- package/dist/components/mapViewUtils.js +235 -235
- package/dist/components/menu.js +179 -178
- package/dist/components/notice.js +131 -130
- package/dist/components/option.js +92 -91
- package/dist/components/panel.js +308 -307
- package/dist/components/pci-calculator.js +170 -169
- package/dist/components/pdf-download2.js +174 -173
- package/dist/components/pick-list-item.js +220 -219
- package/dist/components/popover.js +350 -349
- package/dist/components/progress.js +46 -46
- package/dist/components/public-notification.js +1102 -1101
- package/dist/components/publicNotificationStore.js +39 -39
- package/dist/components/queryUtils.js +152 -152
- package/dist/components/refine-selection2.js +547 -546
- package/dist/components/resources.js +9 -17
- package/dist/components/resources2.js +13 -9
- package/dist/components/resources3.js +5 -9
- package/dist/components/scrim.js +116 -115
- package/dist/components/segmented-control-item.js +63 -62
- package/dist/components/segmented-control.js +214 -213
- package/dist/components/select.js +227 -226
- package/dist/components/shared-list-render.js +3 -3
- package/dist/components/shell-panel.js +398 -398
- package/dist/components/shell.js +120 -119
- package/dist/components/slider.js +899 -898
- package/dist/components/solution-configuration.js +1096 -1095
- package/dist/components/solution-contents2.js +112 -111
- package/dist/components/solution-item-details2.js +218 -217
- package/dist/components/solution-item-icon2.js +331 -330
- package/dist/components/solution-item-sharing2.js +152 -151
- package/dist/components/solution-item2.js +270 -269
- package/dist/components/solution-organization-variables2.js +116 -115
- package/dist/components/solution-resource-item2.js +332 -331
- package/dist/components/solution-spatial-ref2.js +21421 -21420
- package/dist/components/solution-store.js +575 -575
- package/dist/components/solution-template-data2.js +203 -202
- package/dist/components/solution-variables2.js +133 -132
- package/dist/components/sortableComponent.js +1 -1
- package/dist/components/stack.js +79 -78
- package/dist/components/store-manager.js +71 -70
- package/dist/components/switch.js +119 -118
- package/dist/components/tab-nav.js +255 -254
- package/dist/components/tab-title.js +301 -300
- package/dist/components/tab.js +112 -111
- package/dist/components/tabs.js +131 -130
- package/dist/components/tile.js +90 -89
- package/dist/components/time-picker.js +655 -654
- package/dist/components/tooltip.js +208 -207
- package/dist/components/tree-item.js +288 -288
- package/dist/components/tree.js +282 -281
- package/dist/components/utils.js +1 -1
- package/dist/components/utils2.js +2 -2
- package/dist/components/utils3.js +1 -1
- package/dist/components/value-list-item.js +170 -169
- package/dist/components/value-list.js +276 -275
- package/dist/esm/{ExpandToggle-3d10bd1e.js → ExpandToggle-3420fa39.js} +4 -4
- package/dist/esm/{FloatingArrow-29db6da6.js → FloatingArrow-cd8eafa4.js} +1 -1
- package/dist/esm/{Heading-cb79e5b2.js → Heading-1763134e.js} +1 -1
- package/dist/esm/{app-globals-5cbac6b0.js → app-globals-580889bd.js} +20 -25
- package/dist/esm/{ar-4b751ba8.js → ar-ceb1b389.js} +15 -15
- package/dist/esm/{bg-5d8bf5ea.js → bg-a8824832.js} +15 -15
- package/dist/esm/{bs-ff510e71.js → bs-5c2ca44f.js} +15 -15
- package/dist/esm/buffer-tools_4.entry.js +1437 -1437
- package/dist/esm/{ca-b9a5e51a.js → ca-47f86073.js} +15 -15
- package/dist/esm/calcite-accordion-item.entry.js +140 -140
- package/dist/esm/calcite-accordion.entry.js +75 -75
- package/dist/esm/calcite-action-bar.entry.js +216 -216
- package/dist/esm/calcite-action-group_2.entry.js +365 -365
- package/dist/esm/calcite-action-pad.entry.js +135 -135
- package/dist/esm/calcite-action_2.entry.js +445 -445
- package/dist/esm/calcite-alert.entry.js +247 -247
- package/dist/esm/calcite-avatar.entry.js +73 -73
- package/dist/esm/calcite-block-section.entry.js +122 -122
- package/dist/esm/calcite-block.entry.js +131 -131
- package/dist/esm/calcite-button.entry.js +182 -182
- package/dist/esm/calcite-card.entry.js +99 -99
- package/dist/esm/calcite-checkbox.entry.js +125 -125
- package/dist/esm/calcite-chip-group.entry.js +164 -164
- package/dist/esm/calcite-chip.entry.js +213 -213
- package/dist/esm/calcite-color-picker-hex-input_2.entry.js +303 -303
- package/dist/esm/calcite-color-picker.entry.js +886 -886
- package/dist/esm/calcite-combobox-item-group.entry.js +35 -35
- package/dist/esm/calcite-combobox_6.entry.js +1786 -1786
- package/dist/esm/calcite-date-picker-day_3.entry.js +589 -589
- package/dist/esm/calcite-date-picker.entry.js +434 -434
- package/dist/esm/calcite-fab.entry.js +66 -66
- package/dist/esm/calcite-filter_5.entry.js +1131 -1131
- package/dist/esm/calcite-flow-item.entry.js +146 -146
- package/dist/esm/calcite-flow.entry.js +117 -117
- package/dist/esm/calcite-graph.entry.js +66 -66
- package/dist/esm/calcite-icon.entry.js +80 -80
- package/dist/esm/calcite-inline-editable.entry.js +225 -225
- package/dist/esm/calcite-input-date-picker.entry.js +632 -632
- package/dist/esm/calcite-input-number_2.entry.js +846 -846
- package/dist/esm/{calcite-input-time-picker-13448515.js → calcite-input-time-picker-59a3ed66.js} +534 -534
- package/dist/esm/calcite-input-time-picker.entry.js +15 -15
- package/dist/esm/calcite-input-time-zone.entry.js +150 -150
- package/dist/esm/calcite-input_2.entry.js +645 -645
- package/dist/esm/calcite-label.entry.js +40 -40
- package/dist/esm/calcite-link.entry.js +96 -96
- package/dist/esm/calcite-list-item-group.entry.js +46 -46
- package/dist/esm/calcite-loader.entry.js +65 -65
- package/dist/esm/calcite-menu-item.entry.js +246 -246
- package/dist/esm/calcite-menu.entry.js +161 -161
- package/dist/esm/calcite-modal.entry.js +282 -282
- package/dist/esm/calcite-navigation-logo.entry.js +52 -52
- package/dist/esm/calcite-navigation-user.entry.js +45 -45
- package/dist/esm/calcite-navigation.entry.js +126 -126
- package/dist/esm/calcite-notice.entry.js +105 -105
- package/dist/esm/calcite-option-group.entry.js +24 -24
- package/dist/esm/calcite-option_2.entry.js +271 -271
- package/dist/esm/calcite-pagination.entry.js +191 -191
- package/dist/esm/calcite-panel_2.entry.js +346 -346
- package/dist/esm/calcite-pick-list-group.entry.js +46 -46
- package/dist/esm/calcite-pick-list-item.entry.js +181 -181
- package/dist/esm/calcite-pick-list.entry.js +130 -130
- package/dist/esm/calcite-radio-button-group.entry.js +118 -118
- package/dist/esm/calcite-radio-button.entry.js +292 -292
- package/dist/esm/calcite-rating.entry.js +245 -245
- package/dist/esm/calcite-scrim.entry.js +93 -93
- package/dist/esm/calcite-segmented-control_2.entry.js +225 -225
- package/dist/esm/calcite-shell-center-row.entry.js +42 -42
- package/dist/esm/calcite-shell-panel_14.entry.js +2604 -2604
- package/dist/esm/calcite-sortable-list.entry.js +134 -134
- package/dist/esm/calcite-split-button.entry.js +92 -92
- package/dist/esm/calcite-stepper-item.entry.js +197 -197
- package/dist/esm/calcite-stepper.entry.js +187 -187
- package/dist/esm/calcite-switch.entry.js +100 -100
- package/dist/esm/calcite-text-area.entry.js +235 -235
- package/dist/esm/calcite-tile-select-group.entry.js +27 -27
- package/dist/esm/calcite-tile-select.entry.js +180 -180
- package/dist/esm/calcite-tile.entry.js +58 -58
- package/dist/esm/calcite-time-picker.entry.js +619 -619
- package/dist/esm/calcite-tip-group.entry.js +10 -10
- package/dist/esm/calcite-tip-manager.entry.js +185 -185
- package/dist/esm/calcite-tip.entry.js +94 -94
- package/dist/esm/calcite-tooltip.entry.js +185 -185
- package/dist/esm/calcite-tree_3.entry.js +821 -821
- package/dist/esm/card-manager_4.entry.js +652 -652
- package/dist/esm/{conditionalSlot-27a0fce0.js → conditionalSlot-91396dd5.js} +2 -2
- package/dist/esm/crowdsource-manager.entry.js +256 -256
- package/dist/esm/crowdsource-reporter.entry.js +60 -60
- package/dist/esm/{cs-f21a0628.js → cs-f651c3cd.js} +15 -15
- package/dist/esm/{da-dc48fc4c.js → da-e32ccc0a.js} +15 -15
- package/dist/esm/{date-0ed48e97.js → date-51fa981b.js} +1 -1
- package/dist/esm/{de-59290071.js → de-9b417aed.js} +15 -15
- package/dist/esm/{de-at-cd6e6ab7.js → de-at-f73447e2.js} +15 -15
- package/dist/esm/{de-ch-27c44e34.js → de-ch-7ec8c31e.js} +15 -15
- package/dist/esm/deduct-calculator.entry.js +90 -90
- package/dist/esm/{dom-843e3afd.js → dom-8a9e4ee8.js} +2 -2
- package/dist/esm/{downloadUtils-63661805.js → downloadUtils-43b53f5a.js} +660 -660
- package/dist/esm/edit-card_2.entry.js +345 -345
- package/dist/esm/{el-f09fdec6.js → el-9a3189a2.js} +15 -15
- package/dist/esm/{en-au-90087aa5.js → en-au-5aea3b73.js} +15 -15
- package/dist/esm/{en-ca-10751695.js → en-ca-fe3e706b.js} +15 -15
- package/dist/esm/{en-gb-0f8547bd.js → en-gb-a4278000.js} +15 -15
- package/dist/esm/{es-b0997cf1.js → es-383f9c9e.js} +15 -15
- package/dist/esm/{es-mx-226f5028.js → es-mx-7845b382.js} +15 -15
- package/dist/esm/{et-dc96c453.js → et-d8f8df06.js} +15 -15
- package/dist/esm/{fi-0941704d.js → fi-14894338.js} +15 -15
- package/dist/esm/{filter-1cac3edf.js → filter-bf34614b.js} +1 -1
- package/dist/esm/{floating-ui-d28d0fd6.js → floating-ui-9870f74c.js} +2 -2
- package/dist/esm/{focusTrapComponent-ff3a9f28.js → focusTrapComponent-34010d00.js} +1 -1
- package/dist/esm/{form-11c6a015.js → form-6669a774.js} +2 -2
- package/dist/esm/{fr-8da3458d.js → fr-6f570086.js} +15 -15
- package/dist/esm/{fr-ch-739ceddf.js → fr-ch-b9f89159.js} +15 -15
- package/dist/esm/{he-8b662dfa.js → he-174aca6e.js} +15 -15
- package/dist/esm/{hi-10996f89.js → hi-7e469aab.js} +15 -15
- package/dist/esm/{hr-42c2024d.js → hr-a4ac455a.js} +15 -15
- package/dist/esm/{hu-4768b3ff.js → hu-207da291.js} +15 -15
- package/dist/esm/{id-24a08170.js → id-8e4d57bf.js} +15 -15
- package/dist/esm/{index-b91c174c.js → index-4c4a4f3d.js} +1 -1
- package/dist/esm/{index-b5d9d795.js → index-d298aca9.js} +38 -180
- package/dist/esm/{index.es-3a3aa8e3.js → index.es-a185f2b1.js} +6 -6
- package/dist/esm/{interfaces-5a2fe8b4.js → interfaces-bf20e69c.js} +77 -77
- package/dist/esm/{it-ad09649f.js → it-7ade952c.js} +15 -15
- package/dist/esm/{it-ch-b05fc10d.js → it-ch-181d76ab.js} +15 -15
- package/dist/esm/{ja-ab839b73.js → ja-42013dd3.js} +15 -15
- package/dist/esm/{ko-c778539e.js → ko-8de07550.js} +15 -15
- package/dist/esm/{label-6a1caf64.js → label-661d8e10.js} +1 -1
- package/dist/esm/list-item.entry.js +60 -60
- package/dist/esm/{loadModules-2ecd1e44.js → loadModules-cd3569de.js} +19 -19
- package/dist/esm/{loadable-6bca96ad.js → loadable-08376d90.js} +1 -1
- package/dist/esm/loader.js +14 -5
- package/dist/esm/{locale-aa3de591.js → locale-54cac39a.js} +107 -107
- package/dist/esm/{locale-d8561d54.js → locale-73d0926a.js} +3 -3
- package/dist/esm/{lt-447d9aa9.js → lt-1ef29b5b.js} +15 -15
- package/dist/esm/{lv-4d715e11.js → lv-263a2f78.js} +15 -15
- package/dist/esm/map-picker_2.entry.js +243 -243
- package/dist/esm/map-select-tools_3.entry.js +1285 -1285
- package/dist/esm/{mapViewUtils-f0c04325.js → mapViewUtils-1e68cede.js} +384 -384
- package/dist/esm/{mk-b3d7401a.js → mk-d8bae136.js} +15 -15
- package/dist/esm/{nb-2b4a8366.js → nb-494542b3.js} +15 -15
- package/dist/esm/{nl-c0db1da2.js → nl-cd882d7f.js} +15 -15
- package/dist/esm/{openCloseComponent-2b5c6bed.js → openCloseComponent-a40fd6fd.js} +1 -1
- package/dist/esm/pci-calculator.entry.js +102 -102
- package/dist/esm/{pciUtils-59c29b42.js → pciUtils-ecda46e5.js} +836 -836
- package/dist/esm/{pl-0d322bb4.js → pl-b79095d5.js} +15 -15
- package/dist/esm/polyfills/core-js.js +11 -0
- package/dist/esm/polyfills/css-shim.js +1 -0
- package/dist/esm/polyfills/dom.js +79 -0
- package/dist/esm/polyfills/es5-html-element.js +1 -0
- package/dist/esm/polyfills/index.js +34 -0
- package/dist/esm/polyfills/system.js +6 -0
- package/dist/esm/{pt-5997598c.js → pt-5ca0b751.js} +15 -15
- package/dist/esm/{pt-br-6b77e7db.js → pt-br-e1a1ce60.js} +15 -15
- package/dist/esm/public-notification.entry.js +844 -844
- package/dist/esm/{publicNotificationStore-ade82148.js → publicNotificationStore-6ef555f3.js} +40 -40
- package/dist/esm/{ro-ac3724e0.js → ro-5cbc0f2a.js} +15 -15
- package/dist/esm/{ru-4e75151f.js → ru-e66f5b84.js} +15 -15
- package/dist/esm/{shared-list-render-abd19c8d.js → shared-list-render-5b788e63.js} +6 -6
- package/dist/esm/{sk-bbfa22a3.js → sk-be2b5cec.js} +15 -15
- package/dist/esm/{sl-867cecfc.js → sl-74600272.js} +15 -15
- package/dist/esm/solution-configuration.entry.js +888 -888
- package/dist/esm/solution-contents_3.entry.js +21506 -21506
- package/dist/esm/{solution-store-46bc46a5.js → solution-store-c107ca4d.js} +577 -577
- package/dist/esm/solutions-components.js +5 -5
- package/dist/esm/{sortableComponent-db502e97.js → sortableComponent-1dd8a4ae.js} +1 -1
- package/dist/esm/{sr-198b5c00.js → sr-58280ce5.js} +15 -15
- package/dist/esm/store-manager.entry.js +52 -52
- package/dist/esm/{sv-02d64370.js → sv-f0e2171a.js} +15 -15
- package/dist/esm/{t9n-76168237.js → t9n-745553e0.js} +2 -2
- package/dist/esm/{th-1616e303.js → th-6c3eac31.js} +15 -15
- package/dist/esm/{throttle-9ab70933.js → throttle-26fa347b.js} +1 -1
- package/dist/esm/{time-6721a4c2.js → time-7e3ba7c6.js} +1 -1
- package/dist/esm/{tr-f4619f64.js → tr-092713ca.js} +15 -15
- package/dist/esm/{uk-df7df34a.js → uk-95df0f95.js} +15 -15
- package/dist/esm/{utils-ccfd94a7.js → utils-4f695ec2.js} +1 -1
- package/dist/esm/{utils-f54411df.js → utils-ddff4ef3.js} +3 -3
- package/dist/esm/{vi-176ca9f7.js → vi-70a9857c.js} +15 -15
- package/dist/esm/{zh-cn-e13d83d1.js → zh-cn-e024ef2d.js} +15 -15
- package/dist/esm/{zh-hk-d97365d8.js → zh-hk-36ff9e8f.js} +15 -15
- package/dist/esm/{zh-tw-a2b6f0b7.js → zh-tw-96ddb74c.js} +15 -15
- package/dist/loader/index.d.ts +2 -2
- package/dist/solutions-components/{p-15ef7894.js → p-0056655c.js} +1 -1
- package/dist/solutions-components/{p-955a956a.entry.js → p-017265ef.entry.js} +1 -1
- package/dist/solutions-components/{p-844ee452.entry.js → p-017543d5.entry.js} +1 -1
- package/dist/solutions-components/{p-b2e6c578.js → p-0209ed2e.js} +1 -1
- package/dist/solutions-components/{p-5e59219b.entry.js → p-0245bb56.entry.js} +1 -1
- package/dist/solutions-components/{p-916f90ec.entry.js → p-043ead99.entry.js} +1 -1
- package/dist/solutions-components/p-048a2a6d.js +6 -0
- package/dist/solutions-components/{p-e02fcfa9.entry.js → p-050e12eb.entry.js} +1 -1
- package/dist/solutions-components/{p-b0c4138f.entry.js → p-06916de9.entry.js} +1 -1
- package/dist/solutions-components/{p-67ce3c0c.entry.js → p-08320fb9.entry.js} +2 -2
- package/dist/solutions-components/{p-21f00df6.js → p-08e12eb0.js} +1 -1
- package/dist/solutions-components/p-0a2c02fd.js +6 -0
- package/dist/solutions-components/{p-de58bd49.js → p-0a4bc416.js} +1 -1
- package/dist/solutions-components/{p-ef96894d.entry.js → p-0afa17dc.entry.js} +1 -1
- package/dist/solutions-components/{p-4bc7b875.entry.js → p-0b4eb6e4.entry.js} +1 -1
- package/dist/solutions-components/{p-7b9adfff.js → p-0d900572.js} +1 -1
- package/dist/solutions-components/{p-0fbc27fd.entry.js → p-0f4d3009.entry.js} +1 -1
- package/dist/solutions-components/{p-b921aa1a.entry.js → p-10181f33.entry.js} +1 -1
- package/dist/solutions-components/{p-804e4751.entry.js → p-105ef63c.entry.js} +1 -1
- package/dist/solutions-components/{p-35123c90.js → p-11983a08.js} +1 -1
- package/dist/solutions-components/p-1260db08.js +61 -0
- package/dist/solutions-components/{p-a0edbb27.js → p-129fcd0a.js} +1 -1
- package/dist/solutions-components/{p-c1ee0d69.js → p-13f7e487.js} +1 -1
- package/dist/solutions-components/p-14769a01.js +11 -0
- package/dist/solutions-components/{p-c6d83122.entry.js → p-14a4ad77.entry.js} +2 -2
- package/dist/solutions-components/{p-e07b8a72.entry.js → p-15e67907.entry.js} +1 -1
- package/dist/solutions-components/{p-32ef065d.entry.js → p-17799448.entry.js} +1 -1
- package/dist/solutions-components/{p-8a758303.js → p-185a82e0.js} +1 -1
- package/dist/solutions-components/p-191c59e9.js +6 -0
- package/dist/solutions-components/{p-7601988d.entry.js → p-1b63bec9.entry.js} +1 -1
- package/dist/solutions-components/{p-28d2670f.entry.js → p-1c810f4c.entry.js} +1 -1
- package/dist/solutions-components/{p-9603c3ff.entry.js → p-1d28ff09.entry.js} +1 -1
- package/dist/solutions-components/{p-4b95d05e.entry.js → p-1e30069a.entry.js} +1 -1
- package/dist/solutions-components/p-1e63db11.entry.js +6 -0
- package/dist/solutions-components/{p-a08bd8c1.entry.js → p-20274226.entry.js} +1 -1
- package/dist/solutions-components/{p-a843af2a.js → p-2411f1f6.js} +1 -1
- package/dist/solutions-components/{p-ad4d6d02.entry.js → p-2509b65f.entry.js} +2 -2
- package/dist/solutions-components/{p-216801d5.js → p-25faeab6.js} +1 -1
- package/dist/solutions-components/{p-f8dd2784.js → p-27f5bb4f.js} +2 -2
- package/dist/solutions-components/{p-b948ecd2.entry.js → p-2a0d8a46.entry.js} +1 -1
- package/dist/solutions-components/{p-27a1ac1f.entry.js → p-2dea68b6.entry.js} +2 -2
- package/dist/solutions-components/{p-de59d2f5.js → p-2ecd5cb7.js} +1 -1
- package/dist/solutions-components/{p-7aa949a3.entry.js → p-30dbc43d.entry.js} +2 -2
- package/dist/solutions-components/{p-46d5970b.entry.js → p-32d821d1.entry.js} +1 -1
- package/dist/solutions-components/{p-82199b7b.entry.js → p-3479d873.entry.js} +1 -1
- package/dist/solutions-components/{p-9fb16c72.entry.js → p-36d09c0c.entry.js} +1 -1
- package/dist/solutions-components/{p-75f26870.js → p-375f0b74.js} +6 -6
- package/dist/solutions-components/{p-cf1af08f.entry.js → p-38b4873b.entry.js} +1 -1
- package/dist/solutions-components/p-38d61356.js +18 -0
- package/dist/solutions-components/{p-a2748b38.entry.js → p-3a7156b8.entry.js} +1 -1
- package/dist/solutions-components/{p-022a9b7a.js → p-3b041268.js} +1 -1
- package/dist/solutions-components/{p-6a820c4d.js → p-3ca9bb95.js} +1 -1
- package/dist/solutions-components/{p-326fa270.js → p-3e5c8b2f.js} +1 -1
- package/dist/solutions-components/{p-1ede2e18.js → p-3ee6af74.js} +2 -2
- package/dist/solutions-components/{p-97c47bbd.entry.js → p-3eecbcf0.entry.js} +1 -1
- package/dist/solutions-components/{p-5c097e25.entry.js → p-40432de5.entry.js} +1 -1
- package/dist/solutions-components/{p-c9858d8f.entry.js → p-4058733e.entry.js} +1 -1
- package/dist/solutions-components/{p-9e727488.js → p-4152fae0.js} +1 -1
- package/dist/solutions-components/{p-12a4fa84.js → p-4321edfc.js} +1 -1
- package/dist/solutions-components/{p-761a033a.entry.js → p-4344b6ca.entry.js} +1 -1
- package/dist/solutions-components/{p-aeebdb15.js → p-44e26e37.js} +1 -1
- package/dist/solutions-components/{p-3445a8c6.js → p-477ae127.js} +1 -1
- package/dist/solutions-components/{p-9cb94ea0.js → p-4c8b1179.js} +1 -1
- package/dist/solutions-components/p-4e32bf8c.js +6 -0
- package/dist/solutions-components/{p-4c43820f.entry.js → p-4e93132b.entry.js} +1 -1
- package/dist/solutions-components/{p-1add4e39.entry.js → p-4ea79dc4.entry.js} +2 -2
- package/dist/solutions-components/{p-05db4340.js → p-4f51db32.js} +1 -1
- package/dist/solutions-components/{p-4d17943f.js → p-4f64d786.js} +1 -1
- package/dist/solutions-components/{p-2c0dc7b1.js → p-4ff653eb.js} +1 -1
- package/dist/solutions-components/{p-b1f84ae5.js → p-53347add.js} +1 -1
- package/dist/solutions-components/p-54fce798.js +11 -0
- package/dist/solutions-components/{p-abda8ca2.entry.js → p-573d282b.entry.js} +1 -1
- package/dist/solutions-components/{p-a258f5e7.js → p-58340eba.js} +1 -1
- package/dist/solutions-components/p-5930cd6d.entry.js +6 -0
- package/dist/solutions-components/p-5fc99541.js +257 -0
- package/dist/solutions-components/{p-ffac6f88.entry.js → p-6071078a.entry.js} +1 -1
- package/dist/solutions-components/{p-dc9dad31.entry.js → p-69863a28.entry.js} +1 -1
- package/dist/solutions-components/{p-a6900100.entry.js → p-699031c9.entry.js} +2 -2
- package/dist/solutions-components/{p-ab8f5c6b.entry.js → p-6998e886.entry.js} +1 -1
- package/dist/solutions-components/{p-bbb0d957.entry.js → p-6a813a31.entry.js} +1 -1
- package/dist/solutions-components/{p-ad72a379.entry.js → p-6b12b5eb.entry.js} +1 -1
- package/dist/solutions-components/{p-639cca97.js → p-6e89e9dd.js} +1 -1
- package/dist/solutions-components/{p-5adf37ea.entry.js → p-705b7f81.entry.js} +1 -1
- package/dist/solutions-components/p-75578ebf.entry.js +6 -0
- package/dist/solutions-components/{p-5383607a.js → p-7c72df3c.js} +3 -3
- package/dist/solutions-components/{p-03fccde6.entry.js → p-7ca47589.entry.js} +2 -2
- package/dist/solutions-components/{p-a040efff.js → p-7cb8a4db.js} +1 -1
- package/dist/solutions-components/p-7cc13b24.js +8 -0
- package/dist/solutions-components/{p-e4253e1b.entry.js → p-8008b2fe.entry.js} +1 -1
- package/dist/solutions-components/{p-22d580b0.entry.js → p-81531fbe.entry.js} +1 -1
- package/dist/solutions-components/{p-e10a62f4.entry.js → p-81627211.entry.js} +1 -1
- package/dist/solutions-components/{p-2d70d3fd.js → p-8aa806fe.js} +1 -1
- package/dist/solutions-components/{p-052ff2c7.js → p-8ae8b789.js} +1 -1
- package/dist/solutions-components/{p-4daae757.js → p-8b1236bf.js} +1 -1
- package/dist/solutions-components/{p-ee066c67.js → p-8b14f9aa.js} +3 -3
- package/dist/solutions-components/{p-56300653.js → p-8b4e79fd.js} +1 -1
- package/dist/solutions-components/{p-bba3fa4e.entry.js → p-8bc91d5b.entry.js} +2 -2
- package/dist/solutions-components/{p-cad5587c.entry.js → p-8df0c98c.entry.js} +1 -1
- package/dist/solutions-components/p-953cf07a.entry.js +6 -0
- package/dist/solutions-components/{p-5b9b1cbb.entry.js → p-95cf8aa0.entry.js} +1 -1
- package/dist/solutions-components/{p-29d41c7e.js → p-99ece5e1.js} +2 -2
- package/dist/solutions-components/{p-b4157e6a.js → p-9a2a551d.js} +1 -1
- package/dist/solutions-components/{p-541697d0.js → p-9b43b4cf.js} +1 -1
- package/dist/solutions-components/{p-647a4130.js → p-9f922d49.js} +2 -7
- package/dist/solutions-components/p-9fb09c2c.js +11 -0
- package/dist/solutions-components/{p-e645edf2.entry.js → p-a0e50ea6.entry.js} +1 -1
- package/dist/solutions-components/{p-31316d61.entry.js → p-a1154bb5.entry.js} +2 -2
- package/dist/solutions-components/{p-d62784a4.js → p-a709a84a.js} +1 -1
- package/dist/solutions-components/p-a99832c1.js +27 -0
- package/dist/solutions-components/{p-0f8440bb.entry.js → p-ad41cd27.entry.js} +1 -1
- package/dist/solutions-components/{p-bd3a3afe.js → p-ad962e25.js} +1 -1
- package/dist/solutions-components/{p-2b252afd.entry.js → p-ae1459ed.entry.js} +1 -1
- package/dist/solutions-components/{p-90bbf223.entry.js → p-af9510a4.entry.js} +1 -1
- package/dist/solutions-components/{p-4f0c3fc1.js → p-afc462f0.js} +1 -1
- package/dist/solutions-components/{p-6431fd69.js → p-b02a2b2f.js} +2 -2
- package/dist/solutions-components/{p-421d5e7c.js → p-b0eb13a1.js} +1 -1
- package/dist/solutions-components/{p-2656168f.entry.js → p-b1228e6c.entry.js} +1 -1
- package/dist/solutions-components/{p-0e7914e6.entry.js → p-b1ff9f2e.entry.js} +1 -1
- package/dist/solutions-components/p-b20bf7b7.entry.js +6 -0
- package/dist/solutions-components/{p-7920b5a2.entry.js → p-b361af64.entry.js} +1 -1
- package/dist/solutions-components/{p-a777b18c.js → p-b4a6abe2.js} +2 -2
- package/dist/solutions-components/{p-4e4b55b9.entry.js → p-b68b17b6.entry.js} +3 -3
- package/dist/solutions-components/{p-f41105c8.js → p-b73e9c4d.js} +1 -1
- package/dist/solutions-components/{p-19fe7725.js → p-b9111e12.js} +1 -1
- package/dist/solutions-components/{p-3cbe5ef3.js → p-b9653a1e.js} +1 -1
- package/dist/solutions-components/{p-5f5c371e.js → p-b9fa9ca9.js} +1 -1
- package/dist/solutions-components/{p-c07af9c2.entry.js → p-ba9bb2ba.entry.js} +2 -2
- package/dist/solutions-components/{p-b49bdc72.entry.js → p-bc35e445.entry.js} +1 -1
- package/dist/solutions-components/{p-c3f8b670.js → p-bccc74a8.js} +1 -1
- package/dist/solutions-components/{p-1990d9c8.entry.js → p-bd213033.entry.js} +1 -1
- package/dist/solutions-components/{p-a775ba2f.entry.js → p-c0dc792a.entry.js} +1 -1
- package/dist/solutions-components/{p-606ca126.js → p-c16e540d.js} +1 -1
- package/dist/solutions-components/{p-42c7a5fa.entry.js → p-c35b219b.entry.js} +1 -1
- package/dist/solutions-components/{p-b86b4512.entry.js → p-c38c0612.entry.js} +2 -2
- package/dist/solutions-components/{p-6b2f2b85.js → p-c8c3554b.js} +3 -3
- package/dist/solutions-components/{p-634e1240.js → p-cbebdffa.js} +1 -1
- package/dist/solutions-components/{p-91caf655.entry.js → p-cbf52aa2.entry.js} +2 -2
- package/dist/solutions-components/{p-825bac0e.js → p-ce21ee76.js} +1 -1
- package/dist/solutions-components/{p-57c08531.entry.js → p-ce3e73ae.entry.js} +1 -1
- package/dist/solutions-components/{p-d3a22725.js → p-cf14e2f3.js} +1 -1
- package/dist/solutions-components/{p-f28d69ac.entry.js → p-cfebc45c.entry.js} +1 -1
- package/dist/solutions-components/{p-6a524392.entry.js → p-d15a4f36.entry.js} +1 -1
- package/dist/solutions-components/{p-754e2df2.js → p-d3550542.js} +1 -1
- package/dist/solutions-components/{p-b5d67495.entry.js → p-d3dceabd.entry.js} +1 -1
- package/dist/solutions-components/{p-07bc4f07.entry.js → p-d43c1fc8.entry.js} +2 -2
- package/dist/solutions-components/{p-6de98c51.js → p-d7ddd3a2.js} +1 -1
- package/dist/solutions-components/{p-3e139360.js → p-d841cb8b.js} +1 -1
- package/dist/solutions-components/{p-2ae17fa2.js → p-d9868bac.js} +1 -1
- package/dist/solutions-components/{p-32f9c709.js → p-dc94bec2.js} +1 -1
- package/dist/solutions-components/{p-e6bee82f.js → p-dd0f8875.js} +1 -1
- package/dist/solutions-components/p-dec7b660.js +11 -0
- package/dist/solutions-components/{p-3f0193e9.js → p-deca8a07.js} +1 -1
- package/dist/solutions-components/{p-31ff3452.entry.js → p-df5ec082.entry.js} +1 -1
- package/dist/solutions-components/{p-ea282908.js → p-e046f728.js} +1 -1
- package/dist/solutions-components/{p-cf43278c.entry.js → p-e27ce6d2.entry.js} +1 -1
- package/dist/solutions-components/p-e2abc969.js +6 -0
- package/dist/solutions-components/{p-c5e294e4.js → p-e3f9e213.js} +1 -1
- package/dist/solutions-components/{p-2b96e551.entry.js → p-e43839a8.entry.js} +2 -2
- package/dist/solutions-components/{p-418d0b60.entry.js → p-e4d5188b.entry.js} +1 -1
- package/dist/solutions-components/{p-7b90c18e.entry.js → p-e666c0d6.entry.js} +1 -1
- package/dist/solutions-components/{p-39ff5ee5.js → p-e6c20791.js} +1 -1
- package/dist/solutions-components/{p-2005280f.js → p-ec4c8dc3.js} +1 -1
- package/dist/solutions-components/{p-93074bd4.entry.js → p-ef34c9e2.entry.js} +1 -1
- package/dist/solutions-components/{p-361f1fe1.js → p-f346f8ab.js} +2 -2
- package/dist/solutions-components/{p-680d193d.entry.js → p-f780ecc1.entry.js} +2 -2
- package/dist/solutions-components/p-f8be5d5f.js +7 -0
- package/dist/solutions-components/{p-c70392c4.entry.js → p-f9a56d6b.entry.js} +1 -1
- package/dist/solutions-components/{p-0ece6df1.entry.js → p-f9b9b211.entry.js} +1 -1
- package/dist/solutions-components/{p-a0a2c53d.js → p-fc2277fe.js} +1 -1
- package/dist/solutions-components/{p-40bde8b2.entry.js → p-fd65b14d.entry.js} +1 -1
- package/dist/solutions-components/{p-ef48bd77.entry.js → p-fe0e8542.entry.js} +1 -1
- package/dist/solutions-components/solutions-components.esm.js +1 -1
- package/dist/types/components/buffer-tools/buffer-tools.d.ts +170 -170
- package/dist/types/components/card-manager/card-manager.d.ts +70 -70
- package/dist/types/components/crowdsource-manager/crowdsource-manager.d.ts +174 -174
- package/dist/types/components/crowdsource-reporter/crowdsource-reporter.d.ts +26 -26
- package/dist/types/components/deduct-calculator/deduct-calculator.d.ts +90 -90
- package/dist/types/components/edit-card/edit-card.d.ts +140 -140
- package/dist/types/components/info-card/info-card.d.ts +143 -143
- package/dist/types/components/json-editor/json-editor.d.ts +229 -229
- package/dist/types/components/layer-table/layer-table.d.ts +276 -276
- package/dist/types/components/layout-manager/layout-manager.d.ts +69 -69
- package/dist/types/components/list-item/list-item.d.ts +26 -26
- package/dist/types/components/map-card/map-card.d.ts +83 -83
- package/dist/types/components/map-draw-tools/map-draw-tools.d.ts +231 -231
- package/dist/types/components/map-layer-picker/map-layer-picker.d.ts +160 -160
- package/dist/types/components/map-picker/map-picker.d.ts +109 -109
- package/dist/types/components/map-select-tools/map-select-tools.d.ts +469 -469
- package/dist/types/components/map-tools/map-tools.d.ts +104 -104
- package/dist/types/components/pci-calculator/pci-calculator.d.ts +71 -71
- package/dist/types/components/pdf-download/pdf-download.d.ts +101 -101
- package/dist/types/components/public-notification/public-notification.d.ts +610 -610
- package/dist/types/components/refine-selection/refine-selection.d.ts +234 -234
- package/dist/types/components/solution-configuration/solution-configuration.d.ts +205 -205
- package/dist/types/components/solution-contents/solution-contents.d.ts +46 -46
- package/dist/types/components/solution-item/solution-item.d.ts +71 -71
- package/dist/types/components/solution-item-details/solution-item-details.d.ts +100 -100
- package/dist/types/components/solution-item-icon/solution-item-icon.d.ts +44 -44
- package/dist/types/components/solution-item-sharing/solution-item-sharing.d.ts +62 -62
- package/dist/types/components/solution-organization-variables/solution-organization-variables.d.ts +63 -63
- package/dist/types/components/solution-resource-item/solution-resource-item.d.ts +144 -144
- package/dist/types/components/solution-spatial-ref/solution-spatial-ref.d.ts +180 -180
- package/dist/types/components/solution-spatial-ref/spatialreferences.d.ts +17 -17
- package/dist/types/components/solution-template-data/solution-template-data.d.ts +72 -72
- package/dist/types/components/solution-variables/solution-variables.d.ts +69 -69
- package/dist/types/components/store-manager/store-manager.d.ts +55 -55
- package/dist/types/components.d.ts +0 -2
- package/dist/types/index.d.ts +16 -16
- package/dist/types/stencil-public-runtime.d.ts +14 -27
- package/dist/types/utils/common.d.ts +49 -49
- package/dist/types/utils/csvDownload.d.ts +24 -24
- package/dist/types/utils/csvUtils.d.ts +22 -22
- package/dist/types/utils/downloadUtils.d.ts +118 -118
- package/dist/types/utils/interfaces.d.ts +398 -398
- package/dist/types/utils/languageUtil.d.ts +11 -11
- package/dist/types/utils/loadModules.d.ts +17 -17
- package/dist/types/utils/locale.d.ts +22 -22
- package/dist/types/utils/mapViewUtils.d.ts +124 -124
- package/dist/types/utils/pciUtils.d.ts +97 -97
- package/dist/types/utils/pdfUtils.d.ts +27 -27
- package/dist/types/utils/publicNotificationStore.d.ts +24 -24
- package/dist/types/utils/queryUtils.d.ts +95 -95
- package/dist/types/utils/solution-store.d.ts +234 -234
- package/dist/types/utils/templates.d.ts +50 -50
- package/dist/types/utils/test/mocks/jsApi.d.ts +59 -59
- package/dist/types/utils/test/testUtils.d.ts +36 -36
- package/dist/types/utils/types.d.ts +1 -1
- package/package.json +2 -2
- package/dist/collection/components/buffer-tools/test/buffer-tools.e2e.js +0 -29
- package/dist/collection/components/buffer-tools/test/buffer-tools.spec.js +0 -160
- package/dist/collection/components/card-manager/test/card-manager.e2e.js +0 -29
- package/dist/collection/components/card-manager/test/card-manager.spec.js +0 -37
- package/dist/collection/components/crowdsource-manager/test/crowdsource-manager.e2e.js +0 -29
- package/dist/collection/components/crowdsource-manager/test/crowdsource-manager.spec.js +0 -37
- package/dist/collection/components/crowdsource-reporter/test/crowdsource-reporter.e2e.js +0 -29
- package/dist/collection/components/crowdsource-reporter/test/crowdsource-reporter.spec.js +0 -37
- package/dist/collection/components/deduct-calculator/test/deduct-calculator.e2e.js +0 -29
- package/dist/collection/components/deduct-calculator/test/deduct-calculator.spec.js +0 -37
- package/dist/collection/components/edit-card/test/edit-card.e2e.js +0 -14
- package/dist/collection/components/edit-card/test/edit-card.spec.js +0 -22
- package/dist/collection/components/info-card/test/info-card.e2e.js +0 -29
- package/dist/collection/components/info-card/test/info-card.spec.js +0 -37
- package/dist/collection/components/json-editor/test/json-editor.e2e.js +0 -36
- package/dist/collection/components/json-editor/test/json-editor.spec.js +0 -65
- package/dist/collection/components/layer-table/test/layer-table.e2e.js +0 -29
- package/dist/collection/components/layer-table/test/layer-table.spec.js +0 -37
- package/dist/collection/components/layout-manager/test/layout-manager.e2e.js +0 -29
- package/dist/collection/components/layout-manager/test/layout-manager.spec.js +0 -37
- package/dist/collection/components/list-item/test/list-item.e2e.js +0 -29
- package/dist/collection/components/list-item/test/list-item.spec.js +0 -37
- package/dist/collection/components/map-card/test/map-card.e2e.js +0 -29
- package/dist/collection/components/map-card/test/map-card.spec.js +0 -37
- package/dist/collection/components/map-draw-tools/test/map-draw-tools.e2e.js +0 -29
- package/dist/collection/components/map-draw-tools/test/map-draw-tools.spec.js +0 -37
- package/dist/collection/components/map-layer-picker/test/map-layer-picker.e2e.js +0 -29
- package/dist/collection/components/map-layer-picker/test/map-layer-picker.spec.js +0 -114
- package/dist/collection/components/map-picker/test/map-picker.e2e.js +0 -29
- package/dist/collection/components/map-picker/test/map-picker.spec.js +0 -37
- package/dist/collection/components/map-select-tools/test/map-select-tools.e2e.js +0 -29
- package/dist/collection/components/map-select-tools/test/map-select-tools.spec.js +0 -366
- package/dist/collection/components/map-tools/test/map-tools.e2e.js +0 -29
- package/dist/collection/components/map-tools/test/map-tools.spec.js +0 -37
- package/dist/collection/components/pci-calculator/test/pci-calculator.e2e.js +0 -29
- package/dist/collection/components/pci-calculator/test/pci-calculator.spec.js +0 -37
- package/dist/collection/components/pdf-download/test/pdf-download.e2e.js +0 -76
- package/dist/collection/components/pdf-download/test/pdf-download.spec.js +0 -107
- package/dist/collection/components/public-notification/test/public-notification.spec.js +0 -161
- package/dist/collection/components/refine-selection/test/refine-selection.e2e.js +0 -14
- package/dist/collection/components/refine-selection/test/refine-selection.spec.js +0 -22
- package/dist/collection/components/solution-configuration/test/solution-configuration.e2e.js +0 -36
- package/dist/collection/components/solution-configuration/test/solution-configuration.spec.js +0 -119
- package/dist/collection/components/solution-contents/test/solution-contents.e2e.js +0 -94
- package/dist/collection/components/solution-contents/test/solution-contents.spec.js +0 -143
- package/dist/collection/components/solution-item/test/solution-item.e2e.js +0 -36
- package/dist/collection/components/solution-item/test/solution-item.spec.js +0 -77
- package/dist/collection/components/solution-item-details/test/solution-item-details.e2e.js +0 -36
- package/dist/collection/components/solution-item-details/test/solution-item-details.spec.js +0 -142
- package/dist/collection/components/solution-item-icon/test/solution-item-icon.e2e.js +0 -29
- package/dist/collection/components/solution-item-icon/test/solution-item-icon.spec.js +0 -39
- package/dist/collection/components/solution-item-sharing/test/solution-item-sharing.e2e.js +0 -36
- package/dist/collection/components/solution-item-sharing/test/solution-item-sharing.spec.js +0 -54
- package/dist/collection/components/solution-organization-variables/test/solution-organization-variables.e2e.js +0 -36
- package/dist/collection/components/solution-organization-variables/test/solution-organization-variables.spec.js +0 -65
- package/dist/collection/components/solution-resource-item/test/solution-resource-item.e2e.js +0 -36
- package/dist/collection/components/solution-resource-item/test/solution-resource-item.spec.js +0 -55
- package/dist/collection/components/solution-spatial-ref/test/solution-spatial-ref.e2e.js +0 -36
- package/dist/collection/components/solution-spatial-ref/test/solution-spatial-ref.spec.js +0 -175
- package/dist/collection/components/solution-template-data/test/solution-template-data.e2e.js +0 -36
- package/dist/collection/components/solution-template-data/test/solution-template-data.spec.js +0 -60
- package/dist/collection/components/solution-variables/test/solution-variables.e2e.js +0 -36
- package/dist/collection/components/solution-variables/test/solution-variables.spec.js +0 -131
- package/dist/collection/utils/templates.e2e.js +0 -30
- package/dist/collection/utils/test/csvUtils.spec.js +0 -51
- package/dist/collection/utils/test/downloadUtils.spec.js +0 -357
- package/dist/collection/utils/test/pciUtils.spec.js +0 -302
- package/dist/collection/utils/test/solution-store.spec.js +0 -444
- package/dist/esm/resources-40d8e06f.js +0 -20
- package/dist/solutions-components/p-0cc32f06.js +0 -6
- package/dist/solutions-components/p-10248e04.js +0 -11
- package/dist/solutions-components/p-108fbf59.entry.js +0 -6
- package/dist/solutions-components/p-13290851.js +0 -259
- package/dist/solutions-components/p-164be8ef.entry.js +0 -6
- package/dist/solutions-components/p-1ea1dcac.js +0 -61
- package/dist/solutions-components/p-3aba40e8.js +0 -18
- package/dist/solutions-components/p-3bd99fc9.js +0 -11
- package/dist/solutions-components/p-3cce003d.js +0 -27
- package/dist/solutions-components/p-525f1188.js +0 -11
- package/dist/solutions-components/p-6665fa1f.js +0 -6
- package/dist/solutions-components/p-7c33e500.entry.js +0 -6
- package/dist/solutions-components/p-9310b882.js +0 -7
- package/dist/solutions-components/p-9bbc05ff.js +0 -11
- package/dist/solutions-components/p-a82f35c9.js +0 -6
- package/dist/solutions-components/p-b6578a32.js +0 -6
- package/dist/solutions-components/p-b684bbc7.entry.js +0 -6
- package/dist/solutions-components/p-baccfd70.entry.js +0 -6
- package/dist/solutions-components/p-bf9e18d4.js +0 -8
- package/dist/solutions-components/p-d6322e4b.js +0 -6
- /package/dist/cjs/{array-46bb7df1.js → array-51e7da8f.js} +0 -0
- /package/dist/cjs/{debounce-30afab47.js → debounce-69c3bada.js} +0 -0
- /package/dist/cjs/{guid-3abe3cc6.js → guid-ca85ade0.js} +0 -0
- /package/dist/cjs/{html2canvas-34208bbf.js → html2canvas-770c1171.js} +0 -0
- /package/dist/cjs/{interactive-2fe0f43a.js → interactive-4e212b36.js} +0 -0
- /package/dist/cjs/{key-b8b55ea3.js → key-b32a6438.js} +0 -0
- /package/dist/cjs/{math-5132d9bd.js → math-ef14a84a.js} +0 -0
- /package/dist/cjs/{observers-f5fa975b.js → observers-20fe6f01.js} +0 -0
- /package/dist/cjs/{purify-f8c3e427.js → purify-5389d8d6.js} +0 -0
- /package/dist/cjs/{resources-2901b608.js → resources-1d2258a1.js} +0 -0
- /package/dist/cjs/{resources-60c27547.js → resources-7c9bff85.js} +0 -0
- /package/dist/cjs/{resources-9f2b33ee.js → resources-9dcbf30f.js} +0 -0
- /package/dist/cjs/{resources-4da89742.js → resources-a7e3371d.js} +0 -0
- /package/dist/cjs/{resources-8233a151.js → resources-b176fc52.js} +0 -0
- /package/dist/cjs/{resources-77713c2e.js → resources-b4b4b4fe.js} +0 -0
- /package/dist/cjs/{resources-e1258e8a.js → resources-c6f066a4.js} +0 -0
- /package/dist/cjs/{resources-91409a5d.js → resources-f13e2605.js} +0 -0
- /package/dist/cjs/{resources-c913200c.js → resources-f3e30b7b.js} +0 -0
- /package/dist/cjs/{utils-bae432a9.js → utils-662561ad.js} +0 -0
- /package/dist/cjs/{utils-cd14113f.js → utils-8a0f3e68.js} +0 -0
- /package/dist/esm/{array-751a2b87.js → array-4a653f59.js} +0 -0
- /package/dist/esm/{debounce-229b1a22.js → debounce-4c884e5c.js} +0 -0
- /package/dist/esm/{guid-2bbb8cd1.js → guid-1608fd71.js} +0 -0
- /package/dist/esm/{html2canvas-a0a4df55.js → html2canvas-12c862c8.js} +0 -0
- /package/dist/esm/{interactive-eaf4be29.js → interactive-0733ee76.js} +0 -0
- /package/dist/esm/{key-7a525416.js → key-97b504af.js} +0 -0
- /package/dist/esm/{math-5f92f517.js → math-e006358c.js} +0 -0
- /package/dist/esm/{observers-9d66685a.js → observers-67bdf9e5.js} +0 -0
- /package/dist/esm/{purify-c99d2ace.js → purify-75c61cf7.js} +0 -0
- /package/dist/esm/{resources-d6a4d343.js → resources-01034dfa.js} +0 -0
- /package/dist/esm/{resources-c253772f.js → resources-34b761fa.js} +0 -0
- /package/dist/esm/{resources-a9b2d33c.js → resources-43d63050.js} +0 -0
- /package/dist/esm/{resources-dca3d475.js → resources-5490ccf4.js} +0 -0
- /package/dist/esm/{resources-c65f5654.js → resources-6b7800e6.js} +0 -0
- /package/dist/esm/{resources-5bce3953.js → resources-6be20fcc.js} +0 -0
- /package/dist/esm/{resources-58d30a0f.js → resources-913009ae.js} +0 -0
- /package/dist/{components/resources4.js → esm/resources-b5267429.js} +0 -0
- /package/dist/esm/{resources-94c47e64.js → resources-f97db74e.js} +0 -0
- /package/dist/esm/{utils-2c91c963.js → utils-649c76ab.js} +0 -0
- /package/dist/esm/{utils-18db6b1d.js → utils-dcd05f69.js} +0 -0
- /package/dist/solutions-components/{p-f055a840.js → p-0506e06f.js} +0 -0
- /package/dist/solutions-components/{p-283e3a2d.js → p-0630e686.js} +0 -0
- /package/dist/solutions-components/{p-fb7e0054.js → p-08ab045a.js} +0 -0
- /package/dist/solutions-components/{p-2291b598.js → p-0b32d4fe.js} +0 -0
- /package/dist/solutions-components/{p-5961c4e0.js → p-203b16df.js} +0 -0
- /package/dist/solutions-components/{p-3fc17d72.js → p-3adf63ca.js} +0 -0
- /package/dist/solutions-components/{p-d4c103a8.js → p-3b72043f.js} +0 -0
- /package/dist/solutions-components/{p-18f1772b.js → p-43ebe36a.js} +0 -0
- /package/dist/solutions-components/{p-58ce5639.js → p-5242a652.js} +0 -0
- /package/dist/solutions-components/{p-18869c0f.js → p-5d25ba99.js} +0 -0
- /package/dist/solutions-components/{p-1f468797.js → p-76b83a13.js} +0 -0
- /package/dist/solutions-components/{p-d554507d.js → p-7ac7b1a1.js} +0 -0
- /package/dist/solutions-components/{p-868df4a0.js → p-9ab03591.js} +0 -0
- /package/dist/solutions-components/{p-38ef0684.js → p-a963dd48.js} +0 -0
- /package/dist/solutions-components/{p-63a0e9bf.js → p-cc815aca.js} +0 -0
- /package/dist/solutions-components/{p-6f2edf5b.js → p-d556b5c4.js} +0 -0
- /package/dist/solutions-components/{p-215d3505.js → p-f93e6931.js} +0 -0
- /package/dist/solutions-components/{p-4805ff13.js → p-fb3ba11a.js} +0 -0
- /package/dist/solutions-components/{p-b9749e09.js → p-ff4afb7d.js} +0 -0
@@ -3,353 +3,353 @@
|
|
3
3
|
* Licensed under the Apache License, Version 2.0
|
4
4
|
* http://www.apache.org/licenses/LICENSE-2.0
|
5
5
|
*/
|
6
|
-
import { r as registerInstance, h, H as Host, g as getElement } from './index-
|
7
|
-
import { r as request, N as NODEJS_DEFAULT_REFERER_HEADER, c as cleanUrl, e as encodeQueryString, A as ArcGISAuthError, g as getProp, s as state } from './solution-store-
|
8
|
-
import { g as getLocaleComponentStrings } from './locale-
|
9
|
-
import './index-
|
10
|
-
import './interfaces-
|
6
|
+
import { r as registerInstance, h, H as Host, g as getElement } from './index-d298aca9.js';
|
7
|
+
import { r as request, N as NODEJS_DEFAULT_REFERER_HEADER, c as cleanUrl, e as encodeQueryString, A as ArcGISAuthError, g as getProp, s as state } from './solution-store-c107ca4d.js';
|
8
|
+
import { g as getLocaleComponentStrings } from './locale-54cac39a.js';
|
9
|
+
import './index-4c4a4f3d.js';
|
10
|
+
import './interfaces-bf20e69c.js';
|
11
11
|
import './_commonjsHelpers-d5f9d613.js';
|
12
12
|
|
13
|
-
/** @license
|
14
|
-
* Copyright 2022 Esri
|
15
|
-
*
|
16
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
17
|
-
* you may not use this file except in compliance with the License.
|
18
|
-
* You may obtain a copy of the License at
|
19
|
-
*
|
20
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
21
|
-
*
|
22
|
-
* Unless required by applicable law or agreed to in writing, software
|
23
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
24
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
25
|
-
* See the License for the specific language governing permissions and
|
26
|
-
* limitations under the License.
|
27
|
-
*/
|
28
|
-
//--------------------------------------------------------------------------
|
29
|
-
//
|
30
|
-
// Public Functions
|
31
|
-
//
|
32
|
-
//--------------------------------------------------------------------------
|
33
|
-
/**
|
34
|
-
* Sort the solution items
|
35
|
-
*
|
36
|
-
* @param templates a list of item templates from the solution
|
37
|
-
*
|
38
|
-
* @returns a sorted list of solution items
|
39
|
-
*/
|
40
|
-
function getInventoryItems(templates) {
|
41
|
-
const hierarchy = getItemHierarchy(templates);
|
42
|
-
const ids = hierarchy.reduce((prev, cur) => {
|
43
|
-
prev.push(cur.id);
|
44
|
-
return prev;
|
45
|
-
}, []);
|
46
|
-
return templates.reduce((prev, cur) => {
|
47
|
-
if (ids.indexOf(cur.itemId) > -1) {
|
48
|
-
const hierarchyItems = hierarchy.filter(hi => hi.id === cur.itemId);
|
49
|
-
prev.push(_getItemFromTemplate(cur, templates, hierarchyItems[0].dependencies));
|
50
|
-
}
|
51
|
-
return prev;
|
52
|
-
}, []);
|
53
|
-
}
|
54
|
-
/**
|
55
|
-
* Create item hierarchy that will avoid issues from cylical dependencies
|
56
|
-
*
|
57
|
-
* @param templates a list of item templates from the solution
|
58
|
-
*
|
59
|
-
* @returns a hierarchy for item and item dependency display
|
60
|
-
*/
|
61
|
-
function getItemHierarchy(templates) {
|
62
|
-
const hierarchy = [];
|
63
|
-
// Get the template specified by id out of a list of templates
|
64
|
-
function getTemplateInSolution(templates, id) {
|
65
|
-
const iTemplate = templates.findIndex((template) => id === template.itemId);
|
66
|
-
return iTemplate >= 0 ? templates[iTemplate] : null;
|
67
|
-
}
|
68
|
-
// Hierarchically list the dependencies of specified node
|
69
|
-
function traceItemId(id, accumulatedHierarchy, alreadyVisitedIds = []) {
|
70
|
-
// Get the dependencies of the node
|
71
|
-
const template = getTemplateInSolution(templates, id);
|
72
|
-
/* istanbul ignore else */
|
73
|
-
if (template) {
|
74
|
-
const templateEntry = {
|
75
|
-
id,
|
76
|
-
dependencies: []
|
77
|
-
};
|
78
|
-
// Visit each dependency, but only if this template is not in the alreadyVisitedIds list to avoid infinite loops
|
79
|
-
/* istanbul ignore else */
|
80
|
-
if (alreadyVisitedIds.indexOf(id) < 0) {
|
81
|
-
// Add dependency to alreadyVisitedIds list
|
82
|
-
alreadyVisitedIds.push(id);
|
83
|
-
template.dependencies.forEach((dependencyId) => {
|
84
|
-
// Remove dependency from list of templates to visit in the top-level loop
|
85
|
-
const iDependencyTemplate = templateItemIds.indexOf(dependencyId);
|
86
|
-
/* istanbul ignore else */
|
87
|
-
if (iDependencyTemplate >= 0) {
|
88
|
-
templateItemIds.splice(iDependencyTemplate, 1);
|
89
|
-
}
|
90
|
-
traceItemId(dependencyId, templateEntry.dependencies, alreadyVisitedIds);
|
91
|
-
});
|
92
|
-
}
|
93
|
-
accumulatedHierarchy.push(templateEntry);
|
94
|
-
}
|
95
|
-
}
|
96
|
-
// Start with top-level nodes and add in the rest of the nodes to catch cycles without top-level nodes
|
97
|
-
let templateItemIds = _getTopLevelItemIds(templates);
|
98
|
-
const otherItems = templates
|
99
|
-
.filter((template) => templateItemIds.indexOf(template.itemId) < 0) // only keep non-top-level nodes
|
100
|
-
.sort((a, b) => b.dependencies.length - a.dependencies.length); // sort so that nodes with more dependencies come first--reduces stubs
|
101
|
-
templateItemIds = templateItemIds.concat(otherItems.map((template) => template.itemId));
|
102
|
-
// Step through the list of nodes; we'll also remove nodes as we visit them
|
103
|
-
let itemId = templateItemIds.shift();
|
104
|
-
while (typeof itemId !== "undefined") {
|
105
|
-
traceItemId(itemId, hierarchy);
|
106
|
-
itemId = templateItemIds.shift();
|
107
|
-
}
|
108
|
-
return hierarchy;
|
109
|
-
}
|
110
|
-
/**
|
111
|
-
* Explore the solution item templates for variables we will allow users to insert at runtime
|
112
|
-
*
|
113
|
-
* @param templates a list of item templates from the solution
|
114
|
-
* @param translations nls translation object
|
115
|
-
*
|
116
|
-
* @returns a list of variables from the solution item templates
|
117
|
-
*/
|
118
|
-
function getSolutionVariables(templates, translations) {
|
119
|
-
const vars = [];
|
120
|
-
templates.forEach(t => {
|
121
|
-
const item = {
|
122
|
-
id: t.itemId,
|
123
|
-
title: t.item.title || t.item.name,
|
124
|
-
type: t.type,
|
125
|
-
value: undefined,
|
126
|
-
dependencies: [{
|
127
|
-
id: t.itemId,
|
128
|
-
title: translations.itemId,
|
129
|
-
value: `{{${t.itemId}.itemId}}`,
|
130
|
-
}]
|
131
|
-
};
|
132
|
-
if (t.item.url) {
|
133
|
-
item.dependencies.push({
|
134
|
-
id: t.itemId,
|
135
|
-
title: translations.url,
|
136
|
-
value: `{{${t.itemId}.url}}`,
|
137
|
-
});
|
138
|
-
}
|
139
|
-
if (t.type === "Feature Service") {
|
140
|
-
// TODO need to set source service name var...
|
141
|
-
// TODO need to set soure service shape field name "{{d05b3cf1ffcb4a4fa677627dfb18609e.name}}.Shape"
|
142
|
-
item.dependencies.push({
|
143
|
-
id: t.itemId,
|
144
|
-
title: translations.solutionExtent,
|
145
|
-
value: `{{${t.itemId}.solutionExtent}}`,
|
146
|
-
});
|
147
|
-
_addLayersOrTables(t.properties.layers || [], item, t, translations);
|
148
|
-
_addLayersOrTables(t.properties.tables || [], item, t, translations);
|
149
|
-
}
|
150
|
-
vars.push(item);
|
151
|
-
});
|
152
|
-
return vars;
|
153
|
-
}
|
154
|
-
/**
|
155
|
-
* Set key organization variables we will allow users to insert at runtime
|
156
|
-
*
|
157
|
-
* @param translations nls translation object
|
158
|
-
*
|
159
|
-
* @returns a list of variables for the organization
|
160
|
-
*/
|
161
|
-
function getOrganizationVariables(translations) {
|
162
|
-
const orgVars = [{
|
163
|
-
id: "",
|
164
|
-
title: translations.geocodeUrl,
|
165
|
-
value: "{{organization.helperServices.geocode:getDefaultLocatorURL}}"
|
166
|
-
}, {
|
167
|
-
id: "",
|
168
|
-
title: translations.geometryUrl,
|
169
|
-
value: "{{organization.helperServices.geometry.url}}"
|
170
|
-
}, {
|
171
|
-
id: "",
|
172
|
-
title: translations.portalBaseUrl,
|
173
|
-
value: "{{portalBaseUrl}}"
|
174
|
-
}, {
|
175
|
-
id: "",
|
176
|
-
title: translations.routeUrl,
|
177
|
-
value: "{{organization.helperServices.route.url}}"
|
178
|
-
}, {
|
179
|
-
id: "",
|
180
|
-
title: translations.solutionItemExtent,
|
181
|
-
value: "{{solutionItemExtent}}"
|
182
|
-
}];
|
183
|
-
return orgVars;
|
184
|
-
}
|
185
|
-
//--------------------------------------------------------------------------
|
186
|
-
//
|
187
|
-
// Private Functions
|
188
|
-
//
|
189
|
-
//--------------------------------------------------------------------------
|
190
|
-
/**
|
191
|
-
* Explore a solution item template for variables we will allow users to insert at runtime.
|
192
|
-
* This function will update the item argument that is passed in with the var details.
|
193
|
-
*
|
194
|
-
* @param children a list of layers or tables from a template
|
195
|
-
* @param item an object that store key details for a given variable
|
196
|
-
* @param template one of the templates from the current solution
|
197
|
-
* @param translations nls translations object
|
198
|
-
*
|
199
|
-
*/
|
200
|
-
function _addLayersOrTables(children, item, template, translations) {
|
201
|
-
children.forEach(l => {
|
202
|
-
const name = l.name && l.name.indexOf("||") > -1 ? l.name.split("||")[1].replace("}}", "").trim() : l.name;
|
203
|
-
item.dependencies.push({
|
204
|
-
id: template.itemId,
|
205
|
-
title: `${name} (${translations.id})`,
|
206
|
-
value: `{{${template.itemId}.layer${l.id}.id}}`,
|
207
|
-
});
|
208
|
-
item.dependencies.push({
|
209
|
-
id: template.itemId,
|
210
|
-
title: `${name} (${translations.name})`,
|
211
|
-
value: `{{${template.itemId}.layer${l.id}.name||${name}}}`,
|
212
|
-
});
|
213
|
-
});
|
214
|
-
}
|
215
|
-
/**
|
216
|
-
* Capture key details from the solution item template
|
217
|
-
*
|
218
|
-
* @param template one of the templates from the current solution
|
219
|
-
* @param templates full list of templates
|
220
|
-
* @param dependencies list of hierarchical dependencies
|
221
|
-
*
|
222
|
-
* @returns an IInventoryItem that is used by other components to work with this template
|
223
|
-
*/
|
224
|
-
function _getItemFromTemplate(template, templates, dependencies) {
|
225
|
-
return {
|
226
|
-
id: template.itemId || "",
|
227
|
-
title: template.item.title || "",
|
228
|
-
dependencies: _getDependencies(dependencies, templates),
|
229
|
-
type: template.item.type || "",
|
230
|
-
typeKeywords: template.item.typeKeywords || [] /*,
|
231
|
-
solutionItem: {
|
232
|
-
itemId: template.itemId,
|
233
|
-
itemDetails: _getItemDetails(template.item, template.type === "Group"),
|
234
|
-
isResource: _getIsResource(template),
|
235
|
-
data: template.data,
|
236
|
-
properties: template.properties,
|
237
|
-
type: template.type,
|
238
|
-
groupDetails: _getGroupDetails(template, templates)
|
239
|
-
}*/
|
240
|
-
};
|
241
|
-
}
|
242
|
-
/**
|
243
|
-
* Capture key details from the solution item template
|
244
|
-
*
|
245
|
-
* @param dependencies list of dependencies from a template
|
246
|
-
* @param templates full list of templates
|
247
|
-
*
|
248
|
-
* @returns a list of IInventoryItem that are used by other components to work with the templates
|
249
|
-
*/
|
250
|
-
function _getDependencies(dependencies, templates) {
|
251
|
-
const dependencyItems = [];
|
252
|
-
const depIds = dependencies.reduce((prev, cur) => {
|
253
|
-
prev.push(cur.id);
|
254
|
-
dependencyItems.push(cur);
|
255
|
-
return prev;
|
256
|
-
}, []);
|
257
|
-
return templates.reduce((prev, curr) => {
|
258
|
-
const i = depIds.indexOf(curr.itemId);
|
259
|
-
if (i > -1) {
|
260
|
-
prev.push(_getItemFromTemplate(curr, templates, dependencyItems[i].dependencies));
|
261
|
-
}
|
262
|
-
return prev;
|
263
|
-
}, []);
|
264
|
-
}
|
265
|
-
/**
|
266
|
-
* Capture the key item details for a given template
|
267
|
-
*
|
268
|
-
* @param item the templates item
|
269
|
-
* @param isGroup boolean to indicate if the item is a group
|
270
|
-
* @param itemId the item id of the template
|
271
|
-
*
|
272
|
-
* @returns a IItemDetails object for the current item
|
273
|
-
*/
|
274
|
-
/*
|
275
|
-
function _getItemDetails(
|
276
|
-
item: any,
|
277
|
-
isGroup: boolean
|
278
|
-
): IItemDetails {
|
279
|
-
return {
|
280
|
-
title: item.title || "",
|
281
|
-
snippet: item.snippet || "",
|
282
|
-
description: item.description || "",
|
283
|
-
tags: item.tags || [],
|
284
|
-
accessInformation: !isGroup ? item.accessInformation || "" : "",
|
285
|
-
licenseInfo: !isGroup ? item.licenseInfo || "" : ""
|
286
|
-
};
|
287
|
-
}
|
288
|
-
*/
|
289
|
-
/**
|
290
|
-
* Capture the key item details for a given group template
|
291
|
-
*
|
292
|
-
* @param template one of the templates from the current solution
|
293
|
-
* @param templates full list of templates
|
294
|
-
*
|
295
|
-
* @returns a list of IItemShare objects
|
296
|
-
*/
|
297
|
-
/*
|
298
|
-
function _getGroupDetails(
|
299
|
-
template: any,
|
300
|
-
templates: any[]
|
301
|
-
): IItemShare[] {
|
302
|
-
return template.type === "Group" ? templates.reduce((prev, cur) => {
|
303
|
-
if (cur.itemId !== template.itemId && cur.type !== "Group") {
|
304
|
-
prev.push({
|
305
|
-
id: cur.itemId,
|
306
|
-
title: cur.item.name || cur.item.title,
|
307
|
-
isShared: (cur.groups || []).indexOf(template.itemId) > -1,
|
308
|
-
shareItem: (cur.groups || []).indexOf(template.itemId) > -1,
|
309
|
-
type: cur.type,
|
310
|
-
typeKeywords: cur.item.typeKeywords
|
311
|
-
});
|
312
|
-
}
|
313
|
-
return prev;
|
314
|
-
}, []) : [];
|
315
|
-
}
|
316
|
-
*/
|
317
|
-
/**
|
318
|
-
* Used to understand if we are dealing with a binary object that will support upload/download
|
319
|
-
*
|
320
|
-
* @param template one of the templates from the current solution
|
321
|
-
*
|
322
|
-
* @returns true if this item supports upload/download
|
323
|
-
*/
|
324
|
-
/*
|
325
|
-
function _getIsResource(
|
326
|
-
template: any
|
327
|
-
): boolean {
|
328
|
-
return template.type !== "Group" && template.resources.some(r => r.indexOf("_info_thumbnail") < 0) &&
|
329
|
-
(template.data === null || JSON.stringify(template.data) === "{}");
|
330
|
-
}
|
331
|
-
*/
|
332
|
-
/**
|
333
|
-
* Sort the template ids based on their dependencies
|
334
|
-
*
|
335
|
-
* @param templates full list of templates
|
336
|
-
*
|
337
|
-
* @returns a list of Itop level item ids
|
338
|
-
*/
|
339
|
-
function _getTopLevelItemIds(templates) {
|
340
|
-
// Find the top-level nodes. Start with all nodes, then remove those that other nodes depend on
|
341
|
-
const topLevelItemCandidateIds = templates.map((template) => template.itemId);
|
342
|
-
templates.forEach((template) => {
|
343
|
-
(template.dependencies || []).forEach((dependencyId) => {
|
344
|
-
const iNode = topLevelItemCandidateIds.indexOf(dependencyId);
|
345
|
-
if (iNode >= 0) {
|
346
|
-
// Node is somebody's dependency, so remove the node from the list of top-level nodes
|
347
|
-
// If iNode == -1, then it's a shared dependency and it has already been removed
|
348
|
-
topLevelItemCandidateIds.splice(iNode, 1);
|
349
|
-
}
|
350
|
-
});
|
351
|
-
});
|
352
|
-
return topLevelItemCandidateIds;
|
13
|
+
/** @license
|
14
|
+
* Copyright 2022 Esri
|
15
|
+
*
|
16
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
17
|
+
* you may not use this file except in compliance with the License.
|
18
|
+
* You may obtain a copy of the License at
|
19
|
+
*
|
20
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
21
|
+
*
|
22
|
+
* Unless required by applicable law or agreed to in writing, software
|
23
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
24
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
25
|
+
* See the License for the specific language governing permissions and
|
26
|
+
* limitations under the License.
|
27
|
+
*/
|
28
|
+
//--------------------------------------------------------------------------
|
29
|
+
//
|
30
|
+
// Public Functions
|
31
|
+
//
|
32
|
+
//--------------------------------------------------------------------------
|
33
|
+
/**
|
34
|
+
* Sort the solution items
|
35
|
+
*
|
36
|
+
* @param templates a list of item templates from the solution
|
37
|
+
*
|
38
|
+
* @returns a sorted list of solution items
|
39
|
+
*/
|
40
|
+
function getInventoryItems(templates) {
|
41
|
+
const hierarchy = getItemHierarchy(templates);
|
42
|
+
const ids = hierarchy.reduce((prev, cur) => {
|
43
|
+
prev.push(cur.id);
|
44
|
+
return prev;
|
45
|
+
}, []);
|
46
|
+
return templates.reduce((prev, cur) => {
|
47
|
+
if (ids.indexOf(cur.itemId) > -1) {
|
48
|
+
const hierarchyItems = hierarchy.filter(hi => hi.id === cur.itemId);
|
49
|
+
prev.push(_getItemFromTemplate(cur, templates, hierarchyItems[0].dependencies));
|
50
|
+
}
|
51
|
+
return prev;
|
52
|
+
}, []);
|
53
|
+
}
|
54
|
+
/**
|
55
|
+
* Create item hierarchy that will avoid issues from cylical dependencies
|
56
|
+
*
|
57
|
+
* @param templates a list of item templates from the solution
|
58
|
+
*
|
59
|
+
* @returns a hierarchy for item and item dependency display
|
60
|
+
*/
|
61
|
+
function getItemHierarchy(templates) {
|
62
|
+
const hierarchy = [];
|
63
|
+
// Get the template specified by id out of a list of templates
|
64
|
+
function getTemplateInSolution(templates, id) {
|
65
|
+
const iTemplate = templates.findIndex((template) => id === template.itemId);
|
66
|
+
return iTemplate >= 0 ? templates[iTemplate] : null;
|
67
|
+
}
|
68
|
+
// Hierarchically list the dependencies of specified node
|
69
|
+
function traceItemId(id, accumulatedHierarchy, alreadyVisitedIds = []) {
|
70
|
+
// Get the dependencies of the node
|
71
|
+
const template = getTemplateInSolution(templates, id);
|
72
|
+
/* istanbul ignore else */
|
73
|
+
if (template) {
|
74
|
+
const templateEntry = {
|
75
|
+
id,
|
76
|
+
dependencies: []
|
77
|
+
};
|
78
|
+
// Visit each dependency, but only if this template is not in the alreadyVisitedIds list to avoid infinite loops
|
79
|
+
/* istanbul ignore else */
|
80
|
+
if (alreadyVisitedIds.indexOf(id) < 0) {
|
81
|
+
// Add dependency to alreadyVisitedIds list
|
82
|
+
alreadyVisitedIds.push(id);
|
83
|
+
template.dependencies.forEach((dependencyId) => {
|
84
|
+
// Remove dependency from list of templates to visit in the top-level loop
|
85
|
+
const iDependencyTemplate = templateItemIds.indexOf(dependencyId);
|
86
|
+
/* istanbul ignore else */
|
87
|
+
if (iDependencyTemplate >= 0) {
|
88
|
+
templateItemIds.splice(iDependencyTemplate, 1);
|
89
|
+
}
|
90
|
+
traceItemId(dependencyId, templateEntry.dependencies, alreadyVisitedIds);
|
91
|
+
});
|
92
|
+
}
|
93
|
+
accumulatedHierarchy.push(templateEntry);
|
94
|
+
}
|
95
|
+
}
|
96
|
+
// Start with top-level nodes and add in the rest of the nodes to catch cycles without top-level nodes
|
97
|
+
let templateItemIds = _getTopLevelItemIds(templates);
|
98
|
+
const otherItems = templates
|
99
|
+
.filter((template) => templateItemIds.indexOf(template.itemId) < 0) // only keep non-top-level nodes
|
100
|
+
.sort((a, b) => b.dependencies.length - a.dependencies.length); // sort so that nodes with more dependencies come first--reduces stubs
|
101
|
+
templateItemIds = templateItemIds.concat(otherItems.map((template) => template.itemId));
|
102
|
+
// Step through the list of nodes; we'll also remove nodes as we visit them
|
103
|
+
let itemId = templateItemIds.shift();
|
104
|
+
while (typeof itemId !== "undefined") {
|
105
|
+
traceItemId(itemId, hierarchy);
|
106
|
+
itemId = templateItemIds.shift();
|
107
|
+
}
|
108
|
+
return hierarchy;
|
109
|
+
}
|
110
|
+
/**
|
111
|
+
* Explore the solution item templates for variables we will allow users to insert at runtime
|
112
|
+
*
|
113
|
+
* @param templates a list of item templates from the solution
|
114
|
+
* @param translations nls translation object
|
115
|
+
*
|
116
|
+
* @returns a list of variables from the solution item templates
|
117
|
+
*/
|
118
|
+
function getSolutionVariables(templates, translations) {
|
119
|
+
const vars = [];
|
120
|
+
templates.forEach(t => {
|
121
|
+
const item = {
|
122
|
+
id: t.itemId,
|
123
|
+
title: t.item.title || t.item.name,
|
124
|
+
type: t.type,
|
125
|
+
value: undefined,
|
126
|
+
dependencies: [{
|
127
|
+
id: t.itemId,
|
128
|
+
title: translations.itemId,
|
129
|
+
value: `{{${t.itemId}.itemId}}`,
|
130
|
+
}]
|
131
|
+
};
|
132
|
+
if (t.item.url) {
|
133
|
+
item.dependencies.push({
|
134
|
+
id: t.itemId,
|
135
|
+
title: translations.url,
|
136
|
+
value: `{{${t.itemId}.url}}`,
|
137
|
+
});
|
138
|
+
}
|
139
|
+
if (t.type === "Feature Service") {
|
140
|
+
// TODO need to set source service name var...
|
141
|
+
// TODO need to set soure service shape field name "{{d05b3cf1ffcb4a4fa677627dfb18609e.name}}.Shape"
|
142
|
+
item.dependencies.push({
|
143
|
+
id: t.itemId,
|
144
|
+
title: translations.solutionExtent,
|
145
|
+
value: `{{${t.itemId}.solutionExtent}}`,
|
146
|
+
});
|
147
|
+
_addLayersOrTables(t.properties.layers || [], item, t, translations);
|
148
|
+
_addLayersOrTables(t.properties.tables || [], item, t, translations);
|
149
|
+
}
|
150
|
+
vars.push(item);
|
151
|
+
});
|
152
|
+
return vars;
|
153
|
+
}
|
154
|
+
/**
|
155
|
+
* Set key organization variables we will allow users to insert at runtime
|
156
|
+
*
|
157
|
+
* @param translations nls translation object
|
158
|
+
*
|
159
|
+
* @returns a list of variables for the organization
|
160
|
+
*/
|
161
|
+
function getOrganizationVariables(translations) {
|
162
|
+
const orgVars = [{
|
163
|
+
id: "",
|
164
|
+
title: translations.geocodeUrl,
|
165
|
+
value: "{{organization.helperServices.geocode:getDefaultLocatorURL}}"
|
166
|
+
}, {
|
167
|
+
id: "",
|
168
|
+
title: translations.geometryUrl,
|
169
|
+
value: "{{organization.helperServices.geometry.url}}"
|
170
|
+
}, {
|
171
|
+
id: "",
|
172
|
+
title: translations.portalBaseUrl,
|
173
|
+
value: "{{portalBaseUrl}}"
|
174
|
+
}, {
|
175
|
+
id: "",
|
176
|
+
title: translations.routeUrl,
|
177
|
+
value: "{{organization.helperServices.route.url}}"
|
178
|
+
}, {
|
179
|
+
id: "",
|
180
|
+
title: translations.solutionItemExtent,
|
181
|
+
value: "{{solutionItemExtent}}"
|
182
|
+
}];
|
183
|
+
return orgVars;
|
184
|
+
}
|
185
|
+
//--------------------------------------------------------------------------
|
186
|
+
//
|
187
|
+
// Private Functions
|
188
|
+
//
|
189
|
+
//--------------------------------------------------------------------------
|
190
|
+
/**
|
191
|
+
* Explore a solution item template for variables we will allow users to insert at runtime.
|
192
|
+
* This function will update the item argument that is passed in with the var details.
|
193
|
+
*
|
194
|
+
* @param children a list of layers or tables from a template
|
195
|
+
* @param item an object that store key details for a given variable
|
196
|
+
* @param template one of the templates from the current solution
|
197
|
+
* @param translations nls translations object
|
198
|
+
*
|
199
|
+
*/
|
200
|
+
function _addLayersOrTables(children, item, template, translations) {
|
201
|
+
children.forEach(l => {
|
202
|
+
const name = l.name && l.name.indexOf("||") > -1 ? l.name.split("||")[1].replace("}}", "").trim() : l.name;
|
203
|
+
item.dependencies.push({
|
204
|
+
id: template.itemId,
|
205
|
+
title: `${name} (${translations.id})`,
|
206
|
+
value: `{{${template.itemId}.layer${l.id}.id}}`,
|
207
|
+
});
|
208
|
+
item.dependencies.push({
|
209
|
+
id: template.itemId,
|
210
|
+
title: `${name} (${translations.name})`,
|
211
|
+
value: `{{${template.itemId}.layer${l.id}.name||${name}}}`,
|
212
|
+
});
|
213
|
+
});
|
214
|
+
}
|
215
|
+
/**
|
216
|
+
* Capture key details from the solution item template
|
217
|
+
*
|
218
|
+
* @param template one of the templates from the current solution
|
219
|
+
* @param templates full list of templates
|
220
|
+
* @param dependencies list of hierarchical dependencies
|
221
|
+
*
|
222
|
+
* @returns an IInventoryItem that is used by other components to work with this template
|
223
|
+
*/
|
224
|
+
function _getItemFromTemplate(template, templates, dependencies) {
|
225
|
+
return {
|
226
|
+
id: template.itemId || "",
|
227
|
+
title: template.item.title || "",
|
228
|
+
dependencies: _getDependencies(dependencies, templates),
|
229
|
+
type: template.item.type || "",
|
230
|
+
typeKeywords: template.item.typeKeywords || [] /*,
|
231
|
+
solutionItem: {
|
232
|
+
itemId: template.itemId,
|
233
|
+
itemDetails: _getItemDetails(template.item, template.type === "Group"),
|
234
|
+
isResource: _getIsResource(template),
|
235
|
+
data: template.data,
|
236
|
+
properties: template.properties,
|
237
|
+
type: template.type,
|
238
|
+
groupDetails: _getGroupDetails(template, templates)
|
239
|
+
}*/
|
240
|
+
};
|
241
|
+
}
|
242
|
+
/**
|
243
|
+
* Capture key details from the solution item template
|
244
|
+
*
|
245
|
+
* @param dependencies list of dependencies from a template
|
246
|
+
* @param templates full list of templates
|
247
|
+
*
|
248
|
+
* @returns a list of IInventoryItem that are used by other components to work with the templates
|
249
|
+
*/
|
250
|
+
function _getDependencies(dependencies, templates) {
|
251
|
+
const dependencyItems = [];
|
252
|
+
const depIds = dependencies.reduce((prev, cur) => {
|
253
|
+
prev.push(cur.id);
|
254
|
+
dependencyItems.push(cur);
|
255
|
+
return prev;
|
256
|
+
}, []);
|
257
|
+
return templates.reduce((prev, curr) => {
|
258
|
+
const i = depIds.indexOf(curr.itemId);
|
259
|
+
if (i > -1) {
|
260
|
+
prev.push(_getItemFromTemplate(curr, templates, dependencyItems[i].dependencies));
|
261
|
+
}
|
262
|
+
return prev;
|
263
|
+
}, []);
|
264
|
+
}
|
265
|
+
/**
|
266
|
+
* Capture the key item details for a given template
|
267
|
+
*
|
268
|
+
* @param item the templates item
|
269
|
+
* @param isGroup boolean to indicate if the item is a group
|
270
|
+
* @param itemId the item id of the template
|
271
|
+
*
|
272
|
+
* @returns a IItemDetails object for the current item
|
273
|
+
*/
|
274
|
+
/*
|
275
|
+
function _getItemDetails(
|
276
|
+
item: any,
|
277
|
+
isGroup: boolean
|
278
|
+
): IItemDetails {
|
279
|
+
return {
|
280
|
+
title: item.title || "",
|
281
|
+
snippet: item.snippet || "",
|
282
|
+
description: item.description || "",
|
283
|
+
tags: item.tags || [],
|
284
|
+
accessInformation: !isGroup ? item.accessInformation || "" : "",
|
285
|
+
licenseInfo: !isGroup ? item.licenseInfo || "" : ""
|
286
|
+
};
|
287
|
+
}
|
288
|
+
*/
|
289
|
+
/**
|
290
|
+
* Capture the key item details for a given group template
|
291
|
+
*
|
292
|
+
* @param template one of the templates from the current solution
|
293
|
+
* @param templates full list of templates
|
294
|
+
*
|
295
|
+
* @returns a list of IItemShare objects
|
296
|
+
*/
|
297
|
+
/*
|
298
|
+
function _getGroupDetails(
|
299
|
+
template: any,
|
300
|
+
templates: any[]
|
301
|
+
): IItemShare[] {
|
302
|
+
return template.type === "Group" ? templates.reduce((prev, cur) => {
|
303
|
+
if (cur.itemId !== template.itemId && cur.type !== "Group") {
|
304
|
+
prev.push({
|
305
|
+
id: cur.itemId,
|
306
|
+
title: cur.item.name || cur.item.title,
|
307
|
+
isShared: (cur.groups || []).indexOf(template.itemId) > -1,
|
308
|
+
shareItem: (cur.groups || []).indexOf(template.itemId) > -1,
|
309
|
+
type: cur.type,
|
310
|
+
typeKeywords: cur.item.typeKeywords
|
311
|
+
});
|
312
|
+
}
|
313
|
+
return prev;
|
314
|
+
}, []) : [];
|
315
|
+
}
|
316
|
+
*/
|
317
|
+
/**
|
318
|
+
* Used to understand if we are dealing with a binary object that will support upload/download
|
319
|
+
*
|
320
|
+
* @param template one of the templates from the current solution
|
321
|
+
*
|
322
|
+
* @returns true if this item supports upload/download
|
323
|
+
*/
|
324
|
+
/*
|
325
|
+
function _getIsResource(
|
326
|
+
template: any
|
327
|
+
): boolean {
|
328
|
+
return template.type !== "Group" && template.resources.some(r => r.indexOf("_info_thumbnail") < 0) &&
|
329
|
+
(template.data === null || JSON.stringify(template.data) === "{}");
|
330
|
+
}
|
331
|
+
*/
|
332
|
+
/**
|
333
|
+
* Sort the template ids based on their dependencies
|
334
|
+
*
|
335
|
+
* @param templates full list of templates
|
336
|
+
*
|
337
|
+
* @returns a list of Itop level item ids
|
338
|
+
*/
|
339
|
+
function _getTopLevelItemIds(templates) {
|
340
|
+
// Find the top-level nodes. Start with all nodes, then remove those that other nodes depend on
|
341
|
+
const topLevelItemCandidateIds = templates.map((template) => template.itemId);
|
342
|
+
templates.forEach((template) => {
|
343
|
+
(template.dependencies || []).forEach((dependencyId) => {
|
344
|
+
const iNode = topLevelItemCandidateIds.indexOf(dependencyId);
|
345
|
+
if (iNode >= 0) {
|
346
|
+
// Node is somebody's dependency, so remove the node from the list of top-level nodes
|
347
|
+
// If iNode == -1, then it's a shared dependency and it has already been removed
|
348
|
+
topLevelItemCandidateIds.splice(iNode, 1);
|
349
|
+
}
|
350
|
+
});
|
351
|
+
});
|
352
|
+
return topLevelItemCandidateIds;
|
353
353
|
}
|
354
354
|
|
355
355
|
/* Copyright (c) 2017-2020 Environmental Systems Research Institute, Inc.
|
@@ -1438,549 +1438,549 @@ var UserSession = /** @class */ (function () {
|
|
1438
1438
|
|
1439
1439
|
const solutionConfigurationCss = ".configuration-container{position:relative;height:100%;width:100%}.configuration{position:absolute;top:0px;right:0px;bottom:0px;left:0px;display:flex;padding:0.5rem;border:1px #808080 solid}.config-tabs{width:100%}.config-tab{width:100%}.config-solution{position:absolute;top:3.5rem;right:-1px;bottom:-1px;left:-1px;display:flex;padding:0.5rem}.config-inventory{display:inline;max-width:-moz-min-content;max-width:min-content;flex-grow:0;overflow-y:auto}.config-inventory-hide{display:none;max-width:-moz-min-content;max-width:min-content;flex-grow:0;overflow-y:auto}.config-item{position:relative;display:inline;flex-grow:1;overflow-y:auto;margin-inline-start:0.5rem}solution-contents{position:relative;height:100%}solution-item{position:relative;height:100%}solution-spatial-ref{position:relative;height:100%;width:100%;overflow-y:auto}";
|
1440
1440
|
|
1441
|
-
const SolutionConfiguration = class {
|
1442
|
-
async serializedAuthenticationWatchHandler() {
|
1443
|
-
this.authentication = this.serializedAuthentication ? UserSession.deserialize(this.serializedAuthentication) : new UserSession({});
|
1444
|
-
}
|
1445
|
-
async valueWatchHandler() {
|
1446
|
-
await this._loadSolution(this.solutionItemId);
|
1447
|
-
}
|
1448
|
-
//--------------------------------------------------------------------------
|
1449
|
-
//
|
1450
|
-
// Lifecycle
|
1451
|
-
//
|
1452
|
-
//--------------------------------------------------------------------------
|
1453
|
-
constructor(hostRef) {
|
1454
|
-
registerInstance(this, hostRef);
|
1455
|
-
this._solutionStoreHasChanges = false;
|
1456
|
-
this._solutionEditorHasChanges = false;
|
1457
|
-
this._solutionEditorHasErrors = false;
|
1458
|
-
this._canSave = false;
|
1459
|
-
this.authentication = new UserSession({});
|
1460
|
-
this.serializedAuthentication = "";
|
1461
|
-
this.solutionItemId = "";
|
1462
|
-
this.showLoading = false;
|
1463
|
-
this._currentEditItemId = "";
|
1464
|
-
this._organizationVariables = "";
|
1465
|
-
this._solutionContentsComponent = undefined;
|
1466
|
-
this._solutionIsLoaded = false;
|
1467
|
-
this._solutionVariables = "";
|
1468
|
-
this._templateHierarchy = [];
|
1469
|
-
this._translations = undefined;
|
1470
|
-
this._treeOpen = true;
|
1471
|
-
if (this.serializedAuthentication) {
|
1472
|
-
this.authentication = UserSession.deserialize(this.serializedAuthentication);
|
1473
|
-
}
|
1474
|
-
void this._loadSolution(this.solutionItemId);
|
1475
|
-
window.addEventListener("solutionStoreHasChanges", (evt) => {
|
1476
|
-
this._updateSaveability(this._solutionStoreHasChanges = evt.detail, this._solutionEditorHasChanges, this._solutionEditorHasErrors);
|
1477
|
-
});
|
1478
|
-
window.addEventListener("solutionEditorHasChanges", (evt) => {
|
1479
|
-
this._updateSaveability(this._solutionStoreHasChanges, this._solutionEditorHasChanges = evt.detail, this._solutionEditorHasErrors);
|
1480
|
-
});
|
1481
|
-
window.addEventListener("solutionEditorHasErrors", (evt) => {
|
1482
|
-
this._updateSaveability(this._solutionStoreHasChanges, this._solutionEditorHasChanges, this._solutionEditorHasErrors = evt.detail);
|
1483
|
-
});
|
1484
|
-
}
|
1485
|
-
/**
|
1486
|
-
* StencilJS: Called once just after the component is first connected to the DOM.
|
1487
|
-
*
|
1488
|
-
* @returns Promise when complete
|
1489
|
-
*/
|
1490
|
-
async componentWillLoad() {
|
1491
|
-
return this._getTranslations();
|
1492
|
-
}
|
1493
|
-
/**
|
1494
|
-
* Renders the component.
|
1495
|
-
*/
|
1496
|
-
render() {
|
1497
|
-
const wkid = getProp(state.getStoreInfo("spatialReferenceInfo"), "spatialReference");
|
1498
|
-
const hasServices = state.getStoreInfo("featureServices").length > 0;
|
1499
|
-
const solutionData = state.getStoreInfo("solutionData");
|
1500
|
-
this._solutionVariables = JSON.stringify(getSolutionVariables(solutionData.templates, this._translations));
|
1501
|
-
this._organizationVariables = JSON.stringify(getOrganizationVariables(this._translations));
|
1502
|
-
return (h(Host, null, !this._solutionIsLoaded
|
1503
|
-
? h("calcite-loader", { label: '' })
|
1504
|
-
: null, h("div", { class: "configuration-container" }, h("div", { class: "configuration" }, h("calcite-tabs", { class: "config-tabs" }, h("calcite-tab-nav", { slot: "tab-nav" }, h("calcite-tab-title", null, this._translations.definitionTab), hasServices ?
|
1505
|
-
h("calcite-tab-title", null, this._translations.spatialReferenceTab) :
|
1506
|
-
null), h("calcite-tab", { class: "config-tab", selected: true }, h("div", { class: "config-solution" }, h("div", { class: this._treeOpen ? "config-inventory" : "config-inventory-hide" }, h("solution-contents", { id: "configInventory", key: `${this.solutionItemId}-contents`, ref: (el) => (this._solutionContentsComponent = el) })), h("calcite-button", { appearance: "transparent", class: "collapse-btn", "icon-start": this._treeOpen ? "chevrons-left" : "chevrons-right", id: "collapse-vars", onClick: () => this._toggleTree(), scale: "s", title: this._treeOpen ? this._translations.collapse : this._translations.expand }), h("div", { class: "config-item" }, h("solution-item", { authentication: this.authentication, "item-id": this._currentEditItemId, key: `${this.solutionItemId}-item`, "organization-variables": this._organizationVariables, "solution-item-id": this.solutionItemId, "solution-variables": this._solutionVariables })))), hasServices
|
1507
|
-
? h("calcite-tab", { class: "config-tab" }, h("div", { class: "config-solution" }, h("solution-spatial-ref", { defaultWkid: wkid, id: "configure-solution-spatial-ref", key: `${this.solutionItemId}-spatial-ref`, locked: !wkid, services: state.getStoreInfo("featureServices").map(fs => fs.name) })))
|
1508
|
-
: null)))));
|
1509
|
-
}
|
1510
|
-
//--------------------------------------------------------------------------
|
1511
|
-
//
|
1512
|
-
// Event Listeners
|
1513
|
-
//
|
1514
|
-
//--------------------------------------------------------------------------
|
1515
|
-
_solutionItemSelected(event) {
|
1516
|
-
this._currentEditItemId = event.detail;
|
1517
|
-
}
|
1518
|
-
//--------------------------------------------------------------------------
|
1519
|
-
//
|
1520
|
-
// Events
|
1521
|
-
//
|
1522
|
-
//--------------------------------------------------------------------------
|
1523
|
-
//--------------------------------------------------------------------------
|
1524
|
-
//
|
1525
|
-
// Public Methods (async)
|
1526
|
-
//
|
1527
|
-
//--------------------------------------------------------------------------
|
1528
|
-
/*
|
1529
|
-
@Method()
|
1530
|
-
async getEditModels(): Promise<ISolutionItems> {
|
1531
|
-
return Promise.resolve(state.items);
|
1532
|
-
}
|
1533
|
-
*/
|
1534
|
-
async getSpatialReferenceInfo() {
|
1535
|
-
return Promise.resolve(state.getStoreInfo("spatialReferenceInfo"));
|
1536
|
-
}
|
1537
|
-
/*
|
1538
|
-
@Method()
|
1539
|
-
async getSourceTemplates(): Promise<any> {
|
1540
|
-
return Promise.resolve(this._templates);
|
1541
|
-
}
|
1542
|
-
*/
|
1543
|
-
async saveSolution() {
|
1544
|
-
this._solutionIsLoaded = false;
|
1545
|
-
await state.saveSolution();
|
1546
|
-
this._solutionIsLoaded = true;
|
1547
|
-
this.solutionItemId = null;
|
1548
|
-
}
|
1549
|
-
async unloadSolution() {
|
1550
|
-
this.solutionItemId = null;
|
1551
|
-
}
|
1552
|
-
//--------------------------------------------------------------------------
|
1553
|
-
//
|
1554
|
-
// Private Methods
|
1555
|
-
//
|
1556
|
-
//--------------------------------------------------------------------------
|
1557
|
-
/**
|
1558
|
-
* Update the store with the initial values
|
1559
|
-
*
|
1560
|
-
* @param templates the solution items templates
|
1561
|
-
* @param isReset (defaults to false) indicates if we are resetting the controls after save
|
1562
|
-
*/
|
1563
|
-
/*
|
1564
|
-
protected _initState(
|
1565
|
-
templates: any[],
|
1566
|
-
isReset = false
|
1567
|
-
): Promise<any> {
|
1568
|
-
return new Promise((resolve, reject) => {
|
1569
|
-
if (isReset) {
|
1570
|
-
// clear models and state so we can refresh after save
|
1571
|
-
this.modelsSet = false;
|
1572
|
-
state.reset();
|
1573
|
-
}
|
1574
|
-
getModels(templates, this.authentication, this.solutionItemId).then(models => {
|
1575
|
-
state.models = models;
|
1576
|
-
|
1577
|
-
state.featureServices = getFeatureServices(templates);
|
1578
|
-
state.getStoreInfo("spatialReferenceInfo") = getSpatialReferenceInfo(state.featureServices, this._sourceItemData);
|
1579
|
-
|
1580
|
-
if (isReset) {
|
1581
|
-
// reset for undo/redo stack and diff editor tracking
|
1582
|
-
const jsonEditors = Array.from(this.el.getElementsByTagName("json-editor"));
|
1583
|
-
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
1584
|
-
jsonEditors.forEach(e => void e.reset());
|
1585
|
-
}
|
1586
|
-
|
1587
|
-
this.modelsSet = true;
|
1588
|
-
resolve(true);
|
1589
|
-
}, () => reject);
|
1590
|
-
});
|
1591
|
-
}
|
1592
|
-
*/
|
1593
|
-
/**
|
1594
|
-
* Set Props with the initial values
|
1595
|
-
*
|
1596
|
-
* @protected
|
1597
|
-
*/
|
1598
|
-
_initProps() {
|
1599
|
-
const solutionData = state.getStoreInfo("solutionData");
|
1600
|
-
this._templateHierarchy = [...getInventoryItems(solutionData.templates)];
|
1601
|
-
if (this._solutionContentsComponent) {
|
1602
|
-
this._solutionContentsComponent.templateHierarchy = this._templateHierarchy;
|
1603
|
-
}
|
1604
|
-
let firstItem;
|
1605
|
-
if (this._templateHierarchy.length > 0) {
|
1606
|
-
// Start with the first item in the contents
|
1607
|
-
firstItem = state.getItemInfo(this._templateHierarchy[0].id);
|
1608
|
-
}
|
1609
|
-
this._currentEditItemId = firstItem ? firstItem.itemId : "";
|
1610
|
-
}
|
1611
|
-
/**
|
1612
|
-
* Loads a solution.
|
1613
|
-
*
|
1614
|
-
* @param solutionItemId AGO id of solution to load
|
1615
|
-
*
|
1616
|
-
* @returns Resolved promise when task is done
|
1617
|
-
*
|
1618
|
-
* @protected
|
1619
|
-
*/
|
1620
|
-
async _loadSolution(solutionItemId) {
|
1621
|
-
if (solutionItemId) {
|
1622
|
-
this._solutionIsLoaded = false;
|
1623
|
-
await state.loadSolution(solutionItemId, this.authentication);
|
1624
|
-
this._initProps();
|
1625
|
-
this._solutionIsLoaded = true;
|
1626
|
-
}
|
1627
|
-
else {
|
1628
|
-
this._reset();
|
1629
|
-
}
|
1630
|
-
return Promise.resolve();
|
1631
|
-
}
|
1632
|
-
/**
|
1633
|
-
* Resets internal variables.
|
1634
|
-
*
|
1635
|
-
* @protected
|
1636
|
-
*/
|
1637
|
-
_reset() {
|
1638
|
-
this._currentEditItemId = "";
|
1639
|
-
this._organizationVariables = "";
|
1640
|
-
this._solutionVariables = "";
|
1641
|
-
this._templateHierarchy = [];
|
1642
|
-
}
|
1643
|
-
/**
|
1644
|
-
* Toggle _treeOpen prop to show/hide content tree.
|
1645
|
-
*
|
1646
|
-
* @protected
|
1647
|
-
*/
|
1648
|
-
_toggleTree() {
|
1649
|
-
this._treeOpen = !this._treeOpen;
|
1650
|
-
}
|
1651
|
-
/**
|
1652
|
-
* Dispatches an event indicating if the configuration is saveable or not. It's not saveable if there are no
|
1653
|
-
* changes or if there's an error in the JSON editor.
|
1654
|
-
*
|
1655
|
-
* @param solutionStoreHasChanges Are there changes in the configuration editor's internal store?
|
1656
|
-
* @param solutionEditorHasChanges Are there changes in the configuration editor's JSON editor?
|
1657
|
-
* @param solutionEditorHasErrors Are there errors in the configuration editor's JSON editor?
|
1658
|
-
*
|
1659
|
-
* @protected
|
1660
|
-
*/
|
1661
|
-
_updateSaveability(solutionStoreHasChanges, solutionEditorHasChanges, solutionEditorHasErrors) {
|
1662
|
-
const updateSaveability = (solutionStoreHasChanges || solutionEditorHasChanges) && !solutionEditorHasErrors;
|
1663
|
-
if (this._canSave !== updateSaveability) {
|
1664
|
-
window.dispatchEvent(new CustomEvent("solutionCanSave", {
|
1665
|
-
detail: updateSaveability,
|
1666
|
-
bubbles: true,
|
1667
|
-
cancelable: false,
|
1668
|
-
composed: true
|
1669
|
-
}));
|
1670
|
-
}
|
1671
|
-
this._canSave = updateSaveability;
|
1672
|
-
}
|
1673
|
-
/**
|
1674
|
-
* Save all edits from the current configuration
|
1675
|
-
*
|
1676
|
-
* @returns a response that will indicate success or failure and any associated messages
|
1677
|
-
*/
|
1678
|
-
/*
|
1679
|
-
protected async _save() {
|
1680
|
-
const templateUpdates = await this._updateTemplates();
|
1681
|
-
const data = this._setSrInfo(templateUpdates.templates);
|
1682
|
-
return templateUpdates.errors.length === 0 ? save(
|
1683
|
-
this.solutionItemId,
|
1684
|
-
data,
|
1685
|
-
state.models,
|
1686
|
-
this.authentication,
|
1687
|
-
this._translations
|
1688
|
-
).then(saveResult => {
|
1689
|
-
// need to trigger re-render...and re-fetch
|
1690
|
-
this._fetchData = true;
|
1691
|
-
this.modelsSet = false;
|
1692
|
-
return Promise.resolve(saveResult)
|
1693
|
-
}).catch(e => Promise.reject(e)) : Promise.reject({
|
1694
|
-
success: false,
|
1695
|
-
message: `The following templates have errors: ${templateUpdates.errors.join(", ")}`
|
1696
|
-
} as IResponse);
|
1697
|
-
}
|
1698
|
-
*/
|
1699
|
-
/**
|
1700
|
-
* Update the solutions templates based on the stored changes
|
1701
|
-
*
|
1702
|
-
* @returns an object that contains the updated templates as well as any errors that were found
|
1703
|
-
*/
|
1704
|
-
/*
|
1705
|
-
protected async _updateTemplates(): Promise<IUpdateTemplateResponse> {
|
1706
|
-
const errors = [];
|
1707
|
-
const models = await this.getEditModels();
|
1708
|
-
let templates = this._updateGroupDependencies(models, this._templates);
|
1709
|
-
Object.keys(models).forEach(k => {
|
1710
|
-
const m = models[k];
|
1711
|
-
templates = templates.map(t => {
|
1712
|
-
if (t.itemId === m.itemId) {
|
1713
|
-
this._setItem(t, m);
|
1714
|
-
const hasDataError = this._setData(t, m);
|
1715
|
-
const hasPropError = this._setProps(t, m);
|
1716
|
-
if (hasDataError || hasPropError) {
|
1717
|
-
errors.push(m.itemId);
|
1718
|
-
}
|
1719
|
-
}
|
1720
|
-
return t;
|
1721
|
-
});
|
1722
|
-
});
|
1723
|
-
errors.concat(window.monaco.editor.getModelMarkers({}));
|
1724
|
-
return Promise.resolve({
|
1725
|
-
templates,
|
1726
|
-
errors
|
1727
|
-
});
|
1728
|
-
}
|
1729
|
-
*/
|
1730
|
-
/**
|
1731
|
-
* Review all models and store itemIds that should be added or removed from group dependencies
|
1732
|
-
*
|
1733
|
-
* @param models the corresponding models for the current templates
|
1734
|
-
*
|
1735
|
-
* @returns group info (an object with keys of groupIds and
|
1736
|
-
* arrays of itemIds that should be added or removed from group dependencies)
|
1737
|
-
*/
|
1738
|
-
/*
|
1739
|
-
protected _getGroupInfo(
|
1740
|
-
models: any
|
1741
|
-
): any {
|
1742
|
-
const groupInfo = {}
|
1743
|
-
Object.keys(models).forEach(k => {
|
1744
|
-
const m = models[k];
|
1745
|
-
if (m.shareInfo) {
|
1746
|
-
const groupId = m.shareInfo.groupId;
|
1747
|
-
const type = m.shareInfo.shared ? "share" : "unshare";
|
1748
|
-
if (groupInfo[groupId]) {
|
1749
|
-
groupInfo[groupId][type].push(m.itemId);
|
1750
|
-
} else {
|
1751
|
-
groupInfo[groupId] = {};
|
1752
|
-
groupInfo[groupId][type] = [m.itemId];
|
1753
|
-
if (m.shareInfo.shared) {
|
1754
|
-
groupInfo[groupId]["unshare"] = [];
|
1755
|
-
} else {
|
1756
|
-
groupInfo[groupId]["share"] = [];
|
1757
|
-
}
|
1758
|
-
}
|
1759
|
-
}
|
1760
|
-
});
|
1761
|
-
return groupInfo;
|
1762
|
-
}
|
1763
|
-
*/
|
1764
|
-
/**
|
1765
|
-
* Updates group dependency arrays by adding or removing itemIds
|
1766
|
-
*
|
1767
|
-
* @param templates the current templates to update
|
1768
|
-
* @param models the corresponding models for the current templates
|
1769
|
-
*
|
1770
|
-
* @returns updated templates array
|
1771
|
-
*/
|
1772
|
-
/*
|
1773
|
-
protected _updateGroupDependencies(
|
1774
|
-
models: any,
|
1775
|
-
templates: any[]
|
1776
|
-
): any[] {
|
1777
|
-
const groupInfo = this._getGroupInfo(models);
|
1778
|
-
Object.keys(groupInfo).forEach(k => {
|
1779
|
-
templates.some(t => {
|
1780
|
-
if (t.itemId === k) {
|
1781
|
-
// add share items as deps
|
1782
|
-
groupInfo[k].share.forEach(s => {
|
1783
|
-
if (t.dependencies.indexOf(s) < 0) {
|
1784
|
-
t.dependencies.push(s);
|
1785
|
-
}
|
1786
|
-
});
|
1787
|
-
|
1788
|
-
// remove unshare items from deps
|
1789
|
-
groupInfo[k].unshare.forEach(s => {
|
1790
|
-
const index = t.dependencies.indexOf(s);
|
1791
|
-
if (index > -1) {
|
1792
|
-
t.dependencies.splice(index, 1);
|
1793
|
-
}
|
1794
|
-
});
|
1795
|
-
return true;
|
1796
|
-
} else {
|
1797
|
-
return false;
|
1798
|
-
}
|
1799
|
-
})
|
1800
|
-
})
|
1801
|
-
return templates;
|
1802
|
-
}
|
1803
|
-
*/
|
1804
|
-
/**
|
1805
|
-
* Add group IDs to items that should be shared
|
1806
|
-
* This function will update the provided template when shareInfo is available
|
1807
|
-
*
|
1808
|
-
* @param template the current template to update
|
1809
|
-
* @param shareInfo the corresponding shareInfo from the model for the current template
|
1810
|
-
*
|
1811
|
-
*/
|
1812
|
-
/*
|
1813
|
-
protected _updateItemGroups(
|
1814
|
-
template: any,
|
1815
|
-
shareInfo: any
|
1816
|
-
): void {
|
1817
|
-
if (shareInfo) {
|
1818
|
-
const groupIndex = template.groups.indexOf(shareInfo.groupId);
|
1819
|
-
if (groupIndex < 0 && shareInfo.shared) {
|
1820
|
-
template.groups.push(shareInfo.groupId);
|
1821
|
-
}
|
1822
|
-
if (groupIndex > -1 && !shareInfo.shared) {
|
1823
|
-
template.groups.splice(groupIndex, 1);
|
1824
|
-
}
|
1825
|
-
}
|
1826
|
-
}
|
1827
|
-
*/
|
1828
|
-
/**
|
1829
|
-
* Set a templates data property with changes from the models
|
1830
|
-
*
|
1831
|
-
* @param template the current template to update
|
1832
|
-
* @param model the corresponding model for the current template (stores any user changes)
|
1833
|
-
*
|
1834
|
-
* @returns a boolean that indicates if any errors were detected
|
1835
|
-
*/
|
1836
|
-
/*
|
1837
|
-
protected _setData(
|
1838
|
-
template: any,
|
1839
|
-
model: any
|
1840
|
-
): boolean {
|
1841
|
-
return this._setTemplateProp(
|
1842
|
-
template,
|
1843
|
-
model.dataOriginalValue,
|
1844
|
-
model.dataCurrentValue,
|
1845
|
-
"data"
|
1846
|
-
);
|
1847
|
-
}
|
1848
|
-
*/
|
1849
|
-
/**
|
1850
|
-
* Set a templates properties property with changes from the models
|
1851
|
-
*
|
1852
|
-
* @param template the current template to update
|
1853
|
-
* @param model the corresponding model for the current template (stores any user changes)
|
1854
|
-
*
|
1855
|
-
* @returns a boolean that indicates if any errors were detected
|
1856
|
-
*/
|
1857
|
-
/*
|
1858
|
-
protected _setProps(
|
1859
|
-
template: any,
|
1860
|
-
model: any
|
1861
|
-
): boolean {
|
1862
|
-
return this._setTemplateProp(
|
1863
|
-
template,
|
1864
|
-
model.propsOriginalValue,
|
1865
|
-
model.propsCurrentValue,
|
1866
|
-
"properties"
|
1867
|
-
);
|
1868
|
-
}
|
1869
|
-
*/
|
1870
|
-
/**
|
1871
|
-
* Generic function used to set properties or data property on a given template
|
1872
|
-
*
|
1873
|
-
* @param template the current template to update
|
1874
|
-
* @param originValue the original value from the solution template
|
1875
|
-
* @param modelValue the current value from the model (will contain any edits that have been made)
|
1876
|
-
* @param path the path to the property we should update if any changes are found
|
1877
|
-
*
|
1878
|
-
* @returns a boolean that indicates if any errors were detected
|
1879
|
-
*/
|
1880
|
-
/*
|
1881
|
-
protected _setTemplateProp(
|
1882
|
-
template: any,
|
1883
|
-
originValue: any,
|
1884
|
-
modelValue: any,
|
1885
|
-
path: string
|
1886
|
-
): boolean {
|
1887
|
-
let hasError = false;
|
1888
|
-
try {
|
1889
|
-
const _originValue = JSON.parse(originValue);
|
1890
|
-
const _modelValue = JSON.parse(modelValue);
|
1891
|
-
|
1892
|
-
if (_originValue && _modelValue && (JSON.stringify(_originValue) !== JSON.stringify(_modelValue))) {
|
1893
|
-
setProp(template, path, _modelValue);
|
1894
|
-
}
|
1895
|
-
} catch (e) {
|
1896
|
-
console.error(e);
|
1897
|
-
hasError = true;
|
1898
|
-
}
|
1899
|
-
return hasError;
|
1900
|
-
}
|
1901
|
-
*/
|
1902
|
-
/**
|
1903
|
-
* Set a templates item property with changes from the models
|
1904
|
-
*
|
1905
|
-
* @param template the current template to update
|
1906
|
-
* @param model the corresponding model for the current template (stores any user changes)
|
1907
|
-
*
|
1908
|
-
* This function will update the template argument when edits are found
|
1909
|
-
*/
|
1910
|
-
/*
|
1911
|
-
protected _setItem(
|
1912
|
-
template: any,
|
1913
|
-
model: any
|
1914
|
-
): void {
|
1915
|
-
this._updateItemGroups(template, model.shareInfo);
|
1916
|
-
if (model.updateItemValues && Object.keys(model.updateItemValues).length > 0) {
|
1917
|
-
Object.keys(model.updateItemValues).forEach(k => {
|
1918
|
-
template.item[k] = model.updateItemValues[k];
|
1919
|
-
});
|
1920
|
-
}
|
1921
|
-
}
|
1922
|
-
*/
|
1923
|
-
/**
|
1924
|
-
* Set spatial reference info in the solutions data
|
1925
|
-
*
|
1926
|
-
* @param templates a list of item templates from the solution
|
1927
|
-
*
|
1928
|
-
* @returns a cloned copy of the solutions data that has been updated with spatial reference info
|
1929
|
-
*
|
1930
|
-
*/
|
1931
|
-
/*
|
1932
|
-
protected _setSrInfo(
|
1933
|
-
templates: any[]
|
1934
|
-
): any {
|
1935
|
-
const srInfo: any = state.getStoreInfo("spatialReferenceInfo");
|
1936
|
-
|
1937
|
-
const serviceEnabled = typeof srInfo?.services === "undefined" ?
|
1938
|
-
false : Object.keys(srInfo.services).some(k => srInfo.services[k]);
|
1939
|
-
|
1940
|
-
const data = cloneObject(this._sourceItemData);
|
1941
|
-
data.templates = templates;
|
1942
|
-
if (srInfo && srInfo.enabled && serviceEnabled) {
|
1943
|
-
const wkid = srInfo.spatialReference.wkid.toString();
|
1944
|
-
|
1945
|
-
const wkidParam = {
|
1946
|
-
"label": "Spatial Reference",
|
1947
|
-
"default": wkid,
|
1948
|
-
"valueType": "spatialReference",
|
1949
|
-
"attributes": {
|
1950
|
-
"required": "true"
|
1951
|
-
}
|
1952
|
-
};
|
1953
|
-
|
1954
|
-
const params = getProp(data, "params");
|
1955
|
-
const hasWkid = params && params.wkid;
|
1956
|
-
setCreateProp(
|
1957
|
-
data,
|
1958
|
-
hasWkid ? "params.wkid.default" : "params.wkid",
|
1959
|
-
hasWkid ? wkid : params ? wkidParam : wkid
|
1960
|
-
);
|
1961
|
-
} else if (!srInfo.enabled) {
|
1962
|
-
if (getProp(data, "params.wkid")) {
|
1963
|
-
delete (data.params.wkid);
|
1964
|
-
}
|
1965
|
-
}
|
1966
|
-
return data;
|
1967
|
-
}
|
1968
|
-
*/
|
1969
|
-
/**
|
1970
|
-
* Fetches the component's translations
|
1971
|
-
*
|
1972
|
-
* @protected
|
1973
|
-
*/
|
1974
|
-
async _getTranslations() {
|
1975
|
-
const translations = await getLocaleComponentStrings(this.el);
|
1976
|
-
this._translations = translations[0];
|
1977
|
-
}
|
1978
|
-
get el() { return getElement(this); }
|
1979
|
-
static get watchers() { return {
|
1980
|
-
"serializedAuthentication": ["serializedAuthenticationWatchHandler"],
|
1981
|
-
"solutionItemId": ["valueWatchHandler"]
|
1982
|
-
}; }
|
1983
|
-
};
|
1441
|
+
const SolutionConfiguration = class {
|
1442
|
+
async serializedAuthenticationWatchHandler() {
|
1443
|
+
this.authentication = this.serializedAuthentication ? UserSession.deserialize(this.serializedAuthentication) : new UserSession({});
|
1444
|
+
}
|
1445
|
+
async valueWatchHandler() {
|
1446
|
+
await this._loadSolution(this.solutionItemId);
|
1447
|
+
}
|
1448
|
+
//--------------------------------------------------------------------------
|
1449
|
+
//
|
1450
|
+
// Lifecycle
|
1451
|
+
//
|
1452
|
+
//--------------------------------------------------------------------------
|
1453
|
+
constructor(hostRef) {
|
1454
|
+
registerInstance(this, hostRef);
|
1455
|
+
this._solutionStoreHasChanges = false;
|
1456
|
+
this._solutionEditorHasChanges = false;
|
1457
|
+
this._solutionEditorHasErrors = false;
|
1458
|
+
this._canSave = false;
|
1459
|
+
this.authentication = new UserSession({});
|
1460
|
+
this.serializedAuthentication = "";
|
1461
|
+
this.solutionItemId = "";
|
1462
|
+
this.showLoading = false;
|
1463
|
+
this._currentEditItemId = "";
|
1464
|
+
this._organizationVariables = "";
|
1465
|
+
this._solutionContentsComponent = undefined;
|
1466
|
+
this._solutionIsLoaded = false;
|
1467
|
+
this._solutionVariables = "";
|
1468
|
+
this._templateHierarchy = [];
|
1469
|
+
this._translations = undefined;
|
1470
|
+
this._treeOpen = true;
|
1471
|
+
if (this.serializedAuthentication) {
|
1472
|
+
this.authentication = UserSession.deserialize(this.serializedAuthentication);
|
1473
|
+
}
|
1474
|
+
void this._loadSolution(this.solutionItemId);
|
1475
|
+
window.addEventListener("solutionStoreHasChanges", (evt) => {
|
1476
|
+
this._updateSaveability(this._solutionStoreHasChanges = evt.detail, this._solutionEditorHasChanges, this._solutionEditorHasErrors);
|
1477
|
+
});
|
1478
|
+
window.addEventListener("solutionEditorHasChanges", (evt) => {
|
1479
|
+
this._updateSaveability(this._solutionStoreHasChanges, this._solutionEditorHasChanges = evt.detail, this._solutionEditorHasErrors);
|
1480
|
+
});
|
1481
|
+
window.addEventListener("solutionEditorHasErrors", (evt) => {
|
1482
|
+
this._updateSaveability(this._solutionStoreHasChanges, this._solutionEditorHasChanges, this._solutionEditorHasErrors = evt.detail);
|
1483
|
+
});
|
1484
|
+
}
|
1485
|
+
/**
|
1486
|
+
* StencilJS: Called once just after the component is first connected to the DOM.
|
1487
|
+
*
|
1488
|
+
* @returns Promise when complete
|
1489
|
+
*/
|
1490
|
+
async componentWillLoad() {
|
1491
|
+
return this._getTranslations();
|
1492
|
+
}
|
1493
|
+
/**
|
1494
|
+
* Renders the component.
|
1495
|
+
*/
|
1496
|
+
render() {
|
1497
|
+
const wkid = getProp(state.getStoreInfo("spatialReferenceInfo"), "spatialReference");
|
1498
|
+
const hasServices = state.getStoreInfo("featureServices").length > 0;
|
1499
|
+
const solutionData = state.getStoreInfo("solutionData");
|
1500
|
+
this._solutionVariables = JSON.stringify(getSolutionVariables(solutionData.templates, this._translations));
|
1501
|
+
this._organizationVariables = JSON.stringify(getOrganizationVariables(this._translations));
|
1502
|
+
return (h(Host, null, !this._solutionIsLoaded
|
1503
|
+
? h("calcite-loader", { label: '' })
|
1504
|
+
: null, h("div", { class: "configuration-container" }, h("div", { class: "configuration" }, h("calcite-tabs", { class: "config-tabs" }, h("calcite-tab-nav", { slot: "tab-nav" }, h("calcite-tab-title", null, this._translations.definitionTab), hasServices ?
|
1505
|
+
h("calcite-tab-title", null, this._translations.spatialReferenceTab) :
|
1506
|
+
null), h("calcite-tab", { class: "config-tab", selected: true }, h("div", { class: "config-solution" }, h("div", { class: this._treeOpen ? "config-inventory" : "config-inventory-hide" }, h("solution-contents", { id: "configInventory", key: `${this.solutionItemId}-contents`, ref: (el) => (this._solutionContentsComponent = el) })), h("calcite-button", { appearance: "transparent", class: "collapse-btn", "icon-start": this._treeOpen ? "chevrons-left" : "chevrons-right", id: "collapse-vars", onClick: () => this._toggleTree(), scale: "s", title: this._treeOpen ? this._translations.collapse : this._translations.expand }), h("div", { class: "config-item" }, h("solution-item", { authentication: this.authentication, "item-id": this._currentEditItemId, key: `${this.solutionItemId}-item`, "organization-variables": this._organizationVariables, "solution-item-id": this.solutionItemId, "solution-variables": this._solutionVariables })))), hasServices
|
1507
|
+
? h("calcite-tab", { class: "config-tab" }, h("div", { class: "config-solution" }, h("solution-spatial-ref", { defaultWkid: wkid, id: "configure-solution-spatial-ref", key: `${this.solutionItemId}-spatial-ref`, locked: !wkid, services: state.getStoreInfo("featureServices").map(fs => fs.name) })))
|
1508
|
+
: null)))));
|
1509
|
+
}
|
1510
|
+
//--------------------------------------------------------------------------
|
1511
|
+
//
|
1512
|
+
// Event Listeners
|
1513
|
+
//
|
1514
|
+
//--------------------------------------------------------------------------
|
1515
|
+
_solutionItemSelected(event) {
|
1516
|
+
this._currentEditItemId = event.detail;
|
1517
|
+
}
|
1518
|
+
//--------------------------------------------------------------------------
|
1519
|
+
//
|
1520
|
+
// Events
|
1521
|
+
//
|
1522
|
+
//--------------------------------------------------------------------------
|
1523
|
+
//--------------------------------------------------------------------------
|
1524
|
+
//
|
1525
|
+
// Public Methods (async)
|
1526
|
+
//
|
1527
|
+
//--------------------------------------------------------------------------
|
1528
|
+
/*
|
1529
|
+
@Method()
|
1530
|
+
async getEditModels(): Promise<ISolutionItems> {
|
1531
|
+
return Promise.resolve(state.items);
|
1532
|
+
}
|
1533
|
+
*/
|
1534
|
+
async getSpatialReferenceInfo() {
|
1535
|
+
return Promise.resolve(state.getStoreInfo("spatialReferenceInfo"));
|
1536
|
+
}
|
1537
|
+
/*
|
1538
|
+
@Method()
|
1539
|
+
async getSourceTemplates(): Promise<any> {
|
1540
|
+
return Promise.resolve(this._templates);
|
1541
|
+
}
|
1542
|
+
*/
|
1543
|
+
async saveSolution() {
|
1544
|
+
this._solutionIsLoaded = false;
|
1545
|
+
await state.saveSolution();
|
1546
|
+
this._solutionIsLoaded = true;
|
1547
|
+
this.solutionItemId = null;
|
1548
|
+
}
|
1549
|
+
async unloadSolution() {
|
1550
|
+
this.solutionItemId = null;
|
1551
|
+
}
|
1552
|
+
//--------------------------------------------------------------------------
|
1553
|
+
//
|
1554
|
+
// Private Methods
|
1555
|
+
//
|
1556
|
+
//--------------------------------------------------------------------------
|
1557
|
+
/**
|
1558
|
+
* Update the store with the initial values
|
1559
|
+
*
|
1560
|
+
* @param templates the solution items templates
|
1561
|
+
* @param isReset (defaults to false) indicates if we are resetting the controls after save
|
1562
|
+
*/
|
1563
|
+
/*
|
1564
|
+
protected _initState(
|
1565
|
+
templates: any[],
|
1566
|
+
isReset = false
|
1567
|
+
): Promise<any> {
|
1568
|
+
return new Promise((resolve, reject) => {
|
1569
|
+
if (isReset) {
|
1570
|
+
// clear models and state so we can refresh after save
|
1571
|
+
this.modelsSet = false;
|
1572
|
+
state.reset();
|
1573
|
+
}
|
1574
|
+
getModels(templates, this.authentication, this.solutionItemId).then(models => {
|
1575
|
+
state.models = models;
|
1576
|
+
|
1577
|
+
state.featureServices = getFeatureServices(templates);
|
1578
|
+
state.getStoreInfo("spatialReferenceInfo") = getSpatialReferenceInfo(state.featureServices, this._sourceItemData);
|
1579
|
+
|
1580
|
+
if (isReset) {
|
1581
|
+
// reset for undo/redo stack and diff editor tracking
|
1582
|
+
const jsonEditors = Array.from(this.el.getElementsByTagName("json-editor"));
|
1583
|
+
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
1584
|
+
jsonEditors.forEach(e => void e.reset());
|
1585
|
+
}
|
1586
|
+
|
1587
|
+
this.modelsSet = true;
|
1588
|
+
resolve(true);
|
1589
|
+
}, () => reject);
|
1590
|
+
});
|
1591
|
+
}
|
1592
|
+
*/
|
1593
|
+
/**
|
1594
|
+
* Set Props with the initial values
|
1595
|
+
*
|
1596
|
+
* @protected
|
1597
|
+
*/
|
1598
|
+
_initProps() {
|
1599
|
+
const solutionData = state.getStoreInfo("solutionData");
|
1600
|
+
this._templateHierarchy = [...getInventoryItems(solutionData.templates)];
|
1601
|
+
if (this._solutionContentsComponent) {
|
1602
|
+
this._solutionContentsComponent.templateHierarchy = this._templateHierarchy;
|
1603
|
+
}
|
1604
|
+
let firstItem;
|
1605
|
+
if (this._templateHierarchy.length > 0) {
|
1606
|
+
// Start with the first item in the contents
|
1607
|
+
firstItem = state.getItemInfo(this._templateHierarchy[0].id);
|
1608
|
+
}
|
1609
|
+
this._currentEditItemId = firstItem ? firstItem.itemId : "";
|
1610
|
+
}
|
1611
|
+
/**
|
1612
|
+
* Loads a solution.
|
1613
|
+
*
|
1614
|
+
* @param solutionItemId AGO id of solution to load
|
1615
|
+
*
|
1616
|
+
* @returns Resolved promise when task is done
|
1617
|
+
*
|
1618
|
+
* @protected
|
1619
|
+
*/
|
1620
|
+
async _loadSolution(solutionItemId) {
|
1621
|
+
if (solutionItemId) {
|
1622
|
+
this._solutionIsLoaded = false;
|
1623
|
+
await state.loadSolution(solutionItemId, this.authentication);
|
1624
|
+
this._initProps();
|
1625
|
+
this._solutionIsLoaded = true;
|
1626
|
+
}
|
1627
|
+
else {
|
1628
|
+
this._reset();
|
1629
|
+
}
|
1630
|
+
return Promise.resolve();
|
1631
|
+
}
|
1632
|
+
/**
|
1633
|
+
* Resets internal variables.
|
1634
|
+
*
|
1635
|
+
* @protected
|
1636
|
+
*/
|
1637
|
+
_reset() {
|
1638
|
+
this._currentEditItemId = "";
|
1639
|
+
this._organizationVariables = "";
|
1640
|
+
this._solutionVariables = "";
|
1641
|
+
this._templateHierarchy = [];
|
1642
|
+
}
|
1643
|
+
/**
|
1644
|
+
* Toggle _treeOpen prop to show/hide content tree.
|
1645
|
+
*
|
1646
|
+
* @protected
|
1647
|
+
*/
|
1648
|
+
_toggleTree() {
|
1649
|
+
this._treeOpen = !this._treeOpen;
|
1650
|
+
}
|
1651
|
+
/**
|
1652
|
+
* Dispatches an event indicating if the configuration is saveable or not. It's not saveable if there are no
|
1653
|
+
* changes or if there's an error in the JSON editor.
|
1654
|
+
*
|
1655
|
+
* @param solutionStoreHasChanges Are there changes in the configuration editor's internal store?
|
1656
|
+
* @param solutionEditorHasChanges Are there changes in the configuration editor's JSON editor?
|
1657
|
+
* @param solutionEditorHasErrors Are there errors in the configuration editor's JSON editor?
|
1658
|
+
*
|
1659
|
+
* @protected
|
1660
|
+
*/
|
1661
|
+
_updateSaveability(solutionStoreHasChanges, solutionEditorHasChanges, solutionEditorHasErrors) {
|
1662
|
+
const updateSaveability = (solutionStoreHasChanges || solutionEditorHasChanges) && !solutionEditorHasErrors;
|
1663
|
+
if (this._canSave !== updateSaveability) {
|
1664
|
+
window.dispatchEvent(new CustomEvent("solutionCanSave", {
|
1665
|
+
detail: updateSaveability,
|
1666
|
+
bubbles: true,
|
1667
|
+
cancelable: false,
|
1668
|
+
composed: true
|
1669
|
+
}));
|
1670
|
+
}
|
1671
|
+
this._canSave = updateSaveability;
|
1672
|
+
}
|
1673
|
+
/**
|
1674
|
+
* Save all edits from the current configuration
|
1675
|
+
*
|
1676
|
+
* @returns a response that will indicate success or failure and any associated messages
|
1677
|
+
*/
|
1678
|
+
/*
|
1679
|
+
protected async _save() {
|
1680
|
+
const templateUpdates = await this._updateTemplates();
|
1681
|
+
const data = this._setSrInfo(templateUpdates.templates);
|
1682
|
+
return templateUpdates.errors.length === 0 ? save(
|
1683
|
+
this.solutionItemId,
|
1684
|
+
data,
|
1685
|
+
state.models,
|
1686
|
+
this.authentication,
|
1687
|
+
this._translations
|
1688
|
+
).then(saveResult => {
|
1689
|
+
// need to trigger re-render...and re-fetch
|
1690
|
+
this._fetchData = true;
|
1691
|
+
this.modelsSet = false;
|
1692
|
+
return Promise.resolve(saveResult)
|
1693
|
+
}).catch(e => Promise.reject(e)) : Promise.reject({
|
1694
|
+
success: false,
|
1695
|
+
message: `The following templates have errors: ${templateUpdates.errors.join(", ")}`
|
1696
|
+
} as IResponse);
|
1697
|
+
}
|
1698
|
+
*/
|
1699
|
+
/**
|
1700
|
+
* Update the solutions templates based on the stored changes
|
1701
|
+
*
|
1702
|
+
* @returns an object that contains the updated templates as well as any errors that were found
|
1703
|
+
*/
|
1704
|
+
/*
|
1705
|
+
protected async _updateTemplates(): Promise<IUpdateTemplateResponse> {
|
1706
|
+
const errors = [];
|
1707
|
+
const models = await this.getEditModels();
|
1708
|
+
let templates = this._updateGroupDependencies(models, this._templates);
|
1709
|
+
Object.keys(models).forEach(k => {
|
1710
|
+
const m = models[k];
|
1711
|
+
templates = templates.map(t => {
|
1712
|
+
if (t.itemId === m.itemId) {
|
1713
|
+
this._setItem(t, m);
|
1714
|
+
const hasDataError = this._setData(t, m);
|
1715
|
+
const hasPropError = this._setProps(t, m);
|
1716
|
+
if (hasDataError || hasPropError) {
|
1717
|
+
errors.push(m.itemId);
|
1718
|
+
}
|
1719
|
+
}
|
1720
|
+
return t;
|
1721
|
+
});
|
1722
|
+
});
|
1723
|
+
errors.concat(window.monaco.editor.getModelMarkers({}));
|
1724
|
+
return Promise.resolve({
|
1725
|
+
templates,
|
1726
|
+
errors
|
1727
|
+
});
|
1728
|
+
}
|
1729
|
+
*/
|
1730
|
+
/**
|
1731
|
+
* Review all models and store itemIds that should be added or removed from group dependencies
|
1732
|
+
*
|
1733
|
+
* @param models the corresponding models for the current templates
|
1734
|
+
*
|
1735
|
+
* @returns group info (an object with keys of groupIds and
|
1736
|
+
* arrays of itemIds that should be added or removed from group dependencies)
|
1737
|
+
*/
|
1738
|
+
/*
|
1739
|
+
protected _getGroupInfo(
|
1740
|
+
models: any
|
1741
|
+
): any {
|
1742
|
+
const groupInfo = {}
|
1743
|
+
Object.keys(models).forEach(k => {
|
1744
|
+
const m = models[k];
|
1745
|
+
if (m.shareInfo) {
|
1746
|
+
const groupId = m.shareInfo.groupId;
|
1747
|
+
const type = m.shareInfo.shared ? "share" : "unshare";
|
1748
|
+
if (groupInfo[groupId]) {
|
1749
|
+
groupInfo[groupId][type].push(m.itemId);
|
1750
|
+
} else {
|
1751
|
+
groupInfo[groupId] = {};
|
1752
|
+
groupInfo[groupId][type] = [m.itemId];
|
1753
|
+
if (m.shareInfo.shared) {
|
1754
|
+
groupInfo[groupId]["unshare"] = [];
|
1755
|
+
} else {
|
1756
|
+
groupInfo[groupId]["share"] = [];
|
1757
|
+
}
|
1758
|
+
}
|
1759
|
+
}
|
1760
|
+
});
|
1761
|
+
return groupInfo;
|
1762
|
+
}
|
1763
|
+
*/
|
1764
|
+
/**
|
1765
|
+
* Updates group dependency arrays by adding or removing itemIds
|
1766
|
+
*
|
1767
|
+
* @param templates the current templates to update
|
1768
|
+
* @param models the corresponding models for the current templates
|
1769
|
+
*
|
1770
|
+
* @returns updated templates array
|
1771
|
+
*/
|
1772
|
+
/*
|
1773
|
+
protected _updateGroupDependencies(
|
1774
|
+
models: any,
|
1775
|
+
templates: any[]
|
1776
|
+
): any[] {
|
1777
|
+
const groupInfo = this._getGroupInfo(models);
|
1778
|
+
Object.keys(groupInfo).forEach(k => {
|
1779
|
+
templates.some(t => {
|
1780
|
+
if (t.itemId === k) {
|
1781
|
+
// add share items as deps
|
1782
|
+
groupInfo[k].share.forEach(s => {
|
1783
|
+
if (t.dependencies.indexOf(s) < 0) {
|
1784
|
+
t.dependencies.push(s);
|
1785
|
+
}
|
1786
|
+
});
|
1787
|
+
|
1788
|
+
// remove unshare items from deps
|
1789
|
+
groupInfo[k].unshare.forEach(s => {
|
1790
|
+
const index = t.dependencies.indexOf(s);
|
1791
|
+
if (index > -1) {
|
1792
|
+
t.dependencies.splice(index, 1);
|
1793
|
+
}
|
1794
|
+
});
|
1795
|
+
return true;
|
1796
|
+
} else {
|
1797
|
+
return false;
|
1798
|
+
}
|
1799
|
+
})
|
1800
|
+
})
|
1801
|
+
return templates;
|
1802
|
+
}
|
1803
|
+
*/
|
1804
|
+
/**
|
1805
|
+
* Add group IDs to items that should be shared
|
1806
|
+
* This function will update the provided template when shareInfo is available
|
1807
|
+
*
|
1808
|
+
* @param template the current template to update
|
1809
|
+
* @param shareInfo the corresponding shareInfo from the model for the current template
|
1810
|
+
*
|
1811
|
+
*/
|
1812
|
+
/*
|
1813
|
+
protected _updateItemGroups(
|
1814
|
+
template: any,
|
1815
|
+
shareInfo: any
|
1816
|
+
): void {
|
1817
|
+
if (shareInfo) {
|
1818
|
+
const groupIndex = template.groups.indexOf(shareInfo.groupId);
|
1819
|
+
if (groupIndex < 0 && shareInfo.shared) {
|
1820
|
+
template.groups.push(shareInfo.groupId);
|
1821
|
+
}
|
1822
|
+
if (groupIndex > -1 && !shareInfo.shared) {
|
1823
|
+
template.groups.splice(groupIndex, 1);
|
1824
|
+
}
|
1825
|
+
}
|
1826
|
+
}
|
1827
|
+
*/
|
1828
|
+
/**
|
1829
|
+
* Set a templates data property with changes from the models
|
1830
|
+
*
|
1831
|
+
* @param template the current template to update
|
1832
|
+
* @param model the corresponding model for the current template (stores any user changes)
|
1833
|
+
*
|
1834
|
+
* @returns a boolean that indicates if any errors were detected
|
1835
|
+
*/
|
1836
|
+
/*
|
1837
|
+
protected _setData(
|
1838
|
+
template: any,
|
1839
|
+
model: any
|
1840
|
+
): boolean {
|
1841
|
+
return this._setTemplateProp(
|
1842
|
+
template,
|
1843
|
+
model.dataOriginalValue,
|
1844
|
+
model.dataCurrentValue,
|
1845
|
+
"data"
|
1846
|
+
);
|
1847
|
+
}
|
1848
|
+
*/
|
1849
|
+
/**
|
1850
|
+
* Set a templates properties property with changes from the models
|
1851
|
+
*
|
1852
|
+
* @param template the current template to update
|
1853
|
+
* @param model the corresponding model for the current template (stores any user changes)
|
1854
|
+
*
|
1855
|
+
* @returns a boolean that indicates if any errors were detected
|
1856
|
+
*/
|
1857
|
+
/*
|
1858
|
+
protected _setProps(
|
1859
|
+
template: any,
|
1860
|
+
model: any
|
1861
|
+
): boolean {
|
1862
|
+
return this._setTemplateProp(
|
1863
|
+
template,
|
1864
|
+
model.propsOriginalValue,
|
1865
|
+
model.propsCurrentValue,
|
1866
|
+
"properties"
|
1867
|
+
);
|
1868
|
+
}
|
1869
|
+
*/
|
1870
|
+
/**
|
1871
|
+
* Generic function used to set properties or data property on a given template
|
1872
|
+
*
|
1873
|
+
* @param template the current template to update
|
1874
|
+
* @param originValue the original value from the solution template
|
1875
|
+
* @param modelValue the current value from the model (will contain any edits that have been made)
|
1876
|
+
* @param path the path to the property we should update if any changes are found
|
1877
|
+
*
|
1878
|
+
* @returns a boolean that indicates if any errors were detected
|
1879
|
+
*/
|
1880
|
+
/*
|
1881
|
+
protected _setTemplateProp(
|
1882
|
+
template: any,
|
1883
|
+
originValue: any,
|
1884
|
+
modelValue: any,
|
1885
|
+
path: string
|
1886
|
+
): boolean {
|
1887
|
+
let hasError = false;
|
1888
|
+
try {
|
1889
|
+
const _originValue = JSON.parse(originValue);
|
1890
|
+
const _modelValue = JSON.parse(modelValue);
|
1891
|
+
|
1892
|
+
if (_originValue && _modelValue && (JSON.stringify(_originValue) !== JSON.stringify(_modelValue))) {
|
1893
|
+
setProp(template, path, _modelValue);
|
1894
|
+
}
|
1895
|
+
} catch (e) {
|
1896
|
+
console.error(e);
|
1897
|
+
hasError = true;
|
1898
|
+
}
|
1899
|
+
return hasError;
|
1900
|
+
}
|
1901
|
+
*/
|
1902
|
+
/**
|
1903
|
+
* Set a templates item property with changes from the models
|
1904
|
+
*
|
1905
|
+
* @param template the current template to update
|
1906
|
+
* @param model the corresponding model for the current template (stores any user changes)
|
1907
|
+
*
|
1908
|
+
* This function will update the template argument when edits are found
|
1909
|
+
*/
|
1910
|
+
/*
|
1911
|
+
protected _setItem(
|
1912
|
+
template: any,
|
1913
|
+
model: any
|
1914
|
+
): void {
|
1915
|
+
this._updateItemGroups(template, model.shareInfo);
|
1916
|
+
if (model.updateItemValues && Object.keys(model.updateItemValues).length > 0) {
|
1917
|
+
Object.keys(model.updateItemValues).forEach(k => {
|
1918
|
+
template.item[k] = model.updateItemValues[k];
|
1919
|
+
});
|
1920
|
+
}
|
1921
|
+
}
|
1922
|
+
*/
|
1923
|
+
/**
|
1924
|
+
* Set spatial reference info in the solutions data
|
1925
|
+
*
|
1926
|
+
* @param templates a list of item templates from the solution
|
1927
|
+
*
|
1928
|
+
* @returns a cloned copy of the solutions data that has been updated with spatial reference info
|
1929
|
+
*
|
1930
|
+
*/
|
1931
|
+
/*
|
1932
|
+
protected _setSrInfo(
|
1933
|
+
templates: any[]
|
1934
|
+
): any {
|
1935
|
+
const srInfo: any = state.getStoreInfo("spatialReferenceInfo");
|
1936
|
+
|
1937
|
+
const serviceEnabled = typeof srInfo?.services === "undefined" ?
|
1938
|
+
false : Object.keys(srInfo.services).some(k => srInfo.services[k]);
|
1939
|
+
|
1940
|
+
const data = cloneObject(this._sourceItemData);
|
1941
|
+
data.templates = templates;
|
1942
|
+
if (srInfo && srInfo.enabled && serviceEnabled) {
|
1943
|
+
const wkid = srInfo.spatialReference.wkid.toString();
|
1944
|
+
|
1945
|
+
const wkidParam = {
|
1946
|
+
"label": "Spatial Reference",
|
1947
|
+
"default": wkid,
|
1948
|
+
"valueType": "spatialReference",
|
1949
|
+
"attributes": {
|
1950
|
+
"required": "true"
|
1951
|
+
}
|
1952
|
+
};
|
1953
|
+
|
1954
|
+
const params = getProp(data, "params");
|
1955
|
+
const hasWkid = params && params.wkid;
|
1956
|
+
setCreateProp(
|
1957
|
+
data,
|
1958
|
+
hasWkid ? "params.wkid.default" : "params.wkid",
|
1959
|
+
hasWkid ? wkid : params ? wkidParam : wkid
|
1960
|
+
);
|
1961
|
+
} else if (!srInfo.enabled) {
|
1962
|
+
if (getProp(data, "params.wkid")) {
|
1963
|
+
delete (data.params.wkid);
|
1964
|
+
}
|
1965
|
+
}
|
1966
|
+
return data;
|
1967
|
+
}
|
1968
|
+
*/
|
1969
|
+
/**
|
1970
|
+
* Fetches the component's translations
|
1971
|
+
*
|
1972
|
+
* @protected
|
1973
|
+
*/
|
1974
|
+
async _getTranslations() {
|
1975
|
+
const translations = await getLocaleComponentStrings(this.el);
|
1976
|
+
this._translations = translations[0];
|
1977
|
+
}
|
1978
|
+
get el() { return getElement(this); }
|
1979
|
+
static get watchers() { return {
|
1980
|
+
"serializedAuthentication": ["serializedAuthenticationWatchHandler"],
|
1981
|
+
"solutionItemId": ["valueWatchHandler"]
|
1982
|
+
}; }
|
1983
|
+
};
|
1984
1984
|
SolutionConfiguration.style = solutionConfigurationCss;
|
1985
1985
|
|
1986
1986
|
export { SolutionConfiguration as solution_configuration };
|