@kushki/ng-suka
Version:
<p align="center"> <h1 align="center">Suka Components Angular</h1> <p align="center"> An Angular implementation of the Suka Design System </p> </p>
233 lines (232 loc) • 16.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, HostBinding, Output, EventEmitter } from '@angular/core';
export class Progress {
constructor() {
this.baseClass = true;
/**
* Set to `true` to make the progress linear. This allows the user to access any of the steps at any time (like tabs).
*/
this.linear = false;
/**
* Set to `true` to allow the user to edit a step after completed.
*/
this.editable = false;
/**
* Emits an event when a index is selected
*/
this.selected = new EventEmitter();
/**
* Emits an event when the steps change.
*/
this.stepsChange = new EventEmitter();
}
/**
* Sets the steps for the `Progress` component.
* @return {?}
*/
get steps() {
return this._steps;
}
/**
* @param {?} value
* @return {?}
*/
set steps(value) {
this._steps = value;
this.stepsChange.emit(this._steps);
}
/**
* @param {?} newIndex
* @return {?}
*/
select(newIndex) {
this._steps.forEach((/**
* @param {?} step
* @param {?} index
* @return {?}
*/
(step, index) => {
if (index === newIndex) {
step.current = true;
}
else if (step.current) {
delete step.current;
}
}));
this.selected.emit(newIndex);
this.steps = this._steps;
}
/**
* Step is completed.
* @param {?} step
* @return {?}
*/
isComplete(step) {
return step.state === 'complete';
}
/**
* Step is editable.
* @param {?} step
* @return {?}
*/
isEditable(step) {
return step.state === 'complete' && this.editable;
}
/**
* Step is unclickable.
* @param {?} step
* @param {?} index
* @return {?}
*/
isUnclickable(step, index) {
if (step.state === 'complete' && !this.editable) {
return true;
}
if (step.state === 'incomplete' && !this.linear && index !== this.getNextUncompletedStepIndex()) {
return true;
}
return false;
}
/**
* Returns the index of the next uncompleted step.
* @return {?}
*/
getNextUncompletedStepIndex() {
for (const [index, step] of this.steps.entries()) {
if (step.state === 'incomplete') {
return index;
}
}
return -1;
}
/**
* Returns the current step.
* @return {?}
*/
currentStep() {
for (const [_, step] of this.steps.entries()) {
if (step.current) {
return step;
}
}
return null;
}
/**
* Returns the next step.
* @return {?}
*/
nextStep() {
/** @type {?} */
let currentIndex = -1;
for (const [index, step] of this.steps.entries()) {
if (step.current) {
currentIndex = index;
}
if (currentIndex >= 0 && currentIndex + 1 === index) {
return step;
}
}
return null;
}
/**
* Returns the current step index.
* @return {?}
*/
getCurrentStepIndex() {
for (const [index, step] of this.steps.entries()) {
if (step.current) {
return index;
}
}
return -1;
}
}
Progress.decorators = [
{ type: Component, args: [{
selector: 'suka-progress',
template: `
<div class="mobile-progress">
<div class="mobile-progress__label">
<h3 class="mobile-progress__label__current-step">{{currentStep().label}}</h3>
<p class="mobile-progress__label__next-step" *ngIf="getCurrentStepIndex() + 1 < steps.length">Próximo paso: {{nextStep().label}}</p>
<p class="mobile-progress__label__next-step" *ngIf="getCurrentStepIndex() + 1 >= steps.length">Último paso</p>
</div>
<div
class="mobile-progress__status"
[ngClass]="[
'radial-progress-' + (getCurrentStepIndex() + 1) * 100 / steps.length
]"
>
<div class="mobile-progress__status-overlay">
{{getCurrentStepIndex() + 1}} de {{steps.length}}
</div>
</div>
</div>
<div class="progress__wrapper">
<ul class="progress-bar">
<li
*ngFor="let step of steps; let i = index"
class="progress-bar__step"
[ngClass]="{
'progress-bar__step--complete': isComplete(step),
'progress-bar__step--editable': isEditable(step),
'progress-bar__step--error': step.state === 'error',
'progress-bar__step--current': step.current,
'progress-bar__step--unclickable': isUnclickable(step, i)
}"
>
<div class="step" role="button" (click)="select(i)">
<div class="step__indicator">
<ng-container *ngIf="step.state !== 'complete' || step.current">{{ i + 1 }}</ng-container>
<suka-icon icon="check" *ngIf="isComplete(step) && !isEditable(step) && !step.current"></suka-icon>
<suka-icon icon="edit-2" *ngIf="isEditable(step) && !step.current"></suka-icon>
</div>
<span class="step__label"> {{ step.label }}</span>
</div>
</li>
</ul>
</div>
`
}] }
];
Progress.propDecorators = {
baseClass: [{ type: HostBinding, args: ['class.progress',] }],
linear: [{ type: Input }],
editable: [{ type: Input }],
selected: [{ type: Output }],
stepsChange: [{ type: Output }],
steps: [{ type: Input }]
};
if (false) {
/**
* @type {?}
* @private
*/
Progress.prototype._steps;
/** @type {?} */
Progress.prototype.baseClass;
/**
* Set to `true` to make the progress linear. This allows the user to access any of the steps at any time (like tabs).
* @type {?}
*/
Progress.prototype.linear;
/**
* Set to `true` to allow the user to edit a step after completed.
* @type {?}
*/
Progress.prototype.editable;
/**
* Emits an event when a index is selected
* @type {?}
*/
Progress.prototype.selected;
/**
* Emits an event when the steps change.
* @type {?}
*/
Progress.prototype.stepsChange;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"ng://@kushki/ng-suka/","sources":["lib/progress/progress.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, Output, EventEmitter, OnInit } from '@angular/core';\nimport { ProgressStep } from './progress-step.interface';\n\n@Component({\n  selector: 'suka-progress',\n  template: `\n    <div class=\"mobile-progress\">\n      <div class=\"mobile-progress__label\">\n        <h3 class=\"mobile-progress__label__current-step\">{{currentStep().label}}</h3>\n        <p class=\"mobile-progress__label__next-step\" *ngIf=\"getCurrentStepIndex() + 1 < steps.length\">Próximo paso: {{nextStep().label}}</p>\n        <p class=\"mobile-progress__label__next-step\" *ngIf=\"getCurrentStepIndex() + 1 >= steps.length\">Último paso</p>\n      </div>\n\n      <div\n        class=\"mobile-progress__status\"\n        [ngClass]=\"[\n          'radial-progress-' + (getCurrentStepIndex() + 1) * 100 / steps.length\n        ]\"\n      >\n        <div class=\"mobile-progress__status-overlay\">\n          {{getCurrentStepIndex() + 1}} de {{steps.length}}\n        </div>\n      </div>\n    </div>\n    <div class=\"progress__wrapper\">\n      <ul class=\"progress-bar\">\n        <li\n          *ngFor=\"let step of steps; let i = index\"\n          class=\"progress-bar__step\"\n          [ngClass]=\"{\n            'progress-bar__step--complete': isComplete(step),\n            'progress-bar__step--editable': isEditable(step),\n            'progress-bar__step--error': step.state === 'error',\n            'progress-bar__step--current': step.current,\n            'progress-bar__step--unclickable': isUnclickable(step, i)\n          }\"\n        >\n          <div class=\"step\" role=\"button\" (click)=\"select(i)\">\n            <div class=\"step__indicator\">\n              <ng-container *ngIf=\"step.state !== 'complete' || step.current\">{{ i + 1 }}</ng-container>\n              <suka-icon icon=\"check\" *ngIf=\"isComplete(step) && !isEditable(step) && !step.current\"></suka-icon>\n              <suka-icon icon=\"edit-2\" *ngIf=\"isEditable(step) && !step.current\"></suka-icon>\n            </div>\n            <span class=\"step__label\"> {{ step.label }}</span>\n          </div>\n        </li>\n      </ul>\n    </div>\n  `\n})\nexport class Progress {\n  private _steps: Array<ProgressStep>;\n\n  @HostBinding('class.progress') baseClass = true;\n\n  /**\n   * Set to `true` to make the progress linear. This allows the user to access any of the steps at any time (like tabs).\n   */\n  @Input() linear = false;\n\n  /**\n   * Set to `true` to allow the user to edit a step after completed.\n   */\n  @Input() editable = false;\n\n  /**\n   * Emits an event when a index is selected\n   */\n  @Output() selected = new EventEmitter();\n\n  /**\n   * Emits an event when the steps change.\n   */\n  @Output() stepsChange = new EventEmitter();\n  /**\n   * Sets the steps for the `Progress` component.\n   */\n  @Input() get steps() {\n    return this._steps;\n  }\n  set steps(value) {\n    this._steps = value;\n\n    this.stepsChange.emit(this._steps);\n  }\n\n  select(newIndex): void {\n    this._steps.forEach((step, index) => {\n      if (index === newIndex) {\n        step.current = true;\n      } else if (step.current) {\n        delete step.current;\n      }\n    });\n\n    this.selected.emit(newIndex);\n\n    this.steps = this._steps;\n  }\n\n  /**\n   * Step is completed.\n   */\n  isComplete(step: ProgressStep) {\n    return step.state === 'complete';\n  }\n\n  /**\n   * Step is editable.\n   */\n  isEditable(step: ProgressStep) {\n    return step.state === 'complete' && this.editable;\n  }\n\n  /**\n   * Step is unclickable.\n   */\n  isUnclickable(step: ProgressStep, index: number): boolean {\n    if (step.state === 'complete' && !this.editable) {\n      return true;\n    }\n    if (step.state === 'incomplete' && !this.linear && index !== this.getNextUncompletedStepIndex()) {\n      return true;\n    }\n\n    return false;\n  }\n\n  /**\n   * Returns the index of the next uncompleted step.\n   */\n  getNextUncompletedStepIndex(): number {\n    for (const [index, step] of this.steps.entries()) {\n      if (step.state === 'incomplete') {\n        return index;\n      }\n    }\n\n    return -1;\n  }\n\n\n  /**\n   * Returns the current step.\n   */\n  currentStep() {\n    for (const [_, step] of this.steps.entries()) {\n      if (step.current) {\n        return step;\n      }\n    }\n\n    return null;\n  }\n\n  /**\n   * Returns the next step.\n   */\n  nextStep() {\n    let currentIndex = -1;\n\n    for (const [index, step] of this.steps.entries()) {\n      if (step.current) {\n        currentIndex = index;\n      }\n      if (currentIndex >= 0 && currentIndex + 1 === index) {\n        return step;\n      }\n    }\n\n    return null;\n  }\n\n  /**\n   * Returns the current step index.\n   */\n  getCurrentStepIndex() {\n    for (const [index, step] of this.steps.entries()) {\n      if (step.current) {\n        return index;\n      }\n    }\n\n    return -1;\n  }\n}\n"]}