carbon-components-angular
Version:
Next generation components
150 lines • 16.4 kB
JavaScript
import { Component, Input, HostBinding } from "@angular/core";
import { isObservable, of } from "rxjs";
import { BaseNotification } from "./base-notification.component";
import * as i0 from "@angular/core";
import * as i1 from "./notification-display.service";
import * as i2 from "carbon-components-angular/i18n";
import * as i3 from "@angular/common";
import * as i4 from "carbon-components-angular/icon";
import * as i5 from "./notification-title.directive";
import * as i6 from "./notification-subtitle.directive";
/**
* Notification messages are displayed toward the top of the UI and do not interrupt user’s work.
*
* [See demo](../../?path=/story/components-notification--basic)
*/
export class Notification extends BaseNotification {
constructor(notificationDisplayService, i18n) {
super(notificationDisplayService, i18n);
this.notificationDisplayService = notificationDisplayService;
this.i18n = i18n;
this.notificationID = `notification-${Notification.notificationCount++}`;
this.notificationLabel = this.notificationID;
this.notificationClass = true;
}
/**
* Can have `type`, `title`, and `message` members.
*
* `type` can be one of `"error"`, `"info"`, `"info-square"`, `"warning"`, `"warning-alt"`, or `"success"`
*
* `message` is the message to display
*/
get notificationObj() {
return this._notificationObj;
}
set notificationObj(obj) {
if (obj.closeLabel && !isObservable(obj.closeLabel)) {
obj.closeLabel = of(obj.closeLabel);
}
this._notificationObj = Object.assign({}, this.defaultNotificationObj, obj);
}
get isError() { return this.notificationObj.type === "error"; }
get isInfo() { return this.notificationObj.type === "info"; }
get isInfoSquare() { return this.notificationObj.type === "info-square"; }
get isSuccess() { return this.notificationObj.type === "success"; }
get isWarning() { return this.notificationObj.type === "warning"; }
get isWarningAlt() { return this.notificationObj.type === "warning-alt"; }
get isLowContrast() { return this.notificationObj.lowContrast; }
get isCloseHidden() { return !this.notificationObj.showClose; }
}
Notification.notificationCount = 0;
Notification.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Notification, deps: [{ token: i1.NotificationDisplayService }, { token: i2.I18n }], target: i0.ɵɵFactoryTarget.Component });
Notification.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: Notification, selector: "cds-notification, cds-inline-notification, ibm-notification, ibm-inline-notification", inputs: { notificationObj: "notificationObj" }, host: { properties: { "attr.aria-labelledBy": "this.notificationLabel", "class.cds--inline-notification": "this.notificationClass", "class.cds--inline-notification--error": "this.isError", "class.cds--inline-notification--info": "this.isInfo", "class.cds--inline-notification--info-square": "this.isInfoSquare", "class.cds--inline-notification--success": "this.isSuccess", "class.cds--inline-notification--warning": "this.isWarning", "class.cds--inline-notification--warning-alt": "this.isWarningAlt", "class.cds--inline-notification--low-contrast": "this.isLowContrast", "class.cds--inline-notification--hide-close-button": "this.isCloseHidden" } }, usesInheritance: true, ngImport: i0, template: `
<div class="cds--inline-notification__details">
<svg
[cdsIcon]="iconDictionary[notificationObj.type]"
size="20"
*ngIf="notificationObj.type"
class="cds--inline-notification__icon">
</svg>
<div class="cds--inline-notification__text-wrapper">
<div
cdsNotificationTitle
*ngIf="!notificationObj.template"
[innerHTML]="notificationObj.title"
[id]="notificationID">
</div>
<div *ngIf="!notificationObj.template" cdsNotificationSubtitle>
<span [innerHTML]="notificationObj.message"></span>
</div>
<ng-container *ngTemplateOutlet="notificationObj.template; context: { $implicit: notificationObj}"></ng-container>
</div>
</div>
<button
*ngIf="!isCloseHidden"
(click)="onClose()"
class="cds--inline-notification__close-button"
[attr.aria-label]="notificationObj.closeLabel | async"
type="button">
<svg cdsIcon="close" size="16" class="cds--inline-notification__close-icon"></svg>
</button>
`, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "directive", type: i5.NotificationTitle, selector: "[cdsNotificationTitle], [ibmNotificationTitle]" }, { kind: "directive", type: i6.NotificationSubtitle, selector: "[cdsNotificationSubtitle], [ibmNotificationSubtitle]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: Notification, decorators: [{
type: Component,
args: [{
selector: "cds-notification, cds-inline-notification, ibm-notification, ibm-inline-notification",
template: `
<div class="cds--inline-notification__details">
<svg
[cdsIcon]="iconDictionary[notificationObj.type]"
size="20"
*ngIf="notificationObj.type"
class="cds--inline-notification__icon">
</svg>
<div class="cds--inline-notification__text-wrapper">
<div
cdsNotificationTitle
*ngIf="!notificationObj.template"
[innerHTML]="notificationObj.title"
[id]="notificationID">
</div>
<div *ngIf="!notificationObj.template" cdsNotificationSubtitle>
<span [innerHTML]="notificationObj.message"></span>
</div>
<ng-container *ngTemplateOutlet="notificationObj.template; context: { $implicit: notificationObj}"></ng-container>
</div>
</div>
<button
*ngIf="!isCloseHidden"
(click)="onClose()"
class="cds--inline-notification__close-button"
[attr.aria-label]="notificationObj.closeLabel | async"
type="button">
<svg cdsIcon="close" size="16" class="cds--inline-notification__close-icon"></svg>
</button>
`
}]
}], ctorParameters: function () { return [{ type: i1.NotificationDisplayService }, { type: i2.I18n }]; }, propDecorators: { notificationObj: [{
type: Input
}], notificationLabel: [{
type: HostBinding,
args: ["attr.aria-labelledBy"]
}], notificationClass: [{
type: HostBinding,
args: ["class.cds--inline-notification"]
}], isError: [{
type: HostBinding,
args: ["class.cds--inline-notification--error"]
}], isInfo: [{
type: HostBinding,
args: ["class.cds--inline-notification--info"]
}], isInfoSquare: [{
type: HostBinding,
args: ["class.cds--inline-notification--info-square"]
}], isSuccess: [{
type: HostBinding,
args: ["class.cds--inline-notification--success"]
}], isWarning: [{
type: HostBinding,
args: ["class.cds--inline-notification--warning"]
}], isWarningAlt: [{
type: HostBinding,
args: ["class.cds--inline-notification--warning-alt"]
}], isLowContrast: [{
type: HostBinding,
args: ["class.cds--inline-notification--low-contrast"]
}], isCloseHidden: [{
type: HostBinding,
args: ["class.cds--inline-notification--hide-close-button"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.component.js","sourceRoot":"","sources":["../../../src/notification/notification.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tHostBinding\n} from \"@angular/core\";\n\nimport { NotificationContent } from \"./notification-content.interface\";\nimport { I18n } from \"carbon-components-angular/i18n\";\nimport { NotificationDisplayService } from \"./notification-display.service\";\nimport { isObservable, of } from \"rxjs\";\nimport { BaseNotification } from \"./base-notification.component\";\n\n/**\n * Notification messages are displayed toward the top of the UI and do not interrupt user’s work.\n *\n * [See demo](../../?path=/story/components-notification--basic)\n */\n@Component({\n\tselector: \"cds-notification, cds-inline-notification, ibm-notification, ibm-inline-notification\",\n\ttemplate: `\n\t\t<div class=\"cds--inline-notification__details\">\n\t\t\t<svg\n\t\t\t\t[cdsIcon]=\"iconDictionary[notificationObj.type]\"\n\t\t\t\tsize=\"20\"\n\t\t\t\t*ngIf=\"notificationObj.type\"\n\t\t\t\tclass=\"cds--inline-notification__icon\">\n\t\t\t</svg>\n\t\t\t<div class=\"cds--inline-notification__text-wrapper\">\n\t\t\t\t<div\n\t\t\t\t\tcdsNotificationTitle\n\t\t\t\t\t*ngIf=\"!notificationObj.template\"\n\t\t\t\t\t[innerHTML]=\"notificationObj.title\"\n\t\t\t\t\t[id]=\"notificationID\">\n\t\t\t\t</div>\n\t\t\t\t<div *ngIf=\"!notificationObj.template\" cdsNotificationSubtitle>\n\t\t\t\t\t<span [innerHTML]=\"notificationObj.message\"></span>\n\t\t\t\t</div>\n\t\t\t\t<ng-container *ngTemplateOutlet=\"notificationObj.template; context: { $implicit: notificationObj}\"></ng-container>\n\t\t\t</div>\n\t\t</div>\n\t\t<button\n\t\t\t*ngIf=\"!isCloseHidden\"\n\t\t\t(click)=\"onClose()\"\n\t\t\tclass=\"cds--inline-notification__close-button\"\n\t\t\t[attr.aria-label]=\"notificationObj.closeLabel | async\"\n\t\t\ttype=\"button\">\n\t\t\t<svg cdsIcon=\"close\" size=\"16\" class=\"cds--inline-notification__close-icon\"></svg>\n\t\t</button>\n\t`\n})\nexport class Notification extends BaseNotification {\n\tprivate static notificationCount = 0;\n\t/**\n\t * Can have `type`, `title`, and `message` members.\n\t *\n\t * `type` can be one of `\"error\"`, `\"info\"`, `\"info-square\"`, `\"warning\"`, `\"warning-alt\"`, or `\"success\"`\n\t *\n\t * `message` is the message to display\n\t */\n\t@Input() get notificationObj(): NotificationContent {\n\t\treturn this._notificationObj;\n\t}\n\tset notificationObj(obj: NotificationContent) {\n\t\tif (obj.closeLabel && !isObservable(obj.closeLabel)) {\n\t\t\tobj.closeLabel = of(obj.closeLabel);\n\t\t}\n\t\tthis._notificationObj = Object.assign({}, this.defaultNotificationObj, obj);\n\t}\n\n\tnotificationID = `notification-${Notification.notificationCount++}`;\n\t@HostBinding(\"attr.aria-labelledBy\") notificationLabel = this.notificationID;\n\t@HostBinding(\"class.cds--inline-notification\") notificationClass = true;\n\t@HostBinding(\"class.cds--inline-notification--error\") get isError() { return this.notificationObj.type === \"error\"; }\n\t@HostBinding(\"class.cds--inline-notification--info\") get isInfo() { return this.notificationObj.type === \"info\"; }\n\t@HostBinding(\"class.cds--inline-notification--info-square\") get isInfoSquare() { return this.notificationObj.type === \"info-square\"; }\n\t@HostBinding(\"class.cds--inline-notification--success\") get isSuccess() { return this.notificationObj.type === \"success\"; }\n\t@HostBinding(\"class.cds--inline-notification--warning\") get isWarning() { return this.notificationObj.type === \"warning\"; }\n\t@HostBinding(\"class.cds--inline-notification--warning-alt\") get isWarningAlt() { return this.notificationObj.type === \"warning-alt\"; }\n\t@HostBinding(\"class.cds--inline-notification--low-contrast\") get isLowContrast() { return this.notificationObj.lowContrast; }\n\t@HostBinding(\"class.cds--inline-notification--hide-close-button\") get isCloseHidden() { return !this.notificationObj.showClose; }\n\n\tconstructor(protected notificationDisplayService: NotificationDisplayService, protected i18n: I18n) {\n\t\tsuper(notificationDisplayService, i18n);\n\t}\n}\n"]}