113 lines
13 KiB
JavaScript
113 lines
13 KiB
JavaScript
import { Component, HostBinding, Input, Optional } from '@angular/core';
|
|
import { parse, text, } from '@fortawesome/fontawesome-svg-core';
|
|
import { faWarnIfParentNotExist } from '../shared/errors/warn-if-parent-not-exist';
|
|
import { faClassList } from '../shared/utils/classlist.util';
|
|
import * as i0 from "@angular/core";
|
|
import * as i1 from "./layers.component";
|
|
import * as i2 from "@angular/platform-browser";
|
|
export class FaLayersTextComponent {
|
|
/**
|
|
* @deprecated This input was incorrectly exposed and never worked correctly. To be removed in 0.14.0.
|
|
*/
|
|
set spin(value) {
|
|
this.animation = value ? 'spin' : undefined;
|
|
}
|
|
/**
|
|
* @deprecated This input was incorrectly exposed and never worked correctly. To be removed in 0.14.0.
|
|
*/
|
|
set pulse(value) {
|
|
this.animation = value ? 'spin-pulse' : undefined;
|
|
}
|
|
constructor(parent, sanitizer) {
|
|
this.parent = parent;
|
|
this.sanitizer = sanitizer;
|
|
/**
|
|
* Set `class` attribute on the SVG element rendered by the component.
|
|
*
|
|
* @deprecated This input breaks view encapsulation and is not recommended.
|
|
* For simple cases (like colors), use `class` on the component itself, for
|
|
* more complex usages, explicitly opt-in to break the view encapsulation.
|
|
* This input is deprecated since 0.12.0 and will be removed in 0.13.0.
|
|
*/
|
|
this.classes = [];
|
|
faWarnIfParentNotExist(this.parent, 'FaLayersComponent', this.constructor.name);
|
|
}
|
|
ngOnChanges(changes) {
|
|
if (changes) {
|
|
const params = this.buildParams();
|
|
this.updateContent(params);
|
|
}
|
|
}
|
|
/**
|
|
* Updating params by component props.
|
|
*/
|
|
buildParams() {
|
|
const classOpts = {
|
|
flip: this.flip,
|
|
animation: this.animation,
|
|
border: this.border,
|
|
inverse: this.inverse,
|
|
size: this.size || null,
|
|
pull: this.pull || null,
|
|
rotate: this.rotate || null,
|
|
fixedWidth: this.fixedWidth,
|
|
};
|
|
const parsedTransform = typeof this.transform === 'string' ? parse.transform(this.transform) : this.transform;
|
|
return {
|
|
transform: parsedTransform,
|
|
classes: [...faClassList(classOpts), ...this.classes],
|
|
title: this.title,
|
|
styles: this.styles,
|
|
};
|
|
}
|
|
updateContent(params) {
|
|
this.renderedHTML = this.sanitizer.bypassSecurityTrustHtml(text(this.content || '', params).html.join('\n'));
|
|
}
|
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: FaLayersTextComponent, deps: [{ token: i1.FaLayersComponent, optional: true }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.0", type: FaLayersTextComponent, isStandalone: true, selector: "fa-layers-text", inputs: { content: "content", title: "title", styles: "styles", classes: "classes", spin: "spin", pulse: "pulse", flip: "flip", size: "size", pull: "pull", border: "border", inverse: "inverse", rotate: "rotate", fixedWidth: "fixedWidth", transform: "transform" }, host: { properties: { "innerHTML": "this.renderedHTML" }, classAttribute: "ng-fa-layers-text" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true }); }
|
|
}
|
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.0", ngImport: i0, type: FaLayersTextComponent, decorators: [{
|
|
type: Component,
|
|
args: [{
|
|
selector: 'fa-layers-text',
|
|
standalone: true,
|
|
template: '',
|
|
host: {
|
|
class: 'ng-fa-layers-text',
|
|
},
|
|
}]
|
|
}], ctorParameters: () => [{ type: i1.FaLayersComponent, decorators: [{
|
|
type: Optional
|
|
}] }, { type: i2.DomSanitizer }], propDecorators: { content: [{
|
|
type: Input
|
|
}], title: [{
|
|
type: Input
|
|
}], styles: [{
|
|
type: Input
|
|
}], classes: [{
|
|
type: Input
|
|
}], spin: [{
|
|
type: Input
|
|
}], pulse: [{
|
|
type: Input
|
|
}], flip: [{
|
|
type: Input
|
|
}], size: [{
|
|
type: Input
|
|
}], pull: [{
|
|
type: Input
|
|
}], border: [{
|
|
type: Input
|
|
}], inverse: [{
|
|
type: Input
|
|
}], rotate: [{
|
|
type: Input
|
|
}], fixedWidth: [{
|
|
type: Input
|
|
}], transform: [{
|
|
type: Input
|
|
}], renderedHTML: [{
|
|
type: HostBinding,
|
|
args: ['innerHTML']
|
|
}] } });
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layers-text.component.js","sourceRoot":"","sources":["../../../../src/lib/layers/layers-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnChanges, Optional, SimpleChanges } from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport {\n  FlipProp,\n  parse,\n  PullProp,\n  RotateProp,\n  SizeProp,\n  Styles,\n  text,\n  TextParams,\n  Transform,\n} from '@fortawesome/fontawesome-svg-core';\nimport { faWarnIfParentNotExist } from '../shared/errors/warn-if-parent-not-exist';\nimport { AnimationProp, FaProps } from '../shared/models/props.model';\nimport { faClassList } from '../shared/utils/classlist.util';\nimport { FaLayersComponent } from './layers.component';\n\n@Component({\n  selector: 'fa-layers-text',\n  standalone: true,\n  template: '',\n  host: {\n    class: 'ng-fa-layers-text',\n  },\n})\nexport class FaLayersTextComponent implements OnChanges {\n  @Input() content: string;\n  @Input() title?: string;\n\n  /**\n   * Set `style` attribute on the SVG element rendered by the component.\n   *\n   * @deprecated This input breaks view encapsulation and is not recommended.\n   * For simple cases (like colors), use `style` on the component itself, for\n   * more complex usages, explicitly opt-in to break the view encapsulation.\n   * This input is deprecated since 0.12.0 and will be removed in 0.13.0.\n   */\n  @Input() styles?: Styles;\n\n  /**\n   * Set `class` attribute on the SVG element rendered by the component.\n   *\n   * @deprecated This input breaks view encapsulation and is not recommended.\n   * For simple cases (like colors), use `class` on the component itself, for\n   * more complex usages, explicitly opt-in to break the view encapsulation.\n   * This input is deprecated since 0.12.0 and will be removed in 0.13.0.\n   */\n  @Input() classes?: string[] = [];\n\n  /**\n   * @deprecated This input was incorrectly exposed and never worked correctly. To be removed in 0.14.0.\n   */\n  @Input() set spin(value: boolean) {\n    this.animation = value ? 'spin' : undefined;\n  }\n\n  /**\n   * @deprecated This input was incorrectly exposed and never worked correctly. To be removed in 0.14.0.\n   */\n  @Input() set pulse(value: boolean) {\n    this.animation = value ? 'spin-pulse' : undefined;\n  }\n\n  @Input() flip?: FlipProp;\n  @Input() size?: SizeProp;\n  @Input() pull?: PullProp;\n  @Input() border?: boolean;\n  @Input() inverse?: boolean;\n  @Input() rotate?: RotateProp;\n  @Input() fixedWidth?: boolean;\n  @Input() transform?: string | Transform;\n\n  @HostBinding('innerHTML') renderedHTML: SafeHtml;\n\n  private animation: AnimationProp;\n\n  constructor(\n    @Optional() private parent: FaLayersComponent,\n    private sanitizer: DomSanitizer,\n  ) {\n    faWarnIfParentNotExist(this.parent, 'FaLayersComponent', this.constructor.name);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes) {\n      const params = this.buildParams();\n      this.updateContent(params);\n    }\n  }\n\n  /**\n   * Updating params by component props.\n   */\n  protected buildParams(): TextParams {\n    const classOpts: FaProps = {\n      flip: this.flip,\n      animation: this.animation,\n      border: this.border,\n      inverse: this.inverse,\n      size: this.size || null,\n      pull: this.pull || null,\n      rotate: this.rotate || null,\n      fixedWidth: this.fixedWidth,\n    };\n\n    const parsedTransform = typeof this.transform === 'string' ? parse.transform(this.transform) : this.transform;\n\n    return {\n      transform: parsedTransform,\n      classes: [...faClassList(classOpts), ...this.classes],\n      title: this.title,\n      styles: this.styles,\n    };\n  }\n\n  private updateContent(params: TextParams) {\n    this.renderedHTML = this.sanitizer.bypassSecurityTrustHtml(text(this.content || '', params).html.join('\\n'));\n  }\n}\n"]}
|