UNPKG

angular-bootstrap-italia

Version:

<p align="center"> <h1 align="center">Bootstrap Italia + Angular 9</h1>

219 lines 33.9 kB
import { __decorate } 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'; let StepperComponent = class StepperComponent { constructor(qcs) { this.qcs = qcs; this.fromValueChange = new EventEmitter(); this.submitedEvent = new EventEmitter(); this.latitude = 42.50; this.longitude = 12.50; } ngOnInit() { var _a, _b, _c, _d; this.widthExp = 100 / this.stepElements.length; // step a 1 this.currentStepIndex = 1; this.validSteps = []; this.touchedSteps = []; this.formRows = [].concat(...this.stepElements.map(e => e.fromRows)); const elements = [].concat(...this.formRows.map(e => e.items)); this.stepForm = this.qcs.toFormGroup(elements); this.mapId = this.getMapId(); const mapFormRows = this.stepElements.find(elem => elem.mapId).fromRows; this.mapFormFields = [].concat(...mapFormRows.map(e => 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(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(newVal => { this.longitude = newVal; }); this.formStateSubscription = this.stepForm.valueChanges .subscribe(newValue => { var _a; const mapFieldsKeys = this.mapFormFields.map(e => e.key); const mapBoxingValues = []; mapFieldsKeys.forEach(key => { const 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); }); } ngOnDestroy() { if (this.formStateSubscription) { this.formStateSubscription.unsubscribe(); } if (this.latSub) { this.latSub.unsubscribe(); } if (this.lngSub) { this.lngSub.unsubscribe(); } } get stepRows() { const rows = this.stepElements.find(e => e.index === this.currentStepIndex).fromRows; return rows; } getItems(formRow) { const items = formRow.items.filter(item => { var _a, _b, _c, _d, _e, _f, _g; let 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; } getPratentField(itemKey) { const elements = [].concat(...this.formRows.map(e => e.items)); return elements.find(e => e.parentFieldKey === itemKey); } isValidStep(stepIndex) { const step = this.validSteps.find(e => e === stepIndex); if (step) { return true; } return false; } setValidStep(stepIndex) { // ritorna true se tutti campi di quello step sono validi altrimenti false // prendi le chiavi dei campi di quel particolare step const rowsItems = this.stepElements .find(e => e.index === stepIndex).fromRows .map(e => e.items); const rowsElements = [].concat(...rowsItems); const fieldsKeys = rowsElements.map(e => e.key); const controls = this.stepForm.controls; const filtered = Object.keys(controls) .filter(key => fieldsKeys.includes(key) && controls[key].valid) .reduce((obj, key) => { obj[key] = controls[key]; return obj; }, {}); if (arraysEqual(fieldsKeys, Object.keys(filtered))) { const index = this.validSteps.indexOf(stepIndex, 0); if (index === -1) { this.validSteps.push(stepIndex); } } else { const index = this.validSteps.indexOf(stepIndex, 0); if (index > -1) { this.validSteps.splice(index, 1); } } } isTouchedStep(stepIndex) { const step = this.touchedSteps.find(e => e === stepIndex); if (step) { return true; } return false; } prevStep() { this.stepForm.updateValueAndValidity(); this.setValidStep(this.currentStepIndex); this.touchedSteps.push(this.currentStepIndex); this.currentStepIndex--; } nextStep() { this.stepForm.updateValueAndValidity(); this.setValidStep(this.currentStepIndex); this.touchedSteps.push(this.currentStepIndex); this.currentStepIndex++; } onSubmit() { this.submitedEvent.emit(this.stepForm.getRawValue()); } stepHaveMap(stepIndex) { const step = this.stepElements.find(e => 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; } getMapGeojson(geoJson) { this.mapGeoJson = geoJson; console.log(geoJson); } getMapId() { const step = this.stepElements.find(e => e.mapId); if (step && step.mapId) { return step.mapId; } return null; } }; StepperComponent.ctorParameters = () => [ { 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); 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 (let 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"]}