@sapphire-ion/framework 1.0.20 → 1.0.22

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.
@@ -1,4 +1,4 @@
1
- import { Component, effect, Input, model } from '@angular/core';
1
+ import { Component, effect, EventEmitter, Input, model, Output } from '@angular/core';
2
2
  import { firstValueFrom } from "rxjs";
3
3
  import { CompileLstTableField } from "../../../classes/comparison/comparison";
4
4
  import { ViewFiltros } from "../../../classes/filters/view-filtros";
@@ -17,6 +17,8 @@ export class List {
17
17
  this.frm = new ViewFiltros();
18
18
  /** Lista de campos a serem substituídos pelo padrão, armazenado no service enviado como parâmetro */
19
19
  this.lstTableFields = [];
20
+ this.WillRefresh = new EventEmitter();
21
+ this.DidRefresh = new EventEmitter();
20
22
  effect(() => {
21
23
  this.SetFilters();
22
24
  });
@@ -67,6 +69,7 @@ export class List {
67
69
  }
68
70
  }
69
71
  async Refresh(event) {
72
+ this.WillRefresh.emit();
70
73
  this.loading = true;
71
74
  try {
72
75
  await this.Load();
@@ -76,6 +79,7 @@ export class List {
76
79
  event.target.complete();
77
80
  }
78
81
  this.loading = false;
82
+ this.DidRefresh.emit();
79
83
  }
80
84
  async Load() {
81
85
  var vRetorno;
@@ -93,7 +97,7 @@ export class List {
93
97
  return;
94
98
  }
95
99
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: List, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
96
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: List, selector: "ng-component", inputs: { service: { classPropertyName: "service", publicName: "service", isSignal: false, isRequired: false, transformFunction: null }, preloadFilter: { classPropertyName: "preloadFilter", publicName: "preloadFilter", isSignal: true, isRequired: false, transformFunction: null }, loadFrom: { classPropertyName: "loadFrom", publicName: "loadFrom", isSignal: false, isRequired: false, transformFunction: null }, frm: { classPropertyName: "frm", publicName: "frm", isSignal: false, isRequired: false, transformFunction: null }, lstTableFields: { classPropertyName: "lstTableFields", publicName: "lstTableFields", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { preloadFilter: "preloadFilterChange" }, ngImport: i0, template: '', isInline: true, styles: [""] }); }
100
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: List, selector: "ng-component", inputs: { service: { classPropertyName: "service", publicName: "service", isSignal: false, isRequired: false, transformFunction: null }, preloadFilter: { classPropertyName: "preloadFilter", publicName: "preloadFilter", isSignal: true, isRequired: false, transformFunction: null }, loadFrom: { classPropertyName: "loadFrom", publicName: "loadFrom", isSignal: false, isRequired: false, transformFunction: null }, frm: { classPropertyName: "frm", publicName: "frm", isSignal: false, isRequired: false, transformFunction: null }, lstTableFields: { classPropertyName: "lstTableFields", publicName: "lstTableFields", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { preloadFilter: "preloadFilterChange", WillRefresh: "WillRefresh", DidRefresh: "DidRefresh" }, ngImport: i0, template: '', isInline: true, styles: [""] }); }
97
101
  }
98
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: List, decorators: [{
99
103
  type: Component,
@@ -106,5 +110,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
106
110
  type: Input
107
111
  }], lstTableFields: [{
108
112
  type: Input
113
+ }], WillRefresh: [{
114
+ type: Output,
115
+ args: ['WillRefresh']
116
+ }], DidRefresh: [{
117
+ type: Output,
118
+ args: ['DidRefresh']
109
119
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-list/list.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, effect, ElementRef, Input, model, ModelSignal, OnInit } from '@angular/core';\r\nimport { RefresherCustomEvent } from \"@ionic/angular\";\r\nimport { Observable, firstValueFrom } from \"rxjs\";\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\nimport { CompileLstTableField, Comparison } from \"../../../classes/comparison/comparison\";\r\nimport { HttpService, ViewRetorno } from '../../../services/web/http.service';\r\nimport { GenericService } from \"../../../services/generic.service\";\r\nimport { ViewFiltros } from \"../../../classes/filters/view-filtros\";\r\nimport { TableField } from \"../../../classes/inputs/table-field\";\r\nimport { RouteData } from \"../../../classes/routes/route-data\";\r\nimport { LongProperty } from '../../../classes/comparison/properties/long-property';\r\n\r\n//Classe de listagem, implemente carregamento e filtragem de dados\r\n@Component({ template: '', styles: '' })\r\nexport abstract class List<T extends HttpService<V>, V = any> implements OnInit {\r\n\r\n  protected genericService: GenericService;\r\n  protected activatedRoute: ActivatedRoute;\r\n  protected elementRef: ElementRef;\r\n  @Input() service: T;\r\n\r\n  constructor() { \r\n    effect(() => {\r\n      this.SetFilters();\r\n    });\r\n  }\r\n  \r\n  /** @optional Filtro a ser aplicado na busca da listagem na API */\r\n  preloadFilter: ModelSignal<Comparison[]> = model<Comparison[]>([]); \r\n  \r\n  //TODO FIX https://stackoverflow.com/a/73761805 \r\n  /** End-point de carregamento de dados. Deve ser uma função no service aplicado */\r\n  @Input() loadFrom: (view: ViewFiltros) => Observable<ViewRetorno>;\r\n\r\n\r\n  lstDados: V[] = [];\r\n  total   : number;\r\n  nested  : boolean = false;\r\n  loading : boolean = true;\r\n  \r\n  originalFilters: Comparison[] = [];\r\n\r\n  /** Filtro précarregado  */\r\n  @Input() frm: ViewFiltros = new ViewFiltros();\r\n\r\n  /** Lista de campos a serem substituídos pelo padrão, armazenado no service enviado como parâmetro */\r\n  @Input() lstTableFields: TableField[] = [];\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.originalFilters = this.frm.filter;\r\n\r\n    if(this.lstTableFields.length == 0){\r\n      this.lstTableFields = this.service.lstTableFields;\r\n    }\r\n    if(!this.service.route){ console.warn(\"[ Warning! ] [ Url is undefined ]\")}\r\n    if(!this.service.title){ console.warn(\"[ Warning! ] [ titulo is undefined ]\")}\r\n    \r\n    //[ Nested element ]\r\n    if(this.elementRef.nativeElement.parentElement){\r\n      this.nested = (this.elementRef.nativeElement.parentElement.tagName as string).toUpperCase() != \"ION-CONTENT\";\r\n    }else{\r\n      this.nested = true;\r\n    }\r\n\r\n    await this.SetFilters();\r\n    if(this.nested){ this.Refresh(); }\r\n  }\r\n\r\n  /** Carrega os filtros pré-carregados e os filtros compilados */\r\n  protected async SetFilters(): Promise<void>{\r\n    await this.LoadIdComparison();\r\n    const compiled      = CompileLstTableField(this.lstTableFields);\r\n    const preloadFilter = this.preloadFilter();\r\n    // Adiciona os filtros pré-carregados, os filtros compilados e os filtros originais e remove os nulos\r\n    this.frm.filter     = [...preloadFilter, ...compiled, ...this.originalFilters].filter(p => p);\r\n  }\r\n\r\n  async LoadIdComparison(): Promise<void>{\r\n    try{\r\n      const data: RouteData = (await firstValueFrom(this.activatedRoute.data)) as RouteData;\r\n\r\n      const id   = this.genericService.GetId(this.activatedRoute, data.idPreloaderConfiguration.routeDepth);\r\n      var index: number = this.lstTableFields.indexOf(this.lstTableFields.find(p => p.index == data.idPreloaderConfiguration.propertyName));\r\n      const filter: Comparison = new LongProperty(data.idPreloaderConfiguration.propertyName).Equals(id);\r\n\r\n      filter.value = id;\r\n      filter.disableChange = data.idPreloaderConfiguration.disableChange;\r\n      this.lstTableFields[index].filter = [filter];\r\n    }finally{ \r\n      return;\r\n    }\r\n  }\r\n\r\n  async Refresh(event?: RefresherCustomEvent): Promise<void> {\r\n    this.loading = true;\r\n    try{\r\n      await this.Load();\r\n    }\r\n    finally{ }\r\n\r\n    if(event){ event.target.complete(); }\r\n    this.loading = false;\r\n  }\r\n  \r\n  async Load(): Promise<void>{\r\n    var vRetorno: ViewRetorno;\r\n\r\n    try{\r\n      if(this.loadFrom){\r\n        vRetorno = await firstValueFrom(this.service[this.loadFrom.name](this.frm));\r\n      }\r\n      else{\r\n        vRetorno = await firstValueFrom(this.service.List(this.frm));\r\n      }\r\n      this.lstDados = vRetorno.lstDados; \r\n      this.total    = vRetorno.total; \r\n    } finally{ }\r\n    return;\r\n  }\r\n}"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-list/list.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, effect, ElementRef, EventEmitter, Input, model, ModelSignal, OnInit, Output } from '@angular/core';\r\nimport { RefresherCustomEvent } from \"@ionic/angular\";\r\nimport { Observable, firstValueFrom } from \"rxjs\";\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\nimport { CompileLstTableField, Comparison } from \"../../../classes/comparison/comparison\";\r\nimport { HttpService, ViewRetorno } from '../../../services/web/http.service';\r\nimport { GenericService } from \"../../../services/generic.service\";\r\nimport { ViewFiltros } from \"../../../classes/filters/view-filtros\";\r\nimport { TableField } from \"../../../classes/inputs/table-field\";\r\nimport { RouteData } from \"../../../classes/routes/route-data\";\r\nimport { LongProperty } from '../../../classes/comparison/properties/long-property';\r\n\r\n//Classe de listagem, implemente carregamento e filtragem de dados\r\n@Component({ template: '', styles: '' })\r\nexport abstract class List<T extends HttpService<V>, V = any> implements OnInit {\r\n\r\n  protected genericService: GenericService;\r\n  protected activatedRoute: ActivatedRoute;\r\n  protected elementRef: ElementRef;\r\n  @Input() service: T;\r\n\r\n  constructor() { \r\n    effect(() => {\r\n      this.SetFilters();\r\n    });\r\n  }\r\n  \r\n  /** @optional Filtro a ser aplicado na busca da listagem na API */\r\n  preloadFilter: ModelSignal<Comparison[]> = model<Comparison[]>([]); \r\n  \r\n  //TODO FIX https://stackoverflow.com/a/73761805 \r\n  /** End-point de carregamento de dados. Deve ser uma função no service aplicado */\r\n  @Input() loadFrom: (view: ViewFiltros) => Observable<ViewRetorno>;\r\n\r\n\r\n  lstDados: V[] = [];\r\n  total   : number;\r\n  nested  : boolean = false;\r\n  loading : boolean = true;\r\n  \r\n  originalFilters: Comparison[] = [];\r\n\r\n  /** Filtro précarregado  */\r\n  @Input() frm: ViewFiltros = new ViewFiltros();\r\n\r\n  /** Lista de campos a serem substituídos pelo padrão, armazenado no service enviado como parâmetro */\r\n  @Input() lstTableFields: TableField[] = [];\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.originalFilters = this.frm.filter;\r\n\r\n    if(this.lstTableFields.length == 0){\r\n      this.lstTableFields = this.service.lstTableFields;\r\n    }\r\n    if(!this.service.route){ console.warn(\"[ Warning! ] [ Url is undefined ]\")}\r\n    if(!this.service.title){ console.warn(\"[ Warning! ] [ titulo is undefined ]\")}\r\n    \r\n    //[ Nested element ]\r\n    if(this.elementRef.nativeElement.parentElement){\r\n      this.nested = (this.elementRef.nativeElement.parentElement.tagName as string).toUpperCase() != \"ION-CONTENT\";\r\n    }else{\r\n      this.nested = true;\r\n    }\r\n\r\n    await this.SetFilters();\r\n    if(this.nested){ this.Refresh(); }\r\n  }\r\n\r\n  /** Carrega os filtros pré-carregados e os filtros compilados */\r\n  protected async SetFilters(): Promise<void>{\r\n    await this.LoadIdComparison();\r\n    const compiled      = CompileLstTableField(this.lstTableFields);\r\n    const preloadFilter = this.preloadFilter();\r\n    // Adiciona os filtros pré-carregados, os filtros compilados e os filtros originais e remove os nulos\r\n    this.frm.filter     = [...preloadFilter, ...compiled, ...this.originalFilters].filter(p => p);\r\n  }\r\n\r\n  async LoadIdComparison(): Promise<void>{\r\n    try{\r\n      const data: RouteData = (await firstValueFrom(this.activatedRoute.data)) as RouteData;\r\n\r\n      const id   = this.genericService.GetId(this.activatedRoute, data.idPreloaderConfiguration.routeDepth);\r\n      var index: number = this.lstTableFields.indexOf(this.lstTableFields.find(p => p.index == data.idPreloaderConfiguration.propertyName));\r\n      const filter: Comparison = new LongProperty(data.idPreloaderConfiguration.propertyName).Equals(id);\r\n\r\n      filter.value = id;\r\n      filter.disableChange = data.idPreloaderConfiguration.disableChange;\r\n      this.lstTableFields[index].filter = [filter];\r\n    }finally{ \r\n      return;\r\n    }\r\n  }\r\n\r\n  @Output('WillRefresh') WillRefresh: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output('DidRefresh') DidRefresh: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  async Refresh(event?: RefresherCustomEvent): Promise<void> {\r\n    this.WillRefresh.emit();\r\n    this.loading = true;\r\n    try{\r\n      await this.Load();\r\n    }\r\n    finally{ }\r\n    \r\n    if(event){ event.target.complete(); }\r\n    this.loading = false;\r\n    this.DidRefresh.emit();\r\n  }\r\n  \r\n  async Load(): Promise<void>{\r\n    var vRetorno: ViewRetorno;\r\n\r\n    try{\r\n      if(this.loadFrom){\r\n        vRetorno = await firstValueFrom(this.service[this.loadFrom.name](this.frm));\r\n      }\r\n      else{\r\n        vRetorno = await firstValueFrom(this.service.List(this.frm));\r\n      }\r\n      this.lstDados = vRetorno.lstDados; \r\n      this.total    = vRetorno.total; \r\n    } finally{ }\r\n    return;\r\n  }\r\n}"]}
@@ -1934,6 +1934,8 @@ class List {
1934
1934
  this.frm = new ViewFiltros();
1935
1935
  /** Lista de campos a serem substituídos pelo padrão, armazenado no service enviado como parâmetro */
1936
1936
  this.lstTableFields = [];
1937
+ this.WillRefresh = new EventEmitter();
1938
+ this.DidRefresh = new EventEmitter();
1937
1939
  effect(() => {
1938
1940
  this.SetFilters();
1939
1941
  });
@@ -1984,6 +1986,7 @@ class List {
1984
1986
  }
1985
1987
  }
1986
1988
  async Refresh(event) {
1989
+ this.WillRefresh.emit();
1987
1990
  this.loading = true;
1988
1991
  try {
1989
1992
  await this.Load();
@@ -1993,6 +1996,7 @@ class List {
1993
1996
  event.target.complete();
1994
1997
  }
1995
1998
  this.loading = false;
1999
+ this.DidRefresh.emit();
1996
2000
  }
1997
2001
  async Load() {
1998
2002
  var vRetorno;
@@ -2010,7 +2014,7 @@ class List {
2010
2014
  return;
2011
2015
  }
2012
2016
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: List, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
2013
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: List, selector: "ng-component", inputs: { service: { classPropertyName: "service", publicName: "service", isSignal: false, isRequired: false, transformFunction: null }, preloadFilter: { classPropertyName: "preloadFilter", publicName: "preloadFilter", isSignal: true, isRequired: false, transformFunction: null }, loadFrom: { classPropertyName: "loadFrom", publicName: "loadFrom", isSignal: false, isRequired: false, transformFunction: null }, frm: { classPropertyName: "frm", publicName: "frm", isSignal: false, isRequired: false, transformFunction: null }, lstTableFields: { classPropertyName: "lstTableFields", publicName: "lstTableFields", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { preloadFilter: "preloadFilterChange" }, ngImport: i0, template: '', isInline: true, styles: [""] }); }
2017
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: List, selector: "ng-component", inputs: { service: { classPropertyName: "service", publicName: "service", isSignal: false, isRequired: false, transformFunction: null }, preloadFilter: { classPropertyName: "preloadFilter", publicName: "preloadFilter", isSignal: true, isRequired: false, transformFunction: null }, loadFrom: { classPropertyName: "loadFrom", publicName: "loadFrom", isSignal: false, isRequired: false, transformFunction: null }, frm: { classPropertyName: "frm", publicName: "frm", isSignal: false, isRequired: false, transformFunction: null }, lstTableFields: { classPropertyName: "lstTableFields", publicName: "lstTableFields", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { preloadFilter: "preloadFilterChange", WillRefresh: "WillRefresh", DidRefresh: "DidRefresh" }, ngImport: i0, template: '', isInline: true, styles: [""] }); }
2014
2018
  }
2015
2019
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: List, decorators: [{
2016
2020
  type: Component,
@@ -2023,6 +2027,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
2023
2027
  type: Input
2024
2028
  }], lstTableFields: [{
2025
2029
  type: Input
2030
+ }], WillRefresh: [{
2031
+ type: Output,
2032
+ args: ['WillRefresh']
2033
+ }], DidRefresh: [{
2034
+ type: Output,
2035
+ args: ['DidRefresh']
2026
2036
  }] } });
2027
2037
 
2028
2038
  var TelefoneCelular;