UNPKG

progress-button

Version:
175 lines 22.7 kB
import { Injectable } from '@angular/core'; import { mergeOptions, ProgressButtonConfig } from './progress-button.types'; import * as i0 from "@angular/core"; import * as i1 from "./progress-button.types"; export class ProgressButtonService { constructor(config = new ProgressButtonConfig()) { /** * Check if animation is active * @param name ProgressButtonAnimation Animation name */ this.isAnimation = (name) => { return (this.progress.animation === name); }; /** * Return some progress styles * @param progressValue The progress value * @param statusClass The status (state-success | state-error) */ this.styles = (progressValue, statusClass) => { return { progressInner: this.progressInnerStyle(progressValue), button: this.buttonStyle(statusClass), content: this.contentStyle(statusClass) }; }; /** * Get the Progress Inner Style * @param progressValue The progress value */ this.progressInnerStyle = (progressValue) => { const style = { background: this.design.progressInnerBackground, borderColor: null, borderLeftWidth: null, borderRightWidth: null, height: null, width: null, }; // Reset LinesSize if ((this.design.linesSize === null) || (typeof this.design.linesSize === 'undefined')) { this.design.linesSize = 10; } // Lateral Lines if (this.isAnimation('lateral-lines')) { style.background = null; style.borderColor = this.design.progressInnerBackground; style.borderLeftWidth = this.design.linesSize + 'px'; style.borderRightWidth = this.design.linesSize + 'px'; } // Set Size style.height = this.progressInnerHeight(progressValue); style.width = this.progressInnerWidth(progressValue); return style; }; /** * Get Calculated Progress Inner Width */ this.progressInnerWidth = (progressValue) => { if (this.progress.direction === 'horizontal') { return progressValue + '%'; } else { if (this.isAnimation('shrink') && this.design.radius) { return progressValue + '%'; } } if (this.isAnimation('top-line')) { return this.design.linesSize + 'px'; } return null; }; /** * Get Calculated Progress Inner Height */ this.progressInnerHeight = (progressValue) => { if (this.progress.direction === 'vertical') { if (this.isAnimation('shrink') && this.design.radius) { return '100%'; } return progressValue + '%'; } if (this.isAnimation('top-line')) { return this.design.linesSize + 'px'; } return null; }; /** * Get the background color of the button according to the status */ this.mainBackgroundColor = (statusClass) => { let bg = this.design.background; switch (statusClass) { case 'state-success': bg = this.design.successBackground; break; case 'state-error': bg = this.design.errorBackground; break; } return bg; }; /** * Get css style of the button */ this.buttonStyle = (statusClass) => { return { background: (!this.status.isPerspective) ? this.mainBackgroundColor(statusClass) : null, color: this.design.color, borderRadius: (this.status.isBorderRadius) ? this.design.radius + 'px' : null, }; }; /** * Get the content style according to the status */ this.contentStyle = (statusClass) => { return { background: (this.status.isContentBackground) ? this.mainBackgroundColor(statusClass) : null, color: this.design.color, borderRadius: (this.status.isBorderRadius) ? this.design.radius + 'px' : null, }; }; const defConfig = new ProgressButtonConfig(); this.progressP = (config.progress) ? Object.assign({}, config.progress) : Object.assign({}, defConfig.progress); this.designP = (config.design) ? Object.assign({}, config.design) : Object.assign({}, defConfig.design); } /** * Return the status of the data */ get status() { const status = { perspective: null, isHorizontal: true, isPerspective: false, isBorderRadius: false, isRotateAnimation: false, isFlipAnimation: false, isSlideDownAnimation: false, isMoveUpAnimation: false, isContentBackground: false }; status.isHorizontal = (this.progress.direction === 'horizontal'); status.isRotateAnimation = (this.progress.animation.includes('rotate-')); status.isFlipAnimation = (this.progress.animation.includes('flip-')); status.isSlideDownAnimation = (this.progress.animation.includes('slide-down')); status.isMoveUpAnimation = (this.progress.animation.includes('move-up')); status.perspective = (status.isRotateAnimation || status.isFlipAnimation) ? '' : null; // Have progress animation 3D perspective status.isPerspective = (status.perspective !== null); status.isBorderRadius = (!status.isRotateAnimation && this.design.radius !== null); status.isContentBackground = (status.isPerspective || status.isSlideDownAnimation || status.isMoveUpAnimation); return status; } get design() { return this.designP; } set design(value) { this.designP = mergeOptions(value, this.designP); } get progress() { return this.progressP; } set progress(value) { this.progressP = mergeOptions(value, this.progressP); } } /** @nocollapse */ ProgressButtonService.ɵprov = i0.ɵɵdefineInjectable({ factory: function ProgressButtonService_Factory() { return new ProgressButtonService(i0.ɵɵinject(i1.ProgressButtonConfig)); }, token: ProgressButtonService, providedIn: "root" }); ProgressButtonService.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ ProgressButtonService.ctorParameters = () => [ { type: ProgressButtonConfig } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-button.service.js","sourceRoot":"","sources":["../../../../projects/progress-button/src/lib/progress-button.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\nimport {\r\n  mergeOptions,\r\n  ProgressButtonAnimation,\r\n  ProgressButtonConfig,\r\n  ProgressButtonData,\r\n  ProgressButtonDataStatus,\r\n  ProgressButtonDesign, ProgressButtonStyles\r\n} from './progress-button.types';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ProgressButtonService {\r\n\r\n\r\n  private progressP: ProgressButtonData;\r\n  private designP: ProgressButtonDesign;\r\n\r\n  constructor(config: ProgressButtonConfig = new ProgressButtonConfig()) {\r\n    const defConfig = new ProgressButtonConfig();\r\n    this.progressP = (config.progress) ? {...config.progress} : {...defConfig.progress};\r\n    this.designP = (config.design) ? {...config.design} : {...defConfig.design};\r\n  }\r\n\r\n  /**\r\n   * Return the status of the data\r\n   */\r\n  get status(): ProgressButtonDataStatus {\r\n    const status = {\r\n      perspective: null,\r\n      isHorizontal: true,\r\n      isPerspective: false,\r\n      isBorderRadius: false,\r\n      isRotateAnimation: false,\r\n      isFlipAnimation: false,\r\n      isSlideDownAnimation: false,\r\n      isMoveUpAnimation: false,\r\n      isContentBackground: false\r\n    };\r\n    status.isHorizontal = (this.progress.direction === 'horizontal');\r\n    status.isRotateAnimation = (this.progress.animation.includes('rotate-'));\r\n    status.isFlipAnimation = (this.progress.animation.includes('flip-'));\r\n    status.isSlideDownAnimation = (this.progress.animation.includes('slide-down'));\r\n    status.isMoveUpAnimation = (this.progress.animation.includes('move-up'));\r\n    status.perspective = (status.isRotateAnimation || status.isFlipAnimation) ? '' : null; // Have progress animation 3D perspective\r\n    status.isPerspective = (status.perspective !== null);\r\n    status.isBorderRadius = (!status.isRotateAnimation && this.design.radius !== null);\r\n    status.isContentBackground = (status.isPerspective || status.isSlideDownAnimation || status.isMoveUpAnimation);\r\n    return status;\r\n  }\r\n\r\n  get design(): ProgressButtonDesign {\r\n    return this.designP;\r\n  }\r\n\r\n  set design(value: ProgressButtonDesign) {\r\n    this.designP = mergeOptions(value, this.designP);\r\n  }\r\n\r\n  get progress(): ProgressButtonData {\r\n    return this.progressP;\r\n  }\r\n\r\n  set progress(value: ProgressButtonData) {\r\n    this.progressP = mergeOptions(value, this.progressP);\r\n  }\r\n\r\n  /**\r\n   * Check if animation is active\r\n   * @param name ProgressButtonAnimation Animation name\r\n   */\r\n  isAnimation = (name: ProgressButtonAnimation): boolean => {\r\n    return (this.progress.animation === name);\r\n  };\r\n\r\n  /**\r\n   * Return some progress styles\r\n   * @param progressValue The progress value\r\n   * @param statusClass The status (state-success | state-error)\r\n   */\r\n  styles = (progressValue: number, statusClass: string): ProgressButtonStyles => {\r\n    return {\r\n      progressInner: this.progressInnerStyle(progressValue),\r\n      button: this.buttonStyle(statusClass),\r\n      content: this.contentStyle(statusClass)\r\n    };\r\n  };\r\n\r\n  /**\r\n   * Get the Progress Inner Style\r\n   * @param progressValue The progress value\r\n   */\r\n  private progressInnerStyle = (progressValue: number) => {\r\n\r\n    const style = {\r\n      background: this.design.progressInnerBackground,\r\n      borderColor: null,\r\n      borderLeftWidth: null,\r\n      borderRightWidth: null,\r\n      height: null,\r\n      width: null,\r\n    };\r\n\r\n    // Reset LinesSize\r\n    if ((this.design.linesSize === null) || (typeof this.design.linesSize === 'undefined')) {\r\n      this.design.linesSize = 10;\r\n    }\r\n\r\n    // Lateral Lines\r\n    if (this.isAnimation('lateral-lines')) {\r\n      style.background = null;\r\n      style.borderColor = this.design.progressInnerBackground;\r\n      style.borderLeftWidth = this.design.linesSize + 'px';\r\n      style.borderRightWidth = this.design.linesSize + 'px';\r\n    }\r\n\r\n    // Set Size\r\n    style.height = this.progressInnerHeight(progressValue);\r\n    style.width = this.progressInnerWidth(progressValue);\r\n\r\n    return style;\r\n  };\r\n\r\n  /**\r\n   * Get Calculated Progress Inner Width\r\n   */\r\n  private progressInnerWidth = (progressValue: number) => {\r\n    if (this.progress.direction === 'horizontal') {\r\n      return progressValue + '%';\r\n    } else {\r\n      if (this.isAnimation('shrink') && this.design.radius) {\r\n        return progressValue + '%';\r\n      }\r\n    }\r\n    if (this.isAnimation('top-line')) {\r\n      return this.design.linesSize + 'px';\r\n    }\r\n    return null;\r\n  };\r\n\r\n  /**\r\n   * Get Calculated Progress Inner Height\r\n   */\r\n  private progressInnerHeight = (progressValue: number) => {\r\n    if (this.progress.direction === 'vertical') {\r\n      if (this.isAnimation('shrink') && this.design.radius) {\r\n        return '100%';\r\n      }\r\n      return progressValue + '%';\r\n    }\r\n    if (this.isAnimation('top-line')) {\r\n      return this.design.linesSize + 'px';\r\n    }\r\n    return null;\r\n  };\r\n\r\n  /**\r\n   * Get the background color of the button according to the status\r\n   */\r\n  private mainBackgroundColor = (statusClass: string) => {\r\n    let bg = this.design.background;\r\n    switch (statusClass) {\r\n      case 'state-success':\r\n        bg = this.design.successBackground;\r\n        break;\r\n      case 'state-error':\r\n        bg = this.design.errorBackground;\r\n        break;\r\n    }\r\n    return bg;\r\n  };\r\n\r\n  /**\r\n   * Get css style of the button\r\n   */\r\n  private buttonStyle = (statusClass: string) => {\r\n    return {\r\n      background: (!this.status.isPerspective) ? this.mainBackgroundColor(statusClass) : null,\r\n      color: this.design.color,\r\n      borderRadius: (this.status.isBorderRadius) ? this.design.radius + 'px' : null,\r\n    };\r\n  };\r\n\r\n  /**\r\n   * Get the content style according to the status\r\n   */\r\n  private contentStyle = (statusClass: string) => {\r\n    return {\r\n      background: (this.status.isContentBackground) ? this.mainBackgroundColor(statusClass) : null,\r\n      color: this.design.color,\r\n      borderRadius: (this.status.isBorderRadius) ? this.design.radius + 'px' : null,\r\n    };\r\n  };\r\n\r\n}\r\n"]}