@schoolbelle/common
Version:
Demo library to showcase Angular packaging format
282 lines (274 loc) • 25 kB
JavaScript
import { Injectable, Component, forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef, Renderer2, NgModule } from '@angular/core';
import { HttpClient, HttpClientModule, HttpClientJsonpModule } from '@angular/common/http';
import { DomSanitizer } from '@angular/platform-browser';
import { FormGroup, FormControl, NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule, COMPOSITION_BUFFER_MODE } from '@angular/forms';
import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
import { CommonModule } from '@angular/common';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class AddressService {
/**
* @param {?} http
* @param {?} sanitizer
*/
constructor(http, sanitizer) {
this.http = http;
this.sanitizer = sanitizer;
}
/**
* @param {?} q
* @return {?}
*/
search(q) {
// const host = 'schoolbelle.local';
// const url = `https://api.poesis.kr/post/search.php?q=${q}&v=3.0.0-schoolbelle&ref=${host}`;
const /** @type {?} */ apiKey = '906b6df16b1f8b0d02e4bbb4ec75ca02';
const /** @type {?} */ url = `${window.location.protocol}//apis.daum.net/local/v1/search/keyword.json?callback=JSON_CALLBACK&apikey=${apiKey}&query=${q}`;
return this.http
.jsonp(url, 'callback')
.toPromise()
.then((data) => {
return (/** @type {?} */ (data.channel.item)).map(li => {
return /** @type {?} */ ({
address: /** @type {?} */ ((li.address +
' ' +
li.title +
(li.zipcode ? ' (' + li.zipcode + ')' : ''))),
lat: /** @type {?} */ (li.latitude),
lng: /** @type {?} */ (li.longitude)
});
});
});
}
}
AddressService.decorators = [
{ type: Injectable },
];
/** @nocollapse */
AddressService.ctorParameters = () => [
{ type: HttpClient, },
{ type: DomSanitizer, },
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
const /** @type {?} */ AddressInputComponentValueAccessor = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => AddressInputComponent),
multi: true
};
class AddressInputComponent {
/**
* @param {?} addressService
* @param {?} cdRef
* @param {?} elementRef
* @param {?} renderer
*/
constructor(addressService, cdRef, elementRef, renderer) {
this.addressService = addressService;
this.cdRef = cdRef;
this.elementRef = elementRef;
this.renderer = renderer;
this.focused = true;
this.disabled = false;
this.onChange = _ => { };
this.onTouched = () => { };
this.addressSearchList = [];
this.loading = false;
this.subscriptions = [];
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
if (value && typeof value === 'object') {
this.value = value;
setTimeout(() => this.renderer.setProperty(this.input, 'value', value.address));
}
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouched = fn;
}
/**
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
this.disabled = isDisabled;
if (this.disabled)
this.address.disable();
else
this.address.enable();
}
/**
* @return {?}
*/
createFormControls() {
this.address = new FormControl('');
}
/**
* @return {?}
*/
createForm() {
this.form = new FormGroup({
address: this.address
});
}
/**
* @return {?}
*/
ngOnInit() {
this.input = this.elementRef.nativeElement.querySelector('input');
this.createFormControls();
this.createForm();
this.subscriptions.push(this.address.valueChanges.subscribe(v => this.onChange('')));
this.subscriptions.push(this.address.valueChanges.subscribe(v => {
if (v && v.length >= 2) {
this.loading = true;
this.cdRef.detectChanges();
}
else {
this.loading = false;
this.cdRef.detectChanges();
}
}));
this.subscriptions.push(this.address.valueChanges
.pipe(debounceTime(1000), distinctUntilChanged())
.subscribe(v => {
if (v && v.length >= 2) {
this.addressService
.search(v)
.then((list) => {
this.addressSearchList = list;
this.loading = false;
this.cdRef.detectChanges();
})
.catch(() => {
this.loading = false;
this.cdRef.detectChanges();
});
}
}));
}
/**
* @return {?}
*/
ngOnDestroy() {
this.subscriptions.forEach(sub => sub.unsubscribe());
}
/**
* @param {?} $event
* @return {?}
*/
focus($event) {
this.renderer.addClass(this.elementRef.nativeElement, 'focus');
setTimeout(() => {
this.focused = true;
this.cdRef.detectChanges();
}, 100);
}
/**
* @param {?} $event
* @return {?}
*/
blur($event) {
this.renderer.removeClass(this.elementRef.nativeElement, 'focus');
setTimeout(() => {
this.focused = false;
this.cdRef.detectChanges();
}, 100);
}
/**
* @param {?} li
* @return {?}
*/
select(li) {
this.value = li;
this.renderer.setProperty(this.input, 'value', li.address);
this.onChange(this.value);
}
}
AddressInputComponent.decorators = [
{ type: Component, args: [{
selector: 'address-input',
template: `<form class="d-flex align-items-center"
[formGroup]="form">
<input type="text"
formControlName="address"
placeholder="건물명, 지번 검색"
class="w-100"
(focus)="focus($event)"
(blur)="blur($event)"
/>
<span *ngIf="loading" class="w-0 px-3">
<i class="fa fa-spinner fa-pulse fa-fw"></i>
<span class="sr-only">Loading...</span>
</span>
<div class="dropdown-menu show" [ngClass]="{'show':focused && addressSearchList.length !== 0}">
<a *ngFor="let li of addressSearchList" class="dropdown-item" (click)="select(li)" >
{{li.address}}
</a>
</div>
</form>
<!-- { "postcode5": "30100", "postcode6": "339011", "ko_common": "세종특별자치시", "ko_doro": "달빛로 174", "ko_jibeon": "아름동 1275", "en_common": "Sejong", "en_doro": "174, Dalbit-ro", "en_jibeon": "1275, Areum-dong", "building_id": "3611011300102730002000001", "building_name": "", "building_nums": "", "other_addresses": "아름초등학교", "road_id": "361103258103", "internal_id": "4739529" } -->
`,
styles: [`input{border:none;padding:.375em .75em;display:block;width:100%;line-height:1.5;color:#495057;text-align:inherit;background-color:transparent}input:focus{outline:0;box-shadow:none}input:disabled,textarea:disabled{color:#545454;cursor:default;background-color:#e9ecef;opacity:1}`],
providers: [AddressInputComponentValueAccessor],
changeDetection: ChangeDetectionStrategy.OnPush
},] },
];
/** @nocollapse */
AddressInputComponent.ctorParameters = () => [
{ type: AddressService, },
{ type: ChangeDetectorRef, },
{ type: ElementRef, },
{ type: Renderer2, },
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class AddressInputModule {
}
AddressInputModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule,
HttpClientModule,
HttpClientJsonpModule,
FormsModule,
ReactiveFormsModule
],
providers: [
AddressService,
{ provide: COMPOSITION_BUFFER_MODE, useValue: false }
],
declarations: [AddressInputComponent],
exports: [AddressInputComponent]
},] },
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
export { AddressInputModule, AddressService, AddressInputComponent as ɵb, AddressInputComponentValueAccessor as ɵa };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"schoolbelle-common-components-address-input.js.map","sources":["ng://@schoolbelle/common/components/address-input/src/address.service.ts","ng://@schoolbelle/common/components/address-input/src/address-input.component.ts","ng://@schoolbelle/common/components/address-input/src/address-input.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nexport interface AddressInfo {\n  address: string;\n  lat: number;\n  lng: number;\n}\n@Injectable()\nexport class AddressService {\n  constructor(public http: HttpClient, public sanitizer: DomSanitizer) {}\n  public search(q: string): Promise<AddressInfo[]> {\n    // const host = 'schoolbelle.local';\n    // const url =  `https://api.poesis.kr/post/search.php?q=${q}&v=3.0.0-schoolbelle&ref=${host}`;\n\n    const apiKey = '906b6df16b1f8b0d02e4bbb4ec75ca02';\n    const url = `${\n      window.location.protocol\n    }//apis.daum.net/local/v1/search/keyword.json?callback=JSON_CALLBACK&apikey=${apiKey}&query=${q}`;\n\n    return this.http\n      .jsonp(url, 'callback')\n      .toPromise()\n      .then((data: any) => {\n        return (<Array<any>>data.channel.item).map(li => {\n          return {\n            address: (li.address +\n              ' ' +\n              li.title +\n              (li.zipcode ? ' (' + li.zipcode + ')' : '')) as string,\n            lat: li.latitude as number,\n            lng: li.longitude as number\n          } as AddressInfo;\n        });\n      });\n  }\n}\n","import {\n  Component,\n  OnInit,\n  forwardRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef\n} from '@angular/core';\nimport { AddressService, AddressInfo } from './address.service';\nimport { FormGroup, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs/Subscription';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { ElementRef, Renderer2 } from '@angular/core';\n\nexport const AddressInputComponentValueAccessor: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => AddressInputComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'address-input',\n  template: `<form class=\"d-flex align-items-center\" \n[formGroup]=\"form\">\n  <input type=\"text\"         \n  formControlName=\"address\"\n  placeholder=\"ê±´ë¬¼ëª, ì§ë² ê²ì\"\n  class=\"w-100\"\n  (focus)=\"focus($event)\"        \n  (blur)=\"blur($event)\"        \n  />\n  <span *ngIf=\"loading\" class=\"w-0 px-3\">\n      <i class=\"fa fa-spinner fa-pulse fa-fw\"></i>\n      <span class=\"sr-only\">Loading...</span>\n  </span>\n  <div class=\"dropdown-menu show\" [ngClass]=\"{'show':focused && addressSearchList.length !== 0}\">\n    <a *ngFor=\"let li of addressSearchList\" class=\"dropdown-item\" (click)=\"select(li)\" >\n      {{li.address}}\n    </a>\n  </div>\n</form>\n\n<!-- { \"postcode5\": \"30100\", \"postcode6\": \"339011\", \"ko_common\": \"ì¸ì¢í¹ë³ìì¹ì\", \"ko_doro\": \"ë¬ë¹ë¡ 174\", \"ko_jibeon\": \"ìë¦ë 1275\", \"en_common\": \"Sejong\", \"en_doro\": \"174, Dalbit-ro\", \"en_jibeon\": \"1275, Areum-dong\", \"building_id\": \"3611011300102730002000001\", \"building_name\": \"\", \"building_nums\": \"\", \"other_addresses\": \"ìë¦ì´ë±íêµ\", \"road_id\": \"361103258103\", \"internal_id\": \"4739529\" }       -->\n`,\n  styles: [`input{border:none;padding:.375em .75em;display:block;width:100%;line-height:1.5;color:#495057;text-align:inherit;background-color:transparent}input:focus{outline:0;box-shadow:none}input:disabled,textarea:disabled{color:#545454;cursor:default;background-color:#e9ecef;opacity:1}`],\n  providers: [AddressInputComponentValueAccessor],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AddressInputComponent implements OnInit {\n  private input: HTMLInputElement;\n  public focused: boolean = true;\n  disabled: boolean = false;\n  value: AddressInfo;\n  writeValue(value: AddressInfo) {\n    if (value && typeof value === 'object') {\n      this.value = value;\n      setTimeout(() =>\n        this.renderer.setProperty(this.input, 'value', value.address)\n      );\n    }\n  }\n  onChange = _ => {};\n  onTouched = () => {};\n  registerOnChange(fn: (_: any) => void): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    if (this.disabled) this.address.disable();\n    else this.address.enable();\n  }\n\n  constructor(\n    public addressService: AddressService,\n    public cdRef: ChangeDetectorRef,\n    public elementRef: ElementRef,\n    public renderer: Renderer2\n  ) {}\n  form: FormGroup;\n  address: FormControl;\n  addressSearchList: any[] = [];\n  createFormControls() {\n    this.address = new FormControl('');\n  }\n  createForm() {\n    this.form = new FormGroup({\n      address: this.address\n    });\n  }\n\n  loading: boolean = false;\n  subscriptions: Subscription[] = [];\n  ngOnInit() {\n    this.input = this.elementRef.nativeElement.querySelector('input');\n    this.createFormControls();\n    this.createForm();\n    this.subscriptions.push(\n      this.address.valueChanges.subscribe(v => this.onChange(''))\n    );\n    this.subscriptions.push(\n      this.address.valueChanges.subscribe(v => {\n        if (v && v.length >= 2) {\n          this.loading = true;\n          this.cdRef.detectChanges();\n        } else {\n          this.loading = false;\n          this.cdRef.detectChanges();\n        }\n      })\n    );\n    this.subscriptions.push(\n      this.address.valueChanges\n        .pipe(debounceTime(1000), distinctUntilChanged())\n        .subscribe(v => {\n          if (v && v.length >= 2) {\n            this.addressService\n              .search(v)\n              .then((list: any[]) => {\n                this.addressSearchList = list;\n                this.loading = false;\n                this.cdRef.detectChanges();\n              })\n              .catch(() => {\n                this.loading = false;\n                this.cdRef.detectChanges();\n              });\n          }\n        })\n    );\n  }\n  ngOnDestroy() {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n  focus($event) {\n    this.renderer.addClass(this.elementRef.nativeElement, 'focus');\n    setTimeout(() => {\n      this.focused = true;\n      this.cdRef.detectChanges();\n    }, 100);\n  }\n  blur($event) {\n    this.renderer.removeClass(this.elementRef.nativeElement, 'focus');\n    setTimeout(() => {\n      this.focused = false;\n      this.cdRef.detectChanges();\n    }, 100);\n  }\n\n  select(li: AddressInfo) {\n    this.value = li;\n    this.renderer.setProperty(this.input, 'value', li.address);\n    this.onChange(this.value);\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { HttpClientModule, HttpClientJsonpModule } from '@angular/common/http';\nimport {\n  FormsModule,\n  ReactiveFormsModule,\n  COMPOSITION_BUFFER_MODE\n} from '@angular/forms';\n\nimport { AddressInputComponent } from './address-input.component';\nimport { AddressService } from './address.service';\n\n@NgModule({\n  imports: [\n    CommonModule,\n    HttpClientModule,\n    HttpClientJsonpModule,\n    FormsModule,\n    ReactiveFormsModule\n  ],\n  providers: [\n    AddressService,\n    { provide: COMPOSITION_BUFFER_MODE, useValue: false }\n  ],\n  declarations: [AddressInputComponent],\n  exports: [AddressInputComponent]\n})\nexport class AddressInputModule {}\n"],"names":[],"mappings":"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"}