UNPKG

@hxui/angular

Version:

* * *

322 lines 19.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ import { InjectionToken } from '@angular/core'; import { Subject } from 'rxjs'; /** @enum {number} */ const ToastrPosition = { CENTER_CENTER: 0, TOP_CENTER: 1, BOTTOM_CENTER: 2, TOP_FULL_WIDTH: 3, BOTTOM_FULL_WIDTH: 4, TOP_LEFT: 5, TOP_RIGHT: 6, BOTTOM_LEFT: 7, BOTTOM_RIGHT: 8, }; export { ToastrPosition }; ToastrPosition[ToastrPosition.CENTER_CENTER] = 'CENTER_CENTER'; ToastrPosition[ToastrPosition.TOP_CENTER] = 'TOP_CENTER'; ToastrPosition[ToastrPosition.BOTTOM_CENTER] = 'BOTTOM_CENTER'; ToastrPosition[ToastrPosition.TOP_FULL_WIDTH] = 'TOP_FULL_WIDTH'; ToastrPosition[ToastrPosition.BOTTOM_FULL_WIDTH] = 'BOTTOM_FULL_WIDTH'; ToastrPosition[ToastrPosition.TOP_LEFT] = 'TOP_LEFT'; ToastrPosition[ToastrPosition.TOP_RIGHT] = 'TOP_RIGHT'; ToastrPosition[ToastrPosition.BOTTOM_LEFT] = 'BOTTOM_LEFT'; ToastrPosition[ToastrPosition.BOTTOM_RIGHT] = 'BOTTOM_RIGHT'; /** * Configuration for an individual toast. * @record */ export function IndividualConfig() { } if (false) { /** * disable both timeOut and extendedTimeOut * default: false * @type {?} */ IndividualConfig.prototype.disableTimeOut; /** * toast time to live in milliseconds * default: 5000 * @type {?} */ IndividualConfig.prototype.timeOut; /** * toast show close button * default: false * @type {?} */ IndividualConfig.prototype.closeButton; /** * time to close after a user hovers over toast * default: 1000 * @type {?} */ IndividualConfig.prototype.extendedTimeOut; /** * show toast progress bar * default: false * @type {?} */ IndividualConfig.prototype.progressBar; /** * changes toast progress bar animation * default: decreasing * @type {?} */ IndividualConfig.prototype.progressAnimation; /** * render html in toast message (possibly unsafe) * default: false * @type {?} */ IndividualConfig.prototype.enableHtml; /** * css class on toast component * default: toast * @type {?} */ IndividualConfig.prototype.toastClass; /** * Position of toastr container * default: ToastrPosition.TOP_RIGHT * @type {?} */ IndividualConfig.prototype.position; /** * css class on toast title * default: toast-title * @type {?} */ IndividualConfig.prototype.titleClass; /** * css class on toast message * default: toast-message * @type {?} */ IndividualConfig.prototype.messageClass; /** * animation easing on toast * default: ease-in * @type {?} */ IndividualConfig.prototype.easing; /** * animation ease time on toast * default: 300 * @type {?} */ IndividualConfig.prototype.easeTime; /** * clicking on toast dismisses it * default: true * @type {?} */ IndividualConfig.prototype.tapToDismiss; /** * Angular toast component to be shown * default: Toast * @type {?|undefined} */ IndividualConfig.prototype.toastComponent; /** * Helps show toast from a websocket or from event outside Angular * default: false * @type {?} */ IndividualConfig.prototype.onActivateTick; } /** * @record */ export function ToastrIconClasses() { } if (false) { /** @type {?} */ ToastrIconClasses.prototype.none; /** @type {?} */ ToastrIconClasses.prototype.error; /** @type {?} */ ToastrIconClasses.prototype.info; /** @type {?} */ ToastrIconClasses.prototype.success; /** @type {?} */ ToastrIconClasses.prototype.warning; } /** * Global Toast configuration * Includes all IndividualConfig * @record */ export function GlobalConfig() { } if (false) { /** * max toasts opened. Toasts will be queued * Zero is unlimited * default: 0 * @type {?} */ GlobalConfig.prototype.maxOpened; /** * dismiss current toast when max is reached * default: false * @type {?} */ GlobalConfig.prototype.autoDismiss; /** @type {?} */ GlobalConfig.prototype.iconClasses; /** * New toast placement * default: true * @type {?} */ GlobalConfig.prototype.newestOnTop; /** * block duplicate messages * default: false * @type {?} */ GlobalConfig.prototype.preventDuplicates; /** * Reset toast timeout when there's a duplicate (preventDuplicates needs to be set to true) * default: false * @type {?} */ GlobalConfig.prototype.resetTimeoutOnDuplicate; } /** * Everything a toast needs to launch */ export class ToastPackage { /** * @param {?} toastId * @param {?} config * @param {?} message * @param {?} title * @param {?} toastType * @param {?} toastRef */ constructor(toastId, config, message, title, toastType, toastRef) { this.toastId = toastId; this.config = config; this.message = message; this.title = title; this.toastType = toastType; this.toastRef = toastRef; this._onTap = new Subject(); this._onAction = new Subject(); this.toastRef.afterClosed().subscribe(() => { this._onAction.complete(); this._onTap.complete(); }); } /** * Fired on click * @return {?} */ triggerTap() { this._onTap.next(); if (this.config.tapToDismiss) { this._onTap.complete(); } } /** * @return {?} */ onTap() { return this._onTap.asObservable(); } /** * available for use in custom toast * @param {?=} action * @return {?} */ triggerAction(action) { this._onAction.next(action); } /** * @return {?} */ onAction() { return this._onAction.asObservable(); } } if (false) { /** @type {?} */ ToastPackage.prototype._onTap; /** @type {?} */ ToastPackage.prototype._onAction; /** @type {?} */ ToastPackage.prototype.toastId; /** @type {?} */ ToastPackage.prototype.config; /** @type {?} */ ToastPackage.prototype.message; /** @type {?} */ ToastPackage.prototype.title; /** @type {?} */ ToastPackage.prototype.toastType; /** @type {?} */ ToastPackage.prototype.toastRef; } /** * @deprecated use GlobalConfig * @record */ export function GlobalToastrConfig() { } /** * @deprecated use IndividualConfig * @record */ export function IndividualToastrConfig() { } /** * @deprecated use IndividualConfig * @record */ export function ToastrConfig() { } /** @type {?} */ export const DefaultNoComponentGlobalConfig = { maxOpened: 0, autoDismiss: false, newestOnTop: true, preventDuplicates: false, resetTimeoutOnDuplicate: false, iconClasses: { none: '', error: 'is-error', info: 'is-info', success: 'is-success', warning: 'is-warning', }, // Individual closeButton: false, disableTimeOut: false, timeOut: 5000, extendedTimeOut: 1000, enableHtml: false, progressBar: false, toastClass: 'hx-alert', position: ToastrPosition.TOP_RIGHT, titleClass: 'toast-title', messageClass: 'toast-message', easing: 'ease-in', easeTime: 300, tapToDismiss: true, onActivateTick: false, progressAnimation: 'decreasing', }; /** * @record */ export function ToastrToken() { } if (false) { /** @type {?} */ ToastrToken.prototype.default; /** @type {?} */ ToastrToken.prototype.config; } /** @type {?} */ export const TOAST_CONFIG = new InjectionToken('ToastrConfig'); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toastr-config.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/toastr/toastr-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\r\nimport { SafeHtml } from '@angular/platform-browser';\r\n\r\nimport { Observable, Subject } from 'rxjs';\r\n\r\nimport { ComponentType } from './portal/portal';\r\nimport { ToastrRef } from './toastr-injector';\r\n\r\nexport type ProgressAnimationType = 'increasing' | 'decreasing';\r\n\r\nexport enum ToastrPosition {\r\n  CENTER_CENTER,\r\n  TOP_CENTER,\r\n  BOTTOM_CENTER,\r\n  TOP_FULL_WIDTH,\r\n  BOTTOM_FULL_WIDTH,\r\n  TOP_LEFT,\r\n  TOP_RIGHT,\r\n  BOTTOM_LEFT,\r\n  BOTTOM_RIGHT\r\n}\r\n\r\n/**\r\n * Configuration for an individual toast.\r\n */\r\nexport interface IndividualConfig {\r\n  /**\r\n   * disable both timeOut and extendedTimeOut\r\n   * default: false\r\n   */\r\n  disableTimeOut: boolean;\r\n  /**\r\n   * toast time to live in milliseconds\r\n   * default: 5000\r\n   */\r\n  timeOut: number;\r\n  /**\r\n   * toast show close button\r\n   * default: false\r\n   */\r\n  closeButton: boolean;\r\n  /**\r\n   * time to close after a user hovers over toast\r\n   * default: 1000\r\n   */\r\n  extendedTimeOut: number;\r\n  /**\r\n   * show toast progress bar\r\n   * default: false\r\n   */\r\n  progressBar: boolean;\r\n\r\n  /**\r\n   * changes toast progress bar animation\r\n   * default: decreasing\r\n   */\r\n  progressAnimation: ProgressAnimationType;\r\n\r\n  /**\r\n   * render html in toast message (possibly unsafe)\r\n   * default: false\r\n   */\r\n  enableHtml: boolean;\r\n  /**\r\n   * css class on toast component\r\n   * default: toast\r\n   */\r\n  toastClass: string;\r\n  /**\r\n   * Position of toastr container\r\n   * default: ToastrPosition.TOP_RIGHT\r\n   */\r\n  position: ToastrPosition;\r\n  /**\r\n   * css class on toast title\r\n   * default: toast-title\r\n   */\r\n  titleClass: string;\r\n  /**\r\n   * css class on toast message\r\n   * default: toast-message\r\n   */\r\n  messageClass: string;\r\n  /**\r\n   * animation easing on toast\r\n   * default: ease-in\r\n   */\r\n  easing: string;\r\n  /**\r\n   * animation ease time on toast\r\n   * default: 300\r\n   */\r\n  easeTime: string | number;\r\n  /**\r\n   * clicking on toast dismisses it\r\n   * default: true\r\n   */\r\n  tapToDismiss: boolean;\r\n  /**\r\n   * Angular toast component to be shown\r\n   * default: Toast\r\n   */\r\n  toastComponent?: ComponentType<any>;\r\n  /**\r\n   * Helps show toast from a websocket or from event outside Angular\r\n   * default: false\r\n   */\r\n  onActivateTick: boolean;\r\n}\r\n\r\nexport interface ToastrIconClasses {\r\n  none: string;\r\n  error: string;\r\n  info: string;\r\n  success: string;\r\n  warning: string;\r\n}\r\n\r\n/**\r\n * Global Toast configuration\r\n * Includes all IndividualConfig\r\n */\r\nexport interface GlobalConfig extends IndividualConfig {\r\n  /**\r\n   * max toasts opened. Toasts will be queued\r\n   * Zero is unlimited\r\n   * default: 0\r\n   */\r\n  maxOpened: number;\r\n  /**\r\n   * dismiss current toast when max is reached\r\n   * default: false\r\n   */\r\n  autoDismiss: boolean;\r\n  iconClasses: Partial<ToastrIconClasses>;\r\n  /**\r\n   * New toast placement\r\n   * default: true\r\n   */\r\n  newestOnTop: boolean;\r\n  /**\r\n   * block duplicate messages\r\n   * default: false\r\n   */\r\n  preventDuplicates: boolean;\r\n\r\n  /**\r\n   * Reset toast timeout when there's a duplicate (preventDuplicates needs to be set to true)\r\n   * default: false\r\n   */\r\n  resetTimeoutOnDuplicate: boolean;\r\n}\r\n\r\n/**\r\n * Everything a toast needs to launch\r\n */\r\nexport class ToastPackage {\r\n  private _onTap = new Subject<any>();\r\n  private _onAction = new Subject<any>();\r\n\r\n  constructor(\r\n    public toastId: number,\r\n    public config: IndividualConfig,\r\n    public message: string | SafeHtml | null | undefined,\r\n    public title: string | undefined,\r\n    public toastType: string,\r\n    public toastRef: ToastrRef<any>,\r\n  ) {\r\n    this.toastRef.afterClosed().subscribe(() => {\r\n      this._onAction.complete();\r\n      this._onTap.complete();\r\n    });\r\n  }\r\n\r\n  /** Fired on click */\r\n  triggerTap() {\r\n    this._onTap.next();\r\n    if (this.config.tapToDismiss) {\r\n      this._onTap.complete();\r\n    }\r\n  }\r\n\r\n  onTap(): Observable<any> {\r\n    return this._onTap.asObservable();\r\n  }\r\n\r\n  /** available for use in custom toast */\r\n  triggerAction(action?: any) {\r\n    this._onAction.next(action);\r\n  }\r\n\r\n  onAction(): Observable<any> {\r\n    return this._onAction.asObservable();\r\n  }\r\n}\r\n\r\n/* tslint:disable:no-empty-interface */\r\n/** @deprecated use GlobalConfig */\r\nexport interface GlobalToastrConfig extends GlobalConfig {}\r\n/** @deprecated use IndividualConfig */\r\nexport interface IndividualToastrConfig extends IndividualConfig {}\r\n/** @deprecated use IndividualConfig */\r\nexport interface ToastrConfig extends IndividualConfig {}\r\n\r\nexport const DefaultNoComponentGlobalConfig: GlobalConfig = {\r\n  maxOpened: 0,\r\n  autoDismiss: false,\r\n  newestOnTop: true,\r\n  preventDuplicates: false,\r\n  resetTimeoutOnDuplicate: false,\r\n  iconClasses: {\r\n    none: '',\r\n    error: 'is-error',\r\n    info: 'is-info',\r\n    success: 'is-success',\r\n    warning: 'is-warning',\r\n  },\r\n\r\n  // Individual\r\n  closeButton: false,\r\n  disableTimeOut: false,\r\n  timeOut: 5000,\r\n  extendedTimeOut: 1000,\r\n  enableHtml: false,\r\n  progressBar: false,\r\n  toastClass: 'hx-alert',\r\n  position: ToastrPosition.TOP_RIGHT,\r\n  titleClass: 'toast-title',\r\n  messageClass: 'toast-message',\r\n  easing: 'ease-in',\r\n  easeTime: 300,\r\n  tapToDismiss: true,\r\n  onActivateTick: false,\r\n  progressAnimation: 'decreasing',\r\n};\r\n\r\nexport interface ToastrToken {\r\n  default: GlobalConfig;\r\n  config: Partial<GlobalConfig>;\r\n}\r\n\r\nexport const TOAST_CONFIG = new InjectionToken<ToastrToken>('ToastrConfig');\r\n"]}