UNPKG

carbon-components-angular

Version:
212 lines 18 kB
import { Component, Inject, ViewChild, Optional } from "@angular/core"; import { BaseModal } from "./base-modal.class"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "carbon-components-angular/forms"; import * as i3 from "./modal.component"; import * as i4 from "./modal-header.component"; import * as i5 from "./modal-footer.component"; import * as i6 from "./modal-content.directive"; import * as i7 from "./modal-header-heading.directive"; import * as i8 from "./modal-header-label.directive"; /** * Component to create standard modals for presenting content or asking for user's input. * It can show as a passive modal showing only text or show as a transactional modal with * multiple buttons for different actions for the user to choose from. * * Using a modal in your application requires `cds-placeholder` which would generally be * placed near the end of your app component template (app.component.ts or app.component.html) as: * * ```html * <cds-placeholder></cds-placeholder> * ``` * * Example of opening the modal: * * ```typescript * \@Component({ * selector: "app-modal-demo", * template: ` * <button class="btn--primary" (click)="openModal()">Open modal</button> * <cds-placeholder></cds-placeholder>` * }) * export class ModalDemo { * openModal() { * this.modalService.show({ * modalType: "default", * label: "optional header text", * title: "Modal title", * text: "Modal text", * buttons: [{ * text: "Button text", * type: "primary", * click: clickFunction * }] * }); * } * } * ``` */ export class AlertModal extends BaseModal { /** * Creates an instance of `AlertModal`. */ constructor(type = "default", label, title, content, size, hasScrollingContent = null, buttons = [], onClose, showCloseButton = true) { super(); this.type = type; this.label = label; this.title = title; this.content = content; this.size = size; this.hasScrollingContent = hasScrollingContent; this.buttons = buttons; this.onClose = onClose; this.showCloseButton = showCloseButton; for (let i = 0; i < this.buttons.length; i++) { const button = this.buttons[i]; if (!button.id) { button.id = `alert-modal-button-${i}`; } if (!button.type) { button.type = "secondary"; } } } ngAfterViewInit() { if (!this.modalContent) { return false; } const element = this.modalContent.nativeElement; if (element.scrollHeight > element.clientHeight) { element.tabIndex = 0; } else { element.tabIndex = -1; } } buttonClicked(buttonIndex) { const button = this.buttons[buttonIndex]; if (button.click) { button.click(); } this.closeModal(); } dismissModal(trigger) { if (this.onClose && this.onClose(trigger) === false) { return; } this.closeModal(); } } AlertModal.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlertModal, deps: [{ token: "type", optional: true }, { token: "label", optional: true }, { token: "title", optional: true }, { token: "content", optional: true }, { token: "size", optional: true }, { token: "hasScrollingContent", optional: true }, { token: "buttons", optional: true }, { token: "close", optional: true }, { token: "showCloseButton", optional: true }], target: i0.ɵɵFactoryTarget.Component }); AlertModal.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AlertModal, selector: "cds-alert-modal, ibm-alert-modal", viewQueries: [{ propertyName: "modalContent", first: true, predicate: ["modalContent"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: ` <cds-modal [size]="size" [theme]="type" [ariaLabel]="title" [hasScrollingContent]="hasScrollingContent" [open]="open" (overlaySelected)="dismissModal('overlay')"> <cds-modal-header (closeSelect)="dismissModal('close')" [showCloseButton]="showCloseButton"> <p cdsModalHeaderLabel class="cds--type-delta">{{label}}</p> <p cdsModalHeaderHeading class="cds--type-beta">{{title}}</p> </cds-modal-header> <div cdsModalContent #modalContent> <p [innerHTML]="content"></p> </div> <cds-modal-footer *ngIf="buttons.length > 0"> <ng-container *ngFor="let button of buttons; let i = index"> <button [cdsButton]="button.type" (click)="buttonClicked(i)" [id]="button.id" [attr.modal-primary-focus]="(button.type.indexOf('primary') !== -1 ? '' : null)"> {{button.text}} </button> </ng-container> </cds-modal-footer> </cds-modal> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: i3.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i4.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i5.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i6.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i7.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i8.ModalHeaderLabel, selector: "[cdsModalHeaderLabel], [ibmModalHeaderLabel]" }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlertModal, decorators: [{ type: Component, args: [{ selector: "cds-alert-modal, ibm-alert-modal", template: ` <cds-modal [size]="size" [theme]="type" [ariaLabel]="title" [hasScrollingContent]="hasScrollingContent" [open]="open" (overlaySelected)="dismissModal('overlay')"> <cds-modal-header (closeSelect)="dismissModal('close')" [showCloseButton]="showCloseButton"> <p cdsModalHeaderLabel class="cds--type-delta">{{label}}</p> <p cdsModalHeaderHeading class="cds--type-beta">{{title}}</p> </cds-modal-header> <div cdsModalContent #modalContent> <p [innerHTML]="content"></p> </div> <cds-modal-footer *ngIf="buttons.length > 0"> <ng-container *ngFor="let button of buttons; let i = index"> <button [cdsButton]="button.type" (click)="buttonClicked(i)" [id]="button.id" [attr.modal-primary-focus]="(button.type.indexOf('primary') !== -1 ? '' : null)"> {{button.text}} </button> </ng-container> </cds-modal-footer> </cds-modal> ` }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["type"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["label"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["title"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["content"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["size"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["hasScrollingContent"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["buttons"] }] }, { type: Function, decorators: [{ type: Optional }, { type: Inject, args: ["close"] }] }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: ["showCloseButton"] }] }]; }, propDecorators: { modalContent: [{ type: ViewChild, args: ["modalContent", { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert-modal.component.js","sourceRoot":"","sources":["../../../src/modal/alert-modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInject,\n\tViewChild,\n\tAfterViewInit,\n\tOptional\n} from \"@angular/core\";\nimport { BaseModal } from \"./base-modal.class\";\n\n/**\n * Component to create standard modals for presenting content or asking for user's input.\n * It can show as a passive modal showing only text or show as a transactional modal with\n * multiple buttons for different actions for the user to choose from.\n *\n * Using a modal in your application requires `cds-placeholder` which would generally be\n * placed near the end of your app component template (app.component.ts or app.component.html) as:\n *\n * ```html\n * <cds-placeholder></cds-placeholder>\n * ```\n *\n * Example of opening the modal:\n *\n * ```typescript\n * \\@Component({\n *  selector: \"app-modal-demo\",\n *  template: `\n *   <button class=\"btn--primary\" (click)=\"openModal()\">Open modal</button>\n *   <cds-placeholder></cds-placeholder>`\n * })\n * export class ModalDemo {\n * \topenModal() {\n * \t\tthis.modalService.show({\n *\t\t\tmodalType: \"default\",\n *\t\t\tlabel: \"optional header text\",\n *\t\t\ttitle: \"Modal title\",\n *\t\t\ttext: \"Modal text\",\n *\t\t\tbuttons: [{\n *\t\t\t\ttext: \"Button text\",\n *\t\t\t\ttype: \"primary\",\n *\t\t\t\tclick: clickFunction\n *\t\t\t}]\n *\t\t});\n * \t}\n * }\n * ```\n */\n@Component({\n\tselector: \"cds-alert-modal, ibm-alert-modal\",\n\ttemplate: `\n\t\t<cds-modal\n\t\t\t[size]=\"size\"\n\t\t\t[theme]=\"type\"\n\t\t\t[ariaLabel]=\"title\"\n\t\t\t[hasScrollingContent]=\"hasScrollingContent\"\n\t\t\t[open]=\"open\"\n\t\t\t(overlaySelected)=\"dismissModal('overlay')\">\n\t\t\t<cds-modal-header (closeSelect)=\"dismissModal('close')\" [showCloseButton]=\"showCloseButton\">\n\t\t\t\t<p cdsModalHeaderLabel class=\"cds--type-delta\">{{label}}</p>\n\t\t\t\t<p cdsModalHeaderHeading class=\"cds--type-beta\">{{title}}</p>\n\t\t\t</cds-modal-header>\n\t\t\t<div cdsModalContent #modalContent>\n\t\t\t\t<p [innerHTML]=\"content\"></p>\n\t\t\t</div>\n\t\t\t<cds-modal-footer *ngIf=\"buttons.length > 0\">\n\t\t\t\t<ng-container *ngFor=\"let button of buttons; let i = index\">\n\t\t\t\t\t<button\n\t\t\t\t\t\t[cdsButton]=\"button.type\"\n\t\t\t\t\t\t(click)=\"buttonClicked(i)\"\n\t\t\t\t\t\t[id]=\"button.id\"\n\t\t\t\t\t\t[attr.modal-primary-focus]=\"(button.type.indexOf('primary') !== -1 ? '' : null)\">\n\t\t\t\t\t\t{{button.text}}\n\t\t\t\t\t</button>\n\t\t\t\t</ng-container>\n\t\t\t</cds-modal-footer>\n\t\t</cds-modal>\n\t`\n})\nexport class AlertModal extends BaseModal implements AfterViewInit {\n\t@ViewChild(\"modalContent\", { static: true }) modalContent: { nativeElement: any; };\n\t/**\n\t * Creates an instance of `AlertModal`.\n\t */\n\tconstructor(\n\t\t@Optional() @Inject(\"type\") public type = \"default\",\n\t\t@Optional() @Inject(\"label\") public label: string,\n\t\t@Optional() @Inject(\"title\") public title: string,\n\t\t@Optional() @Inject(\"content\") public content: string,\n\t\t@Optional() @Inject(\"size\") public size: string,\n\t\t@Optional() @Inject(\"hasScrollingContent\") public hasScrollingContent: boolean = null,\n\t\t@Optional() @Inject(\"buttons\") public buttons = [],\n\t\t@Optional() @Inject(\"close\") public onClose: Function,\n\t\t@Optional() @Inject(\"showCloseButton\") public showCloseButton = true\n\t) {\n\t\tsuper();\n\t\tfor (let i = 0; i < this.buttons.length; i++) {\n\t\t\tconst button = this.buttons[i];\n\t\t\tif (!button.id) {\n\t\t\t\tbutton.id = `alert-modal-button-${i}`;\n\t\t\t}\n\t\t\tif (!button.type) {\n\t\t\t\tbutton.type = \"secondary\";\n\t\t\t}\n\t\t}\n\t}\n\n\tngAfterViewInit() {\n\t\tif (!this.modalContent) { return false; }\n\t\tconst element = this.modalContent.nativeElement;\n\t\tif (element.scrollHeight > element.clientHeight) {\n\t\t\telement.tabIndex = 0;\n\t\t} else {\n\t\t\telement.tabIndex = -1;\n\t\t}\n\t}\n\n\tbuttonClicked(buttonIndex: string | number) {\n\t\tconst button = this.buttons[buttonIndex];\n\t\tif (button.click) {\n\t\t\tbutton.click();\n\t\t}\n\n\t\tthis.closeModal();\n\t}\n\n\tdismissModal(trigger: any) {\n\t\tif (this.onClose && this.onClose(trigger) === false) {\n\t\t\treturn;\n\t\t}\n\t\tthis.closeModal();\n\t}\n}\n"]}