@hxui/angular
Version:
* * *
322 lines • 19.6 kB
JavaScript
/**
* @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":";;;;AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAG/C,OAAO,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;;;IAQzC,gBAAa;IACb,aAAU;IACV,gBAAa;IACb,iBAAc;IACd,oBAAiB;IACjB,WAAQ;IACR,YAAS;IACT,cAAW;IACX,eAAY;;;;;;;;;;;;;;;;AAMd,sCAmFC;;;;;;;IA9EC,0CAAwB;;;;;;IAKxB,mCAAgB;;;;;;IAKhB,uCAAqB;;;;;;IAKrB,2CAAwB;;;;;;IAKxB,uCAAqB;;;;;;IAMrB,6CAAyC;;;;;;IAMzC,sCAAoB;;;;;;IAKpB,sCAAmB;;;;;;IAKnB,oCAAyB;;;;;;IAKzB,sCAAmB;;;;;;IAKnB,wCAAqB;;;;;;IAKrB,kCAAe;;;;;;IAKf,oCAA0B;;;;;;IAK1B,wCAAsB;;;;;;IAKtB,0CAAoC;;;;;;IAKpC,0CAAwB;;;;;AAG1B,uCAMC;;;IALC,iCAAa;;IACb,kCAAc;;IACd,iCAAa;;IACb,oCAAgB;;IAChB,oCAAgB;;;;;;;AAOlB,kCA6BC;;;;;;;;IAvBC,iCAAkB;;;;;;IAKlB,mCAAqB;;IACrB,mCAAwC;;;;;;IAKxC,mCAAqB;;;;;;IAKrB,yCAA2B;;;;;;IAM3B,+CAAiC;;;;;AAMnC,MAAM,OAAO,YAAY;;;;;;;;;IAIvB,YACS,OAAe,EACf,MAAwB,EACxB,OAA6C,EAC7C,KAAyB,EACzB,SAAiB,EACjB,QAAwB;QALxB,YAAO,GAAP,OAAO,CAAQ;QACf,WAAM,GAAN,MAAM,CAAkB;QACxB,YAAO,GAAP,OAAO,CAAsC;QAC7C,UAAK,GAAL,KAAK,CAAoB;QACzB,cAAS,GAAT,SAAS,CAAQ;QACjB,aAAQ,GAAR,QAAQ,CAAgB;QATzB,WAAM,GAAG,IAAI,OAAO,EAAO,CAAC;QAC5B,cAAS,GAAG,IAAI,OAAO,EAAO,CAAC;QAUrC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACzC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;;;;;IAGD,UAAU;QACR,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;YAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;SACxB;IACH,CAAC;;;;IAED,KAAK;QACH,OAAO,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IACpC,CAAC;;;;;;IAGD,aAAa,CAAC,MAAY;QACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;;;;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACvC,CAAC;CACF;;;IArCC,8BAAoC;;IACpC,iCAAuC;;IAGrC,+BAAsB;;IACtB,8BAA+B;;IAC/B,+BAAoD;;IACpD,6BAAgC;;IAChC,iCAAwB;;IACxB,gCAA+B;;;;;;AAgCnC,wCAA2D;;;;;AAE3D,4CAAmE;;;;;AAEnE,kCAAyD;;AAEzD,MAAM,OAAO,8BAA8B,GAAiB;IAC1D,SAAS,EAAE,CAAC;IACZ,WAAW,EAAE,KAAK;IAClB,WAAW,EAAE,IAAI;IACjB,iBAAiB,EAAE,KAAK;IACxB,uBAAuB,EAAE,KAAK;IAC9B,WAAW,EAAE;QACX,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,UAAU;QACjB,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,YAAY;QACrB,OAAO,EAAE,YAAY;KACtB;;IAGD,WAAW,EAAE,KAAK;IAClB,cAAc,EAAE,KAAK;IACrB,OAAO,EAAE,IAAI;IACb,eAAe,EAAE,IAAI;IACrB,UAAU,EAAE,KAAK;IACjB,WAAW,EAAE,KAAK;IAClB,UAAU,EAAE,UAAU;IACtB,QAAQ,EAAE,cAAc,CAAC,SAAS;IAClC,UAAU,EAAE,aAAa;IACzB,YAAY,EAAE,eAAe;IAC7B,MAAM,EAAE,SAAS;IACjB,QAAQ,EAAE,GAAG;IACb,YAAY,EAAE,IAAI;IAClB,cAAc,EAAE,KAAK;IACrB,iBAAiB,EAAE,YAAY;CAChC;;;;AAED,iCAGC;;;IAFC,8BAAsB;;IACtB,6BAA8B;;;AAGhC,MAAM,OAAO,YAAY,GAAG,IAAI,cAAc,CAAc,cAAc,CAAC","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"]}