angular-bootstrap-italia
Version:
<p align="center"> <h1 align="center">Bootstrap Italia + Angular 9</h1>
227 lines • 35.6 kB
JavaScript
import { __decorate, __read, __spread } from "tslib";
import { Component, Input, Output, EventEmitter } from '@angular/core';
import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
// Components
import { Validators } from '@angular/forms';
// Services
import { DynamicFormControlService } from '../dynamic-form/dynamic-form-control.service';
var StepperComponent = /** @class */ (function () {
function StepperComponent(qcs) {
this.qcs = qcs;
this.fromValueChange = new EventEmitter();
this.submitedEvent = new EventEmitter();
this.latitude = 42.50;
this.longitude = 12.50;
}
StepperComponent.prototype.ngOnInit = function () {
var _this = this;
var _a, _b, _c, _d;
this.widthExp = 100 / this.stepElements.length;
// step a 1
this.currentStepIndex = 1;
this.validSteps = [];
this.touchedSteps = [];
this.formRows = [].concat.apply([], __spread(this.stepElements.map(function (e) { return e.fromRows; })));
var elements = [].concat.apply([], __spread(this.formRows.map(function (e) { return e.items; })));
this.stepForm = this.qcs.toFormGroup(elements);
this.mapId = this.getMapId();
var mapFormRows = this.stepElements.find(function (elem) { return elem.mapId; }).fromRows;
this.mapFormFields = [].concat.apply([], __spread(mapFormRows.map(function (e) { return e.items; })));
// Form Latiture
(_a = this.stepForm.controls.latitude) === null || _a === void 0 ? void 0 : _a.setValue(42.50);
this.latSub = (_b = this.stepForm.controls.latitude) === null || _b === void 0 ? void 0 : _b.valueChanges.pipe(debounceTime(500), distinctUntilChanged()).subscribe(function (newVal) {
_this.latitude = newVal;
});
// Form Longitude
(_c = this.stepForm.controls.longitude) === null || _c === void 0 ? void 0 : _c.setValue(12.50);
this.lngSub = (_d = this.stepForm.controls.longitude) === null || _d === void 0 ? void 0 : _d.valueChanges.pipe(debounceTime(500), distinctUntilChanged()).subscribe(function (newVal) {
_this.longitude = newVal;
});
this.formStateSubscription = this.stepForm.valueChanges
.subscribe(function (newValue) {
var _a;
var mapFieldsKeys = _this.mapFormFields.map(function (e) { return e.key; });
var mapBoxingValues = [];
mapFieldsKeys.forEach(function (key) {
var fieldValue = _this.stepForm.value[key];
if (typeof fieldValue === 'object') {
mapBoxingValues.push(_this.stepForm.value[key]);
}
if (fieldValue === null || fieldValue === void 0 ? void 0 : fieldValue.shapelight) { // TODO: Fix name
_this.mapShapePolygon = fieldValue.shapelight;
}
});
if ((mapBoxingValues === null || mapBoxingValues === void 0 ? void 0 : mapBoxingValues.length) > 0) {
_this.mapBboxPolygon = (_a = mapBoxingValues[mapBoxingValues.length - 1]) === null || _a === void 0 ? void 0 : _a.boundingbox; // TODO: Fix Name
}
_this.fromValueChange.emit(newValue);
});
};
StepperComponent.prototype.ngOnDestroy = function () {
if (this.formStateSubscription) {
this.formStateSubscription.unsubscribe();
}
if (this.latSub) {
this.latSub.unsubscribe();
}
if (this.lngSub) {
this.lngSub.unsubscribe();
}
};
Object.defineProperty(StepperComponent.prototype, "stepRows", {
get: function () {
var _this = this;
var rows = this.stepElements.find(function (e) { return e.index === _this.currentStepIndex; }).fromRows;
return rows;
},
enumerable: true,
configurable: true
});
StepperComponent.prototype.getItems = function (formRow) {
var _this = this;
var items = formRow.items.filter(function (item) {
var _a, _b, _c, _d, _e, _f, _g;
var showCondition = false;
// Se tipo semplice
if (((_a = item.parentShowCondition) === null || _a === void 0 ? void 0 : _a.parentKey) &&
((_b = item.parentShowCondition) === null || _b === void 0 ? void 0 : _b.parentValue) === _this.stepForm.get(item.parentShowCondition.parentKey).value) {
showCondition = true;
}
// Se oggetto
if (((_c = item.parentShowCondition) === null || _c === void 0 ? void 0 : _c.parentKey) && typeof ((_d = item.parentShowCondition) === null || _d === void 0 ? void 0 : _d.parentValue) === 'object'
// tslint:disable-next-line: max-line-length
&& JSON.stringify((_e = item.parentShowCondition) === null || _e === void 0 ? void 0 : _e.parentValue) === JSON.stringify(_this.stepForm.get(item.parentShowCondition.parentKey).value)) {
showCondition = true;
}
if (!item.parentShowCondition || showCondition) {
(_f = _this.stepForm.get(item.key)) === null || _f === void 0 ? void 0 : _f.setValidators(Validators.required);
return item;
}
else {
(_g = _this.stepForm.get(item.key)) === null || _g === void 0 ? void 0 : _g.setValidators(null);
}
});
return items;
};
StepperComponent.prototype.getPratentField = function (itemKey) {
var elements = [].concat.apply([], __spread(this.formRows.map(function (e) { return e.items; })));
return elements.find(function (e) { return e.parentFieldKey === itemKey; });
};
StepperComponent.prototype.isValidStep = function (stepIndex) {
var step = this.validSteps.find(function (e) { return e === stepIndex; });
if (step) {
return true;
}
return false;
};
StepperComponent.prototype.setValidStep = function (stepIndex) {
// ritorna true se tutti campi di quello step sono validi altrimenti false
// prendi le chiavi dei campi di quel particolare step
var rowsItems = this.stepElements
.find(function (e) { return e.index === stepIndex; }).fromRows
.map(function (e) { return e.items; });
var rowsElements = [].concat.apply([], __spread(rowsItems));
var fieldsKeys = rowsElements.map(function (e) { return e.key; });
var controls = this.stepForm.controls;
var filtered = Object.keys(controls)
.filter(function (key) { return fieldsKeys.includes(key) && controls[key].valid; })
.reduce(function (obj, key) {
obj[key] = controls[key];
return obj;
}, {});
if (arraysEqual(fieldsKeys, Object.keys(filtered))) {
var index = this.validSteps.indexOf(stepIndex, 0);
if (index === -1) {
this.validSteps.push(stepIndex);
}
}
else {
var index = this.validSteps.indexOf(stepIndex, 0);
if (index > -1) {
this.validSteps.splice(index, 1);
}
}
};
StepperComponent.prototype.isTouchedStep = function (stepIndex) {
var step = this.touchedSteps.find(function (e) { return e === stepIndex; });
if (step) {
return true;
}
return false;
};
StepperComponent.prototype.prevStep = function () {
this.stepForm.updateValueAndValidity();
this.setValidStep(this.currentStepIndex);
this.touchedSteps.push(this.currentStepIndex);
this.currentStepIndex--;
};
StepperComponent.prototype.nextStep = function () {
this.stepForm.updateValueAndValidity();
this.setValidStep(this.currentStepIndex);
this.touchedSteps.push(this.currentStepIndex);
this.currentStepIndex++;
};
StepperComponent.prototype.onSubmit = function () {
this.submitedEvent.emit(this.stepForm.getRawValue());
};
StepperComponent.prototype.stepHaveMap = function (stepIndex) {
var step = this.stepElements.find(function (e) { return e.index === stepIndex; });
if (step && step.mapId) {
// const fromElements = [].concat(...step.fromRows.map(e => e.items));
// const latitudeControl = fromElements.find(e => e.key === this.latitude);
// const longitudeControl = fromElements.find(e => e.key === this.longitude);
return true;
}
return false;
};
StepperComponent.prototype.getMapGeojson = function (geoJson) {
this.mapGeoJson = geoJson;
console.log(geoJson);
};
StepperComponent.prototype.getMapId = function () {
var step = this.stepElements.find(function (e) { return e.mapId; });
if (step && step.mapId) {
return step.mapId;
}
return null;
};
StepperComponent.ctorParameters = function () { return [
{ type: DynamicFormControlService }
]; };
__decorate([
Input()
], StepperComponent.prototype, "stepElements", void 0);
__decorate([
Output()
], StepperComponent.prototype, "fromValueChange", void 0);
__decorate([
Output()
], StepperComponent.prototype, "submitedEvent", void 0);
StepperComponent = __decorate([
Component({
selector: 'lib-stepper',
template: "<div class=\"steppers\">\r\n <ul class=\"steppers-header custom-stepper-header\">\r\n\r\n <li *ngFor=\"let step of stepElements\"\r\n [ngClass]=\"{'active': step.index === currentStepIndex, 'confirmed': step.index !== currentStepIndex && isValidStep(step.index)}\"\r\n [ngStyle]=\"{'width': widthExp + '%'}\">\r\n {{ step.label }}\r\n <svg class=\"icon icon-success steppers-success\" *ngIf=\"step.index !== currentStepIndex && isValidStep(step.index)\">\r\n <use xlink:href=\"./assets/bootstrap-italia/svg/sprite.svg#it-check\"></use>\r\n </svg>\r\n <svg class=\"icon icon-warning steppers-success\" *ngIf=\"step.index !== currentStepIndex && !isValidStep(step.index) && isTouchedStep(step.index)\">\r\n <use xlink:href=\"./assets/bootstrap-italia/svg/sprite.svg#it-info-circle\"></use>\r\n </svg>\r\n <span class=\"sr-only\" *ngIf=\"step.index === currentStepIndex\">Attivo</span>\r\n <span class=\"sr-only\" *ngIf=\"step.index !== currentStepIndex && isValidStep(step.index)\">Confermato</span>\r\n </li>\r\n\r\n <li class=\"steppers-index\" aria-hidden=\"true\">{{ currentStepIndex }}/{{ stepElements.length }}</li>\r\n\r\n </ul>\r\n <div class=\"align-middle custom-stepper\" aria-live=\"polite\">\r\n <form [formGroup]=\"stepForm\">\r\n <div class=\"form-row\" *ngFor=\"let row of stepRows\">\r\n <div class=\"custom-form-group\" *ngFor=\"let item of getItems(row)\" [ngClass]=\"item.class\">\r\n <lib-dynamic-form-element [field]=\"item\" [parentField]=\"getPratentField(item.parentFieldKey)\" [form]=\"stepForm\"></lib-dynamic-form-element>\r\n </div>\r\n </div>\r\n <div class=\"form-map\" *ngIf=\"stepHaveMap(currentStepIndex)\">\r\n <lib-leaflet-map [latitude]=\"latitude\" [longitude]=\"longitude\" [bboxPolygon]=\"mapBboxPolygon\" [shapePolygon]=\"mapShapePolygon\" (geoJson)=\"getMapGeojson($event)\" [enableEdit]=\"true\"></lib-leaflet-map>\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <nav class=\"steppers-nav custom-stepper-nav\">\r\n <button type=\"button\" class=\"btn btn-outline-primary btn-sm steppers-btn-prev\" (click)=\"prevStep()\" [disabled]=\"currentStepIndex === 1\">\r\n <svg class=\"icon icon-primary\">\r\n <use xlink:href=\"./assets/bootstrap-italia/svg/sprite.svg#it-chevron-left\"></use>\r\n </svg>\r\n Indietro\r\n </button>\r\n <button type=\"button\" class=\"btn btn-primary btn-sm steppers-btn-save\" (click)=\"onSubmit()\" [disabled]=\"!stepForm.valid\">Salva</button>\r\n <button type=\"button\" class=\"btn btn-outline-primary btn-sm steppers-btn-next\" (click)=\"nextStep()\" [disabled]=\"currentStepIndex === stepElements.length\">Avanti\r\n <svg class=\"icon icon-primary\">\r\n <use xlink:href=\"./assets/bootstrap-italia/svg/sprite.svg#it-chevron-right\"></use>\r\n </svg>\r\n </button>\r\n </nav>\r\n</div>\r\n",
styles: [".custom-stepper{min-height:20em;padding-top:3em;padding-left:1em;padding-right:1em;justify-content:center;align-items:center;color:#333}@media (min-width:992px){.custom-stepper{min-height:22em}.custom-stepper .form-map{margin-bottom:3em}.custom-stepper-header{box-shadow:0 10px 40px -30px grey}.custom-stepper-nav{box-shadow:0 -15px 30px -25px grey}.custom-form-group{min-height:5em}}"]
})
], StepperComponent);
return StepperComponent;
}());
export { StepperComponent };
function arraysEqual(a, b) {
if (a === b) {
return true;
}
if (a == null || b == null) {
return false;
}
if (a.length !== b.length) {
return false;
}
for (var i = 0; i < a.length; ++i) {
if (a[i] !== b[i]) {
return false;
}
}
return true;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"ng://angular-bootstrap-italia/","sources":["lib/components/stepper/stepper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';\r\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n// Components\r\nimport { FormGroup, FormControl, Validators } from '@angular/forms';\r\n\r\n// Services\r\nimport { DynamicFormControlService } from '../dynamic-form/dynamic-form-control.service';\r\nimport { Subscription } from 'rxjs';\r\n\r\n// Models\r\nimport { FormRow } from '../form/form-row';\r\nimport { FormBase } from '../form/form-base';\r\nimport { StepperElement } from './stepper-element.model';\r\n\r\n\r\n@Component({\r\n  selector: 'lib-stepper',\r\n  templateUrl: './stepper.component.html',\r\n  styleUrls: ['./stepper.component.scss'],\r\n  // changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class StepperComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() stepElements: StepperElement<string>[];\r\n\r\n  @Output() fromValueChange = new EventEmitter<FormGroup>();\r\n  @Output() submitedEvent = new EventEmitter();\r\n\r\n  widthExp: number;\r\n  currentStepIndex: number; // Diventa Input / Output\r\n  touchedSteps: number[];\r\n  validSteps: number[];\r\n  stepForm: FormGroup;\r\n  formStateSubscription: Subscription;\r\n\r\n  // Map Detalis\r\n  mapId: string;\r\n  latitude = 42.50;\r\n  longitude = 12.50;\r\n  latSub: Subscription;\r\n  lngSub: Subscription;\r\n  mapGeoJson: any;\r\n  mapBboxPolygon: any;\r\n  mapShapePolygon: any;\r\n  mapFormFields: FormBase<any>[];\r\n\r\n  // Form elements\r\n  formRows: FormRow<string>[];\r\n\r\n  constructor(private qcs: DynamicFormControlService) { }\r\n\r\n  ngOnInit(): void {\r\n    this.widthExp = 100 / this.stepElements.length;\r\n\r\n    // step a 1\r\n    this.currentStepIndex = 1;\r\n    this.validSteps = [];\r\n    this.touchedSteps = [];\r\n\r\n    this.formRows = [].concat(...this.stepElements.map(e => e.fromRows));\r\n\r\n    const elements = [].concat(...this.formRows.map(e => e.items));\r\n\r\n    this.stepForm = this.qcs.toFormGroup(elements);\r\n\r\n    this.mapId = this.getMapId();\r\n    const mapFormRows = this.stepElements.find(elem => elem.mapId).fromRows;\r\n    this.mapFormFields = [].concat(...mapFormRows.map(e => e.items));\r\n\r\n    // Form Latiture\r\n    this.stepForm.controls.latitude?.setValue(42.50);\r\n    this.latSub = this.stepForm.controls.latitude?.valueChanges\r\n      .pipe(debounceTime(500), distinctUntilChanged())\r\n      .subscribe(newVal => {\r\n        this.latitude = newVal;\r\n      });\r\n\r\n    // Form Longitude\r\n    this.stepForm.controls.longitude?.setValue(12.50);\r\n    this.lngSub = this.stepForm.controls.longitude?.valueChanges\r\n      .pipe(debounceTime(500), distinctUntilChanged())\r\n      .subscribe(newVal => {\r\n        this.longitude = newVal;\r\n      });\r\n\r\n    this.formStateSubscription = this.stepForm.valueChanges\r\n      .subscribe(newValue => {\r\n        const mapFieldsKeys = this.mapFormFields.map(e => e.key);\r\n        const mapBoxingValues = [];\r\n\r\n        mapFieldsKeys.forEach(key => {\r\n          const fieldValue = this.stepForm.value[key];\r\n          if (typeof fieldValue === 'object') {\r\n            mapBoxingValues.push(this.stepForm.value[key]);\r\n          }\r\n\r\n          if (fieldValue?.shapelight) {  // TODO: Fix name\r\n            this.mapShapePolygon = fieldValue.shapelight;\r\n          }\r\n        });\r\n\r\n        if (mapBoxingValues?.length > 0) {\r\n          this.mapBboxPolygon = mapBoxingValues[mapBoxingValues.length - 1]?.boundingbox; // TODO: Fix Name\r\n        }\r\n\r\n        this.fromValueChange.emit(newValue);\r\n      });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.formStateSubscription) {\r\n      this.formStateSubscription.unsubscribe();\r\n    }\r\n    if (this.latSub) {\r\n      this.latSub.unsubscribe();\r\n    }\r\n    if (this.lngSub) {\r\n      this.lngSub.unsubscribe();\r\n    }\r\n  }\r\n\r\n  get stepRows(): FormRow<string>[] {\r\n    const rows = this.stepElements.find(e => e.index === this.currentStepIndex).fromRows;\r\n    return rows;\r\n  }\r\n\r\n  getItems(formRow: FormRow<string>) {\r\n    const items = formRow.items.filter(item => {\r\n      let showCondition = false;\r\n      // Se tipo semplice\r\n      if (item.parentShowCondition?.parentKey &&\r\n        item.parentShowCondition?.parentValue === this.stepForm.get(item.parentShowCondition.parentKey).value) {\r\n        showCondition = true;\r\n      }\r\n\r\n      // Se oggetto\r\n      if (item.parentShowCondition?.parentKey\r\n        && typeof item.parentShowCondition?.parentValue === 'object'\r\n        // tslint:disable-next-line: max-line-length\r\n        && JSON.stringify(item.parentShowCondition?.parentValue) === JSON.stringify(this.stepForm.get(item.parentShowCondition.parentKey).value)\r\n      ) {\r\n        showCondition = true;\r\n      }\r\n\r\n      if (!item.parentShowCondition || showCondition) {\r\n        this.stepForm.get(item.key)?.setValidators(Validators.required);\r\n        return item;\r\n      } else {\r\n        this.stepForm.get(item.key)?.setValidators(null);\r\n      }\r\n    });\r\n    return items;\r\n  }\r\n\r\n  getPratentField(itemKey: string): FormBase<string> {\r\n    const elements = [].concat(...this.formRows.map(e => e.items));\r\n    return elements.find(e => e.parentFieldKey === itemKey);\r\n  }\r\n\r\n  isValidStep(stepIndex: number) {\r\n    const step = this.validSteps.find(e => e === stepIndex);\r\n    if (step) { return true; }\r\n    return false;\r\n  }\r\n\r\n  setValidStep(stepIndex: number) {\r\n    // ritorna true se tutti campi di quello step sono validi altrimenti false\r\n    // prendi le chiavi dei campi di quel particolare step\r\n    const rowsItems = this.stepElements\r\n      .find(e => e.index === stepIndex).fromRows\r\n      .map(e => e.items);\r\n    const rowsElements = [].concat(...rowsItems);\r\n    const fieldsKeys = rowsElements.map(e => e.key);\r\n    const controls = this.stepForm.controls;\r\n\r\n    const filtered = Object.keys(controls)\r\n      .filter(key => fieldsKeys.includes(key) && controls[key].valid)\r\n      .reduce((obj, key) => {\r\n        obj[key] = controls[key];\r\n        return obj;\r\n      }, {});\r\n\r\n    if (arraysEqual(fieldsKeys, Object.keys(filtered))) {\r\n      const index = this.validSteps.indexOf(stepIndex, 0);\r\n      if (index === -1) {\r\n        this.validSteps.push(stepIndex);\r\n      }\r\n    } else {\r\n      const index = this.validSteps.indexOf(stepIndex, 0);\r\n      if (index > -1) {\r\n        this.validSteps.splice(index, 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  isTouchedStep(stepIndex: number) {\r\n    const step = this.touchedSteps.find(e => e === stepIndex);\r\n    if (step) { return true; }\r\n    return false;\r\n  }\r\n\r\n  prevStep() {\r\n    this.stepForm.updateValueAndValidity();\r\n    this.setValidStep(this.currentStepIndex);\r\n    this.touchedSteps.push(this.currentStepIndex);\r\n    this.currentStepIndex--;\r\n  }\r\n\r\n  nextStep() {\r\n    this.stepForm.updateValueAndValidity();\r\n    this.setValidStep(this.currentStepIndex);\r\n    this.touchedSteps.push(this.currentStepIndex);\r\n    this.currentStepIndex++;\r\n  }\r\n\r\n  onSubmit() {\r\n    this.submitedEvent.emit(this.stepForm.getRawValue());\r\n  }\r\n\r\n  stepHaveMap(stepIndex: number) {\r\n    const step = this.stepElements.find(e => e.index === stepIndex);\r\n    if (step && step.mapId) {\r\n      // const fromElements = [].concat(...step.fromRows.map(e => e.items));\r\n      // const latitudeControl = fromElements.find(e => e.key === this.latitude);\r\n      // const longitudeControl = fromElements.find(e => e.key === this.longitude);\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  getMapGeojson(geoJson: any) {\r\n    this.mapGeoJson = geoJson;\r\n    console.log(geoJson);\r\n  }\r\n\r\n  private getMapId() {\r\n    const step = this.stepElements.find(e => e.mapId);\r\n    if (step && step.mapId) {\r\n      return step.mapId;\r\n    }\r\n    return null;\r\n  }\r\n\r\n}\r\n\r\nfunction arraysEqual(a, b) {\r\n  if (a === b) { return true; }\r\n  if (a == null || b == null) { return false; }\r\n  if (a.length !== b.length) { return false; }\r\n\r\n  for (let i = 0; i < a.length; ++i) {\r\n    if (a[i] !== b[i]) { return false; }\r\n  }\r\n  return true;\r\n}\r\n"]}