UNPKG

@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>

301 lines 20.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, HostBinding, Output, EventEmitter } from '@angular/core'; var Progress = /** @class */ (function () { function Progress() { 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(); } Object.defineProperty(Progress.prototype, "steps", { /** * Sets the steps for the `Progress` component. */ get: /** * Sets the steps for the `Progress` component. * @return {?} */ function () { return this._steps; }, set: /** * @param {?} value * @return {?} */ function (value) { this._steps = value; this.stepsChange.emit(this._steps); }, enumerable: true, configurable: true }); /** * @param {?} newIndex * @return {?} */ Progress.prototype.select = /** * @param {?} newIndex * @return {?} */ function (newIndex) { this._steps.forEach((/** * @param {?} step * @param {?} index * @return {?} */ function (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. */ /** * Step is completed. * @param {?} step * @return {?} */ Progress.prototype.isComplete = /** * Step is completed. * @param {?} step * @return {?} */ function (step) { return step.state === 'complete'; }; /** * Step is editable. */ /** * Step is editable. * @param {?} step * @return {?} */ Progress.prototype.isEditable = /** * Step is editable. * @param {?} step * @return {?} */ function (step) { return step.state === 'complete' && this.editable; }; /** * Step is unclickable. */ /** * Step is unclickable. * @param {?} step * @param {?} index * @return {?} */ Progress.prototype.isUnclickable = /** * Step is unclickable. * @param {?} step * @param {?} index * @return {?} */ function (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. */ /** * Returns the index of the next uncompleted step. * @return {?} */ Progress.prototype.getNextUncompletedStepIndex = /** * Returns the index of the next uncompleted step. * @return {?} */ function () { var e_1, _a; try { for (var _b = tslib_1.__values(this.steps.entries()), _c = _b.next(); !_c.done; _c = _b.next()) { var _d = tslib_1.__read(_c.value, 2), index = _d[0], step = _d[1]; if (step.state === 'incomplete') { return index; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } return -1; }; /** * Returns the current step. */ /** * Returns the current step. * @return {?} */ Progress.prototype.currentStep = /** * Returns the current step. * @return {?} */ function () { var e_2, _a; try { for (var _b = tslib_1.__values(this.steps.entries()), _c = _b.next(); !_c.done; _c = _b.next()) { var _d = tslib_1.__read(_c.value, 2), _ = _d[0], step = _d[1]; if (step.current) { return step; } } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_2) throw e_2.error; } } return null; }; /** * Returns the next step. */ /** * Returns the next step. * @return {?} */ Progress.prototype.nextStep = /** * Returns the next step. * @return {?} */ function () { var e_3, _a; /** @type {?} */ var currentIndex = -1; try { for (var _b = tslib_1.__values(this.steps.entries()), _c = _b.next(); !_c.done; _c = _b.next()) { var _d = tslib_1.__read(_c.value, 2), index = _d[0], step = _d[1]; if (step.current) { currentIndex = index; } if (currentIndex >= 0 && currentIndex + 1 === index) { return step; } } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_3) throw e_3.error; } } return null; }; /** * Returns the current step index. */ /** * Returns the current step index. * @return {?} */ Progress.prototype.getCurrentStepIndex = /** * Returns the current step index. * @return {?} */ function () { var e_4, _a; try { for (var _b = tslib_1.__values(this.steps.entries()), _c = _b.next(); !_c.done; _c = _b.next()) { var _d = tslib_1.__read(_c.value, 2), index = _d[0], step = _d[1]; if (step.current) { return index; } } } catch (e_4_1) { e_4 = { error: e_4_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_4) throw e_4.error; } } return -1; }; Progress.decorators = [ { type: Component, args: [{ selector: 'suka-progress', 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\u00F3ximo paso: {{nextStep().label}}</p>\n <p class=\"mobile-progress__label__next-step\" *ngIf=\"getCurrentStepIndex() + 1 >= steps.length\">\u00DAltimo 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 " }] } ]; Progress.propDecorators = { baseClass: [{ type: HostBinding, args: ['class.progress',] }], linear: [{ type: Input }], editable: [{ type: Input }], selected: [{ type: Output }], stepsChange: [{ type: Output }], steps: [{ type: Input }] }; return Progress; }()); export { Progress }; 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"]}