@skyux/text-editor 9.13.1 → 9.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -429,4 +429,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
429
429
  type: HostBinding,
430
430
  args: ['class.sky-form-control']
431
431
  }] } });
432
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/text-editor.component.ts","../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  NgZone,\n  OnDestroy,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { SkyCoreAdapterService, SkyIdService } from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyToolbarModule } from '@skyux/layout';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyFormsUtility } from '../shared/forms-utility';\n\nimport { FONT_LIST_DEFAULTS } from './defaults/font-list-defaults';\nimport { FONT_SIZE_LIST_DEFAULTS } from './defaults/font-size-list-defaults';\nimport { LINK_WINDOW_OPTIONS_DEFAULTS } from './defaults/link-window-options-defaults';\nimport { MENU_DEFAULTS } from './defaults/menu-defaults';\nimport { STYLE_STATE_DEFAULTS } from './defaults/style-state-defaults';\nimport { TOOLBAR_ACTION_DEFAULTS } from './defaults/toolbar-action-defaults';\nimport { SkyTextEditorMenubarComponent } from './menubar/text-editor-menubar.component';\nimport { SkyTextEditorAdapterService } from './services/text-editor-adapter.service';\nimport { SkyTextEditorSelectionService } from './services/text-editor-selection.service';\nimport { SkyTextEditorService } from './services/text-editor.service';\nimport { SkyTextSanitizationService } from './services/text-sanitization.service';\nimport { SkyTextEditorToolbarComponent } from './toolbar/text-editor-toolbar.component';\nimport { SkyTextEditorFont } from './types/font-state';\nimport { SkyTextEditorLinkWindowOptionsType } from './types/link-window-options-type';\nimport { SkyTextEditorMenuType } from './types/menu-type';\nimport { SkyTextEditorStyleState } from './types/style-state';\nimport { SkyTextEditorMergeField } from './types/text-editor-merge-field';\nimport { SkyTextEditorToolbarActionType } from './types/toolbar-action-type';\n\n/**\n * The text editor component lets users format and manipulate text.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor',\n  templateUrl: './text-editor.component.html',\n  styleUrls: ['./text-editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    SkyTextEditorService,\n    SkyTextEditorSelectionService,\n    SkyTextEditorAdapterService,\n  ],\n  imports: [\n    CommonModule,\n    SkyTextEditorMenubarComponent,\n    SkyTextEditorToolbarComponent,\n    SkyToolbarModule,\n  ],\n})\nexport class SkyTextEditorComponent\n  implements AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  /**\n   * Whether to put focus on the editor after it renders.\n   */\n  @Input()\n  public autofocus: boolean | undefined = false;\n\n  /**\n   * Whether to disable the text editor on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.\n   * To set the disabled state on reactive forms, use the `FormControl` instead.\n   * @default false\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    const coercedValue = SkyFormsUtility.coerceBooleanProperty(value);\n    if (coercedValue !== this.disabled) {\n      this.#_disabled = coercedValue;\n\n      // Update focusableChildren inside the iframe.\n      let focusableChildren: HTMLElement[];\n      /* istanbul ignore else */\n      if (this.iframeRef) {\n        focusableChildren = this.#coreAdapterService.getFocusableChildren(\n          this.iframeRef.nativeElement.contentDocument.body,\n          {\n            ignoreVisibility: true,\n            ignoreTabIndex: true,\n          }\n        );\n\n        if (this.#_disabled) {\n          this.#adapterService.disableEditor(\n            focusableChildren,\n            this.iframeRef.nativeElement\n          );\n        } else {\n          this.#adapterService.enableEditor(\n            focusableChildren,\n            this.iframeRef.nativeElement\n          );\n        }\n        this.#changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  /**\n   * The fonts to include in the font picker.\n   * @default [{name: 'Blackbaud Sans', value: '\"Blackbaud Sans\", Arial, sans-serif'}, {name: 'Arial', value: 'Arial'}, {name: 'Arial Black', value: '\"Arial Black\"'}, {name: 'Courier New', value: '\"Courier New\"'}, {name: 'Georgia', value: 'Georgia, serif'}, {name: 'Tahoma', value: 'Tahoma, Geneva, sans-serif'}, {name: 'Times New Roman', value: '\"Times New Roman\"'}, {name: 'Trebuchet MS', value: '\"Trebuchet MS\", sans-serif'}, {name: 'Verdana', value: 'Verdana, Geneva, sans-serif'}]\n   */\n  @Input()\n  public set fontList(value: SkyTextEditorFont[] | undefined) {\n    this.#_fontList = value || FONT_LIST_DEFAULTS;\n  }\n\n  public get fontList(): SkyTextEditorFont[] {\n    return this.#_fontList;\n  }\n\n  /**\n   * The font sizes to include in the font size picker.\n   * @default [6, 8, 9, 10, 11, 12, 13, 14, 15, 16, 18, 20, 22, 24, 26, 28, 36, 48]\n   */\n  @Input()\n  public set fontSizeList(value: number[] | undefined) {\n    this.#_fontSizeList = value || FONT_SIZE_LIST_DEFAULTS;\n  }\n\n  public get fontSizeList(): number[] {\n    return this.#_fontSizeList;\n  }\n\n  /**\n   * The unique ID attribute for the text editor.\n   * By default, the component generates a random ID.\n   */\n  @Input()\n  public set id(value: string | undefined) {\n    this.#id = value || this.#defaultId;\n  }\n\n  public get id(): string {\n    return this.#id;\n  }\n\n  /**\n   * The initial styles for all content, including background color, font size, and link state.\n   */\n  @Input()\n  public set initialStyleState(state: SkyTextEditorStyleState | undefined) {\n    // Do not update the state after initialization has taken place\n    /* istanbul ignore else */\n    if (!this.#initialized) {\n      this.#_initialStyleState = {\n        ...STYLE_STATE_DEFAULTS,\n        ...state,\n      };\n    }\n  }\n\n  public get initialStyleState(): SkyTextEditorStyleState {\n    return this.#_initialStyleState;\n  }\n\n  /**\n   * The menus to include in the menu bar.\n   * @default [ 'edit', 'format' ]\n   */\n  @Input()\n  public set menus(value: SkyTextEditorMenuType[] | undefined) {\n    this.#_menus = value || MENU_DEFAULTS;\n  }\n\n  public get menus(): SkyTextEditorMenuType[] {\n    return this.#_menus;\n  }\n\n  /**\n   * The merge fields to include in the merge field menu.\n   */\n  @Input()\n  public set mergeFields(value: SkyTextEditorMergeField[] | undefined) {\n    this.#_mergeFields = value || [];\n  }\n\n  public get mergeFields(): SkyTextEditorMergeField[] {\n    return this.#_mergeFields;\n  }\n\n  /**\n   * Placeholder text to display when the text entry area is empty.\n   */\n  @Input()\n  public set placeholder(value: string | undefined) {\n    /* istanbul ignore else */\n    if (value !== this.#_placeholder) {\n      this.#_placeholder = value || '';\n      if (this.#initialized) {\n        this.#adapterService.setPlaceholder(value);\n      }\n    }\n  }\n\n  public get placeholder(): string {\n    return this.#_placeholder;\n  }\n\n  /**\n   * The actions to include in the toolbar in the specified order.\n   * @default [ 'font-family', 'font-size', 'font-style', 'color', 'list', 'link ]\n   */\n  @Input()\n  public set toolbarActions(\n    value: SkyTextEditorToolbarActionType[] | undefined\n  ) {\n    this.#_toolbarActions = value || TOOLBAR_ACTION_DEFAULTS;\n  }\n\n  public get toolbarActions(): SkyTextEditorToolbarActionType[] {\n    return this.#_toolbarActions;\n  }\n\n  /**\n   * The target window options for adding a hyperlink.\n   * @default [ 'new', 'existing' ]\n   */\n  @Input()\n  public set linkWindowOptions(\n    value: SkyTextEditorLinkWindowOptionsType[] | undefined\n  ) {\n    this.#_linkWindowOptions = value ?? LINK_WINDOW_OPTIONS_DEFAULTS;\n  }\n\n  public get linkWindowOptions(): SkyTextEditorLinkWindowOptionsType[] {\n    return this.#_linkWindowOptions;\n  }\n\n  @ViewChild('iframe')\n  public iframeRef: ElementRef | undefined;\n\n  /**\n   * The internal value of the control.\n   */\n  public set value(value: string | undefined) {\n    // Normalize value and set any empty state to an empty string.\n    let normalizedValue: string;\n    const valueTrimmed = value?.trim();\n\n    if (\n      !value ||\n      valueTrimmed === '<p></p>' ||\n      valueTrimmed === '<br>' ||\n      valueTrimmed === '<p><br></p>'\n    ) {\n      normalizedValue = '';\n    } else {\n      normalizedValue = value;\n    }\n\n    normalizedValue = this.#sanitizationService\n      .sanitize(normalizedValue)\n      .trim();\n\n    if (this.#_value !== normalizedValue) {\n      this.#_value = normalizedValue;\n\n      // Update angular form control if model has been normalized.\n      /* istanbul ignore else */\n      if (\n        this.#ngControl?.control &&\n        normalizedValue !== this.#ngControl.control.value\n      ) {\n        this.#ngControl.control.setValue(normalizedValue, {\n          emitModelToViewChange: false,\n        });\n      }\n\n      // Autofocus isn't testable in Firefox and IE.\n      // Don't set focus on the editor now if the iframe isn't initialized.\n      // #initIframe() will do another check later to see if the editor should\n      // receive focus.\n      /* istanbul ignore next */\n      if (this.autofocus && this.#initialized && !this.#focusInitialized) {\n        this.#adapterService.focusEditor();\n        this.#focusInitialized = true;\n      }\n    }\n  }\n\n  public get value(): string {\n    return this.#_value;\n  }\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public inputTemplateRef: TemplateRef<unknown> | undefined;\n\n  public editorFocusStream = new Subject<void>();\n\n  @HostBinding('class.sky-form-control')\n  public formControlClass = !!inject(SkyInputBoxHostService, {\n    optional: true,\n  });\n\n  #defaultId: string;\n  #id: string;\n  #focusInitialized = false;\n  #initialized = false;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_fontList = FONT_LIST_DEFAULTS;\n  #_fontSizeList = FONT_SIZE_LIST_DEFAULTS;\n  #_mergeFields: SkyTextEditorMergeField[] = [];\n  #_menus = MENU_DEFAULTS;\n  #_toolbarActions: SkyTextEditorToolbarActionType[] = TOOLBAR_ACTION_DEFAULTS;\n  #_linkWindowOptions = LINK_WINDOW_OPTIONS_DEFAULTS;\n  #_disabled = false;\n  #_initialStyleState = Object.assign({}, STYLE_STATE_DEFAULTS);\n  #_placeholder = '';\n  #_value = '<p></p>';\n\n  readonly #adapterService = inject(SkyTextEditorAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #coreAdapterService = inject(SkyCoreAdapterService);\n  readonly #editorService = inject(SkyTextEditorService);\n  readonly #idSvc = inject(SkyIdService);\n  readonly #ngControl = inject(NgControl);\n  readonly #sanitizationService = inject(SkyTextSanitizationService);\n  readonly #zone = inject(NgZone);\n\n  constructor() {\n    this.#id = this.#defaultId = this.#idSvc.generateId();\n    this.#ngControl.valueAccessor = this;\n  }\n\n  public ngAfterViewInit(): void {\n    this.#initIframe();\n  }\n\n  public ngOnDestroy(): void {\n    this.#adapterService.removeObservers(this.#editorService.editor);\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public onIframeLoad(): void {\n    // Reinitialize the editor if it already exists to cover situations where the text editor might have been moved in the DOM.\n    if (this.#editorService.isInitialized) {\n      this.#initIframe();\n    }\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public writeValue(value: string): void {\n    this.value = value;\n\n    // Update HTML if necessary.\n    if (this.#initialized) {\n      const editorValue = this.#adapterService.getEditorInnerHtml();\n      if (editorValue !== this.#_value) {\n        this.#adapterService.setEditorInnerHtml(this.#_value);\n      }\n    }\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public registerOnChange(fn: (value: any) => void): void {\n    this.#_onChange = fn;\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public registerOnTouched(fn: () => void): void {\n    this.#_onTouched = fn;\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  #updateStyle(): void {\n    this.#_initialStyleState = {\n      ...this.#_initialStyleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  #initIframe(): void {\n    this.#adapterService.initEditor(\n      this.id,\n      (this.iframeRef as ElementRef).nativeElement,\n      this.initialStyleState,\n      this.placeholder\n    );\n\n    this.#editorService\n      .inputListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Angular doesn't run change detection for changes originating inside an iframe,\n        // so we have to call the onChange() event inside NgZone to force change propagation to consuming components.\n        this.#zone.run(() => {\n          this.#viewToModelUpdate();\n        });\n      });\n\n    this.#editorService\n      .selectionChangeListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateStyle();\n        this.editorFocusStream.next();\n      });\n\n    this.#editorService\n      .clickListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.editorFocusStream.next();\n      });\n\n    this.#editorService\n      .blurListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Angular doesn't run change detection for changes originating inside an iframe,\n        // so we have to run markForCheck() inside the NgZone to force change propagation to consuming components.\n        this.#zone.run(() => {\n          this.#_onTouched();\n        });\n      });\n\n    this.#editorService\n      .commandChangeListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateStyle();\n        this.#viewToModelUpdate();\n      });\n\n    this.#adapterService.setEditorInnerHtml(this.#_value);\n\n    /* istanbul ignore next */\n    if (this.autofocus) {\n      this.#adapterService.focusEditor();\n    }\n\n    this.#initialized = true;\n  }\n\n  #viewToModelUpdate(emitChange = true): void {\n    this.value = this.#adapterService.getEditorInnerHtml();\n    /* istanbul ignore else */\n    if (emitChange) {\n      this.#_onChange(this.#_value);\n    }\n  }\n\n  /* istanbul ignore next */\n  #_onTouched = (): void => {\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n  };\n\n  /* istanbul ignore next */\n  #_onChange: (\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value: any\n  ) => void = () => {\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n  };\n}\n","<div class=\"sky-text-editor\">\n  <sky-toolbar\n    *ngIf=\"\n      (menus && menus.length) > 0 ||\n      (toolbarActions && toolbarActions.length > 0)\n    \"\n    class=\"sky-text-editor-toolbar\"\n  >\n    <sky-toolbar-section\n      *ngIf=\"menus && menus.length > 0\"\n      aria-label=\"Text formatting\"\n      class=\"menubar\"\n      role=\"toolbar\"\n    >\n      <sky-text-editor-menubar\n        [disabled]=\"disabled\"\n        [editorFocusStream]=\"editorFocusStream\"\n        [menus]=\"menus\"\n        [mergeFields]=\"mergeFields\"\n      >\n      </sky-text-editor-menubar>\n    </sky-toolbar-section>\n    <sky-toolbar-section\n      *ngIf=\"toolbarActions && toolbarActions.length > 0\"\n      aria-label=\"Text formatting\"\n      class=\"toolbar\"\n      role=\"toolbar\"\n    >\n      <sky-text-editor-toolbar\n        [disabled]=\"disabled\"\n        [editorFocusStream]=\"editorFocusStream\"\n        [fontList]=\"fontList\"\n        [fontSizeList]=\"fontSizeList\"\n        [linkWindowOptions]=\"linkWindowOptions\"\n        [toolbarActions]=\"toolbarActions\"\n        [styleState]=\"initialStyleState\"\n      >\n      </sky-text-editor-toolbar>\n    </sky-toolbar-section>\n  </sky-toolbar>\n  <iframe\n    class=\"sky-text-editor-wrapper\"\n    src=\"about:blank\"\n    title=\"Text Editor\"\n    [ngClass]=\"{\n      'sky-text-editor-wrapper-disabled': disabled\n    }\"\n    (load)=\"onIframeLoad()\"\n    #iframe\n  >\n  </iframe>\n</div>\n"]}
432
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/text-editor.component.ts","../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/text-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EAET,WAAW,EACX,KAAK,EACL,MAAM,EAEN,WAAW,EACX,SAAS,EACT,iBAAiB,EACjB,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACjE,OAAO,EAAE,qBAAqB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAClE,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEjD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,4BAA4B,EAAE,MAAM,yCAAyC,CAAC;AACvF,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,6BAA6B,EAAE,MAAM,yCAAyC,CAAC;AACxF,OAAO,EAAE,2BAA2B,EAAE,MAAM,wCAAwC,CAAC;AACrF,OAAO,EAAE,6BAA6B,EAAE,MAAM,0CAA0C,CAAC;AACzF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AACtE,OAAO,EAAE,0BAA0B,EAAE,MAAM,sCAAsC,CAAC;AAClF,OAAO,EAAE,6BAA6B,EAAE,MAAM,yCAAyC,CAAC;;;;AAQxF;;GAEG;AAoBH,MAAM,OAAO,sBAAsB;IASjC;;;;OAIG;IACH,IACW,QAAQ,CAAC,KAA0B;QAC5C,MAAM,YAAY,GAAG,eAAe,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAClE,IAAI,YAAY,KAAK,IAAI,CAAC,QAAQ,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAE/B,8CAA8C;YAC9C,IAAI,iBAAgC,CAAC;YACrC,0BAA0B;YAC1B,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,iBAAiB,GAAG,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,CAC/D,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,EACjD;oBACE,gBAAgB,EAAE,IAAI;oBACtB,cAAc,EAAE,IAAI;iBACrB,CACF,CAAC;gBAEF,IAAI,IAAI,CAAC,UAAU,EAAE;oBACnB,IAAI,CAAC,eAAe,CAAC,aAAa,CAChC,iBAAiB,EACjB,IAAI,CAAC,SAAS,CAAC,aAAa,CAC7B,CAAC;iBACH;qBAAM;oBACL,IAAI,CAAC,eAAe,CAAC,YAAY,CAC/B,iBAAiB,EACjB,IAAI,CAAC,SAAS,CAAC,aAAa,CAC7B,CAAC;iBACH;gBACD,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;aACrC;SACF;IACH,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,IACW,QAAQ,CAAC,KAAsC;QACxD,IAAI,CAAC,UAAU,GAAG,KAAK,IAAI,kBAAkB,CAAC;IAChD,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,IACW,YAAY,CAAC,KAA2B;QACjD,IAAI,CAAC,cAAc,GAAG,KAAK,IAAI,uBAAuB,CAAC;IACzD,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED;;;OAGG;IACH,IACW,EAAE,CAAC,KAAyB;QACrC,IAAI,CAAC,GAAG,GAAG,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC;IACtC,CAAC;IAED,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED;;OAEG;IACH,IACW,iBAAiB,CAAC,KAA0C;QACrE,+DAA+D;QAC/D,0BAA0B;QAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,IAAI,CAAC,mBAAmB,GAAG;gBACzB,GAAG,oBAAoB;gBACvB,GAAG,KAAK;aACT,CAAC;SACH;IACH,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAED;;;OAGG;IACH,IACW,KAAK,CAAC,KAA0C;QACzD,IAAI,CAAC,OAAO,GAAG,KAAK,IAAI,aAAa,CAAC;IACxC,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,IACW,WAAW,CAAC,KAA4C;QACjE,IAAI,CAAC,aAAa,GAAG,KAAK,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,IACW,WAAW,CAAC,KAAyB;QAC9C,0BAA0B;QAC1B,IAAI,KAAK,KAAK,IAAI,CAAC,aAAa,EAAE;YAChC,IAAI,CAAC,aAAa,GAAG,KAAK,IAAI,EAAE,CAAC;YACjC,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;aAC5C;SACF;IACH,CAAC;IAED,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED;;;OAGG;IACH,IACW,cAAc,CACvB,KAAmD;QAEnD,IAAI,CAAC,gBAAgB,GAAG,KAAK,IAAI,uBAAuB,CAAC;IAC3D,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACH,IACW,iBAAiB,CAC1B,KAAuD;QAEvD,IAAI,CAAC,mBAAmB,GAAG,KAAK,IAAI,4BAA4B,CAAC;IACnE,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAKD;;OAEG;IACH,IAAW,KAAK,CAAC,KAAyB;QACxC,8DAA8D;QAC9D,IAAI,eAAuB,CAAC;QAC5B,MAAM,YAAY,GAAG,KAAK,EAAE,IAAI,EAAE,CAAC;QAEnC,IACE,CAAC,KAAK;YACN,YAAY,KAAK,SAAS;YAC1B,YAAY,KAAK,MAAM;YACvB,YAAY,KAAK,aAAa,EAC9B;YACA,eAAe,GAAG,EAAE,CAAC;SACtB;aAAM;YACL,eAAe,GAAG,KAAK,CAAC;SACzB;QAED,eAAe,GAAG,IAAI,CAAC,oBAAoB;aACxC,QAAQ,CAAC,eAAe,CAAC;aACzB,IAAI,EAAE,CAAC;QAEV,IAAI,IAAI,CAAC,OAAO,KAAK,eAAe,EAAE;YACpC,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC;YAE/B,4DAA4D;YAC5D,0BAA0B;YAC1B,IACE,IAAI,CAAC,UAAU,EAAE,OAAO;gBACxB,eAAe,KAAK,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,EACjD;gBACA,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,EAAE;oBAChD,qBAAqB,EAAE,KAAK;iBAC7B,CAAC,CAAC;aACJ;YAED,8CAA8C;YAC9C,qEAAqE;YACrE,wEAAwE;YACxE,iBAAiB;YACjB,0BAA0B;YAC1B,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAClE,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;gBACnC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;aAC/B;SACF;IACH,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAeD,UAAU,CAAS;IACnB,GAAG,CAAS;IACZ,iBAAiB,CAAS;IAC1B,YAAY,CAAS;IACrB,cAAc,CAAuB;IAErC,UAAU,CAAsB;IAChC,cAAc,CAA2B;IACzC,aAAa,CAAiC;IAC9C,OAAO,CAAiB;IACxB,gBAAgB,CAA6D;IAC7E,mBAAmB,CAAgC;IACnD,UAAU,CAAS;IACnB,mBAAmB,CAA2C;IAC9D,aAAa,CAAM;IACnB,OAAO,CAAa;IAEX,eAAe,CAAuC;IACtD,eAAe,CAA6B;IAC5C,mBAAmB,CAAiC;IACpD,cAAc,CAAgC;IAC9C,MAAM,CAAwB;IAC9B,UAAU,CAAqB;IAC/B,oBAAoB,CAAsC;IAC1D,KAAK,CAAkB;IAEhC;QAnRA;;WAEG;QAEI,cAAS,GAAwB,KAAK,CAAC;QA8OvC,sBAAiB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGxC,qBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC,sBAAsB,EAAE;YACzD,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC;QAIH,sBAAiB,GAAG,KAAK,CAAC;QAC1B,iBAAY,GAAG,KAAK,CAAC;QACrB,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAErC,eAAU,GAAG,kBAAkB,CAAC;QAChC,mBAAc,GAAG,uBAAuB,CAAC;QACzC,kBAAa,GAA8B,EAAE,CAAC;QAC9C,YAAO,GAAG,aAAa,CAAC;QACxB,qBAAgB,GAAqC,uBAAuB,CAAC;QAC7E,wBAAmB,GAAG,4BAA4B,CAAC;QACnD,eAAU,GAAG,KAAK,CAAC;QACnB,wBAAmB,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,oBAAoB,CAAC,CAAC;QAC9D,kBAAa,GAAG,EAAE,CAAC;QACnB,YAAO,GAAG,SAAS,CAAC;QAEX,oBAAe,GAAG,MAAM,CAAC,2BAA2B,CAAC,CAAC;QACtD,oBAAe,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC5C,wBAAmB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QACpD,mBAAc,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAC9C,WAAM,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;QAC9B,eAAU,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC/B,yBAAoB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAC1D,UAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QA2IhC,0BAA0B;QAC1B,gBAAW,GAAG,GAAS,EAAE;YACvB,gEAAgE;QAClE,CAAC,CAAC;QAEF,0BAA0B;QAC1B,eAAU,GAGE,GAAG,EAAE;YACf,gEAAgE;QAClE,CAAC,CAAC;QAnJA,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;QACtD,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC;IACvC,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QACjE,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAEM,YAAY;QACjB,2HAA2H;QAC3H,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE;YACrC,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAa;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,4BAA4B;QAC5B,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,EAAE,CAAC;YAC9D,IAAI,WAAW,KAAK,IAAI,CAAC,OAAO,EAAE;gBAChC,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACvD;SACF;IACH,CAAC;IAED;;OAEG;IACH,8DAA8D;IACvD,gBAAgB,CAAC,EAAwB;QAC9C,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACI,iBAAiB,CAAC,EAAc;QACrC,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,UAAmB;QACzC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,mBAAmB,GAAG;YACzB,GAAG,IAAI,CAAC,mBAAmB;YAC3B,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;SACxC,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,UAAU,CAC7B,IAAI,CAAC,EAAE,EACN,IAAI,CAAC,SAAwB,CAAC,aAAa,EAC5C,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,WAAW,CACjB,CAAC;QAEF,IAAI,CAAC,cAAc;aAChB,aAAa,EAAE;aACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,iFAAiF;YACjF,6GAA6G;YAC7G,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,cAAc;aAChB,uBAAuB,EAAE;aACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,cAAc;aAChB,aAAa,EAAE;aACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAChC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,cAAc;aAChB,YAAY,EAAE;aACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,iFAAiF;YACjF,0GAA0G;YAC1G,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;gBAClB,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,cAAc;aAChB,qBAAqB,EAAE;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEtD,0BAA0B;QAC1B,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;SACpC;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,kBAAkB,CAAC,UAAU,GAAG,IAAI;QAClC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,EAAE,CAAC;QACvD,0BAA0B;QAC1B,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,0BAA0B;IAC1B,WAAW,CAET;IAEF,0BAA0B;IAC1B,UAAU,CAKR;8GA1aS,sBAAsB;kGAAtB,sBAAsB,6bAZtB;YACT,oBAAoB;YACpB,6BAA6B;YAC7B,2BAA2B;SAC5B,iNAwPO,WAAW,2CCnTrB,o8CAoDA,6kDDSI,YAAY,iOACZ,6BAA6B,uIAC7B,6BAA6B,+LAC7B,gBAAgB;;2FAGP,sBAAsB;kBAnBlC,SAAS;iCACI,IAAI,YACN,iBAAiB,mBAGV,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,aAC1B;wBACT,oBAAoB;wBACpB,6BAA6B;wBAC7B,2BAA2B;qBAC5B,WACQ;wBACP,YAAY;wBACZ,6BAA6B;wBAC7B,6BAA6B;wBAC7B,gBAAgB;qBACjB;0EASM,SAAS;sBADf,KAAK;gBASK,QAAQ;sBADlB,KAAK;gBA2CK,QAAQ;sBADlB,KAAK;gBAcK,YAAY;sBADtB,KAAK;gBAcK,EAAE;sBADZ,KAAK;gBAaK,iBAAiB;sBAD3B,KAAK;gBAqBK,KAAK;sBADf,KAAK;gBAaK,WAAW;sBADrB,KAAK;gBAaK,WAAW;sBADrB,KAAK;gBAoBK,cAAc;sBADxB,KAAK;gBAgBK,iBAAiB;sBAD3B,KAAK;gBAYC,SAAS;sBADf,SAAS;uBAAC,QAAQ;gBA4DZ,gBAAgB;sBAJtB,SAAS;uBAAC,kBAAkB,EAAE;wBAC7B,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACb;gBAMM,gBAAgB;sBADtB,WAAW;uBAAC,wBAAwB","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  Input,\n  NgZone,\n  OnDestroy,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { SkyCoreAdapterService, SkyIdService } from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyToolbarModule } from '@skyux/layout';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyFormsUtility } from '../shared/forms-utility';\n\nimport { FONT_LIST_DEFAULTS } from './defaults/font-list-defaults';\nimport { FONT_SIZE_LIST_DEFAULTS } from './defaults/font-size-list-defaults';\nimport { LINK_WINDOW_OPTIONS_DEFAULTS } from './defaults/link-window-options-defaults';\nimport { MENU_DEFAULTS } from './defaults/menu-defaults';\nimport { STYLE_STATE_DEFAULTS } from './defaults/style-state-defaults';\nimport { TOOLBAR_ACTION_DEFAULTS } from './defaults/toolbar-action-defaults';\nimport { SkyTextEditorMenubarComponent } from './menubar/text-editor-menubar.component';\nimport { SkyTextEditorAdapterService } from './services/text-editor-adapter.service';\nimport { SkyTextEditorSelectionService } from './services/text-editor-selection.service';\nimport { SkyTextEditorService } from './services/text-editor.service';\nimport { SkyTextSanitizationService } from './services/text-sanitization.service';\nimport { SkyTextEditorToolbarComponent } from './toolbar/text-editor-toolbar.component';\nimport { SkyTextEditorFont } from './types/font-state';\nimport { SkyTextEditorLinkWindowOptionsType } from './types/link-window-options-type';\nimport { SkyTextEditorMenuType } from './types/menu-type';\nimport { SkyTextEditorStyleState } from './types/style-state';\nimport { SkyTextEditorMergeField } from './types/text-editor-merge-field';\nimport { SkyTextEditorToolbarActionType } from './types/toolbar-action-type';\n\n/**\n * The text editor component lets users format and manipulate text.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor',\n  templateUrl: './text-editor.component.html',\n  styleUrls: ['./text-editor.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    SkyTextEditorService,\n    SkyTextEditorSelectionService,\n    SkyTextEditorAdapterService,\n  ],\n  imports: [\n    CommonModule,\n    SkyTextEditorMenubarComponent,\n    SkyTextEditorToolbarComponent,\n    SkyToolbarModule,\n  ],\n})\nexport class SkyTextEditorComponent\n  implements AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  /**\n   * Whether to put focus on the editor after it renders.\n   */\n  @Input()\n  public autofocus: boolean | undefined = false;\n\n  /**\n   * Whether to disable the text editor on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.\n   * To set the disabled state on reactive forms, use the `FormControl` instead.\n   * @default false\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    const coercedValue = SkyFormsUtility.coerceBooleanProperty(value);\n    if (coercedValue !== this.disabled) {\n      this.#_disabled = coercedValue;\n\n      // Update focusableChildren inside the iframe.\n      let focusableChildren: HTMLElement[];\n      /* istanbul ignore else */\n      if (this.iframeRef) {\n        focusableChildren = this.#coreAdapterService.getFocusableChildren(\n          this.iframeRef.nativeElement.contentDocument.body,\n          {\n            ignoreVisibility: true,\n            ignoreTabIndex: true,\n          },\n        );\n\n        if (this.#_disabled) {\n          this.#adapterService.disableEditor(\n            focusableChildren,\n            this.iframeRef.nativeElement,\n          );\n        } else {\n          this.#adapterService.enableEditor(\n            focusableChildren,\n            this.iframeRef.nativeElement,\n          );\n        }\n        this.#changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  /**\n   * The fonts to include in the font picker.\n   * @default [{name: 'Blackbaud Sans', value: '\"Blackbaud Sans\", Arial, sans-serif'}, {name: 'Arial', value: 'Arial'}, {name: 'Arial Black', value: '\"Arial Black\"'}, {name: 'Courier New', value: '\"Courier New\"'}, {name: 'Georgia', value: 'Georgia, serif'}, {name: 'Tahoma', value: 'Tahoma, Geneva, sans-serif'}, {name: 'Times New Roman', value: '\"Times New Roman\"'}, {name: 'Trebuchet MS', value: '\"Trebuchet MS\", sans-serif'}, {name: 'Verdana', value: 'Verdana, Geneva, sans-serif'}]\n   */\n  @Input()\n  public set fontList(value: SkyTextEditorFont[] | undefined) {\n    this.#_fontList = value || FONT_LIST_DEFAULTS;\n  }\n\n  public get fontList(): SkyTextEditorFont[] {\n    return this.#_fontList;\n  }\n\n  /**\n   * The font sizes to include in the font size picker.\n   * @default [6, 8, 9, 10, 11, 12, 13, 14, 15, 16, 18, 20, 22, 24, 26, 28, 36, 48]\n   */\n  @Input()\n  public set fontSizeList(value: number[] | undefined) {\n    this.#_fontSizeList = value || FONT_SIZE_LIST_DEFAULTS;\n  }\n\n  public get fontSizeList(): number[] {\n    return this.#_fontSizeList;\n  }\n\n  /**\n   * The unique ID attribute for the text editor.\n   * By default, the component generates a random ID.\n   */\n  @Input()\n  public set id(value: string | undefined) {\n    this.#id = value || this.#defaultId;\n  }\n\n  public get id(): string {\n    return this.#id;\n  }\n\n  /**\n   * The initial styles for all content, including background color, font size, and link state.\n   */\n  @Input()\n  public set initialStyleState(state: SkyTextEditorStyleState | undefined) {\n    // Do not update the state after initialization has taken place\n    /* istanbul ignore else */\n    if (!this.#initialized) {\n      this.#_initialStyleState = {\n        ...STYLE_STATE_DEFAULTS,\n        ...state,\n      };\n    }\n  }\n\n  public get initialStyleState(): SkyTextEditorStyleState {\n    return this.#_initialStyleState;\n  }\n\n  /**\n   * The menus to include in the menu bar.\n   * @default [ 'edit', 'format' ]\n   */\n  @Input()\n  public set menus(value: SkyTextEditorMenuType[] | undefined) {\n    this.#_menus = value || MENU_DEFAULTS;\n  }\n\n  public get menus(): SkyTextEditorMenuType[] {\n    return this.#_menus;\n  }\n\n  /**\n   * The merge fields to include in the merge field menu.\n   */\n  @Input()\n  public set mergeFields(value: SkyTextEditorMergeField[] | undefined) {\n    this.#_mergeFields = value || [];\n  }\n\n  public get mergeFields(): SkyTextEditorMergeField[] {\n    return this.#_mergeFields;\n  }\n\n  /**\n   * Placeholder text to display when the text entry area is empty.\n   */\n  @Input()\n  public set placeholder(value: string | undefined) {\n    /* istanbul ignore else */\n    if (value !== this.#_placeholder) {\n      this.#_placeholder = value || '';\n      if (this.#initialized) {\n        this.#adapterService.setPlaceholder(value);\n      }\n    }\n  }\n\n  public get placeholder(): string {\n    return this.#_placeholder;\n  }\n\n  /**\n   * The actions to include in the toolbar in the specified order.\n   * @default [ 'font-family', 'font-size', 'font-style', 'color', 'list', 'link ]\n   */\n  @Input()\n  public set toolbarActions(\n    value: SkyTextEditorToolbarActionType[] | undefined,\n  ) {\n    this.#_toolbarActions = value || TOOLBAR_ACTION_DEFAULTS;\n  }\n\n  public get toolbarActions(): SkyTextEditorToolbarActionType[] {\n    return this.#_toolbarActions;\n  }\n\n  /**\n   * The target window options for adding a hyperlink.\n   * @default [ 'new', 'existing' ]\n   */\n  @Input()\n  public set linkWindowOptions(\n    value: SkyTextEditorLinkWindowOptionsType[] | undefined,\n  ) {\n    this.#_linkWindowOptions = value ?? LINK_WINDOW_OPTIONS_DEFAULTS;\n  }\n\n  public get linkWindowOptions(): SkyTextEditorLinkWindowOptionsType[] {\n    return this.#_linkWindowOptions;\n  }\n\n  @ViewChild('iframe')\n  public iframeRef: ElementRef | undefined;\n\n  /**\n   * The internal value of the control.\n   */\n  public set value(value: string | undefined) {\n    // Normalize value and set any empty state to an empty string.\n    let normalizedValue: string;\n    const valueTrimmed = value?.trim();\n\n    if (\n      !value ||\n      valueTrimmed === '<p></p>' ||\n      valueTrimmed === '<br>' ||\n      valueTrimmed === '<p><br></p>'\n    ) {\n      normalizedValue = '';\n    } else {\n      normalizedValue = value;\n    }\n\n    normalizedValue = this.#sanitizationService\n      .sanitize(normalizedValue)\n      .trim();\n\n    if (this.#_value !== normalizedValue) {\n      this.#_value = normalizedValue;\n\n      // Update angular form control if model has been normalized.\n      /* istanbul ignore else */\n      if (\n        this.#ngControl?.control &&\n        normalizedValue !== this.#ngControl.control.value\n      ) {\n        this.#ngControl.control.setValue(normalizedValue, {\n          emitModelToViewChange: false,\n        });\n      }\n\n      // Autofocus isn't testable in Firefox and IE.\n      // Don't set focus on the editor now if the iframe isn't initialized.\n      // #initIframe() will do another check later to see if the editor should\n      // receive focus.\n      /* istanbul ignore next */\n      if (this.autofocus && this.#initialized && !this.#focusInitialized) {\n        this.#adapterService.focusEditor();\n        this.#focusInitialized = true;\n      }\n    }\n  }\n\n  public get value(): string {\n    return this.#_value;\n  }\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public inputTemplateRef: TemplateRef<unknown> | undefined;\n\n  public editorFocusStream = new Subject<void>();\n\n  @HostBinding('class.sky-form-control')\n  public formControlClass = !!inject(SkyInputBoxHostService, {\n    optional: true,\n  });\n\n  #defaultId: string;\n  #id: string;\n  #focusInitialized = false;\n  #initialized = false;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_fontList = FONT_LIST_DEFAULTS;\n  #_fontSizeList = FONT_SIZE_LIST_DEFAULTS;\n  #_mergeFields: SkyTextEditorMergeField[] = [];\n  #_menus = MENU_DEFAULTS;\n  #_toolbarActions: SkyTextEditorToolbarActionType[] = TOOLBAR_ACTION_DEFAULTS;\n  #_linkWindowOptions = LINK_WINDOW_OPTIONS_DEFAULTS;\n  #_disabled = false;\n  #_initialStyleState = Object.assign({}, STYLE_STATE_DEFAULTS);\n  #_placeholder = '';\n  #_value = '<p></p>';\n\n  readonly #adapterService = inject(SkyTextEditorAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #coreAdapterService = inject(SkyCoreAdapterService);\n  readonly #editorService = inject(SkyTextEditorService);\n  readonly #idSvc = inject(SkyIdService);\n  readonly #ngControl = inject(NgControl);\n  readonly #sanitizationService = inject(SkyTextSanitizationService);\n  readonly #zone = inject(NgZone);\n\n  constructor() {\n    this.#id = this.#defaultId = this.#idSvc.generateId();\n    this.#ngControl.valueAccessor = this;\n  }\n\n  public ngAfterViewInit(): void {\n    this.#initIframe();\n  }\n\n  public ngOnDestroy(): void {\n    this.#adapterService.removeObservers(this.#editorService.editor);\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public onIframeLoad(): void {\n    // Reinitialize the editor if it already exists to cover situations where the text editor might have been moved in the DOM.\n    if (this.#editorService.isInitialized) {\n      this.#initIframe();\n    }\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public writeValue(value: string): void {\n    this.value = value;\n\n    // Update HTML if necessary.\n    if (this.#initialized) {\n      const editorValue = this.#adapterService.getEditorInnerHtml();\n      if (editorValue !== this.#_value) {\n        this.#adapterService.setEditorInnerHtml(this.#_value);\n      }\n    }\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  public registerOnChange(fn: (value: any) => void): void {\n    this.#_onChange = fn;\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public registerOnTouched(fn: () => void): void {\n    this.#_onTouched = fn;\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  #updateStyle(): void {\n    this.#_initialStyleState = {\n      ...this.#_initialStyleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  #initIframe(): void {\n    this.#adapterService.initEditor(\n      this.id,\n      (this.iframeRef as ElementRef).nativeElement,\n      this.initialStyleState,\n      this.placeholder,\n    );\n\n    this.#editorService\n      .inputListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Angular doesn't run change detection for changes originating inside an iframe,\n        // so we have to call the onChange() event inside NgZone to force change propagation to consuming components.\n        this.#zone.run(() => {\n          this.#viewToModelUpdate();\n        });\n      });\n\n    this.#editorService\n      .selectionChangeListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateStyle();\n        this.editorFocusStream.next();\n      });\n\n    this.#editorService\n      .clickListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.editorFocusStream.next();\n      });\n\n    this.#editorService\n      .blurListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Angular doesn't run change detection for changes originating inside an iframe,\n        // so we have to run markForCheck() inside the NgZone to force change propagation to consuming components.\n        this.#zone.run(() => {\n          this.#_onTouched();\n        });\n      });\n\n    this.#editorService\n      .commandChangeListener()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateStyle();\n        this.#viewToModelUpdate();\n      });\n\n    this.#adapterService.setEditorInnerHtml(this.#_value);\n\n    /* istanbul ignore next */\n    if (this.autofocus) {\n      this.#adapterService.focusEditor();\n    }\n\n    this.#initialized = true;\n  }\n\n  #viewToModelUpdate(emitChange = true): void {\n    this.value = this.#adapterService.getEditorInnerHtml();\n    /* istanbul ignore else */\n    if (emitChange) {\n      this.#_onChange(this.#_value);\n    }\n  }\n\n  /* istanbul ignore next */\n  #_onTouched = (): void => {\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n  };\n\n  /* istanbul ignore next */\n  #_onChange: (\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value: any,\n  ) => void = () => {\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n  };\n}\n","<div class=\"sky-text-editor\">\n  <sky-toolbar\n    *ngIf=\"\n      (menus && menus.length) > 0 ||\n      (toolbarActions && toolbarActions.length > 0)\n    \"\n    class=\"sky-text-editor-toolbar\"\n  >\n    <sky-toolbar-section\n      *ngIf=\"menus && menus.length > 0\"\n      aria-label=\"Text formatting\"\n      class=\"menubar\"\n      role=\"toolbar\"\n    >\n      <sky-text-editor-menubar\n        [disabled]=\"disabled\"\n        [editorFocusStream]=\"editorFocusStream\"\n        [menus]=\"menus\"\n        [mergeFields]=\"mergeFields\"\n      >\n      </sky-text-editor-menubar>\n    </sky-toolbar-section>\n    <sky-toolbar-section\n      *ngIf=\"toolbarActions && toolbarActions.length > 0\"\n      aria-label=\"Text formatting\"\n      class=\"toolbar\"\n      role=\"toolbar\"\n    >\n      <sky-text-editor-toolbar\n        [disabled]=\"disabled\"\n        [editorFocusStream]=\"editorFocusStream\"\n        [fontList]=\"fontList\"\n        [fontSizeList]=\"fontSizeList\"\n        [linkWindowOptions]=\"linkWindowOptions\"\n        [toolbarActions]=\"toolbarActions\"\n        [styleState]=\"initialStyleState\"\n      >\n      </sky-text-editor-toolbar>\n    </sky-toolbar-section>\n  </sky-toolbar>\n  <iframe\n    class=\"sky-text-editor-wrapper\"\n    src=\"about:blank\"\n    title=\"Text Editor\"\n    [ngClass]=\"{\n      'sky-text-editor-wrapper-disabled': disabled\n    }\"\n    (load)=\"onIframeLoad()\"\n    #iframe\n  >\n  </iframe>\n</div>\n"]}
@@ -226,4 +226,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
226
226
  }], disabled: [{
227
227
  type: Input
228
228
  }] } });
229
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.ts","../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,KAAK,EAEL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAEL,yBAAyB,EACzB,oBAAoB,GAErB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAqB,eAAe,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAEL,sBAAsB,EACtB,iBAAiB,GAClB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE9C,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,2BAA2B,EAAE,MAAM,yCAAyC,CAAC;AAKtF,OAAO,EAAE,kBAAkB,EAAE,MAAM,4CAA4C,CAAC;AAChF,OAAO,EAAE,8BAA8B,EAAE,MAAM,8CAA8C,CAAC;AAC9F,OAAO,EAAE,SAAS,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;AAEhE;;GAEG;AAkBH,MAAM,OAAO,6BAA6B;IAjB1C;QA6BS,aAAQ,GAAwB,EAAE,CAAC;QAGnC,iBAAY,GAAa,EAAE,CAAC;QAG5B,mBAAc,GAAqC,EAAE,CAAC;QAGtD,sBAAiB,GAAyC,EAAE,CAAC;QA+B7D,0BAAqB,GAAG,IAAI,OAAO,EAAyB,CAAC;QAC7D,sBAAiB,GAAG,IAAI,OAAO,EAAyB,CAAC;QACzD,qBAAgB,GAAG,IAAI,OAAO,EAAsB,CAAC;QACrD,mBAAc,GAAG,IAAI,OAAO,EAAsB,CAAC;QAI1D,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAErC,wBAAmB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC1C,eAAU,GAAG,KAAK,CAAC;QACnB,iBAAY,GAAG,oBAAoB,CAAC;QAE3B,oBAAe,GAAG,MAAM,CAAC,2BAA2B,CAAC,CAAC;QACtD,oBAAe,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC5C,kBAAa,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;KA0IlD;IA5MC,IACW,iBAAiB,CAAC,KAAoB;QAC/C,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAcD,IACW,UAAU,CAAC,KAA8B;QAClD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,kBAAkB,EAAE;YAC1C,IAAI,KAAK,CAAC,IAAI,KAAK,qCAAqC,EAAE;gBACxD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;aAC/D;iBAAM;gBACL,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aACzD;SACF;IACH,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IACW,QAAQ,CAAC,KAAc;QAChC,MAAM,YAAY,GAAG,eAAe,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAClE,IAAI,YAAY,KAAK,IAAI,CAAC,QAAQ,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAC/B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;SACrC;IACH,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAQD,qBAAqB,CAA2B;IAChD,cAAc,CAAuB;IAErC,mBAAmB,CAAuB;IAC1C,UAAU,CAAS;IACnB,YAAY,CAAwB;IAE3B,eAAe,CAAuC;IACtD,eAAe,CAA6B;IAC5C,aAAa,CAA2B;IAE1C,QAAQ;QACb,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAEM,WAAW,CAAC,OAAe,EAAE,KAAK,GAAG,EAAE;QAC5C,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC;YAC/B,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG;YAChB,GAAG,IAAI,CAAC,UAAU;YAClB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;SACxC,CAAC;IACJ,CAAC;IAEM,eAAe,CACpB,YAAqB,EACrB,QAAiB,EACjB,OAAe;QAEf,IAAI,YAAY,KAAK,QAAQ,EAAE;YAC7B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;SAC3B;QAED,8DAA8D;QAC9D,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;IAEM,IAAI;QACT,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QAC5D,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QACnD,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,8BAA8B,EAAE;YACzE;gBACE,OAAO,EAAE,kBAAkB;gBAC3B,UAAU,EAAE,GAAG,EAAE;oBACf,MAAM,OAAO,GAAG,IAAI,kBAAkB,EAAE,CAAC;oBACzC,OAAO,CAAC,SAAS,GAAG,WAAW,CAAC;oBAChC,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;oBAEnD,OAAO,OAAO,CAAC;gBACjB,CAAC;aACF;SACF,CAAC,CAAC;QACH,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAyB,EAAE,EAAE;YACxD,IAAI,MAAM,CAAC,MAAM,KAAK,MAAM,IAAI,cAAc,EAAE;gBAC9C,IAAI,WAAW,EAAE;oBACf,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,EAAE,CAAC;oBAE3D,IAAI,MAAM,EAAE;wBACV,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;qBAC5C;iBACF;gBAED,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;gBAC3B,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,IAAI,EAAE;oBACzC,iBAAiB;oBACjB,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBACjD;qBAAM;oBACL,aAAa;oBACb,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,mBAAmB,EAAE,CAAC;oBACzD,IAAI,CAAC,WAAW,CACd,YAAY,EACZ,WAAW;wBACT,MAAM,CAAC,IAAI,CAAC,GAAG;wBACf,8CAA8C;wBAC9C,KAAK;wBACL,MAAM,CACT,CAAC;iBACH;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,MAAM;QACX,MAAM,qBAAqB,GAAG,IAAI,CAAC,eAAe;aAC/C,mBAAmB,EAAE;YACtB,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;QAClB,IAAI,qBAAqB,IAAI,qBAAqB,CAAC,QAAQ,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE;YACzE,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,EAAE,CAAC;YAC9D,IAAI,SAAS,EAAE;gBACb,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;aAC/C;SACF;QACD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAEM,cAAc,CAAC,IAAY;QAChC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG;YAChB,GAAG,IAAI,CAAC,UAAU;YAClB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;SACxC,CAAC;IACJ,CAAC;IAEM,yBAAyB,CAC9B,KAA2B,EAC3B,YAAY,GAAG,KAAK;QAEpB,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;IACxE,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;QAE1C,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,iBAAiB;aAChD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,UAAU,GAAG;gBAChB,GAAG,IAAI,CAAC,UAAU;gBAClB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE;aACxC,CAAC;YACF,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACb,MAAM,OAAO,GAA0B;YACrC,IAAI,EAAE,yBAAyB,CAAC,KAAK;SACtC,CAAC;QACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,sBAAsB,CAAC,KAAK,EAAE,CAAC,CAAC;QACnE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,sBAAsB,CAAC,KAAK,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,YAAY,CAAC,QAAgB;QAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC7C,IAAI,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;gBAC5D,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;aAC9B;SACF;QAED,0BAA0B;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;8GA5MU,6BAA6B;kGAA7B,6BAA6B,qTC7D1C,ikSAoRA,g1EDjOI,YAAY,0gBACZ,WAAW,8mBACX,iBAAiB,kTACjB,oBAAoB,wdACpB,iBAAiB,0hBACjB,aAAa,uJACb,cAAc,8BACd,gBAAgB;;2FAGP,6BAA6B;kBAjBzC,SAAS;iCACI,IAAI,YACN,yBAAyB,mBAGlB,uBAAuB,CAAC,MAAM,WACtC;wBACP,YAAY;wBACZ,WAAW;wBACX,iBAAiB;wBACjB,oBAAoB;wBACpB,iBAAiB;wBACjB,aAAa;wBACb,cAAc;wBACd,gBAAgB;qBACjB;8BAIU,iBAAiB;sBAD3B,KAAK;gBAWC,QAAQ;sBADd,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAIC,cAAc;sBADpB,KAAK;gBAIC,iBAAiB;sBADvB,KAAK;gBAIK,UAAU;sBADpB,KAAK;gBAiBK,QAAQ;sBADlB,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n  inject,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport {\n  SkyColorpickerMessage,\n  SkyColorpickerMessageType,\n  SkyColorpickerModule,\n  SkyColorpickerOutput,\n} from '@skyux/colorpicker';\nimport { SkyCheckboxModule } from '@skyux/forms';\nimport { SkyIconModule } from '@skyux/indicators';\nimport { SkyToolbarModule } from '@skyux/layout';\nimport { SkyModalCloseArgs, SkyModalService } from '@skyux/modals';\nimport {\n  SkyDropdownMessage,\n  SkyDropdownMessageType,\n  SkyDropdownModule,\n} from '@skyux/popovers';\nimport { SkyThemeModule } from '@skyux/theme';\n\nimport { Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyFormsUtility } from '../../shared/forms-utility';\nimport { STYLE_STATE_DEFAULTS } from '../defaults/style-state-defaults';\nimport { SkyTextEditorAdapterService } from '../services/text-editor-adapter.service';\nimport { SkyTextEditorFont } from '../types/font-state';\nimport { SkyTextEditorLinkWindowOptionsType } from '../types/link-window-options-type';\nimport { SkyTextEditorStyleState } from '../types/style-state';\nimport { SkyTextEditorToolbarActionType } from '../types/toolbar-action-type';\nimport { SkyUrlModalContext } from '../url-modal/text-editor-url-modal-context';\nimport { SkyTextEditorUrlModalComponent } from '../url-modal/text-editor-url-modal.component';\nimport { UrlTarget } from '../url-modal/text-editor-url-target';\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor-toolbar',\n  templateUrl: './text-editor-toolbar.component.html',\n  styleUrls: ['./text-editor-toolbar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    SkyCheckboxModule,\n    SkyColorpickerModule,\n    SkyDropdownModule,\n    SkyIconModule,\n    SkyThemeModule,\n    SkyToolbarModule,\n  ],\n})\nexport class SkyTextEditorToolbarComponent implements OnInit {\n  @Input()\n  public set editorFocusStream(value: Subject<void>) {\n    this.#_editorFocusStream = value;\n    this.#subscribeEditorFocus();\n  }\n\n  public get editorFocusStream(): Subject<void> {\n    return this.#_editorFocusStream;\n  }\n\n  @Input()\n  public fontList: SkyTextEditorFont[] = [];\n\n  @Input()\n  public fontSizeList: number[] = [];\n\n  @Input()\n  public toolbarActions: SkyTextEditorToolbarActionType[] = [];\n\n  @Input()\n  public linkWindowOptions: SkyTextEditorLinkWindowOptionsType[] = [];\n\n  @Input()\n  public set styleState(value: SkyTextEditorStyleState) {\n    this.#_styleState = value;\n    if (value.font !== this.styleStateFontName) {\n      if (value.font === '\"Blackbaud Sans\", Arial, sans-serif') {\n        this.styleStateFontName = this.#getFontName('Blackbaud Sans');\n      } else {\n        this.styleStateFontName = this.#getFontName(value.font);\n      }\n    }\n  }\n\n  public get styleState(): SkyTextEditorStyleState {\n    return this.#_styleState;\n  }\n\n  @Input()\n  public set disabled(value: boolean) {\n    const coercedValue = SkyFormsUtility.coerceBooleanProperty(value);\n    if (coercedValue !== this.disabled) {\n      this.#_disabled = coercedValue;\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public backColorpickerStream = new Subject<SkyColorpickerMessage>();\n  public colorpickerStream = new Subject<SkyColorpickerMessage>();\n  public fontPickerStream = new Subject<SkyDropdownMessage>();\n  public fontSizeStream = new Subject<SkyDropdownMessage>();\n  public styleStateFontName: string | undefined;\n\n  #editorFocusStreamSub: Subscription | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_editorFocusStream = new Subject<void>();\n  #_disabled = false;\n  #_styleState = STYLE_STATE_DEFAULTS;\n\n  readonly #adapterService = inject(SkyTextEditorAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #modalService = inject(SkyModalService);\n\n  public ngOnInit(): void {\n    this.#subscribeEditorFocus();\n  }\n\n  public execCommand(command: string, value = ''): void {\n    this.#adapterService.execCommand({\n      command: command,\n      value: value,\n    });\n    this.styleState = {\n      ...this.styleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  public toggleFontStyle(\n    currentState: boolean,\n    newState: boolean,\n    command: string\n  ): void {\n    if (currentState !== newState) {\n      this.execCommand(command);\n    }\n\n    // Force sky-checkbox to show changes on user's initial click.\n    this.#changeDetector.detectChanges();\n  }\n\n  public link(): void {\n    const priorSelection = this.#adapterService.saveSelection();\n    const currentLink = this.#adapterService.getLink();\n    const inputModal = this.#modalService.open(SkyTextEditorUrlModalComponent, [\n      {\n        provide: SkyUrlModalContext,\n        useFactory: () => {\n          const context = new SkyUrlModalContext();\n          context.urlResult = currentLink;\n          context.linkWindowOptions = this.linkWindowOptions;\n\n          return context;\n        },\n      },\n    ]);\n    inputModal.closed.subscribe((result: SkyModalCloseArgs) => {\n      if (result.reason === 'save' && priorSelection) {\n        if (currentLink) {\n          const anchor = this.#adapterService.getSelectedAnchorTag();\n\n          if (anchor) {\n            this.#adapterService.selectElement(anchor);\n          }\n        }\n\n        this.execCommand('unlink');\n        if (result.data.target === UrlTarget.None) {\n          // Current window\n          this.execCommand('createLink', result.data.url);\n        } else {\n          // New Window\n          const sText = this.#adapterService.getCurrentSelection();\n          this.execCommand(\n            'insertHTML',\n            '<a href=\"' +\n              result.data.url +\n              '\" rel=\"noopener noreferrer\" target=\"_blank\">' +\n              sText +\n              '</a>'\n          );\n        }\n      }\n    });\n  }\n\n  public unlink(): void {\n    const currentSelectionRange = this.#adapterService\n      .getCurrentSelection()\n      ?.getRangeAt(0);\n    if (currentSelectionRange && currentSelectionRange.toString().length <= 0) {\n      const anchorTag = this.#adapterService.getSelectedAnchorTag();\n      if (anchorTag) {\n        this.#adapterService.selectElement(anchorTag);\n      }\n    }\n    this.execCommand('unlink');\n  }\n\n  public changeFontSize(size: number): void {\n    this.#adapterService.setFontSize(size);\n    this.styleState = {\n      ...this.styleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  public onColorpickerColorChanged(\n    color: SkyColorpickerOutput,\n    isBackground = false\n  ): void {\n    this.execCommand(isBackground ? 'backColor' : 'foreColor', color.hex);\n  }\n\n  #subscribeEditorFocus(): void {\n    this.#editorFocusStreamSub?.unsubscribe();\n\n    this.#editorFocusStreamSub = this.editorFocusStream\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.styleState = {\n          ...this.styleState,\n          ...this.#adapterService.getStyleState(),\n        };\n        this.#closeDropdowns();\n        this.#changeDetector.detectChanges();\n      });\n  }\n\n  #closeDropdowns(): void {\n    const message: SkyColorpickerMessage = {\n      type: SkyColorpickerMessageType.Close,\n    };\n    this.colorpickerStream.next(message);\n    this.backColorpickerStream.next(message);\n    this.fontPickerStream.next({ type: SkyDropdownMessageType.Close });\n    this.fontSizeStream.next({ type: SkyDropdownMessageType.Close });\n  }\n\n  #getFontName(fontName: string): string | undefined {\n    for (let i = 0; i < this.fontList.length; i++) {\n      if (fontName.replace(/['\"]+/g, '') === this.fontList[i].name) {\n        return this.fontList[i].name;\n      }\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n}\n","<sky-toolbar-item\n  *ngFor=\"let action of toolbarActions\"\n  class=\"sky-text-editor-toolbar-action\"\n  [ngClass]=\"'sky-text-editor-toolbar-action-' + action\"\n>\n  <ng-container [ngSwitch]=\"action\">\n    <ng-container *ngSwitchCase=\"'font-family'\">\n      <sky-dropdown\n        class=\"sky-text-editor-font-picker\"\n        [disabled]=\"disabled\"\n        [label]=\"'Font: ' + styleStateFontName\"\n        [messageStream]=\"fontPickerStream\"\n      >\n        <sky-dropdown-button\n          [ngStyle]=\"{\n            'font-family': styleState.font\n          }\"\n        >\n          {{ styleStateFontName }}\n        </sky-dropdown-button>\n        <sky-dropdown-menu>\n          <sky-dropdown-item *ngFor=\"let fontModel of fontList\">\n            <button\n              type=\"button\"\n              [ngStyle]=\"{\n                'font-family': fontModel.value\n              }\"\n              (click)=\"execCommand('fontname', fontModel.name)\"\n            >\n              {{ fontModel.name }}\n            </button>\n          </sky-dropdown-item>\n        </sky-dropdown-menu>\n      </sky-dropdown>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'font-size'\">\n      <sky-dropdown\n        class=\"sky-text-editor-font-size-picker\"\n        [disabled]=\"disabled\"\n        [label]=\"'Font size: ' + styleState.fontSize + 'px'\"\n        [messageStream]=\"fontSizeStream\"\n      >\n        <sky-dropdown-button\n          [ngStyle]=\"{\n            'font-family': styleState.fontSize\n          }\"\n        >\n          {{ styleState.fontSize + 'px' }}\n        </sky-dropdown-button>\n        <sky-dropdown-menu>\n          <sky-dropdown-item *ngFor=\"let size of fontSizeList\">\n            <button type=\"button\" (click)=\"changeFontSize(size)\">\n              {{ size + 'px' }}\n            </button>\n          </sky-dropdown-item>\n        </sky-dropdown-menu>\n      </sky-dropdown>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'font-style'\">\n      <div class=\"sky-switch-icon-group sky-text-editor-font-style-picker\">\n        <sky-checkbox\n          icon=\"bold\"\n          label=\"Bold\"\n          title=\"Bold\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.boldState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.boldState, $event, 'bold')\n          \"\n        >\n        </sky-checkbox>\n        <sky-checkbox\n          icon=\"italic\"\n          label=\"Italicized\"\n          title=\"Italicized\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.italicState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.italicState, $event, 'italic')\n          \"\n        >\n        </sky-checkbox>\n        <sky-checkbox\n          icon=\"underline\"\n          label=\"Underline\"\n          title=\"Underline\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.underlineState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.underlineState, $event, 'underline')\n          \"\n        >\n        </sky-checkbox>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'color'\">\n      <div class=\"sky-text-editor-colorpicker-group\">\n        <div class=\"sky-text-editor-colorpicker-container\">\n          <sky-colorpicker\n            class=\"sky-text-editor-font-color-picker\"\n            label=\"Font color\"\n            [messageStream]=\"colorpickerStream\"\n            [showResetButton]=\"false\"\n            (selectedColorChanged)=\"onColorpickerColorChanged($event)\"\n            pickerButtonIcon=\"highlighter\"\n            pickerButtonIconType=\"skyux\"\n            #colorPicker\n          >\n            <input\n              outputFormat=\"hex\"\n              type=\"text\"\n              [allowTransparency]=\"false\"\n              [disabled]=\"disabled\"\n              [ngModel]=\"styleState.fontColor\"\n              [skyColorpickerInput]=\"colorPicker\"\n            />\n          </sky-colorpicker>\n        </div>\n        <div class=\"sky-text-editor-colorpicker-container\">\n          <sky-colorpicker\n            class=\"sky-text-editor-background-color-picker\"\n            label=\"Background color\"\n            [messageStream]=\"backColorpickerStream\"\n            [showResetButton]=\"false\"\n            (selectedColorChanged)=\"onColorpickerColorChanged($event, true)\"\n            #backColorPicker\n            pickerButtonIcon=\"text-color\"\n            pickerButtonIconType=\"skyux\"\n          >\n            <input\n              outputFormat=\"rgba\"\n              type=\"text\"\n              [allowTransparency]=\"true\"\n              [disabled]=\"disabled\"\n              [ngModel]=\"styleState.backColor\"\n              [skyColorpickerInput]=\"backColorPicker\"\n            />\n          </sky-colorpicker>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'list'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Bulleted list\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Bulleted list\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('insertUnorderedList')\"\n        >\n          <sky-icon icon=\"bullet-list\" />\n        </button>\n        <button\n          aria-label=\"Numbered list\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Numbered list\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('insertOrderedList')\"\n        >\n          <sky-icon icon=\"number-list\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'alignment'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Align left\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align left\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyLeft')\"\n        >\n          <sky-icon icon=\"align-left-text\" />\n        </button>\n        <button\n          aria-label=\"Align center\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align center\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyCenter')\"\n        >\n          <sky-icon icon=\"center-text\" />\n        </button>\n        <button\n          aria-label=\"Align right\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align right\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyRight')\"\n        >\n          <sky-icon icon=\"align-right-text\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'indentation'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Outdent\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Outdent\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('outdent')\"\n        >\n          <sky-icon icon=\"outdent\" />\n        </button>\n        <button\n          aria-label=\"Indent\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Indent\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('indent')\"\n        >\n          <sky-icon icon=\"indent\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'undo-redo'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Undo\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Undo\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('undo')\"\n        >\n          <sky-icon icon=\"undo\" />\n        </button>\n        <button\n          aria-label=\"Redo\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Redo\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('redo')\"\n        >\n          <sky-icon icon=\"redo\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'link'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Link\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Link\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{\n            'icon-btn-active': styleState.linkState\n          }\"\n          (click)=\"link()\"\n        >\n          <sky-icon icon=\"link\" />\n        </button>\n        <button\n          aria-label=\"Unlink\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Unlink\"\n          type=\"button\"\n          [disabled]=\"!styleState.linkState || disabled\"\n          (click)=\"unlink()\"\n        >\n          <sky-icon icon=\"unlink\" />\n        </button>\n      </div>\n    </ng-container>\n  </ng-container>\n</sky-toolbar-item>\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.ts","../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n  inject,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport {\n  SkyColorpickerMessage,\n  SkyColorpickerMessageType,\n  SkyColorpickerModule,\n  SkyColorpickerOutput,\n} from '@skyux/colorpicker';\nimport { SkyCheckboxModule } from '@skyux/forms';\nimport { SkyIconModule } from '@skyux/indicators';\nimport { SkyToolbarModule } from '@skyux/layout';\nimport { SkyModalCloseArgs, SkyModalService } from '@skyux/modals';\nimport {\n  SkyDropdownMessage,\n  SkyDropdownMessageType,\n  SkyDropdownModule,\n} from '@skyux/popovers';\nimport { SkyThemeModule } from '@skyux/theme';\n\nimport { Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyFormsUtility } from '../../shared/forms-utility';\nimport { STYLE_STATE_DEFAULTS } from '../defaults/style-state-defaults';\nimport { SkyTextEditorAdapterService } from '../services/text-editor-adapter.service';\nimport { SkyTextEditorFont } from '../types/font-state';\nimport { SkyTextEditorLinkWindowOptionsType } from '../types/link-window-options-type';\nimport { SkyTextEditorStyleState } from '../types/style-state';\nimport { SkyTextEditorToolbarActionType } from '../types/toolbar-action-type';\nimport { SkyUrlModalContext } from '../url-modal/text-editor-url-modal-context';\nimport { SkyTextEditorUrlModalComponent } from '../url-modal/text-editor-url-modal.component';\nimport { UrlTarget } from '../url-modal/text-editor-url-target';\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor-toolbar',\n  templateUrl: './text-editor-toolbar.component.html',\n  styleUrls: ['./text-editor-toolbar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    SkyCheckboxModule,\n    SkyColorpickerModule,\n    SkyDropdownModule,\n    SkyIconModule,\n    SkyThemeModule,\n    SkyToolbarModule,\n  ],\n})\nexport class SkyTextEditorToolbarComponent implements OnInit {\n  @Input()\n  public set editorFocusStream(value: Subject<void>) {\n    this.#_editorFocusStream = value;\n    this.#subscribeEditorFocus();\n  }\n\n  public get editorFocusStream(): Subject<void> {\n    return this.#_editorFocusStream;\n  }\n\n  @Input()\n  public fontList: SkyTextEditorFont[] = [];\n\n  @Input()\n  public fontSizeList: number[] = [];\n\n  @Input()\n  public toolbarActions: SkyTextEditorToolbarActionType[] = [];\n\n  @Input()\n  public linkWindowOptions: SkyTextEditorLinkWindowOptionsType[] = [];\n\n  @Input()\n  public set styleState(value: SkyTextEditorStyleState) {\n    this.#_styleState = value;\n    if (value.font !== this.styleStateFontName) {\n      if (value.font === '\"Blackbaud Sans\", Arial, sans-serif') {\n        this.styleStateFontName = this.#getFontName('Blackbaud Sans');\n      } else {\n        this.styleStateFontName = this.#getFontName(value.font);\n      }\n    }\n  }\n\n  public get styleState(): SkyTextEditorStyleState {\n    return this.#_styleState;\n  }\n\n  @Input()\n  public set disabled(value: boolean) {\n    const coercedValue = SkyFormsUtility.coerceBooleanProperty(value);\n    if (coercedValue !== this.disabled) {\n      this.#_disabled = coercedValue;\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public backColorpickerStream = new Subject<SkyColorpickerMessage>();\n  public colorpickerStream = new Subject<SkyColorpickerMessage>();\n  public fontPickerStream = new Subject<SkyDropdownMessage>();\n  public fontSizeStream = new Subject<SkyDropdownMessage>();\n  public styleStateFontName: string | undefined;\n\n  #editorFocusStreamSub: Subscription | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_editorFocusStream = new Subject<void>();\n  #_disabled = false;\n  #_styleState = STYLE_STATE_DEFAULTS;\n\n  readonly #adapterService = inject(SkyTextEditorAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #modalService = inject(SkyModalService);\n\n  public ngOnInit(): void {\n    this.#subscribeEditorFocus();\n  }\n\n  public execCommand(command: string, value = ''): void {\n    this.#adapterService.execCommand({\n      command: command,\n      value: value,\n    });\n    this.styleState = {\n      ...this.styleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  public toggleFontStyle(\n    currentState: boolean,\n    newState: boolean,\n    command: string,\n  ): void {\n    if (currentState !== newState) {\n      this.execCommand(command);\n    }\n\n    // Force sky-checkbox to show changes on user's initial click.\n    this.#changeDetector.detectChanges();\n  }\n\n  public link(): void {\n    const priorSelection = this.#adapterService.saveSelection();\n    const currentLink = this.#adapterService.getLink();\n    const inputModal = this.#modalService.open(SkyTextEditorUrlModalComponent, [\n      {\n        provide: SkyUrlModalContext,\n        useFactory: () => {\n          const context = new SkyUrlModalContext();\n          context.urlResult = currentLink;\n          context.linkWindowOptions = this.linkWindowOptions;\n\n          return context;\n        },\n      },\n    ]);\n    inputModal.closed.subscribe((result: SkyModalCloseArgs) => {\n      if (result.reason === 'save' && priorSelection) {\n        if (currentLink) {\n          const anchor = this.#adapterService.getSelectedAnchorTag();\n\n          if (anchor) {\n            this.#adapterService.selectElement(anchor);\n          }\n        }\n\n        this.execCommand('unlink');\n        if (result.data.target === UrlTarget.None) {\n          // Current window\n          this.execCommand('createLink', result.data.url);\n        } else {\n          // New Window\n          const sText = this.#adapterService.getCurrentSelection();\n          this.execCommand(\n            'insertHTML',\n            '<a href=\"' +\n              result.data.url +\n              '\" rel=\"noopener noreferrer\" target=\"_blank\">' +\n              sText +\n              '</a>',\n          );\n        }\n      }\n    });\n  }\n\n  public unlink(): void {\n    const currentSelectionRange = this.#adapterService\n      .getCurrentSelection()\n      ?.getRangeAt(0);\n    if (currentSelectionRange && currentSelectionRange.toString().length <= 0) {\n      const anchorTag = this.#adapterService.getSelectedAnchorTag();\n      if (anchorTag) {\n        this.#adapterService.selectElement(anchorTag);\n      }\n    }\n    this.execCommand('unlink');\n  }\n\n  public changeFontSize(size: number): void {\n    this.#adapterService.setFontSize(size);\n    this.styleState = {\n      ...this.styleState,\n      ...this.#adapterService.getStyleState(),\n    };\n  }\n\n  public onColorpickerColorChanged(\n    color: SkyColorpickerOutput,\n    isBackground = false,\n  ): void {\n    this.execCommand(isBackground ? 'backColor' : 'foreColor', color.hex);\n  }\n\n  #subscribeEditorFocus(): void {\n    this.#editorFocusStreamSub?.unsubscribe();\n\n    this.#editorFocusStreamSub = this.editorFocusStream\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.styleState = {\n          ...this.styleState,\n          ...this.#adapterService.getStyleState(),\n        };\n        this.#closeDropdowns();\n        this.#changeDetector.detectChanges();\n      });\n  }\n\n  #closeDropdowns(): void {\n    const message: SkyColorpickerMessage = {\n      type: SkyColorpickerMessageType.Close,\n    };\n    this.colorpickerStream.next(message);\n    this.backColorpickerStream.next(message);\n    this.fontPickerStream.next({ type: SkyDropdownMessageType.Close });\n    this.fontSizeStream.next({ type: SkyDropdownMessageType.Close });\n  }\n\n  #getFontName(fontName: string): string | undefined {\n    for (let i = 0; i < this.fontList.length; i++) {\n      if (fontName.replace(/['\"]+/g, '') === this.fontList[i].name) {\n        return this.fontList[i].name;\n      }\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n}\n","<sky-toolbar-item\n  *ngFor=\"let action of toolbarActions\"\n  class=\"sky-text-editor-toolbar-action\"\n  [ngClass]=\"'sky-text-editor-toolbar-action-' + action\"\n>\n  <ng-container [ngSwitch]=\"action\">\n    <ng-container *ngSwitchCase=\"'font-family'\">\n      <sky-dropdown\n        class=\"sky-text-editor-font-picker\"\n        [disabled]=\"disabled\"\n        [label]=\"'Font: ' + styleStateFontName\"\n        [messageStream]=\"fontPickerStream\"\n      >\n        <sky-dropdown-button\n          [ngStyle]=\"{\n            'font-family': styleState.font\n          }\"\n        >\n          {{ styleStateFontName }}\n        </sky-dropdown-button>\n        <sky-dropdown-menu>\n          <sky-dropdown-item *ngFor=\"let fontModel of fontList\">\n            <button\n              type=\"button\"\n              [ngStyle]=\"{\n                'font-family': fontModel.value\n              }\"\n              (click)=\"execCommand('fontname', fontModel.name)\"\n            >\n              {{ fontModel.name }}\n            </button>\n          </sky-dropdown-item>\n        </sky-dropdown-menu>\n      </sky-dropdown>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'font-size'\">\n      <sky-dropdown\n        class=\"sky-text-editor-font-size-picker\"\n        [disabled]=\"disabled\"\n        [label]=\"'Font size: ' + styleState.fontSize + 'px'\"\n        [messageStream]=\"fontSizeStream\"\n      >\n        <sky-dropdown-button\n          [ngStyle]=\"{\n            'font-family': styleState.fontSize\n          }\"\n        >\n          {{ styleState.fontSize + 'px' }}\n        </sky-dropdown-button>\n        <sky-dropdown-menu>\n          <sky-dropdown-item *ngFor=\"let size of fontSizeList\">\n            <button type=\"button\" (click)=\"changeFontSize(size)\">\n              {{ size + 'px' }}\n            </button>\n          </sky-dropdown-item>\n        </sky-dropdown-menu>\n      </sky-dropdown>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'font-style'\">\n      <div class=\"sky-switch-icon-group sky-text-editor-font-style-picker\">\n        <sky-checkbox\n          icon=\"bold\"\n          label=\"Bold\"\n          title=\"Bold\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.boldState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.boldState, $event, 'bold')\n          \"\n        >\n        </sky-checkbox>\n        <sky-checkbox\n          icon=\"italic\"\n          label=\"Italicized\"\n          title=\"Italicized\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.italicState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.italicState, $event, 'italic')\n          \"\n        >\n        </sky-checkbox>\n        <sky-checkbox\n          icon=\"underline\"\n          label=\"Underline\"\n          title=\"Underline\"\n          [disabled]=\"disabled\"\n          [ngModel]=\"styleState.underlineState\"\n          (ngModelChange)=\"\n            toggleFontStyle(styleState.underlineState, $event, 'underline')\n          \"\n        >\n        </sky-checkbox>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'color'\">\n      <div class=\"sky-text-editor-colorpicker-group\">\n        <div class=\"sky-text-editor-colorpicker-container\">\n          <sky-colorpicker\n            class=\"sky-text-editor-font-color-picker\"\n            label=\"Font color\"\n            [messageStream]=\"colorpickerStream\"\n            [showResetButton]=\"false\"\n            (selectedColorChanged)=\"onColorpickerColorChanged($event)\"\n            pickerButtonIcon=\"highlighter\"\n            pickerButtonIconType=\"skyux\"\n            #colorPicker\n          >\n            <input\n              outputFormat=\"hex\"\n              type=\"text\"\n              [allowTransparency]=\"false\"\n              [disabled]=\"disabled\"\n              [ngModel]=\"styleState.fontColor\"\n              [skyColorpickerInput]=\"colorPicker\"\n            />\n          </sky-colorpicker>\n        </div>\n        <div class=\"sky-text-editor-colorpicker-container\">\n          <sky-colorpicker\n            class=\"sky-text-editor-background-color-picker\"\n            label=\"Background color\"\n            [messageStream]=\"backColorpickerStream\"\n            [showResetButton]=\"false\"\n            (selectedColorChanged)=\"onColorpickerColorChanged($event, true)\"\n            #backColorPicker\n            pickerButtonIcon=\"text-color\"\n            pickerButtonIconType=\"skyux\"\n          >\n            <input\n              outputFormat=\"rgba\"\n              type=\"text\"\n              [allowTransparency]=\"true\"\n              [disabled]=\"disabled\"\n              [ngModel]=\"styleState.backColor\"\n              [skyColorpickerInput]=\"backColorPicker\"\n            />\n          </sky-colorpicker>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'list'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Bulleted list\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Bulleted list\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('insertUnorderedList')\"\n        >\n          <sky-icon icon=\"bullet-list\" />\n        </button>\n        <button\n          aria-label=\"Numbered list\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Numbered list\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('insertOrderedList')\"\n        >\n          <sky-icon icon=\"number-list\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'alignment'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Align left\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align left\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyLeft')\"\n        >\n          <sky-icon icon=\"align-left-text\" />\n        </button>\n        <button\n          aria-label=\"Align center\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align center\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyCenter')\"\n        >\n          <sky-icon icon=\"center-text\" />\n        </button>\n        <button\n          aria-label=\"Align right\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Align right\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('justifyRight')\"\n        >\n          <sky-icon icon=\"align-right-text\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'indentation'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Outdent\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Outdent\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('outdent')\"\n        >\n          <sky-icon icon=\"outdent\" />\n        </button>\n        <button\n          aria-label=\"Indent\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Indent\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('indent')\"\n        >\n          <sky-icon icon=\"indent\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'undo-redo'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Undo\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Undo\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('undo')\"\n        >\n          <sky-icon icon=\"undo\" />\n        </button>\n        <button\n          aria-label=\"Redo\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Redo\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          (click)=\"execCommand('redo')\"\n        >\n          <sky-icon icon=\"redo\" />\n        </button>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'link'\">\n      <div class=\"sky-switch-icon-group\">\n        <button\n          aria-label=\"Link\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Link\"\n          type=\"button\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{\n            'icon-btn-active': styleState.linkState\n          }\"\n          (click)=\"link()\"\n        >\n          <sky-icon icon=\"link\" />\n        </button>\n        <button\n          aria-label=\"Unlink\"\n          class=\"sky-btn sky-btn-default sky-btn-icon\"\n          title=\"Unlink\"\n          type=\"button\"\n          [disabled]=\"!styleState.linkState || disabled\"\n          (click)=\"unlink()\"\n        >\n          <sky-icon icon=\"unlink\" />\n        </button>\n      </div>\n    </ng-container>\n  </ng-container>\n</sky-toolbar-item>\n"]}
@@ -146,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
146
146
  NgIf,
147
147
  ], template: "<sky-modal>\n <sky-modal-header>\n {{ 'skyux_text_editor_url_modal_header_label' | skyLibResources }}\n </sky-modal-header>\n <sky-modal-content>\n <sky-tabset\n data-sky-id=\"test-tabset\"\n [active]=\"activeTab\"\n (activeChange)=\"activeTabChanged($event)\"\n >\n <sky-tab tabHeading=\"Web page\">\n <div class=\"sky-form-group sky-text-editor-url-modal-first-field\">\n <sky-input-box\n class=\"sky-text-editor-url-input\"\n stacked=\"true\"\n [hintText]=\"\n openLinksInNewWindowOnly\n ? ('skyux_text_editor_url_modal_open_in_new_window_label'\n | skyLibResources)\n : undefined\n \"\n >\n <label\n class=\"sky-control-label sky-control-label-required\"\n [for]=\"urlInput.id\"\n >\n {{ 'skyux_text_editor_url_modal_url_label' | skyLibResources }}\n </label>\n <input\n class=\"sky-form-control\"\n type=\"text\"\n [(ngModel)]=\"url\"\n skyId\n #urlInput=\"skyId\"\n />\n </sky-input-box>\n </div>\n <sky-input-box\n *ngIf=\"allowAllOpenLinkOptions\"\n stacked=\"true\"\n class=\"sky-form-group\"\n >\n <label class=\"sky-control-label\" [for]=\"targetInput.id\">\n {{ 'skyux_text_editor_url_modal_open_label' | skyLibResources }}\n </label>\n <select\n class=\"sky-form-control\"\n [(ngModel)]=\"target\"\n skyId\n #targetInput=\"skyId\"\n >\n <option value=\"0\">\n {{\n 'skyux_text_editor_url_modal_current_option_label'\n | skyLibResources\n }}\n </option>\n <option value=\"1\">\n {{\n 'skyux_text_editor_url_modal_new_option_label' | skyLibResources\n }}\n </option>\n </select>\n </sky-input-box>\n </sky-tab>\n <sky-tab tabHeading=\"Email address\">\n <div class=\"sky-form-group first-field\">\n <sky-input-box stacked=\"true\">\n <label\n class=\"sky-control-label sky-control-label-required\"\n [for]=\"emailAddressInput.id\"\n >\n {{ 'skyux_text_editor_url_modal_email_label' | skyLibResources }}\n </label>\n <input\n class=\"sky-form-control\"\n type=\"text\"\n [(ngModel)]=\"emailAddress\"\n skyId\n #emailAddressInput=\"skyId\"\n />\n </sky-input-box>\n </div>\n <sky-input-box stacked=\"true\" class=\"sky-form-group\">\n <label class=\"sky-control-label\" [for]=\"subjectInput.id\">\n {{ 'skyux_text_editor_url_modal_subject_label' | skyLibResources }}\n </label>\n <input\n class=\"sky-form-control\"\n type=\"text\"\n [(ngModel)]=\"subject\"\n skyId\n #subjectInput=\"skyId\"\n />\n </sky-input-box>\n </sky-tab>\n </sky-tabset>\n </sky-modal-content>\n <sky-modal-footer>\n <button\n type=\"submit\"\n class=\"sky-btn sky-btn-primary\"\n [disabled]=\"!valid\"\n (click)=\"save()\"\n >\n {{ 'skyux_text_editor_url_modal_save_button_label' | skyLibResources }}\n </button>\n <button type=\"button\" class=\"sky-btn sky-btn-link\" (click)=\"cancel()\">\n {{ 'skyux_text_editor_url_modal_cancel_button_label' | skyLibResources }}\n </button>\n </sky-modal-footer>\n</sky-modal>\n", styles: [".sky-text-editor-url-modal-first-field{margin-top:15px}\n"] }]
148
148
  }], ctorParameters: function () { return []; } });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor-url-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/url-modal/text-editor-url-modal.component.ts","../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/url-modal/text-editor-url-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { SkyIdModule } from '@skyux/core';\nimport { SkyInputBoxModule } from '@skyux/forms';\nimport { SkyModalInstance, SkyModalModule } from '@skyux/modals';\nimport { SkyTabIndex, SkyTabsModule } from '@skyux/tabs';\nimport { SkyValidation } from '@skyux/validation';\n\nimport { SkyTextEditorResourcesModule } from '../../shared/sky-text-editor-resources.module';\n\nimport { SkyUrlModalContext } from './text-editor-url-modal-context';\nimport { UrlModalResult } from './text-editor-url-modal-result';\nimport { UrlTarget } from './text-editor-url-target';\n\nconst emailKey = 'mailto:';\nconst queryStringParamKey = '?Subject=';\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor-url-modal',\n  templateUrl: './text-editor-url-modal.component.html',\n  styleUrls: ['./text-editor-url-modal.component.scss'],\n  imports: [\n    FormsModule,\n    SkyModalModule,\n    SkyIdModule,\n    SkyInputBoxModule,\n    SkyTabsModule,\n    SkyTextEditorResourcesModule,\n    NgIf,\n  ],\n})\nexport class SkyTextEditorUrlModalComponent {\n  public set activeTab(value: number) {\n    this.#_activeTab = value;\n    this.valid = this.#isValid();\n  }\n\n  public get activeTab(): number {\n    return this.#_activeTab;\n  }\n\n  public set emailAddress(value: string) {\n    this.#_emailAddress = value;\n    this.valid = this.#isValid();\n  }\n\n  public get emailAddress(): string {\n    return this.#_emailAddress;\n  }\n\n  public set url(value: string) {\n    this.#_url = value;\n    this.valid = this.#isValid();\n  }\n\n  public get url(): string {\n    return this.#_url;\n  }\n\n  public emailAddressValid = false;\n  public allowAllOpenLinkOptions = true;\n  public openLinksInNewWindowOnly = false;\n  public subject = '';\n  public target: number | string = 0;\n  public valid = false;\n\n  #_activeTab = 0;\n  #_emailAddress = '';\n  #_url = 'https://';\n\n  readonly #modalContext = inject(SkyUrlModalContext);\n  readonly #modalInstance = inject(SkyModalInstance);\n\n  constructor() {\n    const linkWindowOptions = this.#modalContext.linkWindowOptions;\n\n    if (linkWindowOptions?.length === 1) {\n      this.allowAllOpenLinkOptions = false;\n      if (linkWindowOptions[0] === 'new') {\n        this.openLinksInNewWindowOnly = true;\n        this.target = 1;\n      } else {\n        this.target = 0;\n      }\n    }\n\n    if (this.#modalContext.urlResult) {\n      if (this.#modalContext.urlResult.url.startsWith(emailKey)) {\n        this.emailAddress = this.#modalContext.urlResult.url.replace(\n          emailKey,\n          ''\n        );\n\n        let queryStringIndex = this.emailAddress.indexOf(queryStringParamKey);\n        queryStringIndex =\n          queryStringIndex > -1\n            ? queryStringIndex\n            : this.emailAddress.indexOf(queryStringParamKey.toLowerCase());\n\n        /* istanbul ignore else */\n        if (queryStringIndex > -1) {\n          this.subject = decodeURI(this.emailAddress).slice(\n            queryStringIndex + queryStringParamKey.length\n          );\n          this.emailAddress = this.emailAddress.slice(0, queryStringIndex);\n        }\n\n        // Set active tab to email\n        this.activeTab = 1;\n      } else {\n        (this.url = this.#modalContext.urlResult.url),\n          (this.target = this.#modalContext.urlResult.target as any);\n\n        // set active tab to web page\n        this.activeTab = 0;\n      }\n    }\n  }\n\n  public activeTabChanged(value: SkyTabIndex): void {\n    this.activeTab = Number(value);\n  }\n\n  public save(): void {\n    /* istanbul ignore else */\n    if (this.#isValid()) {\n      if (this.activeTab === 0) {\n        this.#modalInstance.save({\n          url: this.url,\n          target: this.target\n            ? parseInt(this.target as string, undefined)\n            : UrlTarget.None,\n        } as UrlModalResult);\n      } else {\n        this.#modalInstance.save({\n          url: this.#getEmailUrl(),\n          target: UrlTarget.None,\n        } as UrlModalResult);\n      }\n    }\n  }\n\n  public cancel(): void {\n    this.#modalInstance.cancel();\n  }\n\n  #getEmailUrl(): string {\n    return (\n      emailKey +\n      this.emailAddress +\n      (this.subject ? '?Subject=' + encodeURI(this.subject) : '')\n    );\n  }\n\n  #isValid(): boolean {\n    if (this.activeTab === 0) {\n      return !!this.url && SkyValidation.isUrl(this.url);\n    }\n    return !!this.emailAddress && SkyValidation.isEmail(this.emailAddress);\n  }\n}\n","<sky-modal>\n  <sky-modal-header>\n    {{ 'skyux_text_editor_url_modal_header_label' | skyLibResources }}\n  </sky-modal-header>\n  <sky-modal-content>\n    <sky-tabset\n      data-sky-id=\"test-tabset\"\n      [active]=\"activeTab\"\n      (activeChange)=\"activeTabChanged($event)\"\n    >\n      <sky-tab tabHeading=\"Web page\">\n        <div class=\"sky-form-group sky-text-editor-url-modal-first-field\">\n          <sky-input-box\n            class=\"sky-text-editor-url-input\"\n            stacked=\"true\"\n            [hintText]=\"\n              openLinksInNewWindowOnly\n                ? ('skyux_text_editor_url_modal_open_in_new_window_label'\n                  | skyLibResources)\n                : undefined\n            \"\n          >\n            <label\n              class=\"sky-control-label sky-control-label-required\"\n              [for]=\"urlInput.id\"\n            >\n              {{ 'skyux_text_editor_url_modal_url_label' | skyLibResources }}\n            </label>\n            <input\n              class=\"sky-form-control\"\n              type=\"text\"\n              [(ngModel)]=\"url\"\n              skyId\n              #urlInput=\"skyId\"\n            />\n          </sky-input-box>\n        </div>\n        <sky-input-box\n          *ngIf=\"allowAllOpenLinkOptions\"\n          stacked=\"true\"\n          class=\"sky-form-group\"\n        >\n          <label class=\"sky-control-label\" [for]=\"targetInput.id\">\n            {{ 'skyux_text_editor_url_modal_open_label' | skyLibResources }}\n          </label>\n          <select\n            class=\"sky-form-control\"\n            [(ngModel)]=\"target\"\n            skyId\n            #targetInput=\"skyId\"\n          >\n            <option value=\"0\">\n              {{\n                'skyux_text_editor_url_modal_current_option_label'\n                  | skyLibResources\n              }}\n            </option>\n            <option value=\"1\">\n              {{\n                'skyux_text_editor_url_modal_new_option_label' | skyLibResources\n              }}\n            </option>\n          </select>\n        </sky-input-box>\n      </sky-tab>\n      <sky-tab tabHeading=\"Email address\">\n        <div class=\"sky-form-group first-field\">\n          <sky-input-box stacked=\"true\">\n            <label\n              class=\"sky-control-label sky-control-label-required\"\n              [for]=\"emailAddressInput.id\"\n            >\n              {{ 'skyux_text_editor_url_modal_email_label' | skyLibResources }}\n            </label>\n            <input\n              class=\"sky-form-control\"\n              type=\"text\"\n              [(ngModel)]=\"emailAddress\"\n              skyId\n              #emailAddressInput=\"skyId\"\n            />\n          </sky-input-box>\n        </div>\n        <sky-input-box stacked=\"true\" class=\"sky-form-group\">\n          <label class=\"sky-control-label\" [for]=\"subjectInput.id\">\n            {{ 'skyux_text_editor_url_modal_subject_label' | skyLibResources }}\n          </label>\n          <input\n            class=\"sky-form-control\"\n            type=\"text\"\n            [(ngModel)]=\"subject\"\n            skyId\n            #subjectInput=\"skyId\"\n          />\n        </sky-input-box>\n      </sky-tab>\n    </sky-tabset>\n  </sky-modal-content>\n  <sky-modal-footer>\n    <button\n      type=\"submit\"\n      class=\"sky-btn sky-btn-primary\"\n      [disabled]=\"!valid\"\n      (click)=\"save()\"\n    >\n      {{ 'skyux_text_editor_url_modal_save_button_label' | skyLibResources }}\n    </button>\n    <button type=\"button\" class=\"sky-btn sky-btn-link\" (click)=\"cancel()\">\n      {{ 'skyux_text_editor_url_modal_cancel_button_label' | skyLibResources }}\n    </button>\n  </sky-modal-footer>\n</sky-modal>\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor-url-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/url-modal/text-editor-url-modal.component.ts","../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/url-modal/text-editor-url-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, inject } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { SkyIdModule } from '@skyux/core';\nimport { SkyInputBoxModule } from '@skyux/forms';\nimport { SkyModalInstance, SkyModalModule } from '@skyux/modals';\nimport { SkyTabIndex, SkyTabsModule } from '@skyux/tabs';\nimport { SkyValidation } from '@skyux/validation';\n\nimport { SkyTextEditorResourcesModule } from '../../shared/sky-text-editor-resources.module';\n\nimport { SkyUrlModalContext } from './text-editor-url-modal-context';\nimport { UrlModalResult } from './text-editor-url-modal-result';\nimport { UrlTarget } from './text-editor-url-target';\n\nconst emailKey = 'mailto:';\nconst queryStringParamKey = '?Subject=';\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-text-editor-url-modal',\n  templateUrl: './text-editor-url-modal.component.html',\n  styleUrls: ['./text-editor-url-modal.component.scss'],\n  imports: [\n    FormsModule,\n    SkyModalModule,\n    SkyIdModule,\n    SkyInputBoxModule,\n    SkyTabsModule,\n    SkyTextEditorResourcesModule,\n    NgIf,\n  ],\n})\nexport class SkyTextEditorUrlModalComponent {\n  public set activeTab(value: number) {\n    this.#_activeTab = value;\n    this.valid = this.#isValid();\n  }\n\n  public get activeTab(): number {\n    return this.#_activeTab;\n  }\n\n  public set emailAddress(value: string) {\n    this.#_emailAddress = value;\n    this.valid = this.#isValid();\n  }\n\n  public get emailAddress(): string {\n    return this.#_emailAddress;\n  }\n\n  public set url(value: string) {\n    this.#_url = value;\n    this.valid = this.#isValid();\n  }\n\n  public get url(): string {\n    return this.#_url;\n  }\n\n  public emailAddressValid = false;\n  public allowAllOpenLinkOptions = true;\n  public openLinksInNewWindowOnly = false;\n  public subject = '';\n  public target: number | string = 0;\n  public valid = false;\n\n  #_activeTab = 0;\n  #_emailAddress = '';\n  #_url = 'https://';\n\n  readonly #modalContext = inject(SkyUrlModalContext);\n  readonly #modalInstance = inject(SkyModalInstance);\n\n  constructor() {\n    const linkWindowOptions = this.#modalContext.linkWindowOptions;\n\n    if (linkWindowOptions?.length === 1) {\n      this.allowAllOpenLinkOptions = false;\n      if (linkWindowOptions[0] === 'new') {\n        this.openLinksInNewWindowOnly = true;\n        this.target = 1;\n      } else {\n        this.target = 0;\n      }\n    }\n\n    if (this.#modalContext.urlResult) {\n      if (this.#modalContext.urlResult.url.startsWith(emailKey)) {\n        this.emailAddress = this.#modalContext.urlResult.url.replace(\n          emailKey,\n          '',\n        );\n\n        let queryStringIndex = this.emailAddress.indexOf(queryStringParamKey);\n        queryStringIndex =\n          queryStringIndex > -1\n            ? queryStringIndex\n            : this.emailAddress.indexOf(queryStringParamKey.toLowerCase());\n\n        /* istanbul ignore else */\n        if (queryStringIndex > -1) {\n          this.subject = decodeURI(this.emailAddress).slice(\n            queryStringIndex + queryStringParamKey.length,\n          );\n          this.emailAddress = this.emailAddress.slice(0, queryStringIndex);\n        }\n\n        // Set active tab to email\n        this.activeTab = 1;\n      } else {\n        (this.url = this.#modalContext.urlResult.url),\n          (this.target = this.#modalContext.urlResult.target as any);\n\n        // set active tab to web page\n        this.activeTab = 0;\n      }\n    }\n  }\n\n  public activeTabChanged(value: SkyTabIndex): void {\n    this.activeTab = Number(value);\n  }\n\n  public save(): void {\n    /* istanbul ignore else */\n    if (this.#isValid()) {\n      if (this.activeTab === 0) {\n        this.#modalInstance.save({\n          url: this.url,\n          target: this.target\n            ? parseInt(this.target as string, undefined)\n            : UrlTarget.None,\n        } as UrlModalResult);\n      } else {\n        this.#modalInstance.save({\n          url: this.#getEmailUrl(),\n          target: UrlTarget.None,\n        } as UrlModalResult);\n      }\n    }\n  }\n\n  public cancel(): void {\n    this.#modalInstance.cancel();\n  }\n\n  #getEmailUrl(): string {\n    return (\n      emailKey +\n      this.emailAddress +\n      (this.subject ? '?Subject=' + encodeURI(this.subject) : '')\n    );\n  }\n\n  #isValid(): boolean {\n    if (this.activeTab === 0) {\n      return !!this.url && SkyValidation.isUrl(this.url);\n    }\n    return !!this.emailAddress && SkyValidation.isEmail(this.emailAddress);\n  }\n}\n","<sky-modal>\n  <sky-modal-header>\n    {{ 'skyux_text_editor_url_modal_header_label' | skyLibResources }}\n  </sky-modal-header>\n  <sky-modal-content>\n    <sky-tabset\n      data-sky-id=\"test-tabset\"\n      [active]=\"activeTab\"\n      (activeChange)=\"activeTabChanged($event)\"\n    >\n      <sky-tab tabHeading=\"Web page\">\n        <div class=\"sky-form-group sky-text-editor-url-modal-first-field\">\n          <sky-input-box\n            class=\"sky-text-editor-url-input\"\n            stacked=\"true\"\n            [hintText]=\"\n              openLinksInNewWindowOnly\n                ? ('skyux_text_editor_url_modal_open_in_new_window_label'\n                  | skyLibResources)\n                : undefined\n            \"\n          >\n            <label\n              class=\"sky-control-label sky-control-label-required\"\n              [for]=\"urlInput.id\"\n            >\n              {{ 'skyux_text_editor_url_modal_url_label' | skyLibResources }}\n            </label>\n            <input\n              class=\"sky-form-control\"\n              type=\"text\"\n              [(ngModel)]=\"url\"\n              skyId\n              #urlInput=\"skyId\"\n            />\n          </sky-input-box>\n        </div>\n        <sky-input-box\n          *ngIf=\"allowAllOpenLinkOptions\"\n          stacked=\"true\"\n          class=\"sky-form-group\"\n        >\n          <label class=\"sky-control-label\" [for]=\"targetInput.id\">\n            {{ 'skyux_text_editor_url_modal_open_label' | skyLibResources }}\n          </label>\n          <select\n            class=\"sky-form-control\"\n            [(ngModel)]=\"target\"\n            skyId\n            #targetInput=\"skyId\"\n          >\n            <option value=\"0\">\n              {{\n                'skyux_text_editor_url_modal_current_option_label'\n                  | skyLibResources\n              }}\n            </option>\n            <option value=\"1\">\n              {{\n                'skyux_text_editor_url_modal_new_option_label' | skyLibResources\n              }}\n            </option>\n          </select>\n        </sky-input-box>\n      </sky-tab>\n      <sky-tab tabHeading=\"Email address\">\n        <div class=\"sky-form-group first-field\">\n          <sky-input-box stacked=\"true\">\n            <label\n              class=\"sky-control-label sky-control-label-required\"\n              [for]=\"emailAddressInput.id\"\n            >\n              {{ 'skyux_text_editor_url_modal_email_label' | skyLibResources }}\n            </label>\n            <input\n              class=\"sky-form-control\"\n              type=\"text\"\n              [(ngModel)]=\"emailAddress\"\n              skyId\n              #emailAddressInput=\"skyId\"\n            />\n          </sky-input-box>\n        </div>\n        <sky-input-box stacked=\"true\" class=\"sky-form-group\">\n          <label class=\"sky-control-label\" [for]=\"subjectInput.id\">\n            {{ 'skyux_text_editor_url_modal_subject_label' | skyLibResources }}\n          </label>\n          <input\n            class=\"sky-form-control\"\n            type=\"text\"\n            [(ngModel)]=\"subject\"\n            skyId\n            #subjectInput=\"skyId\"\n          />\n        </sky-input-box>\n      </sky-tab>\n    </sky-tabset>\n  </sky-modal-content>\n  <sky-modal-footer>\n    <button\n      type=\"submit\"\n      class=\"sky-btn sky-btn-primary\"\n      [disabled]=\"!valid\"\n      (click)=\"save()\"\n    >\n      {{ 'skyux_text_editor_url_modal_save_button_label' | skyLibResources }}\n    </button>\n    <button type=\"button\" class=\"sky-btn sky-btn-link\" (click)=\"cancel()\">\n      {{ 'skyux_text_editor_url_modal_cancel_button_label' | skyLibResources }}\n    </button>\n  </sky-modal-footer>\n</sky-modal>\n"]}