progress-button
Version:
A simple angular progress button.
175 lines • 22.7 kB
JavaScript
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"]}