myrta-ui 17.1.10 → 17.1.11

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.
@@ -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":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;;;AAiB9D,MAAM,OAAO,mBAAmB;IACtB,KAAK,GAAW,EAAE,CAAC;IACnB,OAAO,CAAM;IACb,gBAAgB,CAAM;IAEvB,SAAS,GAAY,KAAK,CAAC;IAC3B,WAAW,CAAkB;IAC7B,aAAa,CAAqB;IAElC,IAAI,GAAW,MAAM,EAAE,CAAC;IACf,MAAM,GAAY,EAAE,CAAC;IAC5B,OAAO,GAAsB,IAAI,iBAAiB,EAAE,CAAC;IACrD,KAAK,GAAY,KAAK,CAAC;IACvB,QAAQ,GAAY,KAAK,CAAC;IAEnC,IAAmB,IAAI,CAAC,KAAa;QACnC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAES,OAAO,GAAuC,IAAI,YAAY,EAAwB,CAAC;IACvF,WAAW,GAAwC,IAAI,YAAY,EAAyB,CAAC;IAC7F,UAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;IAEpB,eAAe,CAAc;IAE3E,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,YAAY,CAAC,MAAW;QAC7B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAErC,MAAM,CAAC,uBAAuB,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;gBAClD,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;gBAC9B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACpC,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACrB,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,qBAAqB,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,EAAE,CAAC,CAAC;QACnF,MAAM,CAAC,2BAA2B,CAAC,GAAG,EAAE;YACtC,qBAAqB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEM,YAAY,GAAG,GAAS,EAAE;QAC/B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC;gBACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;YAChD,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACrB,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IAEK,QAAQ,GAAG,GAAS,EAAE;QAC3B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC;gBACH,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACrB,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC,CAAC;IAEK,KAAK;QACV,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;IACxB,CAAC;IAEM,GAAG;QACR,OAAO,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC;IAClC,CAAC;IAEM,OAAO;QACZ,OAAO,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC;IACjC,CAAC;IAEM,GAAG,CAAC,IAAU;QACnB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEM,YAAY,CAAC,KAAU,EAAE,GAAQ;QACtC,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO;QAC1B,MAAM,MAAM,GAAI,MAAc,CAAC,MAAM,CAAC;QACtC,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,EAAE,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9F,CAAC;IACH,CAAC;IAEM,YAAY;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAEM,UAAU,CAAC,UAA6B;QAC7C,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC;QAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC;YACH,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAC3B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,UAAmB;QACzC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,EAAC,QAAQ,EAAE,UAAU,EAAC,CAAC,CAAC;IACtD,CAAC;IAEM,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACpB,CAAC;IAEM,WAAW,CAAC,WAAgB;QACjC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,CAAC,IAAI,EAAC,CAAC,CAAC;QAC3D,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAEM,iBAAiB,CAAC,EAAc;QACrC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC;QAC3E,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;QAE/D,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,EAAE,CAAC;YACzC,OAAO,CAAC,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACtE,CAAC;IACH,CAAC;IAEO,kBAAkB;QACxB,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAChG,IAAI,CAAC,WAAW,GAAG;YACjB,KAAK,EAAE,KAAK;YACZ,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;SAChC,CAAC;IACJ,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,aAAa,GAAG,EAAC,GAAG,IAAI,CAAC,OAAO,EAAC,CAAC;IACzC,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,OAAO;QACnD,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,IAAI,CAAC;QACzF,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;IACxB,CAAC;IAEO,SAAS,CAAC,IAA8B,EAAE,IAAY;QAC5D,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,IAAW,EAAE,EAAE;YACxB,IAAI,CAAC,gBAAgB,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QAChE,CAAC,CAAC;IACJ,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,YAAY,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACpC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC/B,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;IACH,CAAC;IAEO,UAAU,GAAG,CAAC,KAAU,EAAQ,EAAE;IAC1C,CAAC,CAAC;IACM,WAAW,GAAG,GAAS,EAAE;IACjC,CAAC,CAAC;wGAjOS,mBAAmB;4FAAnB,mBAAmB,uOARnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;gBAClD,KAAK,EAAE,IAAI;aACZ;SACF,4JC9BH,uQAOA;;4FDyBa,mBAAmB;kBAb/B,SAAS;+BACE,iBAAiB,mBAGV,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;4BAClD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAYe,MAAM;sBAArB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEa,IAAI;sBAAtB,KAAK;uBAAC,MAAM;gBAYH,OAAO;sBAAhB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBAEuC,eAAe;sBAA5D,SAAS;uBAAC,iBAAiB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC","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{overflow-y:auto}::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);will-change:opacity;display:flex;flex-direction:column;text-align:left}::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}.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: [
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: '100%',
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: '100%',
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{overflow-y:auto}::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);will-change:opacity;display:flex;flex-direction:column;text-align:left}::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}.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"] }]
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":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EAEP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAEL,qBAAqB,EAErB,cAAc,EAEd,cAAc,EAEf,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;;;AAyBjF,MAAM,OAAO,cAAc;IAChB,KAAK,GAAmB,EAAE,CAAA;IAC1B,OAAO,GAAmB,EAAE,CAAA;IAC5B,KAAK,CAAa;IAClB,MAAM,GAAG,aAAa,CAAA;IACtB,SAAS,GAAG,UAAU,CAAA;IACtB,IAAI,GAAoB,OAAO,CAAA;IAC/B,KAAK,GAAoB,SAAS,CAAA;IAClC,aAAa,GAAG,EAAE,CAAA;IAClB,UAAU,GAAG,KAAK,CAAA;IAClB,OAAO,GAAG,KAAK,CAAA;IACf,OAAO,GAAG,IAAI,CAAA;IACd,MAAM,GAAG,KAAK,CAAA;IACd,QAAQ,GAAG,OAAO,CAAA;IAClB,YAAY,GAAG,IAAI,CAAA;IACnB,YAAY,GAA2B,QAAQ,CAAA;IAC/C,SAAS,GAAG,KAAK,CAAC;IAClB,YAAY,GAA4B,MAAM,CAAC;IAEzB,aAAa,CAA4B;IAE9D,EAAE,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAClD,KAAK,GAAuB,IAAI,YAAY,EAAQ,CAAC;IACrD,IAAI,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAE9D,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IACrD,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,GAAI,cAAc,CAAC,IAAI,CAAC,IAAI,CAAE,IAAK,IAAI,CAAC,aAAc,IAAK,IAAI,CAAC,aAAc,EAAE,CAAC;IAC1F,CAAC;IAED,IAAW,cAAc;QACvB,QAAQ,IAAI,CAAC,KAAK,EAAE,CAAC;YACnB,KAAK,UAAU;gBACb,OAAO,UAAU,CAAA;YACnB,KAAK,WAAW;gBACd,OAAO,WAAW,CAAA;YACpB;gBACE,OAAO,SAAS,CAAA;QACpB,CAAC;IACH,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;IACjD,CAAC;IAEM,IAAI;QACT,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,CAAA;IAChB,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAA;IACnB,CAAC;IAEM,MAAM;QACX,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;IAClB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAA;IAC9B,CAAC;wGA9DU,cAAc;4FAAd,cAAc,slBC5C3B,8jEA8DA,+gKDnCc;YACV,OAAO,CAAC,eAAe,EAAE;gBACvB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAClB,MAAM,EAAE,MAAM;oBACd,KAAK,EAAE,MAAM;oBACb,QAAQ,EAAE,MAAM;oBAChB,SAAS,EAAE,OAAO;oBAClB,QAAQ,EAAE,OAAO;oBACjB,SAAS,EAAE,GAAG;oBACd,YAAY,EAAE,GAAG;iBAClB,CAAC,CAAC;gBACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;gBACnD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;gBACpD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;aACrD,CAAC;SACH;;4FAEU,cAAc;kBAtB1B,SAAS;+BACE,WAAW,mBAGJ,uBAAuB,CAAC,MAAM,cACnC;wBACV,OAAO,CAAC,eAAe,EAAE;4BACvB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;gCAClB,MAAM,EAAE,MAAM;gCACd,KAAK,EAAE,MAAM;gCACb,QAAQ,EAAE,MAAM;gCAChB,SAAS,EAAE,OAAO;gCAClB,QAAQ,EAAE,OAAO;gCACjB,SAAS,EAAE,GAAG;gCACd,YAAY,EAAE,GAAG;6BAClB,CAAC,CAAC;4BACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;4BACnD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;4BACpD,UAAU,CAAC,gBAAgB,EAAE,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;yBACrD,CAAC;qBACH;8BAGQ,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEyB,aAAa;sBAA3C,YAAY;uBAAC,eAAe;gBAEnB,EAAE;sBAAX,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACG,IAAI;sBAAb,MAAM","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"]}