@firestitch/address
Version:
184 lines • 24.7 kB
JavaScript
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>"]}