myrta-ui 17.1.10 → 17.1.12
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/esm2022/lib/components/form/code-editor/code-editor.component.mjs +238 -0
- package/esm2022/lib/components/form/code-editor/code-editor.enum.mjs +2 -0
- package/esm2022/lib/components/form/code-editor/code-editor.module.mjs +28 -0
- package/esm2022/lib/components/form/code-editor/utils/codeeditoroptions.mjs +65 -0
- package/esm2022/lib/components/modal/modal.component.mjs +5 -7
- package/esm2022/lib/components/side-page/side-page.component.mjs +3 -3
- package/esm2022/lib/components/side-page/side-page.module.mjs +21 -5
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/myrta-ui.mjs +12035 -11965
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/form/code-editor/code-editor.component.d.ts +57 -0
- package/lib/components/form/code-editor/code-editor.enum.d.ts +5 -0
- package/lib/components/form/code-editor/code-editor.module.d.ts +10 -0
- package/lib/components/form/code-editor/utils/codeeditoroptions.d.ts +51 -0
- package/lib/components/side-page/side-page.module.d.ts +4 -2
- package/package.json +6 -2
- package/public-api.d.ts +4 -0
- package/esm2022/lib/myrta-ui.module.mjs +0 -322
- package/lib/myrta-ui.module.d.ts +0 -62
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
4
|
+
import { CodeEditorOptions } from "./utils/codeeditoroptions";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "ngx-monaco-editor-v2";
|
|
7
|
+
export class CodeEditorComponent {
|
|
8
|
+
_data = {};
|
|
9
|
+
_editor;
|
|
10
|
+
_debounceTimeout;
|
|
11
|
+
isFocused = false;
|
|
12
|
+
editorModel;
|
|
13
|
+
editorOptions;
|
|
14
|
+
uuid = uuidv4();
|
|
15
|
+
fields = [];
|
|
16
|
+
options = new CodeEditorOptions();
|
|
17
|
+
debug = false;
|
|
18
|
+
disabled = false;
|
|
19
|
+
set data(value) {
|
|
20
|
+
this._data = value;
|
|
21
|
+
if (this._editor) {
|
|
22
|
+
this._editor.destroy();
|
|
23
|
+
this.ngOnInit();
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
get data() {
|
|
27
|
+
return this._data;
|
|
28
|
+
}
|
|
29
|
+
changed = new EventEmitter();
|
|
30
|
+
modelChange = new EventEmitter();
|
|
31
|
+
jsonChange = new EventEmitter();
|
|
32
|
+
editorContainer;
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this._initializeEditor();
|
|
35
|
+
}
|
|
36
|
+
ngOnDestroy() {
|
|
37
|
+
this._destroyEditor();
|
|
38
|
+
this._clearDebounce();
|
|
39
|
+
}
|
|
40
|
+
onEditorInit(editor) {
|
|
41
|
+
this._editor = editor;
|
|
42
|
+
this.setDisabledState(this.disabled);
|
|
43
|
+
editor.onDidChangeModelContent(() => {
|
|
44
|
+
try {
|
|
45
|
+
const parsedValue = JSON.parse(editor.getValue());
|
|
46
|
+
this.updateValue(parsedValue);
|
|
47
|
+
this.jsonChange.emit(parsedValue);
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
if (this.debug) {
|
|
51
|
+
console.log(error);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
const debouncedUpdateHeight = this._debounce(() => this._updateEditorHeight(), 50);
|
|
56
|
+
editor.onDidChangeModelDecorations(() => {
|
|
57
|
+
debouncedUpdateHeight();
|
|
58
|
+
});
|
|
59
|
+
this._updateEditorHeight();
|
|
60
|
+
}
|
|
61
|
+
onChangeJSON = () => {
|
|
62
|
+
if (this._editor) {
|
|
63
|
+
try {
|
|
64
|
+
this.jsonChange.emit(this._editor.getValue());
|
|
65
|
+
}
|
|
66
|
+
catch (error) {
|
|
67
|
+
if (this.debug) {
|
|
68
|
+
console.log(error);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
onChange = () => {
|
|
74
|
+
if (this._editor) {
|
|
75
|
+
try {
|
|
76
|
+
const json = this._editor.getValue();
|
|
77
|
+
this.updateValue(json);
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
if (this.debug) {
|
|
81
|
+
console.log(error);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
focus() {
|
|
87
|
+
this._editor?.focus();
|
|
88
|
+
}
|
|
89
|
+
get() {
|
|
90
|
+
return this._editor?.getValue();
|
|
91
|
+
}
|
|
92
|
+
getText() {
|
|
93
|
+
return this._editor?.getText();
|
|
94
|
+
}
|
|
95
|
+
set(json) {
|
|
96
|
+
this._editor.setValue(json);
|
|
97
|
+
this._updateEditorHeight();
|
|
98
|
+
}
|
|
99
|
+
setSelection(start, end) {
|
|
100
|
+
if (!this._editor)
|
|
101
|
+
return;
|
|
102
|
+
const monaco = window.monaco;
|
|
103
|
+
if (monaco) {
|
|
104
|
+
this._editor.setSelection(new monaco.Range(start.line, start.column, end.line, end.column));
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
getSelection() {
|
|
108
|
+
return this._editor.getSelection();
|
|
109
|
+
}
|
|
110
|
+
setOptions(newOptions) {
|
|
111
|
+
this._destroyEditor();
|
|
112
|
+
this.options = newOptions;
|
|
113
|
+
this._initializeEditor();
|
|
114
|
+
}
|
|
115
|
+
destroy() {
|
|
116
|
+
this._destroyEditor();
|
|
117
|
+
}
|
|
118
|
+
getEditor() {
|
|
119
|
+
return this._editor;
|
|
120
|
+
}
|
|
121
|
+
isValidJson() {
|
|
122
|
+
try {
|
|
123
|
+
JSON.parse(this.getText());
|
|
124
|
+
return true;
|
|
125
|
+
}
|
|
126
|
+
catch (e) {
|
|
127
|
+
return false;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
setDisabledState(isDisabled) {
|
|
131
|
+
this.disabled = isDisabled;
|
|
132
|
+
this._editor?.updateOptions({ readOnly: isDisabled });
|
|
133
|
+
}
|
|
134
|
+
writeValue(value) {
|
|
135
|
+
this.data = value;
|
|
136
|
+
}
|
|
137
|
+
updateValue(insideValue) {
|
|
138
|
+
this.changed.emit(insideValue);
|
|
139
|
+
this.modelChange.emit({ value: insideValue, id: this.uuid });
|
|
140
|
+
this.onChangeFn(insideValue);
|
|
141
|
+
this.onTouchedFn();
|
|
142
|
+
}
|
|
143
|
+
registerOnChange(fn) {
|
|
144
|
+
this.onChangeFn = fn;
|
|
145
|
+
}
|
|
146
|
+
registerOnTouched(fn) {
|
|
147
|
+
this.onTouchedFn = fn;
|
|
148
|
+
}
|
|
149
|
+
_initializeEditor() {
|
|
150
|
+
this._updateEditorModel();
|
|
151
|
+
this._updateEditorOptions();
|
|
152
|
+
this.options.onChangeJSON = this.options.onChangeJSON || this.onChangeJSON;
|
|
153
|
+
this.options.onChange = this.options.onChange || this.onChange;
|
|
154
|
+
if (this.debug) {
|
|
155
|
+
console.log(this.options, this._data);
|
|
156
|
+
}
|
|
157
|
+
if (!this.editorContainer?.nativeElement) {
|
|
158
|
+
console.error(`Can't find the ElementRef reference for jsoneditor`);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
_updateEditorModel() {
|
|
162
|
+
const value = typeof this._data === 'string' ? this._data : JSON.stringify(this._data, null, 2);
|
|
163
|
+
this.editorModel = {
|
|
164
|
+
value: value,
|
|
165
|
+
language: this.options.language,
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
_updateEditorOptions() {
|
|
169
|
+
this.editorOptions = { ...this.options };
|
|
170
|
+
}
|
|
171
|
+
_updateEditorHeight() {
|
|
172
|
+
if (!this._editor || !this.editorContainer)
|
|
173
|
+
return;
|
|
174
|
+
this.editorContainer.nativeElement.style.height = `${this._editor.getContentHeight()}px`;
|
|
175
|
+
this._editor.layout();
|
|
176
|
+
}
|
|
177
|
+
_debounce(func, wait) {
|
|
178
|
+
this._clearDebounce();
|
|
179
|
+
return (...args) => {
|
|
180
|
+
this._debounceTimeout = setTimeout(() => func(...args), wait);
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
_clearDebounce() {
|
|
184
|
+
if (this._debounceTimeout) {
|
|
185
|
+
clearTimeout(this._debounceTimeout);
|
|
186
|
+
this._debounceTimeout = null;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
_destroyEditor() {
|
|
190
|
+
if (this._editor) {
|
|
191
|
+
this._editor.dispose();
|
|
192
|
+
this._editor = null;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
onChangeFn = (value) => {
|
|
196
|
+
};
|
|
197
|
+
onTouchedFn = () => {
|
|
198
|
+
};
|
|
199
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
200
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CodeEditorComponent, selector: "mrx-code-editor", inputs: { fields: "fields", options: "options", debug: "debug", disabled: "disabled", data: "data" }, outputs: { changed: "changed", modelChange: "modelChange", jsonChange: "jsonChange" }, providers: [
|
|
201
|
+
{
|
|
202
|
+
provide: NG_VALUE_ACCESSOR,
|
|
203
|
+
useExisting: forwardRef(() => CodeEditorComponent),
|
|
204
|
+
multi: true,
|
|
205
|
+
},
|
|
206
|
+
], viewQueries: [{ propertyName: "editorContainer", first: true, predicate: ["editorContainer"], descendants: true, static: true }], ngImport: i0, template: "<div [id]=\"uuid\" #editorContainer class=\"editor-wrapper\">\r\n\t\t<ngx-monaco-editor\r\n\t\t\t\t\t\t[options]=\"editorOptions\"\r\n\t\t\t\t\t\t[model]=\"editorModel\"\r\n\t\t\t\t\t\t(onInit)=\"onEditorInit($event)\"\r\n\t\t></ngx-monaco-editor>\r\n</div>\r\n", styles: [":host{display:block;width:100%}.editor-wrapper{width:100%;min-height:140px;height:auto}ngx-monaco-editor{height:100%!important;min-height:140px}.monaco-editor,.monaco-editor .overflow-guard{width:100%!important;height:auto!important}\n"], dependencies: [{ kind: "component", type: i1.EditorComponent, selector: "ngx-monaco-editor", inputs: ["options", "model"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
207
|
+
}
|
|
208
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorComponent, decorators: [{
|
|
209
|
+
type: Component,
|
|
210
|
+
args: [{ selector: 'mrx-code-editor', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
211
|
+
{
|
|
212
|
+
provide: NG_VALUE_ACCESSOR,
|
|
213
|
+
useExisting: forwardRef(() => CodeEditorComponent),
|
|
214
|
+
multi: true,
|
|
215
|
+
},
|
|
216
|
+
], template: "<div [id]=\"uuid\" #editorContainer class=\"editor-wrapper\">\r\n\t\t<ngx-monaco-editor\r\n\t\t\t\t\t\t[options]=\"editorOptions\"\r\n\t\t\t\t\t\t[model]=\"editorModel\"\r\n\t\t\t\t\t\t(onInit)=\"onEditorInit($event)\"\r\n\t\t></ngx-monaco-editor>\r\n</div>\r\n", styles: [":host{display:block;width:100%}.editor-wrapper{width:100%;min-height:140px;height:auto}ngx-monaco-editor{height:100%!important;min-height:140px}.monaco-editor,.monaco-editor .overflow-guard{width:100%!important;height:auto!important}\n"] }]
|
|
217
|
+
}], propDecorators: { fields: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], options: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], debug: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], disabled: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], data: [{
|
|
226
|
+
type: Input,
|
|
227
|
+
args: ['data']
|
|
228
|
+
}], changed: [{
|
|
229
|
+
type: Output
|
|
230
|
+
}], modelChange: [{
|
|
231
|
+
type: Output
|
|
232
|
+
}], jsonChange: [{
|
|
233
|
+
type: Output
|
|
234
|
+
}], editorContainer: [{
|
|
235
|
+
type: ViewChild,
|
|
236
|
+
args: ['editorContainer', { static: true }]
|
|
237
|
+
}] } });
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/code-editor/code-editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/code-editor/code-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { NgxEditorModel } from 'ngx-monaco-editor-v2';\r\nimport { CodeEditorOptions } from \"./utils/codeeditoroptions\";\r\nimport { CodeEditorValueTypes, CodeEditorValueWithId } from \"./code-editor.enum\";\r\nimport { Field } from \"../../../services\";\r\n\r\n@Component({\r\n  selector: 'mrx-code-editor',\r\n  templateUrl: './code-editor.component.html',\r\n  styleUrls: ['./code-editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CodeEditorComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class CodeEditorComponent implements ControlValueAccessor, OnInit, OnDestroy {\r\n  private _data: Object = {};\r\n  private _editor: any;\r\n  private _debounceTimeout: any;\r\n\r\n  public isFocused: boolean = false;\r\n  public editorModel!: NgxEditorModel;\r\n  public editorOptions!: CodeEditorOptions;\r\n\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n  @Input() options: CodeEditorOptions = new CodeEditorOptions();\r\n  @Input() debug: boolean = false;\r\n  @Input() disabled: boolean = false;\r\n\r\n  @Input('data') set data(value: Object) {\r\n    this._data = value;\r\n    if (this._editor) {\r\n      this._editor.destroy();\r\n      this.ngOnInit();\r\n    }\r\n  }\r\n\r\n  get data(): Object {\r\n    return this._data;\r\n  }\r\n\r\n  @Output() changed: EventEmitter<CodeEditorValueTypes> = new EventEmitter<CodeEditorValueTypes>();\r\n  @Output() modelChange: EventEmitter<CodeEditorValueWithId> = new EventEmitter<CodeEditorValueWithId>();\r\n  @Output() jsonChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @ViewChild('editorContainer', {static: true}) editorContainer!: ElementRef;\r\n\r\n  ngOnInit(): void {\r\n    this._initializeEditor();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroyEditor();\r\n    this._clearDebounce();\r\n  }\r\n\r\n  public onEditorInit(editor: any): void {\r\n    this._editor = editor;\r\n    this.setDisabledState(this.disabled);\r\n\r\n    editor.onDidChangeModelContent(() => {\r\n      try {\r\n        const parsedValue = JSON.parse(editor.getValue());\r\n        this.updateValue(parsedValue);\r\n        this.jsonChange.emit(parsedValue);\r\n      } catch (error) {\r\n        if (this.debug) {\r\n          console.log(error);\r\n        }\r\n      }\r\n    });\r\n\r\n    const debouncedUpdateHeight = this._debounce(() => this._updateEditorHeight(), 50);\r\n    editor.onDidChangeModelDecorations(() => {\r\n      debouncedUpdateHeight();\r\n    });\r\n\r\n    this._updateEditorHeight();\r\n  }\r\n\r\n  public onChangeJSON = (): void => {\r\n    if (this._editor) {\r\n      try {\r\n        this.jsonChange.emit(this._editor.getValue());\r\n      } catch (error) {\r\n        if (this.debug) {\r\n          console.log(error);\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  public onChange = (): void => {\r\n    if (this._editor) {\r\n      try {\r\n        const json = this._editor.getValue();\r\n        this.updateValue(json);\r\n      } catch (error) {\r\n        if (this.debug) {\r\n          console.log(error);\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  public focus(): void {\r\n    this._editor?.focus();\r\n  }\r\n\r\n  public get(): JSON {\r\n    return this._editor?.getValue();\r\n  }\r\n\r\n  public getText(): string {\r\n    return this._editor?.getText();\r\n  }\r\n\r\n  public set(json: JSON): void {\r\n    this._editor.setValue(json);\r\n    this._updateEditorHeight();\r\n  }\r\n\r\n  public setSelection(start: any, end: any): void {\r\n    if (!this._editor) return;\r\n    const monaco = (window as any).monaco;\r\n    if (monaco) {\r\n      this._editor.setSelection(new monaco.Range(start.line, start.column, end.line, end.column));\r\n    }\r\n  }\r\n\r\n  public getSelection(): any {\r\n    return this._editor.getSelection();\r\n  }\r\n\r\n  public setOptions(newOptions: CodeEditorOptions): void {\r\n    this._destroyEditor();\r\n    this.options = newOptions;\r\n    this._initializeEditor();\r\n  }\r\n\r\n  public destroy(): void {\r\n    this._destroyEditor();\r\n  }\r\n\r\n  public getEditor(): any {\r\n    return this._editor;\r\n  }\r\n\r\n  public isValidJson(): boolean {\r\n    try {\r\n      JSON.parse(this.getText());\r\n      return true;\r\n    } catch (e) {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this._editor?.updateOptions({readOnly: isDisabled});\r\n  }\r\n\r\n  public writeValue(value: any): void {\r\n    this.data = value;\r\n  }\r\n\r\n  public updateValue(insideValue: any): void {\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChangeFn(insideValue);\r\n    this.onTouchedFn();\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChangeFn = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => void): void {\r\n    this.onTouchedFn = fn;\r\n  }\r\n\r\n  private _initializeEditor(): void {\r\n    this._updateEditorModel();\r\n    this._updateEditorOptions();\r\n\r\n    this.options.onChangeJSON = this.options.onChangeJSON || this.onChangeJSON;\r\n    this.options.onChange = this.options.onChange || this.onChange;\r\n\r\n    if (this.debug) {\r\n      console.log(this.options, this._data);\r\n    }\r\n\r\n    if (!this.editorContainer?.nativeElement) {\r\n      console.error(`Can't find the ElementRef reference for jsoneditor`);\r\n    }\r\n  }\r\n\r\n  private _updateEditorModel(): void {\r\n    const value = typeof this._data === 'string' ? this._data : JSON.stringify(this._data, null, 2);\r\n    this.editorModel = {\r\n      value: value,\r\n      language: this.options.language,\r\n    };\r\n  }\r\n\r\n  private _updateEditorOptions(): void {\r\n    this.editorOptions = {...this.options};\r\n  }\r\n\r\n  private _updateEditorHeight(): void {\r\n    if (!this._editor || !this.editorContainer) return;\r\n    this.editorContainer.nativeElement.style.height = `${this._editor.getContentHeight()}px`;\r\n    this._editor.layout();\r\n  }\r\n\r\n  private _debounce(func: (...args: any[]) => void, wait: number): (...args: any[]) => void {\r\n    this._clearDebounce();\r\n    return (...args: any[]) => {\r\n      this._debounceTimeout = setTimeout(() => func(...args), wait);\r\n    };\r\n  }\r\n\r\n  private _clearDebounce(): void {\r\n    if (this._debounceTimeout) {\r\n      clearTimeout(this._debounceTimeout);\r\n      this._debounceTimeout = null;\r\n    }\r\n  }\r\n\r\n  private _destroyEditor(): void {\r\n    if (this._editor) {\r\n      this._editor.dispose();\r\n      this._editor = null;\r\n    }\r\n  }\r\n\r\n  private onChangeFn = (value: any): void => {\r\n  };\r\n  private onTouchedFn = (): void => {\r\n  };\r\n}","<div [id]=\"uuid\" #editorContainer class=\"editor-wrapper\">\r\n\t\t<ngx-monaco-editor\r\n\t\t\t\t\t\t[options]=\"editorOptions\"\r\n\t\t\t\t\t\t[model]=\"editorModel\"\r\n\t\t\t\t\t\t(onInit)=\"onEditorInit($event)\"\r\n\t\t></ngx-monaco-editor>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1lZGl0b3IuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9mb3JtL2NvZGUtZWRpdG9yL2NvZGUtZWRpdG9yLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIENvZGVFZGl0b3JWYWx1ZVR5cGVzID0gYW55O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDb2RlRWRpdG9yVmFsdWVXaXRoSWQge1xyXG4gIHZhbHVlOiBDb2RlRWRpdG9yVmFsdWVUeXBlcztcclxuICBpZDogc3RyaW5nO1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { CodeEditorComponent } from "./code-editor.component";
|
|
4
|
+
import { FormsModule } from "@angular/forms";
|
|
5
|
+
import { MonacoEditorModule } from 'ngx-monaco-editor-v2';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class CodeEditorModule {
|
|
8
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorModule, declarations: [CodeEditorComponent], imports: [CommonModule,
|
|
10
|
+
FormsModule,
|
|
11
|
+
MonacoEditorModule], exports: [CodeEditorComponent] });
|
|
12
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorModule, imports: [CommonModule,
|
|
13
|
+
FormsModule,
|
|
14
|
+
MonacoEditorModule] });
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CodeEditorModule, decorators: [{
|
|
17
|
+
type: NgModule,
|
|
18
|
+
args: [{
|
|
19
|
+
declarations: [CodeEditorComponent],
|
|
20
|
+
imports: [
|
|
21
|
+
CommonModule,
|
|
22
|
+
FormsModule,
|
|
23
|
+
MonacoEditorModule
|
|
24
|
+
],
|
|
25
|
+
exports: [CodeEditorComponent]
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1lZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vY29kZS1lZGl0b3IvY29kZS1lZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFXMUQsTUFBTSxPQUFPLGdCQUFnQjt3R0FBaEIsZ0JBQWdCO3lHQUFoQixnQkFBZ0IsaUJBUlosbUJBQW1CLGFBRWhDLFlBQVk7WUFDWixXQUFXO1lBQ1gsa0JBQWtCLGFBRVYsbUJBQW1CO3lHQUVsQixnQkFBZ0IsWUFOekIsWUFBWTtZQUNaLFdBQVc7WUFDWCxrQkFBa0I7OzRGQUlULGdCQUFnQjtrQkFUNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvZGVFZGl0b3JDb21wb25lbnQgfSBmcm9tIFwiLi9jb2RlLWVkaXRvci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgTW9uYWNvRWRpdG9yTW9kdWxlIH0gZnJvbSAnbmd4LW1vbmFjby1lZGl0b3ItdjInO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtDb2RlRWRpdG9yQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIE1vbmFjb0VkaXRvck1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW0NvZGVFZGl0b3JDb21wb25lbnRdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb2RlRWRpdG9yTW9kdWxlIHtcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export class CodeEditorOptions {
|
|
2
|
+
theme;
|
|
3
|
+
language;
|
|
4
|
+
automaticLayout;
|
|
5
|
+
minimap;
|
|
6
|
+
lineNumbers;
|
|
7
|
+
readOnly;
|
|
8
|
+
fontSize;
|
|
9
|
+
wordWrap;
|
|
10
|
+
folding;
|
|
11
|
+
renderWhitespace;
|
|
12
|
+
tabSize;
|
|
13
|
+
formatOnPaste;
|
|
14
|
+
formatOnType;
|
|
15
|
+
suggest;
|
|
16
|
+
scrollBeyondLastLine;
|
|
17
|
+
foldingHighlight;
|
|
18
|
+
foldingStrategy;
|
|
19
|
+
_enableSchemaValidation;
|
|
20
|
+
validateJson;
|
|
21
|
+
setSchemaValidation;
|
|
22
|
+
onChange;
|
|
23
|
+
onChangeJSON;
|
|
24
|
+
onError;
|
|
25
|
+
onValidate;
|
|
26
|
+
onInit;
|
|
27
|
+
constructor() {
|
|
28
|
+
this.theme = 'vs-light';
|
|
29
|
+
this.language = 'json';
|
|
30
|
+
this.automaticLayout = true;
|
|
31
|
+
this.minimap = { enabled: true };
|
|
32
|
+
this.lineNumbers = 'on';
|
|
33
|
+
this.readOnly = false;
|
|
34
|
+
this.fontSize = 14;
|
|
35
|
+
this.wordWrap = 'off';
|
|
36
|
+
this.folding = true;
|
|
37
|
+
this.renderWhitespace = 'none';
|
|
38
|
+
this.tabSize = 2;
|
|
39
|
+
this.scrollBeyondLastLine = false;
|
|
40
|
+
this.foldingHighlight = true;
|
|
41
|
+
this.foldingStrategy = 'auto';
|
|
42
|
+
this.formatOnPaste = true;
|
|
43
|
+
this.formatOnType = true;
|
|
44
|
+
this.suggest = {
|
|
45
|
+
showWords: true,
|
|
46
|
+
showSnippets: false,
|
|
47
|
+
};
|
|
48
|
+
this._enableSchemaValidation = true;
|
|
49
|
+
this.validateJson = true;
|
|
50
|
+
this.setSchemaValidation = (enabled) => {
|
|
51
|
+
this._enableSchemaValidation = enabled;
|
|
52
|
+
};
|
|
53
|
+
this.onChange = () => {
|
|
54
|
+
};
|
|
55
|
+
this.onChangeJSON = () => {
|
|
56
|
+
};
|
|
57
|
+
this.onError = () => {
|
|
58
|
+
};
|
|
59
|
+
this.onValidate = () => {
|
|
60
|
+
};
|
|
61
|
+
this.onInit = () => {
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZWVkaXRvcm9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9jb2RlLWVkaXRvci91dGlscy9jb2RlZWRpdG9yb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QkEsTUFBTSxPQUFPLGlCQUFpQjtJQUNyQixLQUFLLENBQVU7SUFDZixRQUFRLENBQVU7SUFDbEIsZUFBZSxDQUFXO0lBQzFCLE9BQU8sQ0FBd0I7SUFDL0IsV0FBVyxDQUE2QjtJQUN4QyxRQUFRLENBQVc7SUFDbkIsUUFBUSxDQUFVO0lBQ2xCLFFBQVEsQ0FBK0M7SUFDdkQsT0FBTyxDQUFXO0lBQ2xCLGdCQUFnQixDQUE2QztJQUM3RCxPQUFPLENBQVU7SUFDakIsYUFBYSxDQUFXO0lBQ3hCLFlBQVksQ0FBVztJQUN2QixPQUFPLENBQWtEO0lBQ3pELG9CQUFvQixDQUFXO0lBQy9CLGdCQUFnQixDQUFXO0lBQzNCLGVBQWUsQ0FBVTtJQUN6Qix1QkFBdUIsQ0FBVztJQUNsQyxZQUFZLENBQVc7SUFFdkIsbUJBQW1CLENBQThCO0lBQ2pELFFBQVEsQ0FBNkI7SUFDckMsWUFBWSxDQUF1QjtJQUNuQyxPQUFPLENBQXNDO0lBQzdDLFVBQVUsQ0FBeUM7SUFDbkQsTUFBTSxDQUFnQztJQUU3QztRQUNFLElBQUksQ0FBQyxLQUFLLEdBQUcsVUFBVSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO1FBQzVCLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBQyxPQUFPLEVBQUUsSUFBSSxFQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7UUFDeEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDcEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLE1BQU0sQ0FBQztRQUMvQixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsb0JBQW9CLEdBQUcsS0FBSyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUM7UUFDN0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxNQUFNLENBQUM7UUFDOUIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7UUFDMUIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLE9BQU8sR0FBRztZQUNiLFNBQVMsRUFBRSxJQUFJO1lBQ2YsWUFBWSxFQUFFLEtBQUs7U0FDcEIsQ0FBQztRQUNGLElBQUksQ0FBQyx1QkFBdUIsR0FBRyxJQUFJLENBQUM7UUFDcEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7UUFFekIsSUFBSSxDQUFDLG1CQUFtQixHQUFHLENBQUMsT0FBZ0IsRUFBRSxFQUFFO1lBQzlDLElBQUksQ0FBQyx1QkFBdUIsR0FBRyxPQUFPLENBQUM7UUFDekMsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDckIsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFlBQVksR0FBRyxHQUFHLEVBQUU7UUFDekIsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLEVBQUU7UUFDcEIsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLEVBQUU7UUFDdkIsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7UUFDbkIsQ0FBQyxDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgQ29kZUVkaXRvck1vZGUgPSAnY29kZScgfCAndGV4dCc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvZGVFZGl0b3JFcnJvciB7XHJcbiAgcGF0aDogKHN0cmluZyB8IG51bWJlcilbXTtcclxuICBtZXNzYWdlOiBzdHJpbmc7XHJcbiAgc2V2ZXJpdHk/OiAnZXJyb3InIHwgJ3dhcm5pbmcnIHwgJ2luZm8nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvZGVFZGl0b3JNYXJrZXIge1xyXG4gIHN0YXJ0TGluZU51bWJlcjogbnVtYmVyO1xyXG4gIHN0YXJ0Q29sdW1uOiBudW1iZXI7XHJcbiAgZW5kTGluZU51bWJlcjogbnVtYmVyO1xyXG4gIGVuZENvbHVtbjogbnVtYmVyO1xyXG4gIG1lc3NhZ2U6IHN0cmluZztcclxuICBzZXZlcml0eTogJ0Vycm9yJyB8ICdXYXJuaW5nJyB8ICdJbmZvJztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDb2RlRWRpdG9yIHtcclxuICBnZXRWYWx1ZSgpOiBzdHJpbmc7XHJcblxyXG4gIHNldFZhbHVlKHZhbHVlOiBzdHJpbmcpOiB2b2lkO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQ29kZUVkaXRvck9wdGlvbnMge1xyXG4gIHB1YmxpYyB0aGVtZT86IHN0cmluZztcclxuICBwdWJsaWMgbGFuZ3VhZ2U/OiBzdHJpbmc7XHJcbiAgcHVibGljIGF1dG9tYXRpY0xheW91dD86IGJvb2xlYW47XHJcbiAgcHVibGljIG1pbmltYXA/OiB7IGVuYWJsZWQ6IGJvb2xlYW4gfTtcclxuICBwdWJsaWMgbGluZU51bWJlcnM/OiAnb24nIHwgJ29mZicgfCAncmVsYXRpdmUnO1xyXG4gIHB1YmxpYyByZWFkT25seT86IGJvb2xlYW47XHJcbiAgcHVibGljIGZvbnRTaXplPzogbnVtYmVyO1xyXG4gIHB1YmxpYyB3b3JkV3JhcD86ICdvbicgfCAnb2ZmJyB8ICd3b3JkV3JhcENvbHVtbicgfCAnYm91bmRlZCc7XHJcbiAgcHVibGljIGZvbGRpbmc/OiBib29sZWFuO1xyXG4gIHB1YmxpYyByZW5kZXJXaGl0ZXNwYWNlPzogJ25vbmUnIHwgJ2JvdW5kYXJ5JyB8ICdzZWxlY3Rpb24nIHwgJ2FsbCc7XHJcbiAgcHVibGljIHRhYlNpemU/OiBudW1iZXI7XHJcbiAgcHVibGljIGZvcm1hdE9uUGFzdGU/OiBib29sZWFuO1xyXG4gIHB1YmxpYyBmb3JtYXRPblR5cGU/OiBib29sZWFuO1xyXG4gIHB1YmxpYyBzdWdnZXN0PzogeyBzaG93V29yZHM6IGJvb2xlYW47IHNob3dTbmlwcGV0czogYm9vbGVhbjsgfTtcclxuICBwdWJsaWMgc2Nyb2xsQmV5b25kTGFzdExpbmU/OiBib29sZWFuO1xyXG4gIHB1YmxpYyBmb2xkaW5nSGlnaGxpZ2h0PzogYm9vbGVhbjtcclxuICBwdWJsaWMgZm9sZGluZ1N0cmF0ZWd5Pzogc3RyaW5nO1xyXG4gIHB1YmxpYyBfZW5hYmxlU2NoZW1hVmFsaWRhdGlvbj86IGJvb2xlYW47XHJcbiAgcHVibGljIHZhbGlkYXRlSnNvbj86IGJvb2xlYW47XHJcblxyXG4gIHB1YmxpYyBzZXRTY2hlbWFWYWxpZGF0aW9uPzogKGVuYWJsZWQ6IGJvb2xlYW4pID0+IHZvaWQ7XHJcbiAgcHVibGljIG9uQ2hhbmdlITogKGNvbnRlbnQ6IHN0cmluZykgPT4gdm9pZDtcclxuICBwdWJsaWMgb25DaGFuZ2VKU09OPzogKGpzb246IGFueSkgPT4gdm9pZDtcclxuICBwdWJsaWMgb25FcnJvciE6IChlcnJvcjogQ29kZUVkaXRvckVycm9yW10pID0+IHZvaWQ7XHJcbiAgcHVibGljIG9uVmFsaWRhdGUhOiAobWFya2VyczogQ29kZUVkaXRvck1hcmtlcltdKSA9PiB2b2lkO1xyXG4gIHB1YmxpYyBvbkluaXQhOiAoZWRpdG9yOiBDb2RlRWRpdG9yKSA9PiB2b2lkO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMudGhlbWUgPSAndnMtbGlnaHQnO1xyXG4gICAgdGhpcy5sYW5ndWFnZSA9ICdqc29uJztcclxuICAgIHRoaXMuYXV0b21hdGljTGF5b3V0ID0gdHJ1ZTtcclxuICAgIHRoaXMubWluaW1hcCA9IHtlbmFibGVkOiB0cnVlfTtcclxuICAgIHRoaXMubGluZU51bWJlcnMgPSAnb24nO1xyXG4gICAgdGhpcy5yZWFkT25seSA9IGZhbHNlO1xyXG4gICAgdGhpcy5mb250U2l6ZSA9IDE0O1xyXG4gICAgdGhpcy53b3JkV3JhcCA9ICdvZmYnO1xyXG4gICAgdGhpcy5mb2xkaW5nID0gdHJ1ZTtcclxuICAgIHRoaXMucmVuZGVyV2hpdGVzcGFjZSA9ICdub25lJztcclxuICAgIHRoaXMudGFiU2l6ZSA9IDI7XHJcbiAgICB0aGlzLnNjcm9sbEJleW9uZExhc3RMaW5lID0gZmFsc2U7XHJcbiAgICB0aGlzLmZvbGRpbmdIaWdobGlnaHQgPSB0cnVlO1xyXG4gICAgdGhpcy5mb2xkaW5nU3RyYXRlZ3kgPSAnYXV0byc7XHJcbiAgICB0aGlzLmZvcm1hdE9uUGFzdGUgPSB0cnVlO1xyXG4gICAgdGhpcy5mb3JtYXRPblR5cGUgPSB0cnVlO1xyXG4gICAgdGhpcy5zdWdnZXN0ID0ge1xyXG4gICAgICBzaG93V29yZHM6IHRydWUsXHJcbiAgICAgIHNob3dTbmlwcGV0czogZmFsc2UsXHJcbiAgICB9O1xyXG4gICAgdGhpcy5fZW5hYmxlU2NoZW1hVmFsaWRhdGlvbiA9IHRydWU7XHJcbiAgICB0aGlzLnZhbGlkYXRlSnNvbiA9IHRydWU7XHJcblxyXG4gICAgdGhpcy5zZXRTY2hlbWFWYWxpZGF0aW9uID0gKGVuYWJsZWQ6IGJvb2xlYW4pID0+IHtcclxuICAgICAgdGhpcy5fZW5hYmxlU2NoZW1hVmFsaWRhdGlvbiA9IGVuYWJsZWQ7XHJcbiAgICB9O1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9ICgpID0+IHtcclxuICAgIH07XHJcbiAgICB0aGlzLm9uQ2hhbmdlSlNPTiA9ICgpID0+IHtcclxuICAgIH07XHJcbiAgICB0aGlzLm9uRXJyb3IgPSAoKSA9PiB7XHJcbiAgICB9O1xyXG4gICAgdGhpcy5vblZhbGlkYXRlID0gKCkgPT4ge1xyXG4gICAgfTtcclxuICAgIHRoaXMub25Jbml0ID0gKCkgPT4ge1xyXG4gICAgfTtcclxuICB9XHJcbn0iXX0=
|
|
@@ -59,14 +59,13 @@ export class ModalComponent {
|
|
|
59
59
|
this.isEmbed = !this.isEmbed;
|
|
60
60
|
}
|
|
61
61
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
62
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ModalComponent, selector: "mrx-modal", inputs: { title: "title", message: "message", alert: "alert", okText: "okText", closeText: "closeText", size: "size", color: "color", customClasses: "customClasses", expandable: "expandable", isEmbed: "isEmbed", isClose: "isClose", isBack: "isBack", backText: "backText", enableFooter: "enableFooter", alignButtons: "alignButtons", isLoading: "isLoading", iconPosition: "iconPosition" }, outputs: { ok: "ok", close: "close", back: "back" }, queries: [{ propertyName: "footerContent", first: true, predicate: ["footerContent"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n <div class=\"mrx-modal-header\">\r\n <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n @if (expandable) {\r\n <span\r\n class=\"mrx-icon icon-font-24\"\r\n [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n (click)=\"onExpanding()\"\r\n ></span>\r\n }\r\n\r\n @if (isClose) {\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-modal-body\">\r\n @if (isBack) {\r\n <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n <span>{{ backText }}</span>\r\n </div>\r\n }\r\n\r\n @if (alert && (alert.title || alert.message)) {\r\n <mrx-alert\r\n [customClasses]=\"'mb-3'\"\r\n [title]=\"alert.title || ''\"\r\n [message]=\"alert.message || ''\"\r\n [color]=\"alert.color || 'default'\"\r\n ></mrx-alert>\r\n }\r\n\r\n <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n @if (!footerContent) {\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"getButtonColor\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{closeText}}</mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"getButtonColor\"\r\n [iconPosition]=\"iconPosition\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{okText}}</mrx-button>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["::ng-deep .mrx-modal
|
|
62
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ModalComponent, selector: "mrx-modal", inputs: { title: "title", message: "message", alert: "alert", okText: "okText", closeText: "closeText", size: "size", color: "color", customClasses: "customClasses", expandable: "expandable", isEmbed: "isEmbed", isClose: "isClose", isBack: "isBack", backText: "backText", enableFooter: "enableFooter", alignButtons: "alignButtons", isLoading: "isLoading", iconPosition: "iconPosition" }, outputs: { ok: "ok", close: "close", back: "back" }, queries: [{ propertyName: "footerContent", first: true, predicate: ["footerContent"], descendants: true }], ngImport: i0, template: "<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n <div class=\"mrx-modal-header\">\r\n <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n @if (expandable) {\r\n <span\r\n class=\"mrx-icon icon-font-24\"\r\n [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n (click)=\"onExpanding()\"\r\n ></span>\r\n }\r\n\r\n @if (isClose) {\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-modal-body\">\r\n @if (isBack) {\r\n <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n <span>{{ backText }}</span>\r\n </div>\r\n }\r\n\r\n @if (alert && (alert.title || alert.message)) {\r\n <mrx-alert\r\n [customClasses]=\"'mb-3'\"\r\n [title]=\"alert.title || ''\"\r\n [message]=\"alert.message || ''\"\r\n [color]=\"alert.color || 'default'\"\r\n ></mrx-alert>\r\n }\r\n\r\n <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n @if (!footerContent) {\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"getButtonColor\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{closeText}}</mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"getButtonColor\"\r\n [iconPosition]=\"iconPosition\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{okText}}</mrx-button>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["::ng-deep .mrx-modal>*{display:flex;align-items:center;justify-content:center;height:100%;width:100%}:host{margin:auto 0;width:100vw}.mrx-modal-content{margin:24px auto;background-color:#fff;border-radius:4px;position:relative;transition:opacity .5s ease-out;width:calc(100vw - 32px);max-height:calc(100vh - 48px);will-change:opacity;display:flex;flex-direction:column;text-align:left;overflow:hidden}::ng-deep .mrx-modal-backdrop.cdk-overlay-backdrop{height:100%;inset:0;overflow-x:hidden;overflow-y:auto;padding:0 16px;position:absolute;text-align:center;z-index:1000;display:block}::ng-deep .mrx-modal-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}::ng-deep .mrx-modal.fade-anim{transition:opacity .4s ease-in-out;will-change:opacity;opacity:0}::ng-deep .mrx-modal.fade-anim.in{opacity:1}.mrx-modal-body{padding:var(--spacing-6, 24px) var(--spacing-4, 16px) var(--spacing-4, 16px);flex-grow:1;overflow-y:auto;border-bottom:1px solid var(--neutral-bg-divider);margin-bottom:var(--spacing-4, 16px)}.mrx-modal-body .mrx-modal__back{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);font-size:var(--body-md-font-size)}.mrx-modal-body__message{color:var(--neutral-text-primary);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);font-size:var(--body-md-font-size)}.mrx-modal-content.type-default .mrx-modal-header{background:var(--brand-bg-primary-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-default .mrx-modal-header .icon-close,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content.type-info .mrx-modal-header{background:var(--neutral-bg-island-default);color:var(--neutral-text-primary)}.mrx-modal-content.type-info .mrx-modal-header .icon-close,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-default)}.mrx-modal-content.type-attention .mrx-modal-header{background:var(--system-bg-controls-attention-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-attention .mrx-modal-header .icon-close,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content.type-negative .mrx-modal-header{background:var(--system-bg-controls-negative-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-negative .mrx-modal-header .icon-close,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content .mrx-modal__back{cursor:pointer;color:var(--brand-text-controls-default)}.mrx-modal-content .mrx-modal__back .mrx-icon{color:var(--brand-text-controls-default)}.mrx-modal-content .mrx-modal__back:hover,.mrx-modal-content .mrx-modal__back:hover .mrx-icon{color:var(--brand-text-controls-hover)}.mrx-modal-footer{align-items:center;display:flex;gap:var(--spacing-4);padding:var(--spacing-6);padding-top:0}.mrx-modal-header{padding:16px;position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-modal-header .mrx-modal-title{font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size);text-align:center;text-transform:uppercase}.mrx-modal-header .icon-arrow-expand,.mrx-modal-header .icon-arrow-collapse{position:absolute;top:16px;right:48px;cursor:pointer}.mrx-modal-header .icon-arrow-expand:hover,.mrx-modal-header .icon-arrow-collapse:hover{transform:scale(1.1)}.mrx-modal-header .icon-close{position:absolute;top:16px;right:16px;cursor:pointer}.mrx-modal-header .icon-close:hover{transform:scale(1.1)}.mrx-modal-content.mrx-modal-sm{max-width:440px}.mrx-modal-content.mrx-modal-md{max-width:670px}.mrx-modal-content.mrx-modal-lg{max-width:904px}.mrx-modal-content.mrx-modal-extra-lg{max-width:1024px}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ButtonComponent, selector: "mrx-button", inputs: ["size", "type", "color", "iconPosition", "active", "disabled", "isLoading", "iconOnly", "customClasses", "label", "icon", "iconClass", "buttonType", "href", "target", "routerLink", "queryParams"], outputs: ["mrxClick"] }, { kind: "component", type: i3.AlertComponent, selector: "mrx-alert", inputs: ["customClasses", "color", "customColor", "message", "title", "closable"], outputs: ["close"] }], animations: [
|
|
63
63
|
trigger('animateExpand', [
|
|
64
64
|
state('open', style({
|
|
65
|
-
height: '
|
|
65
|
+
height: '100vh',
|
|
66
66
|
width: '100%',
|
|
67
67
|
maxWidth: 'none',
|
|
68
68
|
minHeight: '100vh',
|
|
69
|
-
minWidth: '100vw',
|
|
70
69
|
marginTop: '0',
|
|
71
70
|
marginBottom: '0'
|
|
72
71
|
})),
|
|
@@ -81,11 +80,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
81
80
|
args: [{ selector: 'mrx-modal', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
82
81
|
trigger('animateExpand', [
|
|
83
82
|
state('open', style({
|
|
84
|
-
height: '
|
|
83
|
+
height: '100vh',
|
|
85
84
|
width: '100%',
|
|
86
85
|
maxWidth: 'none',
|
|
87
86
|
minHeight: '100vh',
|
|
88
|
-
minWidth: '100vw',
|
|
89
87
|
marginTop: '0',
|
|
90
88
|
marginBottom: '0'
|
|
91
89
|
})),
|
|
@@ -93,7 +91,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
93
91
|
transition('open => closed', [animate('0.5s ease')]),
|
|
94
92
|
transition('closed => open', [animate('0.5s ease')]),
|
|
95
93
|
]),
|
|
96
|
-
], template: "<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n <div class=\"mrx-modal-header\">\r\n <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n @if (expandable) {\r\n <span\r\n class=\"mrx-icon icon-font-24\"\r\n [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n (click)=\"onExpanding()\"\r\n ></span>\r\n }\r\n\r\n @if (isClose) {\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-modal-body\">\r\n @if (isBack) {\r\n <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n <span>{{ backText }}</span>\r\n </div>\r\n }\r\n\r\n @if (alert && (alert.title || alert.message)) {\r\n <mrx-alert\r\n [customClasses]=\"'mb-3'\"\r\n [title]=\"alert.title || ''\"\r\n [message]=\"alert.message || ''\"\r\n [color]=\"alert.color || 'default'\"\r\n ></mrx-alert>\r\n }\r\n\r\n <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n @if (!footerContent) {\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"getButtonColor\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{closeText}}</mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"getButtonColor\"\r\n [iconPosition]=\"iconPosition\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{okText}}</mrx-button>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["::ng-deep .mrx-modal
|
|
94
|
+
], template: "<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n <div class=\"mrx-modal-header\">\r\n <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n @if (expandable) {\r\n <span\r\n class=\"mrx-icon icon-font-24\"\r\n [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n (click)=\"onExpanding()\"\r\n ></span>\r\n }\r\n\r\n @if (isClose) {\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n }\r\n </div>\r\n\r\n <div class=\"mrx-modal-body\">\r\n @if (isBack) {\r\n <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n <span>{{ backText }}</span>\r\n </div>\r\n }\r\n\r\n @if (alert && (alert.title || alert.message)) {\r\n <mrx-alert\r\n [customClasses]=\"'mb-3'\"\r\n [title]=\"alert.title || ''\"\r\n [message]=\"alert.message || ''\"\r\n [color]=\"alert.color || 'default'\"\r\n ></mrx-alert>\r\n }\r\n\r\n <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n @if (!footerContent) {\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"getButtonColor\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{closeText}}</mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"getButtonColor\"\r\n [iconPosition]=\"iconPosition\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{okText}}</mrx-button>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n }\r\n </div>\r\n }\r\n</div>\r\n", styles: ["::ng-deep .mrx-modal>*{display:flex;align-items:center;justify-content:center;height:100%;width:100%}:host{margin:auto 0;width:100vw}.mrx-modal-content{margin:24px auto;background-color:#fff;border-radius:4px;position:relative;transition:opacity .5s ease-out;width:calc(100vw - 32px);max-height:calc(100vh - 48px);will-change:opacity;display:flex;flex-direction:column;text-align:left;overflow:hidden}::ng-deep .mrx-modal-backdrop.cdk-overlay-backdrop{height:100%;inset:0;overflow-x:hidden;overflow-y:auto;padding:0 16px;position:absolute;text-align:center;z-index:1000;display:block}::ng-deep .mrx-modal-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}::ng-deep .mrx-modal.fade-anim{transition:opacity .4s ease-in-out;will-change:opacity;opacity:0}::ng-deep .mrx-modal.fade-anim.in{opacity:1}.mrx-modal-body{padding:var(--spacing-6, 24px) var(--spacing-4, 16px) var(--spacing-4, 16px);flex-grow:1;overflow-y:auto;border-bottom:1px solid var(--neutral-bg-divider);margin-bottom:var(--spacing-4, 16px)}.mrx-modal-body .mrx-modal__back{font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);font-size:var(--body-md-font-size)}.mrx-modal-body__message{color:var(--neutral-text-primary);font-family:var(--body-md-font-family);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height);font-size:var(--body-md-font-size)}.mrx-modal-content.type-default .mrx-modal-header{background:var(--brand-bg-primary-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-default .mrx-modal-header .icon-close,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-default .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content.type-info .mrx-modal-header{background:var(--neutral-bg-island-default);color:var(--neutral-text-primary)}.mrx-modal-content.type-info .mrx-modal-header .icon-close,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-info .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-default)}.mrx-modal-content.type-attention .mrx-modal-header{background:var(--system-bg-controls-attention-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-attention .mrx-modal-header .icon-close,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-attention .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content.type-negative .mrx-modal-header{background:var(--system-bg-controls-negative-default);color:var(--neutral-icon-inverse)}.mrx-modal-content.type-negative .mrx-modal-header .icon-close,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-expand,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-collapse,.mrx-modal-content.type-negative .mrx-modal-header .icon-arrow-left{color:var(--neutral-icon-inverse)}.mrx-modal-content .mrx-modal__back{cursor:pointer;color:var(--brand-text-controls-default)}.mrx-modal-content .mrx-modal__back .mrx-icon{color:var(--brand-text-controls-default)}.mrx-modal-content .mrx-modal__back:hover,.mrx-modal-content .mrx-modal__back:hover .mrx-icon{color:var(--brand-text-controls-hover)}.mrx-modal-footer{align-items:center;display:flex;gap:var(--spacing-4);padding:var(--spacing-6);padding-top:0}.mrx-modal-header{padding:16px;position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-modal-header .mrx-modal-title{font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size);text-align:center;text-transform:uppercase}.mrx-modal-header .icon-arrow-expand,.mrx-modal-header .icon-arrow-collapse{position:absolute;top:16px;right:48px;cursor:pointer}.mrx-modal-header .icon-arrow-expand:hover,.mrx-modal-header .icon-arrow-collapse:hover{transform:scale(1.1)}.mrx-modal-header .icon-close{position:absolute;top:16px;right:16px;cursor:pointer}.mrx-modal-header .icon-close:hover{transform:scale(1.1)}.mrx-modal-content.mrx-modal-sm{max-width:440px}.mrx-modal-content.mrx-modal-md{max-width:670px}.mrx-modal-content.mrx-modal-lg{max-width:904px}.mrx-modal-content.mrx-modal-extra-lg{max-width:1024px}\n"] }]
|
|
97
95
|
}], propDecorators: { title: [{
|
|
98
96
|
type: Input
|
|
99
97
|
}], message: [{
|
|
@@ -138,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
138
136
|
}], back: [{
|
|
139
137
|
type: Output
|
|
140
138
|
}] } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/modal/modal.component.ts","../../../../../../projects/myrta-ui/src/lib/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  TemplateRef\r\n} from '@angular/core';\r\n\r\nimport {\r\n  ModalAlert,\r\n  ModalAlignButtonsEnum,\r\n  ModalAlignButtonsTypes,\r\n  ModalColorEnum,\r\n  ModalColorTypes,\r\n  ModalSizesEnum,\r\n  ModalSizesTypes\r\n} from './modal.emun';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { ButtonColorsTypes, ButtonIconPositionTypes } from '../button/button.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-modal',\r\n  templateUrl: './modal.component.html',\r\n  styleUrls: ['./modal.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('animateExpand', [\r\n      state('open', style({\r\n        height: '100%',\r\n        width: '100%',\r\n        maxWidth: 'none',\r\n        minHeight: '100vh',\r\n        minWidth: '100vw',\r\n        marginTop: '0',\r\n        marginBottom: '0'\r\n      })),\r\n      state('closed', style({ height: '*', width: '*' })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n  ],\r\n})\r\nexport class ModalComponent {\r\n  @Input() title?: string | null = ''\r\n  @Input() message?: string | null = ''\r\n  @Input() alert?: ModalAlert\r\n  @Input() okText = 'Подтвердить'\r\n  @Input() closeText = 'Отменить'\r\n  @Input() size: ModalSizesTypes = 'small'\r\n  @Input() color: ModalColorTypes = 'default'\r\n  @Input() customClasses = ''\r\n  @Input() expandable = false\r\n  @Input() isEmbed = false\r\n  @Input() isClose = true\r\n  @Input() isBack = false\r\n  @Input() backText = 'Назад'\r\n  @Input() enableFooter = true\r\n  @Input() alignButtons: ModalAlignButtonsTypes = 'center'\r\n  @Input() isLoading = false;\r\n  @Input() iconPosition: ButtonIconPositionTypes = 'left';\r\n\r\n  @ContentChild('footerContent') footerContent!: TemplateRef<HTMLElement>;\r\n\r\n  @Output() ok: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() close: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() back: EventEmitter<null> = new EventEmitter<null>();\r\n\r\n  public get getColorClass() {\r\n    return this.color ? ModalColorEnum[this.color] : ''\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${ ModalSizesEnum[this.size] } ${ this.getColorClass } ${ this.customClasses }`;\r\n  }\r\n\r\n  public get getButtonColor(): ButtonColorsTypes {\r\n    switch (this.color) {\r\n      case 'negative':\r\n        return 'negative'\r\n      case 'attention':\r\n        return 'attention'\r\n      default:\r\n        return 'default'\r\n    }\r\n  }\r\n\r\n  public get alignButtonsClass(): string {\r\n    return ModalAlignButtonsEnum[this.alignButtons]\r\n  }\r\n\r\n  public onOk(): void {\r\n    this.ok.emit()\r\n  }\r\n\r\n  public onClose(): void {\r\n    this.close.emit()\r\n  }\r\n\r\n  public onBack() {\r\n    this.back.emit()\r\n  }\r\n\r\n  public onExpanding(): void {\r\n    this.isEmbed = !this.isEmbed\r\n  }\r\n}\r\n","<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n  <div class=\"mrx-modal-header\">\r\n    <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n    @if (expandable) {\r\n      <span\r\n        class=\"mrx-icon icon-font-24\"\r\n        [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n        (click)=\"onExpanding()\"\r\n      ></span>\r\n    }\r\n\r\n    @if (isClose) {\r\n      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n    }\r\n  </div>\r\n\r\n  <div class=\"mrx-modal-body\">\r\n    @if (isBack) {\r\n      <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n        <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n        <span>{{ backText }}</span>\r\n      </div>\r\n    }\r\n\r\n    @if (alert && (alert.title || alert.message)) {\r\n      <mrx-alert\r\n        [customClasses]=\"'mb-3'\"\r\n        [title]=\"alert.title || ''\"\r\n        [message]=\"alert.message || ''\"\r\n        [color]=\"alert.color || 'default'\"\r\n      ></mrx-alert>\r\n    }\r\n\r\n    <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  @if (enableFooter) {\r\n    <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n      @if (!footerContent) {\r\n        <mrx-button\r\n          [type]=\"'secondary'\"\r\n          [color]=\"getButtonColor\"\r\n          [size]=\"'medium'\"\r\n          (click)=\"onClose()\"\r\n        >{{closeText}}</mrx-button>\r\n\r\n        <mrx-button\r\n          [type]=\"'primary'\"\r\n          [size]=\"'medium'\"\r\n          [color]=\"getButtonColor\"\r\n          [iconPosition]=\"iconPosition\"\r\n          [isLoading]=\"isLoading\"\r\n          (click)=\"onOk()\"\r\n        >{{okText}}</mrx-button>\r\n      } @else {\r\n        <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n      }\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/modal/modal.component.ts","../../../../../../projects/myrta-ui/src/lib/components/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ContentChild,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  TemplateRef\r\n} from '@angular/core';\r\n\r\nimport {\r\n  ModalAlert,\r\n  ModalAlignButtonsEnum,\r\n  ModalAlignButtonsTypes,\r\n  ModalColorEnum,\r\n  ModalColorTypes,\r\n  ModalSizesEnum,\r\n  ModalSizesTypes\r\n} from './modal.emun';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { ButtonColorsTypes, ButtonIconPositionTypes } from '../button/button.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-modal',\r\n  templateUrl: './modal.component.html',\r\n  styleUrls: ['./modal.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('animateExpand', [\r\n      state('open', style({\r\n        height: '100vh',\r\n        width: '100%',\r\n        maxWidth: 'none',\r\n        minHeight: '100vh',\r\n        marginTop: '0',\r\n        marginBottom: '0'\r\n      })),\r\n      state('closed', style({ height: '*', width: '*' })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n  ],\r\n})\r\nexport class ModalComponent {\r\n  @Input() title?: string | null = ''\r\n  @Input() message?: string | null = ''\r\n  @Input() alert?: ModalAlert\r\n  @Input() okText = 'Подтвердить'\r\n  @Input() closeText = 'Отменить'\r\n  @Input() size: ModalSizesTypes = 'small'\r\n  @Input() color: ModalColorTypes = 'default'\r\n  @Input() customClasses = ''\r\n  @Input() expandable = false\r\n  @Input() isEmbed = false\r\n  @Input() isClose = true\r\n  @Input() isBack = false\r\n  @Input() backText = 'Назад'\r\n  @Input() enableFooter = true\r\n  @Input() alignButtons: ModalAlignButtonsTypes = 'center'\r\n  @Input() isLoading = false;\r\n  @Input() iconPosition: ButtonIconPositionTypes = 'left';\r\n\r\n  @ContentChild('footerContent') footerContent!: TemplateRef<HTMLElement>;\r\n\r\n  @Output() ok: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() close: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() back: EventEmitter<null> = new EventEmitter<null>();\r\n\r\n  public get getColorClass() {\r\n    return this.color ? ModalColorEnum[this.color] : ''\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${ ModalSizesEnum[this.size] } ${ this.getColorClass } ${ this.customClasses }`;\r\n  }\r\n\r\n  public get getButtonColor(): ButtonColorsTypes {\r\n    switch (this.color) {\r\n      case 'negative':\r\n        return 'negative'\r\n      case 'attention':\r\n        return 'attention'\r\n      default:\r\n        return 'default'\r\n    }\r\n  }\r\n\r\n  public get alignButtonsClass(): string {\r\n    return ModalAlignButtonsEnum[this.alignButtons]\r\n  }\r\n\r\n  public onOk(): void {\r\n    this.ok.emit()\r\n  }\r\n\r\n  public onClose(): void {\r\n    this.close.emit()\r\n  }\r\n\r\n  public onBack() {\r\n    this.back.emit()\r\n  }\r\n\r\n  public onExpanding(): void {\r\n    this.isEmbed = !this.isEmbed\r\n  }\r\n}\r\n","<div class=\"mrx-modal-content\" [class]=\"getClasses\" [@animateExpand]=\"isEmbed ? 'open' : 'closed'\">\r\n  <div class=\"mrx-modal-header\">\r\n    <div class=\"mrx-modal-title\" [innerHTML]=\"title\" [style]=\"{padding: expandable ? '0 56px' : '0 24px'}\"></div>\r\n\r\n    @if (expandable) {\r\n      <span\r\n        class=\"mrx-icon icon-font-24\"\r\n        [class]=\"isEmbed ? 'icon-arrow-collapse' : 'icon-arrow-expand'\"\r\n        (click)=\"onExpanding()\"\r\n      ></span>\r\n    }\r\n\r\n    @if (isClose) {\r\n      <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n    }\r\n  </div>\r\n\r\n  <div class=\"mrx-modal-body\">\r\n    @if (isBack) {\r\n      <div class=\"mrx-modal__back d-flex align-items-center mb-3 mt-2\" (click)=\"onBack()\">\r\n        <span class=\"mrx-icon icon-arrow-left icon-font-16 mr-1\"></span>\r\n        <span>{{ backText }}</span>\r\n      </div>\r\n    }\r\n\r\n    @if (alert && (alert.title || alert.message)) {\r\n      <mrx-alert\r\n        [customClasses]=\"'mb-3'\"\r\n        [title]=\"alert.title || ''\"\r\n        [message]=\"alert.message || ''\"\r\n        [color]=\"alert.color || 'default'\"\r\n      ></mrx-alert>\r\n    }\r\n\r\n    <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  @if (enableFooter) {\r\n    <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\">\r\n      @if (!footerContent) {\r\n        <mrx-button\r\n          [type]=\"'secondary'\"\r\n          [color]=\"getButtonColor\"\r\n          [size]=\"'medium'\"\r\n          (click)=\"onClose()\"\r\n        >{{closeText}}</mrx-button>\r\n\r\n        <mrx-button\r\n          [type]=\"'primary'\"\r\n          [size]=\"'medium'\"\r\n          [color]=\"getButtonColor\"\r\n          [iconPosition]=\"iconPosition\"\r\n          [isLoading]=\"isLoading\"\r\n          (click)=\"onOk()\"\r\n        >{{okText}}</mrx-button>\r\n      } @else {\r\n        <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n      }\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|