@arcgis/coding-components 4.30.0 → 4.31.0-next.10
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/arcgis-coding-components/arcgis-coding-components.esm.js +3 -3
- 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/sql-expression-editor/api/sql-expression-api.t9n.en.json +735 -0
- package/dist/arcgis-coding-components/index.esm.js +3 -3
- package/dist/arcgis-coding-components/p-025fda85.js +6 -0
- package/dist/arcgis-coding-components/{p-b7981062.js → p-02cae55d.js} +4 -4
- package/dist/arcgis-coding-components/p-193ac44f.js +6 -0
- package/dist/arcgis-coding-components/{p-ed5c78ce.js → p-22253750.js} +2 -2
- package/dist/arcgis-coding-components/p-4fc79a07.entry.js +6 -0
- package/dist/arcgis-coding-components/p-50484a4f.js +6 -0
- package/dist/arcgis-coding-components/p-6e28fd70.js +6 -0
- package/dist/arcgis-coding-components/p-7164c348.js +6 -0
- package/dist/arcgis-coding-components/p-767b17ee.entry.js +6 -0
- package/dist/arcgis-coding-components/{p-69ef969a.js → p-790067b1.js} +11 -11
- package/dist/arcgis-coding-components/{p-e9510c84.js → p-8196fa73.js} +3 -3
- package/dist/arcgis-coding-components/{p-f40fe9c5.js → p-8cf09bcc.js} +2 -2
- package/dist/arcgis-coding-components/{p-ca3f5530.js → p-923858b5.js} +3 -3
- package/dist/arcgis-coding-components/{p-ae0db715.js → p-960aa9dc.js} +3 -3
- package/dist/arcgis-coding-components/p-9956a574.js +6 -0
- package/dist/arcgis-coding-components/{p-9770fb37.js → p-ab78d6c4.js} +4 -4
- package/dist/arcgis-coding-components/{p-e37595ba.js → p-ad75160d.js} +4 -4
- package/dist/arcgis-coding-components/{p-24fb1d11.js → p-da9431ba.js} +3 -3
- package/dist/arcgis-coding-components/p-f452d4b8.entry.js +6 -0
- package/dist/cjs/{app-globals-18ba6880.js → app-globals-bade840e.js} +2 -2
- package/dist/cjs/arcade-defaults-8b8d6c07.js +116 -0
- package/dist/cjs/arcade-language-features-747fb1da.js +274 -0
- package/dist/cjs/arcade-mode-dce44622.js +336 -0
- package/dist/cjs/{arcgis-arcade-api_6.cjs.entry.js → arcgis-arcade-editor_6.cjs.entry.js} +3806 -5154
- package/dist/cjs/arcgis-coding-components.cjs.js +5 -5
- 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-d8a65bb9.js → css-077ba0c5.js} +2 -2
- package/dist/cjs/{cssMode-07dbb853.js → cssMode-7f2030db.js} +5 -5
- package/dist/cjs/{html-bb10cced.js → html-e3a243e9.js} +5 -5
- package/dist/cjs/{htmlMode-7df0a09d.js → htmlMode-c273d6dc.js} +5 -5
- package/dist/cjs/{index-15bcce7e.js → index-37a86ff4.js} +12 -4
- package/dist/cjs/index.cjs.js +5 -4
- package/dist/cjs/{javascript-f0dbed11.js → javascript-7a33cca7.js} +5 -5
- package/dist/cjs/{jsonMode-9e54e9b7.js → jsonMode-6b4e0850.js} +5 -5
- package/dist/cjs/{arcade-defaults-d0931224.js → language-defaults-base-b32cb091.js} +88 -144
- package/dist/cjs/loader.cjs.js +5 -5
- package/dist/cjs/sql-expr-defaults-8a5834f3.js +1280 -0
- package/dist/cjs/sql-expr-mode-a72a1f92.js +21838 -0
- package/dist/cjs/{tsMode-ca28bc5f.js → tsMode-c2edcd57.js} +6 -6
- package/dist/cjs/{typescript-39540ed7.js → typescript-c50c5516.js} +5 -5
- package/dist/components/arcade-defaults.js +47 -1537
- package/dist/components/arcade-language-features.js +271 -0
- package/dist/components/arcade-mode.js +7 -267
- package/dist/components/arcade-results.js +7 -7
- package/dist/components/arcade-suggestions.js +8 -8
- package/dist/components/arcade-variables.js +7 -7
- package/dist/components/arcgis-arcade-editor.js +49 -50
- package/dist/components/arcgis-arcade-results.js +2 -2
- package/dist/components/arcgis-arcade-suggestions.js +2 -2
- package/dist/components/arcgis-arcade-variables.js +2 -2
- package/dist/components/arcgis-assets.d.ts +2 -2
- package/dist/components/arcgis-assets.js +3 -3
- package/dist/components/arcgis-code-editor.js +2 -2
- 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 +186 -17
- package/dist/components/fields.js +3 -3
- package/dist/components/index.js +2 -2
- package/dist/components/index2.js +31 -23
- package/dist/components/{arcade-api.js → language-api-panel.js} +29 -60
- package/dist/components/language-defaults-base.js +1535 -0
- package/dist/components/markdown.js +3 -3
- package/dist/components/sql-expr-defaults.js +131 -0
- package/dist/components/sql-expr-mode.js +21836 -0
- package/dist/components/sql-expression-fields.js +102 -0
- package/dist/components/useT9n.js +46 -9
- package/dist/components/utilities.js +2 -2
- package/dist/esm/{app-globals-2a0e9afb.js → app-globals-ed47e16d.js} +2 -2
- package/dist/esm/arcade-defaults-562fe19b.js +111 -0
- package/dist/esm/arcade-language-features-8edb3527.js +269 -0
- package/dist/esm/{arcade-mode-e9728a63.js → arcade-mode-ad036f46.js} +7 -266
- package/dist/esm/{arcgis-arcade-api_6.entry.js → arcgis-arcade-editor_6.entry.js} +3793 -5141
- package/dist/esm/arcgis-coding-components.js +6 -6
- 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-61c794c2.js → css-810518f1.js} +2 -2
- package/dist/esm/{cssMode-6e0ccd51.js → cssMode-a7208024.js} +4 -4
- package/dist/esm/{html-44ad432e.js → html-e187d7d8.js} +4 -4
- package/dist/esm/{htmlMode-fd336434.js → htmlMode-06b7bae2.js} +4 -4
- package/dist/esm/{index-0d124a57.js → index-3743d31f.js} +12 -4
- package/dist/esm/index.js +5 -4
- package/dist/esm/{javascript-ac057954.js → javascript-04a3f866.js} +5 -5
- package/dist/esm/{jsonMode-ea8fa529.js → jsonMode-ee8bb2ea.js} +4 -4
- package/dist/esm/{arcade-defaults-811bdd4d.js → language-defaults-base-52a397f5.js} +82 -142
- package/dist/esm/loader.js +6 -6
- package/dist/esm/sql-expr-defaults-f7c2d5ef.js +1274 -0
- package/dist/esm/sql-expr-mode-433b4a39.js +21835 -0
- package/dist/esm/{tsMode-af9c3001.js → tsMode-c80c462e.js} +4 -4
- package/dist/esm/{typescript-baec45d6.js → typescript-a9b8caa7.js} +4 -4
- package/dist/loader/cdn.js +2 -2
- package/dist/loader/index.cjs.js +2 -2
- package/dist/loader/index.es2017.js +2 -2
- package/dist/loader/index.js +2 -2
- 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-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-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/language-defaults-base.d.ts +69 -0
- package/dist/types/utils/profile/predefined-profile.d.ts +3 -1
- package/dist/types/utils/profile/types.d.ts +29 -69
- package/dist/types/utils/profile/utils.d.ts +4 -7
- 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/types.d.ts +91 -0
- package/dist/types/utils/sql-expr-profile/predefined-profile.d.ts +2 -0
- package/package.json +23 -17
- package/dist/arcgis-coding-components/p-98cf909d.js +0 -6
- package/dist/arcgis-coding-components/p-bf047552.entry.js +0 -6
- package/dist/arcgis-coding-components/p-f602fc86.js +0 -6
- package/dist/cjs/arcade-mode-8424eafa.js +0 -595
- 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-2CDDVOQU.js +0 -1364
- 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/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.ca.json → language-api-panel/t9n/language-api-panel.t9n.ca.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
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* All material copyright Esri, All Rights Reserved, unless otherwise specified.
|
|
3
|
-
* See https://js.arcgis.com/4.
|
|
4
|
-
* v4.
|
|
3
|
+
* See https://js.arcgis.com/4.31/esri/copyright.txt for details.
|
|
4
|
+
* v4.31.0-next.10
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
7
|
-
import './
|
|
6
|
+
import { F as main, e as editor, u as languages, J as Emitter } from './language-defaults-base-52a397f5.js';
|
|
7
|
+
import { C as CompletionProvider, F as FormattingProvider, D as DiagnosticsAdapter } from './arcade-language-features-8edb3527.js';
|
|
8
|
+
import './index-3743d31f.js';
|
|
8
9
|
|
|
9
|
-
var
|
|
10
|
+
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
11
|
|
|
11
12
|
const operators = [
|
|
12
13
|
"<=",
|
|
@@ -81,7 +82,7 @@ const arcadeMonarchLanguage = {
|
|
|
81
82
|
// builtinFunctions: [...arcadeService.FunctionNames],
|
|
82
83
|
// Arcade keywords. 'from' is a special case as we want to treat it as a keyword in
|
|
83
84
|
// import statement but as an identifer in var statement.
|
|
84
|
-
keywords:
|
|
85
|
+
keywords: ft.filter((k) => k !== "from"),
|
|
85
86
|
operators,
|
|
86
87
|
constants: ["true", "false", "null"],
|
|
87
88
|
// we include these common regular expressions
|
|
@@ -216,266 +217,6 @@ const arcadeMonarchLanguage = {
|
|
|
216
217
|
},
|
|
217
218
|
};
|
|
218
219
|
|
|
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.exports.DiagnosticSeverity.Error:
|
|
305
|
-
return MarkerSeverity.Error;
|
|
306
|
-
case main.exports.DiagnosticSeverity.Warning:
|
|
307
|
-
return MarkerSeverity.Warning;
|
|
308
|
-
case main.exports.DiagnosticSeverity.Information:
|
|
309
|
-
return MarkerSeverity.Info;
|
|
310
|
-
case main.exports.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.exports.CompletionItemKind.Text:
|
|
350
|
-
return mItemKind.Text;
|
|
351
|
-
case main.exports.CompletionItemKind.Method:
|
|
352
|
-
return mItemKind.Method;
|
|
353
|
-
case main.exports.CompletionItemKind.Function:
|
|
354
|
-
return mItemKind.Function;
|
|
355
|
-
case main.exports.CompletionItemKind.Constructor:
|
|
356
|
-
return mItemKind.Constructor;
|
|
357
|
-
case main.exports.CompletionItemKind.Field:
|
|
358
|
-
return mItemKind.Field;
|
|
359
|
-
case main.exports.CompletionItemKind.Variable:
|
|
360
|
-
return mItemKind.Variable;
|
|
361
|
-
case main.exports.CompletionItemKind.Class:
|
|
362
|
-
return mItemKind.Class;
|
|
363
|
-
case main.exports.CompletionItemKind.Interface:
|
|
364
|
-
return mItemKind.Interface;
|
|
365
|
-
case main.exports.CompletionItemKind.Module:
|
|
366
|
-
return mItemKind.Module;
|
|
367
|
-
case main.exports.CompletionItemKind.Property:
|
|
368
|
-
return mItemKind.Property;
|
|
369
|
-
case main.exports.CompletionItemKind.Unit:
|
|
370
|
-
return mItemKind.Unit;
|
|
371
|
-
case main.exports.CompletionItemKind.Value:
|
|
372
|
-
return mItemKind.Value;
|
|
373
|
-
case main.exports.CompletionItemKind.Enum:
|
|
374
|
-
return mItemKind.Enum;
|
|
375
|
-
case main.exports.CompletionItemKind.Keyword:
|
|
376
|
-
return mItemKind.Keyword;
|
|
377
|
-
case main.exports.CompletionItemKind.Snippet:
|
|
378
|
-
return mItemKind.Snippet;
|
|
379
|
-
case main.exports.CompletionItemKind.Color:
|
|
380
|
-
return mItemKind.Color;
|
|
381
|
-
case main.exports.CompletionItemKind.File:
|
|
382
|
-
return mItemKind.File;
|
|
383
|
-
case main.exports.CompletionItemKind.Reference:
|
|
384
|
-
return mItemKind.Reference;
|
|
385
|
-
case main.exports.CompletionItemKind.Folder:
|
|
386
|
-
return mItemKind.Folder;
|
|
387
|
-
case main.exports.CompletionItemKind.EnumMember:
|
|
388
|
-
return mItemKind.EnumMember;
|
|
389
|
-
case main.exports.CompletionItemKind.Constant:
|
|
390
|
-
return mItemKind.Constant;
|
|
391
|
-
case main.exports.CompletionItemKind.Struct:
|
|
392
|
-
return mItemKind.Struct;
|
|
393
|
-
case main.exports.CompletionItemKind.Event:
|
|
394
|
-
return mItemKind.Event;
|
|
395
|
-
case main.exports.CompletionItemKind.Operator:
|
|
396
|
-
return mItemKind.Operator;
|
|
397
|
-
case main.exports.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.exports.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
220
|
/**
|
|
480
221
|
* Manager to create our arcade worker and client proxy
|
|
481
222
|
*/
|