UNPKG

@firestitch/address

Version:
184 lines 24.7 kB
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Optional, Output, ViewChild, inject } from '@angular/core'; import { ControlContainer, NG_VALUE_ACCESSOR, NgForm } from '@angular/forms'; import { MatDialog } from '@angular/material/dialog'; import { controlContainerFactory } from '@firestitch/core'; import { Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; import { cloneDeep, isObject } from 'lodash-es'; import { AddressFormat } from '../../enums/address-format.enum'; import { createEmptyAddress } from '../../helpers/create-empty-address'; import { FsAddressDialogComponent } from '../address-dialog/address-dialog.component'; import { FsAddressSearchComponent } from '../address-search/address-search.component'; import * as i0 from "@angular/core"; export class FsAddressPickerComponent { _dialog = inject(MatDialog); _cdRef = inject(ChangeDetectorRef); addressSearch; set setConfig(config) { config = cloneDeep(config); if (!config.format) { config.format = AddressFormat.TwoLine; } if (!isObject(config.map)) { config.map = { showMap: false }; } config.disabled = this.config.disabled; config.readonly = this.config.readonly; this.config = config; } set setFormat(value) { this.config.format = value; } set setDisabled(value) { this.config.disabled = value; } set setReadonly(value) { this.config.readonly = value; } address; addressChange = new EventEmitter(); showName = true; search; view = 'search'; config = {}; onChange; _destroy$ = new Subject(); writeValue(obj) { this.address = obj; } registerOnChange(fn) { this.onChange = fn; } registerOnTouched() { // } setDisabledState(disabled) { this.config.disabled = disabled; this._cdRef.markForCheck(); } ngOnChanges(changes) { if (changes.address && changes.address.currentValue !== changes.address.previousValue) { if (!this.address) { this.address = createEmptyAddress(); } } } addressManual() { this.open({ initialChange: false, value: {}, }); } addressChanged(address) { this.address = address; this.addressChange.emit(address); if (this.onChange) { this.onChange(address); } } addressEdit() { this.open({ value: this.address, initialChange: false }); } addressSelected(address) { if (this.config.confirmation || address.manual) { this.open({ value: address, initialChange: true }) .afterClosed() .pipe(takeUntil(this._destroy$)) .subscribe((result) => { if (!result) { this.addressSearch.clear(); } }); } else { this.addressChanged(address); } } open(event) { const dialogRef = this._dialog .open(FsAddressDialogComponent, { width: '700px', data: { address: event.value || this.address, config: this.config, initial: event.initialChange, }, }); dialogRef.afterClosed() .pipe(filter((result) => !!result), takeUntil(this._destroy$)) .subscribe((result) => { this.address = result; // hard dirty fix for DT-T867. // In future it must be ControlValue Accessor... if (result) { this.search.autocomplete.value = this.address; } this.addressChanged(this.address); this._cdRef.markForCheck(); }); return dialogRef; } searchEdited(event) { this.open(event); } clear() { this.address = {}; this.addressSearch.clear(); } ngOnDestroy() { this._destroy$.next(null); this._destroy$.complete(); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: FsAddressPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: FsAddressPickerComponent, isStandalone: true, selector: "fs-address-picker", inputs: { setConfig: ["config", "setConfig"], setFormat: ["format", "setFormat"], setDisabled: ["disabled", "setDisabled"], setReadonly: ["readonly", "setReadonly"], address: "address", showName: "showName" }, outputs: { addressChange: "addressChange" }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: FsAddressPickerComponent, multi: true, }], viewQueries: [{ propertyName: "addressSearch", first: true, predicate: FsAddressSearchComponent, descendants: true, static: true }, { propertyName: "search", first: true, predicate: FsAddressSearchComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"address-picker-container\">\n <div class=\"search\">\n <fs-address-search\n [address]=\"address\"\n [config]=\"config\"\n [format]=\"config.format\"\n [disabled]=\"config.disabled\"\n [readonly]=\"config.readonly\"\n [showName]=\"showName\"\n (edit)=\"addressEdit()\"\n (cleared)=\"addressChanged(null)\"\n (addressChange)=\"addressChanged($event)\"\n (addressManual)=\"addressManual()\"\n (selected)=\"addressSelected($event)\">\n </fs-address-search>\n </div>\n</div>", styles: [".address-picker-container{position:relative}.input-controls{position:absolute;top:0;right:0}:host ::ng-deep .search .mat-form-field-flex{flex-direction:row}:host ::ng-deep .search .mat-form-field-suffix{align-self:center}:host ::ng-deep .hide-underline .mat-form-field-underline{display:none}:host ::ng-deep .hide-underline .mat-form-field-subscript-wrapper{margin-top:0}.map-buttons{margin-top:5px}.map-buttons button{width:100%}\n"], dependencies: [{ kind: "component", type: FsAddressSearchComponent, selector: "fs-address-search", inputs: ["config", "showName", "address", "format", "disabled", "readonly", "required"], outputs: ["cleared", "addressChange", "edit", "selected", "addressManual"] }], viewProviders: [ { provide: ControlContainer, useFactory: controlContainerFactory, deps: [[new Optional(), NgForm]], }, ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: FsAddressPickerComponent, decorators: [{ type: Component, args: [{ selector: 'fs-address-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: FsAddressPickerComponent, multi: true, }], viewProviders: [ { provide: ControlContainer, useFactory: controlContainerFactory, deps: [[new Optional(), NgForm]], }, ], standalone: true, imports: [FsAddressSearchComponent], template: "<div class=\"address-picker-container\">\n <div class=\"search\">\n <fs-address-search\n [address]=\"address\"\n [config]=\"config\"\n [format]=\"config.format\"\n [disabled]=\"config.disabled\"\n [readonly]=\"config.readonly\"\n [showName]=\"showName\"\n (edit)=\"addressEdit()\"\n (cleared)=\"addressChanged(null)\"\n (addressChange)=\"addressChanged($event)\"\n (addressManual)=\"addressManual()\"\n (selected)=\"addressSelected($event)\">\n </fs-address-search>\n </div>\n</div>", styles: [".address-picker-container{position:relative}.input-controls{position:absolute;top:0;right:0}:host ::ng-deep .search .mat-form-field-flex{flex-direction:row}:host ::ng-deep .search .mat-form-field-suffix{align-self:center}:host ::ng-deep .hide-underline .mat-form-field-underline{display:none}:host ::ng-deep .hide-underline .mat-form-field-subscript-wrapper{margin-top:0}.map-buttons{margin-top:5px}.map-buttons button{width:100%}\n"] }] }], propDecorators: { addressSearch: [{ type: ViewChild, args: [FsAddressSearchComponent, { static: true }] }], setConfig: [{ type: Input, args: ['config'] }], setFormat: [{ type: Input, args: ['format'] }], setDisabled: [{ type: Input, args: ['disabled'] }], setReadonly: [{ type: Input, args: ['readonly'] }], address: [{ type: Input }], addressChange: [{ type: Output }], showName: [{ type: Input }], search: [{ type: ViewChild, args: [FsAddressSearchComponent] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"address-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/address-picker/address-picker.component.ts","../../../../../src/app/components/address-picker/address-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnDestroy, Optional, Output, SimpleChanges, ViewChild, inject } from '@angular/core';\nimport { ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR, NgForm } from '@angular/forms';\n\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\n\nimport { controlContainerFactory } from '@firestitch/core';\n\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { cloneDeep, isObject } from 'lodash-es';\n\nimport { AddressFormat } from '../../enums/address-format.enum';\nimport { createEmptyAddress } from '../../helpers/create-empty-address';\nimport { FsAddressPickerConfig } from '../../interfaces/address-config.interface';\nimport { FsAddress } from '../../interfaces/address.interface';\nimport { FsAddressDialogComponent } from '../address-dialog/address-dialog.component';\nimport { FsAddressSearchComponent } from '../address-search/address-search.component';\nimport { AddressSearchEditEvent } from '../address-search/address-search.interface';\n\n\n@Component({\n    selector: 'fs-address-picker',\n    templateUrl: './address-picker.component.html',\n    styleUrls: ['./address-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: FsAddressPickerComponent,\n            multi: true,\n        }],\n    viewProviders: [\n        {\n            provide: ControlContainer,\n            useFactory: controlContainerFactory,\n            deps: [[new Optional(), NgForm]],\n        },\n    ],\n    standalone: true,\n    imports: [FsAddressSearchComponent],\n})\nexport class FsAddressPickerComponent implements OnChanges, OnDestroy, ControlValueAccessor {\n  private _dialog = inject(MatDialog);\n  private _cdRef = inject(ChangeDetectorRef);\n\n\n  @ViewChild(FsAddressSearchComponent, { static: true })\n  public addressSearch: FsAddressSearchComponent;\n\n  @Input('config') public set setConfig(config: FsAddressPickerConfig) {\n    config = cloneDeep(config);\n\n    if (!config.format) {\n      config.format = AddressFormat.TwoLine;\n    }\n\n    if (!isObject(config.map)) {\n      config.map = { showMap: false };\n    }\n\n    config.disabled = this.config.disabled;\n    config.readonly = this.config.readonly;\n\n    this.config = config;\n  }\n\n  @Input('format') public set setFormat(value) {\n    this.config.format = value;\n  }\n\n  @Input('disabled') public set setDisabled(value) {\n    this.config.disabled = value;\n  }\n\n  @Input('readonly') public set setReadonly(value) {\n    this.config.readonly = value;\n  }\n\n  @Input() public address: FsAddress;\n\n  @Output() public addressChange = new EventEmitter();\n\n  @Input() public showName: boolean = true;\n\n  @ViewChild(FsAddressSearchComponent)\n  public search: FsAddressSearchComponent;\n\n  public view = 'search';\n  public config: FsAddressPickerConfig = {};\n  public onChange: (value) => void;\n\n  private _destroy$ = new Subject();\n\n  public writeValue(obj: any): void {\n    this.address = obj;\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(): void {\n    //\n  }\n\n  public setDisabledState?(disabled: boolean): void {\n    this.config.disabled = disabled;\n    this._cdRef.markForCheck();\n  }\n\n  public ngOnChanges(changes: SimpleChanges) {\n    if (\n      changes.address &&\n      changes.address.currentValue !== changes.address.previousValue\n    ) {\n      if (!this.address) {\n        this.address = createEmptyAddress();\n      }\n    }\n  }\n\n  public addressManual() {\n    this.open({\n      initialChange: false,\n      value: {},\n    });\n  }\n\n  public addressChanged(address) {\n    this.address = address;\n    this.addressChange.emit(address);\n    if(this.onChange) {\n      this.onChange(address);\n    }\n  }\n\n  public addressEdit() {\n    this.open({ value: this.address, initialChange: false });\n  }\n\n  public addressSelected(address) {\n    if (this.config.confirmation || address.manual) {\n      this.open({ value: address, initialChange: true })\n        .afterClosed()\n        .pipe(\n          takeUntil(this._destroy$),\n        )\n        .subscribe((result) => {\n          if (!result) {\n            this.addressSearch.clear();\n          }\n        });\n    } else {\n      this.addressChanged(address);\n    }\n  }\n\n  public open(event: AddressSearchEditEvent): MatDialogRef<FsAddressDialogComponent> {\n    const dialogRef = this._dialog\n      .open(FsAddressDialogComponent, {\n        width: '700px',\n        data: {\n          address: event.value || this.address,\n          config: this.config,\n          initial: event.initialChange,\n        },\n      });\n\n    dialogRef.afterClosed()\n      .pipe(\n        filter((result) => !!result),\n        takeUntil(this._destroy$),\n      )\n      .subscribe((result) => {\n        this.address = result;\n\n        // hard dirty fix for DT-T867.\n        // In future it must be ControlValue Accessor...\n        if (result) {\n          this.search.autocomplete.value = this.address;\n        }\n\n        this.addressChanged(this.address);\n        this._cdRef.markForCheck();\n      });\n\n    return dialogRef;\n  }\n\n  public searchEdited(event: AddressSearchEditEvent) {\n    this.open(event);\n  }\n\n  public clear() {\n    this.address = {};\n    this.addressSearch.clear();\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n  }\n}\n","<div class=\"address-picker-container\">\n  <div class=\"search\">\n    <fs-address-search\n      [address]=\"address\"\n      [config]=\"config\"\n      [format]=\"config.format\"\n      [disabled]=\"config.disabled\"\n      [readonly]=\"config.readonly\"\n      [showName]=\"showName\"\n      (edit)=\"addressEdit()\"\n      (cleared)=\"addressChanged(null)\"\n      (addressChange)=\"addressChanged($event)\"\n      (addressManual)=\"addressManual()\"\n      (selected)=\"addressSelected($event)\">\n    </fs-address-search>\n  </div>\n</div>"]}