mirror of
https://github.com/PanJiaChen/vue-element-admin.git
synced 2025-08-10 20:39:48 +08:00
fix: Run process notification without session (#413)
* fix: Show notification run process without session. * close notification after response.
This commit is contained in:
parent
8258da6001
commit
1e837db9e0
@ -176,15 +176,15 @@ export function getLookupList({
|
||||
* @param {number} reportType
|
||||
* @param {number} tableName, table name of tab, used only window
|
||||
* @param {number} recordId, record identifier, used only window
|
||||
* @param {array} parameters, parameters from process [{ columnName, value }]
|
||||
* @param {array} selection, selection records, used only browser
|
||||
* @param {array} parametersList, parameters from process [{ columnName, value }]
|
||||
* @param {array} selectionsList, selection records, used only browser
|
||||
[{
|
||||
selectionId,
|
||||
selectionValues: [{ columnName, value }]
|
||||
}]
|
||||
* @param {string} printFormatUuid
|
||||
*/
|
||||
export function runProcess({ uuid, reportType, tableName, recordId, parameters: parametersList = [], selection: selectionsList = [], printFormatUuid }) {
|
||||
export function runProcess({ uuid, reportType, tableName, recordId, parametersList = [], selectionsList = [], printFormatUuid }) {
|
||||
// Run Process
|
||||
return Instance.call(this).requestRunProcess({
|
||||
uuid,
|
||||
|
@ -487,7 +487,7 @@ export const contextMixin = {
|
||||
})
|
||||
}
|
||||
} else if (action.type === 'updateReport') {
|
||||
var updateReportParams = {
|
||||
const updateReportParams = {
|
||||
instanceUuid: action.instanceUuid,
|
||||
processUuid: action.processUuid,
|
||||
tableName: action.tableName,
|
||||
@ -526,8 +526,7 @@ export const contextMixin = {
|
||||
response.url = link.href
|
||||
}
|
||||
this.$store.dispatch('finishProcess', {
|
||||
processOutput: response,
|
||||
routeToDelete: this.$route
|
||||
processOutput: response
|
||||
})
|
||||
})
|
||||
}
|
||||
|
@ -6,6 +6,7 @@ import { showNotification } from '@/utils/ADempiere/notification'
|
||||
import { isEmptyValue } from '@/utils/ADempiere/valueUtils'
|
||||
import language from '@/lang'
|
||||
import router from '@/router'
|
||||
import { getToken } from '@/utils/auth'
|
||||
|
||||
const initStateProcessControl = {
|
||||
inExecution: [], // process not response from server
|
||||
@ -68,7 +69,7 @@ const processControl = {
|
||||
setReportValues(state, payload) {
|
||||
state.reportObject = payload
|
||||
if (state.reportList.some(report => report.instanceUuid === payload.instanceUuid)) {
|
||||
var reportIndex = state.reportList.findIndex(report => report.instanceUuid === payload.instanceUuid)
|
||||
const reportIndex = state.reportList.findIndex(report => report.instanceUuid === payload.instanceUuid)
|
||||
state.reportList.splice(reportIndex, 1, payload)
|
||||
} else {
|
||||
state.reportList.push(payload)
|
||||
@ -101,12 +102,25 @@ const processControl = {
|
||||
},
|
||||
actions: {
|
||||
// Supported Actions for it
|
||||
startProcess({ commit, state, dispatch, getters, rootGetters }, params) {
|
||||
startProcess({ commit, state, dispatch, getters, rootGetters }, {
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
panelType,
|
||||
action,
|
||||
parametersList,
|
||||
reportFormat,
|
||||
isProcessTableSelection,
|
||||
isActionDocument,
|
||||
tableNameUuidSelection,
|
||||
recordUuidSelection,
|
||||
menuParentUuid,
|
||||
routeToDelete
|
||||
}) {
|
||||
return new Promise((resolve, reject) => {
|
||||
// TODO: Add support to evaluate params to send
|
||||
// const samePocessInExecution = getters.getInExecution(params.containerUuid)
|
||||
// TODO: Add support to evaluate parameters list to send
|
||||
// const samePocessInExecution = getters.getInExecution(containerUuid)
|
||||
// exists some call to executed process with container uuid
|
||||
// if (samePocessInExecution && !params.isProcessTableSelection) {
|
||||
// if (samePocessInExecution && !isProcessTableSelection) {
|
||||
// return reject({
|
||||
// error: 0,
|
||||
// message: `In this process (${samePocessInExecution.name}) there is already an execution in progress.`
|
||||
@ -117,11 +131,11 @@ const processControl = {
|
||||
let selection = []
|
||||
let allData = {}
|
||||
let tab, tableName, recordId
|
||||
if (params.panelType) {
|
||||
if (params.panelType === 'browser') {
|
||||
allData = getters.getDataRecordAndSelection(params.containerUuid)
|
||||
if (panelType) {
|
||||
if (panelType === 'browser') {
|
||||
allData = getters.getDataRecordAndSelection(containerUuid)
|
||||
selection = rootGetters.getSelectionToServer({
|
||||
containerUuid: params.containerUuid,
|
||||
containerUuid,
|
||||
selection: allData.selection
|
||||
})
|
||||
if (selection.length < 1) {
|
||||
@ -131,26 +145,24 @@ const processControl = {
|
||||
})
|
||||
return reject({
|
||||
error: 0,
|
||||
message: `Required selection data record to run this process (${params.action.name})`
|
||||
message: `Required selection data record to run this process (${action.name})`
|
||||
})
|
||||
}
|
||||
}
|
||||
if (params.panelType === 'window') {
|
||||
if (panelType === 'window') {
|
||||
const contextMenu = getters.getRecordUuidMenu
|
||||
if (params.isProcessTableSelection) {
|
||||
tab = rootGetters.getTab(params.parentUuid, params.containerUuid)
|
||||
tableName = params.tableNameUuidSelection
|
||||
recordId = params.recordUuidSelection
|
||||
tab = rootGetters.getTab(parentUuid, containerUuid)
|
||||
if (isProcessTableSelection) {
|
||||
tableName = tableNameUuidSelection
|
||||
recordId = recordUuidSelection
|
||||
} else {
|
||||
if (contextMenu.processTable) {
|
||||
tab = rootGetters.getTab(params.parentUuid, params.containerUuid)
|
||||
tableName = contextMenu.tableName
|
||||
recordId = contextMenu.valueRecord
|
||||
} else {
|
||||
tab = rootGetters.getTab(params.parentUuid, params.containerUuid)
|
||||
tableName = tab.tableName
|
||||
const field = rootGetters.getFieldFromColumnName({
|
||||
containerUuid: params.containerUuid,
|
||||
containerUuid,
|
||||
columnName: `${tableName}_ID`
|
||||
})
|
||||
recordId = field.value
|
||||
@ -159,29 +171,36 @@ const processControl = {
|
||||
}
|
||||
}
|
||||
// get info metadata process
|
||||
const processDefinition = !isEmptyValue(params.isActionDocument) ? params.action : rootGetters.getProcess(params.action.uuid)
|
||||
let reportType = params.reportFormat
|
||||
const processDefinition = !isEmptyValue(isActionDocument) ? action : rootGetters.getProcess(action.uuid)
|
||||
let reportType = reportFormat
|
||||
const finalParameters = rootGetters.getParametersToServer({ containerUuid: processDefinition.uuid })
|
||||
|
||||
showNotification({
|
||||
title: language.t('notifications.processing'),
|
||||
message: processDefinition.name,
|
||||
summary: processDefinition.description,
|
||||
type: 'info'
|
||||
})
|
||||
const isSession = !isEmptyValue(getToken())
|
||||
let procesingMessage = {
|
||||
close: () => false
|
||||
}
|
||||
if (isSession) {
|
||||
procesingMessage = showNotification({
|
||||
title: language.t('notifications.processing'),
|
||||
message: processDefinition.name,
|
||||
summary: processDefinition.description,
|
||||
type: 'info'
|
||||
})
|
||||
}
|
||||
const timeInitialized = (new Date()).getTime()
|
||||
let processResult
|
||||
if (!isEmptyValue(params.isActionDocument)) {
|
||||
if (!isEmptyValue(isActionDocument)) {
|
||||
processResult = {
|
||||
// panel attributes from where it was executed
|
||||
parentUuid: params.parentUuid,
|
||||
containerUuid: params.containerUuid,
|
||||
panelType: params.panelType,
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
panelType,
|
||||
lastRun: timeInitialized,
|
||||
processUuid: params.action.uuid,
|
||||
processId: params.action.id,
|
||||
processUuid: action.uuid,
|
||||
processId: action.id,
|
||||
processName: 'Procesar Orden',
|
||||
parameters: params.parametersList,
|
||||
parameters: parametersList,
|
||||
parametersList,
|
||||
isError: false,
|
||||
isProcessing: true,
|
||||
summary: '',
|
||||
@ -203,12 +222,12 @@ const processControl = {
|
||||
// uuid of process
|
||||
processResult = {
|
||||
// panel attributes from where it was executed
|
||||
parentUuid: params.parentUuid,
|
||||
containerUuid: params.containerUuid,
|
||||
panelType: params.panelType,
|
||||
menuParentUuid: params.menuParentUuid,
|
||||
processIdPath: params.routeToDelete.path,
|
||||
printFormatUuid: params.action.printFormatUuid,
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
panelType,
|
||||
menuParentUuid,
|
||||
processIdPath: routeToDelete.path,
|
||||
printFormatUuid: action.printFormatUuid,
|
||||
// process attributes
|
||||
lastRun: timeInitialized,
|
||||
action: processDefinition.name,
|
||||
@ -237,25 +256,25 @@ const processControl = {
|
||||
}
|
||||
}
|
||||
commit('addInExecution', processResult)
|
||||
if (params.panelType === 'window') {
|
||||
if (panelType === 'window') {
|
||||
reportType = 'pdf'
|
||||
} else if (params.panelType === 'browser') {
|
||||
} else if (panelType === 'browser') {
|
||||
if (allData.record.length <= 100) {
|
||||
// close view if is browser.
|
||||
router.push({ path: '/dashboard' })
|
||||
dispatch('tagsView/delView', params.routeToDelete)
|
||||
dispatch('tagsView/delView', routeToDelete)
|
||||
// delete data associate to browser
|
||||
dispatch('deleteRecordContainer', {
|
||||
viewUuid: params.containerUuid
|
||||
viewUuid: containerUuid
|
||||
})
|
||||
}
|
||||
} else {
|
||||
// close view if is process, report.
|
||||
router.push({ path: '/dashboard' })
|
||||
dispatch('tagsView/delView', params.routeToDelete)
|
||||
dispatch('tagsView/delView', routeToDelete)
|
||||
}
|
||||
if (params.isProcessTableSelection) {
|
||||
var windowSelectionProcess = getters.getProcessSelect
|
||||
if (isProcessTableSelection) {
|
||||
const windowSelectionProcess = getters.getProcessSelect
|
||||
windowSelectionProcess.selection.forEach(selection => {
|
||||
Object.assign(processResult, {
|
||||
selection: selection.UUID,
|
||||
@ -267,9 +286,9 @@ const processControl = {
|
||||
runProcess({
|
||||
uuid: processDefinition.uuid,
|
||||
id: processDefinition.id,
|
||||
reportType: reportType,
|
||||
parameters: isEmptyValue(finalParameters) ? params.parametersList : finalParameters,
|
||||
selection: selection,
|
||||
reportType,
|
||||
parametersList: isEmptyValue(finalParameters) ? parametersList : finalParameters,
|
||||
selectionsList: selection,
|
||||
tableName: windowSelectionProcess.tableName,
|
||||
recordId: selection[windowSelectionProcess.tableName]
|
||||
})
|
||||
@ -414,17 +433,14 @@ const processControl = {
|
||||
const countResponse = state.totalResponse + 1
|
||||
commit('setTotalResponse', countResponse)
|
||||
if (state.totalResponse === state.totalRequest) {
|
||||
// showNotification({
|
||||
// title: language.t('notifications.succesful'),
|
||||
// message: language.t('notifications.totalProcess') + countResponse + language.t('notifications.error') + state.errorSelection + language.t('notifications.succesful') + state.successSelection + language.t('notifications.processExecuted'),
|
||||
// type: 'success'
|
||||
// })
|
||||
const processMessage = {
|
||||
title: language.t('notifications.succesful'),
|
||||
message: language.t('notifications.totalProcess') + countResponse + language.t('notifications.error') + state.errorSelection + language.t('notifications.succesful') + state.successSelection + language.t('notifications.processExecuted'),
|
||||
type: 'success'
|
||||
if (isSession) {
|
||||
showNotification({
|
||||
title: language.t('notifications.succesful'),
|
||||
message: language.t('notifications.totalProcess') + countResponse + language.t('notifications.error') + state.errorSelection + language.t('notifications.succesful') + state.successSelection + language.t('notifications.processExecuted'),
|
||||
type: 'success'
|
||||
})
|
||||
}
|
||||
showNotification(processMessage)
|
||||
|
||||
commit('setTotalRequest', 0)
|
||||
commit('setTotalResponse', 0)
|
||||
commit('setSuccessSelection', 0)
|
||||
@ -438,7 +454,7 @@ const processControl = {
|
||||
commit('addNotificationProcess', processResult)
|
||||
commit('addStartedProcess', processResult)
|
||||
commit('deleteInExecution', {
|
||||
containerUuid: params.containerUuid
|
||||
containerUuid
|
||||
})
|
||||
})
|
||||
}
|
||||
@ -448,15 +464,15 @@ const processControl = {
|
||||
uuid: processDefinition.uuid,
|
||||
id: processDefinition.id,
|
||||
reportType,
|
||||
parameters: isEmptyValue(finalParameters) ? params.parametersList : finalParameters,
|
||||
selection,
|
||||
parametersList: isEmptyValue(finalParameters) ? parametersList : finalParameters,
|
||||
selectionsList: selection,
|
||||
tableName,
|
||||
recordId
|
||||
})
|
||||
.then(runProcessResponse => {
|
||||
const { instanceUuid, output } = runProcessResponse
|
||||
let logList = []
|
||||
if (runProcessResponse.logsList) {
|
||||
if (!isEmptyValue(runProcessResponse.logsList)) {
|
||||
logList = runProcessResponse.logsList
|
||||
}
|
||||
|
||||
@ -529,7 +545,7 @@ const processControl = {
|
||||
}
|
||||
})
|
||||
} else {
|
||||
var index = contextMenuMetadata.actions.findIndex(action => action.option === 'printFormat')
|
||||
const index = contextMenuMetadata.actions.findIndex(action => action.option === 'printFormat')
|
||||
if (index !== -1) {
|
||||
contextMenuMetadata.actions[index] = printFormatList
|
||||
}
|
||||
@ -572,8 +588,8 @@ const processControl = {
|
||||
logs: logList,
|
||||
output
|
||||
})
|
||||
dispatch('setReportTypeToShareLink', processResult.output.reportType)
|
||||
resolve(processResult)
|
||||
dispatch('setReportTypeToShareLink', processResult.output.reportType)
|
||||
})
|
||||
.catch(error => {
|
||||
Object.assign(processResult, {
|
||||
@ -586,17 +602,17 @@ const processControl = {
|
||||
})
|
||||
.finally(() => {
|
||||
if (!processResult.isError) {
|
||||
if (params.panelType === 'window') {
|
||||
if (panelType === 'window') {
|
||||
// TODO: Add conditional to indicate when update record
|
||||
dispatch('updateRecordAfterRunProcess', {
|
||||
parentUuid: params.parentUuid,
|
||||
containerUuid: params.containerUuid,
|
||||
tab: tab
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
tab
|
||||
})
|
||||
} else if (params.panelType === 'browser') {
|
||||
} else if (panelType === 'browser') {
|
||||
if (allData.record.length >= 100) {
|
||||
dispatch('getBrowserSearch', {
|
||||
containerUuid: params.containerUuid
|
||||
containerUuid
|
||||
})
|
||||
}
|
||||
}
|
||||
@ -605,11 +621,11 @@ const processControl = {
|
||||
commit('addNotificationProcess', processResult)
|
||||
dispatch('finishProcess', {
|
||||
processOutput: processResult,
|
||||
routeToDelete: params.routeToDelete
|
||||
procesingMessage
|
||||
})
|
||||
|
||||
commit('deleteInExecution', {
|
||||
containerUuid: params.containerUuid
|
||||
containerUuid
|
||||
})
|
||||
|
||||
dispatch('setProcessTable', {
|
||||
@ -625,30 +641,40 @@ const processControl = {
|
||||
})
|
||||
},
|
||||
// Supported to process selection
|
||||
selectionProcess({ commit, state, dispatch, getters, rootGetters }, params) {
|
||||
selectionProcess({ commit, state, dispatch, getters, rootGetters }, {
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
panelType,
|
||||
action,
|
||||
isProcessTableSelection,
|
||||
menuParentUuid,
|
||||
routeToDelete
|
||||
}) {
|
||||
// get info metadata process
|
||||
const processDefinition = rootGetters.getProcess(params.action.uuid)
|
||||
var reportType = 'pdf'
|
||||
const processDefinition = rootGetters.getProcess(action.uuid)
|
||||
const reportType = 'pdf'
|
||||
const finalParameters = rootGetters.getParametersToServer({ containerUuid: processDefinition.uuid })
|
||||
|
||||
showNotification({
|
||||
title: language.t('notifications.processing'),
|
||||
message: processDefinition.name,
|
||||
summary: processDefinition.description,
|
||||
type: 'info'
|
||||
})
|
||||
const isSession = !isEmptyValue(getToken())
|
||||
if (isSession) {
|
||||
showNotification({
|
||||
title: language.t('notifications.processing'),
|
||||
message: processDefinition.name,
|
||||
summary: processDefinition.description,
|
||||
type: 'info'
|
||||
})
|
||||
}
|
||||
const timeInitialized = (new Date()).getTime()
|
||||
// Run process on server and wait for it for notify
|
||||
if (params.isProcessTableSelection) {
|
||||
var windowSelectionProcess = getters.getProcessSelect
|
||||
if (isProcessTableSelection) {
|
||||
const windowSelectionProcess = getters.getProcessSelect
|
||||
windowSelectionProcess.selection.forEach(selection => {
|
||||
var processResult = {
|
||||
const processResult = {
|
||||
// panel attributes from where it was executed
|
||||
parentUuid: params.parentUuid,
|
||||
containerUuid: params.containerUuid,
|
||||
panelType: params.panelType,
|
||||
menuParentUuid: params.menuParentUuid,
|
||||
processIdPath: params.routeToDelete.path,
|
||||
parentUuid,
|
||||
containerUuid,
|
||||
panelType,
|
||||
menuParentUuid,
|
||||
processIdPath: routeToDelete.path,
|
||||
// process attributes
|
||||
lastRun: timeInitialized,
|
||||
action: processDefinition.name,
|
||||
@ -684,14 +710,14 @@ const processControl = {
|
||||
return runProcess({
|
||||
uuid: processDefinition.uuid,
|
||||
id: processDefinition.id,
|
||||
reportType: reportType,
|
||||
parameters: finalParameters,
|
||||
selection: selection,
|
||||
reportType,
|
||||
parametersList: finalParameters,
|
||||
selectionsList: selection,
|
||||
tableName: windowSelectionProcess.tableName,
|
||||
recordId: selection[windowSelectionProcess.tableName]
|
||||
})
|
||||
.then(response => {
|
||||
var output = {
|
||||
let output = {
|
||||
uuid: '',
|
||||
name: '',
|
||||
description: '',
|
||||
@ -714,7 +740,7 @@ const processControl = {
|
||||
reportType: responseOutput.reporttype
|
||||
}
|
||||
}
|
||||
var logList = []
|
||||
let logList = []
|
||||
if (response.getLogsList) {
|
||||
logList = response.getLogsList.map(itemLog => {
|
||||
return {
|
||||
@ -733,7 +759,7 @@ const processControl = {
|
||||
ResultTableName: response.resulttablename,
|
||||
lastRun: response.lastRun,
|
||||
logs: logList,
|
||||
output: output
|
||||
output
|
||||
})
|
||||
dispatch('setReportTypeToShareLink', processResult.output.reportType)
|
||||
if (processResult.isError) {
|
||||
@ -746,12 +772,13 @@ const processControl = {
|
||||
const countResponse = state.totalResponse + 1
|
||||
commit('setTotalResponse', countResponse)
|
||||
if (state.totalResponse === state.totalRequest) {
|
||||
var processMessage = {
|
||||
title: language.t('notifications.succesful'),
|
||||
message: language.t('notifications.totalProcess') + countResponse + language.t('notifications.error') + state.errorSelection + language.t('notifications.succesful') + state.successSelection + language.t('notifications.processExecuted'),
|
||||
type: 'success'
|
||||
if (isSession) {
|
||||
showNotification({
|
||||
title: language.t('notifications.succesful'),
|
||||
message: language.t('notifications.totalProcess') + countResponse + language.t('notifications.error') + state.errorSelection + language.t('notifications.succesful') + state.successSelection + language.t('notifications.processExecuted'),
|
||||
type: 'success'
|
||||
})
|
||||
}
|
||||
showNotification(processMessage)
|
||||
commit('setTotalRequest', 0)
|
||||
commit('setTotalResponse', 0)
|
||||
commit('setSuccessSelection', 0)
|
||||
@ -765,7 +792,7 @@ const processControl = {
|
||||
commit('addNotificationProcess', processResult)
|
||||
commit('addStartedProcess', processResult)
|
||||
commit('deleteInExecution', {
|
||||
containerUuid: params.containerUuid
|
||||
containerUuid
|
||||
})
|
||||
})
|
||||
.catch(error => {
|
||||
@ -774,7 +801,7 @@ const processControl = {
|
||||
message: error.message,
|
||||
isProcessing: false
|
||||
})
|
||||
console.warn(`Error running the process ${error}.`)
|
||||
console.warn(`Error running the process. Code ${error.code}: ${error.message}.`)
|
||||
})
|
||||
}
|
||||
})
|
||||
@ -828,21 +855,24 @@ const processControl = {
|
||||
* Show modal dialog with process/report, tab (sequence) metadata
|
||||
* @param {object} params
|
||||
*/
|
||||
setShowDialog({ state, commit, dispatch, rootGetters }, params) {
|
||||
setShowDialog({ state, commit, dispatch, rootGetters }, {
|
||||
type,
|
||||
action
|
||||
}) {
|
||||
const panels = ['process', 'report', 'window']
|
||||
if (params.action && (panels.includes(params.type) || panels.includes(params.action.panelType))) {
|
||||
if (action && (panels.includes(type) || panels.includes(action.panelType))) {
|
||||
// show some process loaded in store
|
||||
if (state.metadata && !isEmptyValue(state.metadata.containerUuid) &&
|
||||
state.metadata.containerUuid === params.action.containerUuid) {
|
||||
state.metadata.containerUuid === action.containerUuid) {
|
||||
commit('setShowDialog', true)
|
||||
return
|
||||
}
|
||||
const panel = rootGetters.getPanel(params.action.containerUuid)
|
||||
const panel = rootGetters.getPanel(action.containerUuid)
|
||||
if (panel === undefined) {
|
||||
dispatch('getPanelAndFields', {
|
||||
parentUuid: params.action.parentUuid,
|
||||
containerUuid: isEmptyValue(params.action.uuid) ? params.action.containerUuid : params.action.uuid,
|
||||
panelType: params.action.panelType
|
||||
parentUuid: action.parentUuid,
|
||||
containerUuid: isEmptyValue(action.uuid) ? action.containerUuid : action.uuid,
|
||||
panelType: action.panelType
|
||||
})
|
||||
.then(response => {
|
||||
commit('setMetadata', response)
|
||||
@ -856,53 +886,62 @@ const processControl = {
|
||||
}
|
||||
commit('setShowDialog', false)
|
||||
},
|
||||
finishProcess({ commit }, parameters) {
|
||||
var processMessage = {
|
||||
name: parameters.processOutput.processName,
|
||||
finishProcess({ commit }, {
|
||||
processOutput,
|
||||
procesingMessage
|
||||
}) {
|
||||
const processMessage = {
|
||||
name: processOutput.processName,
|
||||
title: language.t('notifications.succesful'),
|
||||
message: language.t('notifications.processExecuted'),
|
||||
type: 'success',
|
||||
logs: parameters.processOutput.logs,
|
||||
summary: parameters.processOutput.summary
|
||||
logs: processOutput.logs,
|
||||
summary: processOutput.summary
|
||||
}
|
||||
var errorMessage = !isEmptyValue(parameters.processOutput.message) ? parameters.processOutput.message : language.t('notifications.error')
|
||||
const errorMessage = !isEmptyValue(processOutput.message) ? processOutput.message : language.t('notifications.error')
|
||||
// TODO: Add isReport to type always 'success'
|
||||
if (parameters.processOutput.isError || isEmptyValue(parameters.processOutput.processId) || isEmptyValue(parameters.processOutput.instanceUuid)) {
|
||||
if (processOutput.isError || isEmptyValue(processOutput.processId) || isEmptyValue(processOutput.instanceUuid)) {
|
||||
processMessage.title = language.t('notifications.error')
|
||||
processMessage.message = errorMessage
|
||||
processMessage.type = 'error'
|
||||
parameters.processOutput.isError = true
|
||||
processOutput.isError = true
|
||||
}
|
||||
if (parameters.processOutput.isReport && !parameters.processOutput.isError) {
|
||||
if (processOutput.isReport && !processOutput.isError) {
|
||||
// open report viewer with report response
|
||||
if (isEmptyValue(parameters.processOutput.menuParentUuid)) {
|
||||
parameters.processOutput.menuParentUuid = parameters.processOutput.processUuid
|
||||
if (isEmptyValue(processOutput.menuParentUuid)) {
|
||||
processOutput.menuParentUuid = processOutput.processUuid
|
||||
}
|
||||
|
||||
let tableName
|
||||
if (parameters.processOutput.option && !isEmptyValue(parameters.processOutput.option)) {
|
||||
if (parameters.processOutput.option === 'drillTable') {
|
||||
tableName = parameters.processOutput.tableName
|
||||
if (processOutput.option && !isEmptyValue(processOutput.option)) {
|
||||
if (processOutput.option === 'drillTable') {
|
||||
tableName = processOutput.tableName
|
||||
}
|
||||
}
|
||||
router.push({
|
||||
name: 'Report Viewer',
|
||||
params: {
|
||||
processId: parameters.processOutput.processId,
|
||||
instanceUuid: parameters.processOutput.instanceUuid,
|
||||
fileName: isEmptyValue(parameters.processOutput.output.fileName) ? parameters.processOutput.fileName : parameters.processOutput.output.fileName,
|
||||
menuParentUuid: parameters.processOutput.menuParentUuid,
|
||||
tableName: tableName
|
||||
processId: processOutput.processId,
|
||||
instanceUuid: processOutput.instanceUuid,
|
||||
fileName: isEmptyValue(processOutput.output.fileName) ? processOutput.fileName : processOutput.output.fileName,
|
||||
menuParentUuid: processOutput.menuParentUuid,
|
||||
tableName
|
||||
}
|
||||
})
|
||||
}
|
||||
const isSession = !isEmptyValue(getToken())
|
||||
if (isSession) {
|
||||
showNotification(processMessage)
|
||||
}
|
||||
if (!isEmptyValue(procesingMessage)) {
|
||||
procesingMessage.close()
|
||||
}
|
||||
|
||||
showNotification(processMessage)
|
||||
commit('addStartedProcess', parameters.processOutput)
|
||||
commit('setReportValues', parameters.processOutput)
|
||||
commit('addStartedProcess', processOutput)
|
||||
commit('setReportValues', processOutput)
|
||||
},
|
||||
changeFormatReport({ commit }, reportFormat) {
|
||||
if (reportFormat !== undefined) {
|
||||
if (!isEmptyValue(reportFormat)) {
|
||||
commit('changeFormatReport', reportFormat)
|
||||
}
|
||||
}
|
||||
|
@ -6,7 +6,6 @@ export function hasTranslation(text) {
|
||||
const hasKey = language.te('notifications.' + text)
|
||||
if (hasKey) {
|
||||
const translatedText = language.t('notifications.' + text)
|
||||
|
||||
return translatedText
|
||||
}
|
||||
return text
|
||||
@ -14,61 +13,70 @@ export function hasTranslation(text) {
|
||||
|
||||
/**
|
||||
*
|
||||
* @param {object} parameters
|
||||
* @param {object} parameters.type, required
|
||||
* @param {object} parameters.title, required
|
||||
* @param {object} parameters.message, required
|
||||
* @param {object} parameters.summary, required
|
||||
* @param {object} parameters.name, required
|
||||
* @param {string} type, required
|
||||
* @param {string} title, required
|
||||
* @param {object} message
|
||||
* @param {string} summary
|
||||
* @param {string} name
|
||||
* @param {array} logs
|
||||
*/
|
||||
export function showNotification(parameters) {
|
||||
var title = hasTranslation(parameters.title)
|
||||
var message = ''
|
||||
if (parameters.message) {
|
||||
message = hasTranslation(parameters.message)
|
||||
export function showNotification({ type, title, message, summary, name, logs = [] }) {
|
||||
title = hasTranslation(title)
|
||||
if (message) {
|
||||
message = hasTranslation(message)
|
||||
}
|
||||
// For summary
|
||||
if (parameters.summary) {
|
||||
// For summary
|
||||
if (summary) {
|
||||
if (message) {
|
||||
message = message + '<br>' + parameters.summary
|
||||
message = `${message} <br> ${summary}`
|
||||
} else {
|
||||
message = parameters.summary
|
||||
message = summary
|
||||
}
|
||||
}
|
||||
// For logs
|
||||
if (parameters.logs) {
|
||||
parameters.logs.forEach(logResult => {
|
||||
// For logs
|
||||
if (logs && logs.length) {
|
||||
logs.forEach(logResult => {
|
||||
if (logResult) {
|
||||
message = message + '<br>' + logResult.log
|
||||
message = `${message} <br> ${logResult.log}`
|
||||
}
|
||||
})
|
||||
}
|
||||
if (parameters.name) {
|
||||
message = parameters.name + message
|
||||
if (name) {
|
||||
message = name + message
|
||||
}
|
||||
Notification({
|
||||
title: title,
|
||||
message: `<div style="max-height: 100px; overflow-y: auto;">` + message + `</div>`,
|
||||
type: parameters.type,
|
||||
|
||||
return Notification({
|
||||
title,
|
||||
message: `<div style="max-height: 100px; overflow-y: auto;">${message}</div>`,
|
||||
type,
|
||||
position: 'bottom-right',
|
||||
dangerouslyUseHTMLString: true,
|
||||
onClick() {
|
||||
router.push({ name: 'ProcessActivity' })
|
||||
router.push({
|
||||
name: 'ProcessActivity'
|
||||
})
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
export function showMessage(parameters) {
|
||||
var delay = 3000
|
||||
if (parameters.type === 'info') {
|
||||
/**
|
||||
*
|
||||
* @param {string} type
|
||||
* @param {string} message
|
||||
* @param {number} duration
|
||||
*/
|
||||
export function showMessage({ type, message, duration = 0 }) {
|
||||
let delay = 3000
|
||||
if (type === 'info') {
|
||||
delay = 2000
|
||||
}
|
||||
if (parameters.duration) {
|
||||
delay = parameters.duration
|
||||
if (duration) {
|
||||
delay = duration
|
||||
}
|
||||
Message({
|
||||
message: parameters.message,
|
||||
type: parameters.type,
|
||||
|
||||
return Message({
|
||||
message,
|
||||
type,
|
||||
showClose: true,
|
||||
duration: delay
|
||||
})
|
||||
|
Loading…
x
Reference in New Issue
Block a user