@skyux/text-editor 10.22.0 → 10.24.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.
@@ -163,7 +163,12 @@ export class SkyTextEditorToolbarComponent {
163
163
  };
164
164
  }
165
165
  onColorpickerColorChanged(color, isBackground = false) {
166
- this.execCommand(isBackground ? 'backColor' : 'foreColor', color.hex);
166
+ if (isBackground) {
167
+ this.execCommand('backColor', color.rgbaText);
168
+ }
169
+ else {
170
+ this.execCommand('foreColor', color.hex);
171
+ }
167
172
  }
168
173
  #subscribeEditorFocus() {
169
174
  this.#editorFocusStreamSub?.unsubscribe();
@@ -226,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
226
231
  }], disabled: [{
227
232
  type: Input
228
233
  }] } });
229
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.ts","../../../../../../../../../libs/components/text-editor/src/lib/modules/text-editor/toolbar/text-editor-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n  inject,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport {\n  SkyColorpickerMessage,\n  SkyColorpickerMessageType,\n  SkyColorpickerModule,\n  SkyColorpickerOutput,\n} from '@skyux/colorpicker';\nimport { 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    this.execCommand(isBackground ? 'backColor' : 'foreColor', color.hex);\n  }\n\n  #subscribeEditorFocus(): void {\n    this.#editorFocusStreamSub?.unsubscribe();\n\n    this.#editorFocusStreamSub = this.editorFocusStream\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.styleState = {\n          ...this.styleState,\n          ...this.#adapterService.getStyleState(),\n        };\n        this.#closeDropdowns();\n        this.#changeDetector.detectChanges();\n      });\n  }\n\n  #closeDropdowns(): void {\n    const message: SkyColorpickerMessage = {\n      type: SkyColorpickerMessageType.Close,\n    };\n    this.colorpickerStream.next(message);\n    this.backColorpickerStream.next(message);\n    this.fontPickerStream.next({ type: SkyDropdownMessageType.Close });\n    this.fontSizeStream.next({ type: SkyDropdownMessageType.Close });\n  }\n\n  #getFontName(fontName: string): string | undefined {\n    for (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":"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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"]}
@@ -1395,7 +1395,12 @@ class SkyTextEditorToolbarComponent {
1395
1395
  };
1396
1396
  }
1397
1397
  onColorpickerColorChanged(color, isBackground = false) {
1398
- this.execCommand(isBackground ? 'backColor' : 'foreColor', color.hex);
1398
+ if (isBackground) {
1399
+ this.execCommand('backColor', color.rgbaText);
1400
+ }
1401
+ else {
1402
+ this.execCommand('foreColor', color.hex);
1403
+ }
1399
1404
  }
1400
1405
  #subscribeEditorFocus() {
1401
1406
  this.#editorFocusStreamSub?.unsubscribe();