@po-ui/ng-sync 19.27.0 → 20.1.0

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.
Files changed (57) hide show
  1. package/fesm2022/po-ui-ng-sync.mjs +22 -22
  2. package/index.d.ts +1053 -3
  3. package/package.json +6 -6
  4. package/po-ui-ng-sync-20.1.0.tgz +0 -0
  5. package/schematics/migrations.json +7 -2
  6. package/schematics/ng-add/index.js +1 -1
  7. package/schematics/ng-update/v14/index.js +1 -1
  8. package/schematics/ng-update/v15/index.js +1 -1
  9. package/schematics/ng-update/v16/index.js +1 -1
  10. package/schematics/ng-update/v17/index.js +1 -1
  11. package/schematics/ng-update/v18/index.js +1 -1
  12. package/schematics/ng-update/v19/index.js +1 -1
  13. package/schematics/ng-update/v2/index.js +1 -1
  14. package/schematics/ng-update/v20/changes.d.ts +2 -0
  15. package/schematics/ng-update/v20/changes.js +14 -0
  16. package/schematics/ng-update/v20/changes.js.map +1 -0
  17. package/schematics/ng-update/v20/index.d.ts +1 -0
  18. package/schematics/ng-update/v20/index.js +16 -0
  19. package/schematics/ng-update/v20/index.js.map +1 -0
  20. package/schematics/ng-update/v3/index.js +1 -1
  21. package/schematics/ng-update/v4/index.js +1 -1
  22. package/schematics/ng-update/v5/index.js +1 -1
  23. package/schematics/ng-update/v6/index.js +1 -1
  24. package/lib/index.d.ts +0 -14
  25. package/lib/models/index.d.ts +0 -5
  26. package/lib/models/po-data-message.model.d.ts +0 -46
  27. package/lib/models/po-data-transform.model.d.ts +0 -52
  28. package/lib/models/po-entity/po-entity.model.d.ts +0 -122
  29. package/lib/models/po-event-sourcing-error-response.model.d.ts +0 -20
  30. package/lib/models/po-network-status.model.d.ts +0 -25
  31. package/lib/models/po-network-type.enum.d.ts +0 -28
  32. package/lib/models/po-query-builder/po-query-builder.model.d.ts +0 -126
  33. package/lib/models/po-request-type.enum.d.ts +0 -14
  34. package/lib/po-sync.module.d.ts +0 -11
  35. package/lib/services/po-event-sourcing/enums/po-event-sourcing-operation.enum.d.ts +0 -11
  36. package/lib/services/po-event-sourcing/index.d.ts +0 -3
  37. package/lib/services/po-event-sourcing/interfaces/po-event-sourcing-item.interface.d.ts +0 -26
  38. package/lib/services/po-event-sourcing/interfaces/po-event-sourcing-summary-item.interface.d.ts +0 -16
  39. package/lib/services/po-event-sourcing/po-event-sourcing.service.d.ts +0 -74
  40. package/lib/services/po-http-client/interfaces/po-http-header-option.interface.d.ts +0 -15
  41. package/lib/services/po-http-client/interfaces/po-http-request-data.interface.d.ts +0 -24
  42. package/lib/services/po-http-client/interfaces/po-response-api.interface.d.ts +0 -14
  43. package/lib/services/po-http-client/po-http-client.service.d.ts +0 -78
  44. package/lib/services/po-http-client/po-http-request-type.enum.d.ts +0 -23
  45. package/lib/services/po-network/po-network.service.d.ts +0 -35
  46. package/lib/services/po-schema/index.d.ts +0 -3
  47. package/lib/services/po-schema/po-schema-definition/po-schema-definition.service.d.ts +0 -51
  48. package/lib/services/po-schema/po-schema-util/po-schema-util.model.d.ts +0 -79
  49. package/lib/services/po-schema/po-schema.service.d.ts +0 -98
  50. package/lib/services/po-sync/interfaces/po-sync-config.interface.d.ts +0 -24
  51. package/lib/services/po-sync/interfaces/po-sync-field-options.interface.d.ts +0 -15
  52. package/lib/services/po-sync/interfaces/po-sync-response.interface.d.ts +0 -20
  53. package/lib/services/po-sync/interfaces/po-sync-schema.interface.d.ts +0 -37
  54. package/lib/services/po-sync/po-sync.service.d.ts +0 -162
  55. package/lib/utils/utils.d.ts +0 -36
  56. package/po-ui-ng-sync-19.27.0.tgz +0 -0
  57. package/public-api.d.ts +0 -1
@@ -1,126 +0,0 @@
1
- import { PoResponseApi } from './../../services/po-http-client/interfaces/po-response-api.interface';
2
- import { PoSchemaService } from './../../services/po-schema';
3
- import { PoSyncSchema } from '../../services/po-sync/interfaces/po-sync-schema.interface';
4
- /**
5
- * @description
6
- *
7
- * Classe utilitária para construir consultas sobre os registros de um *schema*.
8
- *
9
- * A utilização dos métodos desta classe é feita a partir do retorno do método `PoEntity.find()`. Por exemplo,
10
- * para utilizar o método `PoQueryBuilder.page()`, é necessário:
11
- *
12
- * ``` typescript
13
- * PoSyncService.getModel('schema name').find().page(2).exec();
14
- * ```
15
- *
16
- * O `PoQueryBuilder` foi projetado para que os seus métodos sejam
17
- * chamados em cascata e ao final desse encadeamento invocar o método
18
- * `PoQueryBuilder.exec()` para que a busca seja concluída. Por exemplo:
19
- *
20
- * ``` typescript
21
- * PoSyncService
22
- * .getModel('schema name')
23
- * .find()
24
- * .page(2)
25
- * .pageSize(5)
26
- * .sort()
27
- * .exec();
28
- * ```
29
- */
30
- export declare class PoQueryBuilder {
31
- private poSchemaService;
32
- private schema;
33
- private fields;
34
- private filters;
35
- private _limit;
36
- private _page;
37
- private _pageSize;
38
- private _sort;
39
- constructor(poSchemaService: PoSchemaService, schema: PoSyncSchema);
40
- /**
41
- * Ao final da chamada dos métodos do `PoQueryBuilder` utilizados, este método deve ser chamado para que a busca seja concluída.
42
- *
43
- * @return {Promise<PoResponseApi | object>} Registros do *schema* na qual foi aplicado a consulta.
44
- */
45
- exec(): Promise<PoResponseApi | object>;
46
- /**
47
- * Aplica filtros sobre os registros, baseados nos campos e valores definidos como filtro. Por exemplo:
48
- *
49
- * ```
50
- * PoQueryBuilder.filter({ name: 'Marie', age: 24 });
51
- * ```
52
- * Retorna todos os registros que contenham a propriedade `name` igual a Marie e `age` igual a 24.
53
- *
54
- * @param {object} filter Objeto que contém os campos e valores a serem filtrados no *schema*.
55
- *
56
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
57
- */
58
- filter(filter?: object): PoQueryBuilder;
59
- /**
60
- * Limita o número de registros que serão retornados.
61
- *
62
- * @param {number} limit Número de registros retornados.
63
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
64
- */
65
- limit(limit: number): PoQueryBuilder;
66
- /**
67
- * Especifica a página de registros que se deseja retornar.
68
- *
69
- * @param {number} page Número da página.
70
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
71
- */
72
- page(page: number): PoQueryBuilder;
73
- /**
74
- * Define quantos elementos serão retornados por página.
75
- *
76
- * @param {number} pageSize Número de registros por página.
77
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
78
- */
79
- pageSize(pageSize: number): PoQueryBuilder;
80
- /**
81
- * Utilizado para definir quais campos do *schema* serão retornados na consulta.
82
- *
83
- * @param {string} fields Campos que serão retornados nos registros. Este campos devem estar dentro de
84
- * uma *string* separados por espaço podendo usar o caractere `-` para excluir campos.
85
- * Por exemplo, a definição abaixo:
86
- *
87
- * ```
88
- * PoQueryBuilder.select('name age address');
89
- * ```
90
- * Irá retornar apenas os campos `name`, `age` e `address`. Para não retornar um campo ou mais basta fazer:
91
- *
92
- * ```
93
- * PoQueryBuilder.select('-name -age');
94
- * ```
95
- *
96
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
97
- */
98
- select(fields: string): PoQueryBuilder;
99
- /**
100
- * Ordena os registros por um campo.
101
- *
102
- * @param {string} field Campo a ser ordenado. Para ordenar de forma decrescente basta colocar o caractere `-`
103
- * na frente do campo. Por exemplo:
104
- * ```
105
- * PoQueryBuilder.sort('-name');
106
- * ```
107
- *
108
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
109
- */
110
- sort(field: string): PoQueryBuilder;
111
- /**
112
- * Essa função serve como alias para o `PoQueryBuilder.filter()`. É utilizada somente para dar maior legibilidade ao código.
113
- *
114
- * @param {object} filter Objeto que contém os campos e valores a serem filtrados no *schema*.
115
- * @returns {PoQueryBuilder} Objeto que possibilita encadear um novo método do `PoQueryBuilder`.
116
- */
117
- where(filter: object): PoQueryBuilder;
118
- private applyFields;
119
- private applyFilters;
120
- private groupFields;
121
- private paginate;
122
- private order;
123
- private removeDuplicate;
124
- private removeFieldsData;
125
- private removeRestrictedFields;
126
- }
@@ -1,14 +0,0 @@
1
- /**
2
- * @docsPrivate
3
- *
4
- * @description
5
- *
6
- * Método de requisição HTTP.
7
- */
8
- export declare enum PoRequestType {
9
- GET = "get",
10
- DELETE = "delete",
11
- DIFF = "diff",
12
- PATCH = "patch",
13
- POST = "post"
14
- }
@@ -1,11 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- /**
3
- * @description
4
- *
5
- * Módulo do componente PoSync responsável pela sincronia de dados com backends
6
- */
7
- export declare class PoSyncModule {
8
- static ɵfac: i0.ɵɵFactoryDeclaration<PoSyncModule, never>;
9
- static ɵmod: i0.ɵɵNgModuleDeclaration<PoSyncModule, never, never, never>;
10
- static ɵinj: i0.ɵɵInjectorDeclaration<PoSyncModule>;
11
- }
@@ -1,11 +0,0 @@
1
- /**
2
- * @docsPrivate
3
- *
4
- * Define as operações realizadas no sync.
5
- */
6
- export declare enum PoEventSourcingOperation {
7
- Delete = "DELETE",
8
- Http = "HTTP",
9
- Insert = "INSERT",
10
- Update = "UPDATE"
11
- }
@@ -1,3 +0,0 @@
1
- export * from './po-event-sourcing.service';
2
- export * from './enums/po-event-sourcing-operation.enum';
3
- export * from './interfaces/po-event-sourcing-summary-item.interface';
@@ -1,26 +0,0 @@
1
- import { PoEventSourcingOperation } from './../enums/po-event-sourcing-operation.enum';
2
- import { PoHttpRequestData } from '../../po-http-client/interfaces/po-http-request-data.interface';
3
- /**
4
- * @description
5
- *
6
- * Classe que irá mapear as informações dos `EventSourcing` gerados pela aplicação.
7
- */
8
- export interface PoEventSourcingItem {
9
- /** Valor numérico correspondente ao horário da data em que o registro foi criado de acordo com o horário universal. */
10
- dateTime: number;
11
- /** Identificador do registro. */
12
- id: number;
13
- /** Identificador customizado do registro. */
14
- customRequestId?: string;
15
- /**
16
- * Especifica a operação que deverá ser realizada na API.
17
- */
18
- operation: PoEventSourcingOperation;
19
- /** Objeto *json* com os dados do registro.
20
- *
21
- * > Caso a operação seja do tipo HTTP, o registro deverá ter a assinatura da interface `PoHttpOperationData`.
22
- */
23
- record: any | PoHttpRequestData;
24
- /** Nome do *schema* à qual se refere o `EventSourcing`. */
25
- schema?: string;
26
- }
@@ -1,16 +0,0 @@
1
- import { PoEventSourcingOperation } from '../enums/po-event-sourcing-operation.enum';
2
- /**
3
- * @docsPrivate
4
- *
5
- * @description
6
- *
7
- * Define as informações de um evento para um determinado registro.
8
- */
9
- export interface PoEventSourcingSummaryItem {
10
- /** Identificador customizado do registro. */
11
- customRequestId: string;
12
- /** Especifica a operação que deverá ser realizada na API. */
13
- operation: PoEventSourcingOperation;
14
- /** Objeto *json* com os dados do registro. */
15
- record: object;
16
- }
@@ -1,74 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { PoStorageService } from '@po-ui/ng-storage';
3
- import { PoEventSourcingSummaryItem } from './interfaces/po-event-sourcing-summary-item.interface';
4
- import { PoHttpClientService } from './../po-http-client/po-http-client.service';
5
- import { PoHttpRequestData } from '../po-http-client/interfaces/po-http-request-data.interface';
6
- import { PoSchemaDefinitionService } from './../po-schema/po-schema-definition/po-schema-definition.service';
7
- import { PoSchemaService } from './../po-schema/po-schema.service';
8
- import { PoSyncConfig } from '../po-sync/interfaces/po-sync-config.interface';
9
- import { PoSyncResponse } from '../po-sync/interfaces/po-sync-response.interface';
10
- import * as i0 from "@angular/core";
11
- export declare class PoEventSourcingService {
12
- private poSchemaDefinition;
13
- private poSchemaService;
14
- private poStorage;
15
- private poHttpClient;
16
- static readonly event_sourcing_name: string;
17
- private static readonly VALID_HTTP_STATUS_CODES;
18
- config: PoSyncConfig;
19
- stoppedQueueEventSourcing: boolean;
20
- private emitter;
21
- private eventSub;
22
- private responseSubject;
23
- private schemasSyncConfig;
24
- constructor(poSchemaDefinition: PoSchemaDefinitionService, poSchemaService: PoSchemaService, poStorage: PoStorageService, poHttpClient: PoHttpClientService);
25
- private static getUrl;
26
- create(schemaName: string, newItem: any, customRequestId?: string): Promise<any>;
27
- createBatchEvents(schemaName: string, eventList: Array<PoEventSourcingSummaryItem>): Promise<void>;
28
- /**
29
- * Destrói a chave do *storage* que contém a fila de dados que estão esperando para serem enviados ao
30
- * servidor *(EventSourcing)*.
31
- *
32
- * @returns {Promise<void>} Promessa que é resolvida quando a chave referente a fila de *EventSourcing* for destruída.
33
- */
34
- destroyEventSourcingQueue(): Promise<void>;
35
- httpCommand(httpOperationData: PoHttpRequestData, customRequestId?: string): Promise<number>;
36
- responsesSubject(): Observable<PoSyncResponse>;
37
- onSaveData(): Observable<null>;
38
- remove(schemaName: string, itemToDelete: any, customRequestId?: string): Promise<any>;
39
- removeEventSourcingItem(idEventSourcingItem: any): Promise<any>;
40
- syncGet(): Promise<any>;
41
- syncSend(): Promise<any>;
42
- update(schemaName: string, itemUpdated: any, customRequestId?: string): Promise<any>;
43
- private serializeBody;
44
- private buildUrlParams;
45
- private checkRecordIdExists;
46
- private concatPageItems;
47
- private createEventSourcingItem;
48
- private createEventSourcingList;
49
- private createSchemaSyncConfig;
50
- private deleteOperation;
51
- private diffServerItems;
52
- private getBodyAndDate;
53
- private getServerDiffRecords;
54
- private httpOperation;
55
- private insertEventSourcingQueue;
56
- private insertOperation;
57
- private isValidStatus;
58
- private notifyEventCreation;
59
- private paginateSchemaData;
60
- private removeEventSourcingValidItem;
61
- private selectOperation;
62
- private sendResponseSubject;
63
- private sendServerItem;
64
- private createPoHttpRequestData;
65
- private createFormData;
66
- private updateOperation;
67
- private updatePendingEventSourcing;
68
- private updateRecords;
69
- private updateRecordByServerRecord;
70
- private updateStorageBySchema;
71
- private updateStorageSchemas;
72
- static ɵfac: i0.ɵɵFactoryDeclaration<PoEventSourcingService, never>;
73
- static ɵprov: i0.ɵɵInjectableDeclaration<PoEventSourcingService>;
74
- }
@@ -1,15 +0,0 @@
1
- /**
2
- * @docsPrivate
3
- *
4
- * @usedBy PoHttpClientService
5
- *
6
- * @description
7
- *
8
- * Define o cabeçalho da requisição HTTP.
9
- */
10
- export interface PoHttpHeaderOption {
11
- /** Nome do cabeçalho. */
12
- name: string;
13
- /** Valor do cabeçalho. */
14
- value: string;
15
- }
@@ -1,24 +0,0 @@
1
- import { PoHttpHeaderOption } from './po-http-header-option.interface';
2
- import { PoHttpRequestType } from './../po-http-request-type.enum';
3
- /**
4
- * @usedBy PoSyncService
5
- *
6
- * @description
7
- *
8
- * Interface para definição de uma requisição HTTP.
9
- */
10
- export interface PoHttpRequestData {
11
- /** URL que será utilizada na requisição. */
12
- url: string;
13
- /** Cabeçalho da requisição. */
14
- headers?: Array<PoHttpHeaderOption>;
15
- /** Método HTTP que será utilizado. */
16
- method: PoHttpRequestType;
17
- /** Corpo da requisição. */
18
- body?: any;
19
- /** Nome da propriedade que conterá o arquivo enviado para o servidor */
20
- formField?: string;
21
- bodyType?: string;
22
- mimeType?: string;
23
- fileName?: string;
24
- }
@@ -1,14 +0,0 @@
1
- /**
2
- * @usedBy PoQueryBuilder
3
- *
4
- * @description
5
- *
6
- * Interface que representa a estrutura de resposta de uma coleção de itens.
7
- *
8
- */
9
- export interface PoResponseApi {
10
- /** Lista de itens retornados. */
11
- items: Array<object>;
12
- /** Indica se existe uma próxima página com mais registros para aquela coleção de itens. */
13
- hasNext: boolean;
14
- }
@@ -1,78 +0,0 @@
1
- import { HttpClient, HttpResponse } from '@angular/common/http';
2
- import { Observable } from 'rxjs';
3
- import { PoHttpHeaderOption } from './interfaces/po-http-header-option.interface';
4
- import { PoHttpRequestData } from './interfaces/po-http-request-data.interface';
5
- import * as i0 from "@angular/core";
6
- /**
7
- * @docsPrivate
8
- *
9
- * @description
10
- *
11
- * Serviço para execução de requisições HTTP.
12
- */
13
- export declare class PoHttpClientService {
14
- private httpClient;
15
- constructor(httpClient: HttpClient);
16
- /**
17
- * Constrói uma requisição HTTP personalizada.
18
- *
19
- * @param {PoHttpRequestData} poHttpOperationData Parâmetros para a construção
20
- * da requisição.
21
- */
22
- createRequest(poHttpOperationData: PoHttpRequestData): Observable<HttpResponse<object>>;
23
- /**
24
- * Constrói uma requisição com o método `delete`.
25
- *
26
- * @param {string} url URL da requisição.
27
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
28
- */
29
- delete(url: string, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
30
- /**
31
- * Constrói uma requisição com o método `get`.
32
- *
33
- * @param {string} url URL da requisição.
34
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
35
- */
36
- get(url: string, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
37
- /**
38
- * Constrói uma requisição com o método `head`.
39
- *
40
- * @param {string} url URL da requisição.
41
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
42
- */
43
- head(url: string, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
44
- /**
45
- * Constrói uma requisição com o método `options`.
46
- *
47
- * @param {string} url URL da requisição.
48
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
49
- */
50
- options(url: string, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
51
- /**
52
- * Constrói uma requisição com o método `patch`.
53
- *
54
- * @param {string} url URL da requisição.
55
- * @param {any} body Corpo da requisição.
56
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
57
- */
58
- patch(url: string, body?: any, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
59
- /**
60
- * Constrói uma requisição com o método `post`.
61
- *
62
- * @param {string} url URL da requisição.
63
- * @param {any} body Corpo da requisição.
64
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
65
- */
66
- post(url: string, body?: any, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
67
- /**
68
- * Constrói uma requisição com o método `put`.
69
- *
70
- * @param {string} url URL da requisição.
71
- * @param {any} body Corpo da requisição.
72
- * @param {Array<PoHeaderOption>} httpHeaders Cabeçalhos da requisição.
73
- */
74
- put(url: string, body?: any, httpHeaders?: Array<PoHttpHeaderOption>): Observable<HttpResponse<object>>;
75
- private createHttpHeaders;
76
- static ɵfac: i0.ɵɵFactoryDeclaration<PoHttpClientService, never>;
77
- static ɵprov: i0.ɵɵInjectableDeclaration<PoHttpClientService>;
78
- }
@@ -1,23 +0,0 @@
1
- /**
2
- * @usedBy PoHttpClientService, PoHttpCommandResponse, PoSyncService
3
- *
4
- * @description
5
- *
6
- * Define o método de requisição HTTP.
7
- */
8
- export declare enum PoHttpRequestType {
9
- /** Método `delete` do protocolo HTTP. */
10
- DELETE = "DELETE",
11
- /** Método `get` do protocolo HTTP. */
12
- GET = "GET",
13
- /** Método `head` do protocolo HTTP. */
14
- HEAD = "HEAD",
15
- /** Método `options` do protocolo HTTP. */
16
- OPTIONS = "OPTIONS",
17
- /** Método `patch` do protocolo HTTP. */
18
- PATCH = "PATCH",
19
- /** Método `post` do protocolo HTTP. */
20
- POST = "POST",
21
- /** Método `put` do protocolo HTTP. */
22
- PUT = "PUT"
23
- }
@@ -1,35 +0,0 @@
1
- import { Observable } from 'rxjs';
2
- import { PoNetworkStatus } from './../../models';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * @description
6
- *
7
- * O `PoNetworkService` é utilizado para verificar o status e o tipo da conexão de rede do dispositivo.
8
- */
9
- export declare class PoNetworkService {
10
- private networkType;
11
- private networkTypeNow;
12
- private poNetworkStatus;
13
- constructor();
14
- /**
15
- * Retorna as propriedades tipo e status da conexão do dispositivo no momento da chamada.
16
- *
17
- * @returns {PoNetworkStatus} Instância de [PoNetworkStatus](/documentation/po-network-status) com as
18
- * propriedades da conexão.
19
- */
20
- getConnectionStatus(): PoNetworkStatus;
21
- /**
22
- * Notifica as mudanças no tipo de conexão de rede do dispositivo.
23
- *
24
- * @returns {Observable<{ status: boolean, type: string }>} Observable com as propriedades da conexão.
25
- */
26
- onChange(): Observable<{
27
- status: boolean;
28
- type: string;
29
- }>;
30
- private initNetwork;
31
- private getStatus;
32
- private initSubscriber;
33
- static ɵfac: i0.ɵɵFactoryDeclaration<PoNetworkService, never>;
34
- static ɵprov: i0.ɵɵInjectableDeclaration<PoNetworkService>;
35
- }
@@ -1,3 +0,0 @@
1
- export * from './po-schema-definition/po-schema-definition.service';
2
- export * from './po-schema.service';
3
- export * from './po-schema-util/po-schema-util.model';
@@ -1,51 +0,0 @@
1
- import { PoStorageService } from '@po-ui/ng-storage';
2
- import { PoSyncSchema } from './../../po-sync/interfaces/po-sync-schema.interface';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * @docsPrivate
6
- *
7
- * @description
8
- *
9
- * Serviço que disponibiliza métodos que permite operar sobre as definições dos *schemas*.
10
- */
11
- export declare class PoSchemaDefinitionService {
12
- private poStorage;
13
- constructor(poStorage: PoStorageService);
14
- /**
15
- * Destrói a chave do *storage* que contém as definições dos *schemas*.
16
- *
17
- * > Para que não venham ocorrer erros em ações que dependam das definições dos *schemas*,
18
- * recomenda-se utilizar o método `prepare()` em seguida.
19
- *
20
- * @returns {Promise<void>} Promessa que é resolvida quando a chave referente as definições dos *schemas* for destruída.
21
- */
22
- destroy(): Promise<void>;
23
- /**
24
- * Busca um *schema* a partir do nome informado.
25
- *
26
- * @param {string} schemaName Nome do *schema*.
27
- * @returns {Promise<PoSyncSchema>} Promessa que é resolvida quando o *schema* for retornado.
28
- */
29
- get(schemaName: string): Promise<PoSyncSchema>;
30
- /**
31
- * Retorna uma promessa com a lista dos *schemas* definidos.
32
- *
33
- * @returns {Promise<Array<PoSyncSchema>>} Promessa que é resolvida quando a lista dos *schemas* definidos for retornada.
34
- */
35
- getAll(): Promise<Array<PoSyncSchema>>;
36
- /**
37
- * Salva uma lista de *schemas*.
38
- *
39
- * @param {Array<PoSyncSchema>} schemas Lista de schemas que serão salvos.
40
- * @returns {Promise<Array<PoSyncSchema>>} Promessa que é resolvida quando a lista de *schemas* for salva.
41
- */
42
- saveAll(schemas: Array<PoSyncSchema>): Promise<Array<PoSyncSchema>>;
43
- /**
44
- * Atualiza um *schema* a partir do *schema name*.
45
- *
46
- * @param {PoSyncSchema} updatedSchema **Schema* que será atualizado.
47
- */
48
- update(updatedSchema: PoSyncSchema): Promise<PoSyncSchema[]>;
49
- static ɵfac: i0.ɵɵFactoryDeclaration<PoSchemaDefinitionService, never>;
50
- static ɵprov: i0.ɵɵInjectableDeclaration<PoSchemaDefinitionService>;
51
- }
@@ -1,79 +0,0 @@
1
- import { PoRequestType } from '../../../models/po-request-type.enum';
2
- import { PoSyncSchema } from '../../po-sync/interfaces/po-sync-schema.interface';
3
- /**
4
- * @docsPrivate
5
- *
6
- * @description
7
- *
8
- * Serviço utilitário para operações no PoSyncSchema.
9
- */
10
- export declare class PoSchemaUtil {
11
- /** Valor `default` para o campo `lastSync`. */
12
- static readonly defaultLastSync: string;
13
- /** Nome da chave do identificador interno do sync. */
14
- static readonly syncInternalIdFieldName: string;
15
- /** Nome da chave no `storage` para os Schemas. */
16
- static readonly syncSchemasName: string;
17
- /**
18
- * Verica se existem campos locais no *schema* informado.
19
- *
20
- * @param {PoSyncSchema} schema **Schema* a ser processado.
21
- *
22
- * @returns {boolean} Valor do tipo *boolean* que indica se existem campos locais no *schema* informado.
23
- */
24
- static containsLocalFields(schema: PoSyncSchema): boolean;
25
- /**
26
- * Retorna o valor atual do `lastSync` para determinado *schema*.
27
- *
28
- * @param {Array<PoSyncSchema>} storageSchemas Lista de *schemas* a serem pesquisados.
29
- * @param {string} schemaName Nome do *schema* que se deseja ler o lastSync.
30
- *
31
- * @returns {string} Retorna uma *string* com o valor da última sincronização.
32
- */
33
- static getLastSync(storageSchemas: Array<PoSyncSchema>, schemaName: string): string;
34
- /**
35
- * Retorna a lista de campos locais definidos no *schema*.
36
- *
37
- * @param {PoSyncSchema} schema **Schema* a ser processado.
38
- */
39
- static getLocalFieldNames(schema: PoSyncSchema): Array<string>;
40
- /**
41
- * Retorna a lista de campos não locais definidos no *schema*.
42
- *
43
- * @param {PoSyncSchema} schema **Schema* a ser processado.
44
- */
45
- static getNonLocalFieldNames(schema: PoSyncSchema): Array<string>;
46
- /**
47
- * Retorna o `id` referente ao registro do *schema* informado.
48
- *
49
- * @param {object} record Registro que será buscado o id.
50
- * @param {PoSyncSchema} schema **Schema* a ser processado.
51
- */
52
- static getRecordId(record: object, schema: PoSyncSchema): any;
53
- /**
54
- * Retorna a url correspondente do `PoSyncSchema` dependendo do tipo da requisição `PoRequestType`.
55
- *
56
- * @param {PoSyncSchema} schema **Schema* a ser processado.
57
- * @param {PoRequestType} requestType Tipo da requisição.
58
- */
59
- static getUrl(schema: PoSyncSchema, requestType: PoRequestType): string;
60
- /**
61
- * Compara se dois objetos são iguais baseado na lista de campos.
62
- *
63
- * @param {Array<string>} fields Lista de campos a serem considerados na comparação.
64
- * @param {any} model1 Objeto 1 a ser comparado.
65
- * @param {any} model2 Objeto 2 a ser comparado.
66
- */
67
- static isModelsEqual(fields: Array<string>, model1: any, model2: any): boolean;
68
- /**
69
- * Retorna uma lista com dois objetos referentes ao registro informado.
70
- * O primeiro é o registro com os campos que vão para o servidor e o segundo é com os campos locais.
71
- *
72
- * @param {PoSyncSchema} schema **Schema* do registro.
73
- * @param {object} record Registro que será realizada a separação dos campos locais e do servidor.
74
- */
75
- static separateSchemaFields(schema: PoSyncSchema, record: object): {
76
- serverRecord: object;
77
- localRecord: object;
78
- };
79
- }