作者:管理员 历史版本:1 最后编辑:龚清 更新时间:2024-09-20 15:10
基础功能
将列表数据以卡片得形式展示。
当ibps-card-list元素中注入对应得参数属性后得效果,一般作为容器使用。
<template>
<ibps-card-list
ref="crud"
:title="title"
:height="height"
:data="listData"
:width="width"
:pagination="pagination"
:pk-key="pkKey"
:toolbars="listConfig.toolbars"
:search-form="listConfig.searchForm"
:columns="listConfig.columns"
:row-handle="listConfig.rowHandle"
:loading="loading"
:create-text="createText"
:identity="identity"
@action-event="handleAction"
@sort-change="handleSortChange"
@pagination-change="handlePaginationChange"
>
<template slot="west">
<ibps-type-tree
:width="width"
:height="treeHeight"
:has-contextmenu="true"
:category-key="categoryKey"
:identity="DATATEMPLATE_TREE"
:title="$t('platform.data.data-template.data-template-classification')"
position="west"
@node-click="handleNodeClick"
@expand-collapse="handleExpandCollapse"
/>
</template>
<template slot="searchForm">
<el-form class="search-form" inline @keyup.enter.native.stop="search">
<el-form-item>
<ibps-toolbar
:identity="identity"
:actions="listConfig.toolbars"
@action-event="handleActionEvent"
/>
</el-form-item>
<el-form-item class="ibps-fr ibps-mr-20">
<el-select
v-model="searchTemplateType"
:placeholder="$t('platform.data.data-template.select-type')"
style="width: 100px;"
class="ibps-pr-5 international-group ibps-fl"
clearable
@change="search"
>
<el-option
v-for="item in templateTypeOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<template v-if="i18nEnable">
<el-select
v-model="searchName"
:placeholder="$t('common.placeholder.please-select')"
style="width: 100px;"
class="ibps-pr-5 international-group ibps-fl"
@change="changeSearchField"
>
<el-option
v-for="option in searchFieldOptions"
:key="option.value"
:label="option.label"
:value="option.value"
/>
</el-select>
<!-- 国际化搜索框 模板名称使用国际化,模板key不使用国际化-->
<ibps-international-select
v-if="isShowInternationSelect"
v-model="searchField"
:placeholder="searchPlaceholder"
class="data-template-international-select-search"
@change="search"
/>
<el-input
v-else
v-model="searchField"
:placeholder="searchPlaceholder"
style="width: 199px;margin-left: -6px;"
class="data-template-input-key ibps-fl ibps-mr-15"
clearable
@change="search"
/>
</template>
<template v-else>
<el-input
v-model="searchField"
:placeholder="searchPlaceholder"
clearable
class="input-with-select"
@change="search"
>
<el-select
slot="prepend"
v-model="searchName"
:placeholder="$t('common.placeholder.please-select')"
@change="changeSearchField"
>
<el-option
v-for="option in searchFieldOptions"
:key="option.value"
:label="option.label"
:value="option.value"
/>
</el-select>
</el-input>
</template>
<ibps-toolbar
:actions="listConfig.searchToolbars"
:identity="identity"
position="search"
@action-event="handleActionEvent"
/>
</el-form-item>
</el-form>
</template>
<template slot="item-symbol" slot-scope="scope">
<template v-if="scope.data.type === 'default'">
<i
class="symbol-icon"
:class="
scope.data.showType === 'list'
? 'ibps-icon-table'
: scope.data.showType === 'tree'
? 'ibps-icon-tree'
: 'ibps-icon-puzzle-piece'
"
/>
</template>
<template v-else-if="scope.data.type === 'dialog'">
<span class="ibps-icon-stack symbol-icon" style="font-size: 0.55em">
<i class="ibps-icon-window-maximize ibps-icon-stack-2x" />
<i
:class="
scope.data.showType === 'list'
? 'ibps-icon-table'
: scope.data.showType === 'tree'
? 'ibps-icon-tree'
: 'ibps-icon-puzzle-piece'
"
class="ibps-icon-stack-1x"
style="top: 5px"
/>
</span>
</template>
<template v-else>
<i class="symbol-icon ibps-icon-database" />
</template>
</template>
<!-- 导入数据 -->
<import-data
:id="editId"
:visible="importFormVisible"
@callback="search"
@close="(visible) => (importFormVisible = visible)"
/>
<!-- 复制数据模版 -->
<copy
:id="editId"
:copy-data="copyData"
:visible="copyDialogFormVisible"
@close="(visible) => (copyDialogFormVisible = visible)"
/>
<!--创建数据模版-->
<create
:title="createText"
:type-id="typeId"
:visible="dialogFormVisible"
@callback="search"
@close="(visible) => (dialogFormVisible = visible)"
/>
<template-builder
:id="editId"
:visible="templatebuilderDialogVisible"
@callback="search"
@close="(visible) => (templatebuilderDialogVisible = visible)"
/>
<!--数据模版预览-动态参数-->
<dynamic-params-preview
:visible="dynamicParamsDialogVisible"
:conditions="conditions"
@close="(visible) => (dynamicParamsDialogVisible = visible)"
@callback="handleDynamicParams"
/>
<!--数据模版预览-->
<data-template-render-preview
:visible="templateRendererDialogVisible"
:data="dataTemplate"
:value="selectedValue"
:multiple="multiple"
:label-key="labelKey"
:dynamic-params="dynamicParams"
preview
@close="(visible) => (templateRendererDialogVisible = visible)"
@action-event="handleTemplaterenderActionEvent"
/>
<!--数据模版预览-数据-->
<data-template-render-preview-data
:visible="previewDialogVisible"
:data="previewFormData"
@close="(visible) => (previewDialogVisible = visible)"
/>
</ibps-card-list>
</template>
<script>
import {
queryPageList,
remove,
exportFile,
getByKey
} from '@/api/platform/data/dataTemplate'
import ActionUtils from '@/utils/action'
import fecha from '@/utils/fecha'
import FixHeight from '@/mixins/height'
import Identity from '@/constants/identity'
import { templateTypeOptions } from '@/business/platform/data/constants'
import PreviewMixin from '@/business/platform/data/templaterender/preview/mixins/preview'
import IbpsCardList from '@/components/ibps-card-list'
import IbpsTypeTree from '@/business/platform/cat/type/tree'
import Create from './create'
import TemplateBuilder from '@/business/platform/data/templatebuilder/dialog'
import ImportData from './import'
import Copy from './copy'
import DynamicParamsPreview from '@/business/platform/data/templaterender/preview/dynamic-params'
import DataTemplateRenderPreview from '@/business/platform/data/templaterender/preview'
import DataTemplateRenderPreviewData from '@/business/platform/data/templaterender/preview/preview-data'
// 国际化select远程搜索 at 3.18
import IbpsInternationalSelect from '@/views/platform/international/components/ibps-international-select'
// 读取常量是否启用i18n
import { I18N_ENABLE } from '@/constant'
export default {
components: {
IbpsTypeTree,
IbpsCardList,
Create,
Copy,
ImportData,
TemplateBuilder,
DynamicParamsPreview,
DataTemplateRenderPreview,
DataTemplateRenderPreviewData,
IbpsInternationalSelect
},
mixins: [FixHeight, PreviewMixin],
data() {
return {
width: 220,
height: 500,
title: this.$t('platform.data.data-template.data-template-manage'),
createText: this.$t('platform.data.data-template.create-data-template'),
categoryKey: 'DATA_TEMPLATE_TYPE',
typeId: '',
pkKey: 'id', // 主键 如果主键不是pk需要传主键
loading: false,
dialogFormVisible: false,
templatebuilderDialogVisible: false,
importFormVisible: false,
copyDialogFormVisible: false,
identity: Identity.IBPS.DATA.DATATEMPLATE,
DATATEMPLATE_TREE: Identity.IBPS.DATA.DATATEMPLATE_TREE,
dataTemplate: {},
isShowInternationSelect: true, // 显示国际化搜索框
copyData: {},
searchField: '',
searchName: 'Q^name_^SL',
searchPlaceholder: this.$t(
'platform.data.data-template.please-input-template-name'
),
searchFieldOptions: [
{
label: this.$t('platform.data.data-template.common.template-name'),
value: 'Q^name_^SL'
},
{
label: this.$t('platform.data.data-template.common.template-key'),
value: 'Q^key_^SL'
}
],
searchTemplateType: '',
templateTypeOptions,
editId: '',
listData: [],
listConfig: {
// 查询条件
searchForm: {
prop: 'Q^name_^SL',
label: this.$t('platform.data.data-template.common.template-name')
},
searchToolbars: [
{ key: 'search', accessControl: false },
{ key: 'resetSearch', accessControl: false }
],
// 工具栏
toolbars: [{ key: 'import', type: 'primary' }, { key: 'export' }],
// 表格字段配置
columns: [
{
prop: 'name',
label: this.$t('platform.data.data-template.common.template-name')
}
],
// 管理列
rowHandle: {
actions: [
{
key: 'preview',
label: this.$t('platform.data.data-template.preview')
},
{ key: 'edit', label: this.$t('common.buttons.edit') },
{ key: 'remove', label: this.$t('common.buttons.remove') },
{ key: 'copy', label: this.$t('common.buttons.copy') }
]
}
},
pagination: {},
sorts: {}
}
},
computed: {
treeHeight() {
return this.height
},
i18nEnable() {
return I18N_ENABLE
}
},
created() {
this.loadData()
},
beforeDestroy() {
this.dataTemplate = null
this.copyData = null
this.searchFieldOptions = null
this.listData = null
this.listConfig = null
this.pagination = null
this.sorts = null
},
methods: {
// 加载数据
loadData() {
this.loading = true
queryPageList(this.getSearcFormData())
.then((response) => {
ActionUtils.handleListData(this, response.data)
this.loading = false
})
.catch(() => {
this.loading = false
})
},
/**
* 获取格式化参数
*/
getSearcFormData() {
const params = {}
if (this.$utils.isNotEmpty(this.searchField)) {
params[this.searchName] = this.searchField
}
if (this.$utils.isNotEmpty(this.typeId)) {
params['Q^TYPE_ID_^S'] = this.typeId
}
if (this.$utils.isNotEmpty(this.searchTemplateType)) {
params['Q^TYPE_^S'] = this.searchTemplateType
}
return ActionUtils.formatParams(params, this.pagination, this.sorts)
},
/**
* 处理分页事件
*/
handlePaginationChange(page) {
ActionUtils.setPagination(this.pagination, page)
this.loadData()
},
/**
* 处理排序
*/
handleSortChange(sort) {
ActionUtils.setSorts(this.sorts, sort)
this.loadData()
},
/**
* 查询
*/
search() {
ActionUtils.setFirstPagination(this.pagination)
this.loadData()
},
/**
* 重置查询
*/
resetSearch() {
this.resetSearchForm()
this.search()
},
/**
* 重置表单
*/
resetSearchForm() {
this.searchField = ''
this.searchTemplateType = ''
this.searchName = 'Q^name_^SL'
this.changeSearchField(this.searchName)
},
changeSearchField(value) {
const option = this.searchFieldOptions.find((option) => {
return option.value === value
})
this.searchPlaceholder =
this.$t('common.placeholder.please-select') + option.label
if (value === 'Q^name_^SL') {
this.isShowInternationSelect = true
} else if (value === 'Q^key_^SL') {
this.isShowInternationSelect = false
}
},
/**
* @description 处理按钮的事件 【包含增删改查】
* @param {*} buttonKey
* @param {*} position
* @param {*} data
*/
handleActionEvent(action, position, data, index) {
const buttonKey = action.key
let selection = []
if (this.$refs.crud) {
selection = this.$refs.crud.getSelectedIds()
}
this.handleAction(buttonKey, position, selection, data)
},
handleAction(command, position, selection, data) {
switch (command) {
case 'search': // 查询
this.search()
break
case 'resetSearch': // 重置查询
this.resetSearch()
break
case 'add': // 添加
this.dialogFormVisible = true
break
case 'edit': // 编辑
this.handleEdit(selection)
break
case 'remove': // 删除
ActionUtils.removeRecord(selection)
.then((ids) => {
this.handleRemove(ids)
})
.catch(() => {})
break
case 'import': // 导入
this.handleImport()
break
case 'export': // 导出
ActionUtils.selectedMultiRecord(selection)
.then((ids) => {
this.handleExport(ids)
})
.catch(() => {})
break
case 'preview': // 预览
this.handlePreview(data.key)
break
case 'copy': // 复制
this.handleCopy(data)
break
}
},
handleImport() {
this.importFormVisible = true
},
handleExport(ids) {
exportFile({ templateIds: ids })
.then((response) => {
if (!response) {
return
}
ActionUtils.exportFile(
response.data,
'dataTemplate_' + fecha.formatDate('yyyyMMddHHmmss') + '.zip'
)
})
.catch(() => {})
},
handleEdit(id) {
this.templatebuilderDialogVisible = true
this.editId = id
},
handleCopy(data) {
this.copyDialogFormVisible = true
this.editId = data.id
this.copyData = data
},
/**
* 处理删除
*/
handleRemove(ids) {
remove({ dataTemplateIds: ids })
.then((response) => {
ActionUtils.removeSuccessMessage()
this.search()
})
.catch(() => {})
},
handleNodeClick(typeId) {
this.typeId = typeId
this.loadData()
},
handleExpandCollapse(isExpand) {
this.width = isExpand ? 200 : 30
},
// 预览
handlePreview(key) {
// this.dialogLoading = true
this.dataTemplate = {}
getByKey({
dataTemplateKey: key
})
.then((response) => {
// 从后台获取数据
this.dataTemplate = this.$utils.parseData(response.data)
setTimeout(() => {
this.previewTemplate()
}, 100)
// this.dialogLoading = false
})
.catch(() => {
// this.dialogLoading = false
})
}
}
}
</script>
<style lang="scss">
.international-group .el-input__inner {
border-radius: 3px 0 0 3px;
}
.international-group .el-input {
display: inline-block;
}
.data-template-international-select-search {
float: left;
margin-right: 15px;
margin-left: -6px;
width: 199px;
.el-select .el-input.is-focus .el-input__inner {
border-radius: 0 3px 3px 0;
}
}
.data-template-international-select-search .el-input__inner {
border-radius: 0 3px 3px 0;
}
.data-template-input-key {
.el-input__inner {
border-radius: 0 3px 3px 0;
}
}
</style>