智能表单添加table

This commit is contained in:
慕下 2024-03-26 14:06:38 +08:00
parent 724bb33e1a
commit 615822765c
7 changed files with 128 additions and 15 deletions

View File

@ -3,17 +3,26 @@ package com.ruoyi.crm.system.controller;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.entity.SysDept;
import com.ruoyi.common.core.domain.entity.SysUser;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.crm.system.domain.DesigneeWrapperClass;
import com.ruoyi.crm.system.domain.ServiceTicket;
import com.ruoyi.crm.system.service.IServiceTicketService;
import com.ruoyi.system.service.ISysDeptService;
import com.ruoyi.system.service.ISysUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.stream.Collectors;
/**
* 服务工单Controller
@ -27,6 +36,10 @@ public class ServiceTicketController extends BaseController
{
@Autowired
private IServiceTicketService serviceTicketService;
@Autowired
private ISysUserService userService;
@Autowired
private ISysDeptService deptService;
/**
* 查询服务工单列表
@ -95,4 +108,25 @@ public class ServiceTicketController extends BaseController
{
return toAjax(serviceTicketService.deleteServiceTicketByIds(ids));
}
/**
* 指定员工树形数据
*/
@GetMapping("/designatedPerson")
public AjaxResult designatedPerson(SysUser user){
ArrayList<DesigneeWrapperClass> designeeWrapperClassArrayList = new ArrayList<>();
List<SysUser> sysUsers = userService.selectUserList(user);
for (SysUser sysUser : sysUsers) {
DesigneeWrapperClass designeeWrapperClass = new DesigneeWrapperClass();
if (sysUser.getDept() != null){
SysDept dept = sysUser.getDept();
designeeWrapperClass.setLabel(dept.getDeptName());
designeeWrapperClassArrayList.add(designeeWrapperClass);
}
}
designeeWrapperClassArrayList.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(HashSet::new), ArrayList::new));
System.out.println(designeeWrapperClassArrayList.toString());
return AjaxResult.success(designeeWrapperClassArrayList);
}
}

View File

@ -0,0 +1,18 @@
package com.ruoyi.crm.system.domain;
import lombok.Data;
import java.util.ArrayList;
/**
* 服务工单指定销售人员树形数据结构类
*/
@Data
public class DesigneeWrapperClass {
//系统员工所属部门
private String label;
//系统员工姓名(数组)
private ArrayList<DesigneeWrapperClass> children;
}

View File

@ -92,5 +92,17 @@ public class DynamicDataController extends BaseController {
mongoTemplate.save(dynamicForm);
return AjaxResult.success("保存成功");
}
//根据卡片id查询对应采集数据的列表
@GetMapping("/collectDataList")
public AjaxResult collectDataList(String id){
Query query = new Query();
query.addCriteria(Criteria.where("dynamicDataId").is(id));
List<DynamicForm> dynamicForms = mongoTemplate.find(query, DynamicForm.class);
ArrayList<Object> list = new ArrayList<>();
for (DynamicForm dynamicForm : dynamicForms) {
list.add(dynamicForm.getMap());
}
return AjaxResult.success(list);
}
}

View File

@ -17,3 +17,12 @@ export function saveDynamicData(data) {
data: data
})
}
//查询对应表单的采集数据列表
export function collectDataList(query) {
return request({
url: '/intelligentForm/collectDataList',
method: 'get',
params: {id:query}
})
}

View File

@ -36,7 +36,7 @@ export function treeselect() {
// 查询服务工单下拉树结构
export function designatedPerson() {
return request({
url: '/system/dept/designatedPerson',
url: '/system/ticket/designatedPerson',
method: 'get'
})
}

View File

@ -1,5 +1,5 @@
<template>
<div class="app-container" style="display: flex;flex-wrap: wrap;justify-content: space-between">
<div class="app-container" style="display: flex;flex-wrap: wrap">
<!-- <el-col :span="8" v-for="(o, index) in 1" :key="o" :offset="index > 0 ? 2 : 0">-->
@ -33,11 +33,12 @@ border-color: #fdfdff;">{{o.title}}</span>
<p style="font-size: 25px">{{o.pageView}}</p>
</div>
<div style="width: 30%">
<div style="font-size: 18px;
<el-link style="font-size: 18px;
color: #999595;
background-color:#ffffff;
border-color: #fdfdff;">采集数量</div>
<p style="font-size: 25px">{{o.collectionQuantity}}</p>
border-color: #fdfdff;"
@click="extendList(o.id)">采集数量</el-link>
<p style="font-size: 25px" @click="extendList(o.id)">{{o.collectionQuantity}}</p>
</div>
</div>
<div style="display: flex;justify-content: space-between">
@ -87,18 +88,37 @@ border-color: #fdfdff;">{{o.title}}</span>
<el-input v-model="extendLink" placeholder="请输入内容" :disabled="true"></el-input>
<el-button @click="copyAddress">复制</el-button>
</el-dialog>
<!-- 采集数据列表 -->
<el-dialog :title="collectTitle" :visible.sync="collectOpen" append-to-body>
<el-table border v-loading="loading" :data="collectLink" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<div >
</div>
<!-- <el-table-column label="编号" align="center" prop="id" />-->
<!-- <el-table-column label="id" align="center" prop="dynamicDataId" />-->
<!-- <el-table-column v-for="item in collectLink" :label="item.map" align="center" :prop="item" />-->
<template v-for="item in Object.keys(collectLink[0])">
<el-table-column :label="item">
<template #default="scope">
<span>{{scope.row[item]}}</span>
</template>
</el-table-column>
</template>
</el-table>
</el-dialog>
</div>
</template>
<script>
import { selectDynamicData, saveDynamicData } from "@/api/crm/intelligent";
import VueClipboard from 'vue-clipboard2';
import { selectDynamicData, saveDynamicData, collectDataList } from "@/api/crm/intelligent";
export default {
name: "Business",
dicts: ['stage_type', 'sales_stage'],
data() {
return {
id: '',
inputarr:[''],
//
loading: true,
@ -112,18 +132,22 @@ border-color: #fdfdff;">{{o.title}}</span>
showSearch: true,
//
total: 0,
//
businessList: [],
//
title: "",
//广
extendTitle: "",
//
collectTitle: "",
//
open: false,
// 广
extendOpen: false,
//
collectOpen: false,
//广
extendLink: '',
//
collectLink: [{}],
//
customerList: [],
//
@ -150,7 +174,6 @@ border-color: #fdfdff;">{{o.title}}</span>
selectDynamicData().then(response => {
this.cardList = response.data;
// this.total = response.total;
console.log(this.cardList,'list')
this.loading = false;
});
},
@ -183,7 +206,7 @@ border-color: #fdfdff;">{{o.title}}</span>
},
//广
handelExtend(id) {
this.extendLink = 'https://101.43.112.107:8080/form/extendLink/form?id='+id
this.extendLink = 'http://101.43.112.107/form/extendLink/form?id='+id
this.extendOpen = true;
this.extendTitle = "推广链接";
},
@ -195,7 +218,24 @@ border-color: #fdfdff;">{{o.title}}</span>
input.select();
document.execCommand('copy');
document.body.removeChild(input);
alert('已复制到剪贴板'); },
alert('已复制到剪贴板');
},
//
extendList(id){
this.collectLink = null;
this.id = id
this.collectOpen = true;
this.collectTitle = "采集数据";
collectDataList(this.id).then(response => {
this.collectLink = response.data
});
},
//
handleSelectionChange(selection) {
this.ids = selection.map(item => item.id)
this.single = selection.length!==1
this.multiple = !selection.length
},
},
};
</script>

View File

@ -58,8 +58,8 @@ export default {
// tenant: 'zy_tenant',
// username: 'zy_admin',
// password: 'admin123',
tenant: 'tenant1',
username: 'admin',
tenant: 'zy_tenant',
username: 'zy_admin',
password: 'admin123',
rememberMe: false,
code: '',