@arcgis/coding-components 4.31.0-next.3 → 4.31.0-next.31
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/sql-expr.worker.js +447 -7
- package/dist/arcgis-coding-components/assets/language-api-panel/t9n/language-api-panel.t9n.ca.json +1 -1
- package/dist/arcgis-coding-components/index.esm.js +2 -2
- package/dist/arcgis-coding-components/p-18b2d2f5.js +7 -0
- package/dist/arcgis-coding-components/p-25183ed9.js +6 -0
- package/dist/arcgis-coding-components/{p-93d0e0cc.js → p-416666a0.js} +12 -12
- package/dist/arcgis-coding-components/p-536cdf7f.js +6 -0
- package/dist/arcgis-coding-components/{p-9132bc9c.entry.js → p-5c8677cf.entry.js} +2 -2
- package/dist/arcgis-coding-components/p-6e7ad639.js +6 -0
- package/dist/arcgis-coding-components/p-81152e8f.entry.js +6 -0
- package/dist/arcgis-coding-components/{p-86106a9a.js → p-983460ea.js} +1 -1
- package/dist/arcgis-coding-components/p-98f1e54e.js +6 -0
- package/dist/arcgis-coding-components/{p-111ba641.js → p-9c648939.js} +2 -2
- package/dist/arcgis-coding-components/{p-6554a853.js → p-9d4ed924.js} +1 -1
- package/dist/arcgis-coding-components/{p-7c6b3d40.js → p-b87b9e87.js} +2 -2
- package/dist/arcgis-coding-components/{p-3ca5ba95.entry.js → p-c61b56ec.entry.js} +2 -2
- package/dist/arcgis-coding-components/{p-4986aaf2.js → p-c66ece75.js} +3 -3
- package/dist/arcgis-coding-components/{p-42c8b545.js → p-c7d40b7a.js} +3 -3
- package/dist/arcgis-coding-components/p-e14e15c3.js +6 -0
- package/dist/arcgis-coding-components/{p-8b4298d5.js → p-ec21f417.js} +2 -2
- package/dist/arcgis-coding-components/{p-c4a5150e.js → p-f257c183.js} +3 -3
- package/dist/arcgis-coding-components/{p-5eb82abf.js → p-fc9f9713.js} +2 -2
- package/dist/cjs/{app-globals-92c5b499.js → app-globals-a4195754.js} +1 -1
- package/dist/cjs/arcade-defaults-eb4c386e.js +349 -0
- package/dist/cjs/arcade-language-features-443afb4a.js +274 -0
- package/dist/cjs/{arcade-mode-dfd66b4b.js → arcade-mode-b7f29ea1.js} +6 -266
- package/dist/cjs/arcgis-arcade-editor_6.cjs.entry.js +20 -26
- package/dist/cjs/arcgis-coding-components.cjs.js +5 -5
- package/dist/cjs/arcgis-sql-expression-editor.cjs.entry.js +4 -4
- package/dist/cjs/arcgis-sql-expression-fields.cjs.entry.js +4 -4
- package/dist/cjs/{css-9b0053c3.js → css-69196adc.js} +1 -1
- package/dist/cjs/{cssMode-62e53008.js → cssMode-859f4e51.js} +2 -3
- package/dist/cjs/{html-3036e89e.js → html-4fbc00a9.js} +2 -3
- package/dist/cjs/{htmlMode-c37eee42.js → htmlMode-a72d1bc1.js} +2 -3
- package/dist/cjs/{index-be6b2520.js → index-bdf3252c.js} +43 -15
- package/dist/cjs/index.cjs.js +4 -4
- package/dist/cjs/{javascript-7276c023.js → javascript-58361a1e.js} +3 -4
- package/dist/cjs/{jsonMode-baa295f0.js → jsonMode-193bd3e6.js} +2 -3
- package/dist/cjs/{language-defaults-base-5817af52.js → language-defaults-base-21562698.js} +842 -1062
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{sql-expr-defaults-746bbc5f.js → sql-expr-defaults-c60e217b.js} +101 -39
- package/dist/cjs/sql-expr-mode-d24b61b3.js +1171 -0
- package/dist/cjs/{tsMode-36398912.js → tsMode-7a15853a.js} +2 -3
- package/dist/cjs/{typescript-608a420b.js → typescript-f25eb5d3.js} +2 -3
- package/dist/components/arcade-defaults.js +238 -4
- package/dist/components/arcade-language-features.js +271 -0
- package/dist/components/arcade-mode.js +4 -264
- package/dist/components/arcade-results.js +3 -3
- package/dist/components/arcade-suggestions.js +2 -2
- package/dist/components/arcade-variables.js +2 -2
- package/dist/components/arcgis-arcade-editor.js +7 -6
- 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.js +1 -1
- package/dist/components/arcgis-sql-expression-editor.js +2 -2
- package/dist/components/arcgis-sql-expression-fields.js +1 -1
- package/dist/components/{chunk-6TARY3NN.js → chunk-EOMOY2EF.js} +12 -17
- package/dist/components/code-editor.js +16 -23
- package/dist/components/fields.js +22 -4
- package/dist/components/index.d.ts +18 -3
- package/dist/components/index.js +1 -1
- package/dist/components/index2.js +2 -2
- package/dist/components/language-api-panel.js +2 -2
- package/dist/components/language-defaults-base.js +81 -323
- package/dist/components/markdown.js +1 -1
- package/dist/components/sql-expr-defaults.js +89 -24
- package/dist/components/sql-expr-mode.js +1009 -24971
- package/dist/components/sql-expression-fields.js +2 -2
- package/dist/components/useT9n.js +2 -2
- package/dist/components/utilities.js +1 -1
- package/dist/esm/{app-globals-5e178541.js → app-globals-fe777f03.js} +1 -1
- package/dist/esm/arcade-defaults-59308750.js +344 -0
- package/dist/esm/arcade-language-features-bb595565.js +269 -0
- package/dist/esm/{arcade-mode-02336ce9.js → arcade-mode-ecfbfe83.js} +3 -263
- package/dist/esm/arcgis-arcade-editor_6.entry.js +21 -27
- package/dist/esm/arcgis-coding-components.js +6 -6
- package/dist/esm/arcgis-sql-expression-editor.entry.js +4 -4
- package/dist/esm/arcgis-sql-expression-fields.entry.js +4 -4
- package/dist/esm/{css-e79f1ed1.js → css-5d085688.js} +1 -1
- package/dist/esm/{cssMode-cd007d02.js → cssMode-ce6a5fa5.js} +2 -3
- package/dist/esm/{html-d079d00d.js → html-3bbdbcc4.js} +2 -3
- package/dist/esm/{htmlMode-ff14e035.js → htmlMode-ba97a916.js} +2 -3
- package/dist/esm/{index-88fc341d.js → index-c0152d8f.js} +43 -15
- package/dist/esm/index.js +4 -4
- package/dist/esm/{javascript-69f7c282.js → javascript-882d0f8e.js} +3 -4
- package/dist/esm/{jsonMode-18ddadde.js → jsonMode-81390da0.js} +2 -3
- package/dist/esm/{language-defaults-base-6687d11a.js → language-defaults-base-98463e74.js} +837 -1062
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{sql-expr-defaults-2cdfe08a.js → sql-expr-defaults-7dc678a7.js} +100 -40
- package/dist/esm/sql-expr-mode-3bee46a2.js +1167 -0
- package/dist/esm/{tsMode-c2e5d33a.js → tsMode-c62203dd.js} +2 -3
- package/dist/esm/{typescript-a0fbebf0.js → typescript-b12d65fd.js} +2 -3
- package/dist/loader/cdn.js +2 -3
- package/dist/loader/index.cjs.js +2 -3
- package/dist/loader/index.es2017.js +2 -3
- package/dist/loader/index.js +2 -3
- package/dist/types/components/arcade-editor/arcade-editor.d.ts +13 -3
- package/dist/types/components/arcade-results/arcade-results.d.ts +1 -1
- package/dist/types/components/arcade-suggestions/arcade-suggestions.d.ts +1 -1
- package/dist/types/components/arcade-variables/arcade-variables.d.ts +1 -1
- package/dist/types/components/code-editor/code-editor.d.ts +14 -4
- package/dist/types/components/language-api-panel/language-api-panel.d.ts +1 -1
- package/dist/types/components.d.ts +13 -13
- package/dist/types/data/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-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/stencil-public-runtime.d.ts +3 -8
- package/dist/types/utils/arcade-monaco/arcade-language-features.d.ts +1 -0
- package/dist/types/utils/arcade-monaco/arcade-profile-strategy.d.ts +9 -0
- package/dist/types/utils/fields.d.ts +2 -2
- 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/sql-expr-completion.d.ts +3 -2
- package/dist/types/utils/sql-expr-monaco/sql-expr-constants.d.ts +45 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-contribution.d.ts +1 -11
- package/dist/types/utils/sql-expr-monaco/sql-expr-defaults.d.ts +0 -1
- package/dist/types/utils/sql-expr-monaco/sql-expr-language-features.d.ts +19 -520
- package/dist/types/utils/sql-expr-monaco/sql-expr-mode.d.ts +34 -1
- package/dist/types/utils/sql-expr-monaco/sql-expr-service-accessors.d.ts +19 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-diagnostic-adapter.d.ts +0 -7
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-utils.d.ts +75 -77
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation.d.ts +5 -6
- package/dist/types/utils/sql-expr-monaco/sql-expr-worker-manager.d.ts +2 -0
- package/dist/types/utils/sql-expr-monaco/sql-expr.worker.d.ts +9 -6
- package/dist/types/utils/sql-expr-monaco/sql-expression-profile-strategy.d.ts +13 -0
- package/dist/types/utils/sql-expr-monaco/types.d.ts +6 -12
- package/package.json +19 -19
- package/dist/arcgis-coding-components/p-0105cc95.js +0 -6
- package/dist/arcgis-coding-components/p-5e26a360.js +0 -6
- package/dist/arcgis-coding-components/p-9c7e0089.js +0 -7
- package/dist/arcgis-coding-components/p-b82e98f0.js +0 -6
- package/dist/arcgis-coding-components/p-d353f1ba.entry.js +0 -6
- package/dist/arcgis-coding-components/p-fe6ccfe0.js +0 -6
- package/dist/cjs/arcade-defaults-34e82ff5.js +0 -116
- package/dist/cjs/sql-expr-mode-a9f1b697.js +0 -25135
- package/dist/esm/arcade-defaults-6dac6b30.js +0 -111
- package/dist/esm/polyfills/core-js.js +0 -11
- package/dist/esm/polyfills/dom.js +0 -79
- package/dist/esm/polyfills/es5-html-element.js +0 -1
- package/dist/esm/polyfills/index.js +0 -34
- package/dist/esm/polyfills/system.js +0 -6
- package/dist/esm/sql-expr-mode-f10e5a43.js +0 -25132
- package/dist/types/utils/profile/predefined-profile.d.ts +0 -4
- package/dist/types/utils/sql-expr-monaco/DependentFiles/DateOnly.d.ts +0 -41
- package/dist/types/utils/sql-expr-monaco/DependentFiles/SqlInterval.d.ts +0 -16
- package/dist/types/utils/sql-expr-monaco/DependentFiles/SqlTimestampOffset.d.ts +0 -26
- package/dist/types/utils/sql-expr-monaco/DependentFiles/TimeOnly.d.ts +0 -37
- package/dist/types/utils/sql-expr-monaco/DependentFiles/UnknownTimeZone.d.ts +0 -11
- package/dist/types/utils/sql-expr-monaco/DependentFiles/WhereGrammar.d.ts +0 -122
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlCompareUtils.d.ts +0 -5
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlDateParsingUtils.d.ts +0 -18
- package/dist/types/utils/sql-expr-monaco/DependentFiles/sqlUtils.d.ts +0 -6
- package/dist/types/utils/sql-expr-monaco/DependentFiles/standardizedFunctions.d.ts +0 -156
- package/dist/types/utils/sql-expr-monaco/DependentFiles/support.d.ts +0 -150
- package/dist/types/utils/sql-expr-monaco/PeggyGrammar/sql92grammar.d.ts +0 -1397
- package/dist/types/utils/sql-expr-monaco/libraries/date/properties/index.d.ts +0 -59
- package/dist/types/utils/sql-expr-monaco/libraries/numeric/properties/index.d.ts +0 -295
- package/dist/types/utils/sql-expr-monaco/libraries/string/properties/index.d.ts +0 -135
- package/dist/types/utils/sql-expr-monaco/sql-expr-validation-adapter.d.ts +0 -3
- package/dist/types/utils/sql-expr-profile/predefined-profile.d.ts +0 -2
|
@@ -1,10 +1,10 @@
|
|
|
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.31
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
7
|
-
import './
|
|
6
|
+
import { m as main, g as editor, z as languages, O as Emitter } from './language-defaults-base-98463e74.js';
|
|
7
|
+
import { C as CompletionProvider, F as FormattingProvider, D as DiagnosticsAdapter } from './arcade-language-features-bb595565.js';
|
|
8
8
|
|
|
9
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
|
|
|
@@ -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.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
219
|
/**
|
|
480
220
|
* Manager to create our arcade worker and client proxy
|
|
481
221
|
*/
|