UNPKG

progress-button

Version:
67 lines 13 kB
import { Injectable, InjectionToken } from '@angular/core'; import * as i0 from "@angular/core"; /** * Button Config used to initialize button options */ export class ProgressButtonConfig { constructor() { this.progress = { animation: 'fill', direction: 'horizontal', statusTime: 1500, }; this.design = { background: '#222222', color: '#FFFFFF', successBackground: '#00e175', errorBackground: '#ff2948', successIconColor: '#ffffff', errorIconColor: '#ffffff', progressBackground: '#000000', progressInnerBackground: 'rgba(255, 255, 255,0.5)', linesSize: 10, radius: 0 }; } } /** @nocollapse */ ProgressButtonConfig.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProgressButtonConfig_Factory() { return new ProgressButtonConfig(); }, token: ProgressButtonConfig, providedIn: "root" }); ProgressButtonConfig.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** * Merge an object with another * @param data Object to merge * @param source Original object */ export function mergeOptions(data, source) { if (data) { Object.keys(source).forEach((k) => { if ((data[k] !== null && typeof data[k] !== 'undefined' && data[k] !== '')) { source[k] = data[k]; } }); // Update lateral-lines animation direction to vertical if (typeof source !== 'undefined' && source.animation && source.animation === 'lateral-lines') { source.direction = 'vertical'; } } return source; } // Token that makes the raw options available to the following factory function. export let FOR_ROOT_CONFIG_TOKEN = new InjectionToken('forRoot() ProgressButtonService configuration.'); /** * Return an instance of ProgressButtonConfig * @param config The button config for the module * @return ProgressButtonConfig; */ export function progressButtonConfigFactory(config) { const options = new ProgressButtonConfig(); if (config) { options.progress = mergeOptions(config.progress, options.progress); options.design = mergeOptions(config.design, options.design); } return (options); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-button.types.js","sourceRoot":"","sources":["../../../../projects/progress-button/src/lib/progress-button.types.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,UAAU,EAAE,cAAc,EAAC,MAAM,eAAe,CAAC;;AAoIzD;;GAEG;AACH,MAAM,OAAO,oBAAoB;IANjC;QAOE,aAAQ,GAAuB;YAC7B,SAAS,EAAE,MAAM;YACjB,SAAS,EAAE,YAAY;YACvB,UAAU,EAAE,IAAI;SACjB,CAAC;QACF,WAAM,GAAyB;YAC7B,UAAU,EAAE,SAAS;YACrB,KAAK,EAAE,SAAS;YAChB,iBAAiB,EAAE,SAAS;YAC5B,eAAe,EAAE,SAAS;YAC1B,gBAAgB,EAAE,SAAS;YAC3B,cAAc,EAAE,SAAS;YACzB,kBAAkB,EAAE,SAAS;YAC7B,uBAAuB,EAAE,yBAAyB;YAClD,SAAS,EAAE,EAAE;YACb,MAAM,EAAE,CAAC;SACV,CAAC;KACH;;;;YAxBA,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;AAuDD;;;;GAIG;AACH,MAAM,UAAU,YAAY,CAAC,IAAS,EAAE,MAAW;IACjD,IAAI,IAAI,EAAE;QACR,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YAChC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE;gBAC1E,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;aACrB;QACH,CAAC,CAAC,CAAC;QACH,uDAAuD;QACvD,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,SAAS,KAAK,eAAe,EAAE;YAC7F,MAAM,CAAC,SAAS,GAAG,UAAU,CAAC;SAC/B;KACF;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,gFAAgF;AAChF,MAAM,CAAC,IAAI,qBAAqB,GAAG,IAAI,cAAc,CAA6B,gDAAgD,CAAC,CAAC;AAEpI;;;;GAIG;AACH,MAAM,UAAU,2BAA2B,CAAC,MAAmC;IAC7E,MAAM,OAAO,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC3C,IAAI,MAAM,EAAE;QACV,OAAO,CAAC,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;QACnE,OAAO,CAAC,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;KAC9D;IACD,OAAO,CAAC,OAAO,CAAC,CAAC;AACnB,CAAC","sourcesContent":["import {ProgressButtonService} from './progress-button.service';\r\nimport {Injectable, InjectionToken} from '@angular/core';\r\n\r\n/**\r\n * Type of buttons\r\n */\r\nexport type ProgressButtonType = 'button' | 'reset' | 'submit';\r\n/**\r\n * Types of animation directions\r\n */\r\nexport type ProgressButtonDirection = 'horizontal' | 'vertical';\r\n/**\r\n * Types of status\r\n */\r\nexport type ProgressButtonStatus = 'success' | 'error';\r\n/**\r\n * Types of animations\r\n */\r\nexport type ProgressButtonAnimation =\r\n  'fill'\r\n  | 'shrink'\r\n  | 'rotate-angle-bottom'\r\n  | 'rotate-angle-top'\r\n  | 'rotate-angle-left'\r\n  | 'rotate-angle-right'\r\n  | 'rotate-side-down'\r\n  | 'rotate-side-up'\r\n  | 'rotate-side-left'\r\n  | 'rotate-side-right'\r\n  | 'rotate-back'\r\n  | 'flip-open'\r\n  | 'slide-down'\r\n  | 'move-up'\r\n  | 'top-line'\r\n  | 'lateral-lines';\r\n\r\n/**\r\n * Generic form data for Button\r\n */\r\nexport interface ProgressButtonForm {\r\n  /**\r\n   * Specifies one or more forms the button belongs to\r\n   */\r\n  id?: string | null;\r\n  /**\r\n   * Specifies where to send the form-data when a form is submitted. Only for type=\"submit\"\r\n   */\r\n  action?: string | null;\r\n  /**\r\n   * Specifies that the form-data should not be validated on submission. Only for type=\"submit\"\r\n   */\r\n  noValidate?: boolean | null;\r\n  /**\r\n   * Specifies how form-data should be encoded before sending it to a server. Only for type=\"submit\"\r\n   */\r\n  enctype?: 'application/x-www-form-urlencoded' | 'multipart/form-data' | 'text/plain' | null;\r\n  /**\r\n   * Specifies how to send the form-data (which HTTP method to use). Only for type=\"submit\"\r\n   */\r\n  method?: 'get' | 'post' | null;\r\n  /**\r\n   * Specifies where to display the response after submitting the form. Only for type=\"submit\"\r\n   */\r\n  target?: '_blank' | '_self' | '_parent' | '_top' | null;\r\n}\r\n\r\n/**\r\n * Progress Button Design Options (Input)\r\n */\r\nexport interface ProgressButtonDesign {\r\n  /**\r\n   * The background of the button\r\n   */\r\n  background?: string;\r\n  /**\r\n   * The text color of the button\r\n   */\r\n  color?: string;\r\n  /**\r\n   * The background of the button when status is success\r\n   */\r\n  successBackground?: string;\r\n  /**\r\n   * The background of the button when status is error\r\n   */\r\n  errorBackground?: string;\r\n  /**\r\n   * The color of the icon when status is success\r\n   */\r\n  successIconColor?: string;\r\n  /**\r\n   * The color of the icon when status is error\r\n   */\r\n  errorIconColor?: string;\r\n  /**\r\n   * The background of the progress element\r\n   */\r\n  progressBackground?: string;\r\n  /**\r\n   * The background of the progress inner element\r\n   */\r\n  progressInnerBackground?: string;\r\n  /**\r\n   * The size in px of the progress lines. This value is used in the animation styles top-line and lateral-lines\r\n   */\r\n  linesSize?: number;\r\n  /**\r\n   * Sets rounded shape to button with given radius size\r\n   */\r\n  radius?: number;\r\n}\r\n\r\n/**\r\n * Progress Button Data (Input)\r\n */\r\nexport interface ProgressButtonData {\r\n  /**\r\n   * Defines the progress animation style\r\n   */\r\n  animation?: ProgressButtonAnimation;\r\n  /**\r\n   * Defines the progress animation direction\r\n   */\r\n  direction?: ProgressButtonDirection;\r\n  /**\r\n   * Time in ms that the status (success or error) will be displayed\r\n   */\r\n  statusTime?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\n/**\r\n * Button Config used to initialize button options\r\n */\r\nexport class ProgressButtonConfig {\r\n  progress: ProgressButtonData = {\r\n    animation: 'fill',\r\n    direction: 'horizontal',\r\n    statusTime: 1500,\r\n  };\r\n  design: ProgressButtonDesign = {\r\n    background: '#222222',\r\n    color: '#FFFFFF',\r\n    successBackground: '#00e175',\r\n    errorBackground: '#ff2948',\r\n    successIconColor: '#ffffff',\r\n    errorIconColor: '#ffffff',\r\n    progressBackground: '#000000',\r\n    progressInnerBackground: 'rgba(255, 255, 255,0.5)',\r\n    linesSize: 10,\r\n    radius: 0\r\n  };\r\n}\r\n\r\n/**\r\n * Progress Status Data\r\n */\r\nexport interface ProgressButtonDataStatus {\r\n  perspective?: '' | null;\r\n  isPerspective: boolean;\r\n  isBorderRadius: boolean;\r\n  isRotateAnimation: boolean;\r\n  isFlipAnimation: boolean;\r\n  isSlideDownAnimation: boolean;\r\n  isMoveUpAnimation: boolean;\r\n  isContentBackground: boolean;\r\n  isHorizontal: boolean;\r\n}\r\n\r\n/**\r\n * Styles of Button elements\r\n */\r\nexport interface ProgressButtonStyles {\r\n  progressInner: any;\r\n  button: any;\r\n  content: any;\r\n}\r\n\r\n/**\r\n * Optional Configuration Data passed to the forRoot() method\r\n */\r\nexport interface ProgressButtonModuleConfig {\r\n  progress?: ProgressButtonData;\r\n  design?: ProgressButtonDesign;\r\n}\r\n/**\r\n * Merge an object with another\r\n * @param data Object to merge\r\n * @param source Original object\r\n */\r\nexport function mergeOptions(data: any, source: any) {\r\n  if (data) {\r\n    Object.keys(source).forEach((k) => {\r\n      if ((data[k] !== null && typeof data[k] !== 'undefined' && data[k] !== '')) {\r\n        source[k] = data[k];\r\n      }\r\n    });\r\n    // Update lateral-lines animation direction to vertical\r\n    if (typeof source !== 'undefined' && source.animation && source.animation === 'lateral-lines') {\r\n      source.direction = 'vertical';\r\n    }\r\n  }\r\n  return source;\r\n}\r\n\r\n// Token that makes the raw options available to the following factory function.\r\nexport let FOR_ROOT_CONFIG_TOKEN = new InjectionToken<ProgressButtonModuleConfig>('forRoot() ProgressButtonService configuration.');\r\n\r\n/**\r\n * Return an instance of ProgressButtonConfig\r\n * @param config The button config for the module\r\n * @return ProgressButtonConfig;\r\n */\r\nexport function progressButtonConfigFactory(config?: ProgressButtonModuleConfig): ProgressButtonConfig {\r\n  const options = new ProgressButtonConfig();\r\n  if (config) {\r\n    options.progress = mergeOptions(config.progress, options.progress);\r\n    options.design = mergeOptions(config.design, options.design);\r\n  }\r\n  return (options);\r\n}\r\n"]}