Browse Source

修改待办页面

dev
caoyizhong 2 years ago
parent
commit
b976055f4c
  1. 22
      src/views/activiti/Backlog.vue
  2. 587
      src/views/activiti/Repository.vue
  3. 1090
      src/views/activiti/Schedule.vue

22
src/views/activiti/Backlog.vue

@ -1,25 +1,29 @@
<template> <template>
<div style="background-color: white" :style="conheight" > <div style="background-color: white" :style="conheight" >
<a-tabs default-active-key="1" @change="callback" style="padding:0px 10px"> <!-- <div style="background-color: white" >-->
<a-tab-pane key="1" tab="我的申请"> <Schedule/>
<apply-list/> <!-- <a-tabs default-active-key="1" @change="callback" style="padding:0px 10px">-->
</a-tab-pane> <!-- <a-tab-pane key="1" tab="我的申请">-->
<a-tab-pane key="2" tab="我的待办" force-render> <!-- <apply-list/>-->
<todo-manage/> <!-- </a-tab-pane>-->
</a-tab-pane> <!-- <a-tab-pane key="2" tab="我的待办" force-render>-->
</a-tabs> <!-- <todo-manage/>-->
<!-- </a-tab-pane>-->
<!-- </a-tabs>-->
</div> </div>
</template> </template>
<script> <script>
import applyList from '@views/activiti/applyList' import applyList from '@views/activiti/applyList'
import todoManage from '@views/activiti/todoManage' import todoManage from '@views/activiti/todoManage'
import Schedule from '@views/activiti/Schedule'
export default { export default {
name: "Backlog", name: "Backlog",
components:{ components:{
applyList, applyList,
todoManage todoManage,
Schedule
}, },
data(){ data(){
return{ return{

587
src/views/activiti/Repository.vue

@ -0,0 +1,587 @@
<template>
<a-card :bordered="false">
<!-- 查询区域 -->
<div class="table-page-search-wrapper">
<a-form layout="inline" @keyup.enter.native="searchQuery">
<a-row :gutter="24">
<a-col :xl="5" :lg="7" :md="8" :sm="24">
<a-form-item label="物资类型">
<j-dict-select-tag type="list" v-model="queryParam.materialType" dictCode="material_type"
placeholder="请选择物资类型" />
</a-form-item>
</a-col>
<a-col :xl="5" :lg="7" :md="8" :sm="24">
<a-form-item label="流程发起时间" :labelCol="labelCol" :wrapperCol="wrapperCol">
<a-range-picker
format="YYYY-MM-DD"
:value="processTime"
:placeholder="['开始时间', '结束时间']"
@change="processDateChange"
/>
</a-form-item>
</a-col>
<a-col :xl="5" :lg="7" :md="8" :sm="24" :hidden="showdw">
<a-form-item label="流程发起部门">
<a-select v-model="queryParam.departId" placeholder="请输入项目部" @mouseenter="getUnit" >
<a-select-option v-for="(item,index) in queryParamsUntil" :key="index" :value="item.id">{{item.departName}}</a-select-option>
</a-select>
</a-form-item>
</a-col>
<a-col :xl="5" :lg="7" :md="8" :sm="24">
<a-form-item label="流程计划">
<j-dict-select-tag type="list" v-model="queryParam.processPlan" dictCode="process_plan"
placeholder="请选择计划类型" />
</a-form-item>
</a-col>
<!--<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="需求时间">
<j-date placeholder="请选择需求时间" v-model="queryParam.needTime"></j-date>
</a-form-item>
</a-col>-->
<a-col :xl="4" :lg="7" :md="8" :sm="24">
<span style="overflow: hidden;" class="table-page-search-submitButtons">
<a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
<!-- <a @click="handleToggleSearch" style="margin-left: 8px">-->
<!-- {{ toggleSearchStatus ? '收起' : '展开' }}-->
<!-- <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>-->
<!-- </a>-->
</span>
</a-col>
</a-row>
</a-form>
</div>
<!-- 查询区域-END -->
<!--&lt;!&ndash; 操作按钮区域 &ndash;&gt;
<div class="table-operator">
<a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
<a-button type="primary" icon="download" @click="handleExportXls('预算计划采购流程')">导出</a-button>
<a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
<a-button type="primary" icon="import">导入</a-button>
</a-upload>
&lt;!&ndash; 高级查询区域 &ndash;&gt;
<j-super-query :fieldList="superFieldList" ref="superQueryModal" @handleSuperQuery="handleSuperQuery"></j-super-query>
</div>-->
<!-- table区域-begin -->
<div>
<!-- <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">-->
<!-- <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{-->
<!-- this.selectedRowKeys.length }}</a>-->
<!-- <a style="margin-left: 24px" @click="onClearSelected">清空</a>-->
<!-- </div>-->
<a-table
ref="table"
size="middle"
bordered
rowKey="id"
class="j-table-force-nowrap"
:scroll="{x:true}"
:columns="columns"
:dataSource="dataSource"
:pagination="ipagination"
:loading="loading"
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange,type:'radio'}"
:customRow="clickThenSelect"
@change="handleTableChange">
<span slot="describes" slot-scope="text, record">
<j-ellipsis :value="text" :length="20"/>
</span>
<template slot="htmlSlot" slot-scope="text">
<div v-html="text"></div>
</template>
<template slot="imgSlot" slot-scope="text">
<span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
<img v-else :src="getImgView(text)" height="25px" alt=""
style="max-width:80px;font-size: 12px;font-style: italic;"/>
</template>
<template slot="fileSlot" slot-scope="text">
<span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
<a-button
v-else
:ghost="true"
type="primary"
icon="download"
size="small"
@click="downloadFile(text)">
下载
</a-button>
</template>
<span slot="action" slot-scope="text, record">
<a @click="handleEdit(record)">编辑</a>
<a-divider type="vertical"/>
<a-dropdown>
<a class="ant-dropdown-link">更多 <a-icon type="down"/></a>
<a-menu slot="overlay">
<a-menu-item>
<a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
<a>删除</a>
</a-popconfirm>
</a-menu-item>
</a-menu>
</a-dropdown>
</span>
</a-table>
</div>
<a-tabs defaultActiveKey="1">
<a-tab-pane tab="预算计划采购流程物料清单表" key="1">
<ProcessUdgetPlanMaterialList :mainId="selectedRowKeys"/>
</a-tab-pane>
<a-tab-pane tab="预算计划采购流程物料已入清单表" key="2">
<ProcessMaterialWarehousingListList :mainId="selectedMainId" />
</a-tab-pane>
<a-tab-pane tab="预算计划采购流程物料已申请清单表" key="3">
<ProcessMaterialWarehousingApplyiList :mainId="selectedMainId" />
</a-tab-pane>
</a-tabs>
</a-card>
</template>
<script>
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import { getAction } from '@/api/manage'
import { filterObj } from '@/utils/util'
import ProcessUdgetPlanMaterialList from '@/views/processmaterials/ProcessUdgetPlanMaterialList'
import ProcessMaterialWarehousingListList from '@views/processmaterials/ProcessMaterialWarehousingListList'
import ProcessMaterialWarehousingApplyiList from '@/views/processmaterials/ProcessMaterialWarehousingApplyiList'
import JDictSelectTag from '@/components/dict/JDictSelectTag.vue'
import JSuperQuery from '@/components/jeecg/JSuperQuery.vue'
import '@/assets/less/TableExpand.less'
const MODAL_WIDTH = 1600
export default {
name: 'Repository',
props: ['multi', 'code', 'groupId', 'param'],
components: {
ProcessUdgetPlanMaterialList,
ProcessMaterialWarehousingListList,
ProcessMaterialWarehousingApplyiList,
JSuperQuery,
JDictSelectTag
},
mixins: [JeecgListMixin],
data() {
return {
showdw: true,
visible: false,
confirmLoading: false,
title: '预算计划采购流程管理列表',
description: '预算计划采购流程管理页面',
queryParam: {},
//
columns: [
{
title: '流程编号',
align: 'center',
dataIndex: 'warehousingBatch'
},
{
title: '流程提示',
align: 'center',
scopedSlots: { customRender: 'describes' },
dataIndex: 'describes'
},
{
title: '采购类型',
align: 'center',
dataIndex: 'planType_dictText'
},
{
title: '流程发起公司',
align: 'center',
dataIndex: 'company_dictText'
},
{
title: '流程发起时间',
align: 'center',
dataIndex: 'createTime'
},
{
title: '流程发起部门',
align: 'center',
dataIndex: 'departId_dictText'
},
{
title: '流程发起人',
align: 'center',
dataIndex: 'createBy'
},
{
title: '物资类型',
align: 'center',
dataIndex: 'materialType_dictText'
},
{
title: '流程计划',
align: 'center',
dataIndex: 'processPlan_dictText'
},
{
title: '需求时间',
align: 'center',
dataIndex: 'needTime',
customRender: function(text) {
return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
}
},
// {
// title: '',
// align: 'center',
// dataIndex: 'orderNumber'
// }
/* {
title: '文件id',
align: 'center',
dataIndex: 'fileId',
scopedSlots: { customRender: 'fileSlot' }
}*/
],
url: {
listByuntil: '/unitwaste/processUnitWasteWarehouseCode/listAll',
list: '/hy/processUdgetPlan/listByplan',
delete: '/hy/processUdgetPlan/delete',
deleteBatch: '/hy/processUdgetPlan/deleteBatch',
exportXlsUrl: '/hy/processUdgetPlan/exportXls',
importExcelUrl: 'hy/processUdgetPlan/importExcel'
},
dictOptions: {
company: [],
sysOrgCode: [],
materialType: [],
processPlan: []
},
/* 分页参数 */
ipagination:{
current: 1,
pageSize: 5,
pageSizeOptions: ['5', '10', '50'],
showTotal: (total, range) => {
return range[0] + "-" + range[1] + " 共" + total + "条"
},
showQuickJumper: true,
showSizeChanger: true,
total: 0
},
selectedMainId: '',
materialWarehousingListID: undefined,
superFieldList: [],
selectedRowKeys: [],
modalWidth: MODAL_WIDTH,
changeData: '',
getFileData: false,
//
queryParamsUntil:[],
//
processTime:[],
labelCol: {
xs: { span: 4 },
sm: { span: 4 },
},
wrapperCol: {
xs: { span: 20 },
sm: { span: 20 },
},
}
},
mounted() {
//this.loadColumnsInfo()
},
created() {
this.showDepart()
},
watch: {},
computed: {
showSearchFlag() {
return this.queryInfo && this.queryInfo.length > 0
}
},
methods: {
//
showDepart(){
let ue= sessionStorage.getItem('USER_INFORMATION');
let res=JSON.parse(ue);
if(res.realname == "管理员"){
this.showdw = false;
}
},
//
processDateChange: function (value, dateString) {
this.processTime = value
this.queryParam.processTimeBegin=dateString[0];
this.queryParam.processTimeEnd=dateString[1];
console.log(this.queryParam)
},
//
getUnit(){
getAction(this.url.listByuntil).then((res) => {
if (res.success) {
this.queryParamsUntil = res.result.records||res.result;
console.log(this.queryParamsUntil)
}
})
},
// initDictConfig(){
// initDictOptions('sys_depart,depart_name,id').then((res) => {
// if (res.success) {
// this.$set(this.dictOptions, 'company', res.result)
// }
// })
// initDictOptions('sys_depart,depart_name,id').then((res) => {
// if (res.success) {
// this.$set(this.dictOptions, 'sysOrgCode', res.result)
// }
// })
// initDictOptions('').then((res) => {
// if (res.success) {
// this.$set(this.dictOptions, 'materialType', res.result)
// }
// })
// initDictOptions('').then((res) => {
// if (res.success) {
// this.$set(this.dictOptions, 'processPlan', res.result)
// }
// })
// },
onClearSelected() {
this.selectedRowKeys = []
this.selectionRows = []
this.selectedMainId = ''
},
onSelectChange(selectedRowKeys, selectionRows) {
console.log("selectedRowKeys>>>>>>>>>>>>>>>",selectedRowKeys)
console.log("selectionRows>>>>>>>>>>>>>>>>>>>",selectionRows)
this.selectedMainId = selectedRowKeys[0]
this.selectedRowKeys = selectedRowKeys
this.selectionRows = selectionRows
},
loadData(arg) {
if(!this.url.list){
this.$message.error("请设置url.list属性!")
return
}
// 1
if (arg === 1) {
this.ipagination.current = 1;
}
this.onClearSelected()
var params = this.getQueryParams();//
let ue= sessionStorage.getItem('USER_INFORMATION');
let res=JSON.parse(ue);
if(res.realname !== "管理员"){
if(!!res.departIds){
params.departId = res.departIds ;
}else{
return ;
}
}
this.loading = true;
getAction(this.url.list, params).then((res) => {
console.log("ere",res);
if (res.success) {
this.dataSource = res.result.records;
this.ipagination.total = res.result.total;
}
if(res.code===510){
this.$message.warning(res.message)
}
this.loading = false;
})
},
clickThenSelect(record) {
return {
on: {
click: () => {
this.onSelectChange(record.id.split(','), [record])
}
}
}
},
queryParams() {
let paramTarget = {}
if (this.dynamicParam) {
//
Object.keys(this.dynamicParam).map(key => {
paramTarget['self_' + key] = this.dynamicParam[key]
})
}
let param = Object.assign(paramTarget, this.queryParam, this.sorter)
param.pageNo = this.pagination.current
param.pageSize = this.pagination.pageSize
return filterObj(param)
},
handleChangeInTableSelect(selectedRowKeys, selectionRows) {
//update-begin-author:taoyan date:2020902 for:issueonline LOWCOD-844
if (!selectedRowKeys || selectedRowKeys.length == 0) {
this.table.selectionRows = []
} else if (selectedRowKeys.length == selectionRows.length) {
this.table.selectionRows = selectionRows
} else {
//
let keys = this.table.selectedRowKeys
let rows = this.table.selectionRows
//
for (let i = 0; i < selectionRows.length; i++) {
let combineKey = this.combineRowKey(selectionRows[i])
if (keys.indexOf(combineKey) < 0) {
// key push
rows.push(selectionRows[i])
}
}
//
this.table.selectionRows = rows.filter(item => {
let combineKey = this.combineRowKey(item)
return selectedRowKeys.indexOf(combineKey) >= 0
})
}
//update-end-author:taoyan date:2020902 for:issueonline LOWCOD-844
this.table.selectedRowKeys = selectedRowKeys
},
handleChangeInTable(pagination, filters, sorter) {
//
if (Object.keys(sorter).length > 0) {
this.sorter.column = sorter.field
this.sorter.order = 'ascend' == sorter.order ? 'asc' : 'desc'
}
this.table.pagination = pagination
this.loadData()
},
handleCancel() {
this.close()
},
handleSubmit() {
/*if (this.getFileData) {
this.$emit('close')
this.visible = false
return
}*/
console.log('>>>>>>>>>>>>>>>>>>>>>>>>>',this.changeData)
// if (!this.multi) {
// if (this.selectionRows && this.selectionRows.length > 1) {
// this.$message.warning('')
// return false
// }
// }
if (!this.selectionRows || this.selectionRows.length == 0) {
if (this.getFileData){
this.$emit('close')
this.visible = false
return
}
this.$message.warning('请选择一条记录')
return false
}
this.$emit('ok', this.selectionRows)
this.close()
},
close() {
this.$emit('close')
this.visible = false
//this.onClearSelected()
},
show(val) {
this.visible = true
if (val) {
this.getFileData = true
let data = []
data.push(val.ids[0])
this.changeData = data
// this.loadPlan(1)
}
},
handleToggleSearch() {
this.toggleSearchStatus = !this.toggleSearchStatus
},
searchByquery() {
//this.loadData(1);
},
onlyReload() {
//this.loadData();
},
searchReset() {
this.processTime=[]
Object.keys(this.queryParam).forEach(key => {
this.queryParam[key] = ''
})
this.loadData(1);
},
combineRowKey(record) {
let res = ''
Object.keys(record).forEach(key => {
res += record[key]
})
if (res.length > 50) {
res = res.substring(0, 50)
}
return res
},
clickThenCheck(record) {
return {
on: {
click: () => {
let rowKey = this.combineRowKey(record)
if (!this.table.selectedRowKeys || this.table.selectedRowKeys.length == 0) {
let arr1 = [], arr2 = []
arr1.push(record)
arr2.push(rowKey)
this.table.selectedRowKeys = arr2
this.table.selectionRows = arr1
} else {
if (this.table.selectedRowKeys.indexOf(rowKey) < 0) {
this.table.selectedRowKeys.push(rowKey)
this.table.selectionRows.push(record)
} else {
let rowKey_index = this.table.selectedRowKeys.indexOf(rowKey)
this.table.selectedRowKeys.splice(rowKey_index, 1)
this.table.selectionRows.splice(rowKey_index, 1)
}
}
}
}
}
},
//
initDictOptionData(dictOptions) {
let obj = {}
Object.keys(dictOptions).map(k => {
obj[k] = dictOptions[k].filter(item => {
return item != null
})
})
this.dictOptions = obj
}
}
}
</script>
<style scoped>
@import '~@assets/less/common.less';
/deep/.ant-modal {
/*overflow-y: hidden;*/
width: 80% !important;
height: 93%;
top:45px
}
/deep/.ant-modal-content{
height: 100%;
/*overflow-y: hidden;*/
overflow-y: scroll;
}
/deep/.ant-modal-body{
/*height: 100%;*/
/*overflow-y: scroll;*/
}
</style>

1090
src/views/activiti/Schedule.vue

File diff suppressed because it is too large Load Diff
Loading…
Cancel
Save