@sankhyalabs/sankhyablocks 9.1.0-dev.19 → 9.1.0-dev.20
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.
- package/dist/cjs/snk-application.cjs.entry.js +231 -57
- package/dist/collection/components/snk-application/snk-application.js +1247 -314
- package/dist/components/snk-application2.js +231 -57
- package/dist/esm/snk-application.entry.js +231 -57
- package/dist/types/components/snk-application/snk-application.d.ts +245 -63
- package/dist/types/components.d.ts +235 -44
- package/package.json +1 -1
@@ -616,22 +616,24 @@ const SnkApplication = class {
|
|
616
616
|
}
|
617
617
|
/**
|
618
618
|
* Obtém o controlador de teclado.
|
619
|
-
*
|
620
|
-
* @
|
619
|
+
* @returns {Promise<KeyboardManager>} O gerenciador de teclado.
|
620
|
+
* @async
|
621
621
|
*/
|
622
622
|
async getKeyboardManager() {
|
623
623
|
return Promise.resolve(this._keyboardManager);
|
624
624
|
}
|
625
625
|
/**
|
626
|
-
* Obtém o notificador de Layout de
|
627
|
-
*
|
628
|
-
* @
|
626
|
+
* Obtém o notificador de Layout de formulário.
|
627
|
+
* @returns {Promise<LayoutFormConfig>} O configurador de Layout do Formulário.
|
628
|
+
* @async
|
629
629
|
*/
|
630
630
|
async getLayoutFormConfig() {
|
631
631
|
return Promise.resolve(this._LayoutFormConfigSingleton);
|
632
632
|
}
|
633
633
|
/**
|
634
634
|
* Obtém `true` caso o usuário logado seja o SUP.
|
635
|
+
* @returns {Promise<boolean>} `true` se o usuário for SUP, `false` caso contrário.
|
636
|
+
* @async
|
635
637
|
*/
|
636
638
|
async isUserSup() {
|
637
639
|
return new Promise((resolve, reject) => {
|
@@ -644,9 +646,10 @@ const SnkApplication = class {
|
|
644
646
|
}
|
645
647
|
/**
|
646
648
|
* Adiciona uma ação pendente que deve ser executada por um determinado locker.
|
647
|
-
*
|
648
|
-
* @param
|
649
|
-
* @
|
649
|
+
* @param {string} actionsLocker - Nome do locker da ação que será adicionada.
|
650
|
+
* @param {Function} action - Ação que será executada.
|
651
|
+
* @returns {Promise<void>}
|
652
|
+
* @async
|
650
653
|
*/
|
651
654
|
async addPendingAction(actionsLocker, action) {
|
652
655
|
var _a;
|
@@ -654,15 +657,22 @@ const SnkApplication = class {
|
|
654
657
|
this._pendingActions.set(actionsLocker, [...actionsFromContext, action]);
|
655
658
|
}
|
656
659
|
/**
|
657
|
-
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
660
|
+
* Realiza a chamada ao Service Broker conforme o nome do serviço.
|
661
|
+
* @param {string} serviceName - Nome do serviço.
|
662
|
+
* @param {string | Object} payload - Dados que serão processados na ação.
|
663
|
+
* @param {Options} [options] - Parâmetros de URL.
|
664
|
+
* @returns {Promise<any>} A resposta do Service Broker.
|
665
|
+
* @async
|
666
|
+
*/
|
663
667
|
async callServiceBroker(serviceName, payload, options) {
|
664
668
|
return DataFetcher.DataFetcher.get().callServiceBroker(serviceName, payload, options);
|
665
669
|
}
|
670
|
+
/**
|
671
|
+
* Inicializa o onboarding para uma chave específica.
|
672
|
+
* @param {string} onboardingKey - A chave do onboarding a ser iniciado.
|
673
|
+
* @returns {Promise<void>}
|
674
|
+
* @async
|
675
|
+
*/
|
666
676
|
async initOnboarding(onboardingKey) {
|
667
677
|
if (this.hasToShowNewVersionPopup()) {
|
668
678
|
await this.addPendingAction(this.NEW_VERSION_POPUP_LOCKER, () => this.doInitOnboarding(onboardingKey));
|
@@ -674,7 +684,11 @@ const SnkApplication = class {
|
|
674
684
|
core.OnboardingUtils.getInstance().init(onboardingKey, window.envContext);
|
675
685
|
}
|
676
686
|
/**
|
677
|
-
* Obtém `true` caso o usuário logado
|
687
|
+
* Obtém `true` caso o usuário logado tenha permissão para determinada ação.
|
688
|
+
* @param {AutorizationType} access - O tipo de acesso a ser verificado.
|
689
|
+
* @param {string} [resourceID] - O ID do recurso para verificar a permissão. Se não fornecido, verifica a permissão da aplicação.
|
690
|
+
* @returns {Promise<boolean>} `true` se o usuário tiver acesso, `false` caso contrário.
|
691
|
+
* @async
|
678
692
|
*/
|
679
693
|
async hasAccess(access, resourceID) {
|
680
694
|
return new Promise((resolve, reject) => {
|
@@ -686,7 +700,10 @@ const SnkApplication = class {
|
|
686
700
|
});
|
687
701
|
}
|
688
702
|
/**
|
689
|
-
* Obtém todos os acessos do usuário logado.
|
703
|
+
* Obtém todos os acessos do usuário logado para um recurso específico ou para a aplicação.
|
704
|
+
* @param {string} [resourceID] - O ID do recurso. Se não fornecido, obtém os acessos da aplicação.
|
705
|
+
* @returns {Promise<any>} Um objeto contendo todos os tipos de acesso e se o usuário os possui.
|
706
|
+
* @async
|
690
707
|
*/
|
691
708
|
async getAllAccess(resourceID) {
|
692
709
|
return new Promise((resolve, reject) => {
|
@@ -711,36 +728,57 @@ const SnkApplication = class {
|
|
711
728
|
}
|
712
729
|
/**
|
713
730
|
* Obtém o valor de um parâmetro do tipo string.
|
731
|
+
* @param {string} name - O nome do parâmetro.
|
732
|
+
* @returns {Promise<string>} O valor do parâmetro como string.
|
733
|
+
* @async
|
714
734
|
*/
|
715
735
|
async getStringParam(name) {
|
716
736
|
return this.parameters.asString(name);
|
717
737
|
}
|
718
738
|
/**
|
719
739
|
* Obtém o valor de um parâmetro do tipo Inteiro.
|
740
|
+
* @param {string} name - O nome do parâmetro.
|
741
|
+
* @returns {Promise<number>} O valor do parâmetro como número inteiro.
|
742
|
+
* @async
|
720
743
|
*/
|
721
744
|
async getIntParam(name) {
|
722
745
|
return this.parameters.asInteger(name);
|
723
746
|
}
|
724
747
|
/**
|
725
748
|
* Obtém o valor de um parâmetro do tipo Decimal.
|
749
|
+
* @param {string} name - O nome do parâmetro.
|
750
|
+
* @returns {Promise<number>} O valor do parâmetro como número decimal.
|
751
|
+
* @async
|
726
752
|
*/
|
727
753
|
async getFloatParam(name) {
|
728
754
|
return this.parameters.asFloat(name);
|
729
755
|
}
|
730
756
|
/**
|
731
757
|
* Obtém o valor de um parâmetro do tipo booleano.
|
758
|
+
* @param {string} name - O nome do parâmetro.
|
759
|
+
* @returns {Promise<boolean>} O valor do parâmetro como booleano.
|
760
|
+
* @async
|
732
761
|
*/
|
733
762
|
async getBooleanParam(name) {
|
734
763
|
return this.parameters.asBoolean(name);
|
735
764
|
}
|
736
765
|
/**
|
737
766
|
* Obtém o valor de um parâmetro do tipo data.
|
767
|
+
* @param {string} name - O nome do parâmetro.
|
768
|
+
* @returns {Promise<Date>} O valor do parâmetro como objeto Date.
|
769
|
+
* @async
|
738
770
|
*/
|
739
771
|
async getDateParam(name) {
|
740
772
|
return this.parameters.asDate(name);
|
741
773
|
}
|
742
774
|
/**
|
743
775
|
* Exibe o conteúdo passado em um Popup.
|
776
|
+
* @param {HTMLElement} content - O elemento HTML a ser exibido no popup.
|
777
|
+
* @param {"auto" | "full"} [size="full"] - O tamanho do popup.
|
778
|
+
* @param {boolean} [useHeader=true] - Define se o cabeçalho do popup deve ser usado.
|
779
|
+
* @param {Function} [onCloseCallback] - Função a ser chamada quando o popup for fechado.
|
780
|
+
* @returns {Promise<void>}
|
781
|
+
* @async
|
744
782
|
*/
|
745
783
|
async showPopUp(content, size = "full", useHeader = true, onCloseCallback) {
|
746
784
|
this.clearContent(this._popUp);
|
@@ -757,6 +795,9 @@ const SnkApplication = class {
|
|
757
795
|
}
|
758
796
|
/**
|
759
797
|
* Exibe o conteúdo passado em um Modal.
|
798
|
+
* @param {HTMLElement} content - O elemento HTML a ser exibido no modal.
|
799
|
+
* @returns {Promise<void>}
|
800
|
+
* @async
|
760
801
|
*/
|
761
802
|
async showModal(content) {
|
762
803
|
this.clearContent(this._rightModal);
|
@@ -764,15 +805,18 @@ const SnkApplication = class {
|
|
764
805
|
this._rightModal.opened = true;
|
765
806
|
}
|
766
807
|
/**
|
767
|
-
* Apresenta uma lista de alertas
|
768
|
-
*
|
769
|
-
* de
|
808
|
+
* Apresenta uma lista de alertas.
|
809
|
+
* Geralmente é utilizado para apresentar resultados de processamentos em lote.
|
810
|
+
* @param {Array<AlertItem>} alerts - A lista de alertas a serem exibidos.
|
811
|
+
* @returns {Promise<void>}
|
770
812
|
*/
|
771
813
|
showAlerts(alerts) {
|
772
814
|
return utils.ApplicationUtils.showAlerts({ alerts });
|
773
815
|
}
|
774
816
|
/**
|
775
817
|
* Fecha o Modal e limpa o conteúdo.
|
818
|
+
* @returns {Promise<void>}
|
819
|
+
* @async
|
776
820
|
*/
|
777
821
|
async closeModal() {
|
778
822
|
this.clearContent(this._rightModal);
|
@@ -780,6 +824,8 @@ const SnkApplication = class {
|
|
780
824
|
}
|
781
825
|
/**
|
782
826
|
* Fecha o Popup e limpa o conteúdo.
|
827
|
+
* @returns {Promise<void>}
|
828
|
+
* @async
|
783
829
|
*/
|
784
830
|
async closePopUp() {
|
785
831
|
this.clearContent(this._popUp);
|
@@ -788,7 +834,10 @@ const SnkApplication = class {
|
|
788
834
|
this._popUp.heightMode = "full";
|
789
835
|
}
|
790
836
|
/**
|
791
|
-
* Verifica se a licença do cliente tem determinado opcional (produto)
|
837
|
+
* Verifica se a licença do cliente tem determinado opcional (produto).
|
838
|
+
* @param {string} opcional - O nome do opcional ou uma string de opcionais separados por vírgula.
|
839
|
+
* @returns {Promise<boolean>} `true` se o cliente tiver o opcional, `false` caso contrário.
|
840
|
+
* @async
|
792
841
|
*/
|
793
842
|
async temOpcional(opcional) {
|
794
843
|
const opts = opcional.split(",");
|
@@ -814,7 +863,10 @@ const SnkApplication = class {
|
|
814
863
|
});
|
815
864
|
}
|
816
865
|
/**
|
817
|
-
* Obtém a configuração de um recurso por service broker
|
866
|
+
* Obtém a configuração de um recurso por service broker.
|
867
|
+
* @param {string} key - A chave da configuração.
|
868
|
+
* @returns {Promise<any>} Os dados da configuração.
|
869
|
+
* @async
|
818
870
|
*/
|
819
871
|
async getConfig(key) {
|
820
872
|
let payload = {
|
@@ -858,6 +910,10 @@ const SnkApplication = class {
|
|
858
910
|
}
|
859
911
|
/**
|
860
912
|
* Salva a configuração de determinado recurso.
|
913
|
+
* @param {string} key - A chave da configuração.
|
914
|
+
* @param {Object} data - Os dados da configuração a serem salvos.
|
915
|
+
* @returns {Promise<any>} O resultado da operação de salvamento.
|
916
|
+
* @async
|
861
917
|
*/
|
862
918
|
async saveConfig(key, data) {
|
863
919
|
let payload = {
|
@@ -879,21 +935,30 @@ const SnkApplication = class {
|
|
879
935
|
}
|
880
936
|
/**
|
881
937
|
* Acessa informações de contexto "empurrados" na abertura da tela.
|
938
|
+
* @param {string} attribName - O nome do atributo.
|
939
|
+
* @returns {Promise<string>} O valor do atributo.
|
940
|
+
* @async
|
882
941
|
*/
|
883
942
|
async getAttributeFromHTMLWrapper(attribName) {
|
884
943
|
return Promise.resolve(window[attribName]);
|
885
944
|
}
|
886
945
|
/**
|
887
946
|
* Abre determinada tela, repassando pkObject.
|
947
|
+
* @param {string} resourceId - O ID do recurso da tela a ser aberta.
|
948
|
+
* @param {Object} pkObject - O objeto de chave primária a ser passado para a tela.
|
949
|
+
* @returns {Promise<void>}
|
950
|
+
* @async
|
888
951
|
*/
|
889
952
|
async openApp(resourceId, pkObject) {
|
890
953
|
Workspace.openAppActivity(resourceId, pkObject);
|
891
954
|
}
|
892
955
|
/**
|
893
956
|
* Realiza a chamada do WebConnection para realizar a exportação de arquivo.
|
894
|
-
* @param keyPort - Chave da porta que será requisitada.
|
895
|
-
* @param methodName - Nome do tipo de exportação de arquivo que será realizado.
|
896
|
-
* @param params - Parâmetros necessários para realizar a exportação do arquivo.
|
957
|
+
* @param {string} keyPort - Chave da porta que será requisitada.
|
958
|
+
* @param {string} methodName - Nome do tipo de exportação de arquivo que será realizado.
|
959
|
+
* @param {IAppletCallerParams} params - Parâmetros necessários para realizar a exportação do arquivo.
|
960
|
+
* @returns {Promise<void>}
|
961
|
+
* @async
|
897
962
|
*/
|
898
963
|
async webConnection(keyPort, methodName, params) {
|
899
964
|
this.getStringParam(keyPort).then((port) => {
|
@@ -914,6 +979,13 @@ const SnkApplication = class {
|
|
914
979
|
/**
|
915
980
|
* Cria o DataUnit a partir do nome da entidade. É possível armazená-lo no cache
|
916
981
|
* passando o dataUnitName, assim, se mais de uma chamada for feita, o mesmo DataUnit será usado.
|
982
|
+
* @param {string} entityName - O nome da entidade.
|
983
|
+
* @param {string} [dataUnitName] - O nome para identificar o DataUnit no cache.
|
984
|
+
* @param {DataUnit} [parentDataUnit] - O DataUnit pai, se houver.
|
985
|
+
* @param {string} [configName] - O nome da configuração a ser usada.
|
986
|
+
* @param {string} [resourceID] - O ID do recurso. Se não fornecido, usa o da aplicação.
|
987
|
+
* @returns {Promise<DataUnit>} O DataUnit criado ou obtido do cache.
|
988
|
+
* @async
|
917
989
|
*/
|
918
990
|
async createDataunit(entityName, dataUnitName, parentDataUnit, configName, resourceID) {
|
919
991
|
if (resourceID == undefined) {
|
@@ -945,9 +1017,11 @@ const SnkApplication = class {
|
|
945
1017
|
}
|
946
1018
|
/**
|
947
1019
|
* Atualiza o cache de dataunits da aplicação.
|
948
|
-
* @param oldName - Nome do dataunit que está em cache.
|
949
|
-
* @param dataUnitName - Nome do dataunit que será armazenado em cache.
|
950
|
-
* @param dataUnit -
|
1020
|
+
* @param {string} oldName - Nome do dataunit que está em cache (será removido).
|
1021
|
+
* @param {string} dataUnitName - Nome do dataunit que será armazenado em cache.
|
1022
|
+
* @param {DataUnit} dataUnit - Instância do Dataunit para ser armazenado em cache.
|
1023
|
+
* @returns {Promise<void>}
|
1024
|
+
* @async
|
951
1025
|
*/
|
952
1026
|
async updateDataunitCache(oldName, dataUnitName, dataUnit) {
|
953
1027
|
if (oldName) {
|
@@ -956,7 +1030,14 @@ const SnkApplication = class {
|
|
956
1030
|
this._duCache.set(dataUnitName, dataUnit);
|
957
1031
|
}
|
958
1032
|
/**
|
959
|
-
*
|
1033
|
+
* Obtém um DataUnit do cache ou cria um caso ainda não tenha sido criado.
|
1034
|
+
* @param {string} entityName - O nome da entidade.
|
1035
|
+
* @param {string} dataUnitName - O nome para identificar o DataUnit no cache.
|
1036
|
+
* @param {DataUnit} [parentDataUnit] - O DataUnit pai, se houver.
|
1037
|
+
* @param {string} [configName] - O nome da configuração a ser usada.
|
1038
|
+
* @param {string} [resourceID] - O ID do recurso. Se não fornecido, usa o da aplicação.
|
1039
|
+
* @returns {Promise<DataUnit>} O DataUnit obtido do cache ou recém-criado.
|
1040
|
+
* @async
|
960
1041
|
*/
|
961
1042
|
async getDataUnit(entityName, dataUnitName, parentDataUnit, configName, resourceID) {
|
962
1043
|
return new Promise((resolve, reject) => {
|
@@ -973,9 +1054,10 @@ const SnkApplication = class {
|
|
973
1054
|
}
|
974
1055
|
/**
|
975
1056
|
* Registra um client event para o DataFetcher da aplicação.
|
976
|
-
*
|
977
|
-
* @param
|
978
|
-
* @
|
1057
|
+
* @param {String} eventID - Nome do evento para a aplicação se registrar.
|
1058
|
+
* @param {(clientEvent: IClientEventResponse, dataFetcherReacaller: IDataFetcherRecaller) => void} handler - Função de callback que será chamada quando o client event ocorrer.
|
1059
|
+
* @returns {Promise<void>}
|
1060
|
+
* @async
|
979
1061
|
*/
|
980
1062
|
async addClientEvent(eventID, handler) {
|
981
1063
|
return new Promise((resolve) => {
|
@@ -984,9 +1066,10 @@ const SnkApplication = class {
|
|
984
1066
|
});
|
985
1067
|
}
|
986
1068
|
/**
|
987
|
-
* Remove um client event
|
988
|
-
*
|
989
|
-
* @
|
1069
|
+
* Remove um client event do DataFetcher da aplicação.
|
1070
|
+
* @param {String} eventID - Nome do evento a ser removido.
|
1071
|
+
* @returns {Promise<void>}
|
1072
|
+
* @async
|
990
1073
|
*/
|
991
1074
|
async removeClientEvent(eventID) {
|
992
1075
|
return new Promise((resolve) => {
|
@@ -995,9 +1078,10 @@ const SnkApplication = class {
|
|
995
1078
|
});
|
996
1079
|
}
|
997
1080
|
/**
|
998
|
-
*
|
999
|
-
*
|
1000
|
-
* @
|
1081
|
+
* Verifica se um client event está registrado no DataFetcher da aplicação.
|
1082
|
+
* @param {String} eventID - Nome do evento a ser verificado.
|
1083
|
+
* @returns {Promise<boolean>} `true` se o evento estiver registrado, `false` caso contrário.
|
1084
|
+
* @async
|
1001
1085
|
*/
|
1002
1086
|
async hasClientEvent(eventID) {
|
1003
1087
|
return new Promise((resolve) => {
|
@@ -1015,61 +1099,106 @@ const SnkApplication = class {
|
|
1015
1099
|
}
|
1016
1100
|
/**
|
1017
1101
|
* Obtém o resourceID da tela em questão.
|
1102
|
+
* @returns {Promise<string>} O ID do recurso da aplicação.
|
1103
|
+
* @async
|
1018
1104
|
*/
|
1019
1105
|
async getResourceID() {
|
1020
1106
|
return Promise.resolve(this.applicationResourceID);
|
1021
1107
|
}
|
1022
1108
|
/**
|
1023
|
-
* Obtém o UserId
|
1109
|
+
* Obtém o UserId do usuário logado.
|
1110
|
+
* @returns {Promise<string>} O ID do usuário.
|
1111
|
+
* @async
|
1024
1112
|
*/
|
1025
1113
|
async getUserID() {
|
1026
1114
|
return Promise.resolve(window["UID"]);
|
1027
1115
|
}
|
1028
1116
|
/**
|
1029
1117
|
* Exibe o diálogo de alerta de acordo com os parâmetros passados.
|
1118
|
+
* @param {string} title - O título do alerta.
|
1119
|
+
* @param {string} message - A mensagem do alerta.
|
1120
|
+
* @param {string} [icon] - O nome do ícone a ser exibido.
|
1121
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1122
|
+
* @returns {Promise<boolean>}
|
1123
|
+
* @async
|
1030
1124
|
*/
|
1031
1125
|
async alert(title, message, icon, options) {
|
1032
1126
|
return utils.ApplicationUtils.alert(title, message, icon, options);
|
1033
1127
|
}
|
1034
1128
|
/**
|
1035
1129
|
* Exibe o diálogo de erro de acordo com os parâmetros passados.
|
1130
|
+
* @param {string} title - O título do erro.
|
1131
|
+
* @param {string} message - A mensagem do erro.
|
1132
|
+
* @param {string} [icon] - O nome do ícone a ser exibido.
|
1133
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1134
|
+
* @returns {Promise<boolean>}
|
1135
|
+
* @async
|
1036
1136
|
*/
|
1037
1137
|
async error(title, message, icon, options) {
|
1038
1138
|
return utils.ApplicationUtils.error(title, message, icon, options);
|
1039
1139
|
}
|
1040
1140
|
/**
|
1041
1141
|
* Exibe o diálogo de sucesso de acordo com os parâmetros passados.
|
1142
|
+
* @param {string} title - O título da mensagem de sucesso.
|
1143
|
+
* @param {string} message - A mensagem de sucesso.
|
1144
|
+
* @param {string} [icon] - O nome do ícone a ser exibido.
|
1145
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1146
|
+
* @returns {Promise<boolean>}
|
1147
|
+
* @async
|
1042
1148
|
*/
|
1043
1149
|
async success(title, message, icon, options) {
|
1044
1150
|
return utils.ApplicationUtils.success(title, message, icon, options);
|
1045
1151
|
}
|
1046
1152
|
/**
|
1047
|
-
* Exibe um diálogo de mensagem comum
|
1153
|
+
* Exibe um diálogo de mensagem comum.
|
1154
|
+
* @param {string} title - O título da mensagem.
|
1155
|
+
* @param {string} message - A mensagem.
|
1156
|
+
* @param {string} [icon] - O nome do ícone a ser exibido.
|
1157
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1158
|
+
* @returns {Promise<boolean>}
|
1159
|
+
* @async
|
1048
1160
|
*/
|
1049
1161
|
async message(title, message, icon, options) {
|
1050
1162
|
return utils.ApplicationUtils.message(title, message, icon, options);
|
1051
1163
|
}
|
1052
1164
|
/**
|
1053
|
-
* Exibe um diálogo de confirmação
|
1165
|
+
* Exibe um diálogo de confirmação.
|
1166
|
+
* @param {string} title - O título da confirmação.
|
1167
|
+
* @param {string} message - A mensagem da confirmação.
|
1168
|
+
* @param {string} [icon] - O nome do ícone a ser exibido.
|
1169
|
+
* @param {DialogType} [dialogType] - O tipo de diálogo.
|
1170
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1171
|
+
* @returns {Promise<boolean>} `true` se confirmado, `false` caso contrário.
|
1172
|
+
* @async
|
1054
1173
|
*/
|
1055
1174
|
async confirm(title, message, icon, dialogType, options) {
|
1056
1175
|
return utils.ApplicationUtils.confirm(title, message, icon, dialogType, options);
|
1057
1176
|
}
|
1058
1177
|
/**
|
1059
1178
|
* Exibe uma informação efêmera (de segundo plano).
|
1179
|
+
* @param {string} message - A mensagem a ser exibida.
|
1180
|
+
* @param {MessageOptions} [options] - Opções adicionais para a mensagem.
|
1181
|
+
* @returns {Promise<void>}
|
1182
|
+
* @async
|
1060
1183
|
*/
|
1061
1184
|
async info(message, options) {
|
1062
1185
|
return utils.ApplicationUtils.info(message, options);
|
1063
1186
|
}
|
1064
1187
|
/**
|
1065
1188
|
* Obtém os totalizadores da grade.
|
1189
|
+
* @param {string} name - O nome da configuração de totalizadores.
|
1190
|
+
* @param {string} resourceID - O ID do recurso.
|
1191
|
+
* @param {Array<Filter>} filters - A lista de filtros a serem aplicados.
|
1192
|
+
* @returns {Promise<Map<string, number>>} Um mapa com os nomes dos totalizadores e seus valores.
|
1193
|
+
* @async
|
1066
1194
|
*/
|
1067
1195
|
async loadTotals(name, resourceID, filters) {
|
1068
1196
|
return this.totalsFetcher.fetchTotals(name, resourceID, filters);
|
1069
1197
|
}
|
1070
1198
|
/**
|
1071
|
-
* Obtém a informação se o último carregamento do dataunit foi feito através de um loadByPk
|
1072
|
-
* @returns boolean
|
1199
|
+
* Obtém a informação se o último carregamento do dataunit foi feito através de um loadByPk.
|
1200
|
+
* @returns {Promise<boolean>} `true` se foi carregado por PK, `false` caso contrário.
|
1201
|
+
* @async
|
1073
1202
|
*/
|
1074
1203
|
async isLoadedByPk() {
|
1075
1204
|
return Promise.resolve(this._isLoadedByPk);
|
@@ -1077,6 +1206,10 @@ const SnkApplication = class {
|
|
1077
1206
|
/**
|
1078
1207
|
* Remove registro do cache do PreLoader do dataunit.
|
1079
1208
|
* Deve ser usado quando existe um dataunit usando loader do application, mas o removeLoader está sendo sobrescrito.
|
1209
|
+
* @param {DataUnit} dataUnit - O DataUnit do qual o registro será removido.
|
1210
|
+
* @param {Array<string>} recordsIDs - Os IDs dos registros a serem removidos.
|
1211
|
+
* @returns {Promise<void>}
|
1212
|
+
* @async
|
1080
1213
|
*/
|
1081
1214
|
async preloadMangerRemoveRecord(dataUnit, recordsIDs) {
|
1082
1215
|
const records = recordsIDs.map(id => {
|
@@ -1136,8 +1269,14 @@ const SnkApplication = class {
|
|
1136
1269
|
return this._authFetcher;
|
1137
1270
|
}
|
1138
1271
|
/**
|
1139
|
-
* Obtém as opções em componentes de pesquisa
|
1272
|
+
* Obtém as opções em componentes de pesquisa.
|
1140
1273
|
* Ex.: snk-config-options
|
1274
|
+
* @param {ISearchArgument} searchArgument - Argumentos da pesquisa.
|
1275
|
+
* @param {string} fieldName - Nome do campo no DataUnit.
|
1276
|
+
* @param {DataUnit} dataUnit - Instância do DataUnit.
|
1277
|
+
* @param {ISearchCtxOptions} [ctxOptions] - Opções de contexto adicionais.
|
1278
|
+
* @returns {Promise<Array<IOption> | IOption>} Uma lista de opções ou uma única opção.
|
1279
|
+
* @async
|
1141
1280
|
*/
|
1142
1281
|
async executeSearch(searchArgument, fieldName, dataUnit, ctxOptions) {
|
1143
1282
|
const descriptor = dataUnit === null || dataUnit === void 0 ? void 0 : dataUnit.getField(fieldName);
|
@@ -1235,8 +1374,11 @@ const SnkApplication = class {
|
|
1235
1374
|
return await this.executePreparedSearch(mode, argument, Object.assign(Object.assign({}, options), { useSearchPlus: true }));
|
1236
1375
|
}
|
1237
1376
|
/**
|
1238
|
-
*
|
1239
|
-
*
|
1377
|
+
* @param {string} mode - O modo da pesquisa ("ADVANCED" ou outro).
|
1378
|
+
* @param {string} argument - O argumento da pesquisa.
|
1379
|
+
* @param {any} options - Opções preparadas para a pesquisa. Veja a documentação para exemplo de uso.
|
1380
|
+
* @returns {Promise<Array<IOption> | IOption>} Uma lista de opções ou uma única opção.
|
1381
|
+
* @async
|
1240
1382
|
*/
|
1241
1383
|
async executePreparedSearch(mode, argument, options) {
|
1242
1384
|
const mdByName = {};
|
@@ -1296,14 +1438,21 @@ const SnkApplication = class {
|
|
1296
1438
|
});
|
1297
1439
|
}
|
1298
1440
|
/**
|
1299
|
-
* Obtém o nome
|
1441
|
+
* Obtém o nome (label) da aplicação.
|
1442
|
+
* @returns {Promise<string>} O nome da aplicação.
|
1443
|
+
* @async
|
1300
1444
|
*/
|
1301
1445
|
async getAppLabel() {
|
1302
1446
|
return Workspace.getAppLabel(this.applicationResourceID);
|
1303
1447
|
}
|
1304
1448
|
/**
|
1305
|
-
* Adiciona um listener no fetcher de Pesquisa
|
1306
|
-
|
1449
|
+
* Adiciona um listener no fetcher de Pesquisa.
|
1450
|
+
* @param {string} entityName - O nome da entidade.
|
1451
|
+
* @param {DataUnit} dataUnit - A instância do DataUnit.
|
1452
|
+
* @param {ISearchListener} listener - O listener a ser adicionado.
|
1453
|
+
* @returns {Promise<IRemoveSearchListener>} Uma função para remover o listener.
|
1454
|
+
* @async
|
1455
|
+
*/
|
1307
1456
|
addSearchListener(entityName, dataUnit, listener) {
|
1308
1457
|
return new Promise(resolve => {
|
1309
1458
|
const removeListener = this.pesquisaFetcher.addSearchListener(entityName, dataUnit.dataUnitId, listener);
|
@@ -1311,8 +1460,10 @@ const SnkApplication = class {
|
|
1311
1460
|
});
|
1312
1461
|
}
|
1313
1462
|
/**
|
1314
|
-
Realiza o import de um JavaScript que está
|
1315
|
-
@param relativePath
|
1463
|
+
Realiza o import de um JavaScript que está disponível dentro da pasta /public da aplicação.
|
1464
|
+
@param {string | Array<string>} relativePath - Define o caminho relativo para o arquivo JavaScript a ser importado, ou uma lista de caminhos.
|
1465
|
+
@returns {Promise<void>}
|
1466
|
+
@async
|
1316
1467
|
*/
|
1317
1468
|
importScript(relativePath) {
|
1318
1469
|
return new Promise((resolve) => {
|
@@ -1333,6 +1484,8 @@ const SnkApplication = class {
|
|
1333
1484
|
}
|
1334
1485
|
/**
|
1335
1486
|
* Retorna o path relativo da aplicação.
|
1487
|
+
* @returns {Promise<string>} O caminho relativo da aplicação.
|
1488
|
+
* @async
|
1336
1489
|
*/
|
1337
1490
|
async getApplicationPath() {
|
1338
1491
|
return new Promise((resolve) => {
|
@@ -1353,20 +1506,27 @@ const SnkApplication = class {
|
|
1353
1506
|
* Com base em um campo realiza um "select distinct" respeitando os
|
1354
1507
|
* filtros atuais do dataUnit e um critério de filtro para a própria
|
1355
1508
|
* coluna.
|
1509
|
+
* @param {DataUnit} dataUnit - A instância do DataUnit.
|
1510
|
+
* @param {string} fieldName - O nome do campo para o select distinct.
|
1511
|
+
* @param {string} argument - O argumento de filtro para a coluna.
|
1512
|
+
* @returns {Promise<Array<any>>} Uma lista de valores distintos.
|
1513
|
+
* @async
|
1356
1514
|
*/
|
1357
1515
|
executeSelectDistinct(dataUnit, fieldName, argument) {
|
1358
1516
|
return this.dataUnitFetcher.loadSelectDistinct(dataUnit, fieldName, argument);
|
1359
1517
|
}
|
1360
1518
|
/**
|
1361
|
-
* Retorna a
|
1362
|
-
* @returns DataFetcher
|
1519
|
+
* Retorna a instância do DataFetcher utilizado pelo application.
|
1520
|
+
* @returns {Promise<DataFetcher>} O DataFetcher da aplicação.
|
1521
|
+
* @async
|
1363
1522
|
*/
|
1364
1523
|
getDataFetcher() {
|
1365
1524
|
return Promise.resolve(DataFetcher.DataFetcher.get());
|
1366
1525
|
}
|
1367
1526
|
/**
|
1368
|
-
* Retorna uma promise que
|
1369
|
-
* @returns SnkApplication carregado.
|
1527
|
+
* Retorna uma promise que será resolvida quando o snk-application estiver carregado e registrado no ApplicationContext.
|
1528
|
+
* @returns {Promise<SnkApplication>} O componente SnkApplication carregado.
|
1529
|
+
* @async
|
1370
1530
|
*/
|
1371
1531
|
async whenApplicationReady() {
|
1372
1532
|
const isLoadding = core.ApplicationContext.getContextValue("__SNK__APPLICATION__LOADING__");
|
@@ -1379,9 +1539,10 @@ const SnkApplication = class {
|
|
1379
1539
|
}
|
1380
1540
|
/**
|
1381
1541
|
* Atribui valor para parâmetros de contexto no componente de pesquisa.
|
1382
|
-
*
|
1383
|
-
* @param
|
1384
|
-
* @
|
1542
|
+
* @param {string} name - Nome do parâmetro.
|
1543
|
+
* @param {string} value - String conversível de acordo com o tipo do parâmetro.
|
1544
|
+
* @returns {Promise<void>}
|
1545
|
+
* @async
|
1385
1546
|
*/
|
1386
1547
|
async setSearchFilterContext(name, value) {
|
1387
1548
|
core.ApplicationContext.setContextValue(`__SNK__APPLICATION__FILTER__CONTEXT(${name})__`, value);
|
@@ -1636,6 +1797,12 @@ const SnkApplication = class {
|
|
1636
1797
|
async changeTemplateSkeleton(templateSkeletonType) {
|
1637
1798
|
this._templateSkeleton = templateSkeletonType ? templateSkeletonType : this._templateSkeleton;
|
1638
1799
|
}
|
1800
|
+
/**
|
1801
|
+
* Marca a aplicação para recarregar, opcionalmente especificando um tipo de esqueleto de carregamento.
|
1802
|
+
* @param {TEMPLATES_SKELETON} [templateSkeletonType] - O tipo de esqueleto de carregamento a ser exibido.
|
1803
|
+
* @returns {Promise<void>}
|
1804
|
+
* @async
|
1805
|
+
*/
|
1639
1806
|
async markToReload(templateSkeletonType) {
|
1640
1807
|
if (!this.enableLockManagerLoadingApp)
|
1641
1808
|
return;
|
@@ -1644,6 +1811,13 @@ const SnkApplication = class {
|
|
1644
1811
|
await core.LockManager.resetLocks(this._element, core.LockManagerOperation.APP_LOADING);
|
1645
1812
|
this.resolveApplicationReady();
|
1646
1813
|
}
|
1814
|
+
/**
|
1815
|
+
* Adiciona um bloqueio de carregamento à aplicação.
|
1816
|
+
* @param {boolean} [forceReady=false] - Se `true`, força a aplicação para o estado "não pronto" antes de adicionar o bloqueio.
|
1817
|
+
* @param {TEMPLATES_SKELETON} [templateSkeletonType] - O tipo de esqueleto de carregamento a ser exibido.
|
1818
|
+
* @returns {Promise<string>} O ID do bloqueio adicionado.
|
1819
|
+
* @async
|
1820
|
+
*/
|
1647
1821
|
async addLoadingLock(forceReady = false, templateSkeletonType) {
|
1648
1822
|
if (!this.enableLockManagerLoadingApp)
|
1649
1823
|
return;
|