@clr/angular
Version:
Angular components for Clarity
102 lines • 14.7 kB
JavaScript
/*
* Copyright (c) 2016-2025 Broadcom. All Rights Reserved.
* The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/
import { Component, ContentChildren, EventEmitter, Input, Output, } from '@angular/core';
import { ClrAlert } from './alert';
import { MultiAlertService } from './providers/multi-alert.service';
import * as i0 from "@angular/core";
import * as i1 from "./providers/multi-alert.service";
import * as i2 from "@angular/common";
import * as i3 from "./alerts-pager";
export class ClrAlerts {
constructor(multiAlertService) {
this.multiAlertService = multiAlertService;
this.currentAlertChange = new EventEmitter(false);
this.currentAlertIndexChange = new EventEmitter(false);
this.subscriptions = [];
}
set allAlerts(value) {
this.multiAlertService.manage(value); // provide alerts
}
/**
* Input/Output to support two way binding on current alert index
*/
set _inputCurrentIndex(index) {
if (Number.isInteger(index) && index >= 0) {
this.multiAlertService.current = index;
}
}
get currentAlertIndex() {
return this.multiAlertService.current;
}
set currentAlertIndex(index) {
this.multiAlertService.current = index;
}
/**
* Input/Output to support two way binding on current alert instance
*/
get currentAlert() {
return this.multiAlertService.currentAlert;
}
set currentAlert(alert) {
if (alert) {
this.multiAlertService.currentAlert = alert;
}
}
/**
* Ensure we are only dealing with alerts that have not been closed yet
*/
get alerts() {
return this.allAlerts.filter(alert => {
return alert.hidden === false;
});
}
get currentAlertType() {
if (this.multiAlertService.currentAlert) {
return this.multiAlertService.currentAlert.alertType;
}
return '';
}
ngAfterContentInit() {
this.subscriptions.push(this.multiAlertService.changes.subscribe(index => {
this.currentAlertIndexChange.next(index);
this.currentAlertChange.next(this.multiAlertService.currentAlert);
}));
}
ngOnDestroy() {
this.subscriptions.forEach(sub => sub.unsubscribe());
this.multiAlertService.destroy();
}
}
ClrAlerts.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrAlerts, deps: [{ token: i1.MultiAlertService }], target: i0.ɵɵFactoryTarget.Component });
ClrAlerts.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: ClrAlerts, selector: "clr-alerts", inputs: { _inputCurrentIndex: ["clrCurrentAlertIndex", "_inputCurrentIndex"], currentAlert: ["clrCurrentAlert", "currentAlert"] }, outputs: { currentAlertChange: "clrCurrentAlertChange", currentAlertIndexChange: "clrCurrentAlertIndexChange" }, host: { properties: { "class.alerts": "true", "class.alert-danger": "this.currentAlertType == 'danger'", "class.alert-info": "this.currentAlertType == 'info'", "class.alert-success": "this.currentAlertType == 'success'", "class.alert-warning": "this.currentAlertType == 'warning'", "class.alert-neutral": "this.currentAlertType == 'neutral'" } }, providers: [MultiAlertService], queries: [{ propertyName: "allAlerts", predicate: ClrAlert }], ngImport: i0, template: "<!--\n ~ Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n ~ The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n ~ This software is released under MIT license.\n ~ The full license information can be found in LICENSE in the root directory of this project.\n -->\n<div class=\"alerts-wrapper\">\n <clr-alerts-pager *ngIf=\"multiAlertService.count > 1\" [clrCurrentAlertIndex]=\"currentAlertIndex\"></clr-alerts-pager>\n <ng-content select=\"clr-alert\"></ng-content>\n</div>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ClrAlertsPager, selector: "clr-alerts-pager", inputs: ["clrCurrentAlert", "clrCurrentAlertIndex"], outputs: ["clrCurrentAlertChange", "clrCurrentAlertIndexChange"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrAlerts, decorators: [{
type: Component,
args: [{ selector: 'clr-alerts', providers: [MultiAlertService], host: {
'[class.alerts]': 'true',
'[class.alert-danger]': "this.currentAlertType == 'danger'",
'[class.alert-info]': "this.currentAlertType == 'info'",
'[class.alert-success]': "this.currentAlertType == 'success'",
'[class.alert-warning]': "this.currentAlertType == 'warning'",
'[class.alert-neutral]': "this.currentAlertType == 'neutral'",
}, template: "<!--\n ~ Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n ~ The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n ~ This software is released under MIT license.\n ~ The full license information can be found in LICENSE in the root directory of this project.\n -->\n<div class=\"alerts-wrapper\">\n <clr-alerts-pager *ngIf=\"multiAlertService.count > 1\" [clrCurrentAlertIndex]=\"currentAlertIndex\"></clr-alerts-pager>\n <ng-content select=\"clr-alert\"></ng-content>\n</div>\n", styles: [":host{display:block}\n"] }]
}], ctorParameters: function () { return [{ type: i1.MultiAlertService }]; }, propDecorators: { currentAlertChange: [{
type: Output,
args: ['clrCurrentAlertChange']
}], currentAlertIndexChange: [{
type: Output,
args: ['clrCurrentAlertIndexChange']
}], allAlerts: [{
type: ContentChildren,
args: [ClrAlert]
}], _inputCurrentIndex: [{
type: Input,
args: ['clrCurrentAlertIndex']
}], currentAlert: [{
type: Input,
args: ['clrCurrentAlert']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alerts.js","sourceRoot":"","sources":["../../../../../projects/angular/src/emphasis/alert/alerts.ts","../../../../../projects/angular/src/emphasis/alert/alerts.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { ClrAlert } from './alert';\nimport { MultiAlertService } from './providers/multi-alert.service';\n\n@Component({\n  selector: 'clr-alerts',\n  templateUrl: './alerts.html',\n  providers: [MultiAlertService],\n  host: {\n    '[class.alerts]': 'true',\n    '[class.alert-danger]': \"this.currentAlertType == 'danger'\",\n    '[class.alert-info]': \"this.currentAlertType == 'info'\",\n    '[class.alert-success]': \"this.currentAlertType == 'success'\",\n    '[class.alert-warning]': \"this.currentAlertType == 'warning'\",\n    '[class.alert-neutral]': \"this.currentAlertType == 'neutral'\",\n  },\n  styles: [':host { display: block }'],\n})\nexport class ClrAlerts implements AfterContentInit, OnDestroy {\n  @Output('clrCurrentAlertChange') currentAlertChange = new EventEmitter<ClrAlert>(false);\n  @Output('clrCurrentAlertIndexChange') currentAlertIndexChange = new EventEmitter<number>(false);\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(public multiAlertService: MultiAlertService) {}\n\n  @ContentChildren(ClrAlert)\n  set allAlerts(value: QueryList<ClrAlert>) {\n    this.multiAlertService.manage(value); // provide alerts\n  }\n\n  /**\n   * Input/Output to support two way binding on current alert index\n   */\n  @Input('clrCurrentAlertIndex')\n  set _inputCurrentIndex(index: number) {\n    if (Number.isInteger(index) && index >= 0) {\n      this.multiAlertService.current = index;\n    }\n  }\n\n  get currentAlertIndex() {\n    return this.multiAlertService.current;\n  }\n  set currentAlertIndex(index: number) {\n    this.multiAlertService.current = index;\n  }\n\n  /**\n   * Input/Output to support two way binding on current alert instance\n   */\n  @Input('clrCurrentAlert')\n  get currentAlert() {\n    return this.multiAlertService.currentAlert;\n  }\n  set currentAlert(alert: ClrAlert) {\n    if (alert) {\n      this.multiAlertService.currentAlert = alert;\n    }\n  }\n\n  /**\n   * Ensure we are only dealing with alerts that have not been closed yet\n   */\n  get alerts() {\n    return this.allAlerts.filter(alert => {\n      return alert.hidden === false;\n    });\n  }\n\n  get currentAlertType(): string {\n    if (this.multiAlertService.currentAlert) {\n      return this.multiAlertService.currentAlert.alertType;\n    }\n    return '';\n  }\n\n  ngAfterContentInit() {\n    this.subscriptions.push(\n      this.multiAlertService.changes.subscribe(index => {\n        this.currentAlertIndexChange.next(index);\n        this.currentAlertChange.next(this.multiAlertService.currentAlert);\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n    this.multiAlertService.destroy();\n  }\n}\n","<!--\n  ~ Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n  ~ The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n  ~ This software is released under MIT license.\n  ~ The full license information can be found in LICENSE in the root directory of this project.\n  -->\n<div class=\"alerts-wrapper\">\n  <clr-alerts-pager *ngIf=\"multiAlertService.count > 1\" [clrCurrentAlertIndex]=\"currentAlertIndex\"></clr-alerts-pager>\n  <ng-content select=\"clr-alert\"></ng-content>\n</div>\n"]}