UNPKG

@schoolbelle/common

Version:

Demo library to showcase Angular packaging format

282 lines (274 loc) 25 kB
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":";;;;;;;;;;;AAAA;;;;;IAYE,YAAmB,IAAgB,EAAS,SAAuB;QAAhD,SAAI,GAAJ,IAAI,CAAY;QAAS,cAAS,GAAT,SAAS,CAAc;KAAI;;;;;IAChE,MAAM,CAAC,CAAS;;;QAIrB,uBAAM,MAAM,GAAG,kCAAkC,CAAC;QAClD,uBAAM,GAAG,GAAG,GACV,MAAM,CAAC,QAAQ,CAAC,QAClB,8EAA8E,MAAM,UAAU,CAAC,EAAE,CAAC;QAElG,OAAO,IAAI,CAAC,IAAI;aACb,KAAK,CAAC,GAAG,EAAE,UAAU,CAAC;aACtB,SAAS,EAAE;aACX,IAAI,CAAC,CAAC,IAAS;YACd,OAAO,mBAAa,IAAI,CAAC,OAAO,CAAC,IAAI,GAAE,GAAG,CAAC,EAAE;gBAC3C,yBAAO;oBACL,OAAO,qBAAG,EAAE,CAAC,OAAO;wBAClB,GAAG;wBACH,EAAE,CAAC,KAAK;yBACP,EAAE,CAAC,OAAO,GAAG,IAAI,GAAG,EAAE,CAAC,OAAO,GAAG,GAAG,GAAG,EAAE,CAAC,EAAW;oBACxD,GAAG,oBAAE,EAAE,CAAC,QAAkB,CAAA;oBAC1B,GAAG,oBAAE,EAAE,CAAC,SAAmB,CAAA;iBACb,EAAC;aAClB,CAAC,CAAC;SACJ,CAAC,CAAC;;;;YA1BR,UAAU;;;;YARF,UAAU;YACV,YAAY;;;;;;;ACHrB,uBAaa,kCAAkC,GAAQ;IACrD,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,MAAM,qBAAqB,CAAC;IACpD,KAAK,EAAE,IAAI;CACZ,CAAC;AA8BF;;;;;;;IA2BE,YACS,gBACA,OACA,YACA;QAHA,mBAAc,GAAd,cAAc;QACd,UAAK,GAAL,KAAK;QACL,eAAU,GAAV,UAAU;QACV,aAAQ,GAAR,QAAQ;uBA7BS,IAAI;wBACV,KAAK;wBAUd,CAAC,OAAM;yBACN,SAAQ;iCAqBO,EAAE;uBAUV,KAAK;6BACQ,EAAE;KAd9B;;;;;IA3BJ,UAAU,CAAC,KAAkB;QAC3B,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YACtC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,UAAU,CAAC,MACT,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAC9D,CAAC;SACH;KACF;;;;;IAGD,gBAAgB,CAAC,EAAoB;QACnC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;KACpB;;;;;IACD,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;KACrB;;;;;IACD,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,IAAI,CAAC,QAAQ;YAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;;YACrC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;KAC5B;;;;IAWD,kBAAkB;QAChB,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;KACpC;;;;IACD,UAAU;QACR,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC;YACxB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,CAAC,CAAC;KACJ;;;;IAID,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAClE,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAC5D,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;YACnC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE;gBACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;gBACpB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;aAC5B;iBAAM;gBACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;aAC5B;SACF,CAAC,CACH,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,OAAO,CAAC,YAAY;aACtB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,oBAAoB,EAAE,CAAC;aAChD,SAAS,CAAC,CAAC;YACV,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE;gBACtB,IAAI,CAAC,cAAc;qBAChB,MAAM,CAAC,CAAC,CAAC;qBACT,IAAI,CAAC,CAAC,IAAW;oBAChB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;oBAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;iBAC5B,CAAC;qBACD,KAAK,CAAC;oBACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;oBACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;iBAC5B,CAAC,CAAC;aACN;SACF,CAAC,CACL,CAAC;KACH;;;;IACD,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;KACtD;;;;;IACD,KAAK,CAAC,MAAM;QACV,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAC/D,UAAU,CAAC;YACT,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;SAC5B,EAAE,GAAG,CAAC,CAAC;KACT;;;;;IACD,IAAI,CAAC,MAAM;QACT,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAClE,UAAU,CAAC;YACT,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;SAC5B,EAAE,GAAG,CAAC,CAAC;KACT;;;;;IAED,MAAM,CAAC,EAAe;QACpB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAC3B;;;YAvIF,SAAS,SAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;CAqBX;gBACC,MAAM,EAAE,CAAC,uRAAuR,CAAC;gBACjS,SAAS,EAAE,CAAC,kCAAkC,CAAC;gBAC/C,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;;;;YAvCQ,cAAc;YAFrB,iBAAiB;YAMV,UAAU;YAAE,SAAS;;;;;;;ACX9B;;;YAYC,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;oBACZ,gBAAgB;oBAChB,qBAAqB;oBACrB,WAAW;oBACX,mBAAmB;iBACpB;gBACD,SAAS,EAAE;oBACT,cAAc;oBACd,EAAE,OAAO,EAAE,uBAAuB,EAAE,QAAQ,EAAE,KAAK,EAAE;iBACtD;gBACD,YAAY,EAAE,CAAC,qBAAqB,CAAC;gBACrC,OAAO,EAAE,CAAC,qBAAqB,CAAC;aACjC;;;;;;;;;;;;;;;"}