@wemake4u/feel-editor 1.0.0

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 ADDED
@@ -0,0 +1,12 @@
1
+ # FeelEditor
2
+
3
+ The `FeelEditor` is an Angular wrapper for the [`@bpmn-io/feel-editor`](https://github.com/bpmn-io/feel-editor) component, providing a seamless integration of the FEEL expression editor into Angular applications.
4
+
5
+ This component enables users to:
6
+
7
+ - **Write and edit FEEL expressions** with syntax highlighting and autocompletion
8
+ - **Embed the FEEL editor** in Angular forms or custom UI layouts
9
+ - **Customize configuration options**, such as variables, input constraints, and theming
10
+ - **Handle change events** and validation state directly in Angular components
11
+
12
+ > Fully compatible with Angular reactive forms and validation workflows.
@@ -0,0 +1,222 @@
1
+ /// <reference path="../types/feel-editor.d.ts" />
2
+ import { Component, forwardRef, Input, Output, ViewChild, EventEmitter } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { ReactiveFormsModule } from '@angular/forms';
5
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
6
+ import FeelEditor from '@bpmn-io/feel-editor';
7
+ import { lineNumbers, EditorView } from '@codemirror/view';
8
+ import { keymap } from '@codemirror/view';
9
+ import { indentLess, indentMore } from '@codemirror/commands';
10
+ import * as state from '@codemirror/state';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/common";
13
+ export class FeelEditorComponent {
14
+ editorContainerRef;
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
+ }
63
+ get dialect() {
64
+ return this._dialect;
65
+ }
66
+ set dialect(value) {
67
+ if (this._dialect === value)
68
+ return;
69
+ this._dialect = value;
70
+ this.refreshEditor();
71
+ }
72
+ get builtins() {
73
+ return this._builtins;
74
+ }
75
+ set builtins(value) {
76
+ if (this._builtins === value)
77
+ return;
78
+ this._builtins = value;
79
+ this.refreshEditor();
80
+ }
81
+ get variables() {
82
+ return this._variables;
83
+ }
84
+ set variables(value) {
85
+ this._variables = value;
86
+ if (this._editor) {
87
+ this._editor.setVariables(value || []);
88
+ }
89
+ }
90
+ ngAfterViewInit() {
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
+ }
109
+ //#region Private Members
110
+ isViewInit = false;
111
+ _editor;
112
+ _value = '';
113
+ _readonly = false;
114
+ _disabled = false;
115
+ _lineNumbers = false;
116
+ _placeholder = "";
117
+ _dialect = "expression";
118
+ _builtins;
119
+ _variables;
120
+ onChange = (_) => { };
121
+ onTouched = () => { };
122
+ createEditor() {
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),
129
+ dialect: this.dialect,
130
+ value: this._value,
131
+ builtins: this._builtins,
132
+ variables: this._variables,
133
+ onChange: (value) => {
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.configureKeymap(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
+ configureKeymap(editor) {
156
+ if (!editor._cmEditor)
157
+ return;
158
+ const tabKeymap = 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(tabKeymap)
170
+ });
171
+ }
172
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
173
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FeelEditorComponent, isStandalone: true, selector: "feel-editor", inputs: { embedded: "embedded", minHeight: "minHeight", maxHeight: "maxHeight", disabled: "disabled", readonly: "readonly", lineNumbers: "lineNumbers", placeholder: "placeholder", value: "value", dialect: "dialect", builtins: "builtins", variables: "variables" }, outputs: { change: "change", keydown: "keydown", lint: "lint" }, providers: [
174
+ {
175
+ provide: NG_VALUE_ACCESSOR,
176
+ useExisting: forwardRef(() => FeelEditorComponent),
177
+ multi: true
178
+ }
179
+ ], 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 }] });
180
+ }
181
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, decorators: [{
182
+ type: Component,
183
+ args: [{ selector: 'feel-editor', standalone: true, imports: [CommonModule, ReactiveFormsModule], providers: [
184
+ {
185
+ provide: NG_VALUE_ACCESSOR,
186
+ useExisting: forwardRef(() => FeelEditorComponent),
187
+ multi: true
188
+ }
189
+ ], 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"] }]
190
+ }], propDecorators: { editorContainerRef: [{
191
+ type: ViewChild,
192
+ args: ['editorContainer', { static: true }]
193
+ }], change: [{
194
+ type: Output
195
+ }], keydown: [{
196
+ type: Output
197
+ }], lint: [{
198
+ type: Output
199
+ }], embedded: [{
200
+ type: Input
201
+ }], minHeight: [{
202
+ type: Input
203
+ }], maxHeight: [{
204
+ type: Input
205
+ }], disabled: [{
206
+ type: Input
207
+ }], readonly: [{
208
+ type: Input
209
+ }], lineNumbers: [{
210
+ type: Input
211
+ }], placeholder: [{
212
+ type: Input
213
+ }], value: [{
214
+ type: Input
215
+ }], dialect: [{
216
+ type: Input
217
+ }], builtins: [{
218
+ type: Input
219
+ }], variables: [{
220
+ type: Input
221
+ }] } });
222
+ //# 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 } 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.configureKeymap(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 configureKeymap(editor: any) {\r\n\r\n    if (!editor._cmEditor)\r\n      return;\r\n\r\n    const tabKeymap = 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(tabKeymap)\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"]}
@@ -0,0 +1,5 @@
1
+ /*
2
+ * Public API Surface of feel-editor
3
+ */
4
+ export * from './lib/components/feel-editor.component';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2ZlZWwtZWRpdG9yL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx3Q0FBd0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBmZWVsLWVkaXRvclxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZmVlbC1lZGl0b3IuY29tcG9uZW50JztcclxuIl19
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2VtYWtlNHUtZmVlbC1lZGl0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9mZWVsLWVkaXRvci9zcmMvd2VtYWtlNHUtZmVlbC1lZGl0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -0,0 +1,231 @@
1
+ import * as i0 from '@angular/core';
2
+ import { EventEmitter, forwardRef, Component, ViewChild, Output, Input } from '@angular/core';
3
+ import * as i1 from '@angular/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
6
+ import FeelEditor from '@bpmn-io/feel-editor';
7
+ import { lineNumbers, EditorView, keymap } from '@codemirror/view';
8
+ import { indentMore, indentLess } from '@codemirror/commands';
9
+ import * as state from '@codemirror/state';
10
+
11
+ /// <reference path="../types/feel-editor.d.ts" />
12
+ class FeelEditorComponent {
13
+ editorContainerRef;
14
+ change = new EventEmitter();
15
+ keydown = new EventEmitter();
16
+ lint = new EventEmitter();
17
+ embedded = false;
18
+ minHeight;
19
+ maxHeight;
20
+ get disabled() {
21
+ return this._disabled;
22
+ }
23
+ set disabled(value) {
24
+ if (this._disabled === value)
25
+ return;
26
+ this._disabled = value;
27
+ this.refreshEditor();
28
+ }
29
+ get readonly() {
30
+ return this._readonly;
31
+ }
32
+ set readonly(value) {
33
+ if (this._readonly === value)
34
+ return;
35
+ this._readonly = value;
36
+ this.refreshEditor();
37
+ }
38
+ get lineNumbers() {
39
+ return this._lineNumbers;
40
+ }
41
+ set lineNumbers(value) {
42
+ if (this._lineNumbers === value)
43
+ return;
44
+ this._lineNumbers = value;
45
+ this.refreshEditor();
46
+ }
47
+ get placeholder() {
48
+ return this._placeholder;
49
+ }
50
+ set placeholder(value) {
51
+ this._placeholder = value;
52
+ if (this._editor) {
53
+ this._editor.setPlaceholder(value);
54
+ }
55
+ }
56
+ get value() {
57
+ return this._value;
58
+ }
59
+ set value(value) {
60
+ this.writeValue(value);
61
+ }
62
+ get dialect() {
63
+ return this._dialect;
64
+ }
65
+ set dialect(value) {
66
+ if (this._dialect === value)
67
+ return;
68
+ this._dialect = value;
69
+ this.refreshEditor();
70
+ }
71
+ get builtins() {
72
+ return this._builtins;
73
+ }
74
+ set builtins(value) {
75
+ if (this._builtins === value)
76
+ return;
77
+ this._builtins = value;
78
+ this.refreshEditor();
79
+ }
80
+ get variables() {
81
+ return this._variables;
82
+ }
83
+ set variables(value) {
84
+ this._variables = value;
85
+ if (this._editor) {
86
+ this._editor.setVariables(value || []);
87
+ }
88
+ }
89
+ ngAfterViewInit() {
90
+ this.isViewInit = true;
91
+ this.createEditor();
92
+ }
93
+ writeValue(value) {
94
+ this._value = value || '';
95
+ if (this._editor) {
96
+ this._editor.setValue(this._value);
97
+ }
98
+ }
99
+ registerOnChange(fn) {
100
+ this.onChange = fn;
101
+ }
102
+ registerOnTouched(fn) {
103
+ this.onTouched = fn;
104
+ }
105
+ setDisabledState(isDisabled) {
106
+ this.disabled = isDisabled;
107
+ }
108
+ //#region Private Members
109
+ isViewInit = false;
110
+ _editor;
111
+ _value = '';
112
+ _readonly = false;
113
+ _disabled = false;
114
+ _lineNumbers = false;
115
+ _placeholder = "";
116
+ _dialect = "expression";
117
+ _builtins;
118
+ _variables;
119
+ onChange = (_) => { };
120
+ onTouched = () => { };
121
+ createEditor() {
122
+ if (!this.isViewInit || !this.editorContainerRef?.nativeElement)
123
+ return;
124
+ this._editor = new FeelEditor({
125
+ container: this.editorContainerRef.nativeElement,
126
+ placeholder: this._placeholder,
127
+ readOnly: (this._readonly || this._disabled),
128
+ dialect: this.dialect,
129
+ value: this._value,
130
+ builtins: this._builtins,
131
+ variables: this._variables,
132
+ onChange: (value) => {
133
+ this._value = value;
134
+ this.onChange(value);
135
+ this.change.emit(value);
136
+ },
137
+ onKeyDown: (event) => this.keydown.emit(event),
138
+ onLint: (issues) => this.lint.emit(issues),
139
+ extensions: [...(this._lineNumbers ? [lineNumbers()] : []), EditorView.lineWrapping],
140
+ });
141
+ this.configureKeymap(this._editor);
142
+ this.editorContainerRef?.nativeElement.classList.toggle('disabled', this._disabled);
143
+ }
144
+ destroyEditor() {
145
+ if (this._editor) {
146
+ this._editor = undefined;
147
+ this.editorContainerRef.nativeElement.innerHTML = '';
148
+ }
149
+ }
150
+ refreshEditor() {
151
+ this.destroyEditor();
152
+ this.createEditor();
153
+ }
154
+ configureKeymap(editor) {
155
+ if (!editor._cmEditor)
156
+ return;
157
+ const tabKeymap = keymap.of([
158
+ {
159
+ key: "Shift-+",
160
+ run: indentMore
161
+ },
162
+ {
163
+ key: "Shift--",
164
+ run: indentLess
165
+ }
166
+ ]);
167
+ editor._cmEditor.dispatch({
168
+ effects: state.StateEffect.appendConfig.of(tabKeymap)
169
+ });
170
+ }
171
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
172
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FeelEditorComponent, isStandalone: true, selector: "feel-editor", inputs: { embedded: "embedded", minHeight: "minHeight", maxHeight: "maxHeight", disabled: "disabled", readonly: "readonly", lineNumbers: "lineNumbers", placeholder: "placeholder", value: "value", dialect: "dialect", builtins: "builtins", variables: "variables" }, outputs: { change: "change", keydown: "keydown", lint: "lint" }, providers: [
173
+ {
174
+ provide: NG_VALUE_ACCESSOR,
175
+ useExisting: forwardRef(() => FeelEditorComponent),
176
+ multi: true
177
+ }
178
+ ], 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 }] });
179
+ }
180
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FeelEditorComponent, decorators: [{
181
+ type: Component,
182
+ args: [{ selector: 'feel-editor', standalone: true, imports: [CommonModule, ReactiveFormsModule], providers: [
183
+ {
184
+ provide: NG_VALUE_ACCESSOR,
185
+ useExisting: forwardRef(() => FeelEditorComponent),
186
+ multi: true
187
+ }
188
+ ], 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"] }]
189
+ }], propDecorators: { editorContainerRef: [{
190
+ type: ViewChild,
191
+ args: ['editorContainer', { static: true }]
192
+ }], change: [{
193
+ type: Output
194
+ }], keydown: [{
195
+ type: Output
196
+ }], lint: [{
197
+ type: Output
198
+ }], embedded: [{
199
+ type: Input
200
+ }], minHeight: [{
201
+ type: Input
202
+ }], maxHeight: [{
203
+ type: Input
204
+ }], disabled: [{
205
+ type: Input
206
+ }], readonly: [{
207
+ type: Input
208
+ }], lineNumbers: [{
209
+ type: Input
210
+ }], placeholder: [{
211
+ type: Input
212
+ }], value: [{
213
+ type: Input
214
+ }], dialect: [{
215
+ type: Input
216
+ }], builtins: [{
217
+ type: Input
218
+ }], variables: [{
219
+ type: Input
220
+ }] } });
221
+
222
+ /*
223
+ * Public API Surface of feel-editor
224
+ */
225
+
226
+ /**
227
+ * Generated bundle index. Do not edit.
228
+ */
229
+
230
+ export { FeelEditorComponent };
231
+ //# sourceMappingURL=wemake4u-feel-editor.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wemake4u-feel-editor.mjs","sources":["../../../projects/feel-editor/src/lib/components/feel-editor.component.ts","../../../projects/feel-editor/src/lib/components/feel-editor.component.html","../../../projects/feel-editor/src/public-api.ts","../../../projects/feel-editor/src/wemake4u-feel-editor.ts"],"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 } 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.configureKeymap(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 configureKeymap(editor: any) {\r\n\r\n if (!editor._cmEditor)\r\n return;\r\n\r\n const tabKeymap = 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(tabKeymap)\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","/*\r\n * Public API Surface of feel-editor\r\n */\r\n\r\nexport * from './lib/components/feel-editor.component';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ /// <amd-module name="@wemake4u/feel-editor" />
5
+ export * from './public-api';
@@ -0,0 +1,52 @@
1
+ import { AfterViewInit, ElementRef, EventEmitter } from '@angular/core';
2
+ import { ControlValueAccessor } from '@angular/forms';
3
+ import { FeelDialect, FeelBuiltin, FeelVariable } from '@bpmn-io/feel-editor';
4
+ import * as i0 from "@angular/core";
5
+ export declare class FeelEditorComponent implements ControlValueAccessor, AfterViewInit {
6
+ editorContainerRef: ElementRef;
7
+ change: EventEmitter<string>;
8
+ keydown: EventEmitter<KeyboardEvent>;
9
+ lint: EventEmitter<any[]>;
10
+ embedded: boolean;
11
+ minHeight?: string;
12
+ maxHeight?: string;
13
+ get disabled(): boolean;
14
+ set disabled(value: boolean);
15
+ get readonly(): boolean;
16
+ set readonly(value: boolean);
17
+ get lineNumbers(): boolean;
18
+ set lineNumbers(value: boolean);
19
+ get placeholder(): string;
20
+ set placeholder(value: string);
21
+ get value(): string;
22
+ set value(value: string);
23
+ get dialect(): FeelDialect;
24
+ set dialect(value: FeelDialect);
25
+ get builtins(): FeelBuiltin[] | undefined;
26
+ set builtins(value: FeelBuiltin[] | undefined);
27
+ get variables(): FeelVariable[] | undefined;
28
+ set variables(value: FeelVariable[] | undefined);
29
+ ngAfterViewInit(): void;
30
+ writeValue(value: string): void;
31
+ registerOnChange(fn: any): void;
32
+ registerOnTouched(fn: any): void;
33
+ setDisabledState(isDisabled: boolean): void;
34
+ private isViewInit;
35
+ private _editor?;
36
+ private _value;
37
+ private _readonly;
38
+ private _disabled;
39
+ private _lineNumbers;
40
+ private _placeholder;
41
+ private _dialect;
42
+ private _builtins;
43
+ private _variables;
44
+ private onChange;
45
+ onTouched: () => void;
46
+ private createEditor;
47
+ private destroyEditor;
48
+ private refreshEditor;
49
+ private configureKeymap;
50
+ static ɵfac: i0.ɵɵFactoryDeclaration<FeelEditorComponent, never>;
51
+ static ɵcmp: i0.ɵɵComponentDeclaration<FeelEditorComponent, "feel-editor", never, { "embedded": { "alias": "embedded"; "required": false; }; "minHeight": { "alias": "minHeight"; "required": false; }; "maxHeight": { "alias": "maxHeight"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "lineNumbers": { "alias": "lineNumbers"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "value": { "alias": "value"; "required": false; }; "dialect": { "alias": "dialect"; "required": false; }; "builtins": { "alias": "builtins"; "required": false; }; "variables": { "alias": "variables"; "required": false; }; }, { "change": "change"; "keydown": "keydown"; "lint": "lint"; }, never, never, true, never>;
52
+ }
package/package.json ADDED
@@ -0,0 +1,26 @@
1
+ {
2
+ "name": "@wemake4u/feel-editor",
3
+ "version": "1.0.0",
4
+ "peerDependencies": {
5
+ "@angular/common": "^18.2.0",
6
+ "@angular/core": "^18.2.0"
7
+ },
8
+ "dependencies": {
9
+ "tslib": "^2.3.0",
10
+ "@bpmn-io/feel-editor": "1.10.1"
11
+ },
12
+ "sideEffects": false,
13
+ "module": "fesm2022/wemake4u-feel-editor.mjs",
14
+ "typings": "index.d.ts",
15
+ "exports": {
16
+ "./package.json": {
17
+ "default": "./package.json"
18
+ },
19
+ ".": {
20
+ "types": "./index.d.ts",
21
+ "esm2022": "./esm2022/wemake4u-feel-editor.mjs",
22
+ "esm": "./esm2022/wemake4u-feel-editor.mjs",
23
+ "default": "./fesm2022/wemake4u-feel-editor.mjs"
24
+ }
25
+ }
26
+ }
@@ -0,0 +1 @@
1
+ export * from './lib/components/feel-editor.component';