myrta-ui 17.0.24 → 17.0.26
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/error-message/error-message.component.mjs +1 -1
- package/esm2022/lib/components/form/editor/editor.component.mjs +2 -2
- package/esm2022/lib/components/modal/modal.component.mjs +3 -3
- package/esm2022/lib/components/side-page/side-page.component.mjs +96 -55
- package/esm2022/lib/components/side-page/side-page.emun.mjs +6 -1
- package/esm2022/lib/services/modal-service/helpers/modal-ref.mjs +9 -1
- package/esm2022/lib/services/modal-service/modal-service.service.mjs +7 -2
- package/fesm2022/myrta-ui.mjs +111 -57
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/side-page/side-page.component.d.ts +25 -4
- package/lib/components/side-page/side-page.emun.d.ts +5 -0
- package/lib/services/modal-service/helpers/modal-ref.d.ts +3 -0
- package/lib/services/modal-service/modal-service.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -29,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
29
29
|
}], customClasses: [{
|
|
30
30
|
type: Input
|
|
31
31
|
}] } });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3ItbWVzc2FnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZXJyb3ItbWVzc2FnZS9lcnJvci1tZXNzYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL215cnRhLXVpL3NyYy9saWIvY29tcG9uZW50cy9lcnJvci1tZXNzYWdlL2Vycm9yLW1lc3NhZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVExRSxNQUFNLE9BQU8scUJBQXFCO0lBQ2hCLE9BQU8sR0FBWSxJQUFJLENBQUM7SUFDeEIsY0FBYyxHQUFzQixFQUFFLENBQUM7SUFDdkMsYUFBYSxHQUFHLEVBQUUsQ0FBQztJQUduQyxJQUFXLFVBQVU7UUFDbkIsT0FBTyxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNqQyxDQUFDO0lBRUQsSUFBVyxtQkFBbUI7UUFDNUIsSUFBSSxPQUFPLElBQUksQ0FBQyxjQUFjLEtBQUssUUFBUSxFQUFFLENBQUM7WUFDNUMsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3BDLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO1FBQzdCLENBQUM7SUFDSCxDQUFDO3dHQWhCVSxxQkFBcUI7NEZBQXJCLHFCQUFxQiwySkNSbEMscVFBU0E7OzRGRERhLHFCQUFxQjtrQkFOakMsU0FBUzsrQkFDRSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTTs4QkFHL0IsT0FBTztzQkFBdEIsS0FBSztnQkFDVSxjQUFjO3NCQUE3QixLQUFLO2dCQUNVLGFBQWE7c0JBQTVCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdtcngtZXJyb3ItbWVzc2FnZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Vycm9yLW1lc3NhZ2UuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWydlcnJvci1tZXNzYWdlLmNvbXBvbmVudC5sZXNzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFcnJvck1lc3NhZ2VDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBpbnZhbGlkOiBib29sZWFuID0gdHJ1ZTtcclxuICBASW5wdXQoKSBwdWJsaWMgaW52YWxpZE1lc3NhZ2U6IHN0cmluZyB8IHN0cmluZ1tdID0gJyc7XHJcbiAgQElucHV0KCkgcHVibGljIGN1c3RvbUNsYXNzZXMgPSAnJztcclxuXHJcblxyXG4gIHB1YmxpYyBnZXQgZ2V0Q2xhc3NlcygpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIGAke3RoaXMuY3VzdG9tQ2xhc3Nlc31gO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBpbnZhbGlkTWVzc2FnZUFycmF5KCk6IHN0cmluZ1tdIHtcclxuICAgIGlmICh0eXBlb2YgdGhpcy5pbnZhbGlkTWVzc2FnZSA9PT0gJ3N0cmluZycpIHtcclxuICAgICAgcmV0dXJuIEFycmF5KHRoaXMuaW52YWxpZE1lc3NhZ2UpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuIHRoaXMuaW52YWxpZE1lc3NhZ2U7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxzcGFuXHJcbiAgICAqbmdGb3I9XCJsZXQgaW52YWxpZE1lc3NhZ2Ugb2YgaW52YWxpZE1lc3NhZ2VBcnJheVwiXHJcbiAgICBjbGFzcz1cIm1yeC1lcnJvci1tZXNzYWdlIGQtYmxvY2sgbXQtMVwiXHJcbiAgICBbY2xhc3NdPVwiZ2V0Q2xhc3Nlc1wiXHJcbiAgICBbY2xhc3MuY29sb3ItbWVzc2FnZV09XCJpbnZhbGlkXCJcclxuPlxyXG4gIHt7aW52YWxpZE1lc3NhZ2V9fVxyXG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuPC9zcGFuPlxyXG4iXX0=
|
|
@@ -178,7 +178,7 @@ export class EditorComponent {
|
|
|
178
178
|
return `${this.customClasses} ${this.checkValidClasses}`;
|
|
179
179
|
}
|
|
180
180
|
insertPositionText(text) {
|
|
181
|
-
this.editorElementRef.
|
|
181
|
+
this.editorElementRef.jodit.s.insertHTML(text);
|
|
182
182
|
}
|
|
183
183
|
changeFocused(value) {
|
|
184
184
|
this.isFocused = value;
|
|
@@ -278,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
278
278
|
}], modelChange: [{
|
|
279
279
|
type: Output
|
|
280
280
|
}] } });
|
|
281
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnChanges,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { changeIconsFunction } from './modules/change-icon-module';\r\nimport { defaultToolbar } from './config';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { popupToolbars } from './config/popups-toolbar';\r\nimport { ToolbarConfig } from './models/toolbar.model';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { defaultInlineStyleConstant } from './config/default-inline-style';\r\n\r\nimport { Jodit } from 'jodit';\r\nimport { JoditConfig } from 'ngx-jodit';\r\n\r\nimport ru from 'jodit/esm/langs/ru.js';\r\n\r\nimport 'jodit/esm/plugins/source/source.js';\r\nimport 'jodit/esm/plugins/line-height/line-height.js';\r\nimport 'jodit/esm/plugins/indent/indent.js';\r\nimport 'jodit/esm/plugins/video/video.js';\r\nimport 'jodit/esm/plugins/search/search.js';\r\nimport { InputEditorModeEnum, InputEditorValueWithId } from './editor.enum';\r\n\r\nJodit.lang.de = ru;\r\n\r\n// export interface CustomJoditConfig extends JoditConfig {\r\n//   getIcon: (a: any) => void,\r\n//   link: any,\r\n//   cleanHTML: any,\r\n// }\r\n\r\n@Component({\r\n  selector: 'mrx-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => EditorComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n})\r\nexport class EditorComponent implements ControlValueAccessor, OnChanges {\r\n  private _isInit = false;\r\n  public value = '';\r\n  public valueLength = 0;\r\n  public isFocused: boolean | null = false;\r\n\r\n  public options = {\r\n    language: 'ru'\r\n  };\r\n\r\n  public defaultConfig: any = {\r\n    ...defaultToolbar,\r\n    popup: popupToolbars,\r\n    defaultMode: InputEditorModeEnum.MODE_WYSIWYG,\r\n    language: 'ru',\r\n    showCharsCounter: false,\r\n    showWordsCounter: false,\r\n    showXPathInStatusbar: false,\r\n    link: {\r\n      noFollowCheckbox: false\r\n    },\r\n    minHeight: 110,\r\n    iframe: false,\r\n    imageDefaultWidth: 200,\r\n    editHTMLDocumentMode: true,\r\n    cleanHTML: {\r\n      fillEmptyParagraph: true\r\n    },\r\n    placeholder: '',\r\n    toolbarAdaptive: false,\r\n    toolbarInline: true,\r\n    toolbarInlineForSelection: false,\r\n    toolbarInlineDisableFor: [],\r\n    toolbarInlineDisabledButtons: ['source'],\r\n    disabled: false,\r\n    readonly: false,\r\n    askBeforePasteHTML: false,\r\n    defaultActionOnPaste: 'insert_only_text',\r\n    askBeforePasteFromWord: false,\r\n    hidePoweredByJodit: true,\r\n    beautifyHTML: true,\r\n    addNewLine: true,\r\n    createAttributes: {},\r\n    getIcon: (iconName: string) => {\r\n      return changeIconsFunction(iconName);\r\n    },\r\n    events: {\r\n      focus: () => {\r\n        this.changeFocused(true);\r\n      },\r\n      blur: () => {\r\n        this.changeFocused(false);\r\n      }\r\n    }\r\n    // uploader: {\r\n    //   insertImageAsBase64URI: true\r\n    // },\r\n    // limitChars: 10,\r\n    // limitHTML: 170,\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public toolbar!: ToolbarConfig;\r\n  @Input() public maxLength = 0;\r\n  @Input() public minHeight = 110;\r\n  @Input() public customClasses = '';\r\n  @Input() public placeholder = '';\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public iframe = false;\r\n  @Input() public defaultInlineStyle = false;\r\n  @Input() public config: any = this.defaultConfig;\r\n\r\n  @Input() public editHTMLDocumentMode = false;\r\n  @Input() public defaultMode: InputEditorModeEnum = InputEditorModeEnum.MODE_WYSIWYG;\r\n\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('editorElementRef') editorElementRef!: any;\r\n\r\n  @Output() public changed: EventEmitter<string> = new EventEmitter<string>();\r\n  @Output() public modelChange: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\r\n\r\n  constructor(private changeDetection: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['toolbar']) {\r\n      this.defaultConfig = {...this.defaultConfig, ...changes['toolbar'].currentValue};\r\n    }\r\n    if (changes['maxLength']) {\r\n      this.defaultConfig = {...this.defaultConfig, limitChars: changes['maxLength'].currentValue};\r\n    }\r\n    if (changes['placeholder']) {\r\n      this.defaultConfig = {...this.defaultConfig, placeholder: changes['placeholder'].currentValue};\r\n    }\r\n    if (changes['disabled']) {\r\n      this.defaultConfig = {...this.defaultConfig, disabled: changes['disabled'].currentValue};\r\n    }\r\n    if (changes['readonly']) {\r\n      this.defaultConfig = {...this.defaultConfig, readonly: changes['readonly'].currentValue};\r\n    }\r\n    if (changes['iframe']) {\r\n      this.defaultConfig = {...this.defaultConfig, iframe: changes['iframe'].currentValue};\r\n    }\r\n    if (changes['defaultInlineStyle']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        createAttributes: {...this.defaultConfig.createAttributes, ...defaultInlineStyleConstant}\r\n      };\r\n    }\r\n    if (changes['editHTMLDocumentMode']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        editHTMLDocumentMode: changes['editHTMLDocumentMode'].currentValue\r\n      };\r\n    }\r\n    if (changes['askBeforePasteHTML']) {\r\n      this.defaultConfig = {...this.defaultConfig, askBeforePasteHTML: changes['askBeforePasteHTML'].currentValue};\r\n    }\r\n    if (changes['askBeforePasteFromWord']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        askBeforePasteFromWord: changes['askBeforePasteFromWord'].currentValue\r\n      };\r\n    }\r\n    if (changes['defaultMode']) {\r\n      this.defaultConfig = {...this.defaultConfig, defaultMode: changes['defaultMode'].currentValue};\r\n    }\r\n    if (changes['defaultActionOnPaste']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        defaultActionOnPaste: changes['defaultActionOnPaste'].currentValue\r\n      };\r\n    }\r\n    if (changes['minHeight']) {\r\n      this.defaultConfig = {...this.defaultConfig, minHeight: changes['minHeight'].currentValue};\r\n    }\r\n    if (changes['config']) {\r\n      this.defaultConfig = {...this.defaultConfig, ...changes['config'].currentValue};\r\n    }\r\n  }\r\n\r\n  public get isValid(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public insertPositionText(text: string) {\r\n    this.editorElementRef.editor.s.insertHTML(text);\r\n  }\r\n\r\n  public changeFocused(value: boolean): void {\r\n    this.isFocused = value;\r\n    this.changeDetection.detectChanges();\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: any) {\r\n    this.value = this._sanitizeValue(outsideValue);\r\n    if (outsideValue !== null) {\r\n      setTimeout(() => {\r\n        this._isInit = true;\r\n      }, 100);\r\n    }\r\n  }\r\n\r\n  public updateValue(insideValue: string) {\r\n\r\n    if (this.maxLength) {\r\n      this._calculateChartsCount();\r\n    }\r\n    if (this._isInit) {\r\n      this.value = insideValue;\r\n      this.changed.emit(insideValue);\r\n      this.modelChange.emit({value: insideValue, id: this.uuid});\r\n      this.onChange(insideValue);\r\n      this.onTouched();\r\n    }\r\n  }\r\n\r\n  private _sanitizeValue(value: string): string {\r\n    return value ? value.replace(/<script\\b[^<]*(?:(?!<\\/script>)<[^<]*)*<\\/script>/gi, '') : value;\r\n  }\r\n\r\n  private _calculateChartsCount() {\r\n    this.valueLength = this.editorElementRef.editor.text.replace(/\\s+/g, '').length;\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-editor\"\r\n  [class.mrx-input-focused]=\"isFocused\"\r\n  [class.mrx-input-error]=\"!isValid || invalid\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <ngx-jodit\r\n    #editorElementRef\r\n    [(ngModel)]=\"value\"\r\n    [options]=\"defaultConfig\"\r\n    (ngModelChange)=\"updateValue($event)\"\r\n  ></ngx-jodit>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"(!isValid || invalid) && isInvalidMessage\"\r\n    [invalidMessage]=\"invalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-chars-left [maxlength]=\"maxLength\" [valueLength]=\"valueLength\"></mrx-chars-left>\r\n\r\n  <mrx-save-state type=\"editor\" [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnChanges,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { changeIconsFunction } from './modules/change-icon-module';\r\nimport { defaultToolbar } from './config';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { popupToolbars } from './config/popups-toolbar';\r\nimport { ToolbarConfig } from './models/toolbar.model';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { defaultInlineStyleConstant } from './config/default-inline-style';\r\n\r\nimport { Jodit } from 'jodit';\r\nimport { JoditConfig } from 'ngx-jodit';\r\n\r\nimport ru from 'jodit/esm/langs/ru.js';\r\n\r\nimport 'jodit/esm/plugins/source/source.js';\r\nimport 'jodit/esm/plugins/line-height/line-height.js';\r\nimport 'jodit/esm/plugins/indent/indent.js';\r\nimport 'jodit/esm/plugins/video/video.js';\r\nimport 'jodit/esm/plugins/search/search.js';\r\nimport { InputEditorModeEnum, InputEditorValueWithId } from './editor.enum';\r\n\r\nJodit.lang.de = ru;\r\n\r\n// export interface CustomJoditConfig extends JoditConfig {\r\n//   getIcon: (a: any) => void,\r\n//   link: any,\r\n//   cleanHTML: any,\r\n// }\r\n\r\n@Component({\r\n  selector: 'mrx-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => EditorComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n})\r\nexport class EditorComponent implements ControlValueAccessor, OnChanges {\r\n  private _isInit = false;\r\n  public value = '';\r\n  public valueLength = 0;\r\n  public isFocused: boolean | null = false;\r\n\r\n  public options = {\r\n    language: 'ru'\r\n  };\r\n\r\n  public defaultConfig: any = {\r\n    ...defaultToolbar,\r\n    popup: popupToolbars,\r\n    defaultMode: InputEditorModeEnum.MODE_WYSIWYG,\r\n    language: 'ru',\r\n    showCharsCounter: false,\r\n    showWordsCounter: false,\r\n    showXPathInStatusbar: false,\r\n    link: {\r\n      noFollowCheckbox: false\r\n    },\r\n    minHeight: 110,\r\n    iframe: false,\r\n    imageDefaultWidth: 200,\r\n    editHTMLDocumentMode: true,\r\n    cleanHTML: {\r\n      fillEmptyParagraph: true\r\n    },\r\n    placeholder: '',\r\n    toolbarAdaptive: false,\r\n    toolbarInline: true,\r\n    toolbarInlineForSelection: false,\r\n    toolbarInlineDisableFor: [],\r\n    toolbarInlineDisabledButtons: ['source'],\r\n    disabled: false,\r\n    readonly: false,\r\n    askBeforePasteHTML: false,\r\n    defaultActionOnPaste: 'insert_only_text',\r\n    askBeforePasteFromWord: false,\r\n    hidePoweredByJodit: true,\r\n    beautifyHTML: true,\r\n    addNewLine: true,\r\n    createAttributes: {},\r\n    getIcon: (iconName: string) => {\r\n      return changeIconsFunction(iconName);\r\n    },\r\n    events: {\r\n      focus: () => {\r\n        this.changeFocused(true);\r\n      },\r\n      blur: () => {\r\n        this.changeFocused(false);\r\n      }\r\n    }\r\n    // uploader: {\r\n    //   insertImageAsBase64URI: true\r\n    // },\r\n    // limitChars: 10,\r\n    // limitHTML: 170,\r\n  };\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public toolbar!: ToolbarConfig;\r\n  @Input() public maxLength = 0;\r\n  @Input() public minHeight = 110;\r\n  @Input() public customClasses = '';\r\n  @Input() public placeholder = '';\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public iframe = false;\r\n  @Input() public defaultInlineStyle = false;\r\n  @Input() public config: any = this.defaultConfig;\r\n\r\n  @Input() public editHTMLDocumentMode = false;\r\n  @Input() public defaultMode: InputEditorModeEnum = InputEditorModeEnum.MODE_WYSIWYG;\r\n\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('editorElementRef') editorElementRef!: any;\r\n\r\n  @Output() public changed: EventEmitter<string> = new EventEmitter<string>();\r\n  @Output() public modelChange: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\r\n\r\n  constructor(private changeDetection: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['toolbar']) {\r\n      this.defaultConfig = {...this.defaultConfig, ...changes['toolbar'].currentValue};\r\n    }\r\n    if (changes['maxLength']) {\r\n      this.defaultConfig = {...this.defaultConfig, limitChars: changes['maxLength'].currentValue};\r\n    }\r\n    if (changes['placeholder']) {\r\n      this.defaultConfig = {...this.defaultConfig, placeholder: changes['placeholder'].currentValue};\r\n    }\r\n    if (changes['disabled']) {\r\n      this.defaultConfig = {...this.defaultConfig, disabled: changes['disabled'].currentValue};\r\n    }\r\n    if (changes['readonly']) {\r\n      this.defaultConfig = {...this.defaultConfig, readonly: changes['readonly'].currentValue};\r\n    }\r\n    if (changes['iframe']) {\r\n      this.defaultConfig = {...this.defaultConfig, iframe: changes['iframe'].currentValue};\r\n    }\r\n    if (changes['defaultInlineStyle']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        createAttributes: {...this.defaultConfig.createAttributes, ...defaultInlineStyleConstant}\r\n      };\r\n    }\r\n    if (changes['editHTMLDocumentMode']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        editHTMLDocumentMode: changes['editHTMLDocumentMode'].currentValue\r\n      };\r\n    }\r\n    if (changes['askBeforePasteHTML']) {\r\n      this.defaultConfig = {...this.defaultConfig, askBeforePasteHTML: changes['askBeforePasteHTML'].currentValue};\r\n    }\r\n    if (changes['askBeforePasteFromWord']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        askBeforePasteFromWord: changes['askBeforePasteFromWord'].currentValue\r\n      };\r\n    }\r\n    if (changes['defaultMode']) {\r\n      this.defaultConfig = {...this.defaultConfig, defaultMode: changes['defaultMode'].currentValue};\r\n    }\r\n    if (changes['defaultActionOnPaste']) {\r\n      this.defaultConfig = {\r\n        ...this.defaultConfig,\r\n        defaultActionOnPaste: changes['defaultActionOnPaste'].currentValue\r\n      };\r\n    }\r\n    if (changes['minHeight']) {\r\n      this.defaultConfig = {...this.defaultConfig, minHeight: changes['minHeight'].currentValue};\r\n    }\r\n    if (changes['config']) {\r\n      this.defaultConfig = {...this.defaultConfig, ...changes['config'].currentValue};\r\n    }\r\n  }\r\n\r\n  public get isValid(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage?.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${this.customClasses} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public insertPositionText(text: string) {\r\n    this.editorElementRef.jodit.s.insertHTML(text);\r\n  }\r\n\r\n  public changeFocused(value: boolean): void {\r\n    this.isFocused = value;\r\n    this.changeDetection.detectChanges();\r\n  }\r\n\r\n  private onChange = (value: any) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: any) {\r\n    this.value = this._sanitizeValue(outsideValue);\r\n    if (outsideValue !== null) {\r\n      setTimeout(() => {\r\n        this._isInit = true;\r\n      }, 100);\r\n    }\r\n  }\r\n\r\n  public updateValue(insideValue: string) {\r\n\r\n    if (this.maxLength) {\r\n      this._calculateChartsCount();\r\n    }\r\n    if (this._isInit) {\r\n      this.value = insideValue;\r\n      this.changed.emit(insideValue);\r\n      this.modelChange.emit({value: insideValue, id: this.uuid});\r\n      this.onChange(insideValue);\r\n      this.onTouched();\r\n    }\r\n  }\r\n\r\n  private _sanitizeValue(value: string): string {\r\n    return value ? value.replace(/<script\\b[^<]*(?:(?!<\\/script>)<[^<]*)*<\\/script>/gi, '') : value;\r\n  }\r\n\r\n  private _calculateChartsCount() {\r\n    this.valueLength = this.editorElementRef.editor.text.replace(/\\s+/g, '').length;\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-editor\"\r\n  [class.mrx-input-focused]=\"isFocused\"\r\n  [class.mrx-input-error]=\"!isValid || invalid\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <ngx-jodit\r\n    #editorElementRef\r\n    [(ngModel)]=\"value\"\r\n    [options]=\"defaultConfig\"\r\n    (ngModelChange)=\"updateValue($event)\"\r\n  ></ngx-jodit>\r\n\r\n  <mrx-error-message\r\n    *ngIf=\"(!isValid || invalid) && isInvalidMessage\"\r\n    [invalidMessage]=\"invalidMessage\"\r\n  ></mrx-error-message>\r\n\r\n  <mrx-chars-left [maxlength]=\"maxLength\" [valueLength]=\"valueLength\"></mrx-chars-left>\r\n\r\n  <mrx-save-state type=\"editor\" [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -7,8 +7,8 @@ import * as i2 from "../button/button.component";
|
|
|
7
7
|
export class ModalComponent {
|
|
8
8
|
title = '';
|
|
9
9
|
message = '';
|
|
10
|
-
okText = '
|
|
11
|
-
closeText = '
|
|
10
|
+
okText = 'Подтвердить';
|
|
11
|
+
closeText = 'Отменить';
|
|
12
12
|
size = 'small';
|
|
13
13
|
color = 'default';
|
|
14
14
|
customClasses = '';
|
|
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
134
134
|
}], back: [{
|
|
135
135
|
type: Output
|
|
136
136
|
}] } });
|
|
137
|
-
//# 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  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() okText = 'Отменить'\r\n\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    <span\r\n        *ngIf=\"expandable\"\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    <span class=\"mrx-icon icon-close icon-font-24\" *ngIf=\"isClose\" (click)=\"onClose()\"></span>\r\n  </div>\r\n\r\n  <div class=\"mrx-modal-body\">\r\n    <div *ngIf=\"isBack\" 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    <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n\r\n  <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\" *ngIf=\"enableFooter\">\r\n    <ng-container *ngIf=\"!footerContent; else footerContentTemplate\">\r\n      <mrx-button\r\n          [customClasses]=\"'mr-3'\"\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    </ng-container>\r\n\r\n    <ng-template #footerContentTemplate>\r\n      <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n    </ng-template>\r\n  </div>\r\n</div>\r\n"]}
|
|
137
|
+
//# 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  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() 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    <span\r\n        *ngIf=\"expandable\"\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    <span class=\"mrx-icon icon-close icon-font-24\" *ngIf=\"isClose\" (click)=\"onClose()\"></span>\r\n  </div>\r\n\r\n  <div class=\"mrx-modal-body\">\r\n    <div *ngIf=\"isBack\" 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    <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n\r\n  <div class=\"mrx-modal-footer\" [class]=\"alignButtonsClass\" *ngIf=\"enableFooter\">\r\n    <ng-container *ngIf=\"!footerContent; else footerContentTemplate\">\r\n      <mrx-button\r\n          [customClasses]=\"'mr-3'\"\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    </ng-container>\r\n\r\n    <ng-template #footerContentTemplate>\r\n      <ng-container *ngTemplateOutlet=\"footerContent\"></ng-container>\r\n    </ng-template>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -1,14 +1,39 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
-
import { SidePagePositionEnum, SidePageSizesEnum } from './side-page.emun';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { SidePageHeaderSizesEnum, SidePagePositionEnum, SidePageSizesEnum } from './side-page.emun';
|
|
3
3
|
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
4
|
+
import { delay, of } from 'rxjs';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../button/button.component";
|
|
8
|
+
import * as i3 from "../breadcrumbs/breadcrumbs.component";
|
|
9
|
+
import * as i4 from "../cdk-tooltip/cdk-tooltip.directive";
|
|
10
|
+
import * as i5 from "../error-message/error-message.component";
|
|
6
11
|
export class SidePageComponent {
|
|
7
12
|
detector;
|
|
13
|
+
title = '';
|
|
14
|
+
tooltip = '';
|
|
8
15
|
isOpen = false;
|
|
9
16
|
size = 'large';
|
|
10
17
|
position = 'right';
|
|
11
18
|
customClasses = '';
|
|
19
|
+
enableHeader = true;
|
|
20
|
+
enableFooter = true;
|
|
21
|
+
headerSize = 'large';
|
|
22
|
+
paddingTop = '';
|
|
23
|
+
okText = 'Подтвердить';
|
|
24
|
+
closeText = 'Отменить';
|
|
25
|
+
isLoading = false;
|
|
26
|
+
// BackArrow
|
|
27
|
+
isBack = false;
|
|
28
|
+
backText = 'Назад';
|
|
29
|
+
backRouterLink = '/';
|
|
30
|
+
backQueryParams = {};
|
|
31
|
+
closeAfterLink = true;
|
|
32
|
+
// Error message
|
|
33
|
+
invalid = false;
|
|
34
|
+
invalidMessage = '';
|
|
35
|
+
headerTemplate;
|
|
36
|
+
footerTemplate;
|
|
12
37
|
ok = new EventEmitter();
|
|
13
38
|
close = new EventEmitter();
|
|
14
39
|
back = new EventEmitter();
|
|
@@ -23,47 +48,45 @@ export class SidePageComponent {
|
|
|
23
48
|
get getClasses() {
|
|
24
49
|
return `${SidePageSizesEnum[this.size]} ${SidePagePositionEnum[this.position]} ${this.customClasses}`;
|
|
25
50
|
}
|
|
51
|
+
get getHeaderClasses() {
|
|
52
|
+
return `${SidePageHeaderSizesEnum[this.headerSize]}`;
|
|
53
|
+
}
|
|
26
54
|
onOk() {
|
|
27
|
-
this.
|
|
55
|
+
this.toggleSidePage(false)
|
|
56
|
+
.pipe(delay(300))
|
|
57
|
+
.subscribe(() => {
|
|
58
|
+
this.ok.emit();
|
|
59
|
+
});
|
|
28
60
|
}
|
|
29
61
|
onClose() {
|
|
30
|
-
this.toggleSidePage(false)
|
|
31
|
-
|
|
62
|
+
this.toggleSidePage(false)
|
|
63
|
+
.pipe(delay(300))
|
|
64
|
+
.subscribe(() => {
|
|
32
65
|
this.close.emit();
|
|
33
|
-
}
|
|
66
|
+
});
|
|
34
67
|
}
|
|
35
68
|
toggleSidePage(value) {
|
|
36
69
|
this.isOpen = value;
|
|
37
70
|
this.detector.detectChanges();
|
|
71
|
+
return of(true);
|
|
72
|
+
}
|
|
73
|
+
closeModal() {
|
|
74
|
+
if (this.closeAfterLink) {
|
|
75
|
+
this.toggleSidePage(false)
|
|
76
|
+
.pipe(delay(300))
|
|
77
|
+
.subscribe(() => {
|
|
78
|
+
this.close.emit();
|
|
79
|
+
});
|
|
80
|
+
}
|
|
38
81
|
}
|
|
39
82
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SidePageComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SidePageComponent, selector: "mrx-side-page", inputs: { isOpen: "isOpen", size: "size", position: "position", customClasses: "customClasses" }, outputs: { ok: "ok", close: "close", back: "back" }, ngImport: i0, template: "<div\r\n class=\"mrx-side-page-content\"\r\n [class]=\"getClasses\"\r\n [@animateExpandLarge]=\"size === 'large' ? isOpen ? 'open' : 'closed' : ''\"\r\n [@animateExpandMedium]=\"size === 'medium' ? isOpen ? 'open' : 'closed' : ''\"\r\n [@animateExpandSmall]=\"size === 'small' ? isOpen ? 'open' : 'closed' : ''\"\r\n>\r\n <div class=\"mrx-side-page-header brdb\">\r\n\r\n <div class=\"mrx-side-page-header__content\">\r\n <h2 class=\"mrx-side-page-header__content--title\">\r\n <span>Title</span>\r\n <span class=\"mrx-icon icon-info icon-font-16\" mrxCdkTooltip=\"asdasdasdasda\"></span>\r\n </h2>\r\n </div>\r\n\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n </div>\r\n\r\n<!-- <div class=\"mrx-modal-body\">-->\r\n<!-- <div *ngIf=\"isBack\" 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<!-- <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>-->\r\n<!-- <ng-content></ng-content>-->\r\n<!-- </div>-->\r\n\r\n\r\n <div class=\"mrx-side-page-footer brdt\">\r\n asdasd\r\n </div>\r\n</div>\r\n", styles: [".mrx-side-page-content{display:flex;flex-direction:column;justify-content:space-between;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}::ng-deep .mrx-side-page-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-side-page-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}.mrx-side-page-content.mrx-side-page--position-right{position:absolute;top:0;right:0;bottom:0}.mrx-side-page-content.mrx-side-page--position-left{position:absolute;top:0;left:0;bottom:0}.mrx-side-page--lg{width:620px}.mrx-side-page--md{width:400px}.mrx-side-page--sm{width:280px}.mrx-side-page-header{padding:24px;position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-side-page-header__content{display:flex;flex-direction:column;align-items:flex-start;min-height:24px}.mrx-side-page-header__content--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)}.mrx-side-page-header__content--title span{display:inline}.mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-header .icon-close{position:absolute;top:24px;right:24px;cursor:pointer}.mrx-side-page-header .icon-close:hover{transform:scale(1.1)}.mrx-side-page-footer{padding:24px;min-height:24px}\n"], dependencies: [{ kind: "directive", type: i1.CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }], animations: [
|
|
41
|
-
trigger('
|
|
42
|
-
state('open', style({
|
|
43
|
-
transform: 'translateX(0)'
|
|
44
|
-
})),
|
|
45
|
-
state('closed', style({
|
|
46
|
-
transform: 'translateX(620px)'
|
|
47
|
-
})),
|
|
48
|
-
transition('open => closed', [animate('0.5s ease')]),
|
|
49
|
-
transition('closed => open', [animate('0.5s ease')]),
|
|
50
|
-
]),
|
|
51
|
-
trigger('animateExpandMedium', [
|
|
52
|
-
state('open', style({
|
|
53
|
-
transform: 'translateX(0)'
|
|
54
|
-
})),
|
|
55
|
-
state('closed', style({
|
|
56
|
-
transform: 'translateX(400px)'
|
|
57
|
-
})),
|
|
58
|
-
transition('open => closed', [animate('0.5s ease')]),
|
|
59
|
-
transition('closed => open', [animate('0.5s ease')]),
|
|
60
|
-
]),
|
|
61
|
-
trigger('animateExpandSmall', [
|
|
83
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: SidePageComponent, selector: "mrx-side-page", inputs: { title: "title", tooltip: "tooltip", isOpen: "isOpen", size: "size", position: "position", customClasses: "customClasses", enableHeader: "enableHeader", enableFooter: "enableFooter", headerSize: "headerSize", paddingTop: "paddingTop", okText: "okText", closeText: "closeText", isLoading: "isLoading", isBack: "isBack", backText: "backText", backRouterLink: "backRouterLink", backQueryParams: "backQueryParams", closeAfterLink: "closeAfterLink", invalid: "invalid", invalidMessage: "invalidMessage" }, outputs: { ok: "ok", close: "close", back: "back" }, queries: [{ propertyName: "headerTemplate", first: true, predicate: ["headerTemplate"], descendants: true }, { propertyName: "footerTemplate", first: true, predicate: ["footerTemplate"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-side-page-content\"\r\n [class]=\"getClasses\"\r\n [style.top]=\"paddingTop\"\r\n [@animateExpand]=\"isOpen ? 'open' : 'closed'\"\r\n>\r\n @if (enableHeader) {\r\n @if (!headerTemplate) {\r\n <div class=\"mrx-side-page-header brdb\" [class]=\"getHeaderClasses\">\r\n <div class=\"mrx-side-page-header__content\">\r\n @if (isBack) {\r\n <mrx-breadcrumbs\r\n type=\"link\"\r\n customClasses=\"mb-2\"\r\n [item]=\"{\r\n text: backText,\r\n routerLink: backRouterLink,\r\n queryParams: backQueryParams,\r\n isShowArrow: true\r\n }\"\r\n (click)=\"closeModal()\"\r\n ></mrx-breadcrumbs>\r\n }\r\n\r\n <h2 class=\"mrx-side-page-header__content--title\">\r\n @if (title) {\r\n <span>{{ title }}</span>\r\n }\r\n\r\n @if (tooltip) {\r\n <span class=\"mrx-icon icon-info icon-font-16\" [mrxCdkTooltip]=\"tooltip\"></span>\r\n }\r\n </h2>\r\n </div>\r\n\r\n <span class=\"mrx-icon icon-close\" (click)=\"onClose()\"></span>\r\n </div>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\r\n }\r\n }\r\n\r\n <div class=\"mrx-side-page-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n @if (!footerTemplate) {\r\n <div class=\"mrx-side-page-footer brdt\">\r\n @if (invalidMessage) {\r\n <mrx-error-message [invalid]=\"invalid\">{{ invalidMessage }}</mrx-error-message>\r\n }\r\n\r\n <div class=\"mrx-side-page-footer__controls\">\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"'default'\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{ closeText }}\r\n </mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"'default'\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </div>\r\n </div>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n }\r\n }\r\n</div>\r\n", styles: [".mrx-side-page-content{display:flex;flex-direction:column;justify-content:space-between;max-width:100%;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}::ng-deep .mrx-side-page-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-side-page-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}.mrx-side-page-content.mrx-side-page--position-right{position:absolute;top:0;right:0;bottom:0}.mrx-side-page-content.mrx-side-page--position-left{position:absolute;top:0;left:0;bottom:0}.mrx-side-page--lg{width:620px}.mrx-side-page--md{width:400px}.mrx-side-page--sm{width:280px}@media (max-width: 576px){.mrx-side-page--lg,.mrx-side-page--md,.mrx-side-page--sm{width:100%}}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm{padding:16px 56px 16px 24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .icon-close{top:calc(50% - 12px);right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm{padding:16px 40px 16px 24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--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)}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .icon-close{top:calc(50% - 8px);right:16px;font-size:16px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm{padding:16px 40px 16px 24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--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)}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .icon-close{top:calc(50% - 8px);right:16px;font-size:16px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content .mrx-side-page-header{position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-side-page-content .mrx-side-page-header__content{display:flex;flex-direction:column;align-items:flex-start;min-height:24px}.mrx-side-page-content .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content .mrx-side-page-header .icon-close{position:absolute;cursor:pointer}.mrx-side-page-content .mrx-side-page-header .icon-close:hover{transform:scale(1.1)}.mrx-side-page-footer{padding:24px;min-height:24px;display:flex;flex-direction:column;align-items:flex-start;gap:16px}.mrx-side-page-footer__controls{display:flex;align-items:center;justify-content:flex-start;gap:16px}:host::ng-deep .mrx-error-message{margin-top:0!important}.mrx-side-page-body{flex-grow:1}\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"], outputs: ["mrxClick"] }, { kind: "component", type: i3.BreadcrumbsComponent, selector: "mrx-breadcrumbs", inputs: ["type", "items", "item", "customClasses"] }, { kind: "directive", type: i4.CdkTooltipDirective, selector: "[mrxCdkTooltip]", inputs: ["mrxCdkTooltip", "tooltipActive", "autoCloseByScroll", "tooltipPosition", "tooltipMaxWidth"] }, { kind: "component", type: i5.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }], animations: [
|
|
84
|
+
trigger('animateExpand', [
|
|
62
85
|
state('open', style({
|
|
63
86
|
transform: 'translateX(0)'
|
|
64
87
|
})),
|
|
65
88
|
state('closed', style({
|
|
66
|
-
transform: 'translateX(
|
|
89
|
+
transform: 'translateX(100%)'
|
|
67
90
|
})),
|
|
68
91
|
transition('open => closed', [animate('0.5s ease')]),
|
|
69
92
|
transition('closed => open', [animate('0.5s ease')]),
|
|
@@ -73,38 +96,22 @@ export class SidePageComponent {
|
|
|
73
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SidePageComponent, decorators: [{
|
|
74
97
|
type: Component,
|
|
75
98
|
args: [{ selector: 'mrx-side-page', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
76
|
-
trigger('
|
|
99
|
+
trigger('animateExpand', [
|
|
77
100
|
state('open', style({
|
|
78
101
|
transform: 'translateX(0)'
|
|
79
102
|
})),
|
|
80
103
|
state('closed', style({
|
|
81
|
-
transform: 'translateX(
|
|
104
|
+
transform: 'translateX(100%)'
|
|
82
105
|
})),
|
|
83
106
|
transition('open => closed', [animate('0.5s ease')]),
|
|
84
107
|
transition('closed => open', [animate('0.5s ease')]),
|
|
85
108
|
]),
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
})),
|
|
93
|
-
transition('open => closed', [animate('0.5s ease')]),
|
|
94
|
-
transition('closed => open', [animate('0.5s ease')]),
|
|
95
|
-
]),
|
|
96
|
-
trigger('animateExpandSmall', [
|
|
97
|
-
state('open', style({
|
|
98
|
-
transform: 'translateX(0)'
|
|
99
|
-
})),
|
|
100
|
-
state('closed', style({
|
|
101
|
-
transform: 'translateX(280px)'
|
|
102
|
-
})),
|
|
103
|
-
transition('open => closed', [animate('0.5s ease')]),
|
|
104
|
-
transition('closed => open', [animate('0.5s ease')]),
|
|
105
|
-
]),
|
|
106
|
-
], template: "<div\r\n class=\"mrx-side-page-content\"\r\n [class]=\"getClasses\"\r\n [@animateExpandLarge]=\"size === 'large' ? isOpen ? 'open' : 'closed' : ''\"\r\n [@animateExpandMedium]=\"size === 'medium' ? isOpen ? 'open' : 'closed' : ''\"\r\n [@animateExpandSmall]=\"size === 'small' ? isOpen ? 'open' : 'closed' : ''\"\r\n>\r\n <div class=\"mrx-side-page-header brdb\">\r\n\r\n <div class=\"mrx-side-page-header__content\">\r\n <h2 class=\"mrx-side-page-header__content--title\">\r\n <span>Title</span>\r\n <span class=\"mrx-icon icon-info icon-font-16\" mrxCdkTooltip=\"asdasdasdasda\"></span>\r\n </h2>\r\n </div>\r\n\r\n <span class=\"mrx-icon icon-close icon-font-24\" (click)=\"onClose()\"></span>\r\n </div>\r\n\r\n<!-- <div class=\"mrx-modal-body\">-->\r\n<!-- <div *ngIf=\"isBack\" 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<!-- <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>-->\r\n<!-- <ng-content></ng-content>-->\r\n<!-- </div>-->\r\n\r\n\r\n <div class=\"mrx-side-page-footer brdt\">\r\n asdasd\r\n </div>\r\n</div>\r\n", styles: [".mrx-side-page-content{display:flex;flex-direction:column;justify-content:space-between;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}::ng-deep .mrx-side-page-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-side-page-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}.mrx-side-page-content.mrx-side-page--position-right{position:absolute;top:0;right:0;bottom:0}.mrx-side-page-content.mrx-side-page--position-left{position:absolute;top:0;left:0;bottom:0}.mrx-side-page--lg{width:620px}.mrx-side-page--md{width:400px}.mrx-side-page--sm{width:280px}.mrx-side-page-header{padding:24px;position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-side-page-header__content{display:flex;flex-direction:column;align-items:flex-start;min-height:24px}.mrx-side-page-header__content--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)}.mrx-side-page-header__content--title span{display:inline}.mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-header .icon-close{position:absolute;top:24px;right:24px;cursor:pointer}.mrx-side-page-header .icon-close:hover{transform:scale(1.1)}.mrx-side-page-footer{padding:24px;min-height:24px}\n"] }]
|
|
107
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { isOpen: [{
|
|
109
|
+
], template: "<div\r\n class=\"mrx-side-page-content\"\r\n [class]=\"getClasses\"\r\n [style.top]=\"paddingTop\"\r\n [@animateExpand]=\"isOpen ? 'open' : 'closed'\"\r\n>\r\n @if (enableHeader) {\r\n @if (!headerTemplate) {\r\n <div class=\"mrx-side-page-header brdb\" [class]=\"getHeaderClasses\">\r\n <div class=\"mrx-side-page-header__content\">\r\n @if (isBack) {\r\n <mrx-breadcrumbs\r\n type=\"link\"\r\n customClasses=\"mb-2\"\r\n [item]=\"{\r\n text: backText,\r\n routerLink: backRouterLink,\r\n queryParams: backQueryParams,\r\n isShowArrow: true\r\n }\"\r\n (click)=\"closeModal()\"\r\n ></mrx-breadcrumbs>\r\n }\r\n\r\n <h2 class=\"mrx-side-page-header__content--title\">\r\n @if (title) {\r\n <span>{{ title }}</span>\r\n }\r\n\r\n @if (tooltip) {\r\n <span class=\"mrx-icon icon-info icon-font-16\" [mrxCdkTooltip]=\"tooltip\"></span>\r\n }\r\n </h2>\r\n </div>\r\n\r\n <span class=\"mrx-icon icon-close\" (click)=\"onClose()\"></span>\r\n </div>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\r\n }\r\n }\r\n\r\n <div class=\"mrx-side-page-body\">\r\n <ng-content></ng-content>\r\n </div>\r\n\r\n @if (enableFooter) {\r\n @if (!footerTemplate) {\r\n <div class=\"mrx-side-page-footer brdt\">\r\n @if (invalidMessage) {\r\n <mrx-error-message [invalid]=\"invalid\">{{ invalidMessage }}</mrx-error-message>\r\n }\r\n\r\n <div class=\"mrx-side-page-footer__controls\">\r\n <mrx-button\r\n [type]=\"'secondary'\"\r\n [color]=\"'default'\"\r\n [size]=\"'medium'\"\r\n (click)=\"onClose()\"\r\n >{{ closeText }}\r\n </mrx-button>\r\n\r\n <mrx-button\r\n [type]=\"'primary'\"\r\n [size]=\"'medium'\"\r\n [color]=\"'default'\"\r\n [isLoading]=\"isLoading\"\r\n (click)=\"onOk()\"\r\n >{{ okText }}\r\n </mrx-button>\r\n </div>\r\n </div>\r\n } @else {\r\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n }\r\n }\r\n</div>\r\n", styles: [".mrx-side-page-content{display:flex;flex-direction:column;justify-content:space-between;max-width:100%;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}::ng-deep .mrx-side-page-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-side-page-backdrop.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{background-color:var(--neutral-bg-modal)}.mrx-side-page-content.mrx-side-page--position-right{position:absolute;top:0;right:0;bottom:0}.mrx-side-page-content.mrx-side-page--position-left{position:absolute;top:0;left:0;bottom:0}.mrx-side-page--lg{width:620px}.mrx-side-page--md{width:400px}.mrx-side-page--sm{width:280px}@media (max-width: 576px){.mrx-side-page--lg,.mrx-side-page--md,.mrx-side-page--sm{width:100%}}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm{padding:16px 56px 16px 24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--sm .icon-close{top:calc(50% - 12px);right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--lg .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm{padding:16px 40px 16px 24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--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)}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--sm .icon-close{top:calc(50% - 8px);right:16px;font-size:16px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--md .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm{padding:16px 40px 16px 24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--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)}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--sm .icon-close{top:calc(50% - 8px);right:16px;font-size:16px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg{padding:24px 56px 24px 24px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title{font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content.mrx-side-page--sm .mrx-side-page-header--lg .icon-close{top:16px;right:16px;font-size:24px}.mrx-side-page-content .mrx-side-page-header{position:relative;border-top-left-radius:4px;border-top-right-radius:4px}.mrx-side-page-content .mrx-side-page-header__content{display:flex;flex-direction:column;align-items:flex-start;min-height:24px}.mrx-side-page-content .mrx-side-page-header__content--title span{display:inline}.mrx-side-page-content .mrx-side-page-header__content--title span.mrx-icon{margin-left:8px}.mrx-side-page-content .mrx-side-page-header .icon-close{position:absolute;cursor:pointer}.mrx-side-page-content .mrx-side-page-header .icon-close:hover{transform:scale(1.1)}.mrx-side-page-footer{padding:24px;min-height:24px;display:flex;flex-direction:column;align-items:flex-start;gap:16px}.mrx-side-page-footer__controls{display:flex;align-items:center;justify-content:flex-start;gap:16px}:host::ng-deep .mrx-error-message{margin-top:0!important}.mrx-side-page-body{flex-grow:1}\n"] }]
|
|
110
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { title: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], tooltip: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], isOpen: [{
|
|
108
115
|
type: Input
|
|
109
116
|
}], size: [{
|
|
110
117
|
type: Input
|
|
@@ -112,6 +119,40 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
112
119
|
type: Input
|
|
113
120
|
}], customClasses: [{
|
|
114
121
|
type: Input
|
|
122
|
+
}], enableHeader: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], enableFooter: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], headerSize: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], paddingTop: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], okText: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], closeText: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], isLoading: [{
|
|
135
|
+
type: Input
|
|
136
|
+
}], isBack: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], backText: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], backRouterLink: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], backQueryParams: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], closeAfterLink: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], invalid: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], invalidMessage: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], headerTemplate: [{
|
|
151
|
+
type: ContentChild,
|
|
152
|
+
args: ['headerTemplate']
|
|
153
|
+
}], footerTemplate: [{
|
|
154
|
+
type: ContentChild,
|
|
155
|
+
args: ['footerTemplate']
|
|
115
156
|
}], ok: [{
|
|
116
157
|
type: Output
|
|
117
158
|
}], close: [{
|
|
@@ -119,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
119
160
|
}], back: [{
|
|
120
161
|
type: Output
|
|
121
162
|
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-page.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/side-page/side-page.component.ts","../../../../../../projects/myrta-ui/src/lib/components/side-page/side-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport {\r\n  SidePagePositionEnum,\r\n  SidePagePositionTypes,\r\n  SidePageSizesEnum,\r\n  SidePageSizesTypes\r\n} from './side-page.emun';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\n\r\n@Component({\r\n  selector: 'mrx-side-page',\r\n  templateUrl: './side-page.component.html',\r\n  styleUrls: ['./side-page.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('animateExpandLarge', [\r\n      state('open', style({\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('closed', style({\r\n        transform: 'translateX(620px)'\r\n      })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n    trigger('animateExpandMedium', [\r\n      state('open', style({\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('closed', style({\r\n        transform: 'translateX(400px)'\r\n      })),\r\n      transition('open => closed', [animate('0.5s ease')]),\r\n      transition('closed => open', [animate('0.5s ease')]),\r\n    ]),\r\n    trigger('animateExpandSmall', [\r\n      state('open', style({\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('closed', style({\r\n        transform: 'translateX(280px)'\r\n      })),\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 SidePageComponent implements AfterViewInit {\r\n  @Input() isOpen: boolean = false;\r\n  @Input() size: SidePageSizesTypes = 'large';\r\n  @Input() position: SidePagePositionTypes = 'right';\r\n  @Input() customClasses = '';\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  constructor(\r\n    private detector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.isOpen) {\r\n      this.toggleSidePage(true)\r\n    }\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${SidePageSizesEnum[this.size]} ${SidePagePositionEnum[this.position]} ${this.customClasses}`;\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.toggleSidePage(false)\r\n    setTimeout(() => {\r\n      this.close.emit();\r\n    }, 300)\r\n  }\r\n\r\n  public toggleSidePage(value: boolean) {\r\n    this.isOpen = value\r\n    this.detector.detectChanges()\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-side-page-content\"\r\n  [class]=\"getClasses\"\r\n  [@animateExpandLarge]=\"size === 'large' ? isOpen ? 'open' : 'closed' : ''\"\r\n  [@animateExpandMedium]=\"size === 'medium' ? isOpen ? 'open' : 'closed' : ''\"\r\n  [@animateExpandSmall]=\"size === 'small' ? isOpen ? 'open' : 'closed' : ''\"\r\n>\r\n  <div class=\"mrx-side-page-header brdb\">\r\n\r\n    <div class=\"mrx-side-page-header__content\">\r\n      <h2 class=\"mrx-side-page-header__content--title\">\r\n        <span>Title</span>\r\n        <span class=\"mrx-icon icon-info icon-font-16\" mrxCdkTooltip=\"asdasdasdasda\"></span>\r\n      </h2>\r\n    </div>\r\n\r\n    <span class=\"mrx-icon icon-close icon-font-24\"  (click)=\"onClose()\"></span>\r\n  </div>\r\n\r\n<!--  <div class=\"mrx-modal-body\">-->\r\n<!--    <div *ngIf=\"isBack\" 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<!--    <div class=\"mrx-modal-body__message\" [innerHTML]=\"message\"></div>-->\r\n<!--    <ng-content></ng-content>-->\r\n<!--  </div>-->\r\n\r\n\r\n  <div class=\"mrx-side-page-footer brdt\">\r\n    asdasd\r\n  </div>\r\n</div>\r\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-page.component.js","sourceRoot":"","sources":["../../../../../../projects/myrta-ui/src/lib/components/side-page/side-page.component.ts","../../../../../../projects/myrta-ui/src/lib/components/side-page/side-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component, ContentChild,\r\n  EventEmitter,\r\n  Input,\r\n  Output, TemplateRef,\r\n} from '@angular/core';\r\n\r\nimport {\r\n  SidePageHeaderSizesEnum, SidePageHeaderSizesTypes,\r\n  SidePagePositionEnum,\r\n  SidePagePositionTypes,\r\n  SidePageSizesEnum,\r\n  SidePageSizesTypes\r\n} from './side-page.emun';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { delay, Observable, of } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'mrx-side-page',\r\n  templateUrl: './side-page.component.html',\r\n  styleUrls: ['./side-page.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [\r\n    trigger('animateExpand', [\r\n      state('open', style({\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('closed', style({\r\n        transform: 'translateX(100%)'\r\n      })),\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 SidePageComponent implements AfterViewInit {\r\n  @Input() title: string = ''\r\n  @Input() tooltip: string = ''\r\n  @Input() isOpen: boolean = false;\r\n  @Input() size: SidePageSizesTypes = 'large';\r\n  @Input() position: SidePagePositionTypes = 'right';\r\n  @Input() customClasses = '';\r\n  @Input() enableHeader = true;\r\n  @Input() enableFooter = true;\r\n  @Input() headerSize: SidePageHeaderSizesTypes = 'large';\r\n  @Input() paddingTop: string = '';\r\n\r\n  @Input() okText = 'Подтвердить';\r\n  @Input() closeText = 'Отменить';\r\n\r\n  @Input() isLoading = false;\r\n\r\n  // BackArrow\r\n  @Input() isBack = false;\r\n  @Input() backText = 'Назад';\r\n  @Input() backRouterLink = '/';\r\n  @Input() backQueryParams = {};\r\n  @Input() closeAfterLink = true;\r\n\r\n  // Error message\r\n  @Input() invalid = false;\r\n  @Input() invalidMessage = '';\r\n\r\n  @ContentChild('headerTemplate') headerTemplate!: TemplateRef<HTMLElement>;\r\n  @ContentChild('footerTemplate') footerTemplate!: 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  constructor(\r\n    private detector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.isOpen) {\r\n      this.toggleSidePage(true);\r\n    }\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${SidePageSizesEnum[this.size]} ${SidePagePositionEnum[this.position]} ${this.customClasses}`;\r\n  }\r\n\r\n  public get getHeaderClasses(): string {\r\n    return `${SidePageHeaderSizesEnum[this.headerSize]}`;\r\n  }\r\n\r\n  public onOk(): void {\r\n    this.toggleSidePage(false)\r\n      .pipe(delay(300))\r\n      .subscribe(() => {\r\n        this.ok.emit();\r\n      });\r\n  }\r\n\r\n  public onClose(): void {\r\n    this.toggleSidePage(false)\r\n      .pipe(delay(300))\r\n      .subscribe(() => {\r\n        this.close.emit();\r\n      });\r\n  }\r\n\r\n  public toggleSidePage(value: boolean): Observable<boolean> {\r\n    this.isOpen = value;\r\n    this.detector.detectChanges();\r\n\r\n    return of(true);\r\n  }\r\n\r\n  public closeModal() {\r\n    if (this.closeAfterLink) {\r\n      this.toggleSidePage(false)\r\n        .pipe(delay(300))\r\n        .subscribe(() => {\r\n          this.close.emit();\r\n        });\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-side-page-content\"\r\n  [class]=\"getClasses\"\r\n  [style.top]=\"paddingTop\"\r\n  [@animateExpand]=\"isOpen ? 'open' : 'closed'\"\r\n>\r\n  @if (enableHeader) {\r\n    @if (!headerTemplate) {\r\n      <div class=\"mrx-side-page-header brdb\" [class]=\"getHeaderClasses\">\r\n        <div class=\"mrx-side-page-header__content\">\r\n          @if (isBack) {\r\n            <mrx-breadcrumbs\r\n              type=\"link\"\r\n              customClasses=\"mb-2\"\r\n              [item]=\"{\r\n            text: backText,\r\n            routerLink: backRouterLink,\r\n            queryParams: backQueryParams,\r\n            isShowArrow: true\r\n          }\"\r\n              (click)=\"closeModal()\"\r\n            ></mrx-breadcrumbs>\r\n          }\r\n\r\n          <h2 class=\"mrx-side-page-header__content--title\">\r\n            @if (title) {\r\n              <span>{{ title }}</span>\r\n            }\r\n\r\n            @if (tooltip) {\r\n              <span class=\"mrx-icon icon-info icon-font-16\" [mrxCdkTooltip]=\"tooltip\"></span>\r\n            }\r\n          </h2>\r\n        </div>\r\n\r\n        <span class=\"mrx-icon icon-close\" (click)=\"onClose()\"></span>\r\n      </div>\r\n    } @else {\r\n      <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\r\n    }\r\n  }\r\n\r\n  <div class=\"mrx-side-page-body\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n\r\n  @if (enableFooter) {\r\n    @if (!footerTemplate) {\r\n      <div class=\"mrx-side-page-footer brdt\">\r\n        @if (invalidMessage) {\r\n          <mrx-error-message [invalid]=\"invalid\">{{ invalidMessage }}</mrx-error-message>\r\n        }\r\n\r\n        <div class=\"mrx-side-page-footer__controls\">\r\n          <mrx-button\r\n            [type]=\"'secondary'\"\r\n            [color]=\"'default'\"\r\n            [size]=\"'medium'\"\r\n            (click)=\"onClose()\"\r\n          >{{ closeText }}\r\n          </mrx-button>\r\n\r\n          <mrx-button\r\n            [type]=\"'primary'\"\r\n            [size]=\"'medium'\"\r\n            [color]=\"'default'\"\r\n            [isLoading]=\"isLoading\"\r\n            (click)=\"onOk()\"\r\n          >{{ okText }}\r\n          </mrx-button>\r\n        </div>\r\n      </div>\r\n    } @else {\r\n      <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\r\n    }\r\n  }\r\n</div>\r\n"]}
|
|
@@ -9,4 +9,9 @@ export var SidePageSizesEnum;
|
|
|
9
9
|
SidePageSizesEnum["medium"] = "mrx-side-page--md";
|
|
10
10
|
SidePageSizesEnum["large"] = "mrx-side-page--lg";
|
|
11
11
|
})(SidePageSizesEnum || (SidePageSizesEnum = {}));
|
|
12
|
-
|
|
12
|
+
export var SidePageHeaderSizesEnum;
|
|
13
|
+
(function (SidePageHeaderSizesEnum) {
|
|
14
|
+
SidePageHeaderSizesEnum["small"] = "mrx-side-page-header--sm";
|
|
15
|
+
SidePageHeaderSizesEnum["large"] = "mrx-side-page-header--lg";
|
|
16
|
+
})(SidePageHeaderSizesEnum || (SidePageHeaderSizesEnum = {}));
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1wYWdlLmVtdW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvc2lkZS1wYWdlL3NpZGUtcGFnZS5lbXVuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG9CQUdYO0FBSEQsV0FBWSxvQkFBb0I7SUFDOUIsK0RBQXlDLENBQUE7SUFDekMsNkRBQXVDLENBQUE7QUFDekMsQ0FBQyxFQUhXLG9CQUFvQixLQUFwQixvQkFBb0IsUUFHL0I7QUFJRCxNQUFNLENBQU4sSUFBWSxpQkFJWDtBQUpELFdBQVksaUJBQWlCO0lBQzNCLGdEQUE2QixDQUFBO0lBQzdCLGlEQUE4QixDQUFBO0lBQzlCLGdEQUE2QixDQUFBO0FBQy9CLENBQUMsRUFKVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBSTVCO0FBSUQsTUFBTSxDQUFOLElBQVksdUJBR1g7QUFIRCxXQUFZLHVCQUF1QjtJQUNqQyw2REFBb0MsQ0FBQTtJQUNwQyw2REFBb0MsQ0FBQTtBQUN0QyxDQUFDLEVBSFcsdUJBQXVCLEtBQXZCLHVCQUF1QixRQUdsQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFNpZGVQYWdlUG9zaXRpb25FbnVtIHtcclxuICAncmlnaHQnID0gJ21yeC1zaWRlLXBhZ2UtLXBvc2l0aW9uLXJpZ2h0JyxcclxuICAnbGVmdCcgPSAnbXJ4LXNpZGUtcGFnZS0tcG9zaXRpb24tbGVmdCdcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgU2lkZVBhZ2VQb3NpdGlvblR5cGVzID0gJ3JpZ2h0JyB8ICdsZWZ0J1xyXG5cclxuZXhwb3J0IGVudW0gU2lkZVBhZ2VTaXplc0VudW0ge1xyXG4gICdzbWFsbCcgPSAnbXJ4LXNpZGUtcGFnZS0tc20nLFxyXG4gICdtZWRpdW0nID0gJ21yeC1zaWRlLXBhZ2UtLW1kJyxcclxuICAnbGFyZ2UnID0gJ21yeC1zaWRlLXBhZ2UtLWxnJ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBTaWRlUGFnZVNpemVzVHlwZXMgPSAnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnXHJcblxyXG5leHBvcnQgZW51bSBTaWRlUGFnZUhlYWRlclNpemVzRW51bSB7XHJcbiAgJ3NtYWxsJyA9ICdtcngtc2lkZS1wYWdlLWhlYWRlci0tc20nLFxyXG4gICdsYXJnZScgPSAnbXJ4LXNpZGUtcGFnZS1oZWFkZXItLWxnJ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBTaWRlUGFnZUhlYWRlclNpemVzVHlwZXMgPSAnc21hbGwnIHwgJ2xhcmdlJ1xyXG4iXX0=
|
|
@@ -5,6 +5,7 @@ export class ModalRef {
|
|
|
5
5
|
modalService;
|
|
6
6
|
ID;
|
|
7
7
|
afterClosedSubject = new Subject();
|
|
8
|
+
afterSendSubject = new Subject();
|
|
8
9
|
constructor(overlayRef, config, modalService, ID) {
|
|
9
10
|
this.overlayRef = overlayRef;
|
|
10
11
|
this.config = config;
|
|
@@ -27,8 +28,15 @@ export class ModalRef {
|
|
|
27
28
|
this.afterClosedSubject.next(result);
|
|
28
29
|
this.afterClosedSubject.complete();
|
|
29
30
|
}
|
|
31
|
+
send(result) {
|
|
32
|
+
this.afterSendSubject.next(result);
|
|
33
|
+
this.afterSendSubject.complete();
|
|
34
|
+
}
|
|
30
35
|
afterClosed() {
|
|
31
36
|
return this.afterClosedSubject.asObservable();
|
|
32
37
|
}
|
|
38
|
+
afterSend() {
|
|
39
|
+
return this.afterClosedSubject.asObservable();
|
|
40
|
+
}
|
|
33
41
|
}
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtcmVmLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9zZXJ2aWNlcy9tb2RhbC1zZXJ2aWNlL2hlbHBlcnMvbW9kYWwtcmVmLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxPQUFPLEVBQWMsTUFBTSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBSW5ELE1BQU0sT0FBTyxRQUFRO0lBS1Q7SUFDQTtJQUNBO0lBQ0E7SUFQRixrQkFBa0IsR0FBRyxJQUFJLE9BQU8sRUFBTyxDQUFDO0lBQ3hDLGdCQUFnQixHQUFHLElBQUksT0FBTyxFQUFPLENBQUM7SUFFOUMsWUFDVSxVQUFzQixFQUN0QixNQUFtQixFQUNuQixZQUEwQixFQUMxQixFQUFtQjtRQUhuQixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ3RCLFdBQU0sR0FBTixNQUFNLENBQWE7UUFDbkIsaUJBQVksR0FBWixZQUFZLENBQWM7UUFDMUIsT0FBRSxHQUFGLEVBQUUsQ0FBaUI7UUFFM0IsSUFBSSxNQUFNLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7Z0JBQzdDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDeEIsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBRUQsSUFBSSxNQUFNLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxJQUFJLENBQ2xDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLEtBQUssUUFBUSxDQUFDLENBQ3hDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDZixJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3hCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7SUFFTSxLQUFLLENBQUMsTUFBVztRQUN0QixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzFCLElBQUksQ0FBQyxZQUFZLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1FBQzVDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDckMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFTSxJQUFJLENBQUMsTUFBWTtRQUN0QixJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25DLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBRU0sV0FBVztRQUNoQixPQUFPLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUNoRCxDQUFDO0lBRU0sU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ2hELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUsIGZpbHRlciB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBNb2RhbENvbmZpZyB9IGZyb20gJy4uL21vZGVscy9tb2RhbC1jb25maWcubW9kZWwnO1xyXG5pbXBvcnQgeyBNb2RhbFNlcnZpY2UgfSBmcm9tICcuLi9tb2RhbC1zZXJ2aWNlLnNlcnZpY2UnO1xyXG5cclxuZXhwb3J0IGNsYXNzIE1vZGFsUmVmPFQxPiB7XHJcbiAgcHJpdmF0ZSBhZnRlckNsb3NlZFN1YmplY3QgPSBuZXcgU3ViamVjdDxhbnk+KCk7XHJcbiAgcHJpdmF0ZSBhZnRlclNlbmRTdWJqZWN0ID0gbmV3IFN1YmplY3Q8YW55PigpO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgb3ZlcmxheVJlZjogT3ZlcmxheVJlZixcclxuICAgIHByaXZhdGUgY29uZmlnOiBNb2RhbENvbmZpZyxcclxuICAgIHByaXZhdGUgbW9kYWxTZXJ2aWNlOiBNb2RhbFNlcnZpY2UsXHJcbiAgICBwcml2YXRlIElEOiBzdHJpbmcgfCBudW1iZXJcclxuICApIHtcclxuICAgIGlmIChjb25maWcuY2xvc2VPbkNsaWNrT3V0c2lkZSkge1xyXG4gICAgICB0aGlzLm92ZXJsYXlSZWYuYmFja2Ryb3BDbGljaygpLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgdGhpcy5jbG9zZSh1bmRlZmluZWQpO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoY29uZmlnLmNsb3NlT25Fc2NhcGUpIHtcclxuICAgICAgdGhpcy5vdmVybGF5UmVmLmtleWRvd25FdmVudHMoKS5waXBlKFxyXG4gICAgICAgIGZpbHRlcihldmVudCA9PiBldmVudC5rZXkgPT09ICdFc2NhcGUnKVxyXG4gICAgICApLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgdGhpcy5jbG9zZSh1bmRlZmluZWQpO1xyXG4gICAgICB9KTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBjbG9zZShyZXN1bHQ/OiBUMSkge1xyXG4gICAgdGhpcy5vdmVybGF5UmVmLmRpc3Bvc2UoKTtcclxuICAgIHRoaXMubW9kYWxTZXJ2aWNlLmRlbGV0ZVJlZkZyb21MaXN0KHRoaXMuSUQpXHJcbiAgICB0aGlzLmFmdGVyQ2xvc2VkU3ViamVjdC5uZXh0KHJlc3VsdCk7XHJcbiAgICB0aGlzLmFmdGVyQ2xvc2VkU3ViamVjdC5jb21wbGV0ZSgpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHNlbmQocmVzdWx0PzogYW55KSB7XHJcbiAgICB0aGlzLmFmdGVyU2VuZFN1YmplY3QubmV4dChyZXN1bHQpO1xyXG4gICAgdGhpcy5hZnRlclNlbmRTdWJqZWN0LmNvbXBsZXRlKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgYWZ0ZXJDbG9zZWQoKTogT2JzZXJ2YWJsZTxUMT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuYWZ0ZXJDbG9zZWRTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGFmdGVyU2VuZCgpOiBPYnNlcnZhYmxlPFQxPiB7XHJcbiAgICByZXR1cm4gdGhpcy5hZnRlckNsb3NlZFN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|