design-angular-kit
Version:
Un toolkit Angular conforme alle linee guida di design per i servizi web della PA
194 lines • 27.1 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { ItAbstractComponent } from '../../../abstracts/abstract.component';
import { Modal } from 'bootstrap-italia';
import { TranslateModule } from '@ngx-translate/core';
import { inputToBoolean } from '../../../utils/coercion';
import * as i0 from "@angular/core";
import * as i1 from "@ngx-translate/core";
/**
* Modal windows
* @description To show featured content, notifications to users, or personalized content.
*/
export class ItModalComponent extends ItAbstractComponent {
constructor() {
super(...arguments);
/**
* Show/Hide close button on header
* @default true
*/
this.closeButton = true;
/**
* To have modals that appear with fades
* @default true
*/
this.fade = true;
/**
* Includes a modal-backdrop element. Alternatively, specify static for a backdrop which doesn’t close the modal when clicked.
* @default true
*/
this.backdrop = true;
/**
* Puts the focus on the modal when initialized.
* @default true
*/
this.focus = true;
/**
* Closes the modal when escape key is pressed.
* @default true
*/
this.keyboard = true;
/**
* This event fires immediately when the instance method show is called.
*/
this.showEvent = new EventEmitter();
/**
* This event fires when the modal has been made visible to the user (it will wait for CSS transitions to complete).
*/
this.shownEvent = new EventEmitter();
/**
* This event is raised immediately when the instance method hide has been called.
*/
this.hideEvent = new EventEmitter();
/**
* This event fires when the modal has finished hiding from the user (it will wait for CSS transitions to complete).
*/
this.hiddenEvent = new EventEmitter();
/**
* This event is fired when the modal is displayed, its background is static and a click outside the modal or a press
* of the esc key occurs and data-bs-keyboard is set to false.
*/
this.hidePreventedEvent = new EventEmitter();
}
ngAfterViewInit() {
super.ngAfterViewInit();
this._renderer.removeAttribute(this._elementRef.nativeElement, 'title');
if (this.modalElement) {
const element = this.modalElement.nativeElement;
this.modal = Modal.getOrCreateInstance(element, {
...this.options,
backdrop: this.backdrop === 'static' ? 'static' : this.backdrop,
focus: this.focus,
keyboard: this.keyboard,
});
element.addEventListener('show.bs.modal', event => this.showEvent.emit(event));
element.addEventListener('shown.bs.modal', event => this.shownEvent.emit(event));
element.addEventListener('hide.bs.modal', event => this.hideEvent.emit(event));
element.addEventListener('hidden.bs.modal', event => this.hiddenEvent.emit(event));
element.addEventListener('hidePrevented.bs.modal', event => this.hidePreventedEvent.emit(event));
}
}
get modalClass() {
let modalClass = 'modal';
if (this.fade) {
modalClass += ` fade`;
}
if (this.alertModal) {
modalClass += ` alert-modal`;
}
if (this.dialogLinkList) {
modalClass += ` it-dialog-link-list`;
}
if (this.popconfirm) {
modalClass += ` popconfirm-modal`;
}
if (this.scrollable) {
modalClass += ` it-dialog-scrollable`;
}
return modalClass;
}
get dialogClass() {
let dialogClass = 'modal-dialog';
if (this.alignment) {
dialogClass += ` modal-dialog-${this.alignment}`;
}
if (this.size) {
dialogClass += ` modal-${this.size}`;
}
return dialogClass;
}
/**
* Manually activate/deactivate a modal. Returns to the caller before the modal has actually been shown or hidden
*/
toggle() {
this.modal?.toggle();
}
/**
* Manually open a modal. Returns to the caller before the modal has actually been displayed
*/
show() {
this.modal?.show();
}
/**
* Manually hide a modal. Returns to the caller before the modal has actually been hidden
*/
hide() {
this.modal?.hide();
}
/**
* Manually reposition the modal if the height of the modal changes when it is opened (in case a scroll bar appears).
*/
handleUpdate() {
this.modal?.handleUpdate();
}
/**
* Destroys the modal of an element.
*/
dispose() {
this.modal?.dispose();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItModalComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItModalComponent, isStandalone: true, selector: "it-modal", inputs: { closeButton: ["closeButton", "closeButton", inputToBoolean], alertModal: ["alertModal", "alertModal", inputToBoolean], dialogLinkList: ["dialogLinkList", "dialogLinkList", inputToBoolean], popconfirm: ["popconfirm", "popconfirm", inputToBoolean], scrollable: ["scrollable", "scrollable", inputToBoolean], fade: ["fade", "fade", inputToBoolean], alignment: "alignment", size: "size", backdrop: "backdrop", focus: ["focus", "focus", inputToBoolean], keyboard: ["keyboard", "keyboard", inputToBoolean], footerShadow: ["footerShadow", "footerShadow", inputToBoolean], options: "options" }, outputs: { showEvent: "showEvent", shownEvent: "shownEvent", hideEvent: "hideEvent", hiddenEvent: "hiddenEvent", hidePreventedEvent: "hidePreventedEvent" }, viewQueries: [{ propertyName: "modalElement", first: true, predicate: ["modalElement"], descendants: true }], exportAs: ["itModal"], usesInheritance: true, ngImport: i0, template: "<div\n #modalElement\n [id]=\"id\"\n [class]=\"modalClass\"\n tabindex=\"-1\"\n role=\"dialog\"\n aria-hidden=\"true\"\n [attr.aria-labelledby]=\"id + '-title'\"\n [attr.aria-describedby]=\"id + '-description'\">\n <div [class]=\"dialogClass\">\n <div class=\"modal-content\" role=\"document\">\n <div class=\"modal-header\">\n <ng-content select=\"[beforeTitle]\"></ng-content>\n\n <h2 class=\"modal-title h5\" id=\"{{ id }}-title\">\n <ng-content select=\"[modalTitle]\"></ng-content>\n </h2>\n\n @if (closeButton) {\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" [attr.aria-label]=\"'it.core.close-modal' | translate\"></button>\n }\n </div>\n\n <div class=\"modal-body\">\n <div id=\"{{ id }}-description\">\n <ng-content select=\"[description]\"></ng-content>\n </div>\n <ng-content></ng-content>\n </div>\n\n <div class=\"modal-footer\" [class.modal-footer-shadow]=\"footerShadow\">\n <ng-content select=\"[footer]\"></ng-content>\n </div>\n </div>\n </div>\n</div>\n", styles: [".modal-footer:empty{display:none}\n"], dependencies: [{ 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: ItModalComponent, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'it-modal', exportAs: 'itModal', changeDetection: ChangeDetectionStrategy.OnPush, imports: [TranslateModule], template: "<div\n #modalElement\n [id]=\"id\"\n [class]=\"modalClass\"\n tabindex=\"-1\"\n role=\"dialog\"\n aria-hidden=\"true\"\n [attr.aria-labelledby]=\"id + '-title'\"\n [attr.aria-describedby]=\"id + '-description'\">\n <div [class]=\"dialogClass\">\n <div class=\"modal-content\" role=\"document\">\n <div class=\"modal-header\">\n <ng-content select=\"[beforeTitle]\"></ng-content>\n\n <h2 class=\"modal-title h5\" id=\"{{ id }}-title\">\n <ng-content select=\"[modalTitle]\"></ng-content>\n </h2>\n\n @if (closeButton) {\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" [attr.aria-label]=\"'it.core.close-modal' | translate\"></button>\n }\n </div>\n\n <div class=\"modal-body\">\n <div id=\"{{ id }}-description\">\n <ng-content select=\"[description]\"></ng-content>\n </div>\n <ng-content></ng-content>\n </div>\n\n <div class=\"modal-footer\" [class.modal-footer-shadow]=\"footerShadow\">\n <ng-content select=\"[footer]\"></ng-content>\n </div>\n </div>\n </div>\n</div>\n", styles: [".modal-footer:empty{display:none}\n"] }]
}], propDecorators: { closeButton: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], alertModal: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], dialogLinkList: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], popconfirm: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], scrollable: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], fade: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], alignment: [{
type: Input
}], size: [{
type: Input
}], backdrop: [{
type: Input
}], focus: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], keyboard: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], footerShadow: [{
type: Input,
args: [{ transform: inputToBoolean }]
}], options: [{
type: Input
}], showEvent: [{
type: Output
}], shownEvent: [{
type: Output
}], hideEvent: [{
type: Output
}], hiddenEvent: [{
type: Output
}], hidePreventedEvent: [{
type: Output
}], modalElement: [{
type: ViewChild,
args: ['modalElement', { static: false }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/modal/modal.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/core/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { ItAbstractComponent } from '../../../abstracts/abstract.component';\nimport { Modal } from 'bootstrap-italia';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { Modal as BSModal } from 'bootstrap';\nimport { inputToBoolean } from '../../../utils/coercion';\n\n/**\n * Modal windows\n * @description To show featured content, notifications to users, or personalized content.\n */\n@Component({\n  standalone: true,\n  selector: 'it-modal',\n  templateUrl: './modal.component.html',\n  styleUrls: ['./modal.component.scss'],\n  exportAs: 'itModal',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule],\n})\nexport class ItModalComponent extends ItAbstractComponent implements AfterViewInit {\n  /**\n   * Show/Hide close button on header\n   * @default true\n   */\n  @Input({ transform: inputToBoolean }) closeButton: boolean = true;\n\n  /**\n   * To correctly format the contents of the modal with icon\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) alertModal?: boolean;\n\n  /**\n   * To correctly format the contents of the modal with Link List\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) dialogLinkList?: boolean;\n\n  /**\n   * Modal type Popconfirm can be used for short confirmation messages.\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) popconfirm?: boolean;\n\n  /**\n   * You can choose to use a scroll inside the modal, keeping the header and footer of the modal always visible\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) scrollable?: boolean;\n\n  /**\n   * To have modals that appear with fades\n   * @default true\n   */\n  @Input({ transform: inputToBoolean }) fade?: boolean = true;\n\n  /**\n   * Modal alignment\n   * - <b>centered</b>: to vertically center the modal\n   * - <b>left</b>: to left-align the modal\n   * - <b>right</b>: to right-align the modal\n   * @default undefined\n   */\n  @Input() alignment: 'centered' | 'left' | 'right' | undefined;\n\n  /**\n   * The modal size\n   * @default undefined\n   */\n  @Input() size: 'sm' | 'lg' | 'xl' | undefined;\n\n  /**\n   * Includes a modal-backdrop element. Alternatively, specify static for a backdrop which doesn’t close the modal when clicked.\n   * @default true\n   */\n  @Input() backdrop: 'static' | boolean = true;\n\n  /**\n   * Puts the focus on the modal when initialized.\n   * @default true\n   */\n  @Input({ transform: inputToBoolean }) focus: boolean = true;\n\n  /**\n   * Closes the modal when escape key is pressed.\n   * @default true\n   */\n  @Input({ transform: inputToBoolean }) keyboard: boolean = true;\n\n  /**\n   * To better distinguish the footer element with a shadow\n   * @default false\n   */\n  @Input({ transform: inputToBoolean }) footerShadow?: boolean;\n\n  /**\n   * Modal options\n   */\n  @Input() options?: Partial<BSModal.Options>;\n\n  /**\n   * This event fires immediately when the instance method show is called.\n   */\n  @Output() public showEvent: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event fires when the modal has been made visible to the user (it will wait for CSS transitions to complete).\n   */\n  @Output() public shownEvent: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event is raised immediately when the instance method hide has been called.\n   */\n  @Output() public hideEvent: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event fires when the modal has finished hiding from the user (it will wait for CSS transitions to complete).\n   */\n  @Output() public hiddenEvent: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event is fired when the modal is displayed, its background is static and a click outside the modal or a press\n   * of the esc key occurs and data-bs-keyboard is set to false.\n   */\n  @Output() public hidePreventedEvent: EventEmitter<Event> = new EventEmitter();\n\n  private modal?: Modal;\n\n  @ViewChild('modalElement', { static: false }) private modalElement?: ElementRef<HTMLDivElement>;\n\n  override ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n    this._renderer.removeAttribute(this._elementRef.nativeElement, 'title');\n\n    if (this.modalElement) {\n      const element = this.modalElement.nativeElement;\n      this.modal = Modal.getOrCreateInstance(element, {\n        ...this.options,\n        backdrop: this.backdrop === 'static' ? 'static' : this.backdrop,\n        focus: this.focus,\n        keyboard: this.keyboard,\n      });\n\n      element.addEventListener('show.bs.modal', event => this.showEvent.emit(event));\n      element.addEventListener('shown.bs.modal', event => this.shownEvent.emit(event));\n      element.addEventListener('hide.bs.modal', event => this.hideEvent.emit(event));\n      element.addEventListener('hidden.bs.modal', event => this.hiddenEvent.emit(event));\n      element.addEventListener('hidePrevented.bs.modal', event => this.hidePreventedEvent.emit(event));\n    }\n  }\n\n  protected get modalClass(): string {\n    let modalClass = 'modal';\n    if (this.fade) {\n      modalClass += ` fade`;\n    }\n    if (this.alertModal) {\n      modalClass += ` alert-modal`;\n    }\n    if (this.dialogLinkList) {\n      modalClass += ` it-dialog-link-list`;\n    }\n    if (this.popconfirm) {\n      modalClass += ` popconfirm-modal`;\n    }\n    if (this.scrollable) {\n      modalClass += ` it-dialog-scrollable`;\n    }\n    return modalClass;\n  }\n\n  protected get dialogClass(): string {\n    let dialogClass = 'modal-dialog';\n    if (this.alignment) {\n      dialogClass += ` modal-dialog-${this.alignment}`;\n    }\n    if (this.size) {\n      dialogClass += ` modal-${this.size}`;\n    }\n    return dialogClass;\n  }\n\n  /**\n   * Manually activate/deactivate a modal. Returns to the caller before the modal has actually been shown or hidden\n   */\n  public toggle(): void {\n    this.modal?.toggle();\n  }\n\n  /**\n   * Manually open a modal. Returns to the caller before the modal has actually been displayed\n   */\n  public show(): void {\n    this.modal?.show();\n  }\n\n  /**\n   * Manually hide a modal. Returns to the caller before the modal has actually been hidden\n   */\n  public hide(): void {\n    this.modal?.hide();\n  }\n\n  /**\n   * Manually reposition the modal if the height of the modal changes when it is opened (in case a scroll bar appears).\n   */\n  public handleUpdate(): void {\n    this.modal?.handleUpdate();\n  }\n\n  /**\n   * Destroys the modal of an element.\n   */\n  public dispose(): void {\n    this.modal?.dispose();\n  }\n}\n","<div\n  #modalElement\n  [id]=\"id\"\n  [class]=\"modalClass\"\n  tabindex=\"-1\"\n  role=\"dialog\"\n  aria-hidden=\"true\"\n  [attr.aria-labelledby]=\"id + '-title'\"\n  [attr.aria-describedby]=\"id + '-description'\">\n  <div [class]=\"dialogClass\">\n    <div class=\"modal-content\" role=\"document\">\n      <div class=\"modal-header\">\n        <ng-content select=\"[beforeTitle]\"></ng-content>\n\n        <h2 class=\"modal-title h5\" id=\"{{ id }}-title\">\n          <ng-content select=\"[modalTitle]\"></ng-content>\n        </h2>\n\n        @if (closeButton) {\n          <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" [attr.aria-label]=\"'it.core.close-modal' | translate\"></button>\n        }\n      </div>\n\n      <div class=\"modal-body\">\n        <div id=\"{{ id }}-description\">\n          <ng-content select=\"[description]\"></ng-content>\n        </div>\n        <ng-content></ng-content>\n      </div>\n\n      <div class=\"modal-footer\" [class.modal-footer-shadow]=\"footerShadow\">\n        <ng-content select=\"[footer]\"></ng-content>\n      </div>\n    </div>\n  </div>\n</div>\n"]}