[Feature][UI Next]Added the method of downloading files (#9605)

dependabot/maven/org.springframework-spring-core-5.3.19
labbomb 2022-04-20 12:15:39 +08:00 committed by GitHub
parent 2be7183563
commit 5b2a96b830
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 70 additions and 49 deletions

View File

@ -15,7 +15,8 @@
* limitations under the License.
*/
import { axios, downloadFile } from '@/service/service'
import { axios } from '@/service/service'
import utils from '@/utils'
import {
ResourceTypeReq,
NameReq,
@ -211,7 +212,7 @@ export function deleteResource(id: number): any {
}
export function downloadResource(id: number): void {
downloadFile(`resources/${id}/download`)
utils.downloadFile(`resources/${id}/download`)
}
export function viewUIUdfFunction(id: IdReq): any {

View File

@ -15,7 +15,8 @@
* limitations under the License.
*/
import { axios, downloadFile } from '@/service/service'
import { axios } from '@/service/service'
import utils from '@/utils'
import { ProjectCodeReq, IdReq, TaskListReq } from './types'
export function queryTaskListPaging(
@ -37,5 +38,5 @@ export function forceSuccess(taskId: IdReq, projectCode: ProjectCodeReq): any {
}
export function downloadLog(id: number): void {
downloadFile('log/download-log', { taskInstanceId: id })
utils.downloadFile('log/download-log', { taskInstanceId: id })
}

View File

@ -93,46 +93,5 @@ service.interceptors.response.use((res: AxiosResponse) => {
}
}, err)
const apiPrefix = '/dolphinscheduler'
const reSlashPrefix = /^\/+/
const resolveURL = (url: string) => {
if (url.indexOf('http') === 0) {
return url
}
if (url.charAt(0) !== '/') {
return `${apiPrefix}/${url.replace(reSlashPrefix, '')}`
}
return url
}
/**
* download file
*/
const downloadFile = (url: string, obj?: any) => {
const param: any = {
url: resolveURL(url),
obj: obj || {}
}
const form = document.createElement('form')
form.action = param.url
form.method = 'get'
form.style.display = 'none'
Object.keys(param.obj).forEach((key) => {
const input = document.createElement('input')
input.type = 'hidden'
input.name = key
input.value = param.obj[key]
form.appendChild(input)
})
const button = document.createElement('input')
button.type = 'submit'
form.appendChild(button)
document.body.appendChild(form)
form.submit()
document.body.removeChild(form)
}
export { service as axios, downloadFile }
export { service as axios }

View File

@ -0,0 +1,58 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const apiPrefix = '/dolphinscheduler'
const reSlashPrefix = /^\/+/
const resolveURL = (url: string) => {
if (url.indexOf('http') === 0) {
return url
}
if (url.charAt(0) !== '/') {
return `${apiPrefix}/${url.replace(reSlashPrefix, '')}`
}
return url
}
const downloadFile = (url: string, obj?: any) => {
const param: any = {
url: resolveURL(url),
obj: obj || {}
}
const form = document.createElement('form')
form.action = param.url
form.method = 'get'
form.style.display = 'none'
Object.keys(param.obj).forEach((key) => {
const input = document.createElement('input')
input.type = 'hidden'
input.name = key
input.value = param.obj[key]
form.appendChild(input)
})
const button = document.createElement('input')
button.type = 'submit'
form.appendChild(button)
document.body.appendChild(form)
form.submit()
document.body.removeChild(form)
}
export default downloadFile

View File

@ -19,12 +19,14 @@ import mapping from './mapping'
import regex from './regex'
import truncateText from './truncate-text'
import log from './log'
import downloadFile from './downloadFile'
const utils = {
mapping,
regex,
truncateText,
log
log,
downloadFile
}
export default utils

View File

@ -53,7 +53,7 @@ import LogModal from '@/components/log-modal'
import './x6-style.scss'
import { queryLog } from '@/service/modules/log'
import { useAsyncState } from '@vueuse/core'
import { downloadFile } from '@/service/service'
import utils from '@/utils'
const props = {
// If this prop is passed, it means from definition detail
@ -265,7 +265,7 @@ export default defineComponent({
}
const downloadLogs = () => {
downloadFile('log/download-log', {
utils.downloadFile('log/download-log', {
taskInstanceId: nodeVariables.logTaskId
})
}