@skyux/text-editor 10.28.0 → 10.30.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.
@@ -527,4 +527,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
527
527
  type: HostBinding,
528
528
  args: ['style.display']
529
529
  }] } });
530
- //# 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  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport {\n  SkyCoreAdapterService,\n  SkyFormsUtility,\n  SkyIdModule,\n  SkyIdService,\n} from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyFormFieldLabelTextRequiredService,\n  SkyInputBoxHostService,\n  SkyRequiredStateDirective,\n} from '@skyux/forms';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyToolbarModule } from '@skyux/layout';\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    SkyToolbarModule,\n    SkyFormErrorsModule,\n    SkyTextEditorResourcesModule,\n  ],\n})\nexport class SkyTextEditorComponent\n  implements AfterViewInit, OnInit, 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 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.\n   * @preview\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   * @preview\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   * @preview\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   * @preview\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   * @preview\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-margin-stacked-lg')\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, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline) button is\n   * placed beside the text editor label. Clicking the button invokes global help as configured by the application.\n   * @preview\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  @HostBinding('style.display')\n  public display: string | undefined;\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  readonly #labelTextRequired = inject(SkyFormFieldLabelTextRequiredService, {\n    optional: true,\n  });\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 ngOnInit(): void {\n    if (this.#labelTextRequired && !this.labelText) {\n      this.display = 'none';\n    }\n    this.#labelTextRequired?.validateLabelText(this.labelText);\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    // 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\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    'sky-margin-stacked-xs': !!hintText\n  }\"\n>\n  <div class=\"sky-text-editor-label-wrapper\">\n    <ng-container *ngIf=\"labelText\">\n      <label\n        class=\"sky-control-label\"\n        [ngClass]=\"{\n          'sky-control-label-required': requiredState.isRequired(),\n          'sky-margin-inline-xs': helpPopoverContent\n        }\"\n        >{{ labelText }}</label\n      >\n      <sky-help-inline\n        *ngIf=\"helpPopoverContent || helpKey\"\n        [helpKey]=\"helpKey\"\n        [labelText]=\"labelText\"\n        [popoverContent]=\"helpPopoverContent\"\n        [popoverTitle]=\"helpPopoverTitle\"\n      />\n    </ng-container>\n  </div>\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    [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    #iframe\n    allow=\"clipboard-read *; clipboard-write *\"\n  >\n  </iframe>\n</div>\n<div\n  skyId\n  [ngClass]=\"{\n    'sky-font-deemphasized sky-text-editor-hint-text': !!hintText\n  }\"\n  #hintTextEl=\"skyId\"\n>\n  {{ hintText }}\n</div>\n<sky-form-errors\n  *ngIf=\"labelText && ngControl?.errors\"\n  [id]=\"errorId\"\n  [errors]=\"ngControl.errors\"\n  [labelText]=\"labelText\"\n  [showErrors]=\"ngControl.touched || ngControl.dirty\"\n>\n  <ng-content select=\"sky-form-error\" />\n</sky-form-errors>\n"]}
530
+ //# 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  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport {\n  SkyCoreAdapterService,\n  SkyFormsUtility,\n  SkyIdModule,\n  SkyIdService,\n} from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyFormFieldLabelTextRequiredService,\n  SkyInputBoxHostService,\n  SkyRequiredStateDirective,\n} from '@skyux/forms';\nimport { SkyHelpInlineModule } from '@skyux/help-inline';\nimport { SkyToolbarModule } from '@skyux/layout';\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    SkyToolbarModule,\n    SkyFormErrorsModule,\n    SkyTextEditorResourcesModule,\n  ],\n})\nexport class SkyTextEditorComponent\n  implements AfterViewInit, OnInit, 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 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.\n   * @preview\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   * @preview\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   * @preview\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   * @preview\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   * @preview\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-margin-stacked-lg')\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, 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.\n   * @preview\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  @HostBinding('style.display')\n  public display: string | undefined;\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  readonly #labelTextRequired = inject(SkyFormFieldLabelTextRequiredService, {\n    optional: true,\n  });\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 ngOnInit(): void {\n    if (this.#labelTextRequired && !this.labelText) {\n      this.display = 'none';\n    }\n    this.#labelTextRequired?.validateLabelText(this.labelText);\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    // 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\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    'sky-margin-stacked-xs': !!hintText\n  }\"\n>\n  <div class=\"sky-text-editor-label-wrapper\">\n    <ng-container *ngIf=\"labelText\">\n      <label\n        class=\"sky-control-label\"\n        [ngClass]=\"{\n          'sky-control-label-required': requiredState.isRequired(),\n          'sky-margin-inline-xs': helpPopoverContent\n        }\"\n        >{{ labelText }}</label\n      >\n      <sky-help-inline\n        *ngIf=\"helpPopoverContent || helpKey\"\n        [helpKey]=\"helpKey\"\n        [labelText]=\"labelText\"\n        [popoverContent]=\"helpPopoverContent\"\n        [popoverTitle]=\"helpPopoverTitle\"\n      />\n    </ng-container>\n  </div>\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    [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    #iframe\n    allow=\"clipboard-read *; clipboard-write *\"\n  >\n  </iframe>\n</div>\n<div\n  skyId\n  [ngClass]=\"{\n    'sky-font-deemphasized sky-text-editor-hint-text': !!hintText\n  }\"\n  #hintTextEl=\"skyId\"\n>\n  {{ hintText }}\n</div>\n<sky-form-errors\n  *ngIf=\"labelText && ngControl?.errors\"\n  [id]=\"errorId\"\n  [errors]=\"ngControl.errors\"\n  [labelText]=\"labelText\"\n  [showErrors]=\"ngControl.touched || ngControl.dirty\"\n>\n  <ng-content select=\"sky-form-error\" />\n</sky-form-errors>\n"]}
@@ -202,7 +202,7 @@ export class SkyTextEditorToolbarComponent {
202
202
  return undefined;
203
203
  }
204
204
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyTextEditorToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
205
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: SkyTextEditorToolbarComponent, isStandalone: true, selector: "sky-text-editor-toolbar", inputs: { editorFocusStream: "editorFocusStream", fontList: "fontList", fontSizeList: "fontSizeList", toolbarActions: "toolbarActions", linkWindowOptions: "linkWindowOptions", styleState: "styleState", disabled: "disabled" }, ngImport: i0, template: "<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", styles: [".sky-text-editor-toolbar-action .sky-toolbar-item{margin-right:15px}.sky-text-editor-toolbar-action .sky-text-editor-font-picker ::ng-deep .sky-dropdown-button-content-container{width:140px;height:20px;text-align:left}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group{display:flex}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{position:relative;top:3px;margin:0 10px 0 0}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child{margin-right:0}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn{margin-left:0;margin-right:0;border-radius:0;border-right:none}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:first-of-type{border-top-left-radius:3px;border-bottom-left-radius:3px}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border-top-right-radius:3px;border-bottom-right-radius:3px;border-right:1px solid #cdcfd2}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:first-of-type,:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}:host-context(.sky-theme-modern) .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}.sky-theme-modern .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}.sky-theme-modern .sky-switch-icon-group .sky-btn:first-of-type,.sky-theme-modern .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}.sky-theme-modern .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: SkyCheckboxModule }, { kind: "component", type: i3.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "helpPopoverContent", "helpPopoverTitle", "icon", "checkboxType", "checked", "indeterminate", "required", "labelText", "labelHidden", "hintText", "stacked", "helpKey"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "ngmodule", type: SkyColorpickerModule }, { kind: "component", type: i4.λ1, selector: "sky-colorpicker", inputs: ["pickerButtonIcon", "pickerButtonIconType", "label", "labelledBy", "labelText", "helpPopoverContent", "helpPopoverTitle", "messageStream", "showResetButton"], outputs: ["selectedColorChanged", "selectedColorApplied"] }, { kind: "directive", type: i4.λ2, selector: "[skyColorpickerInput]", inputs: ["skyColorpickerInput", "initialColor", "id", "returnFormat", "outputFormat", "presetColors", "alphaChannel", "allowTransparency"] }, { kind: "ngmodule", type: SkyDropdownModule }, { kind: "component", type: i5.λ2, selector: "sky-dropdown-button" }, { kind: "component", type: i5.λ3, selector: "sky-dropdown", inputs: ["buttonStyle", "buttonType", "disabled", "dismissOnBlur", "label", "horizontalAlignment", "messageStream", "title", "trigger"] }, { kind: "component", type: i5.λ1, selector: "sky-dropdown-item", inputs: ["ariaRole"] }, { kind: "component", type: i5.λ4, selector: "sky-dropdown-menu", inputs: ["ariaLabelledBy", "ariaRole", "useNativeFocus"], outputs: ["menuChanges"] }, { kind: "ngmodule", type: SkyIconModule }, { kind: "component", type: i6.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "ngmodule", type: SkyThemeModule }, { kind: "ngmodule", type: SkyToolbarModule }, { kind: "component", type: i7.λ39, selector: "sky-toolbar-item" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
205
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: SkyTextEditorToolbarComponent, isStandalone: true, selector: "sky-text-editor-toolbar", inputs: { editorFocusStream: "editorFocusStream", fontList: "fontList", fontSizeList: "fontSizeList", toolbarActions: "toolbarActions", linkWindowOptions: "linkWindowOptions", styleState: "styleState", disabled: "disabled" }, ngImport: i0, template: "<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", styles: [".sky-text-editor-toolbar-action .sky-toolbar-item{margin-right:15px}.sky-text-editor-toolbar-action .sky-text-editor-font-picker ::ng-deep .sky-dropdown-button-content-container{width:140px;height:20px;text-align:left}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group{display:flex}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{position:relative;top:3px;margin:0 10px 0 0}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child{margin-right:0}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn{margin-left:0;margin-right:0;border-radius:0;border-right:none}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:first-of-type{border-top-left-radius:3px;border-bottom-left-radius:3px}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border-top-right-radius:3px;border-bottom-right-radius:3px;border-right:1px solid #cdcfd2}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:first-of-type,:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}:host-context(.sky-theme-modern) .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}.sky-theme-modern .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}.sky-theme-modern .sky-switch-icon-group .sky-btn:first-of-type,.sky-theme-modern .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}.sky-theme-modern .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: SkyCheckboxModule }, { kind: "component", type: i3.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "helpPopoverContent", "helpPopoverTitle", "icon", "checkboxType", "checked", "indeterminate", "required", "labelText", "labelHidden", "hintText", "stacked", "helpKey"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "ngmodule", type: SkyColorpickerModule }, { kind: "component", type: i4.λ1, selector: "sky-colorpicker", inputs: ["pickerButtonIcon", "pickerButtonIconType", "label", "labelledBy", "labelText", "labelHidden", "helpKey", "helpPopoverContent", "helpPopoverTitle", "hintText", "stacked", "messageStream", "showResetButton"], outputs: ["selectedColorChanged", "selectedColorApplied"] }, { kind: "directive", type: i4.λ2, selector: "[skyColorpickerInput]", inputs: ["skyColorpickerInput", "initialColor", "id", "returnFormat", "outputFormat", "presetColors", "alphaChannel", "allowTransparency"] }, { kind: "ngmodule", type: SkyDropdownModule }, { kind: "component", type: i5.λ2, selector: "sky-dropdown-button" }, { kind: "component", type: i5.λ3, selector: "sky-dropdown", inputs: ["buttonStyle", "buttonType", "disabled", "dismissOnBlur", "label", "horizontalAlignment", "messageStream", "title", "trigger"] }, { kind: "component", type: i5.λ1, selector: "sky-dropdown-item", inputs: ["ariaRole"] }, { kind: "component", type: i5.λ4, selector: "sky-dropdown-menu", inputs: ["ariaLabelledBy", "ariaRole", "useNativeFocus"], outputs: ["menuChanges"] }, { kind: "ngmodule", type: SkyIconModule }, { kind: "component", type: i6.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "ngmodule", type: SkyThemeModule }, { kind: "ngmodule", type: SkyToolbarModule }, { kind: "component", type: i7.λ39, selector: "sky-toolbar-item" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
206
206
  }
207
207
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyTextEditorToolbarComponent, decorators: [{
208
208
  type: Component,
@@ -231,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
231
231
  }], disabled: [{
232
232
  type: Input
233
233
  }] } });
234
- //# 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 { SkyFormsUtility } from '@skyux/core';\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 { 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    if (isBackground) {\n      this.execCommand('backColor', color.rgbaText);\n    } else {\n      this.execCommand('foreColor', color.hex);\n    }\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 (const skyTextEditorFont of this.fontList) {\n      if (fontName.replace(/['\"]+/g, '') === skyTextEditorFont.name) {\n        return skyTextEditorFont.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"]}
234
+ //# 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,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,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,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;KA8IlD;IAhNC,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,CAAC;YAC3C,IAAI,KAAK,CAAC,IAAI,KAAK,qCAAqC,EAAE,CAAC;gBACzD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;YAChE,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC1D,CAAC;QACH,CAAC;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,CAAC;YACnC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAC/B,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QACtC,CAAC;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,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC5B,CAAC;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,CAAC;gBAC/C,IAAI,WAAW,EAAE,CAAC;oBAChB,MAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,EAAE,CAAC;oBAE3D,IAAI,MAAM,EAAE,CAAC;wBACX,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;oBAC7C,CAAC;gBACH,CAAC;gBAED,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;gBAC3B,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,IAAI,EAAE,CAAC;oBAC1C,iBAAiB;oBACjB,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAClD,CAAC;qBAAM,CAAC;oBACN,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;gBACJ,CAAC;YACH,CAAC;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,CAAC;YAC1E,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,EAAE,CAAC;YAC9D,IAAI,SAAS,EAAE,CAAC;gBACd,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;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,YAAY,EAAE,CAAC;YACjB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;QAChD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3C,CAAC;IACH,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,MAAM,iBAAiB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC9C,IAAI,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,KAAK,iBAAiB,CAAC,IAAI,EAAE,CAAC;gBAC9D,OAAO,iBAAiB,CAAC,IAAI,CAAC;YAChC,CAAC;QACH,CAAC;QAED,0BAA0B;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;8GAhNU,6BAA6B;kGAA7B,6BAA6B,qTC7D1C,ikSAoRA,g1EDjOI,YAAY,0gBACZ,WAAW,8mBACX,iBAAiB,0ZACjB,oBAAoB,skBACpB,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 { SkyFormsUtility } from '@skyux/core';\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 { 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    if (isBackground) {\n      this.execCommand('backColor', color.rgbaText);\n    } else {\n      this.execCommand('foreColor', color.hex);\n    }\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 (const skyTextEditorFont of this.fontList) {\n      if (fontName.replace(/['\"]+/g, '') === skyTextEditorFont.name) {\n        return skyTextEditorFont.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"]}
@@ -1434,7 +1434,7 @@ class SkyTextEditorToolbarComponent {
1434
1434
  return undefined;
1435
1435
  }
1436
1436
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyTextEditorToolbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1437
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: SkyTextEditorToolbarComponent, isStandalone: true, selector: "sky-text-editor-toolbar", inputs: { editorFocusStream: "editorFocusStream", fontList: "fontList", fontSizeList: "fontSizeList", toolbarActions: "toolbarActions", linkWindowOptions: "linkWindowOptions", styleState: "styleState", disabled: "disabled" }, ngImport: i0, template: "<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", styles: [".sky-text-editor-toolbar-action .sky-toolbar-item{margin-right:15px}.sky-text-editor-toolbar-action .sky-text-editor-font-picker ::ng-deep .sky-dropdown-button-content-container{width:140px;height:20px;text-align:left}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group{display:flex}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{position:relative;top:3px;margin:0 10px 0 0}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child{margin-right:0}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn{margin-left:0;margin-right:0;border-radius:0;border-right:none}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:first-of-type{border-top-left-radius:3px;border-bottom-left-radius:3px}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border-top-right-radius:3px;border-bottom-right-radius:3px;border-right:1px solid #cdcfd2}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:first-of-type,:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}:host-context(.sky-theme-modern) .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}.sky-theme-modern .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}.sky-theme-modern .sky-switch-icon-group .sky-btn:first-of-type,.sky-theme-modern .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}.sky-theme-modern .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: SkyCheckboxModule }, { kind: "component", type: i1$3.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "helpPopoverContent", "helpPopoverTitle", "icon", "checkboxType", "checked", "indeterminate", "required", "labelText", "labelHidden", "hintText", "stacked", "helpKey"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "ngmodule", type: SkyColorpickerModule }, { kind: "component", type: i4$1.λ1, selector: "sky-colorpicker", inputs: ["pickerButtonIcon", "pickerButtonIconType", "label", "labelledBy", "labelText", "helpPopoverContent", "helpPopoverTitle", "messageStream", "showResetButton"], outputs: ["selectedColorChanged", "selectedColorApplied"] }, { kind: "directive", type: i4$1.λ2, selector: "[skyColorpickerInput]", inputs: ["skyColorpickerInput", "initialColor", "id", "returnFormat", "outputFormat", "presetColors", "alphaChannel", "allowTransparency"] }, { kind: "ngmodule", type: SkyDropdownModule }, { kind: "component", type: i2.λ2, selector: "sky-dropdown-button" }, { kind: "component", type: i2.λ3, selector: "sky-dropdown", inputs: ["buttonStyle", "buttonType", "disabled", "dismissOnBlur", "label", "horizontalAlignment", "messageStream", "title", "trigger"] }, { kind: "component", type: i2.λ1, selector: "sky-dropdown-item", inputs: ["ariaRole"] }, { kind: "component", type: i2.λ4, selector: "sky-dropdown-menu", inputs: ["ariaLabelledBy", "ariaRole", "useNativeFocus"], outputs: ["menuChanges"] }, { kind: "ngmodule", type: SkyIconModule }, { kind: "component", type: i6$1.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "ngmodule", type: SkyThemeModule }, { kind: "ngmodule", type: SkyToolbarModule }, { kind: "component", type: i5.λ39, selector: "sky-toolbar-item" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1437
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: SkyTextEditorToolbarComponent, isStandalone: true, selector: "sky-text-editor-toolbar", inputs: { editorFocusStream: "editorFocusStream", fontList: "fontList", fontSizeList: "fontSizeList", toolbarActions: "toolbarActions", linkWindowOptions: "linkWindowOptions", styleState: "styleState", disabled: "disabled" }, ngImport: i0, template: "<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", styles: [".sky-text-editor-toolbar-action .sky-toolbar-item{margin-right:15px}.sky-text-editor-toolbar-action .sky-text-editor-font-picker ::ng-deep .sky-dropdown-button-content-container{width:140px;height:20px;text-align:left}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group{display:flex}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{position:relative;top:3px;margin:0 10px 0 0}.sky-text-editor-toolbar-action .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child{margin-right:0}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn{margin-left:0;margin-right:0;border-radius:0;border-right:none}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:first-of-type{border-top-left-radius:3px;border-bottom-left-radius:3px}.sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border-top-right-radius:3px;border-bottom-right-radius:3px;border-right:1px solid #cdcfd2}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}:host-context(.sky-theme-modern) .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:first-of-type,:host-context(.sky-theme-modern) .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}:host-context(.sky-theme-modern) .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container{top:-2px;margin:0}.sky-theme-modern .sky-text-editor-colorpicker-group .sky-text-editor-colorpicker-container:last-child ::ng-deep sky-colorpicker .sky-colorpicker-button{margin-right:0}.sky-theme-modern .sky-switch-icon-group .sky-btn{margin:inherit;border-radius:6px}.sky-theme-modern .sky-switch-icon-group .sky-btn:first-of-type,.sky-theme-modern .sky-switch-icon-group .sky-btn:last-of-type{border-radius:6px}.sky-theme-modern .sky-text-editor-toolbar-action .sky-switch-icon-group .sky-btn:last-of-type{border:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i1$1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1$1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: SkyCheckboxModule }, { kind: "component", type: i1$3.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "helpPopoverContent", "helpPopoverTitle", "icon", "checkboxType", "checked", "indeterminate", "required", "labelText", "labelHidden", "hintText", "stacked", "helpKey"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "ngmodule", type: SkyColorpickerModule }, { kind: "component", type: i4$1.λ1, selector: "sky-colorpicker", inputs: ["pickerButtonIcon", "pickerButtonIconType", "label", "labelledBy", "labelText", "labelHidden", "helpKey", "helpPopoverContent", "helpPopoverTitle", "hintText", "stacked", "messageStream", "showResetButton"], outputs: ["selectedColorChanged", "selectedColorApplied"] }, { kind: "directive", type: i4$1.λ2, selector: "[skyColorpickerInput]", inputs: ["skyColorpickerInput", "initialColor", "id", "returnFormat", "outputFormat", "presetColors", "alphaChannel", "allowTransparency"] }, { kind: "ngmodule", type: SkyDropdownModule }, { kind: "component", type: i2.λ2, selector: "sky-dropdown-button" }, { kind: "component", type: i2.λ3, selector: "sky-dropdown", inputs: ["buttonStyle", "buttonType", "disabled", "dismissOnBlur", "label", "horizontalAlignment", "messageStream", "title", "trigger"] }, { kind: "component", type: i2.λ1, selector: "sky-dropdown-item", inputs: ["ariaRole"] }, { kind: "component", type: i2.λ4, selector: "sky-dropdown-menu", inputs: ["ariaLabelledBy", "ariaRole", "useNativeFocus"], outputs: ["menuChanges"] }, { kind: "ngmodule", type: SkyIconModule }, { kind: "component", type: i6$1.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "ngmodule", type: SkyThemeModule }, { kind: "ngmodule", type: SkyToolbarModule }, { kind: "component", type: i5.λ39, selector: "sky-toolbar-item" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1438
1438
  }
1439
1439
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: SkyTextEditorToolbarComponent, decorators: [{
1440
1440
  type: Component,