@wemake4u/feel-editor 1.0.1 → 1.0.3
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 +6 -0
- package/THIRD_PARTY_LICENSES.txt +13 -0
- package/esm2022/lib/assets/builtins.json +506 -0
- package/esm2022/lib/components/feel-editor.component.mjs +34 -177
- package/esm2022/lib/utils/parseBuiltins.mjs +25 -0
- package/fesm2022/wemake4u-feel-editor.mjs +564 -175
- package/fesm2022/wemake4u-feel-editor.mjs.map +1 -1
- package/lib/components/feel-editor.component.d.ts +10 -43
- package/lib/utils/parseBuiltins.d.ts +9 -0
- package/package.json +4 -2
|
@@ -1,65 +1,14 @@
|
|
|
1
1
|
/// <reference path="../types/feel-editor.d.ts" />
|
|
2
|
-
import { Component,
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { ReactiveFormsModule } from '@angular/forms';
|
|
5
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
6
5
|
import FeelEditor from '@bpmn-io/feel-editor';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import { indentLess, indentMore, history, historyKeymap } from '@codemirror/commands';
|
|
10
|
-
import * as state from '@codemirror/state';
|
|
6
|
+
import { getDefaultBuiltins } from '../utils/parseBuiltins';
|
|
7
|
+
import { CodeEditorComponent, createValueAccessorProvider } from '@wemake4u/code-editor';
|
|
11
8
|
import * as i0 from "@angular/core";
|
|
12
9
|
import * as i1 from "@angular/common";
|
|
13
|
-
export class FeelEditorComponent {
|
|
14
|
-
|
|
15
|
-
change = new EventEmitter();
|
|
16
|
-
keydown = new EventEmitter();
|
|
17
|
-
lint = new EventEmitter();
|
|
18
|
-
embedded = false;
|
|
19
|
-
minHeight;
|
|
20
|
-
maxHeight;
|
|
21
|
-
get disabled() {
|
|
22
|
-
return this._disabled;
|
|
23
|
-
}
|
|
24
|
-
set disabled(value) {
|
|
25
|
-
if (this._disabled === value)
|
|
26
|
-
return;
|
|
27
|
-
this._disabled = value;
|
|
28
|
-
this.refreshEditor();
|
|
29
|
-
}
|
|
30
|
-
get readonly() {
|
|
31
|
-
return this._readonly;
|
|
32
|
-
}
|
|
33
|
-
set readonly(value) {
|
|
34
|
-
if (this._readonly === value)
|
|
35
|
-
return;
|
|
36
|
-
this._readonly = value;
|
|
37
|
-
this.refreshEditor();
|
|
38
|
-
}
|
|
39
|
-
get lineNumbers() {
|
|
40
|
-
return this._lineNumbers;
|
|
41
|
-
}
|
|
42
|
-
set lineNumbers(value) {
|
|
43
|
-
if (this._lineNumbers === value)
|
|
44
|
-
return;
|
|
45
|
-
this._lineNumbers = value;
|
|
46
|
-
this.refreshEditor();
|
|
47
|
-
}
|
|
48
|
-
get placeholder() {
|
|
49
|
-
return this._placeholder;
|
|
50
|
-
}
|
|
51
|
-
set placeholder(value) {
|
|
52
|
-
this._placeholder = value;
|
|
53
|
-
if (this._editor) {
|
|
54
|
-
this._editor.setPlaceholder(value);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
get value() {
|
|
58
|
-
return this._value;
|
|
59
|
-
}
|
|
60
|
-
set value(value) {
|
|
61
|
-
this.writeValue(value);
|
|
62
|
-
}
|
|
10
|
+
export class FeelEditorComponent extends CodeEditorComponent {
|
|
11
|
+
//#region dialect
|
|
63
12
|
get dialect() {
|
|
64
13
|
return this._dialect;
|
|
65
14
|
}
|
|
@@ -69,6 +18,8 @@ export class FeelEditorComponent {
|
|
|
69
18
|
this._dialect = value;
|
|
70
19
|
this.refreshEditor();
|
|
71
20
|
}
|
|
21
|
+
//#endregion
|
|
22
|
+
//#region builtins
|
|
72
23
|
get builtins() {
|
|
73
24
|
return this._builtins;
|
|
74
25
|
}
|
|
@@ -78,149 +29,55 @@ export class FeelEditorComponent {
|
|
|
78
29
|
this._builtins = value;
|
|
79
30
|
this.refreshEditor();
|
|
80
31
|
}
|
|
32
|
+
getBuiltins() {
|
|
33
|
+
if (Array.isArray(this._builtins)) {
|
|
34
|
+
return [...getDefaultBuiltins(), ...this._builtins];
|
|
35
|
+
}
|
|
36
|
+
return this._builtins;
|
|
37
|
+
}
|
|
38
|
+
//#endregion
|
|
39
|
+
//#region variables
|
|
81
40
|
get variables() {
|
|
82
41
|
return this._variables;
|
|
83
42
|
}
|
|
84
43
|
set variables(value) {
|
|
85
44
|
this._variables = value;
|
|
86
|
-
if (this.
|
|
87
|
-
this.
|
|
45
|
+
if (this._feelEditor) {
|
|
46
|
+
this._feelEditor.setVariables(value || []);
|
|
88
47
|
}
|
|
89
48
|
}
|
|
90
|
-
|
|
91
|
-
this.isViewInit = true;
|
|
92
|
-
this.createEditor();
|
|
93
|
-
}
|
|
94
|
-
writeValue(value) {
|
|
95
|
-
this._value = value || '';
|
|
96
|
-
if (this._editor) {
|
|
97
|
-
this._editor.setValue(this._value);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
registerOnChange(fn) {
|
|
101
|
-
this.onChange = fn;
|
|
102
|
-
}
|
|
103
|
-
registerOnTouched(fn) {
|
|
104
|
-
this.onTouched = fn;
|
|
105
|
-
}
|
|
106
|
-
setDisabledState(isDisabled) {
|
|
107
|
-
this.disabled = isDisabled;
|
|
108
|
-
}
|
|
49
|
+
//#endregion
|
|
109
50
|
//#region Private Members
|
|
110
|
-
|
|
111
|
-
_editor;
|
|
112
|
-
_value = '';
|
|
113
|
-
_readonly = false;
|
|
114
|
-
_disabled = false;
|
|
115
|
-
_lineNumbers = false;
|
|
116
|
-
_placeholder = "";
|
|
51
|
+
_feelEditor;
|
|
117
52
|
_dialect = "expression";
|
|
118
53
|
_builtins;
|
|
119
54
|
_variables;
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
if (!this.isViewInit || !this.editorContainerRef?.nativeElement)
|
|
124
|
-
return;
|
|
125
|
-
this._editor = new FeelEditor({
|
|
126
|
-
container: this.editorContainerRef.nativeElement,
|
|
127
|
-
placeholder: this._placeholder,
|
|
128
|
-
readOnly: (this._readonly || this._disabled),
|
|
55
|
+
createEditorView(container) {
|
|
56
|
+
this._feelEditor = new FeelEditor({
|
|
57
|
+
container: container,
|
|
129
58
|
dialect: this.dialect,
|
|
130
|
-
value: this.
|
|
131
|
-
builtins: this.
|
|
132
|
-
variables: this._variables,
|
|
133
|
-
|
|
134
|
-
this._value = value;
|
|
135
|
-
this.onChange(value);
|
|
136
|
-
this.change.emit(value);
|
|
137
|
-
},
|
|
138
|
-
onKeyDown: (event) => this.keydown.emit(event),
|
|
139
|
-
onLint: (issues) => this.lint.emit(issues),
|
|
140
|
-
extensions: [...(this._lineNumbers ? [lineNumbers()] : []), EditorView.lineWrapping],
|
|
141
|
-
});
|
|
142
|
-
this.configureEditor(this._editor);
|
|
143
|
-
this.editorContainerRef?.nativeElement.classList.toggle('disabled', this._disabled);
|
|
144
|
-
}
|
|
145
|
-
destroyEditor() {
|
|
146
|
-
if (this._editor) {
|
|
147
|
-
this._editor = undefined;
|
|
148
|
-
this.editorContainerRef.nativeElement.innerHTML = '';
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
refreshEditor() {
|
|
152
|
-
this.destroyEditor();
|
|
153
|
-
this.createEditor();
|
|
154
|
-
}
|
|
155
|
-
configureEditor(editor) {
|
|
156
|
-
if (!editor._cmEditor)
|
|
157
|
-
return;
|
|
158
|
-
const customKeymap = keymap.of([
|
|
159
|
-
{
|
|
160
|
-
key: "Shift-+",
|
|
161
|
-
run: indentMore
|
|
162
|
-
},
|
|
163
|
-
{
|
|
164
|
-
key: "Shift--",
|
|
165
|
-
run: indentLess
|
|
166
|
-
}
|
|
167
|
-
]);
|
|
168
|
-
editor._cmEditor.dispatch({
|
|
169
|
-
effects: state.StateEffect.appendConfig.of([
|
|
170
|
-
history(),
|
|
171
|
-
keymap.of(historyKeymap),
|
|
172
|
-
customKeymap
|
|
173
|
-
])
|
|
59
|
+
value: this.value,
|
|
60
|
+
builtins: this.getBuiltins() ?? undefined,
|
|
61
|
+
variables: this._variables ?? undefined,
|
|
62
|
+
extensions: this.getExtensions()
|
|
174
63
|
});
|
|
64
|
+
return this._feelEditor._cmEditor;
|
|
175
65
|
}
|
|
176
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, deps:
|
|
177
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FeelEditorComponent, isStandalone: true, selector: "feel-editor", inputs: {
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
useExisting: forwardRef(() => FeelEditorComponent),
|
|
181
|
-
multi: true
|
|
182
|
-
}
|
|
183
|
-
], viewQueries: [{ propertyName: "editorContainerRef", first: true, predicate: ["editorContainer"], descendants: true, static: true }], ngImport: i0, template: "<div #editorContainer\r\n class=\"feel-editor-container\"\r\n (blur)=\"onTouched()\"\r\n [ngClass]=\"embedded ? 'feel-editor-embedded' : 'feel-editor-standalone'\"\r\n [style.min-height]=\"minHeight\"\r\n [style.max-height]=\"maxHeight\">\r\n</div>\r\n", styles: [".feel-editor-container{height:100%;overflow-y:auto}.feel-editor-standalone{border:1px solid #ccc;padding:5px}.feel-editor-embedded{border:0px;padding:0}.feel-editor-container.disabled{pointer-events:none;opacity:.6}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
66
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FeelEditorComponent, isStandalone: true, selector: "feel-editor", inputs: { dialect: "dialect", builtins: "builtins", variables: "variables" }, providers: [
|
|
68
|
+
createValueAccessorProvider(FeelEditorComponent)
|
|
69
|
+
], usesInheritance: true, ngImport: i0, template: "<div #editorContainer\r\n class=\"feel-editor-container\"\r\n (blur)=\"onTouched()\"\r\n [ngClass]=\"embedded ? 'feel-editor-embedded' : 'feel-editor-standalone'\"\r\n [style.min-height]=\"minHeight\"\r\n [style.max-height]=\"maxHeight\">\r\n</div>\r\n", styles: [".feel-editor-container{height:100%;overflow-y:auto}.feel-editor-standalone{border:1px solid #ccc;padding:5px}.feel-editor-embedded{border:0px;padding:0}.feel-editor-container.disabled{pointer-events:none;opacity:.6}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
|
|
184
70
|
}
|
|
185
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, decorators: [{
|
|
186
72
|
type: Component,
|
|
187
73
|
args: [{ selector: 'feel-editor', standalone: true, imports: [CommonModule, ReactiveFormsModule], providers: [
|
|
188
|
-
|
|
189
|
-
provide: NG_VALUE_ACCESSOR,
|
|
190
|
-
useExisting: forwardRef(() => FeelEditorComponent),
|
|
191
|
-
multi: true
|
|
192
|
-
}
|
|
74
|
+
createValueAccessorProvider(FeelEditorComponent)
|
|
193
75
|
], template: "<div #editorContainer\r\n class=\"feel-editor-container\"\r\n (blur)=\"onTouched()\"\r\n [ngClass]=\"embedded ? 'feel-editor-embedded' : 'feel-editor-standalone'\"\r\n [style.min-height]=\"minHeight\"\r\n [style.max-height]=\"maxHeight\">\r\n</div>\r\n", styles: [".feel-editor-container{height:100%;overflow-y:auto}.feel-editor-standalone{border:1px solid #ccc;padding:5px}.feel-editor-embedded{border:0px;padding:0}.feel-editor-container.disabled{pointer-events:none;opacity:.6}\n"] }]
|
|
194
|
-
}], propDecorators: {
|
|
195
|
-
type: ViewChild,
|
|
196
|
-
args: ['editorContainer', { static: true }]
|
|
197
|
-
}], change: [{
|
|
198
|
-
type: Output
|
|
199
|
-
}], keydown: [{
|
|
200
|
-
type: Output
|
|
201
|
-
}], lint: [{
|
|
202
|
-
type: Output
|
|
203
|
-
}], embedded: [{
|
|
204
|
-
type: Input
|
|
205
|
-
}], minHeight: [{
|
|
206
|
-
type: Input
|
|
207
|
-
}], maxHeight: [{
|
|
208
|
-
type: Input
|
|
209
|
-
}], disabled: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], readonly: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], lineNumbers: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], placeholder: [{
|
|
216
|
-
type: Input
|
|
217
|
-
}], value: [{
|
|
218
|
-
type: Input
|
|
219
|
-
}], dialect: [{
|
|
76
|
+
}], propDecorators: { dialect: [{
|
|
220
77
|
type: Input
|
|
221
78
|
}], builtins: [{
|
|
222
79
|
type: Input
|
|
223
80
|
}], variables: [{
|
|
224
81
|
type: Input
|
|
225
82
|
}] } });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feel-editor.component.js","sourceRoot":"","sources":["../../../../../projects/feel-editor/src/lib/components/feel-editor.component.ts","../../../../../projects/feel-editor/src/lib/components/feel-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["/// <reference path=\"../types/feel-editor.d.ts\" />\r\n\r\nimport {\r\n  Component, forwardRef, Input, Output, AfterViewInit, ViewChild\r\n  , ElementRef, EventEmitter\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport FeelEditor, { FeelDialect, FeelBuiltin, FeelVariable } from '@bpmn-io/feel-editor';\r\nimport { lineNumbers, EditorView } from '@codemirror/view';\r\nimport { keymap } from '@codemirror/view';\r\nimport { indentLess, indentMore, history, historyKeymap } from '@codemirror/commands'\r\nimport * as state from '@codemirror/state';\r\n\r\n@Component({\r\n  selector: 'feel-editor',\r\n  templateUrl: './feel-editor.component.html',\r\n  styleUrls: ['./feel-editor.component.css'],\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => FeelEditorComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class FeelEditorComponent implements ControlValueAccessor, AfterViewInit {\r\n  @ViewChild('editorContainer', { static: true }) editorContainerRef!: ElementRef;\r\n\r\n  @Output() change = new EventEmitter<string>();\r\n  @Output() keydown = new EventEmitter<KeyboardEvent>();\r\n  @Output() lint = new EventEmitter<any[]>();\r\n\r\n  @Input() embedded: boolean = false;\r\n  @Input() minHeight?: string;\r\n  @Input() maxHeight?: string;\r\n\r\n  get disabled(): boolean {\r\n    return this._disabled;\r\n  }\r\n\r\n  @Input()\r\n  set disabled(value: boolean) {\r\n    if (this._disabled === value)\r\n      return;\r\n    this._disabled = value;\r\n    this.refreshEditor();\r\n  }\r\n\r\n  get readonly(): boolean {\r\n    return this._readonly;\r\n  }\r\n\r\n  @Input()\r\n  set readonly(value: boolean) {\r\n    if (this._readonly === value)\r\n      return;\r\n    this._readonly = value;\r\n    this.refreshEditor();\r\n  }\r\n\r\n  get lineNumbers(): boolean {\r\n    return this._lineNumbers;\r\n  }\r\n\r\n  @Input()\r\n  set lineNumbers(value: boolean) {\r\n    if (this._lineNumbers === value)\r\n      return;\r\n    this._lineNumbers = value;\r\n    this.refreshEditor();\r\n  }\r\n\r\n  get placeholder(): string {\r\n    return this._placeholder;\r\n  }\r\n\r\n  @Input()\r\n  set placeholder(value: string) {\r\n    this._placeholder = value;\r\n    if (this._editor) {\r\n      this._editor.setPlaceholder(value);\r\n    }\r\n  }\r\n\r\n  get value(): string {\r\n    return this._value;\r\n  }\r\n\r\n  @Input()\r\n  set value(value: string) {\r\n    this.writeValue(value);\r\n  }\r\n\r\n  get dialect(): FeelDialect {\r\n    return this._dialect;\r\n  }\r\n\r\n  @Input()\r\n  set dialect(value: FeelDialect) {\r\n    if (this._dialect === value)\r\n      return;\r\n    this._dialect = value;\r\n    this.refreshEditor();\r\n  }\r\n\r\n  get builtins(): FeelBuiltin[] | undefined {\r\n    return this._builtins;\r\n  }\r\n\r\n  @Input()\r\n  set builtins(value: FeelBuiltin[] | undefined) {\r\n    if (this._builtins === value)\r\n      return;    \r\n    this._builtins = value;\r\n    this.refreshEditor();\r\n  }\r\n\r\n  get variables(): FeelVariable[] | undefined {\r\n    return this._variables;\r\n  }\r\n\r\n  @Input()\r\n  set variables(value: FeelVariable[] | undefined) {\r\n    this._variables = value;\r\n    if (this._editor) {\r\n      this._editor.setVariables(value || []);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.isViewInit = true;\r\n    this.createEditor();    \r\n  }\r\n\r\n  writeValue(value: string): void {\r\n    this._value = value || '';\r\n    if (this._editor) {\r\n      this._editor.setValue(this._value);\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  //#region Private Members\r\n\r\n  private isViewInit = false;\r\n\r\n  private _editor?: FeelEditor;\r\n\r\n  private _value = '';\r\n\r\n  private _readonly: boolean = false;\r\n\r\n  private _disabled: boolean = false;\r\n\r\n  private _lineNumbers: boolean = false;\r\n\r\n  private _placeholder: string = \"\";\r\n\r\n  private _dialect: FeelDialect = \"expression\";\r\n\r\n  private _builtins: FeelBuiltin[] | undefined;\r\n\r\n  private _variables: FeelVariable[] | undefined;\r\n\r\n  private onChange = (_: any) => { };\r\n\r\n  public onTouched = () => { };\r\n\r\n  private createEditor(): void {\r\n    if (!this.isViewInit || !this.editorContainerRef?.nativeElement)\r\n      return;\r\n\r\n    this._editor = new FeelEditor({\r\n      container: this.editorContainerRef.nativeElement,\r\n      placeholder: this._placeholder,\r\n      readOnly: (this._readonly || this._disabled),\r\n      dialect: this.dialect,\r\n      value: this._value,\r\n      builtins: this._builtins,\r\n      variables: this._variables,\r\n      onChange: (value: string) => {\r\n        this._value = value;\r\n        this.onChange(value);\r\n        this.change.emit(value);\r\n      },\r\n      onKeyDown: (event: KeyboardEvent) => this.keydown.emit(event),\r\n      onLint: (issues: any[]) => this.lint.emit(issues),\r\n      extensions: [...(this._lineNumbers ? [lineNumbers()] : []), EditorView.lineWrapping],\r\n    });\r\n\r\n    this.configureEditor(this._editor);\r\n\r\n    this.editorContainerRef?.nativeElement.classList.toggle('disabled', this._disabled);\r\n  }\r\n\r\n  private destroyEditor(): void {\r\n    if (this._editor) {\r\n      this._editor = undefined;\r\n      this.editorContainerRef.nativeElement.innerHTML = '';\r\n    }    \r\n  }\r\n\r\n  private refreshEditor(): void {\r\n    this.destroyEditor();\r\n    this.createEditor();\r\n  }\r\n\r\n  private configureEditor(editor: any) {\r\n\r\n    if (!editor._cmEditor)\r\n      return;\r\n\r\n    const customKeymap = keymap.of([\r\n      {\r\n        key: \"Shift-+\",\r\n        run: indentMore\r\n      },\r\n      {\r\n        key: \"Shift--\",\r\n        run: indentLess\r\n      }\r\n    ]);\r\n\r\n    editor._cmEditor.dispatch({\r\n      effects: state.StateEffect.appendConfig.of([\r\n        history(),\r\n        keymap.of(historyKeymap),\r\n        customKeymap\r\n      ])\r\n    });\r\n  }\r\n\r\n  //#endregion\r\n}\r\n","<div #editorContainer\r\n     class=\"feel-editor-container\"\r\n     (blur)=\"onTouched()\"\r\n     [ngClass]=\"embedded ? 'feel-editor-embedded' : 'feel-editor-standalone'\"\r\n     [style.min-height]=\"minHeight\"\r\n     [style.max-height]=\"maxHeight\">\r\n</div>\r\n"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlbC1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZmVlbC1lZGl0b3Ivc3JjL2xpYi9jb21wb25lbnRzL2ZlZWwtZWRpdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZlZWwtZWRpdG9yL3NyYy9saWIvY29tcG9uZW50cy9mZWVsLWVkaXRvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxrREFBa0Q7QUFFbEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sVUFBc0QsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7O0FBWXpGLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxtQkFBbUI7SUFFMUQsaUJBQWlCO0lBRWpCLElBQUksT0FBTztRQUNULE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFDSSxPQUFPLENBQUMsS0FBa0I7UUFDNUIsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLEtBQUs7WUFDekIsT0FBTztRQUNULElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsWUFBWTtJQUVaLGtCQUFrQjtJQUVsQixJQUFJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQ0ksUUFBUSxDQUFDLEtBQXVDO1FBQ2xELElBQUksSUFBSSxDQUFDLFNBQVMsS0FBSyxLQUFLO1lBQzFCLE9BQU87UUFDVCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUN2QixJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVPLFdBQVc7UUFDakIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDO1lBQ2xDLE9BQU8sQ0FBQyxHQUFHLGtCQUFrQixFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDdEQsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsWUFBWTtJQUVaLG1CQUFtQjtJQUVuQixJQUFJLFNBQVM7UUFDWCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQ0ksU0FBUyxDQUFDLEtBQXdDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUMsQ0FBQztRQUM3QyxDQUFDO0lBQ0gsQ0FBQztJQUVELFlBQVk7SUFFWix5QkFBeUI7SUFFakIsV0FBVyxDQUFnQztJQUUzQyxRQUFRLEdBQWdCLFlBQVksQ0FBQztJQUVyQyxTQUFTLENBQW1DO0lBRTVDLFVBQVUsQ0FBb0M7SUFFN0MsZ0JBQWdCLENBQUMsU0FBYztRQUV0QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksVUFBVSxDQUFDO1lBQ2hDLFNBQVMsRUFBRSxTQUFTO1lBQ3BCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDakIsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxTQUFTO1lBQ3pDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxJQUFJLFNBQVM7WUFDdkMsVUFBVSxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUU7U0FDakMsQ0FBQyxDQUFDO1FBRUgsT0FBUSxJQUFJLENBQUMsV0FBbUIsQ0FBRSxTQUFTLENBQUM7SUFDOUMsQ0FBQzt3R0FoRlUsbUJBQW1COzRGQUFuQixtQkFBbUIsd0lBSm5CO1lBQ1QsMkJBQTJCLENBQUMsbUJBQW1CLENBQUM7U0FDakQsaURDakJILGtSQU9BLGtSRE9ZLFlBQVksNEhBQUUsbUJBQW1COzs0RkFLaEMsbUJBQW1CO2tCQVYvQixTQUFTOytCQUNFLGFBQWEsY0FHWCxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsbUJBQW1CLENBQUMsYUFDakM7d0JBQ1QsMkJBQTJCLHFCQUFxQjtxQkFDakQ7OEJBV0csT0FBTztzQkFEVixLQUFLO2dCQWlCRixRQUFRO3NCQURYLEtBQUs7Z0JBeUJGLFNBQVM7c0JBRFosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8vLyA8cmVmZXJlbmNlIHBhdGg9XCIuLi90eXBlcy9mZWVsLWVkaXRvci5kLnRzXCIgLz5cclxuXHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IEZlZWxFZGl0b3IsIHsgRmVlbERpYWxlY3QsIEZlZWxCdWlsdGluLCBGZWVsVmFyaWFibGUgfSBmcm9tICdAYnBtbi1pby9mZWVsLWVkaXRvcic7XHJcbmltcG9ydCB7IGdldERlZmF1bHRCdWlsdGlucyB9IGZyb20gJy4uL3V0aWxzL3BhcnNlQnVpbHRpbnMnO1xyXG5pbXBvcnQgeyBDb2RlRWRpdG9yQ29tcG9uZW50LCBjcmVhdGVWYWx1ZUFjY2Vzc29yUHJvdmlkZXIgfSBmcm9tICdAd2VtYWtlNHUvY29kZS1lZGl0b3InO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdmZWVsLWVkaXRvcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ZlZWwtZWRpdG9yLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9mZWVsLWVkaXRvci5jb21wb25lbnQuY3NzJ10sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIGNyZWF0ZVZhbHVlQWNjZXNzb3JQcm92aWRlcihGZWVsRWRpdG9yQ29tcG9uZW50KVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZlZWxFZGl0b3JDb21wb25lbnQgZXh0ZW5kcyBDb2RlRWRpdG9yQ29tcG9uZW50IHtcclxuXHJcbiAgLy8jcmVnaW9uIGRpYWxlY3RcclxuXHJcbiAgZ2V0IGRpYWxlY3QoKTogRmVlbERpYWxlY3Qge1xyXG4gICAgcmV0dXJuIHRoaXMuX2RpYWxlY3Q7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHNldCBkaWFsZWN0KHZhbHVlOiBGZWVsRGlhbGVjdCkge1xyXG4gICAgaWYgKHRoaXMuX2RpYWxlY3QgPT09IHZhbHVlKVxyXG4gICAgICByZXR1cm47XHJcbiAgICB0aGlzLl9kaWFsZWN0ID0gdmFsdWU7XHJcbiAgICB0aGlzLnJlZnJlc2hFZGl0b3IoKTtcclxuICB9XHJcblxyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gYnVpbHRpbnNcclxuXHJcbiAgZ2V0IGJ1aWx0aW5zKCk6IEZlZWxCdWlsdGluW10gfCBudWxsIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiB0aGlzLl9idWlsdGlucztcclxuICB9XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc2V0IGJ1aWx0aW5zKHZhbHVlOiBGZWVsQnVpbHRpbltdIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xyXG4gICAgaWYgKHRoaXMuX2J1aWx0aW5zID09PSB2YWx1ZSlcclxuICAgICAgcmV0dXJuO1xyXG4gICAgdGhpcy5fYnVpbHRpbnMgPSB2YWx1ZTtcclxuICAgIHRoaXMucmVmcmVzaEVkaXRvcigpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBnZXRCdWlsdGlucygpIHtcclxuICAgIGlmIChBcnJheS5pc0FycmF5KHRoaXMuX2J1aWx0aW5zKSkge1xyXG4gICAgICByZXR1cm4gWy4uLmdldERlZmF1bHRCdWlsdGlucygpLCAuLi50aGlzLl9idWlsdGluc107XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHRoaXMuX2J1aWx0aW5zO1xyXG4gIH1cclxuXHJcbiAgLy8jZW5kcmVnaW9uXHJcblxyXG4gIC8vI3JlZ2lvbiB2YXJpYWJsZXNcclxuXHJcbiAgZ2V0IHZhcmlhYmxlcygpOiBGZWVsVmFyaWFibGVbXSB8IG51bGwgfCB1bmRlZmluZWQge1xyXG4gICAgcmV0dXJuIHRoaXMuX3ZhcmlhYmxlcztcclxuICB9XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc2V0IHZhcmlhYmxlcyh2YWx1ZTogRmVlbFZhcmlhYmxlW10gfCBudWxsIHwgdW5kZWZpbmVkKSB7XHJcbiAgICB0aGlzLl92YXJpYWJsZXMgPSB2YWx1ZTtcclxuICAgIGlmICh0aGlzLl9mZWVsRWRpdG9yKSB7XHJcbiAgICAgIHRoaXMuX2ZlZWxFZGl0b3Iuc2V0VmFyaWFibGVzKHZhbHVlIHx8IFtdKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8vI2VuZHJlZ2lvblxyXG5cclxuICAvLyNyZWdpb24gUHJpdmF0ZSBNZW1iZXJzXHJcblxyXG4gIHByaXZhdGUgX2ZlZWxFZGl0b3I6IEZlZWxFZGl0b3IgfCBudWxsIHwgdW5kZWZpbmVkO1xyXG5cclxuICBwcml2YXRlIF9kaWFsZWN0OiBGZWVsRGlhbGVjdCA9IFwiZXhwcmVzc2lvblwiO1xyXG5cclxuICBwcml2YXRlIF9idWlsdGluczogRmVlbEJ1aWx0aW5bXSB8IG51bGwgfCB1bmRlZmluZWQ7XHJcblxyXG4gIHByaXZhdGUgX3ZhcmlhYmxlczogRmVlbFZhcmlhYmxlW10gfCBudWxsIHwgdW5kZWZpbmVkO1xyXG5cclxuICBvdmVycmlkZSBjcmVhdGVFZGl0b3JWaWV3KGNvbnRhaW5lcjogYW55KSB7XHJcblxyXG4gICAgdGhpcy5fZmVlbEVkaXRvciA9IG5ldyBGZWVsRWRpdG9yKHtcclxuICAgICAgY29udGFpbmVyOiBjb250YWluZXIsXHJcbiAgICAgIGRpYWxlY3Q6IHRoaXMuZGlhbGVjdCxcclxuICAgICAgdmFsdWU6IHRoaXMudmFsdWUsXHJcbiAgICAgIGJ1aWx0aW5zOiB0aGlzLmdldEJ1aWx0aW5zKCkgPz8gdW5kZWZpbmVkLFxyXG4gICAgICB2YXJpYWJsZXM6IHRoaXMuX3ZhcmlhYmxlcyA/PyB1bmRlZmluZWQsXHJcbiAgICAgIGV4dGVuc2lvbnM6IHRoaXMuZ2V0RXh0ZW5zaW9ucygpXHJcbiAgICB9KTtcclxuXHJcbiAgICByZXR1cm4gKHRoaXMuX2ZlZWxFZGl0b3IgYXMgYW55KSAuX2NtRWRpdG9yO1xyXG4gIH1cclxuXHJcbiAgLy8jZW5kcmVnaW9uXHJcbn1cclxuIiwiPGRpdiAjZWRpdG9yQ29udGFpbmVyXHJcbiAgICAgY2xhc3M9XCJmZWVsLWVkaXRvci1jb250YWluZXJcIlxyXG4gICAgIChibHVyKT1cIm9uVG91Y2hlZCgpXCJcclxuICAgICBbbmdDbGFzc109XCJlbWJlZGRlZCA/ICdmZWVsLWVkaXRvci1lbWJlZGRlZCcgOiAnZmVlbC1lZGl0b3Itc3RhbmRhbG9uZSdcIlxyXG4gICAgIFtzdHlsZS5taW4taGVpZ2h0XT1cIm1pbkhlaWdodFwiXHJcbiAgICAgW3N0eWxlLm1heC1oZWlnaHRdPVwibWF4SGVpZ2h0XCI+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { domify } from 'min-dom';
|
|
2
|
+
import defaultBuiltins from '../assets/builtins.json';
|
|
3
|
+
export function parseBuiltins(builtins) {
|
|
4
|
+
return builtins.map(parseBuiltin);
|
|
5
|
+
}
|
|
6
|
+
export function parseBuiltin(builtin) {
|
|
7
|
+
const { name, description } = builtin;
|
|
8
|
+
const match = name.match(/^([\w\s]+)\((.*)\)$/);
|
|
9
|
+
const functionName = match ? match[1] : "";
|
|
10
|
+
const functionArguments = match ? match[2] : "";
|
|
11
|
+
const params = functionArguments ? functionArguments.split(', ').map((name) => ({ name })) : [];
|
|
12
|
+
return {
|
|
13
|
+
name: functionName,
|
|
14
|
+
type: 'function',
|
|
15
|
+
params,
|
|
16
|
+
info: () => {
|
|
17
|
+
return domify(`<div class="description">${description}<div>`);
|
|
18
|
+
},
|
|
19
|
+
boost: 0
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export function getDefaultBuiltins() {
|
|
23
|
+
return parseBuiltins(defaultBuiltins);
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2VCdWlsdGlucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZlZWwtZWRpdG9yL3NyYy9saWIvdXRpbHMvcGFyc2VCdWlsdGlucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBRWpDLE9BQU8sZUFBZSxNQUFNLHlCQUF5QixDQUFDO0FBT3RELE1BQU0sVUFBVSxhQUFhLENBQUMsUUFBdUI7SUFDbkQsT0FBTyxRQUFRLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxDQUFDO0FBQ3BDLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLE9BQW9CO0lBRS9DLE1BQU0sRUFDSixJQUFJLEVBQ0osV0FBVyxFQUNaLEdBQUcsT0FBTyxDQUFDO0lBRVosTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDM0MsTUFBTSxpQkFBaUIsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQSxDQUFDLENBQUMsRUFBRSxDQUFDO0lBRS9DLE1BQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFFeEcsT0FBTztRQUNMLElBQUksRUFBRSxZQUFZO1FBQ2xCLElBQUksRUFBRSxVQUFVO1FBQ2hCLE1BQU07UUFDTixJQUFJLEVBQUUsR0FBRyxFQUFFO1lBQ1QsT0FBTyxNQUFNLENBQUMsNEJBQTRCLFdBQVcsT0FBTyxDQUFDLENBQUM7UUFDaEUsQ0FBQztRQUNELEtBQUssRUFBRSxDQUFDO0tBQ1QsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCO0lBQ2hDLE9BQU8sYUFBYSxDQUFDLGVBQWUsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkb21pZnkgfSBmcm9tICdtaW4tZG9tJztcclxuaW1wb3J0IHsgRmVlbEJ1aWx0aW4gfSBmcm9tICdAYnBtbi1pby9mZWVsLWVkaXRvcic7XHJcbmltcG9ydCBkZWZhdWx0QnVpbHRpbnMgZnJvbSAnLi4vYXNzZXRzL2J1aWx0aW5zLmpzb24nO1xyXG5cclxuaW50ZXJmYWNlIEJ1aWx0aW5JbmZvIHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgZGVzY3JpcHRpb246IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIHBhcnNlQnVpbHRpbnMoYnVpbHRpbnM6IEJ1aWx0aW5JbmZvW10pOiBGZWVsQnVpbHRpbltdIHtcclxuICByZXR1cm4gYnVpbHRpbnMubWFwKHBhcnNlQnVpbHRpbik7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBwYXJzZUJ1aWx0aW4oYnVpbHRpbjogQnVpbHRpbkluZm8pOiBGZWVsQnVpbHRpbiB7XHJcblxyXG4gIGNvbnN0IHtcclxuICAgIG5hbWUsXHJcbiAgICBkZXNjcmlwdGlvblxyXG4gIH0gPSBidWlsdGluO1xyXG5cclxuICBjb25zdCBtYXRjaCA9IG5hbWUubWF0Y2goL14oW1xcd1xcc10rKVxcKCguKilcXCkkLyk7XHJcbiAgY29uc3QgZnVuY3Rpb25OYW1lID0gbWF0Y2ggPyBtYXRjaFsxXSA6IFwiXCI7XHJcbiAgY29uc3QgZnVuY3Rpb25Bcmd1bWVudHMgPSBtYXRjaCA/IG1hdGNoWzJdOiBcIlwiO1xyXG5cclxuICBjb25zdCBwYXJhbXMgPSBmdW5jdGlvbkFyZ3VtZW50cyA/IGZ1bmN0aW9uQXJndW1lbnRzLnNwbGl0KCcsICcpLm1hcCgobmFtZTogc3RyaW5nKSA9PiAoeyBuYW1lIH0pKSA6IFtdO1xyXG5cclxuICByZXR1cm4ge1xyXG4gICAgbmFtZTogZnVuY3Rpb25OYW1lLFxyXG4gICAgdHlwZTogJ2Z1bmN0aW9uJyxcclxuICAgIHBhcmFtcyxcclxuICAgIGluZm86ICgpID0+IHtcclxuICAgICAgcmV0dXJuIGRvbWlmeShgPGRpdiBjbGFzcz1cImRlc2NyaXB0aW9uXCI+JHtkZXNjcmlwdGlvbn08ZGl2PmApO1xyXG4gICAgfSxcclxuICAgIGJvb3N0OiAwXHJcbiAgfTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGdldERlZmF1bHRCdWlsdGlucygpOiBGZWVsQnVpbHRpbltdIHtcclxuICByZXR1cm4gcGFyc2VCdWlsdGlucyhkZWZhdWx0QnVpbHRpbnMpO1xyXG59XHJcbiJdfQ==
|