mirror of
https://github.com/dataease/dataease.git
synced 2025-02-27 05:33:08 +08:00
data:image/s3,"s3://crabby-images/46f68/46f683c70b8a316b006f30844e8bf22c80a8ddff" alt="Dovahkinn"
* fix: 执行 eslint 命令, 修复代码 * fix(frontend): justify-content 不支持的值 start, end 改为 flex-start, flex-end * Update format-utils.js 去掉注释 * fix(frontend): 修复 css 中不再支持的样式深度选择符号 >>> 导致命令行报错的问题, 替换为 ::v-deep * Update DateFormat.vue * Update FrameLinks.vue * Update Hyperlinks.vue * Update HyperlinksDialog.vue * Update LinkageField.vue * Update VideoLinks.vue * Update DeNumberRange.vue * Update DeSelectGrid.vue * Update index.scss * Update index.vue * Update BackgroundColorSelector.vue * Update LegendSelector.vue * Update LegendSelectorAntV.vue * Update SplitSelector.vue * Update SplitSelectorAntV.vue * Update TitleSelector.vue * Update TitleSelectorAntV.vue * Update XAxisSelector.vue * Update XAxisSelectorAntV.vue * Update YAxisExtSelector.vue * Update YAxisExtSelectorAntV.vue * Update YAxisSelector.vue * Update YAxisSelectorAntV.vue * Update QuotaFilterEditor.vue * Update ResultFilterEditor.vue * Update LabelNormal.vue * Update LabelNormalText.vue * Update AssistLine.vue * Update FunctionCfg.vue * Update ScrollCfg.vue * Update Threshold.vue * Update ColorSelector.vue * Update LabelSelector.vue * Update SizeSelector.vue * Update TooltipSelector.vue * Update TooltipSelectorAntV.vue * Update TotalCfg.vue * Update TableNormal.vue * Update ChartStyle.vue * Update AddCustom.vue * Update AddExcel.vue * Update DatasetChartDetail.vue * Update DatasetGroupSelector.vue * Update DatasetGroupSelectorTree.vue * Update CalcFieldEdit.vue * Update FieldEdit.vue * Update TabDataPreview.vue * Update UnionView.vue * Update UpdateInfo.vue * Update Group.vue * Update all.vue * Update readed.vue * Update unread.vue * Update index.vue * Update index.vue * Update index.vue * Update PanelBackgroundColorSelector.vue * Update PanelColorSelector.vue * Update ViewAttribute.vue * Update SubjectTemplateItem.vue * Update multiplexing.vue * Update filterDialog.vue * Update PanelList.vue * Update PanelMain.vue * Update PanelDetailInfo.vue * Update MapSettingLeft.vue * Update index.vue * Update DatasetTaskList.vue * Update TaskRecord.vue * Update dataset.vue * Update personPwd.vue * Update privateForm.vue Co-authored-by: 王嘉豪 <42510293+ziyujiahao@users.noreply.github.com>
299 lines
8.7 KiB
Vue
299 lines
8.7 KiB
Vue
<template>
|
|
<layout-content>
|
|
<template v-slot:header>
|
|
<el-icon name="back" class="back-button" @click.native="backToList" />
|
|
{{
|
|
params && params.id && params.showModel && params.showModel === 'show' && !canEdit ? $t('driver.show_info') : $t('driver.modify')
|
|
}}
|
|
<el-button v-if="canEdit" size="mini" style="float: right;"type="primary" @click="save">{{ $t('commons.save') }}
|
|
</el-button>
|
|
<el-button v-else size="mini" style="float: right;" type="primary" @click="changeEdit">{{ $t('commons.edit') }}
|
|
</el-button>
|
|
|
|
</template>
|
|
<div>
|
|
|
|
<el-form
|
|
ref="driverForm"
|
|
:model="driverForm"
|
|
:rules="rule"
|
|
size="small"
|
|
:disabled="params && params.id && params.showModel && params.showModel === 'show' && !canEdit"
|
|
label-width="180px"
|
|
label-position="right"
|
|
>
|
|
<el-form-item :label="$t('commons.name')" prop="name">
|
|
<el-input v-model="driverForm.name" autocomplete="off" />
|
|
</el-form-item>
|
|
<el-form-item :label="$t('commons.description')">
|
|
<el-input v-model="driverForm.desc" autocomplete="off" />
|
|
</el-form-item>
|
|
<el-form-item :label="$t('datasource.type')" prop="type">
|
|
<el-select
|
|
v-model="driverForm.type"
|
|
:placeholder="$t('datasource.please_choose_type')"
|
|
class="select-width"
|
|
style="width: 100%"
|
|
disabled
|
|
filterable
|
|
>
|
|
<el-option
|
|
v-for="item in dsTypes"
|
|
:key="item.type"
|
|
:label="item.name"
|
|
:value="item.type"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
|
|
<!-- <el-form-item :label="$t('driver.driver')" >-->
|
|
<!-- <el-select-->
|
|
<!-- v-model="driverForm.driverClass"-->
|
|
<!-- :placeholder="$t('driver.please_choose_driver')"-->
|
|
<!-- class="select-width"-->
|
|
<!-- filterable-->
|
|
<!-- >-->
|
|
<!-- <el-option-->
|
|
<!-- v-for="item in driverClassList"-->
|
|
<!-- :key="item"-->
|
|
<!-- :label="item"-->
|
|
<!-- :value="item"-->
|
|
<!-- />-->
|
|
<!-- </el-select>-->
|
|
<!-- </el-form-item>-->
|
|
|
|
<el-form-item :label="$t('driver.driver')" prop="driverClass">
|
|
<el-input v-model="driverForm.driverClass" autocomplete="off" />
|
|
</el-form-item>
|
|
|
|
</el-form>
|
|
|
|
<el-upload
|
|
:action="baseUrl+'driver/file/upload'"
|
|
:multiple="true"
|
|
:show-file-list="false"
|
|
:file-list="fileList"
|
|
:data="params"
|
|
accept=".jar"
|
|
:before-upload="beforeUpload"
|
|
:on-success="uploadSuccess"
|
|
:on-error="uploadFail"
|
|
name="file"
|
|
:headers="headers"
|
|
style="float: right;"
|
|
>
|
|
<el-button size="mini" type="primary" style="float: right;" :disabled="uploading">
|
|
<span v-if="!uploading" style="font-size: 12px;">{{ $t('dataset.upload_file') }}</span>
|
|
<span v-if="uploading" style="font-size: 12px;"><i class="el-icon-loading" /> {{ $t('dataset.uploading') }}</span>
|
|
</el-button>
|
|
</el-upload>
|
|
<fu-table :data="driverFiles">
|
|
<el-table-column prop="fileName" :label="$t('driver.file_name')" />
|
|
<!-- <el-table-column prop="version" :label="$t('driver.version')"/>-->
|
|
<fu-table-operations :buttons="buttons" :label="$t('commons.operating')" fix />
|
|
</fu-table>
|
|
|
|
</div>
|
|
</layout-content>
|
|
</template>
|
|
|
|
<script>
|
|
import LayoutContent from '@/components/business/LayoutContent'
|
|
import i18n from '@/lang/index'
|
|
import ApiHttpRequestForm from '@/views/system/datasource/ApiHttpRequestForm'
|
|
import DsConfiguration from '@/views/system/datasource/DsConfiguration'
|
|
import PluginCom from '@/views/system/plugin/PluginCom'
|
|
import { deleteDriverFile, listDriverDetails, updateDriver } from '@/api/system/datasource'
|
|
import { delUser } from '@/api/system/user'
|
|
import { $alert } from '@/utils/message'
|
|
import store from '@/store'
|
|
import { getToken } from '@/utils/auth'
|
|
|
|
const token = getToken()
|
|
|
|
export default {
|
|
name: 'DriverForm',
|
|
components: {
|
|
DsConfiguration,
|
|
LayoutContent,
|
|
ApiHttpRequestForm,
|
|
PluginCom
|
|
},
|
|
props: {
|
|
params: {
|
|
type: Object,
|
|
default: null
|
|
},
|
|
tData: {
|
|
type: Array,
|
|
default: null
|
|
},
|
|
dsTypes: {
|
|
type: Array,
|
|
default: null
|
|
}
|
|
},
|
|
data() {
|
|
return {
|
|
disabled: false,
|
|
driverForm: {
|
|
id: '',
|
|
name: '',
|
|
desc: '',
|
|
type: '',
|
|
driverClass: ''
|
|
},
|
|
datasourceType: {},
|
|
driverClassList: [],
|
|
rule: {
|
|
name: [{ required: true, message: i18n.t('datasource.input_name'), trigger: 'blur' },
|
|
{ min: 2, max: 50, message: i18n.t('datasource.input_limit_2_25', [2, 25]), trigger: 'blur' }],
|
|
desc: [{ required: true, message: i18n.t('datasource.input_name'), trigger: 'blur' },
|
|
{ min: 2, max: 200, message: i18n.t('datasource.input_limit_2_25', [2, 25]), trigger: 'blur' }],
|
|
type: [{ required: true, message: i18n.t('datasource.please_choose_type'), trigger: 'blur' }],
|
|
driverClass: [{ required: true, message: i18n.t('driver.please_set_driverClass'), trigger: 'blur' }]
|
|
},
|
|
canEdit: false,
|
|
driverFiles: [],
|
|
btnDisabled: false,
|
|
buttons: [
|
|
{
|
|
label: this.$t('commons.delete'), icon: 'el-icon-delete', type: 'danger', click: this.deleteDriverFile,
|
|
disabled: this.btnDisabled
|
|
}
|
|
],
|
|
uploading: false,
|
|
baseUrl: process.env.VUE_APP_BASE_API,
|
|
headers: { Authorization: token, 'Accept-Language': i18n.locale.replace('_', '-') },
|
|
fileList: []
|
|
}
|
|
},
|
|
|
|
created() {
|
|
const row = this.params
|
|
this.driverForm = JSON.parse(JSON.stringify(row))
|
|
this.disabled = this.params && this.params.id && this.params.showModel && this.params.showModel === 'show' && !this.canEdit
|
|
this.listDriverDetails()
|
|
},
|
|
mounted() {
|
|
},
|
|
|
|
methods: {
|
|
beforeUpload(file) {
|
|
this.uploading = true
|
|
},
|
|
uploadSuccess(response, file, fileList) {
|
|
this.uploading = false
|
|
this.listDriverDetails()
|
|
},
|
|
uploadFail(response, file, fileList) {
|
|
let myError = response.toString()
|
|
myError = myError.replace('Error: ', '')
|
|
if (myError.indexOf('AuthenticationException') >= 0) {
|
|
const message = i18n.t('login.tokenError')
|
|
$alert(message, () => {
|
|
store.dispatch('user/logout').then(() => {
|
|
location.reload()
|
|
})
|
|
}, {
|
|
confirmButtonText: i18n.t('login.re_login'),
|
|
showClose: false
|
|
})
|
|
return
|
|
}
|
|
const errorMessage = JSON.parse(myError).message
|
|
this.uploading = false
|
|
this.$message({
|
|
type: 'error',
|
|
message: errorMessage,
|
|
showClose: true
|
|
})
|
|
},
|
|
deleteDriverFile(row) {
|
|
deleteDriverFile(row).then(res => {
|
|
this.$success(this.$t('commons.delete_success'))
|
|
this.listDriverDetails()
|
|
})
|
|
},
|
|
listDriverDetails() {
|
|
listDriverDetails(this.driverForm.id).then(res => {
|
|
this.driverFiles = res.data
|
|
this.driverClassList = []
|
|
this.driverFiles.forEach(driverFile => {
|
|
this.driverClassList = this.driverClassList.concat(driverFile.driverClass.split(','))
|
|
})
|
|
})
|
|
},
|
|
changeEdit() {
|
|
this.canEdit = true
|
|
this.formType = 'modify'
|
|
this.disabled = this.params && this.params.id && this.params.showModel && this.params.showModel === 'show' && !this.canEdit
|
|
},
|
|
save() {
|
|
this.$refs.driverForm.validate(valid => {
|
|
if (!valid) {
|
|
return false
|
|
}
|
|
updateDriver(this.driverForm).then(res => {
|
|
this.$success(i18n.t('commons.success'))
|
|
this.canEdit = false
|
|
})
|
|
})
|
|
},
|
|
reset() {
|
|
this.$refs.dsForm.resetFields()
|
|
},
|
|
backToList() {
|
|
this.$emit('switch-component', {})
|
|
},
|
|
refreshType(form) {
|
|
this.$emit('refresh-type', DsForm)
|
|
},
|
|
handleClick(tab, event) {}
|
|
}
|
|
}
|
|
</script>
|
|
<style scoped>
|
|
/* .el-input {
|
|
width: 300px;
|
|
}
|
|
|
|
.el-select {
|
|
width: 300px;
|
|
} */
|
|
|
|
.ms-http-input {
|
|
width: 500px;
|
|
margin-top: 5px;
|
|
}
|
|
|
|
.tip {
|
|
padding: 3px 5px;
|
|
font-size: 16px;
|
|
border-radius: 0;
|
|
border-left: 4px solid #409EFF;
|
|
margin: 5px 5px 10px 5px;
|
|
}
|
|
|
|
.el-select ::v-deep input {
|
|
padding-right: 10px;
|
|
}
|
|
|
|
.el-select ::v-deep .el-input__suffix {
|
|
right: 0;
|
|
}
|
|
|
|
.dialog-css ::v-deep .el-dialog__header {
|
|
padding: 10px 20px 0px;
|
|
}
|
|
|
|
.dialog-css ::v-deep .el-dialog__body {
|
|
padding: 10px 20px 10px;
|
|
}
|
|
|
|
.dialog-footer ::v-deep .el-dialog__footer {
|
|
padding: 10px 10px 10px;
|
|
}
|
|
|
|
</style>
|