@arcgis/coding-components 4.31.0-next.0 → 4.31.0-next.11
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/README.md +22 -3
- package/dist/arcgis-coding-components/arcgis-coding-components.esm.js +2 -2
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.ar.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.bg.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.bs.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.ca.json +6 -6
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.cs.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.da.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.de.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.el.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.es.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.et.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.fi.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.fr.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.he.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.hr.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.id.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.it.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.ko.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.nb.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.nl.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.pl.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.pt-BR.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.pt-PT.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.ru.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.sk.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.sl.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.sr.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.sv.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.th.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.tr.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.uk.json +5 -5
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.vi.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.zh-CN.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.zh-HK.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-language/t9n/profile.t9n.zh-TW.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-results/t9n/arcade-results.t9n.ca.json +2 -2
- package/dist/arcgis-coding-components/assets/arcade-results/t9n/arcade-results.t9n.de.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-results/t9n/arcade-results.t9n.he.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-variables/t9n/arcade-variables.t9n.ca.json +1 -1
- package/dist/arcgis-coding-components/assets/arcade-variables/t9n/arcade-variables.t9n.it.json +1 -1
- package/dist/arcgis-coding-components/assets/code-editor/arcade.worker.js +13 -13
- package/dist/arcgis-coding-components/assets/code-editor/css.worker.js +1 -1
- package/dist/arcgis-coding-components/assets/code-editor/html.worker.js +1 -1
- package/dist/arcgis-coding-components/assets/code-editor/json.worker.js +1 -1
- package/dist/arcgis-coding-components/assets/code-editor/sql-expr.worker.js +11 -0
- package/dist/arcgis-coding-components/assets/code-editor/ts.worker.js +1 -1
- package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ca.json → language-api-panel/t9n/language-api-panel.t9n.ca.json} +1 -1
- package/dist/arcgis-coding-components/assets/sql-expression-editor/api/sql-expression-api.t9n.en.json +735 -0
- package/dist/arcgis-coding-components/index.esm.js +2 -2
- package/dist/arcgis-coding-components/{p-4b079737.js → p-21306a37.js} +2 -2
- package/dist/arcgis-coding-components/p-29b05690.entry.js +6 -0
- package/dist/arcgis-coding-components/p-2db85972.js +6 -0
- package/dist/arcgis-coding-components/{p-b0f66fd8.js → p-2f2288de.js} +2 -2
- package/dist/arcgis-coding-components/{p-d34c7a85.js → p-4050b5db.js} +2 -2
- package/dist/arcgis-coding-components/{p-25960980.js → p-44052160.js} +2 -2
- package/dist/arcgis-coding-components/p-47bb2fdc.entry.js +6 -0
- package/dist/arcgis-coding-components/p-4fcb5bf0.js +6 -0
- package/dist/arcgis-coding-components/{p-bd97ed67.js → p-79e7d01c.js} +3 -3
- package/dist/arcgis-coding-components/{p-a333eca1.js → p-aedf8504.js} +3 -3
- package/dist/arcgis-coding-components/p-af7ed920.js +68 -0
- package/dist/arcgis-coding-components/p-c28eef63.js +6 -0
- package/dist/arcgis-coding-components/p-ca85726f.js +7 -0
- package/dist/arcgis-coding-components/p-cdc11558.js +6 -0
- package/dist/arcgis-coding-components/{p-f32a81b3.js → p-decda64c.js} +1 -1
- package/dist/arcgis-coding-components/p-e6442988.js +6 -0
- package/dist/arcgis-coding-components/p-eb99e7e7.entry.js +6 -0
- package/dist/arcgis-coding-components/{p-73af647c.js → p-ef0c4126.js} +3 -3
- package/dist/arcgis-coding-components/p-fa824326.js +6 -0
- package/dist/cjs/app-globals-d8d56a70.js +10 -0
- package/dist/cjs/arcade-defaults-b1300c3f.js +349 -0
- package/dist/cjs/arcade-language-features-5c4510c9.js +274 -0
- package/dist/cjs/arcade-mode-185370a7.js +335 -0
- package/dist/cjs/{arcgis-arcade-api_6.cjs.entry.js → arcgis-arcade-editor_6.cjs.entry.js} +3823 -5071
- package/dist/cjs/arcgis-coding-components.cjs.js +14 -12
- package/dist/cjs/arcgis-sql-expression-editor.cjs.entry.js +81 -0
- package/dist/cjs/arcgis-sql-expression-fields.cjs.entry.js +80 -0
- package/dist/cjs/{css-c5819912.js → css-0d91050a.js} +1 -1
- package/dist/cjs/{cssMode-555a44d1.js → cssMode-e8786e83.js} +3 -4
- package/dist/cjs/{html-2bff0c65.js → html-adbae3fd.js} +3 -4
- package/dist/cjs/{htmlMode-77c4a499.js → htmlMode-608f8da7.js} +3 -4
- package/dist/cjs/index-1cf75f2d.js +1311 -0
- package/dist/cjs/index.cjs.js +4 -3
- package/dist/cjs/{javascript-70a512ed.js → javascript-c8733e40.js} +3 -4
- package/dist/cjs/{jsonMode-0a74131c.js → jsonMode-98ec5315.js} +3 -4
- package/dist/cjs/{arcade-defaults-fa428ea6.js → language-defaults-base-2b2f9d3e.js} +930 -1142
- package/dist/cjs/loader.cjs.js +6 -4
- package/dist/cjs/sql-expr-defaults-a1d5380d.js +1331 -0
- package/dist/cjs/sql-expr-mode-19618e11.js +21838 -0
- package/dist/cjs/{tsMode-8cb776f7.js → tsMode-ed34ec8f.js} +4 -5
- package/dist/cjs/{typescript-2695cf9d.js → typescript-c3d83864.js} +3 -4
- package/dist/components/arcade-defaults.js +68 -1324
- package/dist/components/arcade-language-features.js +271 -0
- package/dist/components/arcade-mode.js +8 -268
- package/dist/components/arcade-results.js +10 -7
- package/dist/components/arcade-suggestions.js +11 -8
- package/dist/components/arcade-variables.js +10 -7
- package/dist/components/arcgis-arcade-editor.js +52 -50
- package/dist/components/arcgis-arcade-results.js +1 -1
- package/dist/components/arcgis-arcade-suggestions.js +1 -1
- package/dist/components/arcgis-arcade-variables.js +1 -1
- package/dist/components/arcgis-assets.d.ts +1 -1
- package/dist/components/arcgis-assets.js +1 -1
- package/dist/components/arcgis-code-editor.js +1 -1
- package/dist/components/arcgis-language-api-panel.d.ts +11 -0
- package/dist/components/arcgis-language-api-panel.js +11 -0
- package/dist/components/arcgis-sql-expression-editor.d.ts +11 -0
- package/dist/components/arcgis-sql-expression-editor.js +120 -0
- package/dist/components/arcgis-sql-expression-fields.d.ts +11 -0
- package/dist/components/arcgis-sql-expression-fields.js +11 -0
- package/dist/components/chunk-3IUJHIAA.js +1154 -0
- package/dist/components/code-editor.js +190 -18
- package/dist/components/fields.js +5 -5
- package/dist/components/index.js +1 -1
- package/dist/components/index2.js +40 -27
- package/dist/components/{arcade-api.js → language-api-panel.js} +30 -57
- package/dist/components/language-defaults-base.js +1309 -0
- package/dist/components/markdown.js +7 -19
- package/dist/components/sql-expr-defaults.js +182 -0
- package/dist/components/sql-expr-mode.js +21836 -0
- package/dist/components/sql-expression-fields.js +102 -0
- package/dist/components/useT9n.js +48 -9
- package/dist/components/utilities.js +1 -1
- package/dist/esm/app-globals-a48930ca.js +8 -0
- package/dist/esm/arcade-defaults-3ea67051.js +344 -0
- package/dist/esm/arcade-language-features-8274cdc7.js +269 -0
- package/dist/esm/{arcade-mode-f534f6f8.js → arcade-mode-c48c3fc6.js} +7 -267
- package/dist/esm/{arcgis-arcade-api_6.entry.js → arcgis-arcade-editor_6.entry.js} +3794 -5042
- package/dist/esm/arcgis-coding-components.js +15 -13
- package/dist/esm/arcgis-sql-expression-editor.entry.js +77 -0
- package/dist/esm/arcgis-sql-expression-fields.entry.js +76 -0
- package/dist/esm/{css-34fa13c1.js → css-4f85f426.js} +1 -1
- package/dist/esm/{cssMode-8758c994.js → cssMode-d655f1b9.js} +2 -3
- package/dist/esm/{html-c2757f30.js → html-dd1552df.js} +2 -3
- package/dist/esm/{htmlMode-64bfdd08.js → htmlMode-0b7c2367.js} +2 -3
- package/dist/esm/index-38d652b8.js +1280 -0
- package/dist/esm/index.js +4 -3
- package/dist/esm/{javascript-7cb6a2cd.js → javascript-ef70f152.js} +3 -4
- package/dist/esm/{jsonMode-728cfcab.js → jsonMode-a6ed58a5.js} +2 -3
- package/dist/esm/{arcade-defaults-ef553659.js → language-defaults-base-77487def.js} +921 -1139
- package/dist/esm/loader.js +7 -5
- package/dist/esm/sql-expr-defaults-54db53a8.js +1325 -0
- package/dist/esm/sql-expr-mode-5c1d43ea.js +21835 -0
- package/dist/esm/{tsMode-f3c09a15.js → tsMode-fce6766b.js} +2 -3
- package/dist/esm/{typescript-a359e263.js → typescript-aed3d402.js} +2 -3
- package/dist/loader/cdn.js +1 -1
- package/dist/loader/index.cjs.js +1 -1
- package/dist/loader/index.es2017.js +1 -1
- package/dist/loader/index.js +1 -1
- package/dist/types/components/arcade-editor/arcade-editor.d.ts +45 -10
- package/dist/types/components/arcade-results/arcade-results.d.ts +43 -1
- package/dist/types/components/arcade-suggestions/arcade-suggestions.d.ts +22 -1
- package/dist/types/components/arcade-variables/arcade-variables.d.ts +28 -1
- package/dist/types/components/code-editor/code-editor.d.ts +16 -5
- package/dist/types/components/language-api-panel/language-api-panel.d.ts +73 -0
- package/dist/types/components/sql-expression-editor/sql-expression-editor.d.ts +24 -0
- package/dist/types/components/sql-expression-fields/sql-expression-fields.d.ts +32 -0
- package/dist/types/components.d.ts +148 -70
- package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stories/internal/arcade-editor/arcade-editor.stories.d.ts +8 -1
- package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stories/internal/arcade-editor/editorContext.d.ts +5 -1
- package/dist/types/data/actions-runner-1/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stories/internal/sql-expression-editor/sql-expression-editor.stories.d.ts +13 -0
- package/dist/types/dependencies.d.ts +21 -0
- package/dist/types/utils/arcade-monaco/arcade-contribution.d.ts +1 -24
- package/dist/types/utils/arcade-monaco/arcade-defaults.d.ts +12 -49
- package/dist/types/utils/arcade-monaco/arcade-language-features.d.ts +6 -4
- package/dist/types/utils/arcade-monaco/arcade-mode.d.ts +3 -2
- package/dist/types/utils/arcade-monaco/arcade-profile-strategy.d.ts +9 -0
- package/dist/types/utils/arcade-monaco/arcade-service-accessors.d.ts +31 -0
- package/dist/types/utils/arcade-monaco/arcade-worker-manager.d.ts +3 -2
- package/dist/types/utils/arcade-monaco/arcade.worker.d.ts +5 -5
- package/dist/types/utils/arcade-monaco/types.d.ts +6 -35
- package/dist/types/utils/fields.d.ts +2 -2
- package/dist/types/utils/language-defaults-base.d.ts +69 -0
- package/dist/types/utils/profile/editor-profile.d.ts +7 -6
- package/dist/types/utils/profile/types.d.ts +53 -65
- package/dist/types/utils/profile/utils.d.ts +9 -8
- package/dist/types/utils/sql-expr-monaco/DependentFiles/DateOnly.d.ts +41 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/SqlInterval.d.ts +16 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/SqlTimestampOffset.d.ts +26 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/TimeOnly.d.ts +37 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/UnknownTimeZone.d.ts +11 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/WhereGrammar.d.ts +122 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlCompareUtils.d.ts +5 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlDateParsingUtils.d.ts +18 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlUtils.d.ts +6 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/standardizedFunctions.d.ts +156 -0
- package/dist/types/utils/sql-expr-monaco/DependentFiles/support.d.ts +150 -0
- package/dist/types/utils/sql-expr-monaco/PeggyGrammar/sql92grammar.d.ts +1397 -0
- package/dist/types/utils/sql-expr-monaco/libraries/date/properties/index.d.ts +59 -0
- package/dist/types/utils/sql-expr-monaco/libraries/numeric/properties/index.d.ts +295 -0
- package/dist/types/utils/sql-expr-monaco/libraries/string/properties/index.d.ts +135 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-completion.d.ts +6 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-contribution.d.ts +11 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-defaults.d.ts +22 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-language-features.d.ts +61 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-language-syntax.d.ts +8 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-mode.d.ts +10 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-adapter.d.ts +3 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-diagnostic-adapter.d.ts +41 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-utils.d.ts +99 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation.d.ts +41 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-worker-manager.d.ts +15 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr.worker.d.ts +21 -0
- package/dist/types/utils/sql-expr-monaco/sql-expression-profile-strategy.d.ts +9 -0
- package/dist/types/utils/sql-expr-monaco/types.d.ts +91 -0
- package/package.json +30 -24
- package/dist/arcgis-coding-components/p-3fb3347e.js +0 -6
- package/dist/arcgis-coding-components/p-52fc1b44.js +0 -7
- package/dist/arcgis-coding-components/p-75571c31.entry.js +0 -6
- package/dist/arcgis-coding-components/p-c07f51a4.js +0 -68
- package/dist/cjs/arcade-mode-75d2c139.js +0 -595
- package/dist/cjs/index-f61a8dce.js +0 -1994
- package/dist/components/arcade-contribution.js +0 -181
- package/dist/components/arcgis-arcade-api.d.ts +0 -11
- package/dist/components/arcgis-arcade-api.js +0 -11
- package/dist/components/chunk-63RMNUHL.js +0 -1275
- package/dist/esm/index-7be467d0.js +0 -1963
- package/dist/types/components/arcade-api/arcade-api.d.ts +0 -45
- package/dist/types/components/arcade-api/t9n-types.d.ts +0 -8
- package/dist/types/components/arcade-editor/t9n-types.d.ts +0 -8
- package/dist/types/components/arcade-results/t9n-types.d.ts +0 -13
- package/dist/types/components/arcade-suggestions/t9n-types.d.ts +0 -6
- package/dist/types/components/arcade-variables/t9n-types.d.ts +0 -8
- package/dist/types/utils/profile/predefined-profile.d.ts +0 -2
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ar.json → language-api-panel/t9n/language-api-panel.t9n.ar.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.bg.json → language-api-panel/t9n/language-api-panel.t9n.bg.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.bs.json → language-api-panel/t9n/language-api-panel.t9n.bs.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.cs.json → language-api-panel/t9n/language-api-panel.t9n.cs.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.da.json → language-api-panel/t9n/language-api-panel.t9n.da.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.de.json → language-api-panel/t9n/language-api-panel.t9n.de.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.el.json → language-api-panel/t9n/language-api-panel.t9n.el.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.en.json → language-api-panel/t9n/language-api-panel.t9n.en.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.es.json → language-api-panel/t9n/language-api-panel.t9n.es.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.et.json → language-api-panel/t9n/language-api-panel.t9n.et.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.fi.json → language-api-panel/t9n/language-api-panel.t9n.fi.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.fr.json → language-api-panel/t9n/language-api-panel.t9n.fr.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.he.json → language-api-panel/t9n/language-api-panel.t9n.he.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.hr.json → language-api-panel/t9n/language-api-panel.t9n.hr.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.hu.json → language-api-panel/t9n/language-api-panel.t9n.hu.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.id.json → language-api-panel/t9n/language-api-panel.t9n.id.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.it.json → language-api-panel/t9n/language-api-panel.t9n.it.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ja.json → language-api-panel/t9n/language-api-panel.t9n.ja.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ko.json → language-api-panel/t9n/language-api-panel.t9n.ko.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.lt.json → language-api-panel/t9n/language-api-panel.t9n.lt.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.lv.json → language-api-panel/t9n/language-api-panel.t9n.lv.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.nb.json → language-api-panel/t9n/language-api-panel.t9n.nb.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.nl.json → language-api-panel/t9n/language-api-panel.t9n.nl.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.pl.json → language-api-panel/t9n/language-api-panel.t9n.pl.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.pt-BR.json → language-api-panel/t9n/language-api-panel.t9n.pt-BR.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.pt-PT.json → language-api-panel/t9n/language-api-panel.t9n.pt-PT.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ro.json → language-api-panel/t9n/language-api-panel.t9n.ro.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.ru.json → language-api-panel/t9n/language-api-panel.t9n.ru.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.sk.json → language-api-panel/t9n/language-api-panel.t9n.sk.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.sl.json → language-api-panel/t9n/language-api-panel.t9n.sl.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.sr.json → language-api-panel/t9n/language-api-panel.t9n.sr.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.sv.json → language-api-panel/t9n/language-api-panel.t9n.sv.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.th.json → language-api-panel/t9n/language-api-panel.t9n.th.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.tr.json → language-api-panel/t9n/language-api-panel.t9n.tr.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.uk.json → language-api-panel/t9n/language-api-panel.t9n.uk.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.vi.json → language-api-panel/t9n/language-api-panel.t9n.vi.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.zh-CN.json → language-api-panel/t9n/language-api-panel.t9n.zh-CN.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.zh-HK.json → language-api-panel/t9n/language-api-panel.t9n.zh-HK.json} +0 -0
- /package/dist/arcgis-coding-components/assets/{arcade-api/t9n/arcade-api.t9n.zh-TW.json → language-api-panel/t9n/language-api-panel.t9n.zh-TW.json} +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stencil.config.d.ts +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stories/internal/code-editor/code-editor.stories.d.ts +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/stories/reference/stories/arcade-editor.stories.d.ts +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/support/sass-inline-url-importer.d.ts +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/support/sass-json-importer.d.ts +0 -0
- /package/dist/types/data/{actions-runner-2 → actions-runner-1}/_work/arcgis-web-components/arcgis-web-components/packages/coding-packages/coding-components/.stencil/support/stencil-monaco-plugins.d.ts +0 -0
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* All material copyright Esri, All Rights Reserved, unless otherwise specified.
|
|
3
|
+
* See https://js.arcgis.com/4.31/esri/copyright.txt for details.
|
|
4
|
+
* v4.31.0-next.11
|
|
5
|
+
*/
|
|
6
|
+
import { g as editor, P as MarkerSeverity, m as main, R as Range, z as languages, Q as debounce } from './language-defaults-base-77487def.js';
|
|
7
|
+
|
|
8
|
+
//#region Diagnostic
|
|
9
|
+
class DiagnosticsAdapter {
|
|
10
|
+
constructor(_languageId, _worker, { defaults, diagnosticsService, }) {
|
|
11
|
+
this._languageId = _languageId;
|
|
12
|
+
this._worker = _worker;
|
|
13
|
+
this._disposables = [];
|
|
14
|
+
this._listener = new Map();
|
|
15
|
+
this._diagnosticsService = diagnosticsService;
|
|
16
|
+
this._defaults = defaults;
|
|
17
|
+
const onModelAdd = (model) => {
|
|
18
|
+
const languageId = model.getLanguageId();
|
|
19
|
+
if (languageId !== this._languageId) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const debouncedValidate = debounce(() => {
|
|
23
|
+
this._doValidate(model, languageId).catch((err) => {
|
|
24
|
+
throw err;
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
this._listener.set(model.uri.toString(), model.onDidChangeContent(debouncedValidate));
|
|
28
|
+
this._doValidate(model, languageId).catch(console.error);
|
|
29
|
+
};
|
|
30
|
+
const onModelRemoved = (model) => {
|
|
31
|
+
const uriStr = model.uri.toString();
|
|
32
|
+
editor.setModelMarkers(model, this._languageId, []);
|
|
33
|
+
const listener = this._listener.get(uriStr);
|
|
34
|
+
if (listener) {
|
|
35
|
+
listener.dispose();
|
|
36
|
+
this._listener.delete(uriStr);
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
this._disposables.push(editor.onDidCreateModel(onModelAdd));
|
|
40
|
+
this._disposables.push(editor.onWillDisposeModel((model) => {
|
|
41
|
+
onModelRemoved(model);
|
|
42
|
+
}));
|
|
43
|
+
this._disposables.push(editor.onDidChangeModelLanguage((event) => {
|
|
44
|
+
onModelRemoved(event.model);
|
|
45
|
+
onModelAdd(event.model);
|
|
46
|
+
}));
|
|
47
|
+
this._disposables.push(defaults.onDidChange(() => {
|
|
48
|
+
editor.getModels().forEach((model) => {
|
|
49
|
+
if (model.getLanguageId() === this._languageId) {
|
|
50
|
+
onModelRemoved(model);
|
|
51
|
+
onModelAdd(model);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}));
|
|
55
|
+
this._disposables.push(defaults.onModelContextDidChange((key) => {
|
|
56
|
+
editor.getModels().forEach((model) => {
|
|
57
|
+
if (model.getLanguageId() === this._languageId && model.uri.toString() === key) {
|
|
58
|
+
this._doValidate(model, this._languageId).catch(console.error);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}));
|
|
62
|
+
this._disposables.push({
|
|
63
|
+
dispose: () => {
|
|
64
|
+
this._listener.forEach((value) => value.dispose());
|
|
65
|
+
this._listener.clear();
|
|
66
|
+
},
|
|
67
|
+
});
|
|
68
|
+
editor.getModels().forEach(onModelAdd);
|
|
69
|
+
}
|
|
70
|
+
dispose() {
|
|
71
|
+
this._disposables.forEach((d) => d.dispose());
|
|
72
|
+
this._disposables = [];
|
|
73
|
+
}
|
|
74
|
+
async _doValidate(model, languageId) {
|
|
75
|
+
if (!model.isAttachedToEditor()) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
try {
|
|
79
|
+
const workerProxy = await this._worker(model.uri);
|
|
80
|
+
const context = this._defaults.getApiContextForModel(model.uri);
|
|
81
|
+
const diagnostics = await workerProxy.doValidation(model.uri.toString(), context);
|
|
82
|
+
const markers = diagnostics.map((d) => toMarker(model.uri, d));
|
|
83
|
+
this._diagnosticsService.fireDiagnosticsChange(model.uri, diagnostics);
|
|
84
|
+
editor.setModelMarkers(model, languageId, markers);
|
|
85
|
+
}
|
|
86
|
+
catch (err) {
|
|
87
|
+
console.error(err);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
function toSeverity(languageServiceSeverity) {
|
|
92
|
+
switch (languageServiceSeverity) {
|
|
93
|
+
case main.exports.DiagnosticSeverity.Error:
|
|
94
|
+
return MarkerSeverity.Error;
|
|
95
|
+
case main.exports.DiagnosticSeverity.Warning:
|
|
96
|
+
return MarkerSeverity.Warning;
|
|
97
|
+
case main.exports.DiagnosticSeverity.Information:
|
|
98
|
+
return MarkerSeverity.Info;
|
|
99
|
+
case main.exports.DiagnosticSeverity.Hint:
|
|
100
|
+
return MarkerSeverity.Hint;
|
|
101
|
+
default:
|
|
102
|
+
return MarkerSeverity.Info;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
function toMarker(_resource, diag) {
|
|
106
|
+
// Diagnostics positions are zero-based, MarkerData are 1-based
|
|
107
|
+
return {
|
|
108
|
+
severity: toSeverity(diag.severity),
|
|
109
|
+
startLineNumber: diag.range.start.line + 1,
|
|
110
|
+
startColumn: diag.range.start.character + 1,
|
|
111
|
+
endLineNumber: diag.range.end.line + 1,
|
|
112
|
+
endColumn: diag.range.end.character + 1,
|
|
113
|
+
message: diag.message,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
//#endregion
|
|
117
|
+
//#region Completion
|
|
118
|
+
function fromPosition(position) {
|
|
119
|
+
// Language service is zero based
|
|
120
|
+
return { character: position.column - 1, line: position.lineNumber - 1 };
|
|
121
|
+
}
|
|
122
|
+
function toRange(range) {
|
|
123
|
+
return new Range(range.start.line + 1, range.start.character + 1, range.end.line + 1, range.end.character + 1);
|
|
124
|
+
}
|
|
125
|
+
function toTextEdit(textEdit) {
|
|
126
|
+
return {
|
|
127
|
+
range: toRange(textEdit.range),
|
|
128
|
+
text: textEdit.newText,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
function isInsertReplaceEdit(edit) {
|
|
132
|
+
return (typeof edit.insert !== "undefined" &&
|
|
133
|
+
typeof edit.replace !== "undefined");
|
|
134
|
+
}
|
|
135
|
+
// TODO: extract this function to common util
|
|
136
|
+
function toCompletionItemKind(kind) {
|
|
137
|
+
const mItemKind = languages.CompletionItemKind;
|
|
138
|
+
switch (kind) {
|
|
139
|
+
case main.exports.CompletionItemKind.Text:
|
|
140
|
+
return mItemKind.Text;
|
|
141
|
+
case main.exports.CompletionItemKind.Method:
|
|
142
|
+
return mItemKind.Method;
|
|
143
|
+
case main.exports.CompletionItemKind.Function:
|
|
144
|
+
return mItemKind.Function;
|
|
145
|
+
case main.exports.CompletionItemKind.Constructor:
|
|
146
|
+
return mItemKind.Constructor;
|
|
147
|
+
case main.exports.CompletionItemKind.Field:
|
|
148
|
+
return mItemKind.Field;
|
|
149
|
+
case main.exports.CompletionItemKind.Variable:
|
|
150
|
+
return mItemKind.Variable;
|
|
151
|
+
case main.exports.CompletionItemKind.Class:
|
|
152
|
+
return mItemKind.Class;
|
|
153
|
+
case main.exports.CompletionItemKind.Interface:
|
|
154
|
+
return mItemKind.Interface;
|
|
155
|
+
case main.exports.CompletionItemKind.Module:
|
|
156
|
+
return mItemKind.Module;
|
|
157
|
+
case main.exports.CompletionItemKind.Property:
|
|
158
|
+
return mItemKind.Property;
|
|
159
|
+
case main.exports.CompletionItemKind.Unit:
|
|
160
|
+
return mItemKind.Unit;
|
|
161
|
+
case main.exports.CompletionItemKind.Value:
|
|
162
|
+
return mItemKind.Value;
|
|
163
|
+
case main.exports.CompletionItemKind.Enum:
|
|
164
|
+
return mItemKind.Enum;
|
|
165
|
+
case main.exports.CompletionItemKind.Keyword:
|
|
166
|
+
return mItemKind.Keyword;
|
|
167
|
+
case main.exports.CompletionItemKind.Snippet:
|
|
168
|
+
return mItemKind.Snippet;
|
|
169
|
+
case main.exports.CompletionItemKind.Color:
|
|
170
|
+
return mItemKind.Color;
|
|
171
|
+
case main.exports.CompletionItemKind.File:
|
|
172
|
+
return mItemKind.File;
|
|
173
|
+
case main.exports.CompletionItemKind.Reference:
|
|
174
|
+
return mItemKind.Reference;
|
|
175
|
+
case main.exports.CompletionItemKind.Folder:
|
|
176
|
+
return mItemKind.Folder;
|
|
177
|
+
case main.exports.CompletionItemKind.EnumMember:
|
|
178
|
+
return mItemKind.EnumMember;
|
|
179
|
+
case main.exports.CompletionItemKind.Constant:
|
|
180
|
+
return mItemKind.Constant;
|
|
181
|
+
case main.exports.CompletionItemKind.Struct:
|
|
182
|
+
return mItemKind.Struct;
|
|
183
|
+
case main.exports.CompletionItemKind.Event:
|
|
184
|
+
return mItemKind.Event;
|
|
185
|
+
case main.exports.CompletionItemKind.Operator:
|
|
186
|
+
return mItemKind.Operator;
|
|
187
|
+
case main.exports.CompletionItemKind.TypeParameter:
|
|
188
|
+
return mItemKind.TypeParameter;
|
|
189
|
+
default:
|
|
190
|
+
return mItemKind.Property;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
class CompletionProvider {
|
|
194
|
+
constructor(_worker, _defaults) {
|
|
195
|
+
this._worker = _worker;
|
|
196
|
+
this._defaults = _defaults;
|
|
197
|
+
this.triggerCharacters = [".", "("];
|
|
198
|
+
}
|
|
199
|
+
async provideCompletionItems(model, position) {
|
|
200
|
+
const worker = await this._worker(model.uri);
|
|
201
|
+
const context = this._defaults.getApiContextForModel(model.uri);
|
|
202
|
+
const completionList = await worker.doComplete(model.uri.toString(), fromPosition(position), context);
|
|
203
|
+
const wordInfo = model.getWordUntilPosition(position);
|
|
204
|
+
const wordRange = new Range(position.lineNumber, wordInfo.startColumn, position.lineNumber, wordInfo.endColumn);
|
|
205
|
+
const items = completionList.items.map((entry) => {
|
|
206
|
+
const item = {
|
|
207
|
+
label: entry.label,
|
|
208
|
+
insertText: entry.insertText || entry.label,
|
|
209
|
+
sortText: entry.sortText,
|
|
210
|
+
filterText: entry.filterText,
|
|
211
|
+
detail: entry.detail,
|
|
212
|
+
range: wordRange,
|
|
213
|
+
kind: toCompletionItemKind(entry.kind),
|
|
214
|
+
};
|
|
215
|
+
if (entry.textEdit) {
|
|
216
|
+
if (isInsertReplaceEdit(entry.textEdit)) {
|
|
217
|
+
item.range = {
|
|
218
|
+
insert: toRange(entry.textEdit.insert),
|
|
219
|
+
replace: toRange(entry.textEdit.replace),
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
else {
|
|
223
|
+
item.range = toRange(entry.textEdit.range);
|
|
224
|
+
}
|
|
225
|
+
item.insertText = entry.textEdit.newText;
|
|
226
|
+
}
|
|
227
|
+
if (entry.additionalTextEdits) {
|
|
228
|
+
item.additionalTextEdits = entry.additionalTextEdits.map(toTextEdit);
|
|
229
|
+
}
|
|
230
|
+
if (entry.insertTextFormat === main.exports.InsertTextFormat.Snippet) {
|
|
231
|
+
item.insertTextRules = languages.CompletionItemInsertTextRule.InsertAsSnippet;
|
|
232
|
+
}
|
|
233
|
+
if (entry.documentation) {
|
|
234
|
+
if (typeof entry.documentation === "string") {
|
|
235
|
+
item.documentation = entry.documentation;
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
item.documentation = {
|
|
239
|
+
supportThemeIcons: false,
|
|
240
|
+
value: entry.documentation.value,
|
|
241
|
+
supportHtml: true,
|
|
242
|
+
};
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
return item;
|
|
246
|
+
});
|
|
247
|
+
return {
|
|
248
|
+
incomplete: completionList.isIncomplete,
|
|
249
|
+
suggestions: items,
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
//#endregion
|
|
254
|
+
//#region Formatter
|
|
255
|
+
class FormattingProvider {
|
|
256
|
+
constructor(_worker, _defaults) {
|
|
257
|
+
this._worker = _worker;
|
|
258
|
+
this._defaults = _defaults;
|
|
259
|
+
}
|
|
260
|
+
async provideDocumentFormattingEdits(model) {
|
|
261
|
+
const worker = await this._worker(model.uri);
|
|
262
|
+
const context = this._defaults.getApiContextForModel(model.uri.toString());
|
|
263
|
+
const edits = await worker.doFormat(model.uri.toString(), context);
|
|
264
|
+
return edits.map((e) => ({ range: toRange(e.range), text: e.newText }));
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
//#endregion
|
|
268
|
+
|
|
269
|
+
export { CompletionProvider as C, DiagnosticsAdapter as D, FormattingProvider as F, toCompletionItemKind as t };
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* All material copyright Esri, All Rights Reserved, unless otherwise specified.
|
|
3
3
|
* See https://js.arcgis.com/4.31/esri/copyright.txt for details.
|
|
4
|
-
* v4.31.0-next.
|
|
4
|
+
* v4.31.0-next.11
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
7
|
-
import './
|
|
6
|
+
import { m as main, g as editor, z as languages, O as Emitter } from './language-defaults-base-77487def.js';
|
|
7
|
+
import { C as CompletionProvider, F as FormattingProvider, D as DiagnosticsAdapter } from './arcade-language-features-8274cdc7.js';
|
|
8
8
|
|
|
9
|
-
var
|
|
9
|
+
var V={False:"false",Null:"null",True:"true"},f={Break:"break",Continue:"continue",Else:"else",For:"for",From:"from",Function:"function",If:"if",Import:"import",Export:"export",In:"in",Return:"return",Var:"var",While:"while"},Ee=["++","--"],Je=["-","+","!","~"],Qe=["=","/=","*=","%=","+=","-="],Ze=["||","&&"],Lt=["|","&",">>","<<",">>>","^","==","!=","<","<=",">",">=","+","-","*","/","%"];var U=[[],[],[]];Ee.forEach(t=>U[t.length-1]?.push(t));Je.forEach(t=>U[t.length-1]?.push(t));Ze.forEach(t=>U[t.length-1]?.push(t));Qe.forEach(t=>U[t.length-1]?.push(t));Lt.forEach(t=>U[t.length-1]?.push(t));var ft=Object.values(f),gt=Object.values(V);gt.map(t=>({label:t,kind:main.exports.CompletionItemKind.Constant}));ft.map(t=>({label:t,kind:main.exports.CompletionItemKind.Keyword}));
|
|
10
10
|
|
|
11
11
|
const operators = [
|
|
12
12
|
"<=",
|
|
@@ -81,7 +81,7 @@ const arcadeMonarchLanguage = {
|
|
|
81
81
|
// builtinFunctions: [...arcadeService.FunctionNames],
|
|
82
82
|
// Arcade keywords. 'from' is a special case as we want to treat it as a keyword in
|
|
83
83
|
// import statement but as an identifer in var statement.
|
|
84
|
-
keywords:
|
|
84
|
+
keywords: ft.filter((k) => k !== "from"),
|
|
85
85
|
operators,
|
|
86
86
|
constants: ["true", "false", "null"],
|
|
87
87
|
// we include these common regular expressions
|
|
@@ -139,8 +139,8 @@ const arcadeMonarchLanguage = {
|
|
|
139
139
|
// delimiter: after number because of .\d floats
|
|
140
140
|
[/[;,.]/u, "delimiter"],
|
|
141
141
|
// strings
|
|
142
|
-
[/"([^"\\]|\\.)*$/u, "string.invalid"],
|
|
143
|
-
[/'([^'\\]|\\.)*$/u, "string.invalid"],
|
|
142
|
+
[/"([^"\\]|\\.)*$/u, "string.invalid"], // non-teminated string
|
|
143
|
+
[/'([^'\\]|\\.)*$/u, "string.invalid"], // non-teminated string
|
|
144
144
|
[/"/u, "string", "@string_double"],
|
|
145
145
|
[/'/u, "string", "@string_single"],
|
|
146
146
|
[/`/u, "string", "@string_backtick"],
|
|
@@ -216,266 +216,6 @@ const arcadeMonarchLanguage = {
|
|
|
216
216
|
},
|
|
217
217
|
};
|
|
218
218
|
|
|
219
|
-
//#region Diagnostic
|
|
220
|
-
class DiagnosticsAdapter {
|
|
221
|
-
constructor(_languageId, _worker, { defaults, diagnosticsService, }) {
|
|
222
|
-
this._languageId = _languageId;
|
|
223
|
-
this._worker = _worker;
|
|
224
|
-
this._disposables = [];
|
|
225
|
-
this._listener = new Map();
|
|
226
|
-
this._diagnosticsService = diagnosticsService;
|
|
227
|
-
this._defaults = defaults;
|
|
228
|
-
const onModelAdd = (model) => {
|
|
229
|
-
const languageId = model.getLanguageId();
|
|
230
|
-
if (languageId !== this._languageId) {
|
|
231
|
-
return;
|
|
232
|
-
}
|
|
233
|
-
const debouncedValidate = debounce(() => {
|
|
234
|
-
this._doValidate(model, languageId).catch((err) => {
|
|
235
|
-
throw err;
|
|
236
|
-
});
|
|
237
|
-
});
|
|
238
|
-
this._listener.set(model.uri.toString(), model.onDidChangeContent(debouncedValidate));
|
|
239
|
-
this._doValidate(model, languageId).catch(console.error);
|
|
240
|
-
};
|
|
241
|
-
const onModelRemoved = (model) => {
|
|
242
|
-
const uriStr = model.uri.toString();
|
|
243
|
-
editor.setModelMarkers(model, this._languageId, []);
|
|
244
|
-
const listener = this._listener.get(uriStr);
|
|
245
|
-
if (listener) {
|
|
246
|
-
listener.dispose();
|
|
247
|
-
this._listener.delete(uriStr);
|
|
248
|
-
}
|
|
249
|
-
};
|
|
250
|
-
this._disposables.push(editor.onDidCreateModel(onModelAdd));
|
|
251
|
-
this._disposables.push(editor.onWillDisposeModel((model) => {
|
|
252
|
-
onModelRemoved(model);
|
|
253
|
-
}));
|
|
254
|
-
this._disposables.push(editor.onDidChangeModelLanguage((event) => {
|
|
255
|
-
onModelRemoved(event.model);
|
|
256
|
-
onModelAdd(event.model);
|
|
257
|
-
}));
|
|
258
|
-
this._disposables.push(defaults.onDidChange(() => {
|
|
259
|
-
editor.getModels().forEach((model) => {
|
|
260
|
-
if (model.getLanguageId() === this._languageId) {
|
|
261
|
-
onModelRemoved(model);
|
|
262
|
-
onModelAdd(model);
|
|
263
|
-
}
|
|
264
|
-
});
|
|
265
|
-
}));
|
|
266
|
-
this._disposables.push(defaults.onModelContextDidChange((key) => {
|
|
267
|
-
editor.getModels().forEach((model) => {
|
|
268
|
-
if (model.getLanguageId() === this._languageId && model.uri.toString() === key) {
|
|
269
|
-
this._doValidate(model, this._languageId).catch(console.error);
|
|
270
|
-
}
|
|
271
|
-
});
|
|
272
|
-
}));
|
|
273
|
-
this._disposables.push({
|
|
274
|
-
dispose: () => {
|
|
275
|
-
this._listener.forEach((value) => value.dispose());
|
|
276
|
-
this._listener.clear();
|
|
277
|
-
},
|
|
278
|
-
});
|
|
279
|
-
editor.getModels().forEach(onModelAdd);
|
|
280
|
-
}
|
|
281
|
-
dispose() {
|
|
282
|
-
this._disposables.forEach((d) => d.dispose());
|
|
283
|
-
this._disposables = [];
|
|
284
|
-
}
|
|
285
|
-
async _doValidate(model, languageId) {
|
|
286
|
-
if (!model.isAttachedToEditor()) {
|
|
287
|
-
return;
|
|
288
|
-
}
|
|
289
|
-
try {
|
|
290
|
-
const workerProxy = await this._worker(model.uri);
|
|
291
|
-
const context = this._defaults.getApiContextForModel(model.uri);
|
|
292
|
-
const diagnostics = await workerProxy.doValidation(model.uri.toString(), context);
|
|
293
|
-
const markers = diagnostics.map((d) => toMarker(model.uri, d));
|
|
294
|
-
this._diagnosticsService.fireDiagnosticsChange(model.uri, diagnostics);
|
|
295
|
-
editor.setModelMarkers(model, languageId, markers);
|
|
296
|
-
}
|
|
297
|
-
catch (err) {
|
|
298
|
-
console.error(err);
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
function toSeverity(languageServiceSeverity) {
|
|
303
|
-
switch (languageServiceSeverity) {
|
|
304
|
-
case main.DiagnosticSeverity.Error:
|
|
305
|
-
return MarkerSeverity.Error;
|
|
306
|
-
case main.DiagnosticSeverity.Warning:
|
|
307
|
-
return MarkerSeverity.Warning;
|
|
308
|
-
case main.DiagnosticSeverity.Information:
|
|
309
|
-
return MarkerSeverity.Info;
|
|
310
|
-
case main.DiagnosticSeverity.Hint:
|
|
311
|
-
return MarkerSeverity.Hint;
|
|
312
|
-
default:
|
|
313
|
-
return MarkerSeverity.Info;
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
function toMarker(_resource, diag) {
|
|
317
|
-
// Diagnostics positions are zero-based, MarkerData are 1-based
|
|
318
|
-
return {
|
|
319
|
-
severity: toSeverity(diag.severity),
|
|
320
|
-
startLineNumber: diag.range.start.line + 1,
|
|
321
|
-
startColumn: diag.range.start.character + 1,
|
|
322
|
-
endLineNumber: diag.range.end.line + 1,
|
|
323
|
-
endColumn: diag.range.end.character + 1,
|
|
324
|
-
message: diag.message,
|
|
325
|
-
};
|
|
326
|
-
}
|
|
327
|
-
//#endregion
|
|
328
|
-
//#region Completion
|
|
329
|
-
function fromPosition(position) {
|
|
330
|
-
// Language service is zero based
|
|
331
|
-
return { character: position.column - 1, line: position.lineNumber - 1 };
|
|
332
|
-
}
|
|
333
|
-
function toRange(range) {
|
|
334
|
-
return new Range(range.start.line + 1, range.start.character + 1, range.end.line + 1, range.end.character + 1);
|
|
335
|
-
}
|
|
336
|
-
function toTextEdit(textEdit) {
|
|
337
|
-
return {
|
|
338
|
-
range: toRange(textEdit.range),
|
|
339
|
-
text: textEdit.newText,
|
|
340
|
-
};
|
|
341
|
-
}
|
|
342
|
-
function isInsertReplaceEdit(edit) {
|
|
343
|
-
return (typeof edit.insert !== "undefined" &&
|
|
344
|
-
typeof edit.replace !== "undefined");
|
|
345
|
-
}
|
|
346
|
-
function toCompletionItemKind(kind) {
|
|
347
|
-
const mItemKind = languages.CompletionItemKind;
|
|
348
|
-
switch (kind) {
|
|
349
|
-
case main.CompletionItemKind.Text:
|
|
350
|
-
return mItemKind.Text;
|
|
351
|
-
case main.CompletionItemKind.Method:
|
|
352
|
-
return mItemKind.Method;
|
|
353
|
-
case main.CompletionItemKind.Function:
|
|
354
|
-
return mItemKind.Function;
|
|
355
|
-
case main.CompletionItemKind.Constructor:
|
|
356
|
-
return mItemKind.Constructor;
|
|
357
|
-
case main.CompletionItemKind.Field:
|
|
358
|
-
return mItemKind.Field;
|
|
359
|
-
case main.CompletionItemKind.Variable:
|
|
360
|
-
return mItemKind.Variable;
|
|
361
|
-
case main.CompletionItemKind.Class:
|
|
362
|
-
return mItemKind.Class;
|
|
363
|
-
case main.CompletionItemKind.Interface:
|
|
364
|
-
return mItemKind.Interface;
|
|
365
|
-
case main.CompletionItemKind.Module:
|
|
366
|
-
return mItemKind.Module;
|
|
367
|
-
case main.CompletionItemKind.Property:
|
|
368
|
-
return mItemKind.Property;
|
|
369
|
-
case main.CompletionItemKind.Unit:
|
|
370
|
-
return mItemKind.Unit;
|
|
371
|
-
case main.CompletionItemKind.Value:
|
|
372
|
-
return mItemKind.Value;
|
|
373
|
-
case main.CompletionItemKind.Enum:
|
|
374
|
-
return mItemKind.Enum;
|
|
375
|
-
case main.CompletionItemKind.Keyword:
|
|
376
|
-
return mItemKind.Keyword;
|
|
377
|
-
case main.CompletionItemKind.Snippet:
|
|
378
|
-
return mItemKind.Snippet;
|
|
379
|
-
case main.CompletionItemKind.Color:
|
|
380
|
-
return mItemKind.Color;
|
|
381
|
-
case main.CompletionItemKind.File:
|
|
382
|
-
return mItemKind.File;
|
|
383
|
-
case main.CompletionItemKind.Reference:
|
|
384
|
-
return mItemKind.Reference;
|
|
385
|
-
case main.CompletionItemKind.Folder:
|
|
386
|
-
return mItemKind.Folder;
|
|
387
|
-
case main.CompletionItemKind.EnumMember:
|
|
388
|
-
return mItemKind.EnumMember;
|
|
389
|
-
case main.CompletionItemKind.Constant:
|
|
390
|
-
return mItemKind.Constant;
|
|
391
|
-
case main.CompletionItemKind.Struct:
|
|
392
|
-
return mItemKind.Struct;
|
|
393
|
-
case main.CompletionItemKind.Event:
|
|
394
|
-
return mItemKind.Event;
|
|
395
|
-
case main.CompletionItemKind.Operator:
|
|
396
|
-
return mItemKind.Operator;
|
|
397
|
-
case main.CompletionItemKind.TypeParameter:
|
|
398
|
-
return mItemKind.TypeParameter;
|
|
399
|
-
default:
|
|
400
|
-
return mItemKind.Property;
|
|
401
|
-
}
|
|
402
|
-
}
|
|
403
|
-
class CompletionProvider {
|
|
404
|
-
constructor(_worker, _defaults) {
|
|
405
|
-
this._worker = _worker;
|
|
406
|
-
this._defaults = _defaults;
|
|
407
|
-
this.triggerCharacters = [".", "("];
|
|
408
|
-
}
|
|
409
|
-
async provideCompletionItems(model, position) {
|
|
410
|
-
const worker = await this._worker(model.uri);
|
|
411
|
-
const context = this._defaults.getApiContextForModel(model.uri);
|
|
412
|
-
const completionList = await worker.doComplete(model.uri.toString(), fromPosition(position), context);
|
|
413
|
-
const wordInfo = model.getWordUntilPosition(position);
|
|
414
|
-
const wordRange = new Range(position.lineNumber, wordInfo.startColumn, position.lineNumber, wordInfo.endColumn);
|
|
415
|
-
const items = completionList.items.map((entry) => {
|
|
416
|
-
const item = {
|
|
417
|
-
label: entry.label,
|
|
418
|
-
insertText: entry.insertText || entry.label,
|
|
419
|
-
sortText: entry.sortText,
|
|
420
|
-
filterText: entry.filterText,
|
|
421
|
-
detail: entry.detail,
|
|
422
|
-
range: wordRange,
|
|
423
|
-
kind: toCompletionItemKind(entry.kind),
|
|
424
|
-
};
|
|
425
|
-
if (entry.textEdit) {
|
|
426
|
-
if (isInsertReplaceEdit(entry.textEdit)) {
|
|
427
|
-
item.range = {
|
|
428
|
-
insert: toRange(entry.textEdit.insert),
|
|
429
|
-
replace: toRange(entry.textEdit.replace),
|
|
430
|
-
};
|
|
431
|
-
}
|
|
432
|
-
else {
|
|
433
|
-
item.range = toRange(entry.textEdit.range);
|
|
434
|
-
}
|
|
435
|
-
item.insertText = entry.textEdit.newText;
|
|
436
|
-
}
|
|
437
|
-
if (entry.additionalTextEdits) {
|
|
438
|
-
item.additionalTextEdits = entry.additionalTextEdits.map(toTextEdit);
|
|
439
|
-
}
|
|
440
|
-
if (entry.insertTextFormat === main.InsertTextFormat.Snippet) {
|
|
441
|
-
item.insertTextRules = languages.CompletionItemInsertTextRule.InsertAsSnippet;
|
|
442
|
-
}
|
|
443
|
-
if (entry.documentation) {
|
|
444
|
-
if (typeof entry.documentation === "string") {
|
|
445
|
-
item.documentation = entry.documentation;
|
|
446
|
-
}
|
|
447
|
-
else {
|
|
448
|
-
item.documentation = {
|
|
449
|
-
supportThemeIcons: false,
|
|
450
|
-
value: entry.documentation.value,
|
|
451
|
-
supportHtml: true,
|
|
452
|
-
};
|
|
453
|
-
}
|
|
454
|
-
}
|
|
455
|
-
return item;
|
|
456
|
-
});
|
|
457
|
-
return {
|
|
458
|
-
incomplete: completionList.isIncomplete,
|
|
459
|
-
suggestions: items,
|
|
460
|
-
};
|
|
461
|
-
}
|
|
462
|
-
}
|
|
463
|
-
//#endregion
|
|
464
|
-
//#region Formatter
|
|
465
|
-
class FormattingProvider {
|
|
466
|
-
constructor(_worker, _defaults) {
|
|
467
|
-
this._worker = _worker;
|
|
468
|
-
this._defaults = _defaults;
|
|
469
|
-
}
|
|
470
|
-
async provideDocumentFormattingEdits(model) {
|
|
471
|
-
const worker = await this._worker(model.uri);
|
|
472
|
-
const context = this._defaults.getApiContextForModel(model.uri.toString());
|
|
473
|
-
const edits = await worker.doFormat(model.uri.toString(), context);
|
|
474
|
-
return edits.map((e) => ({ range: toRange(e.range), text: e.newText }));
|
|
475
|
-
}
|
|
476
|
-
}
|
|
477
|
-
//#endregion
|
|
478
|
-
|
|
479
219
|
/**
|
|
480
220
|
* Manager to create our arcade worker and client proxy
|
|
481
221
|
*/
|