@sapphire-ion/framework 1.0.35 → 1.0.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,6 +3,17 @@ import { HttpService } from "../../../services/web/http.service";
3
3
  import { HttpServiceAtivo } from "../../../services/web/http.ativo.service";
4
4
  import { ViewFiltros } from "../../../classes/filters/view-filtros";
5
5
  import { INT_MAX } from "../../../services/utils.service";
6
+ export var SelectInterfaces;
7
+ (function (SelectInterfaces) {
8
+ /** Interface padrão do select
9
+ * Popover quando web, Modal quando mobile
10
+ */
11
+ SelectInterfaces[SelectInterfaces["Dynamic"] = 0] = "Dynamic";
12
+ SelectInterfaces[SelectInterfaces["Popover"] = 0] = "Popover";
13
+ SelectInterfaces[SelectInterfaces["Modal"] = 1] = "Modal";
14
+ SelectInterfaces[SelectInterfaces["Alert"] = 2] = "Alert";
15
+ SelectInterfaces[SelectInterfaces["ActionSheet"] = 3] = "ActionSheet";
16
+ })(SelectInterfaces || (SelectInterfaces = {}));
6
17
  export class InputSelectConfiguration {
7
18
  static Create(options) {
8
19
  const config = new InputSelectConfiguration(options.bindValue, options.bindLabel, options.clearable, options.searcheable, options.loadFrom, options.multiple, options.vFiltros || null, options.disableConditional || null);
@@ -15,6 +26,9 @@ export class InputSelectConfiguration {
15
26
  if (options.useInfiniteScroll != undefined) {
16
27
  config.useInfiniteScroll = options.useInfiniteScroll;
17
28
  }
29
+ if (options.interface) {
30
+ config.interface = options.interface;
31
+ }
18
32
  return config;
19
33
  }
20
34
  ;
@@ -54,6 +68,8 @@ export class InputSelectConfiguration {
54
68
  };
55
69
  this.vFiltros = null;
56
70
  this.useInfiniteScroll = false;
71
+ /** Interface do select */
72
+ this.interface = SelectInterfaces.Dynamic;
57
73
  this.clearable = clearable;
58
74
  this.searcheable = searcheable;
59
75
  this.multiple = multiple;
@@ -202,4 +218,4 @@ export function BindLabelFactory(configuration) {
202
218
  }
203
219
  return bindLabel;
204
220
  }
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.select.configuration.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-select/input.select.configuration.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable, firstValueFrom } from \"rxjs\";\r\n\r\nimport { HttpService, ViewRetorno } from \"../../../services/web/http.service\";\r\nimport { HttpServiceAtivo } from \"../../../services/web/http.ativo.service\";\r\nimport { ViewFiltros } from \"../../../classes/filters/view-filtros\";\r\nimport { INT_MAX } from \"../../../services/utils.service\";\r\nimport { Comparison } from \"../../../classes/comparison/comparison\";\r\nimport { InputSelectComponent } from \"./input-select.component\";\r\nimport { Placement } from \"@floating-ui/dom\";\r\n\r\nexport type DefaultModelOptions = { value: string, label: string };\r\n\r\nexport class InputSelectConfiguration{\r\n  static Create(options: {\r\n    bindLabel: string | ((obj: any) => string),\r\n    bindValue: string | ((obj: any) => any),\r\n    clearable?: boolean,\r\n    searcheable?: boolean,\r\n    loadFrom?: HttpService | Observable<ViewRetorno> | any[],\r\n    multiple?: boolean,\r\n    vFiltros?: Partial<{ \r\n      search: string,\r\n      orderByProperty: string,\r\n      ascending: boolean,\r\n      filter: Comparison[]\r\n    }>,\r\n    disableConditional?: ((obj: any) => boolean)\r\n    useInfiniteScroll?: boolean,\r\n    placeholder?: string,\r\n    noItensFoundText?: string\r\n  }\r\n  ){\r\n    const config = new InputSelectConfiguration(\r\n      options.bindValue,\r\n      options.bindLabel,\r\n      options.clearable,\r\n      options.searcheable,\r\n      options.loadFrom,\r\n      options.multiple,\r\n      options.vFiltros || null,\r\n      options.disableConditional || null\r\n    );\r\n    if(options.placeholder){\r\n      config.placeholder = options.placeholder;\r\n    }\r\n    if(options.noItensFoundText){\r\n      config.noItensFoundText = options.noItensFoundText;\r\n    }\r\n    if(options.useInfiniteScroll != undefined){\r\n      config.useInfiniteScroll = options.useInfiniteScroll;\r\n    }\r\n    return config;\r\n  };\r\n\r\n\r\n  placeholder     : string = \"Selecione um item...\"\r\n  noItensFoundText: string = \"Sem items encontrados...\"\r\n\r\n  loader: InputSelectDataLoader;\r\n  loadFromArray   : any[];\r\n  loadFromService : HttpService | HttpServiceAtivo\r\n  loadFromFunction: Observable<any>\r\n\r\n  popoverConfiguration: {\r\n    flip: boolean,\r\n    placement: Placement,\r\n  } = {\r\n    flip: true,\r\n    placement: \"bottom\"\r\n  }\r\n\r\n  public vFiltros: ViewFiltros | null = null;\r\n  public useInfiniteScroll: boolean = false;\r\n\r\n  constructor(\r\n    /** Valor que será setado no formControl */\r\n    public bindValue: string | ((obj: any) => any)     = \"id\"  ,\r\n    /** Valor que será exibido */\r\n    public bindLabel: string | ((obj: any) => string)  = \"nome\", \r\n    \r\n    /** Indica se o select pode ser nulo e limpavel */\r\n    public clearable  : boolean = true, \r\n    /** Indica se o select pode ser pesquisado */\r\n    public searcheable: boolean = true, \r\n    \r\n    /** \r\n     * Se LoadFrom instanceof HttpService      -> Os dados serão carregados do List()\r\n     * Se LoadFrom instanceof Observable       -> Os dados serão carregados da função indicada\r\n     * Se LoadFrom instanceof Array            -> Os dados serão o array\r\n     */\r\n    public loadFrom?:  HttpService | Observable<ViewRetorno> | any[], \r\n    /** Se = true Os valores no form control seráo um array dos items selecionados */\r\n    public multiple : boolean = false,\r\n    /** Aplica os filtros na pesquisa */\r\n    vFiltros : Partial<{ \r\n      /** Aplica uma pesquisa em texto  */\r\n      search: string\r\n      /** Propriedade de ordenação */\r\n      orderByProperty: string\r\n      /** Orientação de ordenação */\r\n      ascending: boolean,\r\n      /** Filtro  */\r\n      filter: Comparison[]\r\n    }> | null = null,\r\n    /** Desativa os items que estão de acordo com a função */\r\n    public disableConditional: ((obj: any) => boolean) | null = null\r\n  ){\r\n    this.clearable   = clearable;\r\n    this.searcheable = searcheable;\r\n    this.multiple    = multiple;\r\n\r\n    if(vFiltros != null){\r\n      const v = vFiltros;\r\n      if(v.ascending == null || v.ascending == undefined){ \r\n        v.ascending = true; \r\n      }\r\n      this.vFiltros = new ViewFiltros(INT_MAX, v.search, 1, v.orderByProperty, v.ascending);\r\n      this.vFiltros.filter = v.filter;\r\n    }\r\n\r\n    if(loadFrom){\r\n      if(Array.isArray(loadFrom)){ \r\n        this.loadFromArray    = loadFrom; \r\n      } else\r\n      if(loadFrom instanceof HttpService || loadFrom instanceof HttpServiceAtivo){ \r\n        this.loadFromService  = loadFrom;\r\n      } else {  \r\n        this.loadFromFunction = loadFrom;\r\n      }\r\n    }\r\n\r\n    this.loader = new InputSelectDataLoader(this);\r\n  }\r\n}\r\n\r\nexport class InputSelectDataLoader{\r\n  private lstComponents: InputSelectComponent[] = [];\r\n  private configuration: InputSelectConfiguration;\r\n\r\n  /** Valor que será setado no formControl */\r\n  public bindValue: ((obj: any) => any)   | null = null;\r\n  /** Valor que será exibido */\r\n  public bindLabel: ((obj: any) => string)| null = null;\r\n\r\n  constructor(configuration: InputSelectConfiguration)  { \r\n    this.configuration = configuration; \r\n    this.bindValue = BindValueFactory(configuration)\r\n    this.bindLabel = BindLabelFactory(configuration)\r\n  }\r\n\r\n  public AddComponent(component: InputSelectComponent): void { \r\n    this.lstComponents.push(component);\r\n  }\r\n\r\n  //TODO Remove function\r\n   public GetLabel(value: any){\r\n    if(!this.items || !this.bindValue || !this.bindLabel){ return \"\"; }\r\n    const item = this.items.find(p => this.bindValue(p) == value);\r\n    if(!item){ return \"\" ;}\r\n    return this.bindLabel(item);\r\n  }\r\n\r\n  isLoaded: boolean = false;\r\n  error   : boolean = false;\r\n\r\n  async Refresh(items?: any[]): Promise<void>{\r\n    for (const component of this.lstComponents) {\r\n      component.loadingFromLoader = true;\r\n    }\r\n    \r\n    if(!this.configuration.loadFromService  && \r\n       !this.configuration.loadFromFunction && \r\n       (!this.configuration.loadFromArray || !this.configuration.loadFromArray.length)\r\n      ){\r\n      this.items = [...items || []];\r\n      this.isLoaded = true;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n    }\r\n    \r\n    try{\r\n      await this.Load();\r\n      this.isLoaded = true;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]);\r\n      }\r\n    }\r\n    finally{\r\n      for (const component of this.lstComponents) {\r\n        component.loadingFromLoader = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  items: any[] = [];\r\n  async Load(): Promise<void>{\r\n    if(this.isLoaded){\r\n      for (const component of this.lstComponents) {\r\n       if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n      return;\r\n    }\r\n\r\n    //[ Load from Array ]\r\n    if(this.configuration.loadFromArray != undefined && this.configuration.loadFromArray.length){\r\n      this.items = [...this.configuration.loadFromArray];\r\n      for (const component of this.lstComponents) {\r\n       if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n      return;\r\n    }\r\n\r\n    //[ Load from api ]\r\n    let vFiltros: ViewFiltros | null = this.configuration.vFiltros;\r\n    try{\r\n      let lstDados: any[] = [];\r\n      \r\n      if(this.configuration.loadFromService){\r\n        lstDados = (await firstValueFrom(this.configuration.loadFromService.List(vFiltros))).lstDados\r\n      }else{\r\n        lstDados = (await firstValueFrom(this.configuration.loadFromFunction)).lstDados;\r\n      }\r\n\r\n      this.items = lstDados;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      };\r\n      this.error = false;\r\n    }\r\n    catch (e){ this.error = true; throw e; }\r\n  }\r\n}\r\n\r\nexport function BindValueFactory(configuration: InputSelectConfiguration): ((obj: any) => any) {\r\n  const cBindValue = configuration.bindValue;\r\n  let bindValue: ((args: any) => any) = null;\r\n  if(typeof(cBindValue) == 'string'){\r\n    let bvS: string               = cBindValue;\r\n    bindValue = ((obj: any): any => { return obj[bvS]; });\r\n  }else{\r\n    let bvF: ((args: any) => any) = cBindValue;\r\n    bindValue = ((obj: any): any => { return bvF(obj); });\r\n  }\r\n  return bindValue;\r\n}\r\n\r\nexport function BindLabelFactory(configuration: InputSelectConfiguration): ((obj: any) => string) {\r\n  const cBindLabel = configuration.bindLabel;\r\n  let bindLabel: ((args: any) => string) = null;\r\n  if(typeof(cBindLabel) == 'string'){\r\n    let blS: string               = cBindLabel;\r\n    bindLabel = ((obj: any): string => { return obj[blS] + ''; });\r\n  }else{\r\n    let blF: ((args: any) => any) = cBindLabel;\r\n    bindLabel = ((obj: any): string => { return blF(obj) + ''; });\r\n  }\r\n  return bindLabel;\r\n}"]}
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.select.configuration.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-select/input.select.configuration.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable, firstValueFrom } from \"rxjs\";\r\n\r\nimport { HttpService, ViewRetorno } from \"../../../services/web/http.service\";\r\nimport { HttpServiceAtivo } from \"../../../services/web/http.ativo.service\";\r\nimport { ViewFiltros } from \"../../../classes/filters/view-filtros\";\r\nimport { INT_MAX } from \"../../../services/utils.service\";\r\nimport { Comparison } from \"../../../classes/comparison/comparison\";\r\nimport { InputSelectComponent } from \"./input-select.component\";\r\nimport { Placement } from \"@floating-ui/dom\";\r\n\r\nexport type DefaultModelOptions = { value: string, label: string };\r\n\r\nexport enum SelectInterfaces    {\r\n  /** Interface padrão do select \r\n   * Popover quando web, Modal quando mobile\r\n   */\r\n  Dynamic     = 0,\r\n  Popover     = 0,\r\n  Modal       = 1,\r\n  Alert       = 2,\r\n  ActionSheet = 3,\r\n} \r\n\r\nexport class InputSelectConfiguration{\r\n  static Create(options: {\r\n    bindLabel: string | ((obj: any) => string),\r\n    bindValue: string | ((obj: any) => any),\r\n    clearable?: boolean,\r\n    searcheable?: boolean,\r\n    loadFrom?: HttpService | Observable<ViewRetorno> | any[],\r\n    multiple?: boolean,\r\n    vFiltros?: Partial<{ \r\n      search: string,\r\n      orderByProperty: string,\r\n      ascending: boolean,\r\n      filter: Comparison[]\r\n    }>,\r\n    disableConditional?: ((obj: any) => boolean)\r\n    useInfiniteScroll?: boolean,\r\n    placeholder?: string,\r\n    noItensFoundText?: string,\r\n    interface?: SelectInterfaces,\r\n  }\r\n  ){\r\n    const config = new InputSelectConfiguration(\r\n      options.bindValue,\r\n      options.bindLabel,\r\n      options.clearable,\r\n      options.searcheable,\r\n      options.loadFrom,\r\n      options.multiple,\r\n      options.vFiltros || null,\r\n      options.disableConditional || null\r\n    );\r\n    if(options.placeholder){\r\n      config.placeholder = options.placeholder;\r\n    }\r\n    if(options.noItensFoundText){\r\n      config.noItensFoundText = options.noItensFoundText;\r\n    }\r\n    if(options.useInfiniteScroll != undefined){\r\n      config.useInfiniteScroll = options.useInfiniteScroll;\r\n    }\r\n    if(options.interface){\r\n      config.interface = options.interface;\r\n    }\r\n    return config;\r\n  };\r\n\r\n\r\n  placeholder     : string = \"Selecione um item...\"\r\n  noItensFoundText: string = \"Sem items encontrados...\"\r\n\r\n  loader: InputSelectDataLoader;\r\n  loadFromArray   : any[];\r\n  loadFromService : HttpService | HttpServiceAtivo\r\n  loadFromFunction: Observable<any>\r\n\r\n  popoverConfiguration: {\r\n    flip: boolean,\r\n    placement: Placement,\r\n  } = {\r\n    flip: true,\r\n    placement: \"bottom\"\r\n  }\r\n\r\n  public vFiltros: ViewFiltros | null = null;\r\n  public useInfiniteScroll: boolean = false;\r\n\r\n  /** Interface do select */\r\n  public interface: SelectInterfaces = SelectInterfaces.Dynamic;\r\n\r\n  constructor(\r\n    /** Valor que será setado no formControl */\r\n    public bindValue: string | ((obj: any) => any)     = \"id\"  ,\r\n    /** Valor que será exibido */\r\n    public bindLabel: string | ((obj: any) => string)  = \"nome\", \r\n    \r\n    /** Indica se o select pode ser nulo e limpavel */\r\n    public clearable  : boolean = true, \r\n    /** Indica se o select pode ser pesquisado */\r\n    public searcheable: boolean = true, \r\n    \r\n    /** \r\n     * Se LoadFrom instanceof HttpService      -> Os dados serão carregados do List()\r\n     * Se LoadFrom instanceof Observable       -> Os dados serão carregados da função indicada\r\n     * Se LoadFrom instanceof Array            -> Os dados serão o array\r\n     */\r\n    public loadFrom?:  HttpService | Observable<ViewRetorno> | any[], \r\n    /** Se = true Os valores no form control seráo um array dos items selecionados */\r\n    public multiple : boolean = false,\r\n    /** Aplica os filtros na pesquisa */\r\n    vFiltros : Partial<{ \r\n      /** Aplica uma pesquisa em texto  */\r\n      search: string\r\n      /** Propriedade de ordenação */\r\n      orderByProperty: string\r\n      /** Orientação de ordenação */\r\n      ascending: boolean,\r\n      /** Filtro  */\r\n      filter: Comparison[]\r\n    }> | null = null,\r\n    /** Desativa os items que estão de acordo com a função */\r\n    public disableConditional: ((obj: any) => boolean) | null = null\r\n  ){\r\n    this.clearable   = clearable;\r\n    this.searcheable = searcheable;\r\n    this.multiple    = multiple;\r\n\r\n    if(vFiltros != null){\r\n      const v = vFiltros;\r\n      if(v.ascending == null || v.ascending == undefined){ \r\n        v.ascending = true; \r\n      }\r\n      this.vFiltros = new ViewFiltros(INT_MAX, v.search, 1, v.orderByProperty, v.ascending);\r\n      this.vFiltros.filter = v.filter;\r\n    }\r\n\r\n    if(loadFrom){\r\n      if(Array.isArray(loadFrom)){ \r\n        this.loadFromArray    = loadFrom; \r\n      } else\r\n      if(loadFrom instanceof HttpService || loadFrom instanceof HttpServiceAtivo){ \r\n        this.loadFromService  = loadFrom;\r\n      } else {  \r\n        this.loadFromFunction = loadFrom;\r\n      }\r\n    }\r\n\r\n    this.loader = new InputSelectDataLoader(this);\r\n  }\r\n}\r\n\r\nexport class InputSelectDataLoader{\r\n  private lstComponents: InputSelectComponent[] = [];\r\n  private configuration: InputSelectConfiguration;\r\n\r\n  /** Valor que será setado no formControl */\r\n  public bindValue: ((obj: any) => any)   | null = null;\r\n  /** Valor que será exibido */\r\n  public bindLabel: ((obj: any) => string)| null = null;\r\n\r\n  constructor(configuration: InputSelectConfiguration)  { \r\n    this.configuration = configuration; \r\n    this.bindValue = BindValueFactory(configuration)\r\n    this.bindLabel = BindLabelFactory(configuration)\r\n  }\r\n\r\n  public AddComponent(component: InputSelectComponent): void { \r\n    this.lstComponents.push(component);\r\n  }\r\n\r\n  //TODO Remove function\r\n   public GetLabel(value: any){\r\n    if(!this.items || !this.bindValue || !this.bindLabel){ return \"\"; }\r\n    const item = this.items.find(p => this.bindValue(p) == value);\r\n    if(!item){ return \"\" ;}\r\n    return this.bindLabel(item);\r\n  }\r\n\r\n  isLoaded: boolean = false;\r\n  error   : boolean = false;\r\n\r\n  async Refresh(items?: any[]): Promise<void>{\r\n    for (const component of this.lstComponents) {\r\n      component.loadingFromLoader = true;\r\n    }\r\n    \r\n    if(!this.configuration.loadFromService  && \r\n       !this.configuration.loadFromFunction && \r\n       (!this.configuration.loadFromArray || !this.configuration.loadFromArray.length)\r\n      ){\r\n      this.items = [...items || []];\r\n      this.isLoaded = true;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n    }\r\n    \r\n    try{\r\n      await this.Load();\r\n      this.isLoaded = true;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]);\r\n      }\r\n    }\r\n    finally{\r\n      for (const component of this.lstComponents) {\r\n        component.loadingFromLoader = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  items: any[] = [];\r\n  async Load(): Promise<void>{\r\n    if(this.isLoaded){\r\n      for (const component of this.lstComponents) {\r\n       if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n      return;\r\n    }\r\n\r\n    //[ Load from Array ]\r\n    if(this.configuration.loadFromArray != undefined && this.configuration.loadFromArray.length){\r\n      this.items = [...this.configuration.loadFromArray];\r\n      for (const component of this.lstComponents) {\r\n       if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      }\r\n      return;\r\n    }\r\n\r\n    //[ Load from api ]\r\n    let vFiltros: ViewFiltros | null = this.configuration.vFiltros;\r\n    try{\r\n      let lstDados: any[] = [];\r\n      \r\n      if(this.configuration.loadFromService){\r\n        lstDados = (await firstValueFrom(this.configuration.loadFromService.List(vFiltros))).lstDados\r\n      }else{\r\n        lstDados = (await firstValueFrom(this.configuration.loadFromFunction)).lstDados;\r\n      }\r\n\r\n      this.items = lstDados;\r\n      for (const component of this.lstComponents) {\r\n        if(!component.destroyed)\r\n        component.items.set([...this.items]); \r\n      };\r\n      this.error = false;\r\n    }\r\n    catch (e){ this.error = true; throw e; }\r\n  }\r\n}\r\n\r\nexport function BindValueFactory(configuration: InputSelectConfiguration): ((obj: any) => any) {\r\n  const cBindValue = configuration.bindValue;\r\n  let bindValue: ((args: any) => any) = null;\r\n  if(typeof(cBindValue) == 'string'){\r\n    let bvS: string               = cBindValue;\r\n    bindValue = ((obj: any): any => { return obj[bvS]; });\r\n  }else{\r\n    let bvF: ((args: any) => any) = cBindValue;\r\n    bindValue = ((obj: any): any => { return bvF(obj); });\r\n  }\r\n  return bindValue;\r\n}\r\n\r\nexport function BindLabelFactory(configuration: InputSelectConfiguration): ((obj: any) => string) {\r\n  const cBindLabel = configuration.bindLabel;\r\n  let bindLabel: ((args: any) => string) = null;\r\n  if(typeof(cBindLabel) == 'string'){\r\n    let blS: string               = cBindLabel;\r\n    bindLabel = ((obj: any): string => { return obj[blS] + ''; });\r\n  }else{\r\n    let blF: ((args: any) => any) = cBindLabel;\r\n    bindLabel = ((obj: any): string => { return blF(obj) + ''; });\r\n  }\r\n  return bindLabel;\r\n}"]}
@@ -23,6 +23,7 @@ import { InputColorComponent } from './input-color/input-color.component';
23
23
  import { InputCepComponent } from './input-cep/input-cep.component';
24
24
  import { InputTelefoneComponent } from './input-telefone/input-telefone.component';
25
25
  import { InputIconComponent } from './input-icon/input-icon.component';
26
+ import { OverlayModule } from '@angular/cdk/overlay';
26
27
  import * as i0 from "@angular/core";
27
28
  const lstComponents = [
28
29
  InputBoolComponent,
@@ -67,7 +68,8 @@ export class InputsModule {
67
68
  MaskitoDirective,
68
69
  SIonPopoverModule,
69
70
  LoadingComponent,
70
- NgVarDirective], exports: [InputBoolComponent,
71
+ NgVarDirective,
72
+ OverlayModule], exports: [InputBoolComponent,
71
73
  InputCepComponent,
72
74
  InputColorComponent,
73
75
  InputCpfCnpjComponent,
@@ -89,7 +91,8 @@ export class InputsModule {
89
91
  FormsModule,
90
92
  ImageComponent,
91
93
  SIonPopoverModule,
92
- LoadingComponent] }); }
94
+ LoadingComponent,
95
+ OverlayModule] }); }
93
96
  }
94
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InputsModule, decorators: [{
95
98
  type: NgModule,
@@ -105,8 +108,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
105
108
  MaskitoDirective,
106
109
  SIonPopoverModule,
107
110
  LoadingComponent,
108
- NgVarDirective
111
+ NgVarDirective,
112
+ OverlayModule
109
113
  ]
110
114
  }]
111
115
  }] });
112
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dHMvaW5wdXRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQztBQUNyRyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSwrREFBK0QsQ0FBQztBQUNqSCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUNqRyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRXZFLE1BQU0sYUFBYSxHQUFHO0lBQ3BCLGtCQUFrQjtJQUNsQixpQkFBaUI7SUFDakIsbUJBQW1CO0lBQ25CLHFCQUFxQjtJQUNyQixrQkFBa0I7SUFDbEIscUJBQXFCO0lBQ3JCLGtCQUFrQjtJQUNsQixrQkFBa0I7SUFDbEIsb0JBQW9CO0lBQ2xCLDBCQUEwQjtJQUMxQiwyQkFBMkI7SUFDM0IsZ0NBQWdDO0lBQ2xDLG9CQUFvQjtJQUNwQixzQkFBc0I7SUFDdEIsc0JBQXNCO0lBQ3RCLHVCQUF1QjtDQUN4QixDQUFBO0FBaUJELE1BQU0sT0FBTyxZQUFZOytHQUFaLFlBQVk7Z0hBQVosWUFBWSxpQkFqQ3ZCLGtCQUFrQjtZQUNsQixpQkFBaUI7WUFDakIsbUJBQW1CO1lBQ25CLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIscUJBQXFCO1lBQ3JCLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsb0JBQW9CO1lBQ2xCLDBCQUEwQjtZQUMxQiwyQkFBMkI7WUFDM0IsZ0NBQWdDO1lBQ2xDLG9CQUFvQjtZQUNwQixzQkFBc0I7WUFDdEIsc0JBQXNCO1lBQ3RCLHVCQUF1QixhQU9yQixXQUFXO1lBQ1gsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsY0FBYztZQUNkLGdCQUFnQjtZQUNoQixpQkFBaUI7WUFDakIsZ0JBQWdCO1lBQ2hCLGNBQWMsYUE5QmhCLGtCQUFrQjtZQUNsQixpQkFBaUI7WUFDakIsbUJBQW1CO1lBQ25CLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIscUJBQXFCO1lBQ3JCLGtCQUFrQjtZQUNsQixrQkFBa0I7WUFDbEIsb0JBQW9CO1lBQ2xCLDBCQUEwQjtZQUMxQiwyQkFBMkI7WUFDM0IsZ0NBQWdDO1lBQ2xDLG9CQUFvQjtZQUNwQixzQkFBc0I7WUFDdEIsc0JBQXNCO1lBQ3RCLHVCQUF1QjtnSEFrQlosWUFBWSxZQVhyQixXQUFXO1lBQ1gsWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsY0FBYztZQUVkLGlCQUFpQjtZQUNqQixnQkFBZ0I7OzRGQUlQLFlBQVk7a0JBZnhCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUUsR0FBRyxhQUFhLENBQUU7b0JBQ2xDLE9BQU8sRUFBTyxDQUFFLEdBQUcsYUFBYSxDQUFFO29CQUNsQyxPQUFPLEVBQUU7d0JBQ1AsV0FBVzt3QkFDWCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsV0FBVzt3QkFDWCxjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBQ2hCLGNBQWM7cUJBQ2Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWFza2l0b0RpcmVjdGl2ZSB9IGZyb20gJ0BtYXNraXRvL2FuZ3VsYXInO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IElucHV0VGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LXRleHRhcmVhL2lucHV0LXRleHRhcmVhLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0U3RyaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1zdHJpbmcvaW5wdXQtc3RyaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0RGVjaW1hbENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtZGVjaW1hbC9pbnB1dC1kZWNpbWFsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0Qm9vbENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtYm9vbC9pbnB1dC1ib29sLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0RmlsZUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtZmlsZS9pbnB1dC1maWxlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vaW1hZ2UvaW1hZ2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXREYXRlQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1kYXRlL2lucHV0LWRhdGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LXNlbGVjdC9pbnB1dC1zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU0lvblBvcG92ZXJNb2R1bGUgfSBmcm9tICcuLi9wb3BvdmVyL3Npb24tcG9wb3Zlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTSW9uTGFiZWxUZW1wbGF0ZURpcmVjdGl2ZSB9IGZyb20gJy4vaW5wdXQtc2VsZWN0L2RpcmVjdGl2ZXMvc2lvbi1sYWJlbC10ZW1wbGF0ZS5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBTSW9uT3B0aW9uVGVtcGxhdGVEaXJlY3RpdmUgfSBmcm9tICcuL2lucHV0LXNlbGVjdC9kaXJlY3RpdmVzL3Npb24tb3B0aW9uLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFNJb25QbGFjZWhvbGRlclRlbXBsYXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9pbnB1dC1zZWxlY3QvZGlyZWN0aXZlcy9zaW9uLXBsYWNlaG9sZGVyLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IElucHV0Q3BmQ25wakNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtY3BmLWNucGovaW5wdXQtY3BmLWNucGouY29tcG9uZW50JztcclxuaW1wb3J0IHsgRG93bmxvYWRCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2lucHV0LWZpbGUvZG93bmxvYWQtYnV0dG9uL2Rvd25sb2FkLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi4vbG9hZGluZy9sb2FkaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE5nVmFyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZy12YXIuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgSW5wdXRDb2xvckNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtY29sb3IvaW5wdXQtY29sb3IuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRDZXBDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LWNlcC9pbnB1dC1jZXAuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRUZWxlZm9uZUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtdGVsZWZvbmUvaW5wdXQtdGVsZWZvbmUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1pY29uL2lucHV0LWljb24uY29tcG9uZW50JztcclxuXHJcbmNvbnN0IGxzdENvbXBvbmVudHMgPSBbXHJcbiAgSW5wdXRCb29sQ29tcG9uZW50LFxyXG4gIElucHV0Q2VwQ29tcG9uZW50LFxyXG4gIElucHV0Q29sb3JDb21wb25lbnQsXHJcbiAgSW5wdXRDcGZDbnBqQ29tcG9uZW50LFxyXG4gIElucHV0RGF0ZUNvbXBvbmVudCxcclxuICBJbnB1dERlY2ltYWxDb21wb25lbnQsXHJcbiAgSW5wdXRGaWxlQ29tcG9uZW50LFxyXG4gIElucHV0SWNvbkNvbXBvbmVudCxcclxuICBJbnB1dFNlbGVjdENvbXBvbmVudCxcclxuICAgIFNJb25MYWJlbFRlbXBsYXRlRGlyZWN0aXZlLFxyXG4gICAgU0lvbk9wdGlvblRlbXBsYXRlRGlyZWN0aXZlLFxyXG4gICAgU0lvblBsYWNlaG9sZGVyVGVtcGxhdGVEaXJlY3RpdmUsXHJcbiAgSW5wdXRTdHJpbmdDb21wb25lbnQsXHJcbiAgSW5wdXRUZWxlZm9uZUNvbXBvbmVudCxcclxuICBJbnB1dFRleHRhcmVhQ29tcG9uZW50LFxyXG4gIERvd25sb2FkQnV0dG9uQ29tcG9uZW50LFxyXG5dXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogWyAuLi5sc3RDb21wb25lbnRzIF0sXHJcbiAgZXhwb3J0cyAgICAgOiBbIC4uLmxzdENvbXBvbmVudHMgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBJb25pY01vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIEltYWdlQ29tcG9uZW50LFxyXG4gICAgTWFza2l0b0RpcmVjdGl2ZSxcclxuICAgIFNJb25Qb3BvdmVyTW9kdWxlLFxyXG4gICAgTG9hZGluZ0NvbXBvbmVudCxcclxuICAgIE5nVmFyRGlyZWN0aXZlXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXRzTW9kdWxlIHsgfVxyXG4iXX0=
116
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9pbnB1dHMvaW5wdXRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQztBQUNyRyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsZ0NBQWdDLEVBQUUsTUFBTSwrREFBK0QsQ0FBQztBQUNqSCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNsRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQztBQUNqRyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDbkUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQUVyRCxNQUFNLGFBQWEsR0FBRztJQUNwQixrQkFBa0I7SUFDbEIsaUJBQWlCO0lBQ2pCLG1CQUFtQjtJQUNuQixxQkFBcUI7SUFDckIsa0JBQWtCO0lBQ2xCLHFCQUFxQjtJQUNyQixrQkFBa0I7SUFDbEIsa0JBQWtCO0lBQ2xCLG9CQUFvQjtJQUNsQiwwQkFBMEI7SUFDMUIsMkJBQTJCO0lBQzNCLGdDQUFnQztJQUNsQyxvQkFBb0I7SUFDcEIsc0JBQXNCO0lBQ3RCLHNCQUFzQjtJQUN0Qix1QkFBdUI7Q0FDeEIsQ0FBQTtBQWtCRCxNQUFNLE9BQU8sWUFBWTsrR0FBWixZQUFZO2dIQUFaLFlBQVksaUJBbEN2QixrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLG1CQUFtQjtZQUNuQixxQkFBcUI7WUFDckIsa0JBQWtCO1lBQ2xCLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsa0JBQWtCO1lBQ2xCLG9CQUFvQjtZQUNsQiwwQkFBMEI7WUFDMUIsMkJBQTJCO1lBQzNCLGdDQUFnQztZQUNsQyxvQkFBb0I7WUFDcEIsc0JBQXNCO1lBQ3RCLHNCQUFzQjtZQUN0Qix1QkFBdUIsYUFPckIsV0FBVztZQUNYLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsaUJBQWlCO1lBQ2pCLGdCQUFnQjtZQUNoQixjQUFjO1lBQ2QsYUFBYSxhQS9CZixrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLG1CQUFtQjtZQUNuQixxQkFBcUI7WUFDckIsa0JBQWtCO1lBQ2xCLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsa0JBQWtCO1lBQ2xCLG9CQUFvQjtZQUNsQiwwQkFBMEI7WUFDMUIsMkJBQTJCO1lBQzNCLGdDQUFnQztZQUNsQyxvQkFBb0I7WUFDcEIsc0JBQXNCO1lBQ3RCLHNCQUFzQjtZQUN0Qix1QkFBdUI7Z0hBbUJaLFlBQVksWUFackIsV0FBVztZQUNYLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLGNBQWM7WUFFZCxpQkFBaUI7WUFDakIsZ0JBQWdCO1lBRWhCLGFBQWE7OzRGQUdKLFlBQVk7a0JBaEJ4QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFFLEdBQUcsYUFBYSxDQUFFO29CQUNsQyxPQUFPLEVBQU8sQ0FBRSxHQUFHLGFBQWEsQ0FBRTtvQkFDbEMsT0FBTyxFQUFFO3dCQUNQLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGlCQUFpQjt3QkFDakIsZ0JBQWdCO3dCQUNoQixjQUFjO3dCQUNkLGFBQWE7cUJBQ2Q7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWFza2l0b0RpcmVjdGl2ZSB9IGZyb20gJ0BtYXNraXRvL2FuZ3VsYXInO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IElucHV0VGV4dGFyZWFDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LXRleHRhcmVhL2lucHV0LXRleHRhcmVhLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0U3RyaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1zdHJpbmcvaW5wdXQtc3RyaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0RGVjaW1hbENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtZGVjaW1hbC9pbnB1dC1kZWNpbWFsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0Qm9vbENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtYm9vbC9pbnB1dC1ib29sLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElucHV0RmlsZUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtZmlsZS9pbnB1dC1maWxlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vaW1hZ2UvaW1hZ2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXREYXRlQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1kYXRlL2lucHV0LWRhdGUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LXNlbGVjdC9pbnB1dC1zZWxlY3QuY29tcG9uZW50JztcclxuaW1wb3J0IHsgU0lvblBvcG92ZXJNb2R1bGUgfSBmcm9tICcuLi9wb3BvdmVyL3Npb24tcG9wb3Zlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTSW9uTGFiZWxUZW1wbGF0ZURpcmVjdGl2ZSB9IGZyb20gJy4vaW5wdXQtc2VsZWN0L2RpcmVjdGl2ZXMvc2lvbi1sYWJlbC10ZW1wbGF0ZS5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBTSW9uT3B0aW9uVGVtcGxhdGVEaXJlY3RpdmUgfSBmcm9tICcuL2lucHV0LXNlbGVjdC9kaXJlY3RpdmVzL3Npb24tb3B0aW9uLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IFNJb25QbGFjZWhvbGRlclRlbXBsYXRlRGlyZWN0aXZlIH0gZnJvbSAnLi9pbnB1dC1zZWxlY3QvZGlyZWN0aXZlcy9zaW9uLXBsYWNlaG9sZGVyLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IElucHV0Q3BmQ25wakNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtY3BmLWNucGovaW5wdXQtY3BmLWNucGouY29tcG9uZW50JztcclxuaW1wb3J0IHsgRG93bmxvYWRCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL2lucHV0LWZpbGUvZG93bmxvYWQtYnV0dG9uL2Rvd25sb2FkLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi4vbG9hZGluZy9sb2FkaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE5nVmFyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZy12YXIuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgSW5wdXRDb2xvckNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtY29sb3IvaW5wdXQtY29sb3IuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRDZXBDb21wb25lbnQgfSBmcm9tICcuL2lucHV0LWNlcC9pbnB1dC1jZXAuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRUZWxlZm9uZUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtdGVsZWZvbmUvaW5wdXQtdGVsZWZvbmUuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSW5wdXRJY29uQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1pY29uL2lucHV0LWljb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuXHJcbmNvbnN0IGxzdENvbXBvbmVudHMgPSBbXHJcbiAgSW5wdXRCb29sQ29tcG9uZW50LFxyXG4gIElucHV0Q2VwQ29tcG9uZW50LFxyXG4gIElucHV0Q29sb3JDb21wb25lbnQsXHJcbiAgSW5wdXRDcGZDbnBqQ29tcG9uZW50LFxyXG4gIElucHV0RGF0ZUNvbXBvbmVudCxcclxuICBJbnB1dERlY2ltYWxDb21wb25lbnQsXHJcbiAgSW5wdXRGaWxlQ29tcG9uZW50LFxyXG4gIElucHV0SWNvbkNvbXBvbmVudCxcclxuICBJbnB1dFNlbGVjdENvbXBvbmVudCxcclxuICAgIFNJb25MYWJlbFRlbXBsYXRlRGlyZWN0aXZlLFxyXG4gICAgU0lvbk9wdGlvblRlbXBsYXRlRGlyZWN0aXZlLFxyXG4gICAgU0lvblBsYWNlaG9sZGVyVGVtcGxhdGVEaXJlY3RpdmUsXHJcbiAgSW5wdXRTdHJpbmdDb21wb25lbnQsXHJcbiAgSW5wdXRUZWxlZm9uZUNvbXBvbmVudCxcclxuICBJbnB1dFRleHRhcmVhQ29tcG9uZW50LFxyXG4gIERvd25sb2FkQnV0dG9uQ29tcG9uZW50LFxyXG5dXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogWyAuLi5sc3RDb21wb25lbnRzIF0sXHJcbiAgZXhwb3J0cyAgICAgOiBbIC4uLmxzdENvbXBvbmVudHMgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBJb25pY01vZHVsZSxcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIEltYWdlQ29tcG9uZW50LFxyXG4gICAgTWFza2l0b0RpcmVjdGl2ZSxcclxuICAgIFNJb25Qb3BvdmVyTW9kdWxlLFxyXG4gICAgTG9hZGluZ0NvbXBvbmVudCxcclxuICAgIE5nVmFyRGlyZWN0aXZlLFxyXG4gICAgT3ZlcmxheU1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIElucHV0c01vZHVsZSB7IH1cclxuIl19
@@ -1,11 +1,10 @@
1
- import { Component, ElementRef, EventEmitter, Input, NgZone, Output, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
1
+ import { Component, ElementRef, EventEmitter, Input, NgZone, Output, ViewChild } from '@angular/core';
2
2
  import { autoUpdate, computePosition, flip, limitShift, offset, shift, arrow } from '@floating-ui/dom';
3
3
  import { Timeout } from '../../../services/utils.service';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
6
  export class SIonPopoverComponent {
7
- constructor(viewContainerRef, ngZone) {
8
- this.viewContainerRef = viewContainerRef;
7
+ constructor(ngZone) {
9
8
  this.ngZone = ngZone;
10
9
  this.fill = 'blur';
11
10
  this.arrow = true;
@@ -20,9 +19,9 @@ export class SIonPopoverComponent {
20
19
  this.anchor = undefined;
21
20
  this.state = POPOVER_STATE.IDLE;
22
21
  }
23
- ngOnInit() {
24
- this.CreateEmbeddedView();
25
- this.CreateInstance();
22
+ ngAfterViewInit() {
23
+ this._instance = this.contentContainer.nativeElement;
24
+ document.body.appendChild(this._instance);
26
25
  //TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19
27
26
  this.ngZone.runOutsideAngular(() => {
28
27
  this.documentClickListener = (event) => {
@@ -41,27 +40,6 @@ export class SIonPopoverComponent {
41
40
  document.addEventListener('click', this.documentClickListener, true);
42
41
  });
43
42
  }
44
- CreateEmbeddedView() {
45
- if (this._embeddedView) {
46
- return;
47
- }
48
- this._embeddedView = this.popoverTemplate.createEmbeddedView({});
49
- this.viewRef = this.viewContainerRef.insert(this._embeddedView);
50
- }
51
- CreateInstance() {
52
- this._instance = this._embeddedView.rootNodes[0];
53
- document.body.appendChild(this._instance);
54
- // const style = {
55
- // "solid" : ['bg-light'],
56
- // "outline": ['bg-transparent'],
57
- // "blur" : ['backdrop-blur-md', 'bg-light/80'],
58
- // "clear" : ['!border-0 bg-transparent'],
59
- // }[this.fill];
60
- // style.forEach(s => {
61
- // this._instance.classList.add(s);
62
- // this.arrowEl?.classList.add(s);
63
- // });
64
- }
65
43
  get arrowEl() {
66
44
  return this._instance.querySelector('.popover-arrow');
67
45
  }
@@ -122,7 +100,6 @@ export class SIonPopoverComponent {
122
100
  }
123
101
  ngOnDestroy() {
124
102
  if (this._instance) {
125
- document.body.removeChild(this._instance);
126
103
  this._instance.remove();
127
104
  this._instance = undefined;
128
105
  }
@@ -149,13 +126,13 @@ export class SIonPopoverComponent {
149
126
  ].filter(p => p),
150
127
  });
151
128
  }
152
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
153
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SIonPopoverComponent, selector: "sion-popover", inputs: { fill: "fill", arrow: "arrow", flip: "flip", placement: "placement", height: "height", width: "width", anchor: "anchor" }, outputs: { onWillPresent: "onWillPresent", onDidPresent: "onDidPresent", onWillDismiss: "onWillDismiss", onDidDismiss: "onDidDismiss" }, viewQueries: [{ propertyName: "popoverTemplate", first: true, predicate: ["popoverTemplate"], descendants: true, static: true }, { propertyName: "contentContainer", first: true, predicate: ["popoverWrapper"], descendants: true }, { propertyName: "arrowElement", first: true, predicate: ["popoverArrow"], descendants: true }], ngImport: i0, template: "<ng-template #popoverTemplate>\r\n <div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n > \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n\r\n <ng-content #content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".popover-wrapper{z-index:50;border-radius:.75rem;width:max-content;position:absolute;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95)}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
129
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
130
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SIonPopoverComponent, selector: "sion-popover", inputs: { fill: "fill", arrow: "arrow", flip: "flip", placement: "placement", height: "height", width: "width", anchor: "anchor" }, outputs: { onWillPresent: "onWillPresent", onDidPresent: "onDidPresent", onWillDismiss: "onWillDismiss", onDidDismiss: "onDidDismiss" }, viewQueries: [{ propertyName: "contentContainer", first: true, predicate: ["popoverWrapper"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n> \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n <ng-content #content></ng-content>\r\n</div>", styles: [".popover-wrapper{border-radius:.75rem;width:max-content;position:fixed;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95);pointer-events:auto!important;z-index:10001!important}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
154
131
  }
155
132
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverComponent, decorators: [{
156
133
  type: Component,
157
- args: [{ selector: 'sion-popover', template: "<ng-template #popoverTemplate>\r\n <div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n > \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n\r\n <ng-content #content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".popover-wrapper{z-index:50;border-radius:.75rem;width:max-content;position:absolute;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95)}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none}\n"] }]
158
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.NgZone }], propDecorators: { fill: [{
134
+ args: [{ selector: 'sion-popover', template: "<div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n> \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n <ng-content #content></ng-content>\r\n</div>", styles: [".popover-wrapper{border-radius:.75rem;width:max-content;position:fixed;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95);pointer-events:auto!important;z-index:10001!important}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none!important}\n"] }]
135
+ }], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { fill: [{
159
136
  type: Input
160
137
  }], arrow: [{
161
138
  type: Input
@@ -177,15 +154,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
177
154
  type: Output
178
155
  }], anchor: [{
179
156
  type: Input
180
- }], popoverTemplate: [{
181
- type: ViewChild,
182
- args: ['popoverTemplate', { static: true }]
183
157
  }], contentContainer: [{
184
158
  type: ViewChild,
185
- args: ['popoverWrapper']
186
- }], arrowElement: [{
187
- type: ViewChild,
188
- args: ['popoverArrow']
159
+ args: ['popoverWrapper', { read: ElementRef }]
189
160
  }] } });
190
161
  var POPOVER_STATE;
191
162
  (function (POPOVER_STATE) {
@@ -206,4 +177,4 @@ const ROTATIONS = {
206
177
  left: "225deg",
207
178
  right: "45deg",
208
179
  };
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sion-popover.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.ts","../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EmbeddedViewRef, EventEmitter, Input, NgZone, OnDestroy, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef, ViewRef } from '@angular/core';\r\nimport { autoUpdate, computePosition, ComputePositionReturn, flip, limitShift, offset, Placement, shift, arrow } from '@floating-ui/dom';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\ntype Fill = 'solid' | 'outline' | 'blur' | 'clear';\r\n\r\n@Component({\r\n  selector: 'sion-popover',\r\n  templateUrl: './sion-popover.component.html',\r\n  styleUrls: ['./sion-popover.component.scss'],\r\n})\r\nexport class SIonPopoverComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() fill: Fill = 'blur';\r\n  @Input() arrow: boolean = true;\r\n  @Input() flip : boolean = true;\r\n\r\n\r\n  @Input() placement: Placement = 'bottom';\r\n  @Input() height: string = 'auto';\r\n  @Input() width: string = 'auto';\r\n\r\n\r\n  @Output() onWillPresent: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidPresent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output() onWillDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() anchor: HTMLElement | undefined = undefined;\r\n\r\n  constructor(\r\n    private viewContainerRef: ViewContainerRef,\r\n    private ngZone: NgZone\r\n  ) { }\r\n\r\n\r\n\r\n  @ViewChild('popoverTemplate', { static: true }) popoverTemplate!: TemplateRef<any>;\r\n  @ViewChild('popoverWrapper') contentContainer: ElementRef<HTMLDivElement>;\r\n  @ViewChild('popoverArrow'  ) arrowElement    : ElementRef<HTMLElement>;\r\n\r\n  ngOnInit() {\r\n    this.CreateEmbeddedView();\r\n    this.CreateInstance();\r\n  \r\n    //TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19\r\n    this.ngZone.runOutsideAngular(() => {\r\n      this.documentClickListener = (event: MouseEvent) => {\r\n        // Run back inside Angular's zone when handling the event\r\n        this.ngZone.run(() => {\r\n          if(!this._instance){ return;}\r\n          if (\r\n            !this._instance.contains(event.target as Node) &&\r\n            !this.anchor.contains(event.target as Node)\r\n          ) {\r\n            this.dismiss();\r\n          }\r\n        });\r\n      };\r\n      \r\n      // Use the native DOM API directly with capture phase\r\n      document.addEventListener('click', this.documentClickListener, true);\r\n    });\r\n  }\r\n  documentClickListener: (event: MouseEvent) => void;\r\n  viewRef?: ViewRef;\r\n\r\n  private _embeddedView?: EmbeddedViewRef<any> | undefined;\r\n  CreateEmbeddedView(): void {\r\n    if(this._embeddedView){ return; }\r\n    this._embeddedView = this.popoverTemplate.createEmbeddedView({});\r\n    this.viewRef = this.viewContainerRef.insert(this._embeddedView);\r\n  }\r\n  private _instance?: HTMLElement | undefined;\r\n  CreateInstance(): void {\r\n    this._instance = this._embeddedView.rootNodes[0] as HTMLElement;\r\n    document.body.appendChild(this._instance);\r\n\r\n    // const style = {\r\n    //   \"solid\"  : ['bg-light'],\r\n    //   \"outline\": ['bg-transparent'],\r\n    //   \"blur\"   : ['backdrop-blur-md', 'bg-light/80'],\r\n    //   \"clear\"  : ['!border-0 bg-transparent'],\r\n    // }[this.fill];\r\n    // style.forEach(s => {\r\n    //   this._instance.classList.add(s);\r\n    //   this.arrowEl?.classList.add(s);\r\n    // });\r\n  }\r\n\r\n  get arrowEl(): HTMLElement | undefined {\r\n    return this._instance.querySelector('.popover-arrow') as HTMLElement;\r\n  }\r\n  \r\n  private cleanupAutoUpdate?: () => void;\r\n  public state: POPOVER_STATE = POPOVER_STATE.IDLE;\r\n  public async present(event?: Event): Promise<void> {\r\n    if(this.state != POPOVER_STATE.IDLE) { return; }\r\n    this.onWillPresent.emit();\r\n    \r\n    this.state = POPOVER_STATE.PRESENTING;\r\n    const refEl   = this.anchor ? this.anchor : event.target as HTMLElement;\r\n    const arrowEl = this.arrowEl;\r\n\r\n    await this.update(refEl, arrowEl)\r\n    this._instance.classList.add('show');\r\n    this.cleanupAutoUpdate = autoUpdate(refEl, this._instance, async () => this.update(refEl, arrowEl));\r\n    \r\n    this.state = POPOVER_STATE.VISIBLE;\r\n    this.onDidPresent.emit();\r\n  }\r\n\r\n  private async update(refEl: HTMLElement, arrowEl: HTMLElement): Promise<void> {\r\n    const computePositionReturn: ComputePositionReturn = await this.GetComputePositionReturn(refEl, this._instance, arrowEl);\r\n    this.HandleComputePositionReturn(computePositionReturn, arrowEl);\r\n  }\r\n\r\n  public async dismiss(): Promise<void> {\r\n    if(this.state == POPOVER_STATE.IDLE) { return; }\r\n    if(this.cleanupAutoUpdate) {\r\n      this.cleanupAutoUpdate();\r\n      this.cleanupAutoUpdate = undefined;\r\n    }\r\n    this.onWillDismiss.emit();\r\n    this.state = POPOVER_STATE.DISMISSING;\r\n    this._instance.classList.remove('show');\r\n    await Timeout(200);\r\n    this.state = POPOVER_STATE.IDLE;\r\n    this.onDidDismiss.emit();\r\n  }\r\n\r\n  HandleComputePositionReturn(computePositionReturn: ComputePositionReturn, arrowEl: HTMLElement): void {\r\n    Object.assign(this._instance.style, {\r\n      left: `${computePositionReturn.x}px`,\r\n      top:  `${computePositionReturn.y}px`,\r\n      width : this.width,\r\n      height: this.height,\r\n      position: 'absolute',\r\n    });\r\n    if(computePositionReturn.middlewareData.arrow){\r\n      const { x: arrowX, y: arrowY } = computePositionReturn.middlewareData.arrow;\r\n      const position = computePositionReturn.placement.split('-')[0];\r\n      const staticSide = STATIC_SIDES[position];\r\n      Object.assign(arrowEl.style, {\r\n        left: arrowX != null ? `${arrowX}px` : '',\r\n        top : arrowY != null ? `${arrowY}px` : '',\r\n        right : '',\r\n        bottom: '',\r\n        [staticSide]: `-7px`,\r\n      });\r\n      arrowEl.style.setProperty(`--rotation`, ROTATIONS[position]);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if(this._instance) {\r\n      document.body.removeChild(this._instance);\r\n      this._instance.remove();\r\n      this._instance = undefined;\r\n    }\r\n    if(this._embeddedView) {\r\n      this._embeddedView.destroy();\r\n      this._embeddedView = undefined;\r\n    }\r\n\r\n    if (this.documentClickListener) {\r\n      document.removeEventListener('click', this.documentClickListener, true);\r\n    }\r\n    if (this.viewRef) {\r\n      this.viewRef.destroy();\r\n      this.viewRef = undefined;\r\n    }\r\n  }\r\n\r\n  async GetComputePositionReturn(refEl: HTMLElement, popEl: HTMLElement, arrowEl: HTMLElement): Promise<ComputePositionReturn> {\r\n    return await computePosition(refEl, popEl, {\r\n      placement: this.placement,\r\n      middleware: [ \r\n        offset(10), \r\n        this.flip  ? flip({ crossAxis: false }) : undefined, \r\n        shift({ limiter: limitShift(), padding: 5 }), \r\n        this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,\r\n      ].filter(p => p),\r\n    });\r\n  }\r\n}\r\n\r\nenum POPOVER_STATE{\r\n  IDLE       = 1,\r\n  PRESENTING = 2,\r\n  DISMISSING = 3,\r\n  VISIBLE    = 4\r\n}\r\nconst STATIC_SIDES = {\r\n  top: \"bottom\",\r\n  right: \"left\",\r\n  bottom: \"top\",\r\n  left: \"right\"\r\n};\r\nconst ROTATIONS = {\r\n  bottom: \"135deg\",\r\n  top: \"315deg\",\r\n  left: \"225deg\",\r\n  right: \"45deg\",\r\n}\r\n","<ng-template #popoverTemplate>\r\n  <div #popoverWrapper \r\n    class=\"popover-wrapper translucid-border\"\r\n    [style.height]=\"height\"\r\n    [style.width]=\"width\"\r\n    [ngClass]=\"{\r\n        'bg-light'        : fill == 'solid',\r\n        'bg-transparent'  : fill == 'outline',\r\n        'backdrop-blur-md bg-light/80': fill == 'blur',\r\n        '!border-0'       : fill == 'clear',\r\n      }\"\r\n  > \r\n    <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n      [ngClass]=\"{\r\n        'bg-light'        : fill == 'solid',\r\n        'bg-transparent'  : fill == 'outline',\r\n        'backdrop-blur-md bg-light/80': fill == 'blur',\r\n        '!border-0'       : fill == 'clear',\r\n      }\"\r\n    ></div>\r\n\r\n    <ng-content #content></ng-content>\r\n  </div>\r\n</ng-template>"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sion-popover.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.ts","../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EmbeddedViewRef, EventEmitter, Input, NgZone, OnDestroy, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef, ViewRef } from '@angular/core';\r\nimport { autoUpdate, computePosition, ComputePositionReturn, flip, limitShift, offset, Placement, shift, arrow } from '@floating-ui/dom';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\ntype Fill = 'solid' | 'outline' | 'blur' | 'clear';\r\n\r\n@Component({\r\n  selector: 'sion-popover',\r\n  templateUrl: './sion-popover.component.html',\r\n  styleUrls: ['./sion-popover.component.scss'],\r\n})\r\nexport class SIonPopoverComponent implements AfterViewInit, OnDestroy {\r\n\r\n  @Input() fill: Fill = 'blur';\r\n  @Input() arrow: boolean = true;\r\n  @Input() flip : boolean = true;\r\n\r\n\r\n  @Input() placement: Placement = 'bottom';\r\n  @Input() height: string = 'auto';\r\n  @Input() width: string = 'auto';\r\n\r\n\r\n  @Output() onWillPresent: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidPresent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output() onWillDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() anchor: HTMLElement | undefined = undefined;\r\n\r\n  constructor(\r\n    private ngZone: NgZone\r\n  ) { }\r\n\r\n  @ViewChild('popoverWrapper' , { read: ElementRef }) contentContainer: ElementRef<HTMLDivElement>;\r\n  \r\n  ngAfterViewInit() {\r\n    this._instance = this.contentContainer.nativeElement;\r\n    document.body.appendChild(this._instance);\r\n\r\n    //TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19\r\n    this.ngZone.runOutsideAngular(() => {\r\n      this.documentClickListener = (event: MouseEvent) => {\r\n        // Run back inside Angular's zone when handling the event\r\n        this.ngZone.run(() => {\r\n          if(!this._instance){ return;}\r\n          if (\r\n            !this._instance.contains(event.target as Node) &&\r\n            !this.anchor.contains(event.target as Node)\r\n          ) {\r\n            this.dismiss();\r\n          }\r\n        });\r\n      };\r\n      \r\n      // Use the native DOM API directly with capture phase\r\n      document.addEventListener('click', this.documentClickListener, true);\r\n    });\r\n  }\r\n  documentClickListener: (event: MouseEvent) => void;\r\n  viewRef?: ViewRef;\r\n\r\n  private _embeddedView?: EmbeddedViewRef<any> | undefined;\r\n  private _instance?: HTMLElement | undefined;\r\n\r\n  get arrowEl(): HTMLElement | undefined {\r\n    return this._instance.querySelector('.popover-arrow') as HTMLElement;\r\n  }\r\n  \r\n  private cleanupAutoUpdate?: () => void;\r\n  public state: POPOVER_STATE = POPOVER_STATE.IDLE;\r\n  public async present(event?: Event): Promise<void> {\r\n    if(this.state != POPOVER_STATE.IDLE) { return; }\r\n    this.onWillPresent.emit();\r\n    \r\n    this.state = POPOVER_STATE.PRESENTING;\r\n    const refEl   = this.anchor ? this.anchor : event.target as HTMLElement;\r\n    const arrowEl = this.arrowEl;\r\n\r\n    await this.update(refEl, arrowEl)\r\n    this._instance.classList.add('show');\r\n    this.cleanupAutoUpdate = autoUpdate(refEl, this._instance, async () => this.update(refEl, arrowEl));\r\n    \r\n    this.state = POPOVER_STATE.VISIBLE;\r\n    this.onDidPresent.emit();\r\n  }\r\n\r\n  private async update(refEl: HTMLElement, arrowEl: HTMLElement): Promise<void> {\r\n    const computePositionReturn: ComputePositionReturn = await this.GetComputePositionReturn(refEl, this._instance, arrowEl);\r\n    this.HandleComputePositionReturn(computePositionReturn, arrowEl);\r\n  }\r\n\r\n  public async dismiss(): Promise<void> {\r\n    if(this.state == POPOVER_STATE.IDLE) { return; }\r\n    if(this.cleanupAutoUpdate) {\r\n      this.cleanupAutoUpdate();\r\n      this.cleanupAutoUpdate = undefined;\r\n    }\r\n    this.onWillDismiss.emit();\r\n    this.state = POPOVER_STATE.DISMISSING;\r\n    this._instance.classList.remove('show');\r\n    await Timeout(200);\r\n    this.state = POPOVER_STATE.IDLE;\r\n    this.onDidDismiss.emit();\r\n  }\r\n\r\n  HandleComputePositionReturn(computePositionReturn: ComputePositionReturn, arrowEl: HTMLElement): void {\r\n    Object.assign(this._instance.style, {\r\n      left: `${computePositionReturn.x}px`,\r\n      top:  `${computePositionReturn.y}px`,\r\n      width : this.width,\r\n      height: this.height,\r\n      position: 'absolute',\r\n    });\r\n    if(computePositionReturn.middlewareData.arrow){\r\n      const { x: arrowX, y: arrowY } = computePositionReturn.middlewareData.arrow;\r\n      const position = computePositionReturn.placement.split('-')[0];\r\n      const staticSide = STATIC_SIDES[position];\r\n      Object.assign(arrowEl.style, {\r\n        left: arrowX != null ? `${arrowX}px` : '',\r\n        top : arrowY != null ? `${arrowY}px` : '',\r\n        right : '',\r\n        bottom: '',\r\n        [staticSide]: `-7px`,\r\n      });\r\n      arrowEl.style.setProperty(`--rotation`, ROTATIONS[position]);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if(this._instance) {\r\n      this._instance.remove();\r\n      this._instance = undefined;\r\n    }\r\n    if(this._embeddedView) {\r\n      this._embeddedView.destroy();\r\n      this._embeddedView = undefined;\r\n    }\r\n\r\n    if (this.documentClickListener) {\r\n      document.removeEventListener('click', this.documentClickListener, true);\r\n    }\r\n    if (this.viewRef) {\r\n      this.viewRef.destroy();\r\n      this.viewRef = undefined;\r\n    }\r\n  }\r\n\r\n  async GetComputePositionReturn(refEl: HTMLElement, popEl: HTMLElement, arrowEl: HTMLElement): Promise<ComputePositionReturn> {\r\n    return await computePosition(refEl, popEl, {\r\n      placement: this.placement,\r\n      middleware: [ \r\n        offset(10), \r\n        this.flip  ? flip({ crossAxis: false }) : undefined, \r\n        shift({ limiter: limitShift(), padding: 5 }), \r\n        this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,\r\n      ].filter(p => p),\r\n    });\r\n  }\r\n}\r\n\r\nenum POPOVER_STATE{\r\n  IDLE       = 1,\r\n  PRESENTING = 2,\r\n  DISMISSING = 3,\r\n  VISIBLE    = 4\r\n}\r\nconst STATIC_SIDES = {\r\n  top: \"bottom\",\r\n  right: \"left\",\r\n  bottom: \"top\",\r\n  left: \"right\"\r\n};\r\nconst ROTATIONS = {\r\n  bottom: \"135deg\",\r\n  top: \"315deg\",\r\n  left: \"225deg\",\r\n  right: \"45deg\",\r\n}\r\n","<div #popoverWrapper \r\n  class=\"popover-wrapper translucid-border\"\r\n  [style.height]=\"height\"\r\n  [style.width]=\"width\"\r\n  [ngClass]=\"{\r\n      'bg-light'        : fill == 'solid',\r\n      'bg-transparent'  : fill == 'outline',\r\n      'backdrop-blur-md bg-light/80': fill == 'blur',\r\n      '!border-0'       : fill == 'clear',\r\n    }\"\r\n> \r\n  <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n    [ngClass]=\"{\r\n      'bg-light'        : fill == 'solid',\r\n      'bg-transparent'  : fill == 'outline',\r\n      'backdrop-blur-md bg-light/80': fill == 'blur',\r\n      '!border-0'       : fill == 'clear',\r\n    }\"\r\n  ></div>\r\n  <ng-content #content></ng-content>\r\n</div>"]}
@@ -1,11 +1,12 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { SIonPopoverComponent } from './sion-popover/sion-popover.component';
4
+ import { OverlayModule } from '@angular/cdk/overlay';
4
5
  import * as i0 from "@angular/core";
5
6
  export class SIonPopoverModule {
6
7
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, declarations: [SIonPopoverComponent], imports: [CommonModule], exports: [SIonPopoverComponent] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, imports: [CommonModule] }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, declarations: [SIonPopoverComponent], imports: [CommonModule, OverlayModule], exports: [SIonPopoverComponent] }); }
9
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, imports: [CommonModule, OverlayModule] }); }
9
10
  }
10
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, decorators: [{
11
12
  type: NgModule,
@@ -13,8 +14,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
13
14
  declarations: [SIonPopoverComponent],
14
15
  exports: [SIonPopoverComponent],
15
16
  imports: [
16
- CommonModule
17
+ CommonModule, OverlayModule
17
18
  ]
18
19
  }]
19
20
  }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lvbi1wb3BvdmVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9wb3BvdmVyL3Npb24tcG9wb3Zlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBUzdFLE1BQU0sT0FBTyxpQkFBaUI7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQU5aLG9CQUFvQixhQUdsQyxZQUFZLGFBRkgsb0JBQW9CO2dIQUtwQixpQkFBaUIsWUFIMUIsWUFBWTs7NEZBR0gsaUJBQWlCO2tCQVA3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFFLG9CQUFvQixDQUFHO29CQUN2QyxPQUFPLEVBQUUsQ0FBRSxvQkFBb0IsQ0FBRTtvQkFDakMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7cUJBQ2I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBTSW9uUG9wb3ZlckNvbXBvbmVudCB9IGZyb20gJy4vc2lvbi1wb3BvdmVyL3Npb24tcG9wb3Zlci5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFsgU0lvblBvcG92ZXJDb21wb25lbnQgIF0sXHJcbiAgZXhwb3J0czogWyBTSW9uUG9wb3ZlckNvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNJb25Qb3BvdmVyTW9kdWxlIHsgfVxyXG4iXX0=
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lvbi1wb3BvdmVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9wb3BvdmVyL3Npb24tcG9wb3Zlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQVFyRCxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkFOWixvQkFBb0IsYUFHbEMsWUFBWSxFQUFFLGFBQWEsYUFGbEIsb0JBQW9CO2dIQUtwQixpQkFBaUIsWUFIMUIsWUFBWSxFQUFFLGFBQWE7OzRGQUdsQixpQkFBaUI7a0JBUDdCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUUsb0JBQW9CLENBQUc7b0JBQ3ZDLE9BQU8sRUFBRSxDQUFFLG9CQUFvQixDQUFFO29CQUNqQyxPQUFPLEVBQUU7d0JBQ1AsWUFBWSxFQUFFLGFBQWE7cUJBQzVCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgU0lvblBvcG92ZXJDb21wb25lbnQgfSBmcm9tICcuL3Npb24tcG9wb3Zlci9zaW9uLXBvcG92ZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFsgU0lvblBvcG92ZXJDb21wb25lbnQgIF0sXHJcbiAgZXhwb3J0czogWyBTSW9uUG9wb3ZlckNvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSwgT3ZlcmxheU1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNJb25Qb3BvdmVyTW9kdWxlIHsgfVxyXG4iXX0=
@@ -1,29 +1,34 @@
1
1
  import { InjectionToken, NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { EnvironmentService } from './services/environment.service';
4
+ import { ModalFocusTrapService } from './services/modal-focus-trap.service';
4
5
  import * as i0 from "@angular/core";
6
+ import * as i1 from "./services/modal-focus-trap.service";
5
7
  export const EnvironmentInjectionToken = new InjectionToken('Environment');
6
8
  export class SapphireIonFrameworkModule {
9
+ constructor(mis) {
10
+ this.mis = mis;
11
+ }
7
12
  static forRoot(config) {
8
13
  return {
9
14
  ngModule: SapphireIonFrameworkModule,
10
15
  providers: [
16
+ ModalFocusTrapService,
11
17
  EnvironmentService, { provide: EnvironmentInjectionToken, useValue: config },
12
18
  ]
13
19
  };
14
20
  }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
21
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, deps: [{ token: i1.ModalFocusTrapService }], target: i0.ɵɵFactoryTarget.NgModule }); }
16
22
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, imports: [CommonModule] }); }
17
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, imports: [CommonModule] }); }
23
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, providers: [ModalFocusTrapService], imports: [CommonModule] }); }
18
24
  }
19
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SapphireIonFrameworkModule, decorators: [{
20
26
  type: NgModule,
21
27
  args: [{
22
28
  declarations: [],
23
29
  exports: [],
24
- imports: [
25
- CommonModule
26
- ],
30
+ imports: [CommonModule,],
31
+ providers: [ModalFocusTrapService],
27
32
  }]
28
- }] });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NvcmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7O0FBRXBFLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLElBQUksY0FBYyxDQUFjLGFBQWEsQ0FBQyxDQUFDO0FBVXhGLE1BQU0sT0FBTywwQkFBMEI7SUFDckMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFtQjtRQUNoQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLDBCQUEwQjtZQUNwQyxTQUFTLEVBQUU7Z0JBQ1Qsa0JBQWtCLEVBQUUsRUFBRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRTthQUM3RTtTQUNGLENBQUE7SUFDSCxDQUFDOytHQVJVLDBCQUEwQjtnSEFBMUIsMEJBQTBCLFlBSG5DLFlBQVk7Z0hBR0gsMEJBQTBCLFlBSG5DLFlBQVk7OzRGQUdILDBCQUEwQjtrQkFQdEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFPLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3FCQUNiO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5pbXBvcnQgeyBFbnZpcm9ubWVudCB9IGZyb20gJy4vY2xhc3Nlcy9lbnZpcm9ubWVudCc7XHJcbmltcG9ydCB7IEVudmlyb25tZW50U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZW52aXJvbm1lbnQuc2VydmljZSc7XHJcblxyXG5leHBvcnQgY29uc3QgRW52aXJvbm1lbnRJbmplY3Rpb25Ub2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxFbnZpcm9ubWVudD4oJ0Vudmlyb25tZW50Jyk7XHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtdLFxyXG4gIGV4cG9ydHMgICAgIDogW10sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlXHJcbiAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNhcHBoaXJlSW9uRnJhbWV3b3JrTW9kdWxlIHsgXHJcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnOiBFbnZpcm9ubWVudCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8U2FwcGhpcmVJb25GcmFtZXdvcmtNb2R1bGU+IHtcclxuICAgIHJldHVybiB7IFxyXG4gICAgICBuZ01vZHVsZTogU2FwcGhpcmVJb25GcmFtZXdvcmtNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogWyBcclxuICAgICAgICBFbnZpcm9ubWVudFNlcnZpY2UsIHsgcHJvdmlkZTogRW52aXJvbm1lbnRJbmplY3Rpb25Ub2tlbiwgdXNlVmFsdWU6IGNvbmZpZyB9LCBcclxuICAgICAgXVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
33
+ }], ctorParameters: () => [{ type: i1.ModalFocusTrapService }] });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NvcmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDcEUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0scUNBQXFDLENBQUM7OztBQUU1RSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLGNBQWMsQ0FBYyxhQUFhLENBQUMsQ0FBQztBQU94RixNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLFlBQXFCLEdBQTBCO1FBQTFCLFFBQUcsR0FBSCxHQUFHLENBQXVCO0lBQUksQ0FBQztJQUVwRCxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQW1CO1FBQ2hDLE9BQU87WUFDTCxRQUFRLEVBQUUsMEJBQTBCO1lBQ3BDLFNBQVMsRUFBRTtnQkFDVCxxQkFBcUI7Z0JBQ3JCLGtCQUFrQixFQUFFLEVBQUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUU7YUFDN0U7U0FDRixDQUFBO0lBQ0gsQ0FBQzsrR0FYVSwwQkFBMEI7Z0hBQTFCLDBCQUEwQixZQUgxQixZQUFZO2dIQUdaLDBCQUEwQixhQUYxQixDQUFFLHFCQUFxQixDQUFFLFlBRHpCLFlBQVk7OzRGQUdaLDBCQUEwQjtrQkFOdEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFPLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRSxDQUFFLFlBQVksRUFBRztvQkFDMUIsU0FBUyxFQUFFLENBQUUscUJBQXFCLENBQUU7aUJBQ3JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5pbXBvcnQgeyBFbnZpcm9ubWVudCB9IGZyb20gJy4vY2xhc3Nlcy9lbnZpcm9ubWVudCc7XHJcbmltcG9ydCB7IEVudmlyb25tZW50U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZW52aXJvbm1lbnQuc2VydmljZSc7XHJcbmltcG9ydCB7IE1vZGFsRm9jdXNUcmFwU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvbW9kYWwtZm9jdXMtdHJhcC5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCBjb25zdCBFbnZpcm9ubWVudEluamVjdGlvblRva2VuID0gbmV3IEluamVjdGlvblRva2VuPEVudmlyb25tZW50PignRW52aXJvbm1lbnQnKTtcclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtdLFxyXG4gIGV4cG9ydHMgICAgIDogW10sXHJcbiAgaW1wb3J0czogWyBDb21tb25Nb2R1bGUsIF0sXHJcbiAgcHJvdmlkZXJzOiBbIE1vZGFsRm9jdXNUcmFwU2VydmljZSBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2FwcGhpcmVJb25GcmFtZXdvcmtNb2R1bGUgeyBcclxuICBjb25zdHJ1Y3RvciggcHJpdmF0ZSBtaXM6IE1vZGFsRm9jdXNUcmFwU2VydmljZSApIHt9XHJcblxyXG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogRW52aXJvbm1lbnQpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPFNhcHBoaXJlSW9uRnJhbWV3b3JrTW9kdWxlPiB7XHJcbiAgICByZXR1cm4geyBcclxuICAgICAgbmdNb2R1bGU6IFNhcHBoaXJlSW9uRnJhbWV3b3JrTW9kdWxlLFxyXG4gICAgICBwcm92aWRlcnM6IFsgXHJcbiAgICAgICAgTW9kYWxGb2N1c1RyYXBTZXJ2aWNlLFxyXG4gICAgICAgIEVudmlyb25tZW50U2VydmljZSwgeyBwcm92aWRlOiBFbnZpcm9ubWVudEluamVjdGlvblRva2VuLCB1c2VWYWx1ZTogY29uZmlnIH0sIFxyXG4gICAgICBdXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -0,0 +1,62 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * Corrige o focus trap em modais do Ionic, permite que o foco não fique preso dentro do modal.
5
+ * Utilizado para concertar interatividade com popovers e outros elementos que podem ser interativos fora do modal.
6
+ */
7
+ export class ModalFocusTrapService {
8
+ constructor() {
9
+ this.initGlobalFocusTrapDisable();
10
+ }
11
+ initGlobalFocusTrapDisable() {
12
+ // Wait for the platform to be ready
13
+ document.addEventListener('DOMContentLoaded', () => {
14
+ this.setupModalObserver();
15
+ });
16
+ }
17
+ setupModalObserver() {
18
+ // Create a mutation observer to watch for new modals
19
+ const observer = new MutationObserver((mutations) => {
20
+ mutations.forEach((mutation) => {
21
+ mutation.addedNodes.forEach((node) => {
22
+ if (node.nodeType === Node.ELEMENT_NODE) {
23
+ const element = node;
24
+ // Check if the added node is an ion-modal
25
+ if (element.tagName?.toLowerCase() === 'ion-modal') {
26
+ this.disableFocusTrap(element);
27
+ }
28
+ // Check for ion-modal children
29
+ const modals = element.querySelectorAll?.('ion-modal');
30
+ modals?.forEach(modal => this.disableFocusTrap(modal));
31
+ }
32
+ });
33
+ });
34
+ });
35
+ // Start observing
36
+ observer.observe(document.body, {
37
+ childList: true,
38
+ subtree: true
39
+ });
40
+ // Also handle existing modals
41
+ const existingModals = document.querySelectorAll('ion-modal');
42
+ existingModals.forEach(modal => this.disableFocusTrap(modal));
43
+ }
44
+ disableFocusTrap(modal) {
45
+ // Add the CSS class
46
+ modal.classList.add('ion-disable-focus-trap');
47
+ // Set the property if it exists
48
+ const modalElement = modal;
49
+ if (modalElement.disableFocusTrap !== undefined) {
50
+ modalElement.disableFocusTrap = true;
51
+ }
52
+ }
53
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalFocusTrapService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
54
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalFocusTrapService, providedIn: 'root' }); }
55
+ }
56
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModalFocusTrapService, decorators: [{
57
+ type: Injectable,
58
+ args: [{
59
+ providedIn: 'root'
60
+ }]
61
+ }], ctorParameters: () => [] });
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtZm9jdXMtdHJhcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zZXJ2aWNlcy9tb2RhbC1mb2N1cy10cmFwLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFM0M7OztHQUdHO0FBSUgsTUFBTSxPQUFPLHFCQUFxQjtJQUVoQztRQUNFLElBQUksQ0FBQywwQkFBMEIsRUFBRSxDQUFDO0lBQ3BDLENBQUM7SUFFTywwQkFBMEI7UUFDaEMsb0NBQW9DO1FBQ3BDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxHQUFHLEVBQUU7WUFDakQsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU8sa0JBQWtCO1FBQ3hCLHFEQUFxRDtRQUNyRCxNQUFNLFFBQVEsR0FBRyxJQUFJLGdCQUFnQixDQUFDLENBQUMsU0FBUyxFQUFFLEVBQUU7WUFDbEQsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO2dCQUM3QixRQUFRLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO29CQUNuQyxJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO3dCQUN4QyxNQUFNLE9BQU8sR0FBRyxJQUFlLENBQUM7d0JBRWhDLDBDQUEwQzt3QkFDMUMsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLFdBQVcsRUFBRSxLQUFLLFdBQVcsRUFBRSxDQUFDOzRCQUNuRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLENBQUM7d0JBQ2pDLENBQUM7d0JBRUQsK0JBQStCO3dCQUMvQixNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxXQUFXLENBQUMsQ0FBQzt3QkFDdkQsTUFBTSxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO29CQUN6RCxDQUFDO2dCQUNILENBQUMsQ0FBQyxDQUFDO1lBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUVILGtCQUFrQjtRQUNsQixRQUFRLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUU7WUFDOUIsU0FBUyxFQUFFLElBQUk7WUFDZixPQUFPLEVBQUUsSUFBSTtTQUNkLENBQUMsQ0FBQztRQUVILDhCQUE4QjtRQUM5QixNQUFNLGNBQWMsR0FBRyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDOUQsY0FBYyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxLQUFjO1FBQ3JDLG9CQUFvQjtRQUNwQixLQUFLLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBRTlDLGdDQUFnQztRQUNoQyxNQUFNLFlBQVksR0FBRyxLQUFZLENBQUM7UUFDbEMsSUFBSSxZQUFZLENBQUMsZ0JBQWdCLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDaEQsWUFBWSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQztRQUN2QyxDQUFDO0lBQ0gsQ0FBQzsrR0F0RFUscUJBQXFCO21IQUFyQixxQkFBcUIsY0FGcEIsTUFBTTs7NEZBRVAscUJBQXFCO2tCQUhqQyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBDb3JyaWdlIG8gZm9jdXMgdHJhcCBlbSBtb2RhaXMgZG8gSW9uaWMsIHBlcm1pdGUgcXVlIG8gZm9jbyBuw6NvIGZpcXVlIHByZXNvIGRlbnRybyBkbyBtb2RhbC5cclxuICogVXRpbGl6YWRvIHBhcmEgY29uY2VydGFyIGludGVyYXRpdmlkYWRlIGNvbSBwb3BvdmVycyBlIG91dHJvcyBlbGVtZW50b3MgcXVlIHBvZGVtIHNlciBpbnRlcmF0aXZvcyBmb3JhIGRvIG1vZGFsLlxyXG4gKi9cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTW9kYWxGb2N1c1RyYXBTZXJ2aWNlIHtcclxuICBcclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMuaW5pdEdsb2JhbEZvY3VzVHJhcERpc2FibGUoKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgaW5pdEdsb2JhbEZvY3VzVHJhcERpc2FibGUoKSB7XHJcbiAgICAvLyBXYWl0IGZvciB0aGUgcGxhdGZvcm0gdG8gYmUgcmVhZHlcclxuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ0RPTUNvbnRlbnRMb2FkZWQnLCAoKSA9PiB7XHJcbiAgICAgIHRoaXMuc2V0dXBNb2RhbE9ic2VydmVyKCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgc2V0dXBNb2RhbE9ic2VydmVyKCkge1xyXG4gICAgLy8gQ3JlYXRlIGEgbXV0YXRpb24gb2JzZXJ2ZXIgdG8gd2F0Y2ggZm9yIG5ldyBtb2RhbHNcclxuICAgIGNvbnN0IG9ic2VydmVyID0gbmV3IE11dGF0aW9uT2JzZXJ2ZXIoKG11dGF0aW9ucykgPT4ge1xyXG4gICAgICBtdXRhdGlvbnMuZm9yRWFjaCgobXV0YXRpb24pID0+IHtcclxuICAgICAgICBtdXRhdGlvbi5hZGRlZE5vZGVzLmZvckVhY2goKG5vZGUpID0+IHtcclxuICAgICAgICAgIGlmIChub2RlLm5vZGVUeXBlID09PSBOb2RlLkVMRU1FTlRfTk9ERSkge1xyXG4gICAgICAgICAgICBjb25zdCBlbGVtZW50ID0gbm9kZSBhcyBFbGVtZW50O1xyXG4gICAgICAgICAgICBcclxuICAgICAgICAgICAgLy8gQ2hlY2sgaWYgdGhlIGFkZGVkIG5vZGUgaXMgYW4gaW9uLW1vZGFsXHJcbiAgICAgICAgICAgIGlmIChlbGVtZW50LnRhZ05hbWU/LnRvTG93ZXJDYXNlKCkgPT09ICdpb24tbW9kYWwnKSB7XHJcbiAgICAgICAgICAgICAgdGhpcy5kaXNhYmxlRm9jdXNUcmFwKGVsZW1lbnQpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIFxyXG4gICAgICAgICAgICAvLyBDaGVjayBmb3IgaW9uLW1vZGFsIGNoaWxkcmVuXHJcbiAgICAgICAgICAgIGNvbnN0IG1vZGFscyA9IGVsZW1lbnQucXVlcnlTZWxlY3RvckFsbD8uKCdpb24tbW9kYWwnKTtcclxuICAgICAgICAgICAgbW9kYWxzPy5mb3JFYWNoKG1vZGFsID0+IHRoaXMuZGlzYWJsZUZvY3VzVHJhcChtb2RhbCkpO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9KTtcclxuICAgIH0pO1xyXG5cclxuICAgIC8vIFN0YXJ0IG9ic2VydmluZ1xyXG4gICAgb2JzZXJ2ZXIub2JzZXJ2ZShkb2N1bWVudC5ib2R5LCB7XHJcbiAgICAgIGNoaWxkTGlzdDogdHJ1ZSxcclxuICAgICAgc3VidHJlZTogdHJ1ZVxyXG4gICAgfSk7XHJcblxyXG4gICAgLy8gQWxzbyBoYW5kbGUgZXhpc3RpbmcgbW9kYWxzXHJcbiAgICBjb25zdCBleGlzdGluZ01vZGFscyA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoJ2lvbi1tb2RhbCcpO1xyXG4gICAgZXhpc3RpbmdNb2RhbHMuZm9yRWFjaChtb2RhbCA9PiB0aGlzLmRpc2FibGVGb2N1c1RyYXAobW9kYWwpKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZGlzYWJsZUZvY3VzVHJhcChtb2RhbDogRWxlbWVudCkge1xyXG4gICAgLy8gQWRkIHRoZSBDU1MgY2xhc3NcclxuICAgIG1vZGFsLmNsYXNzTGlzdC5hZGQoJ2lvbi1kaXNhYmxlLWZvY3VzLXRyYXAnKTtcclxuICAgIFxyXG4gICAgLy8gU2V0IHRoZSBwcm9wZXJ0eSBpZiBpdCBleGlzdHNcclxuICAgIGNvbnN0IG1vZGFsRWxlbWVudCA9IG1vZGFsIGFzIGFueTtcclxuICAgIGlmIChtb2RhbEVsZW1lbnQuZGlzYWJsZUZvY3VzVHJhcCAhPT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgIG1vZGFsRWxlbWVudC5kaXNhYmxlRm9jdXNUcmFwID0gdHJ1ZTtcclxuICAgIH1cclxuICB9XHJcbn0iXX0=