diff --git a/backend/src/main/java/io/dataease/controller/sys/SysUserController.java b/backend/src/main/java/io/dataease/controller/sys/SysUserController.java index a3074b4366..8c8f4d0f87 100644 --- a/backend/src/main/java/io/dataease/controller/sys/SysUserController.java +++ b/backend/src/main/java/io/dataease/controller/sys/SysUserController.java @@ -258,7 +258,7 @@ public class SysUserController { } @PostMapping("/unbindAssist/{type}") - public void unbindAssist(String type) { + public void unbindAssist(@PathVariable("type") String type) { Boolean valid = StringUtils.equals(WECOM, type) || StringUtils.equals(DINGTALK, type) || StringUtils.equals(LARK, type); if (!valid) { @@ -275,6 +275,9 @@ public class SysUserController { if (StringUtils.equals(LARK, type)) { sysUserAssist.setLarkId(null); } + if (StringUtils.isBlank(sysUserAssist.getWecomId()) && StringUtils.isBlank(sysUserAssist.getDingtalkId()) && StringUtils.isBlank(sysUserAssist.getLarkId())) { + sysUserService.changeUserFrom(userId, 0); + } sysUserService.saveAssist(userId, sysUserAssist.getWecomId(), sysUserAssist.getDingtalkId(), sysUserAssist.getLarkId()); } diff --git a/backend/src/main/java/io/dataease/plugins/server/XDingtalkServer.java b/backend/src/main/java/io/dataease/plugins/server/XDingtalkServer.java index 474ae29640..fcc5d24756 100644 --- a/backend/src/main/java/io/dataease/plugins/server/XDingtalkServer.java +++ b/backend/src/main/java/io/dataease/plugins/server/XDingtalkServer.java @@ -159,10 +159,12 @@ public class XDingtalkServer { SysUserEntity userEntity = authUserService.getUserById(Long.parseLong(state)); if (ObjectUtils.isEmpty(userEntity)) { bindError(response, url, "绑定用户不存在"); + return; } SysUserAssist sysUserAssist = sysUserService.assistInfo(Long.parseLong(state)); - if (ObjectUtils.isNotEmpty(sysUserAssist) && StringUtils.isNotBlank(sysUserAssist.getWecomId())) { + if (ObjectUtils.isNotEmpty(sysUserAssist) && StringUtils.isNotBlank(sysUserAssist.getDingtalkId())) { bindError(response, url, "目标用户已绑定其他钉钉账号"); + return; } Boolean isOpen = authUserService.supportDingtalk(); if (!isOpen) { @@ -177,6 +179,7 @@ public class XDingtalkServer { SysUserEntity sysUserEntity = authUserService.getUserByDingtalkId(userId); if (null != sysUserEntity) { bindError(response, url, "当前钉钉账号已绑定其他DE用户"); + return; } if (ObjectUtils.isEmpty(sysUserAssist)) { sysUserAssist = new SysUserAssist(); diff --git a/backend/src/main/java/io/dataease/plugins/server/XLarkServer.java b/backend/src/main/java/io/dataease/plugins/server/XLarkServer.java index 5e6711324e..77553bbb4d 100644 --- a/backend/src/main/java/io/dataease/plugins/server/XLarkServer.java +++ b/backend/src/main/java/io/dataease/plugins/server/XLarkServer.java @@ -158,10 +158,12 @@ public class XLarkServer { SysUserEntity userEntity = authUserService.getUserById(Long.parseLong(state)); if (ObjectUtils.isEmpty(userEntity)) { bindError(response, url, "绑定用户不存在"); + return; } SysUserAssist sysUserAssist = sysUserService.assistInfo(Long.parseLong(state)); - if (ObjectUtils.isNotEmpty(sysUserAssist) && StringUtils.isNotBlank(sysUserAssist.getWecomId())) { + if (ObjectUtils.isNotEmpty(sysUserAssist) && StringUtils.isNotBlank(sysUserAssist.getLarkId())) { bindError(response, url, "目标用户已绑定其他飞书账号"); + return; } Boolean isOpen = authUserService.supportLark(); @@ -176,6 +178,7 @@ public class XLarkServer { SysUserEntity sysUserEntity = authUserService.getUserByLarkId(userId); if (null != sysUserEntity) { bindError(response, url, "当前飞书账号已绑定其他DE用户"); + return; } if (ObjectUtils.isEmpty(sysUserAssist)) { diff --git a/backend/src/main/java/io/dataease/plugins/server/XWecomServer.java b/backend/src/main/java/io/dataease/plugins/server/XWecomServer.java index c92d31c1ed..7ff7678cdb 100644 --- a/backend/src/main/java/io/dataease/plugins/server/XWecomServer.java +++ b/backend/src/main/java/io/dataease/plugins/server/XWecomServer.java @@ -165,15 +165,18 @@ public class XWecomServer { SysUserEntity userEntity = authUserService.getUserById(Long.parseLong(state)); if (ObjectUtils.isEmpty(userEntity)) { bindError(response, url, "绑定用户不存在"); + return; } SysUserAssist sysUserAssist = sysUserService.assistInfo(Long.parseLong(state)); if (ObjectUtils.isNotEmpty(sysUserAssist) && StringUtils.isNotBlank(sysUserAssist.getWecomId())) { bindError(response, url, "目标用户已绑定其他企业微信账号"); + return; } Boolean supportWecom = authUserService.supportWecom(); if (!supportWecom) { DEException.throwException("未开启企业微信"); + return; } wecomXpackService = SpringContextUtil.getBean(WecomXpackService.class); WecomAuthResult authResult = wecomXpackService.auth(code); @@ -183,6 +186,7 @@ public class XWecomServer { SysUserEntity sysUserEntity = authUserService.getUserByWecomId(userId); if (null != sysUserEntity) { bindError(response, url, "当前企业微信账号已绑定其他DE用户"); + return; } if (ObjectUtils.isEmpty(sysUserAssist)) { sysUserAssist = new SysUserAssist(); diff --git a/backend/src/main/java/io/dataease/service/dataset/DataSetTableService.java b/backend/src/main/java/io/dataease/service/dataset/DataSetTableService.java index f1be09918c..1486fc545f 100644 --- a/backend/src/main/java/io/dataease/service/dataset/DataSetTableService.java +++ b/backend/src/main/java/io/dataease/service/dataset/DataSetTableService.java @@ -204,6 +204,19 @@ public class DataSetTableService { excelSheetData.setData(null); excelSheetData.setJsonArray(null); }); + } + for (String s : map.keySet()) { + DataSetTableRequest sheetTable = new DataSetTableRequest(); + BeanUtils.copyBean(sheetTable, datasetTable); + sheetTable.setId(UUID.randomUUID().toString()); + sheetTable.setCreateBy(AuthUtils.getUser().getUsername()); + sheetTable.setCreateTime(System.currentTimeMillis()); + List excelSheetDataList = map.get(s); + sheetTable.setName(excelSheetDataList.get(0).getDatasetName()); + excelSheetDataList.forEach(excelSheetData -> { + excelSheetData.setData(null); + excelSheetData.setJsonArray(null); + }); DataTableInfoDTO info = new DataTableInfoDTO(); info.setExcelSheetDataList(excelSheetDataList); sheetTable.setInfo(new Gson().toJson(info)); @@ -225,6 +238,9 @@ public class DataSetTableService { if (checkIsRepeat(fieldArray)) { DataEaseException.throwException(Translator.get("i18n_excel_field_repeat")); } + } + + for (ExcelSheetData sheet : datasetTable.getSheets()) { DataSetTableRequest sheetTable = new DataSetTableRequest(); BeanUtils.copyBean(sheetTable, datasetTable); sheetTable.setId(UUID.randomUUID().toString()); diff --git a/backend/src/main/java/io/dataease/service/sys/SysUserService.java b/backend/src/main/java/io/dataease/service/sys/SysUserService.java index ab70cae6a5..52192680a5 100644 --- a/backend/src/main/java/io/dataease/service/sys/SysUserService.java +++ b/backend/src/main/java/io/dataease/service/sys/SysUserService.java @@ -529,7 +529,7 @@ public class SysUserService { public boolean needPwdNoti(Long userId) { SysUserAssist userAssist = sysUserAssistMapper.selectByPrimaryKey(userId); - return ObjectUtils.isEmpty(userAssist) || userAssist.getNeedFirstNoti(); + return ObjectUtils.isEmpty(userAssist) || ObjectUtils.isEmpty(userAssist.getNeedFirstNoti()) || userAssist.getNeedFirstNoti(); } public void saveUserAssist(Boolean noti) { @@ -567,4 +567,11 @@ public class SysUserService { return sysUserAssistMapper.selectByPrimaryKey(userId); } + public void changeUserFrom(Long userId, Integer from) { + SysUser sysUser = new SysUser(); + sysUser.setUserId(userId); + sysUser.setFrom(from); + sysUserMapper.updateByPrimaryKeySelective(sysUser); + } + } diff --git a/frontend/src/components/canvas/components/Toolbar.vue b/frontend/src/components/canvas/components/Toolbar.vue index 44096977d0..4cbddbe300 100644 --- a/frontend/src/components/canvas/components/Toolbar.vue +++ b/frontend/src/components/canvas/components/Toolbar.vue @@ -193,6 +193,7 @@ export default { ]) }, created() { + eventBus.$on('editPanelInitReady', this.editPanelInit) eventBus.$on('preview', this.preview) eventBus.$on('save', this.save) eventBus.$on('clearCanvas', this.clearCanvas) @@ -205,10 +206,14 @@ export default { eventBus.$off('preview', this.preview) eventBus.$off('save', this.save) eventBus.$off('clearCanvas', this.clearCanvas) + eventBus.$off('editPanelInitReady', this.editPanelInit) clearInterval(this.timer) this.timer = null }, methods: { + editPanelInit(){ + this.showGridSwitch = this.canvasStyleData.aidedDesign.showGrid + }, close() { // 关闭页面清理缓存 this.$store.commit('initCanvasBase') diff --git a/frontend/src/components/canvas/utils/style.js b/frontend/src/components/canvas/utils/style.js index 116d37ba14..538a9e05f2 100644 --- a/frontend/src/components/canvas/utils/style.js +++ b/frontend/src/components/canvas/utils/style.js @@ -1,6 +1,7 @@ import { sin, cos } from '@/components/canvas/utils/translate' import store from '@/store' import Vue from 'vue' + export const LIGHT_THEME_COLOR_MAIN = '#000000' export const LIGHT_THEME_COLOR_SLAVE1 = '#CCCCCC' export const LIGHT_THEME_PANEL_BACKGROUND = '#F1F3F5' @@ -35,6 +36,9 @@ export function getStyle(style, filter = []) { if (key === 'backgroundColor') { result[key] = colorRgb(style[key], style.opacity) } + if (key === 'fontSize' && result[key] < 12) { + result[key] = 12 + } if (needUnit.includes(key)) { result[key] += 'px' } diff --git a/frontend/src/icons/svg/field_time.svg b/frontend/src/icons/svg/field_time.svg index 77a79164c4..b5c0c4e47d 100644 --- a/frontend/src/icons/svg/field_time.svg +++ b/frontend/src/icons/svg/field_time.svg @@ -1,4 +1 @@ - - - - \ No newline at end of file + \ No newline at end of file diff --git a/frontend/src/lang/en.js b/frontend/src/lang/en.js index 9940582d9b..cce695692c 100644 --- a/frontend/src/lang/en.js +++ b/frontend/src/lang/en.js @@ -1656,7 +1656,11 @@ export default { sql_ds_union_error: 'Direct connect SQL dataset can not be union', api_data: 'API dataset', copy: 'Copy', - sync_log: 'Sync log' + sync_log: 'Sync log', + field_edit_name: 'Field Name', + input_edit_name: 'Input field name', + edit_search: 'Search by name', + na: 'None' }, driver: { driver: 'Driver', diff --git a/frontend/src/lang/tw.js b/frontend/src/lang/tw.js index eeecbe3040..abd48e4d4a 100644 --- a/frontend/src/lang/tw.js +++ b/frontend/src/lang/tw.js @@ -1656,7 +1656,11 @@ export default { sql_ds_union_error: '直連模式下SQL數據集,不支持關聯', api_data: 'API 數據集', copy: '復製', - sync_log: '同步日誌' + sync_log: '同步日誌', + field_edit_name: '字段名稱', + input_edit_name: '請輸入字段名稱', + edit_search: '通過名稱搜索', + na: '暫無' }, driver: { driver: '驅動', diff --git a/frontend/src/lang/zh.js b/frontend/src/lang/zh.js index e1f5e5861a..62976c8d72 100644 --- a/frontend/src/lang/zh.js +++ b/frontend/src/lang/zh.js @@ -1655,7 +1655,11 @@ export default { sql_ds_union_error: '直连模式下SQL数据集,不支持关联', api_data: 'API 数据集', copy: '复制', - sync_log: '同步日志' + sync_log: '同步日志', + field_edit_name: '字段名称', + input_edit_name: '请输入字段名称', + edit_search: '通过名称搜索', + na: '暂无' }, driver: { driver: '驱动', diff --git a/frontend/src/styles/index.scss b/frontend/src/styles/index.scss index 9b85bc1a56..fa4d359aa5 100644 --- a/frontend/src/styles/index.scss +++ b/frontend/src/styles/index.scss @@ -302,7 +302,7 @@ div:focus { .field-icon-time { @extend %field-icon; - color: #faaa39; + color: #3370FF; } .field-icon-value { @@ -322,6 +322,14 @@ div:focus { margin: 0 2px 1px 0; } +.field-icon-dimension{ + color: #3370FF!important; +} + +.field-icon-quota{ + color: #04B49C!important; +} + .ds-icon-pdf { width: 20px; height: 20px; diff --git a/frontend/src/views/chart/chart/common/common.js b/frontend/src/views/chart/chart/common/common.js index 321c238bc0..5bd5f738e7 100644 --- a/frontend/src/views/chart/chart/common/common.js +++ b/frontend/src/views/chart/chart/common/common.js @@ -274,9 +274,11 @@ export function seniorCfg(chart_option, chart) { } } // begin mark line settings - chart_option.series[0].markLine = { - symbol: 'none', - data: [] + if (chart_option.series && chart_option.series.length > 0) { + chart_option.series[0].markLine = { + symbol: 'none', + data: [] + } } if (senior.assistLine && senior.assistLine.length > 0) { if (chart_option.series && chart_option.series.length > 0) { diff --git a/frontend/src/views/chart/components/senior/dialog/AssistLineEdit.vue b/frontend/src/views/chart/components/senior/dialog/AssistLineEdit.vue index 7ee93b8e3e..5340ba5cfe 100644 --- a/frontend/src/views/chart/components/senior/dialog/AssistLineEdit.vue +++ b/frontend/src/views/chart/components/senior/dialog/AssistLineEdit.vue @@ -124,7 +124,7 @@ export default { addLine() { const obj = { ...this.lineObj, curField: this.quotaData ? this.quotaData[0] : null, - fieldId: this.quotaData ? this.quotaData[0].id : null + fieldId: this.quotaData ? this.quotaData[0]?.id : null } this.lineArr.push(JSON.parse(JSON.stringify(obj))) this.changeAssistLine() diff --git a/frontend/src/views/chart/view/CalcChartFieldEdit.vue b/frontend/src/views/chart/view/CalcChartFieldEdit.vue index 4f7e3264f9..e13ebae46c 100644 --- a/frontend/src/views/chart/view/CalcChartFieldEdit.vue +++ b/frontend/src/views/chart/view/CalcChartFieldEdit.vue @@ -2,8 +2,8 @@ - {{ $t('dataset.field_name') }} - + {{ $t('dataset.field_edit_name') }} + @@ -94,13 +94,14 @@
{{ $t('chart.dimension') }} +
{{ $t('dataset.na') }}
{{ $t('chart.quota') }} +
{{ $t('dataset.na') }}
@@ -176,7 +180,7 @@ @@ -670,4 +674,11 @@ span { float: right; margin-top: 10px; } + +.class-na { + margin-top: 8px; + text-align: center; + font-size: 14px; + color: var(--deTextDisable); +} diff --git a/frontend/src/views/dataset/data/CalcFieldEdit.vue b/frontend/src/views/dataset/data/CalcFieldEdit.vue index b9073177fa..0d3881ed9a 100644 --- a/frontend/src/views/dataset/data/CalcFieldEdit.vue +++ b/frontend/src/views/dataset/data/CalcFieldEdit.vue @@ -1,11 +1,11 @@ @@ -326,16 +327,16 @@ export default { } }, watch: { - param: function () { + param: function() { this.initFunctions() }, field: { - handler: function () { + handler: function() { this.initField() }, deep: true }, - tableFields: function () { + tableFields: function() { this.dimensionData = JSON.parse( JSON.stringify(this.tableFields.dimensionList) ).filter((ele) => ele.extField === 0) @@ -343,7 +344,7 @@ export default { JSON.stringify(this.tableFields.quotaList) ).filter((ele) => ele.extField === 0) }, - searchField: function (val) { + searchField: function(val) { if (val && val !== '') { this.dimensionData = JSON.parse( JSON.stringify( @@ -374,7 +375,7 @@ export default { ).filter((ele) => ele.extField === 0) } }, - searchFunction: function (val) { + searchFunction: function(val) { if (val && val !== '') { this.functionData = JSON.parse( JSON.stringify( @@ -563,10 +564,10 @@ export default { box-sizing: border-box; margin-left: 12px; width: 214px; - overflow-y: auto; + overflow-y: hidden; } .field-height { - height: calc(50% - 25px); + height: calc(50% - 41px); margin-top: 4px; } .drag-list { @@ -673,7 +674,7 @@ export default { background: var(--ContentBG); } .function-height { - height: calc(100% - 50px); + height: calc(100% - 21px - 32px - 4px - 24px); overflow: auto; margin-top: 4px; } @@ -689,6 +690,13 @@ export default { margin: 6px 0 0 0; font-size: 10px; } + +.class-na { + margin-top: 8px; + text-align: center; + font-size: 14px; + color: var(--deTextDisable); +} \ No newline at end of file + diff --git a/frontend/src/views/dataset/data/FieldEdit.vue b/frontend/src/views/dataset/data/FieldEdit.vue index 7da11cf244..93ef48423f 100644 --- a/frontend/src/views/dataset/data/FieldEdit.vue +++ b/frontend/src/views/dataset/data/FieldEdit.vue @@ -146,22 +146,22 @@ {{ @@ -174,28 +174,28 @@ @@ -220,7 +220,7 @@ scope.row.deExtractType === 6 " icon-class="field_text" - class="field-icon-text" + class="field-icon-text field-icon-dimension" /> {{ $t('dataset.text') }} @@ -228,7 +228,7 @@ {{ $t('dataset.time') }} @@ -246,7 +246,7 @@ scope.row.deExtractType === 4 " icon-class="field_value" - class="field-icon-value" + class="field-icon-value field-icon-dimension" /> {{ $t('dataset.location') }} @@ -464,22 +464,22 @@ {{ @@ -492,28 +492,28 @@ @@ -530,7 +530,7 @@ {{ $t('dataset.text') }} @@ -538,7 +538,7 @@ {{ $t('dataset.time') }} @@ -556,7 +556,7 @@ scope.row.deExtractType === 4 " icon-class="field_value" - class="field-icon-value" + class="field-icon-value field-icon-quota" /> {{ $t('dataset.location') }} @@ -1098,4 +1098,4 @@ span { transform: translate(-50%, -50%); } } - \ No newline at end of file + diff --git a/frontend/src/views/panel/appTemplateMarket/log/index.vue b/frontend/src/views/panel/appTemplateMarket/log/index.vue index 6f2e1946b3..24bb969e13 100644 --- a/frontend/src/views/panel/appTemplateMarket/log/index.vue +++ b/frontend/src/views/panel/appTemplateMarket/log/index.vue @@ -2,74 +2,73 @@ - {{$t('commons.create')}} + >{{ $t('commons.create') }}   - + /> {{ $t("user.filter") - }} + >{{ $t("user.filter") + }} -
+
{{ paginationConfig.total }} {{ $t("user.result_one") }} - + + @click="scrollPre" + />
-

- {{ ele }} +

+ {{ ele }}

+ @click="scrollNext" + /> {{ $t("user.clear_filter") }} + >{{ $t("user.clear_filter") }}
- - + + \ No newline at end of file + diff --git a/frontend/src/views/system/log/index.vue b/frontend/src/views/system/log/index.vue index 6c734f4365..5335fb9118 100644 --- a/frontend/src/views/system/log/index.vue +++ b/frontend/src/views/system/log/index.vue @@ -9,64 +9,62 @@ - + /> {{ $t("user.filter") - }} + >{{ $t("user.filter") + }} -
+
{{ paginationConfig.total }} {{ $t("user.result_one") }} - + + @click="scrollPre" + />
-

- {{ ele }} +

+ {{ ele }}

+ @click="scrollNext" + /> {{ $t("user.clear_filter") }} + >{{ $t("user.clear_filter") }}
- - + + \ No newline at end of file + diff --git a/frontend/src/views/system/task/TaskRecord.vue b/frontend/src/views/system/task/TaskRecord.vue index f26205b02d..da9aa30d64 100644 --- a/frontend/src/views/system/task/TaskRecord.vue +++ b/frontend/src/views/system/task/TaskRecord.vue @@ -6,60 +6,58 @@ - + /> {{ $t("user.filter") - }} + >{{ $t("user.filter") + }} -
+
{{ paginationConfig.total }} {{ $t("user.result_one") }} - + + @click="scrollPre" + />
-

- {{ ele }} +

+ {{ ele }}

+ @click="scrollNext" + /> {{ $t("user.clear_filter") }} + >{{ $t("user.clear_filter") }}
{{ scope.row.name }} + >{{ scope.row.name }} @@ -107,7 +104,7 @@ - +
{}, + default: () => {} }, transCondition: { type: Object, - default: () => {}, - }, + default: () => {} + } }, data() { return { columns: [], - nikeName: "", + nickName: '', showScroll: false, filterTexts: [], cacheCondition: [], paginationConfig: { currentPage: 1, pageSize: 10, - total: 0, + total: 0 }, data: [], orderConditions: [], show_error_massage: false, - error_massage: "", + error_massage: '', matchLogId: null, - lastRequestComplete: true, - }; - }, - created() { - const { taskId: id, name: label } = this.transCondition; - if (id) { - this.nikeName = label; + lastRequestComplete: true } - const { taskId, name, logId } = (this.param || {}); - if (this.param !== null && taskId) { - this.matchLogId = logId || this.matchLogId; - this.transCondition.taskId = taskId; - this.transCondition.name = name; - this.nikeName = name; - } - this.createTimer(); - }, - mounted() { - this.resizeObserver(); }, watch: { filterTexts: { handler() { - this.getScrollStatus(); + this.getScrollStatus() }, - deep: true, - }, + deep: true + } + }, + created() { + const { taskId: id, name: label } = this.transCondition + if (id) { + this.nickName = label + } + const { taskId, name, logId } = (this.param || {}) + if (this.param !== null && taskId) { + this.matchLogId = logId || this.matchLogId + this.transCondition.taskId = taskId + this.transCondition.name = name + this.nickName = name + } + this.createTimer() + }, + mounted() { + this.resizeObserver() }, beforeDestroy() { - this.destroyTimer(); + this.destroyTimer() }, methods: { exportConfirm() { - this.$confirm(this.$t("log.confirm"), "", { - confirmButtonText: this.$t("commons.confirm"), - cancelButtonText: this.$t("commons.cancel"), - type: "warning", + this.$confirm(this.$t('log.confirm'), '', { + confirmButtonText: this.$t('commons.confirm'), + cancelButtonText: this.$t('commons.cancel'), + type: 'warning' }) .then(() => { - this.exportData(); + this.exportData() }) .catch(() => { // this.$info(this.$t('commons.delete_cancel')) - }); + }) }, exportData() { - const { taskId, name } = this.transCondition; + const { taskId, name } = this.transCondition const param = { orders: formatOrders(this.orderConditions), - conditions: [...this.cacheCondition], - }; - if (this.nikeName) { + conditions: [...this.cacheCondition] + } + if (this.nickName) { param.conditions.push({ field: `dataset_table_task.name`, - operator: "like", - value: this.nikeName, - }); + operator: 'like', + value: this.nickName + }) } - if (taskId && this.nikeName === name) { + if (taskId && this.nickName === name) { param.conditions.push({ - operator: "eq", + operator: 'eq', value: taskId, - field: "dataset_table_task.id", - }); + field: 'dataset_table_task.id' + }) } exportExcel(param).then((res) => { - const blob = new Blob([res], { type: "application/vnd.ms-excel" }); - const link = document.createElement("a"); - link.style.display = "none"; - link.href = URL.createObjectURL(blob); - link.download = "DataEase" + this.$t("dataset.sync_log") + ".xls"; - document.body.appendChild(link); - link.click(); - document.body.removeChild(link); - }); + const blob = new Blob([res], { type: 'application/vnd.ms-excel' }) + const link = document.createElement('a') + link.style.display = 'none' + link.href = URL.createObjectURL(blob) + link.download = 'DataEase' + this.$t('dataset.sync_log') + '.xls' + document.body.appendChild(link) + link.click() + document.body.removeChild(link) + }) }, getScrollStatus() { this.$nextTick(() => { - const dom = document.querySelector(".filter-texts-container"); - this.showScroll = dom && dom.scrollWidth > dom.offsetWidth; - }); + const dom = document.querySelector('.filter-texts-container') + this.showScroll = dom && dom.scrollWidth > dom.offsetWidth + }) }, resizeObserver() { this.resizeForFilter = new ResizeObserver((entries) => { - if (!this.filterTexts.length) return; - this.layoutResize(); - }); + if (!this.filterTexts.length) return + this.layoutResize() + }) this.resizeForFilter.observe( - document.querySelector("#resize-for-filter") - ); + document.querySelector('#resize-for-filter') + ) }, - layoutResize: _.debounce(function () { - this.getScrollStatus(); + layoutResize: _.debounce(function() { + this.getScrollStatus() }, 200), scrollPre() { - const dom = document.querySelector(".filter-texts-container"); - dom.scrollLeft -= 10; + const dom = document.querySelector('.filter-texts-container') + dom.scrollLeft -= 10 if (dom.scrollLeft <= 0) { - dom.scrollLeft = 0; + dom.scrollLeft = 0 } }, scrollNext() { - const dom = document.querySelector(".filter-texts-container"); - dom.scrollLeft += 10; - const width = dom.scrollWidth - dom.offsetWidth; + const dom = document.querySelector('.filter-texts-container') + dom.scrollLeft += 10 + const width = dom.scrollWidth - dom.offsetWidth if (dom.scrollLeft > width) { - dom.scrollLeft = width; + dom.scrollLeft = width } }, clearFilter() { - this.$refs.filterUser.clearFilter(); + this.$refs.filterUser.clearFilter() }, clearOneFilter(index) { - this.$refs.filterUser.clearOneFilter(index); - this.$refs.filterUser.search(); + this.$refs.filterUser.clearOneFilter(index) + this.$refs.filterUser.search() }, filterDraw(condition, filterTexts = []) { - this.cacheCondition = condition; - this.filterTexts = filterTexts; - this.initSearch(); + this.cacheCondition = condition + this.filterTexts = filterTexts + this.initSearch() }, filterShow() { - this.$refs.filterUser.init(); + this.$refs.filterUser.init() }, createTimer() { - this.initSearch(); + this.initSearch() if (!this.timer) { this.timer = setInterval(() => { - this.timerSearch(false); - }, 15000); + this.timerSearch(false) + }, 15000) } }, destroyTimer() { if (this.timer) { - clearInterval(this.timer); - this.timer = null; + clearInterval(this.timer) + this.timer = null } }, handleSizeChange(pageSize) { - this.paginationConfig.currentPage = 1; - this.paginationConfig.pageSize = pageSize; - this.search(); + this.paginationConfig.currentPage = 1 + this.paginationConfig.pageSize = pageSize + this.search() }, handleCurrentChange(currentPage) { - this.paginationConfig.currentPage = currentPage; - this.search(); + this.paginationConfig.currentPage = currentPage + this.search() }, initSearch() { - this.handleCurrentChange(1); + this.handleCurrentChange(1) }, timerSearch(showLoading = true) { if (!this.lastRequestComplete) { - return; + return } else { - this.lastRequestComplete = false; + this.lastRequestComplete = false } - const { taskId, name } = this.transCondition; + const { taskId, name } = this.transCondition const param = { orders: formatOrders(this.orderConditions), - conditions: [...this.cacheCondition], - }; - if (this.nikeName) { + conditions: [...this.cacheCondition] + } + if (this.nickName) { param.conditions.push({ field: `dataset_table_task.name`, - operator: "like", - value: this.nikeName, - }); + operator: 'like', + value: this.nickName + }) } - if (taskId && this.nikeName === name) { + if (taskId && this.nickName === name) { param.conditions.push({ - operator: "eq", + operator: 'eq', value: taskId, - field: "dataset_table_task.id", - }); + field: 'dataset_table_task.id' + }) } post( - "/dataset/taskLog/list/notexcel/" + + '/dataset/taskLog/list/notexcel/' + this.paginationConfig.currentPage + - "/" + + '/' + this.paginationConfig.pageSize, param, showLoading ) .then((response) => { - this.data = response.data.listObject; - this.paginationConfig.total = response.data.itemCount; - this.lastRequestComplete = true; + this.data = response.data.listObject + this.paginationConfig.total = response.data.itemCount + this.lastRequestComplete = true }) .catch(() => { - this.lastRequestComplete = true; - }); + this.lastRequestComplete = true + }) }, search(condition, showLoading = true) { - const { taskId, name } = this.transCondition; + const { taskId, name } = this.transCondition const param = { orders: formatOrders(this.orderConditions), - conditions: [...this.cacheCondition], - }; - if (this.nikeName) { + conditions: [...this.cacheCondition] + } + if (this.nickName) { param.conditions.push({ field: `dataset_table_task.name`, - operator: "like", - value: this.nikeName, - }); + operator: 'like', + value: this.nickName + }) } - if (taskId && this.nikeName === name) { + if (taskId && this.nickName === name) { param.conditions.push({ - operator: "eq", + operator: 'eq', value: taskId, - field: "dataset_table_task.id", - }); + field: 'dataset_table_task.id' + }) } post( - "/dataset/taskLog/list/notexcel/" + + '/dataset/taskLog/list/notexcel/' + this.paginationConfig.currentPage + - "/" + + '/' + this.paginationConfig.pageSize, param, showLoading ).then((response) => { - this.data = response.data.listObject; - this.paginationConfig.total = response.data.itemCount; - }); + this.data = response.data.listObject + this.paginationConfig.total = response.data.itemCount + }) }, showErrorMassage(massage) { - this.show_error_massage = true; - this.error_massage = massage; + this.show_error_massage = true + this.error_massage = massage }, jumpTask(item) { - this.$emit("jumpTask", item); + this.$emit('jumpTask', item) }, rowClassMethod({ row, rowIndex }) { if (this.matchLogId && this.matchLogId === row.id) { - return "row-match-class"; + return 'row-match-class' } - return ""; - }, - }, -}; + return '' + } + } +}