design-angular-kit
Version:
Un toolkit Angular conforme alle linee guida di design per i servizi web della PA
136 lines • 15.4 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';
import { NgClass } from '@angular/common';
import { TranslateModule } from '@ngx-translate/core';
import { IT_ASSET_BASE_PATH } from '../../../interfaces/design-angular-kit-config';
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
export class ItChipComponent {
/**
* Indica la label
*/
set label(value) {
this._label = value;
}
get label() {
return this._label;
}
/**
* Indica se mostrate il pulante di chisura
*/
set showCloseButton(value) {
this._showCloseButton = value;
}
get showCloseButton() {
return this._showCloseButton;
}
/**
* Indica il size
*/
set size(value) {
this._size = value;
}
get size() {
return this._size;
}
/**
* Indica il colore della chip
*/
set color(value) {
this._color = value;
}
get color() {
return this._color;
}
/**
* Indica se la chip è disabilitata
*/
set disabled(value) {
this._disabled = value;
}
get disabled() {
return this._disabled;
}
/**
* Indica il nome dell'icona, se valorizzata viene mostrata
*/
set icon(value) {
this._icon = value;
}
get icon() {
return this._icon;
}
/**
* Indica l'url dell'avatar, se valorizzata viene mostrata
*/
set avatar(value) {
this._avatar = value;
}
get avatar() {
return this._avatar;
}
/**
* Indica il valore da aggiungere al parametro alt, di default ''
*/
set altAvatar(value) {
this._altAvatar = value;
}
get altAvatar() {
return this._altAvatar;
}
/**
* Return the icon href
*/
get iconHref() {
return `${this.assetBasePath}/dist/svg/sprites.svg#it-${this._icon}`;
}
/**
* Return the close icon href
*/
get iconCloseHref() {
return `${this.assetBasePath}/dist/svg/sprites.svg#it-${this.iconClose}`;
}
constructor() {
this._label = '';
this._showCloseButton = false;
this._size = '';
this._color = undefined;
this._disabled = false;
this._icon = undefined;
this._avatar = undefined;
this._altAvatar = '';
/**
* Evento emesso al click sul bottone di chiusura
*/
this.closeEvent = new EventEmitter();
this.iconClose = 'close';
this.assetBasePath = inject(IT_ASSET_BASE_PATH);
}
clickToClose() {
this.closeEvent.emit();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItChipComponent, isStandalone: true, selector: "it-chip", inputs: { label: "label", showCloseButton: "showCloseButton", size: "size", color: "color", disabled: "disabled", icon: "icon", avatar: "avatar", altAvatar: "altAvatar" }, outputs: { closeEvent: "closeEvent" }, ngImport: i0, template: "<div\n class=\"chip\"\n [ngClass]=\"[\n !showCloseButton ? 'chip-simple' : 'alert',\n size === 'lg' ? 'chip-lg' : '',\n color ? 'chip-' + color : '',\n disabled ? 'chip-disabled' : '',\n ]\">\n @if (icon) {\n <svg class=\"icon icon-xs\">\n <use [attr.href]=\"iconHref\" [attr.xlink:href]=\"iconHref\"></use>\n </svg>\n }\n @if (avatar) {\n <div class=\"avatar size-xs\"><img [src]=\"avatar\" [alt]=\"altAvatar\" /></div>\n }\n <span class=\"chip-label\">{{ label }}</span>\n @if (showCloseButton) {\n <button (click)=\"clickToClose()\" [disabled]=\"disabled\">\n <svg class=\"icon\">\n <use [attr.href]=\"iconCloseHref\" [attr.xlink:href]=\"iconCloseHref\"></use>\n </svg>\n <span class=\"visually-hidden\">{{ 'it.core.remove' | translate }} {{ label }}</span>\n </button>\n }\n</div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItChipComponent, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'it-chip', changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgClass, TranslateModule], template: "<div\n class=\"chip\"\n [ngClass]=\"[\n !showCloseButton ? 'chip-simple' : 'alert',\n size === 'lg' ? 'chip-lg' : '',\n color ? 'chip-' + color : '',\n disabled ? 'chip-disabled' : '',\n ]\">\n @if (icon) {\n <svg class=\"icon icon-xs\">\n <use [attr.href]=\"iconHref\" [attr.xlink:href]=\"iconHref\"></use>\n </svg>\n }\n @if (avatar) {\n <div class=\"avatar size-xs\"><img [src]=\"avatar\" [alt]=\"altAvatar\" /></div>\n }\n <span class=\"chip-label\">{{ label }}</span>\n @if (showCloseButton) {\n <button (click)=\"clickToClose()\" [disabled]=\"disabled\">\n <svg class=\"icon\">\n <use [attr.href]=\"iconCloseHref\" [attr.xlink:href]=\"iconCloseHref\"></use>\n </svg>\n <span class=\"visually-hidden\">{{ 'it.core.remove' | translate }} {{ label }}</span>\n </button>\n }\n</div>\n" }]
}], ctorParameters: () => [], propDecorators: { label: [{
type: Input
}], showCloseButton: [{
type: Input
}], size: [{
type: Input
}], color: [{
type: Input
}], disabled: [{
type: Input
}], icon: [{
type: Input
}], avatar: [{
type: Input
}], altAvatar: [{
type: Input
}], closeEvent: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/chip/chip.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/core/chip/chip.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';\nimport { IconName } from '../../../interfaces/icon';\nimport { ChipColor } from '../../../interfaces/core';\nimport { NgClass } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IT_ASSET_BASE_PATH } from '../../../interfaces/design-angular-kit-config';\n\n@Component({\n  standalone: true,\n  selector: 'it-chip',\n  templateUrl: './chip.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [NgClass, TranslateModule],\n})\nexport class ItChipComponent {\n  /**\n   * Indica la label\n   */\n  @Input() set label(value: string) {\n    this._label = value;\n  }\n\n  get label(): string {\n    return this._label;\n  }\n\n  private _label = '';\n\n  /**\n   * Indica se mostrate il pulante di chisura\n   */\n  @Input() set showCloseButton(value: boolean) {\n    this._showCloseButton = value;\n  }\n\n  get showCloseButton(): boolean {\n    return this._showCloseButton;\n  }\n\n  private _showCloseButton = false;\n\n  /**\n   * Indica il size\n   */\n  @Input() set size(value: '' | 'lg') {\n    this._size = value;\n  }\n\n  get size(): '' | 'lg' {\n    return this._size;\n  }\n\n  private _size: '' | 'lg' = '';\n\n  /**\n   * Indica il colore della chip\n   */\n  @Input() set color(value: ChipColor | undefined) {\n    this._color = value;\n  }\n\n  get color(): ChipColor | undefined {\n    return this._color;\n  }\n\n  private _color: ChipColor | undefined = undefined;\n\n  /**\n   * Indica se la chip è disabilitata\n   */\n  @Input() set disabled(value: boolean) {\n    this._disabled = value;\n  }\n\n  get disabled(): boolean {\n    return this._disabled;\n  }\n\n  private _disabled: boolean = false;\n\n  /**\n   * Indica il nome dell'icona, se valorizzata viene mostrata\n   */\n  @Input() set icon(value: IconName | undefined) {\n    this._icon = value;\n  }\n\n  get icon(): IconName | undefined {\n    return this._icon;\n  }\n\n  private _icon: IconName | undefined = undefined;\n\n  /**\n   * Indica l'url dell'avatar, se valorizzata viene mostrata\n   */\n  @Input() set avatar(value: string | undefined) {\n    this._avatar = value;\n  }\n\n  get avatar(): string | undefined {\n    return this._avatar;\n  }\n\n  private _avatar: string | undefined = undefined;\n\n  /**\n   * Indica il valore da aggiungere al parametro alt, di default ''\n   */\n  @Input() set altAvatar(value: string) {\n    this._altAvatar = value;\n  }\n\n  get altAvatar(): string {\n    return this._altAvatar;\n  }\n\n  private _altAvatar: string = '';\n\n  /**\n   * Evento emesso al click sul bottone di chiusura\n   */\n  @Output() closeEvent = new EventEmitter();\n\n  /**\n   * Return the icon href\n   */\n  protected get iconHref(): string {\n    return `${this.assetBasePath}/dist/svg/sprites.svg#it-${this._icon}`;\n  }\n\n  private iconClose: IconName = 'close';\n\n  /**\n   * Return the close icon href\n   */\n  protected get iconCloseHref(): string {\n    return `${this.assetBasePath}/dist/svg/sprites.svg#it-${this.iconClose}`;\n  }\n\n  /**\n   * The bootstrap-italia asset folder path\n   * @default ./bootstrap-italia\n   */\n  protected assetBasePath: string;\n\n  constructor() {\n    this.assetBasePath = inject(IT_ASSET_BASE_PATH);\n  }\n\n  clickToClose(): void {\n    this.closeEvent.emit();\n  }\n}\n","<div\n  class=\"chip\"\n  [ngClass]=\"[\n    !showCloseButton ? 'chip-simple' : 'alert',\n    size === 'lg' ? 'chip-lg' : '',\n    color ? 'chip-' + color : '',\n    disabled ? 'chip-disabled' : '',\n  ]\">\n  @if (icon) {\n    <svg class=\"icon icon-xs\">\n      <use [attr.href]=\"iconHref\" [attr.xlink:href]=\"iconHref\"></use>\n    </svg>\n  }\n  @if (avatar) {\n    <div class=\"avatar size-xs\"><img [src]=\"avatar\" [alt]=\"altAvatar\" /></div>\n  }\n  <span class=\"chip-label\">{{ label }}</span>\n  @if (showCloseButton) {\n    <button (click)=\"clickToClose()\" [disabled]=\"disabled\">\n      <svg class=\"icon\">\n        <use [attr.href]=\"iconCloseHref\" [attr.xlink:href]=\"iconCloseHref\"></use>\n      </svg>\n      <span class=\"visually-hidden\">{{ 'it.core.remove' | translate }} {{ label }}</span>\n    </button>\n  }\n</div>\n"]}