@acrodata/gui
Version:
JSON powered GUI for configurable panels.
147 lines • 22.1 kB
JavaScript
import { CodeEditor } from '@acrodata/code-editor';
import { coerceCssPixelValue } from '@angular/cdk/coercion';
import { ChangeDetectionStrategy, Component, forwardRef, Input, ViewEncapsulation, } from '@angular/core';
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
import { MatIconButton } from '@angular/material/button';
import { MatHint } from '@angular/material/form-field';
import { MatIcon } from '@angular/material/icon';
import { GuiFieldLabel } from '../field-label/field-label';
import { GuiIconButtonWrapper } from '../icon-button-wrapper/icon-button-wrapper';
import { GuiCodeareaDialog } from './codearea-dialog';
import * as i0 from "@angular/core";
import * as i1 from "@acrodata/rnd-dialog";
import * as i2 from "./codearea-config";
import * as i3 from "../gui-icons";
import * as i4 from "@angular/forms";
export class GuiCodearea {
get height() {
return coerceCssPixelValue(this.config.height || this._height);
}
set height(value) {
this._height = value;
}
get language() {
return this.config.language || this._language;
}
set language(value) {
this._language = value;
}
get languages() {
return this.codeareaCfg.languages;
}
get theme() {
return this.codeareaCfg.theme;
}
get dialogData() {
return {
value: this.value,
disabled: this.disabled,
language: this.language,
};
}
get extensions() {
return typeof this.codeareaCfg.extensions === 'function'
? this.codeareaCfg.extensions(this.dialogData)
: this.codeareaCfg.extensions;
}
constructor(rndDialog, cdr, destroyRef, codeareaCfg, iconsRegistry) {
this.rndDialog = rndDialog;
this.cdr = cdr;
this.destroyRef = destroyRef;
this.codeareaCfg = codeareaCfg;
this.config = {};
this.disabled = false;
this.setup = 'minimal';
this._height = 120;
this._language = '';
this.value = '';
this.oldValue = '';
this.onChange = () => { };
this.onTouched = () => { };
iconsRegistry.add('expand');
this.codeareaCfg.changes.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
this.cdr.markForCheck();
});
}
writeValue(value) {
if (typeof value === 'string' || value == null) {
this.value = value || '';
}
else {
this.value = value.toString();
}
this.oldValue = this.value;
this.cdr.markForCheck();
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
this.cdr.markForCheck();
}
onValueChange() {
if (this.value !== this.oldValue) {
this.onChange(this.value);
this.oldValue = this.value;
}
}
onExpand() {
const dialogRef = this.rndDialog.open(GuiCodeareaDialog, {
panelClass: 'gui-codearea-dialog-panel',
hasBackdrop: false,
width: '600px',
data: this.dialogData,
});
dialogRef.closed.subscribe(newValue => {
if (newValue) {
this.value = newValue;
this.cdr.detectChanges();
this.onValueChange();
}
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GuiCodearea, deps: [{ token: i1.RndDialog }, { token: i0.ChangeDetectorRef }, { token: i0.DestroyRef }, { token: i2.GuiCodeareaConfig }, { token: i3.GuiIconsRegistry }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: GuiCodearea, isStandalone: true, selector: "gui-codearea", inputs: { config: "config", disabled: "disabled", setup: "setup", height: "height", language: "language" }, host: { classAttribute: "gui-field gui-codearea" }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => GuiCodearea),
multi: true,
},
], ngImport: i0, template: "<code-editor\n [style.height]=\"height\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [language]=\"language\"\n [languages]=\"languages\"\n [theme]=\"theme\"\n [setup]=\"setup\"\n [extensions]=\"extensions\"\n (blur)=\"onValueChange()\"\n/>\n\n<div class=\"gui-codearea-btns\">\n <gui-icon-button-wrapper>\n <button mat-icon-button type=\"button\" (click)=\"onExpand()\">\n <mat-icon svgIcon=\"expand\" />\n </button>\n </gui-icon-button-wrapper>\n</div>\n\n@if (config.parentType === 'inline') {\n <mat-hint>\n <gui-field-label [config]=\"config\" />\n </mat-hint>\n}\n", styles: [".gui-codearea{position:relative;overflow:auto;border:1px solid var(--mdc-outlined-text-field-outline-color);border-radius:var(--mdc-outlined-text-field-container-shape)}.gui-codearea .code-editor{width:100%;min-height:1.5rem;overflow:auto;resize:vertical}.gui-codearea:hover .gui-codearea-btns{display:block}.gui-codearea-btns{position:absolute;top:0;right:0;display:none;margin:2px}[dir=rtl] .gui-codearea-btns{left:0;right:auto}.gui-codearea-btns .gui-icon-button-wrapper .mat-mdc-icon-button,.gui-codearea-btns .gui-icon-button-wrapper .mat-icon{width:1.25rem;height:1.25rem}.gui-codearea-btns .mat-mdc-icon-button{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:.25rem}.gui-codearea-btns .mat-mdc-icon-button .mat-mdc-button-persistent-ripple{border-radius:inherit}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: CodeEditor, selector: "code-editor", inputs: ["root", "autoFocus", "value", "disabled", "readonly", "theme", "placeholder", "indentWithTab", "indentUnit", "lineWrapping", "highlightWhitespace", "languages", "language", "setup", "extensions"], outputs: ["change", "focus", "blur"] }, { kind: "component", type: GuiFieldLabel, selector: "gui-field-label", inputs: ["config", "index"] }, { kind: "component", type: GuiIconButtonWrapper, selector: "gui-icon-button-wrapper" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GuiCodearea, decorators: [{
type: Component,
args: [{ selector: 'gui-codearea', host: {
class: 'gui-field gui-codearea',
}, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => GuiCodearea),
multi: true,
},
], standalone: true, imports: [
FormsModule,
MatIcon,
MatIconButton,
MatHint,
CodeEditor,
GuiFieldLabel,
GuiIconButtonWrapper,
], template: "<code-editor\n [style.height]=\"height\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [language]=\"language\"\n [languages]=\"languages\"\n [theme]=\"theme\"\n [setup]=\"setup\"\n [extensions]=\"extensions\"\n (blur)=\"onValueChange()\"\n/>\n\n<div class=\"gui-codearea-btns\">\n <gui-icon-button-wrapper>\n <button mat-icon-button type=\"button\" (click)=\"onExpand()\">\n <mat-icon svgIcon=\"expand\" />\n </button>\n </gui-icon-button-wrapper>\n</div>\n\n@if (config.parentType === 'inline') {\n <mat-hint>\n <gui-field-label [config]=\"config\" />\n </mat-hint>\n}\n", styles: [".gui-codearea{position:relative;overflow:auto;border:1px solid var(--mdc-outlined-text-field-outline-color);border-radius:var(--mdc-outlined-text-field-container-shape)}.gui-codearea .code-editor{width:100%;min-height:1.5rem;overflow:auto;resize:vertical}.gui-codearea:hover .gui-codearea-btns{display:block}.gui-codearea-btns{position:absolute;top:0;right:0;display:none;margin:2px}[dir=rtl] .gui-codearea-btns{left:0;right:auto}.gui-codearea-btns .gui-icon-button-wrapper .mat-mdc-icon-button,.gui-codearea-btns .gui-icon-button-wrapper .mat-icon{width:1.25rem;height:1.25rem}.gui-codearea-btns .mat-mdc-icon-button{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:.25rem}.gui-codearea-btns .mat-mdc-icon-button .mat-mdc-button-persistent-ripple{border-radius:inherit}\n"] }]
}], ctorParameters: () => [{ type: i1.RndDialog }, { type: i0.ChangeDetectorRef }, { type: i0.DestroyRef }, { type: i2.GuiCodeareaConfig }, { type: i3.GuiIconsRegistry }], propDecorators: { config: [{
type: Input
}], disabled: [{
type: Input
}], setup: [{
type: Input
}], height: [{
type: Input
}], language: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"codearea.js","sourceRoot":"","sources":["../../../../projects/gui/codearea/codearea.ts","../../../../projects/gui/codearea/codearea.html"],"names":[],"mappings":"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","sourcesContent":["import { CodeEditor, Setup } from '@acrodata/code-editor';\nimport { RndDialog } from '@acrodata/rnd-dialog';\nimport { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  forwardRef,\n  Input,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MatIconButton } from '@angular/material/button';\nimport { MatHint } from '@angular/material/form-field';\nimport { MatIcon } from '@angular/material/icon';\nimport { GuiFieldLabel } from '../field-label/field-label';\nimport { GuiIconsRegistry } from '../gui-icons';\nimport { GuiIconButtonWrapper } from '../icon-button-wrapper/icon-button-wrapper';\nimport { GuiControl } from '../interface';\nimport { GuiCodeareaConfig } from './codearea-config';\nimport { GuiCodeareaDialog, GuiCodeareaDialogData } from './codearea-dialog';\n\n@Component({\n  selector: 'gui-codearea',\n  templateUrl: './codearea.html',\n  styleUrl: './codearea.scss',\n  host: {\n    class: 'gui-field gui-codearea',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => GuiCodearea),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    FormsModule,\n    MatIcon,\n    MatIconButton,\n    MatHint,\n    CodeEditor,\n    GuiFieldLabel,\n    GuiIconButtonWrapper,\n  ],\n})\nexport class GuiCodearea implements ControlValueAccessor {\n  @Input() config: Partial<GuiControl> = {};\n  @Input() disabled = false;\n\n  @Input() setup: Setup = 'minimal';\n\n  @Input()\n  get height() {\n    return coerceCssPixelValue(this.config.height || this._height);\n  }\n  set height(value: string | number) {\n    this._height = value;\n  }\n  private _height: string | number = 120;\n\n  @Input()\n  get language() {\n    return this.config.language || this._language;\n  }\n  set language(value: string) {\n    this._language = value;\n  }\n  private _language = '';\n\n  get languages() {\n    return this.codeareaCfg.languages;\n  }\n\n  get theme() {\n    return this.codeareaCfg.theme;\n  }\n\n  get dialogData(): GuiCodeareaDialogData {\n    return {\n      value: this.value,\n      disabled: this.disabled,\n      language: this.language,\n    };\n  }\n\n  get extensions() {\n    return typeof this.codeareaCfg.extensions === 'function'\n      ? this.codeareaCfg.extensions(this.dialogData)\n      : this.codeareaCfg.extensions;\n  }\n\n  value = '';\n  private oldValue = '';\n\n  private onChange: (value: string) => void = () => {};\n  private onTouched: () => void = () => {};\n\n  constructor(\n    private rndDialog: RndDialog,\n    private cdr: ChangeDetectorRef,\n    private destroyRef: DestroyRef,\n    private codeareaCfg: GuiCodeareaConfig,\n    iconsRegistry: GuiIconsRegistry\n  ) {\n    iconsRegistry.add('expand');\n\n    this.codeareaCfg.changes.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  writeValue(value: any) {\n    if (typeof value === 'string' || value == null) {\n      this.value = value || '';\n    } else {\n      this.value = value.toString();\n    }\n    this.oldValue = this.value;\n    this.cdr.markForCheck();\n  }\n\n  registerOnChange(fn: (value: string) => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  onValueChange() {\n    if (this.value !== this.oldValue) {\n      this.onChange(this.value);\n      this.oldValue = this.value;\n    }\n  }\n\n  onExpand() {\n    const dialogRef = this.rndDialog.open<string, GuiCodeareaDialogData, GuiCodeareaDialog>(\n      GuiCodeareaDialog,\n      {\n        panelClass: 'gui-codearea-dialog-panel',\n        hasBackdrop: false,\n        width: '600px',\n        data: this.dialogData,\n      }\n    );\n\n    dialogRef.closed.subscribe(newValue => {\n      if (newValue) {\n        this.value = newValue;\n        this.cdr.detectChanges();\n        this.onValueChange();\n      }\n    });\n  }\n}\n","<code-editor\n  [style.height]=\"height\"\n  [(ngModel)]=\"value\"\n  [disabled]=\"disabled\"\n  [language]=\"language\"\n  [languages]=\"languages\"\n  [theme]=\"theme\"\n  [setup]=\"setup\"\n  [extensions]=\"extensions\"\n  (blur)=\"onValueChange()\"\n/>\n\n<div class=\"gui-codearea-btns\">\n  <gui-icon-button-wrapper>\n    <button mat-icon-button type=\"button\" (click)=\"onExpand()\">\n      <mat-icon svgIcon=\"expand\" />\n    </button>\n  </gui-icon-button-wrapper>\n</div>\n\n@if (config.parentType === 'inline') {\n  <mat-hint>\n    <gui-field-label [config]=\"config\" />\n  </mat-hint>\n}\n"]}