@skyux/text-editor 11.37.0 → 11.38.1

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.
@@ -41,22 +41,7 @@ export class SkyTextEditorComponent {
41
41
  set disabled(value) {
42
42
  if (value !== this.disabled) {
43
43
  this.#_disabled = value;
44
- // Update focusableChildren inside the iframe.
45
- let focusableChildren;
46
- /* istanbul ignore else */
47
- if (this.iframeRef) {
48
- focusableChildren = this.#coreAdapterService.getFocusableChildren(this.iframeRef.nativeElement.contentDocument.body, {
49
- ignoreVisibility: true,
50
- ignoreTabIndex: true,
51
- });
52
- if (this.#_disabled) {
53
- this.#adapterService.disableEditor(focusableChildren, this.iframeRef.nativeElement);
54
- }
55
- else {
56
- this.#adapterService.enableEditor(focusableChildren, this.iframeRef.nativeElement);
57
- }
58
- this.#changeDetector.markForCheck();
59
- }
44
+ this.#applyDisabledState();
60
45
  }
61
46
  }
62
47
  get disabled() {
@@ -406,6 +391,7 @@ export class SkyTextEditorComponent {
406
391
  if (this.autofocus) {
407
392
  this.#adapterService.focusEditor();
408
393
  }
394
+ this.#applyDisabledState();
409
395
  this.#initialized = true;
410
396
  this.#focusInitialized = false;
411
397
  this.#checkAutofocusAndFocus();
@@ -424,6 +410,24 @@ export class SkyTextEditorComponent {
424
410
  this.#_onChange(this.#_value);
425
411
  }
426
412
  }
413
+ #applyDisabledState() {
414
+ // Update focusableChildren inside the iframe.
415
+ let focusableChildren;
416
+ /* istanbul ignore else */
417
+ if (this.iframeRef?.nativeElement.contentDocument?.body) {
418
+ focusableChildren = this.#coreAdapterService.getFocusableChildren(this.iframeRef.nativeElement.contentDocument.body, {
419
+ ignoreVisibility: true,
420
+ ignoreTabIndex: true,
421
+ });
422
+ if (this.#_disabled) {
423
+ this.#adapterService.disableEditor(focusableChildren, this.iframeRef.nativeElement);
424
+ }
425
+ else {
426
+ this.#adapterService.enableEditor(focusableChildren, this.iframeRef.nativeElement);
427
+ }
428
+ this.#changeDetector.markForCheck();
429
+ }
430
+ }
427
431
  /* istanbul ignore next */
428
432
  #_onTouched;
429
433
  /* istanbul ignore next */
@@ -511,4 +515,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
511
515
  type: HostBinding,
512
516
  args: ['class.sky-form-control']
513
517
  }] } });
514
- //# 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  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { SkyCoreAdapterService, SkyIdModule, SkyIdService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxHostService,\n  SkyRequiredStateDirective,\n} from '@skyux/forms';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyToolbarModule } from '@skyux/layout';\nimport { SkyThemeModule } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTextEditorResourcesModule } from '../shared/sky-text-editor-resources.module';\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    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  hostDirectives: [\n    {\n      directive: SkyRequiredStateDirective,\n      inputs: ['required'],\n    },\n  ],\n  imports: [\n    CommonModule,\n    SkyHelpInlineModule,\n    SkyIdModule,\n    SkyTextEditorMenubarComponent,\n    SkyTextEditorToolbarComponent,\n    SkyThemeModule,\n    SkyToolbarModule,\n    SkyFormErrorsModule,\n    SkyTextEditorResourcesModule,\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({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value !== this.disabled) {\n      this.#_disabled = value;\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 content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to the text editor. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\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 text to display as the text editor's label.\n   */\n  @Input()\n  public set labelText(value: string | undefined) {\n    this.#_labelText = value;\n    this.#updateA11yAttributes();\n  }\n\n  public get labelText(): string | undefined {\n    return this.#_labelText;\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   * Whether the text editor is stacked on another form component. When specified,\n   * the appropriate vertical spacing is automatically added to the text editor.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-form-field-stacked')\n  public stacked = false;\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  /**\n   * A help key that identifies the global help content to display. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the text editor label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\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      // #initIframe() will do another check later to see if the editor should\n      // receive focus if not initialized before this is called.\n      this.#checkAutofocusAndFocus();\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  protected editorFocused = false;\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  #_labelText: string | undefined;\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 #sanitizationService = inject(SkyTextSanitizationService);\n  readonly #zone = inject(NgZone);\n\n  protected readonly errorId = this.#idSvc.generateId();\n  protected readonly ngControl = inject(NgControl);\n  protected readonly requiredState = inject(SkyRequiredStateDirective);\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  #checkAutofocusAndFocus(): void {\n    // Don't set focus on the editor if the iframe isn't initialized.\n    // Autofocus isn't testable in Firefox and IE.\n    /* istanbul ignore next */\n    if (this.autofocus && this.#initialized && !this.#focusInitialized) {\n      this.#adapterService.focusEditor();\n      this.#focusInitialized = true;\n    }\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.ngControl.statusChanges\n      ?.pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateA11yAttributes();\n\n        // Trigger change detection when the field status is modified programmatically.\n        this.#changeDetector.markForCheck();\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          this.editorFocused = false;\n          this.#changeDetector.markForCheck();\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.#editorService\n      .focusListener()\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.editorFocused = true;\n          this.#changeDetector.markForCheck();\n        });\n      });\n\n    this.#adapterService.setEditorInnerHtml(this.#_value);\n    this.#updateA11yAttributes();\n\n    /* istanbul ignore next */\n    if (this.autofocus) {\n      this.#adapterService.focusEditor();\n    }\n\n    this.#initialized = true;\n    this.#focusInitialized = false;\n\n    this.#checkAutofocusAndFocus();\n  }\n\n  #updateA11yAttributes(): void {\n    if (this.#editorService.isInitialized) {\n      this.#adapterService.setLabelAttribute(this.labelText);\n      this.#adapterService.setErrorAttributes(\n        this.labelText ? this.errorId : '',\n        this.ngControl.errors,\n      );\n      this.#adapterService.setRequiredAttribute(\n        this.requiredState.isRequired(),\n      );\n    }\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\n  /* istanbul ignore next */\n  #_onChange: (\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value: any,\n  ) => void = () => {};\n}\n","<div\n  class=\"sky-text-editor\"\n  [ngClass]=\"{\n    'sky-text-editor-disabled': disabled,\n    'sky-text-editor-wrapper-focused': editorFocused,\n    'sky-text-editor-invalid':\n      ngControl.errors && (ngControl.touched || ngControl.dirty)\n  }\"\n>\n  <div class=\"sky-text-editor-label-wrapper\">\n    @if (labelText) {\n      <label\n        class=\"sky-control-label\"\n        [ngClass]=\"{\n          'sky-control-label-required': requiredState.isRequired()\n        }\"\n        >{{ labelText }}</label\n      >\n      @if (helpPopoverContent || helpKey) {\n        <span class=\"sky-control-help-container\">\n          <sky-help-inline\n            [helpKey]=\"helpKey\"\n            [labelText]=\"labelText\"\n            [popoverContent]=\"helpPopoverContent\"\n            [popoverTitle]=\"helpPopoverTitle\"\n          />\n        </span>\n      }\n    }\n  </div>\n  @if (\n    (menus && menus.length) > 0 || (toolbarActions && toolbarActions.length > 0)\n  ) {\n    <sky-toolbar class=\"sky-text-editor-toolbar\">\n      @if (menus && menus.length > 0) {\n        <sky-toolbar-section\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-toolbar-section>\n      }\n      @if (toolbarActions && toolbarActions.length > 0) {\n        <sky-toolbar-section\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-toolbar-section>\n      }\n    </sky-toolbar>\n  }\n  <iframe\n    #iframe\n    class=\"sky-text-editor-wrapper\"\n    src=\"about:blank\"\n    allow=\"clipboard-read *; clipboard-write *\"\n    [attr.title]=\"\n      labelText || ('skyux_text_editor_iframe_title_default' | skyLibResources)\n    \"\n    [attr.aria-describedby]=\"hintText ? hintTextEl.id : undefined\"\n    [ngClass]=\"{\n      'sky-text-editor-wrapper-disabled': disabled\n    }\"\n    (load)=\"onIframeLoad()\"\n  >\n  </iframe>\n</div>\n<div\n  #hintTextEl=\"skyId\"\n  skyId\n  class=\"sky-text-editor-hint-text\"\n  [skyThemeClass]=\"{\n    'sky-font-deemphasized': 'default',\n    'sky-font-hint-text-s': 'modern'\n  }\"\n>\n  {{ hintText }}\n</div>\n<sky-form-errors\n  class=\"sky-text-editor-errors\"\n  [id]=\"errorId\"\n  [errors]=\"ngControl.errors\"\n  [labelText]=\"labelText\"\n  [touched]=\"ngControl.touched\"\n  [dirty]=\"ngControl.dirty\"\n>\n  <ng-content select=\"sky-form-error\" />\n</sky-form-errors>\n"]}
518
+ //# 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  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { SkyCoreAdapterService, SkyIdModule, SkyIdService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxHostService,\n  SkyRequiredStateDirective,\n} from '@skyux/forms';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyToolbarModule } from '@skyux/layout';\nimport { SkyThemeModule } from '@skyux/theme';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTextEditorResourcesModule } from '../shared/sky-text-editor-resources.module';\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    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  hostDirectives: [\n    {\n      directive: SkyRequiredStateDirective,\n      inputs: ['required'],\n    },\n  ],\n  imports: [\n    CommonModule,\n    SkyHelpInlineModule,\n    SkyIdModule,\n    SkyTextEditorMenubarComponent,\n    SkyTextEditorToolbarComponent,\n    SkyThemeModule,\n    SkyToolbarModule,\n    SkyFormErrorsModule,\n    SkyTextEditorResourcesModule,\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({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value !== this.disabled) {\n      this.#_disabled = value;\n      this.#applyDisabledState();\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 content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to the text editor. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\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 text to display as the text editor's label.\n   */\n  @Input()\n  public set labelText(value: string | undefined) {\n    this.#_labelText = value;\n    this.#updateA11yAttributes();\n  }\n\n  public get labelText(): string | undefined {\n    return this.#_labelText;\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   * Whether the text editor is stacked on another form component. When specified,\n   * the appropriate vertical spacing is automatically added to the text editor.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-form-field-stacked')\n  public stacked = false;\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  /**\n   * A help key that identifies the global help content to display. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the text editor label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\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      // #initIframe() will do another check later to see if the editor should\n      // receive focus if not initialized before this is called.\n      this.#checkAutofocusAndFocus();\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  protected editorFocused = false;\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  #_labelText: string | undefined;\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 #sanitizationService = inject(SkyTextSanitizationService);\n  readonly #zone = inject(NgZone);\n\n  protected readonly errorId = this.#idSvc.generateId();\n  protected readonly ngControl = inject(NgControl);\n  protected readonly requiredState = inject(SkyRequiredStateDirective);\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  #checkAutofocusAndFocus(): void {\n    // Don't set focus on the editor if the iframe isn't initialized.\n    // Autofocus isn't testable in Firefox and IE.\n    /* istanbul ignore next */\n    if (this.autofocus && this.#initialized && !this.#focusInitialized) {\n      this.#adapterService.focusEditor();\n      this.#focusInitialized = true;\n    }\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.ngControl.statusChanges\n      ?.pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#updateA11yAttributes();\n\n        // Trigger change detection when the field status is modified programmatically.\n        this.#changeDetector.markForCheck();\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          this.editorFocused = false;\n          this.#changeDetector.markForCheck();\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.#editorService\n      .focusListener()\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.editorFocused = true;\n          this.#changeDetector.markForCheck();\n        });\n      });\n\n    this.#adapterService.setEditorInnerHtml(this.#_value);\n    this.#updateA11yAttributes();\n\n    /* istanbul ignore next */\n    if (this.autofocus) {\n      this.#adapterService.focusEditor();\n    }\n\n    this.#applyDisabledState();\n\n    this.#initialized = true;\n    this.#focusInitialized = false;\n\n    this.#checkAutofocusAndFocus();\n  }\n\n  #updateA11yAttributes(): void {\n    if (this.#editorService.isInitialized) {\n      this.#adapterService.setLabelAttribute(this.labelText);\n      this.#adapterService.setErrorAttributes(\n        this.labelText ? this.errorId : '',\n        this.ngControl.errors,\n      );\n      this.#adapterService.setRequiredAttribute(\n        this.requiredState.isRequired(),\n      );\n    }\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  #applyDisabledState(): void {\n    // Update focusableChildren inside the iframe.\n    let focusableChildren: HTMLElement[];\n    /* istanbul ignore else */\n    if (this.iframeRef?.nativeElement.contentDocument?.body) {\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  /* istanbul ignore next */\n  #_onTouched = (): void => {};\n\n  /* istanbul ignore next */\n  #_onChange: (\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value: any,\n  ) => void = () => {};\n}\n","<div\n  class=\"sky-text-editor\"\n  [ngClass]=\"{\n    'sky-text-editor-disabled': disabled,\n    'sky-text-editor-wrapper-focused': editorFocused,\n    'sky-text-editor-invalid':\n      ngControl.errors && (ngControl.touched || ngControl.dirty)\n  }\"\n>\n  <div class=\"sky-text-editor-label-wrapper\">\n    @if (labelText) {\n      <label\n        class=\"sky-control-label\"\n        [ngClass]=\"{\n          'sky-control-label-required': requiredState.isRequired()\n        }\"\n        >{{ labelText }}</label\n      >\n      @if (helpPopoverContent || helpKey) {\n        <span class=\"sky-control-help-container\">\n          <sky-help-inline\n            [helpKey]=\"helpKey\"\n            [labelText]=\"labelText\"\n            [popoverContent]=\"helpPopoverContent\"\n            [popoverTitle]=\"helpPopoverTitle\"\n          />\n        </span>\n      }\n    }\n  </div>\n  @if (\n    (menus && menus.length) > 0 || (toolbarActions && toolbarActions.length > 0)\n  ) {\n    <sky-toolbar class=\"sky-text-editor-toolbar\">\n      @if (menus && menus.length > 0) {\n        <sky-toolbar-section\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-toolbar-section>\n      }\n      @if (toolbarActions && toolbarActions.length > 0) {\n        <sky-toolbar-section\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-toolbar-section>\n      }\n    </sky-toolbar>\n  }\n  <iframe\n    #iframe\n    class=\"sky-text-editor-wrapper\"\n    src=\"about:blank\"\n    allow=\"clipboard-read *; clipboard-write *\"\n    [attr.title]=\"\n      labelText || ('skyux_text_editor_iframe_title_default' | skyLibResources)\n    \"\n    [attr.aria-describedby]=\"hintText ? hintTextEl.id : undefined\"\n    [ngClass]=\"{\n      'sky-text-editor-wrapper-disabled': disabled\n    }\"\n    (load)=\"onIframeLoad()\"\n  >\n  </iframe>\n</div>\n<div\n  #hintTextEl=\"skyId\"\n  skyId\n  class=\"sky-text-editor-hint-text\"\n  [skyThemeClass]=\"{\n    'sky-font-deemphasized': 'default',\n    'sky-font-hint-text-s': 'modern'\n  }\"\n>\n  {{ hintText }}\n</div>\n<sky-form-errors\n  class=\"sky-text-editor-errors\"\n  [id]=\"errorId\"\n  [errors]=\"ngControl.errors\"\n  [labelText]=\"labelText\"\n  [touched]=\"ngControl.touched\"\n  [dirty]=\"ngControl.dirty\"\n>\n  <ng-content select=\"sky-form-error\" />\n</sky-form-errors>\n"]}
@@ -1463,22 +1463,7 @@ class SkyTextEditorComponent {
1463
1463
  set disabled(value) {
1464
1464
  if (value !== this.disabled) {
1465
1465
  this.#_disabled = value;
1466
- // Update focusableChildren inside the iframe.
1467
- let focusableChildren;
1468
- /* istanbul ignore else */
1469
- if (this.iframeRef) {
1470
- focusableChildren = this.#coreAdapterService.getFocusableChildren(this.iframeRef.nativeElement.contentDocument.body, {
1471
- ignoreVisibility: true,
1472
- ignoreTabIndex: true,
1473
- });
1474
- if (this.#_disabled) {
1475
- this.#adapterService.disableEditor(focusableChildren, this.iframeRef.nativeElement);
1476
- }
1477
- else {
1478
- this.#adapterService.enableEditor(focusableChildren, this.iframeRef.nativeElement);
1479
- }
1480
- this.#changeDetector.markForCheck();
1481
- }
1466
+ this.#applyDisabledState();
1482
1467
  }
1483
1468
  }
1484
1469
  get disabled() {
@@ -1828,6 +1813,7 @@ class SkyTextEditorComponent {
1828
1813
  if (this.autofocus) {
1829
1814
  this.#adapterService.focusEditor();
1830
1815
  }
1816
+ this.#applyDisabledState();
1831
1817
  this.#initialized = true;
1832
1818
  this.#focusInitialized = false;
1833
1819
  this.#checkAutofocusAndFocus();
@@ -1846,6 +1832,24 @@ class SkyTextEditorComponent {
1846
1832
  this.#_onChange(this.#_value);
1847
1833
  }
1848
1834
  }
1835
+ #applyDisabledState() {
1836
+ // Update focusableChildren inside the iframe.
1837
+ let focusableChildren;
1838
+ /* istanbul ignore else */
1839
+ if (this.iframeRef?.nativeElement.contentDocument?.body) {
1840
+ focusableChildren = this.#coreAdapterService.getFocusableChildren(this.iframeRef.nativeElement.contentDocument.body, {
1841
+ ignoreVisibility: true,
1842
+ ignoreTabIndex: true,
1843
+ });
1844
+ if (this.#_disabled) {
1845
+ this.#adapterService.disableEditor(focusableChildren, this.iframeRef.nativeElement);
1846
+ }
1847
+ else {
1848
+ this.#adapterService.enableEditor(focusableChildren, this.iframeRef.nativeElement);
1849
+ }
1850
+ this.#changeDetector.markForCheck();
1851
+ }
1852
+ }
1849
1853
  /* istanbul ignore next */
1850
1854
  #_onTouched;
1851
1855
  /* istanbul ignore next */