| /** |
| * @fileoverview added by tsickle |
| * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc |
| */ |
| import { Component, Input, HostBinding, ChangeDetectionStrategy, ViewChild, ElementRef } from '@angular/core'; |
| /** @enum {string} */ |
| var TdNotificationCountPositionY = { |
| Top: 'top', |
| Bottom: 'bottom', |
| Center: 'center', |
| }; |
| export { TdNotificationCountPositionY }; |
| /** @enum {string} */ |
| var TdNotificationCountPositionX = { |
| Before: 'before', |
| After: 'after', |
| Center: 'center', |
| }; |
| export { TdNotificationCountPositionX }; |
| /** @type {?} */ |
| export var DEFAULT_NOTIFICATION_LIMIT = 99; |
| var TdNotificationCountComponent = /** @class */ (function () { |
| function TdNotificationCountComponent() { |
| this._notifications = 0; |
| this._limit = DEFAULT_NOTIFICATION_LIMIT; |
| /** |
| * color?: "primary" | "accent" | "warn" |
| * Sets the theme color of the notification tip. Defaults to "warn" |
| */ |
| this.color = 'warn'; |
| } |
| Object.defineProperty(TdNotificationCountComponent.prototype, "positionX", { |
| get: /** |
| * @return {?} |
| */ |
| function () { |
| return this._positionX; |
| }, |
| /** |
| * positionX?: TdNotificationCountPositionX or "before" | "after" | "center" |
| * Sets the X position of the notification tip. |
| * Defaults to "after" if it has content, else 'center'. |
| */ |
| set: /** |
| * positionX?: TdNotificationCountPositionX or "before" | "after" | "center" |
| * Sets the X position of the notification tip. |
| * Defaults to "after" if it has content, else 'center'. |
| * @param {?} positionX |
| * @return {?} |
| */ |
| function (positionX) { |
| this._positionX = positionX; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "positionY", { |
| get: /** |
| * @return {?} |
| */ |
| function () { |
| return this._positionY; |
| }, |
| /** |
| * positionY?: TdNotificationCountPositionY or "top" | "bottom" | "center" |
| * Sets the Y position of the notification tip. |
| * Defaults to "top" if it has content, else 'center'. |
| */ |
| set: /** |
| * positionY?: TdNotificationCountPositionY or "top" | "bottom" | "center" |
| * Sets the Y position of the notification tip. |
| * Defaults to "top" if it has content, else 'center'. |
| * @param {?} positionY |
| * @return {?} |
| */ |
| function (positionY) { |
| this._positionY = positionY; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "notifications", { |
| /** |
| * notifications?: number | boolean |
| * Number for the notification count. Shows component only if the input is a positive number or 'true' |
| */ |
| set: /** |
| * notifications?: number | boolean |
| * Number for the notification count. Shows component only if the input is a positive number or 'true' |
| * @param {?} notifications |
| * @return {?} |
| */ |
| function (notifications) { |
| this._notifications = notifications; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "limit", { |
| /** |
| * limit?: number |
| * Limit for notification count. If the number of notifications is greater than limit, then + will be added. Defaults to 99. |
| */ |
| set: /** |
| * limit?: number |
| * Limit for notification count. If the number of notifications is greater than limit, then + will be added. Defaults to 99. |
| * @param {?} limit |
| * @return {?} |
| */ |
| function (limit) { |
| this._limit = limit; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "hideHost", { |
| get: /** |
| * @return {?} |
| */ |
| function () { |
| return !this.show && !this._hasContent(); |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "noCount", { |
| /** |
| * Sets the component in its 'noCount' state if [notifications] is a boolean 'true'. |
| * Makes the notification tip show without a count. |
| */ |
| get: /** |
| * Sets the component in its 'noCount' state if [notifications] is a boolean 'true'. |
| * Makes the notification tip show without a count. |
| * @return {?} |
| */ |
| function () { |
| return this._notifications === true; |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "notificationsDisplay", { |
| /** |
| * Notification display string when a count is available. |
| * Anything over 99 gets set as 99+ |
| */ |
| get: /** |
| * Notification display string when a count is available. |
| * Anything over 99 gets set as 99+ |
| * @return {?} |
| */ |
| function () { |
| if (this._notifications > this._limit) { |
| return this._limit + "+"; |
| } |
| return this._notifications.toString(); |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| Object.defineProperty(TdNotificationCountComponent.prototype, "show", { |
| /** |
| * Shows notification tip only when [notifications] is true or a positive integer. |
| */ |
| get: /** |
| * Shows notification tip only when [notifications] is true or a positive integer. |
| * @return {?} |
| */ |
| function () { |
| return this._notifications === true || (!isNaN((/** @type {?} */ (this._notifications))) && this._notifications > 0); |
| }, |
| enumerable: true, |
| configurable: true |
| }); |
| /** |
| * Check if [positionX] and [positionY] have been set as inputs, else use defaults depending on component content. |
| */ |
| /** |
| * Check if [positionX] and [positionY] have been set as inputs, else use defaults depending on component content. |
| * @return {?} |
| */ |
| TdNotificationCountComponent.prototype.ngAfterContentInit = /** |
| * Check if [positionX] and [positionY] have been set as inputs, else use defaults depending on component content. |
| * @return {?} |
| */ |
| function () { |
| if (!this._positionX) { |
| this.positionX = this._hasContent() ? TdNotificationCountPositionX.After : TdNotificationCountPositionX.Center; |
| } |
| if (!this._positionY) { |
| this.positionY = this._hasContent() ? TdNotificationCountPositionY.Top : TdNotificationCountPositionY.Center; |
| } |
| }; |
| /** |
| * Method to check if element has any kind of content (elements or text) |
| */ |
| /** |
| * Method to check if element has any kind of content (elements or text) |
| * @return {?} |
| */ |
| TdNotificationCountComponent.prototype._hasContent = /** |
| * Method to check if element has any kind of content (elements or text) |
| * @return {?} |
| */ |
| function () { |
| if (this.content) { |
| /** @type {?} */ |
| var contentElement = this.content.nativeElement; |
| return contentElement && (contentElement.children.length > 0 || !!contentElement.textContent.trim()); |
| } |
| return false; |
| }; |
| TdNotificationCountComponent.decorators = [ |
| { type: Component, args: [{ |
| selector: 'td-notification-count', |
| template: "<div #content class=\"td-notification-content\">\n <ng-content></ng-content>\n</div>\n<div *ngIf=\"show\"\n class=\"td-notification-count mat-{{color}}\"\n [class.td-notification-top]=\"positionY === 'top'\"\n [class.td-notification-bottom]=\"positionY === 'bottom'\"\n [class.td-notification-before]=\"positionX === 'before'\"\n [class.td-notification-after]=\"positionX === 'after'\"\n [class.td-notification-center-y]=\"positionY === 'center'\"\n [class.td-notification-center-x]=\"positionX === 'center'\"\n [class.td-notification-no-count]=\"noCount\">\n {{noCount ? '' : notificationsDisplay}}\n</div>", |
| changeDetection: ChangeDetectionStrategy.OnPush, |
| styles: [":host{position:relative;display:block;text-align:center;min-width:40px;height:40px}:host.td-notification-hidden{min-width:0}.td-notification-count{line-height:21px;width:20px;height:20px;position:absolute;font-size:10px;font-weight:600;border-radius:50%;z-index:1}.td-notification-count.td-notification-center-x{margin-left:auto;margin-right:auto;left:0;right:0}.td-notification-count.td-notification-center-y{margin-top:auto;margin-bottom:auto;top:0;bottom:0}.td-notification-count.td-notification-top{top:0}.td-notification-count.td-notification-bottom{bottom:0}.td-notification-count.td-notification-before{left:0}.td-notification-count.td-notification-after{right:0}.td-notification-count.td-notification-no-count{width:8px;height:8px}.td-notification-count.td-notification-no-count.td-notification-top{top:8px}.td-notification-count.td-notification-no-count.td-notification-bottom{bottom:8px}.td-notification-count.td-notification-no-count.td-notification-before{left:8px}.td-notification-count.td-notification-no-count.td-notification-after{right:8px}::ng-deep [dir=rtl] .td-notification-count.td-notification-before{right:0;left:auto}::ng-deep [dir=rtl] .td-notification-count.td-notification-after{left:0;right:auto}::ng-deep [dir=rtl] .td-notification-count.td-notification-no-count.td-notification-before{right:8px;left:auto}::ng-deep [dir=rtl] .td-notification-count.td-notification-no-count.td-notification-after{left:8px;right:auto}.td-notification-content,.td-notification-content ::ng-deep>*{line-height:40px}"] |
| }] } |
| ]; |
| TdNotificationCountComponent.propDecorators = { |
| content: [{ type: ViewChild, args: ['content',] }], |
| color: [{ type: Input }], |
| positionX: [{ type: Input }], |
| positionY: [{ type: Input }], |
| notifications: [{ type: Input }], |
| limit: [{ type: Input }], |
| hideHost: [{ type: HostBinding, args: ['class.td-notification-hidden',] }] |
| }; |
| return TdNotificationCountComponent; |
| }()); |
| export { TdNotificationCountComponent }; |
| if (false) { |
| /** @type {?} */ |
| TdNotificationCountComponent.prototype._notifications; |
| /** @type {?} */ |
| TdNotificationCountComponent.prototype._positionY; |
| /** @type {?} */ |
| TdNotificationCountComponent.prototype._positionX; |
| /** @type {?} */ |
| TdNotificationCountComponent.prototype._limit; |
| /** |
| * Div content wrapper of `ng-content`. |
| * @type {?} |
| */ |
| TdNotificationCountComponent.prototype.content; |
| /** |
| * color?: "primary" | "accent" | "warn" |
| * Sets the theme color of the notification tip. Defaults to "warn" |
| * @type {?} |
| */ |
| TdNotificationCountComponent.prototype.color; |
| } |
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification-count.component.js","sourceRoot":"ng://@covalent/core/","sources":["notifications/notification-count.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, ChangeDetectionStrategy,\n         ViewChild, ElementRef, AfterContentInit } from '@angular/core';\n\nexport enum TdNotificationCountPositionY {\n  Top = 'top',\n  Bottom = 'bottom',\n  Center = 'center',\n}\n\nexport enum TdNotificationCountPositionX {\n  Before = 'before',\n  After = 'after',\n  Center = 'center',\n}\n\nexport const DEFAULT_NOTIFICATION_LIMIT: number = 99;\n\n@Component({\n  selector: 'td-notification-count',\n  styleUrls: ['./notification-count.component.scss' ],\n  templateUrl: './notification-count.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdNotificationCountComponent implements AfterContentInit {\n\n  private _notifications: number | boolean = 0;\n  private _positionY: TdNotificationCountPositionY;\n  private _positionX: TdNotificationCountPositionX;\n  private _limit: number = DEFAULT_NOTIFICATION_LIMIT;\n\n  /**\n   * Div content wrapper of `ng-content`.\n   */\n  @ViewChild('content') content: ElementRef;\n\n  /**\n   * color?: \"primary\" | \"accent\" | \"warn\"\n   * Sets the theme color of the notification tip. Defaults to \"warn\"\n   */\n  @Input() color: 'primary' | 'accent' | 'warn' = 'warn';\n\n  /**\n   * positionX?: TdNotificationCountPositionX or \"before\" | \"after\" | \"center\"\n   * Sets the X position of the notification tip.\n   * Defaults to \"after\" if it has content, else 'center'.\n   */\n  @Input()\n  set positionX(positionX: TdNotificationCountPositionX) {\n    this._positionX = positionX;\n  }\n  get positionX(): TdNotificationCountPositionX {\n    return this._positionX;\n  }\n\n  /**\n   * positionY?: TdNotificationCountPositionY or \"top\" | \"bottom\" | \"center\"\n   * Sets the Y position of the notification tip.\n   * Defaults to \"top\" if it has content, else 'center'.\n   */\n  @Input()\n  set positionY(positionY: TdNotificationCountPositionY) {\n    this._positionY = positionY;\n  }\n  get positionY(): TdNotificationCountPositionY {\n    return this._positionY;\n  }\n\n  /**\n   * notifications?: number | boolean\n   * Number for the notification count. Shows component only if the input is a positive number or 'true'\n   */\n  @Input()\n  set notifications(notifications: number | boolean) {\n    this._notifications = notifications;\n  }\n\n   /**\n    * limit?: number\n    * Limit for notification count. If the number of notifications is greater than limit, then + will be added. Defaults to 99.\n    */\n  @Input()\n  set limit(limit: number) {\n    this._limit = limit;\n  }\n\n  @HostBinding('class.td-notification-hidden')\n  get hideHost(): boolean {\n    return !this.show && !this._hasContent();\n  }\n\n  /**\n   * Sets the component in its 'noCount' state if [notifications] is a boolean 'true'.\n   * Makes the notification tip show without a count.\n   */\n  get noCount(): string | boolean {\n    return this._notifications === true;\n  }\n\n  /**\n   * Notification display string when a count is available.\n   * Anything over 99 gets set as 99+\n   */\n  get notificationsDisplay(): string {\n    if (this._notifications > this._limit) {\n      return `${this._limit}+`;\n    }\n    return this._notifications.toString();\n  }\n\n  /**\n   * Shows notification tip only when [notifications] is true or a positive integer.\n   */\n  get show(): boolean {\n    return this._notifications === true || (!isNaN(<any>this._notifications) && this._notifications > 0);\n  }\n\n  /**\n   * Check if [positionX] and [positionY] have been set as inputs, else use defaults depending on component content.\n   */\n  ngAfterContentInit(): void {\n    if (!this._positionX) {\n      this.positionX = this._hasContent() ? TdNotificationCountPositionX.After : TdNotificationCountPositionX.Center;\n    }\n    if (!this._positionY) {\n      this.positionY = this._hasContent() ? TdNotificationCountPositionY.Top : TdNotificationCountPositionY.Center;\n    }\n  }\n\n  /**\n   * Method to check if element has any kind of content (elements or text)\n   */\n  private _hasContent(): boolean {\n    if (this.content) {\n      let contentElement: HTMLElement = this.content.nativeElement;\n      return contentElement && (contentElement.children.length > 0 || !!contentElement.textContent.trim());\n    }\n    return false;\n  }\n\n}\n"]} |