<!doctype html>
|
<html>
|
<head>
|
<meta charset="utf-8"><meta http-equiv="Expires" content="0"><meta http-equiv="Pragma" content="no-cache"><meta http-equiv="Cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache">
|
<title>协议管理</title>
|
|
<script type="text/javascript">
|
var pageVue = null;
|
function loadJsCss(callback) {
|
var jscss_urls = [];
|
window.top.initJsCss(document, jscss_urls, callback);
|
};
|
|
function initVue() {
|
pageVue = new TabTableVue({
|
el: "#vbody",
|
data: {
|
title: "协议管理",
|
dataname: "agm_agreement",
|
//Tab项设置
|
tabs_d: [//agm_agreement
|
{code: "Input", name: "协议申请", dataname: "agm_agreement", filterTxt: " (agm_agreement.state_code='Input' or agm_agreement.state_code='Rejected' or agm_agreement.state_code='OpeningApproval')", orderby: "agm_agreement.update_time desc",},
|
// {code: "Working", name: "审批中", dataname: "agm_agreement", filterTxt: " state_code='OpeningApproval'", orderby: "update_time desc",},
|
{code: "Open", name: "生效", dataname: "agm_agreement", filterTxt: " agm_agreement.state_code='Open'", orderby: "agm_agreement.update_time desc", },
|
{code: "Close", name: "终止", dataname: "agm_agreement", filterTxt: " agm_agreement.state_code='Cancel'", orderby: "agm_agreement.update_time desc",},
|
// {code: "Overdue", name: "逾期", dataname: "agm_agreement", filterTxt: " (date_to < NOW())", orderby: "update_time desc",},
|
{code: "All", name: "全部", dataname: "agm_agreement", filterTxt: "1=1", orderby: "agm_agreement.update_time desc",},
|
],
|
// d_tabs: {
|
// Input: true,
|
// Working: true,
|
// Open: true,
|
// Close: true,
|
// Overdue: true,
|
// All: true,
|
// },
|
tabsobj: {},
|
tabs: [],
|
cbuttons_r: {},
|
ctabs_r: {},
|
selectedrows: [],
|
markSelected: false,
|
isCustomer: false,
|
},
|
created() {
|
this.isCustomer = window.top.vue.isCustomer
|
},
|
|
mounted() {
|
var me = this;
|
if (window.top.tab.selected.option.page_id) {
|
this.title = window.top.tab.selected.option.menutitle
|
getPageByPageId(window.top.tab.selected.option.page_id, function(result){
|
me.cbuttons_r = result.buttons_r;
|
me.ctabs_r = result.tabs_r;
|
// me.ctabs_r = me.d_tabs //标识2:
|
var tabsarr = [];
|
me.tabs_d.map(e=>{
|
if(me.ctabs_r[e.code]){
|
tabsarr.push(e)
|
}
|
})
|
me.tabs = tabsarr;
|
|
if(me.tabs.length>0){
|
me.activeTabName = me.tabs[0].code;
|
}
|
|
//初始化Tabs
|
me.initTabsPage(function() {
|
//获取数据
|
me.initData();
|
});
|
|
me.$nextTick(() => { // 以服务的方式调用的 Loading 需要异步关闭
|
hideLoading();
|
});
|
})
|
}
|
},
|
|
methods:{
|
onhandleClick() {
|
this.initData();
|
},
|
|
initData() {
|
var me = this;
|
me.tableButtonClick();
|
this.doQueryByTab(function(result, callback) {//查询后的回调,用于获取字段的
|
if (result.meta && result.meta[me.selectTabObj.dataname] && result.meta[me.selectTabObj.dataname].fields) {
|
var metas = clone(result.meta[me.selectTabObj.dataname].fields);
|
var filterFields_ = [];
|
var tableFields_ = [];
|
|
metas.map(f=>{
|
f.isshow = "T";
|
|
if (me.selectTabObj.code == 'Input') {
|
if (f.field == 'contract_attachment_name') {
|
f.isshow = "F";
|
}
|
}
|
|
if (me.isCustomer && (f.field == "contact_department" || f.field == "contact_phone"
|
|| f.field == "template_attachment_name" || f.field == "logistics_code"
|
|| f.field == "creator_name" || f.field == "create_time" || f.field == "update_time"
|
)) {
|
f.isshow = "F"
|
f.isfilter = false
|
}
|
|
if (me.isCustomer && me.selectTabObj.code != "Close" && (f.field == "suspend_date" || f.field == "suspend_remark")) {
|
f.isshow = "F"
|
f.isfilter = false
|
}
|
|
if (f.isfilter) {
|
filterFields_.push(clone(f));
|
}
|
else {
|
var filter_f = clone(f);
|
filter_f.isshow = "F";
|
filterFields_.push(filter_f);
|
}
|
|
tableFields_.push(clone(f));
|
})
|
|
if (me.selectTabObj.code != "Input") {
|
var file_operation = {
|
isshow: "T", field: "file_operation", name: "操作", inputtype: "buttons",
|
width: "350", align: "center", isfixed: "right",
|
buttons: [
|
{code: "B001", name: "发起", type: "success"},
|
{code: "B002", name: "签章", type: "warning"},
|
{code: "B003", name: "浏览/下载", type: "primary"},
|
{code: "B004", name: "撤回", type: "danger"},
|
{code: "B005", name: "作废", type: "danger"},
|
]
|
}
|
if (me.isCustomer) {
|
file_operation = {
|
isshow: "T", field: "file_operation", name: "操作", inputtype: "buttons",
|
width: "350", align: "center", isfixed: "right",
|
buttons: [
|
// {code: "B001", name: "发起", type: "success"},
|
{code: "B002", name: "签章", type: "warning"},
|
{code: "B003", name: "浏览/下载", type: "primary"},
|
{code: "B004", name: "撤回", type: "danger"},
|
// {code: "B005", name: "作废", type: "danger"},
|
]
|
}
|
}
|
|
tableFields_.push(file_operation);
|
}
|
|
if (!me.selectTabObj.filterFields || (me.selectTabObj.filterFields && me.selectTabObj.filterFields.length == 0)) {
|
me.selectTabObj.filterFields = clone(filterFields_);
|
me.selectTabObj.tableFields = clone(tableFields_);
|
|
// me.selectTabObj.filterFields = clone(me.default_filterFields);
|
// me.selectTabObj.tableFields = clone(me.default_tableFields);
|
|
//字段数组转字段obj,目的为了筛选时获取字段属性
|
me.fieldsToFieldsObj();
|
|
//设置字段事件
|
me.tableFieldClick();
|
}
|
}
|
|
if (callback) {
|
callback();
|
}
|
});
|
},
|
|
// 设置表格工具栏按键事件
|
tableButtonClick() {
|
var me = this;
|
var tablebuttonClick = {};
|
tablebuttonClick.Input = [
|
{
|
// name: "新增", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.add ? me.cbuttons_r.add : false,
|
code: "add", isselected: false, classname: "",
|
onclick: function(obj) {
|
// obj.selectedList
|
me.openAgreement('add', obj.selectedList[0]);
|
}
|
},
|
{
|
// name: "提交", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.submit ? me.cbuttons_r.submit : false, type: "success",
|
code: "submit", isselected: true, classname: "",
|
disabled: function(selectRowList) {
|
var bo_ = true;
|
if (selectRowList[0] && selectRowList[0].state_code == "Input") {
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
|
// obj.selectedList
|
// me.closeData('browse', obj.selectedList[0]);
|
// me.commitData(obj.selectedList[0]);
|
me.openAgreement('edit', obj.selectedList[0]);
|
}
|
},
|
{
|
// name: "详情", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.formdetail ? me.cbuttons_r.formdetail : false,
|
code: "formdetail", isselected: true, classname: "",
|
disabled: function(selectRowList) {
|
var bo_ = true;
|
if (selectRowList[0]) {
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
// obj.selectedList
|
me.openAgreement('browse', obj.selectedList[0]);
|
}
|
},
|
{
|
// name: "编辑", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.edit ? me.cbuttons_r.edit : false,
|
code: "edit", isselected: true, classname: "",
|
disabled: function(selectRowList) {
|
var bo_ = true;
|
if (selectRowList[0] && selectRowList[0].state_code == "Input") {
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
// obj.selectedList
|
me.openAgreement('edit', obj.selectedList[0]);
|
}
|
},
|
{
|
// name: "删除", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.delete ? me.cbuttons_r.delete : false, type: "danger",
|
code: "delete", isselected: true, classname: "",
|
disabled: function(selectRowList) {
|
var bo_ = true;
|
if (selectRowList[0] && selectRowList[0].state_code == "Input") {
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
me.delData()
|
// obj.selectedList
|
// me.closeData('browse', obj.selectedList[0]);
|
// me.closeData();
|
}
|
},
|
]
|
|
tablebuttonClick.Open = [
|
// {
|
// name: "物流单号", type: "primary", icon: "el-icon-truck",
|
// isbuttonshow: me.cbuttons_r.logisticsCode ? me.cbuttons_r.logisticsCode : false,
|
// code: "logisticsCode", isselected: true, classname: "",
|
// disabled: function(selectRowList, selectedList) {
|
// var bo_ = true;
|
// if (selectRowList[0]) {
|
// bo_ = false;
|
// }
|
// return bo_
|
// },
|
// onclick: function(obj) {
|
// // obj.selectedList
|
// me.editLogisticsCode();
|
// }
|
// },
|
|
// {
|
// name: "协议打印", type: "primary", icon: "el-icon-copy-document",
|
// isbuttonshow: me.cbuttons_r.PDFFile ? me.cbuttons_r.PDFFile : false,
|
// code: "PDFFile", isselected: true, classname: "",
|
// disabled: function(selectRowList, selectedList) {
|
// var bo_ = true;
|
// if (selectRowList[0] && selectRowList[0].comeback_attachment_id) {
|
// bo_ = false;
|
// }
|
// return bo_
|
// },
|
// onclick: function(obj) {
|
// // obj.selectedList
|
// me.showFileImgByFileId(me.selectTabObj.selectedrow, 'comeback_attachment_name', 'comeback_attachment_id', me.dataname)
|
// }
|
// },
|
// {
|
// name: "协议回挂", type: "primary", icon: "el-icon-copy-document",
|
// isbuttonshow: me.cbuttons_r.uploadFilePDF ? me.cbuttons_r.uploadFilePDF : false,
|
// code: "uploadFilePDF", isselected: true, classname: "",
|
// disabled: function(selectRowList, selectedList) {
|
// var bo_ = true;
|
// if (selectRowList[0]) {
|
// bo_ = false;
|
// }
|
// return bo_
|
// },
|
// onclick: function(obj) {
|
// // obj.selectedList
|
// me.onPopupByUploadFile(me.selectTabObj.selectedrow, 'comeback_attachment_name', 'comeback_attachment_id', me.dataname)
|
// }
|
// },
|
{
|
name: "续签", type: "primary", icon: "el-icon-copy-document",
|
isbuttonshow: me.cbuttons_r.agmCopy ? me.cbuttons_r.agmCopy : false,
|
code: "agmCopy", isselected: true, classname: "",
|
islistselected: true, // 可以多选
|
disabled: function(selectRowList, selectedList) {
|
var bo_ = true;
|
if (selectedList.length) { // 可以多选
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
// obj.selectedList
|
me.onCopyList(function(suspendData){
|
var selectedList_ = clone(obj.selectedList);
|
// selectedList_.map(row=>{
|
// var old_row = clone(row);
|
// var new_row = clone(row);
|
|
// // 原协议的下一天
|
// var nextDate = new Date(old_row.date_to);
|
// if (old_row.suspend_date) { // 如果有终止日期
|
// nextDate = new Date(old_row.suspend_date);
|
// }
|
// nextDate.setDate(nextDate.getDate() + 1);
|
|
// new_row.id = "";
|
// new_row.agreement_no = "";
|
// new_row.state_code = "";
|
// new_row.state_name = "";
|
|
// new_row.date_from = dateFormat(nextDate, "yyyy-MM-dd");
|
// new_row.date_to = suspendData.date_to;
|
// new_row.suspend_date = "";
|
|
// new_row.contract_attachment_id = "";
|
// new_row.contract_attachment_name = "";
|
// new_row.comeback_attachment_id = "";
|
// new_row.comeback_attachment_name = "";
|
// new_row.logistics_code = "";
|
|
// new_row.source_id = old_row.id;
|
// })
|
me.onSaveList(selectedList_);
|
// return 0;
|
})
|
|
}
|
},
|
{
|
name: "变更", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.change ? me.cbuttons_r.change : false,
|
code: "change", isselected: true, classname: "",
|
disabled: function(selectRowList) {
|
var bo_ = true;
|
if (selectRowList[0] && selectRowList[0].state_code == "Open") {
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
// obj.selectedList
|
me.openAgreement('change', obj.selectedList[0]);
|
}
|
},
|
{
|
// name: "作废", // type: "primary", // icon: "el-icon-edit",
|
isbuttonshow: me.cbuttons_r.repeal ? me.cbuttons_r.repeal : false, type: "danger",
|
code: "suspend", isselected: true, classname: "",
|
islistselected: true, // 可以多选
|
disabled: function(selectRowList, selectedList) {
|
var bo_ = true;
|
if (selectedList.length) { // 可以多选
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
me.onSuspend(function(suspendData){
|
var selectedList_ = clone(obj.selectedList);
|
selectedList_.map(row=>{
|
row.suspend_date = suspendData.suspend_date
|
row.suspend_remark = suspendData.suspend_remark
|
})
|
me.onSaveSuspend(selectedList_);
|
})
|
|
// me.cancelConfirm();
|
}
|
},
|
|
]
|
|
tablebuttonClick.Close = [
|
{
|
name: "续签", type: "primary", icon: "el-icon-copy-document",
|
isbuttonshow: me.cbuttons_r.agmCopy ? me.cbuttons_r.agmCopy : false,
|
code: "agmCopy", isselected: true, classname: "",
|
islistselected: true, // 可以多选
|
disabled: function(selectRowList, selectedList) {
|
var bo_ = true;
|
if (selectedList.length) { // 可以多选
|
bo_ = false;
|
}
|
return bo_
|
},
|
onclick: function(obj) {
|
// obj.selectedList
|
me.onCopyList(function(suspendData){
|
var selectedList_ = clone(obj.selectedList);
|
var newList_ = [];
|
selectedList_.map(row=>{
|
var old_row = clone(row);
|
var new_row = clone(row);
|
|
// 原协议的下一天
|
var nextDate = new Date(old_row.date_to);
|
if (old_row.suspend_date) { // 如果有终止日期
|
nextDate = new Date(old_row.suspend_date);
|
}
|
nextDate.setDate(nextDate.getDate() + 1);
|
|
new_row.id = "";
|
new_row.agreement_no = "";
|
new_row.state_code = "Input";
|
new_row.state_name = "草稿";
|
|
new_row.date_from = dateFormat(nextDate, "yyyy-MM-dd");
|
new_row.date_to = suspendData.date_to;
|
new_row.suspend_date = null;
|
|
new_row.contract_attachment_id = null;
|
new_row.contract_attachment_name = null;
|
new_row.comeback_attachment_id = null;
|
new_row.comeback_attachment_name = null;
|
new_row.logistics_code = "";
|
|
new_row.source_id = old_row.id;
|
newList_.push(new_row);
|
})
|
me.onSaveList(selectedList_);
|
})
|
}
|
},
|
]
|
|
if (tablebuttonClick[this.activeTabName]) {
|
this.selectTabObj.tablebuttonClick = tablebuttonClick[this.activeTabName];
|
}
|
else {
|
this.selectTabObj.tablebuttonClick = []
|
}
|
},
|
|
onSaveSuspend(list) {
|
var me = this;
|
if (list.length) {
|
var row = list[0];
|
var param = {
|
dataname: me.selectTabObj.dataname,
|
data: {},
|
}
|
param.data[me.selectTabObj.dataname] = {
|
id: row.id,
|
suspend_date: row.suspend_date,
|
suspend_remark: row.suspend_remark
|
};
|
Server.call("root/data/saveEntity", param, function(result) {
|
console.log(result);
|
if (result.success) {
|
list.remove(row);
|
me.onSaveSuspend(list);
|
}
|
});
|
}
|
else {
|
me.onQuery();
|
}
|
|
},
|
|
onSaveList(list) {
|
var me = this;
|
if (list.length) {
|
var row = list[0];
|
var list_ = []
|
list.map(f=>{
|
list_.push(f.id)
|
})
|
var param = {
|
dataname: me.selectTabObj.dataname,
|
id:row.id
|
}
|
// param.data[me.selectTabObj.dataname] = row;
|
// param.data[me.selectTabObj.dataname] = {
|
// id:list_
|
// };
|
Server.call("root/data/clone", param, function(result) {
|
console.log(result);
|
if (result.success) {
|
Root.message({
|
type: 'success',
|
message: '续签成功'
|
});
|
list.remove(row);
|
me.onSaveList(list);
|
}
|
});
|
}
|
else {
|
me.onQuery();
|
}
|
|
},
|
|
tableFieldClick() {
|
var me = this;
|
var tablefieldClick = {};
|
//表格字段事件设置
|
tablefieldClick = {
|
file_operation: { //字段事件设置
|
buttons: {
|
onclick: function(obj, code) {//数据值点击事件
|
var signer = "partya";
|
if (me.isCustomer) {
|
signer = "partyb"
|
}
|
if (code == "B001") { // 发起
|
me.onWeaverCreatebyFile("agm_agreement", obj.row.id, function() {
|
// 打开签章页面
|
// me.onSignature("agm_agreement", obj.row.id, signer);
|
|
Root.message({
|
type: 'success',
|
message: '已发起签章'
|
});
|
me.onQuery();
|
});
|
}
|
else if (code == "B002") { // 打开签章页面
|
me.onSignature("agm_agreement", obj.row.id, signer);
|
}
|
else if (code == "B003") { // 浏览/下载
|
//打开预览sign_state_code : SIGNING("签署中"), COMPLETE("签署完成"), TERMINATED("已作废"), DRAFT("待发起");
|
if (obj.row.document_id && obj.row.contract_id) { // 已签章的预览
|
me.onPreviewSignature("agm_agreement", obj.row.id);
|
}
|
else { // 未签章的预览
|
me.previewAuthorization(obj.row.contract_attachment_id, "协议.pdf", me.selectTabObj.dataname)
|
}
|
}
|
else if (code == "B004") { // 撤回
|
me.onRecallSignature("agm_agreement", obj.row.id, signer, function() {
|
me.onQuery();
|
});
|
}
|
else if (code == "B005") { // 作废
|
me.onCancelSignature("agm_agreement", obj.row.id, signer, function() {
|
me.onQuery();
|
});
|
}
|
},
|
},
|
},
|
agreement_no: {//字段事件设置
|
val: {//有值时的点击事件
|
notclick_val: "",//不可点击的值,1、是数组["11","22"];2、以“;”分隔的字符串"111;222"
|
notclick_bindfield: [],//当该字段值等于指定字段值时不可点击["filterfield": "111"]
|
onclick: function(obj) {//数据值点击事件
|
//打开
|
me.onShowData(obj);
|
},
|
},
|
defaultval: {
|
val: "查看",//空值时的显示值
|
onclick: function(obj) {//默认值点击事件,此事件需要设置val才有效
|
me.onShowData(obj);
|
}
|
},
|
},
|
state_name: {//状态
|
val: {//有值时的点击事件
|
notclick_val: ["草稿","草稿"],
|
notclick_bindfield: [],
|
onclick: function(obj) {
|
var config = {
|
totab: false,
|
width: "1100px",
|
height: "520px",
|
icon: "icon-product",
|
text: "流程步骤",
|
id: "popup_workflow_step_user" + obj.row.id,
|
url: "module/tool/page/popup_workflow_step_user.html?v=2023020703",
|
data: obj.row,
|
delta: {},
|
sceneCode: "browse",
|
callback: function(obj, callback) {
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
},
|
},
|
template_attachment_name: {//字段事件设置
|
val: {//有值时的点击事件
|
notclick_val: "",//不可点击的值,1、是数组["11","22"];2、以“;”分隔的字符串"111;222"
|
notclick_bindfield: [{field:"contract_attachment_id", val: null}],//当该字段值等于指定字段值时不可点击["filterfield": "111"]
|
onclick: function(obj) {//数据值点击事件
|
//打开
|
me.showFileImgByFileId(obj.row, "template_attachment_name", "contract_attachment_id", me.dataname);
|
},
|
},
|
},
|
contract_attachment_name: {//字段事件设置
|
defaultval: {
|
val: "原协议上传",//空值时的显示值
|
onclick: function(obj) {//默认值点击事件,此事件需要设置val才有效
|
me.onPopupByUploadFile(obj.row, "contract_attachment_name", "contract_attachment_id", me.dataname);
|
}
|
},
|
val:{
|
onclick: function(obj){
|
me.showFileImgByFileId(obj.row, "contract_attachment_name", "contract_attachment_id", me.dataname);
|
}
|
},
|
suffixval: {
|
val: "原协议上传",//有值时的后缀,此后缀和单位后缀不同,如:详情,更多,查看等
|
onclick: function(obj) {//有值时的后缀点击事件,此事件需要设置val才有效
|
me.onPopupByUploadFile(obj.row, "contract_attachment_name", "contract_attachment_id", me.dataname);
|
}
|
},
|
},
|
|
comeback_attachment_name: {//字段事件设置
|
defaultval: {
|
val: "协议回挂",//空值时的显示值
|
onclick: function(obj) {//默认值点击事件,此事件需要设置val才有效
|
me.onPopupByUploadFile(obj.row, "comeback_attachment_name", "comeback_attachment_id", me.dataname);
|
}
|
},
|
val:{
|
onclick: function(obj){
|
me.showFileImgByFileId(obj.row, "comeback_attachment_name", "comeback_attachment_id", me.dataname);
|
}
|
},
|
suffixval: {
|
val: "协议回挂",//有值时的后缀,此后缀和单位后缀不同,如:详情,更多,查看等
|
onclick: function(obj) {//有值时的后缀点击事件,此事件需要设置val才有效
|
me.onPopupByUploadFile(obj.row, "comeback_attachment_name", "comeback_attachment_id", me.dataname);
|
}
|
},
|
},
|
};
|
|
tablefieldClickBeforeOpen = {
|
agreement_no: {//字段事件设置
|
val: {//有值时的点击事件
|
notclick_val: "",//不可点击的值,1、是数组["11","22"];2、以“;”分隔的字符串"111;222"
|
notclick_bindfield: [],//当该字段值等于指定字段值时不可点击["filterfield": "111"]
|
onclick: function(obj) {//数据值点击事件
|
//打开
|
me.onShowData(obj);
|
},
|
},
|
defaultval: {
|
val: "查看",//空值时的显示值
|
onclick: function(obj) {//默认值点击事件,此事件需要设置val才有效
|
me.onShowData(obj);
|
}
|
},
|
},
|
state_name: {//状态
|
val: {//有值时的点击事件
|
notclick_val: ["草稿","草稿"],
|
notclick_bindfield: [],
|
onclick: function(obj) {
|
var config = {
|
totab: false,
|
width: "1100px",
|
height: "520px",
|
icon: "icon-product",
|
text: "流程步骤",
|
id: "popup_workflow_step_user" + obj.row.id,
|
url: "module/tool/page/popup_workflow_step_user.html?v=2023020703",
|
data: obj.row,
|
delta: {},
|
sceneCode: "browse",
|
callback: function(obj, callback) {
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
},
|
},
|
template_attachment_name: {//字段事件设置
|
val: {//有值时的点击事件
|
notclick_val: "",//不可点击的值,1、是数组["11","22"];2、以“;”分隔的字符串"111;222"
|
notclick_bindfield: [{field:"contract_attachment_id", val: null}],//当该字段值等于指定字段值时不可点击["filterfield": "111"]
|
onclick: function(obj) {//数据值点击事件
|
//打开
|
me.showFileImgByFileId(obj.row, "template_attachment_name", "contract_attachment_id", me.dataname);
|
},
|
},
|
},
|
};
|
|
if (this.selectTabObj.code != 'Input') {
|
this.selectTabObj.tablefieldClick = tablefieldClick;
|
} else {
|
this.selectTabObj.tablefieldClick = tablefieldClickBeforeOpen;
|
}
|
},
|
|
// 发起签章
|
// onFileSignature(dataname, row, callback) {
|
// let me = this;
|
// var is_signature = this.selectTabObj.selectedrow.is_signature ? true : false;
|
// var signer = null; // 甲乙方的标识
|
// if (is_signature) { // 已签章
|
// Root.message({
|
// type: 'info',
|
// message: '文件已发起'
|
// });
|
// }
|
// else { // 待发布
|
// this.onWeaverCreatebyFile(dataname, row.id, callback);
|
// }
|
// },
|
|
onSuspend(callback) {
|
var me = this;
|
var config = {
|
totab: false, //true: 以Tab导航的方式打开
|
width: "400px",
|
height: "400px",
|
icon: "icon-product",
|
text: "终止设置",
|
url: "module/tool/page/popup_suspend.html",
|
data: {},
|
delta: {},
|
sceneCode: "add", //"add"//"browse",
|
callback: function(popupobj, popupcallback) {
|
callback(popupobj.row);
|
if (popupcallback) {
|
popupcallback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
|
onShowData(obj) {
|
var me = this;
|
var row = obj.row;
|
|
//1. empty row
|
if (!row || !row.id) {
|
Root.message({
|
type: 'warning',
|
message: '请选择要查看的数据'
|
});
|
return false;
|
}
|
|
var config = {
|
totab: true, //true: 以Tab导航的方式打开
|
width: "900px",
|
height: "900px",
|
icon: "icon-product",
|
text: "协议详情",
|
id: "apply_edit_b" + row.id,
|
url: "module/md/page/customer/page/customer_list_agreement_edit.html",
|
data: row,
|
delta: {},
|
sceneCode: "browse", //"add"//"browse",
|
callback: function(obj, callback) {
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
|
onAddData() {
|
var me = this;
|
|
var config = {
|
totab: true, //true: 以Tab导航的方式打开
|
icon: "icon-product",
|
text: "协议信息",
|
id: "apply_edit",//totab: true时需设置,用于判断是否已打开此页面
|
url: "module/md/page/customer/page/customer_list_agreement_edit.html",
|
data: {},
|
delta: {},
|
sceneCode: "add",//"refuseedit",//"approval", //"add"//"browse",
|
callback: function(obj, callback) {
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
|
commitData(obj) {
|
var me = this;
|
Root.confirm('确定提交协议' + obj.agreement_no + '吗?', '提交提示', {
|
confirmButtonText: '提交',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
var param = {
|
dataname: me.selectTabObj.dataname,
|
id: obj.id,
|
// to_state: "OpeningApproval"
|
}
|
Server.call("root/data/commit", param, function(result) {
|
console.log(result);
|
if (result.success) {
|
Root.message({
|
type: 'success',
|
message: '提交成功'
|
});
|
me.onQuery();
|
}
|
});
|
}).catch(() => {
|
Root.message({
|
type: 'info',
|
message: '已取消'
|
});
|
});
|
},
|
|
onEditData() {
|
var me = this;
|
var row = this.selectTabObj.selectedrow;;
|
|
//1. empty row
|
if (!row || !row.id) {
|
Root.message({
|
type: 'warning',
|
message: '请选择要编辑的数据'
|
});
|
return false;
|
}
|
|
var config = {
|
totab: true, //true: 以Tab导航的方式打开
|
icon: "icon-product",
|
text: "协议信息",
|
id: "apply_edit" + row.id,//totab: true时需设置,用于判断是否已打开此页面
|
url: "module/md/page/customer/page/customer_list_agreement_edit.html",
|
data: row,
|
delta: {},
|
sceneCode: "edit",//"refuseedit",//"approval", //"add"//"browse",
|
callback: function(obj, callback) {
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
delData: function(scope) {
|
let me = this;
|
var row = me.selectTabObj.selectedrow;
|
let name_ = "该数据";
|
|
if (!row.id) {
|
Root.message({
|
type: 'warning',
|
message: '该事件需存在数据ID'
|
});
|
return
|
}
|
if (row.agreement_no) {
|
name_ = "_" + row.agreement_no + "_";
|
}
|
|
Root.confirm('确定删除' + name_ + '吗?', '删除提示', {
|
confirmButtonText: '删除',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
let param = {
|
id: row.id,
|
dataname: me.selectTabObj.dataname,
|
}
|
Server.call("root/data/deleteEntity", param, function(result) {
|
Root.message({
|
type: 'success',
|
message: '删除成功!'
|
});
|
me.onQuery();
|
});
|
}).catch(() => {
|
Root.message({
|
type: 'info',
|
message: '已取消删除'
|
});
|
});
|
},
|
|
//作废模板
|
cancelConfirm() {
|
let me = this;
|
data = me.selectTabObj.selectedrow;
|
Root.confirm('确定终止-' + data.agreement_no + '-吗?', '终止提示', {
|
confirmButtonText: '确定',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
me.onCancelData();
|
}).catch(() => {
|
Root.message({
|
type: 'info',
|
message: '已取消终止'
|
});
|
});
|
},
|
|
onCancelData() {
|
var me = this;
|
|
let param = {
|
dataname: me.dataname,
|
data: {
|
"agm_agreement" :{
|
id: me.selectTabObj.selectedrow.id,
|
date_suspend: "", // 终止日期
|
remark_suspend: "", // 终止说明
|
state_code: "Cancel",
|
state_name: "终止",
|
}
|
},
|
}
|
|
Server.call("root/data/saveEntity", param, function(result) {
|
console.log(result);
|
Root.message({
|
type: 'success',
|
message: '已作废'
|
});
|
me.onQuery();
|
});
|
},
|
|
showFileImgByFileId(row, filenamefield, fileidfield, dataname) {
|
let me = this;
|
var file_name = row[filenamefield];
|
var file_id = row[fileidfield];
|
if(file_id) {
|
var fileid = file_id;
|
let fileName = clone(file_name);
|
let index1 = fileName.lastIndexOf(".");
|
let index2 = fileName.length;
|
let suffix = fileName.substring(index1, index2).toLowerCase(); //后缀名
|
if (suffix == ".png" || suffix == ".jpg" || suffix == ".pdf") {
|
var row = {
|
fileid: fileid,
|
filename: fileName,
|
dataname: dataname
|
}
|
|
var config = {
|
totab: false,
|
width: "1000px",
|
height: 800,
|
icon: "icon-product",
|
text: "附件预览",
|
id: "pdf_" + fileid,
|
url: "module/tool/page/popup_file_pdf.html",
|
data: row,
|
delta: {},
|
callback: function(obj, callback) {
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
this.doPopupByPublic(config);
|
}
|
else {//只可下载,不可预览
|
// handleDownloadUrl(fileid,false);
|
handleDownload(fileid, dataname);
|
}
|
}
|
},
|
|
onPopupByUploadFile(row, filenamefield, fileidfield, dataname) {
|
var me = this;
|
if (row.state_code != 'Open') {
|
Root.message({
|
type: 'warning',
|
message: '仅生效数据可以进行协议回挂'
|
});
|
return;
|
}
|
var txt_ = "";
|
var isexists = false;
|
if (filenamefield == "comeback_attachment_name") { // 协议回挂
|
txt_ = "重新进行协议回挂将替换原回挂协议";
|
if (row.comeback_attachment_id) {
|
isexists = true;
|
}
|
}
|
else if (filenamefield == "contract_attachment_name") { // 协议原件
|
txt_ = "重新上传协议原件将替换原协议原件";
|
if (row.contract_attachment_id) {
|
isexists = true;
|
}
|
}
|
|
|
if (isexists) {
|
Root.confirm(txt_, '上传提示', {
|
confirmButtonText: '确定',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
me.doPopupByUploadFile(row, filenamefield, fileidfield, dataname);
|
}).catch(() => {
|
Root.message({
|
type: 'info',
|
message: '已取消上传'
|
});
|
});
|
} else {
|
me.doPopupByUploadFile(row, filenamefield, fileidfield, dataname);
|
}
|
},
|
|
doPopupByUploadFile(row, filenamefield, fileidfield, dataname) {
|
var me = this;
|
var analysistype_ = "";
|
var delta_ = {filetypelist: []}//[".png", ".jpg", ".pdf"]
|
var config = {
|
totab: false,
|
width: "500px",
|
icon: "icon-product",
|
text: "附件上传",
|
id: "popupByUploadFile",
|
url: "module/tool/page/popup_uploadFile.html",
|
data: {
|
dataName: dataname,
|
fileidfieldName: fileidfield,
|
id: row.id,
|
fileNamefieldName: filenamefield
|
},
|
delta: delta_,
|
callback: function(fileobj, callback) {
|
me.$message({
|
showClose: true,
|
message: '上传成功!',
|
type: 'success'
|
});
|
row[filenamefield] =decodeURI(fileobj.row[0].name);
|
row[fileidfield] = fileobj.row[0].id;
|
me.onQuery();
|
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
this.doPopupByPublic(config);
|
},
|
|
download() {
|
var fileid = this.selectTabObj.selectedrow.template_attachment_id;
|
handleDownload(fileid);
|
},
|
|
// 续签
|
onCopy(row) {
|
//
|
let me = this;
|
var old_row = clone(row);
|
var new_row = clone(row);
|
|
// 原协议的下一天
|
var nextDate = new Date(old_row.date_to);
|
if (old_row.suspend_date) { // 如果有终止日期
|
nextDate = new Date(old_row.suspend_date);
|
}
|
nextDate.setDate(nextDate.getDate() + 1);
|
|
new_row.id = "";
|
new_row.agreement_no = "";
|
new_row.state_code = "";
|
new_row.state_name = "";
|
|
new_row.date_from = dateFormat(nextDate, "yyyy-MM-dd");
|
new_row.date_to = "";
|
new_row.suspend_date = "";
|
|
new_row.contract_attachment_id = "";
|
new_row.contract_attachment_name = "";
|
new_row.comeback_attachment_id = "";
|
new_row.comeback_attachment_name = "";
|
new_row.logistics_code = "";
|
|
new_row.source_id = old_row.id;
|
|
Root.confirm('确定续签吗?', '续签提示', {
|
confirmButtonText: '确定',
|
cancelButtonText: '取消',
|
type: 'warning'
|
}).then(() => {
|
var me = this;
|
return
|
var config = {
|
totab: true, //true: 以Tab导航的方式打开
|
icon: "icon-product",
|
text: "协议信息",
|
id: "customer_list_agreement_edit",//totab: true时需设置,用于判断是否已打开此页面
|
url: "module/md/page/customer/page/customer_list_agreement_edit.html",
|
data: {},
|
delta: {
|
rows: rows,
|
},
|
sceneCode: "copyAdd",//"refuseedit",//"approval", //"add"//"browse",
|
callback: function(obj, callback) {
|
// me.emptyShoppingcart();
|
me.$refs[me.selectTabObj.code].emptyShoppingcart();
|
console.log(me.selectTabObj.selectedrows);
|
console.log(me.$refs);
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
}).catch(() => {
|
Root.message({
|
type: 'info',
|
message: '已取消续签'
|
});
|
});
|
},
|
// 批量续签
|
onCopyList(callback) {
|
var me = this;
|
var config = {
|
totab: false, //true: 以Tab导航的方式打开
|
width: "400px",
|
height: "400px",
|
icon: "icon-product",
|
text: "续签时间设置",
|
url: "module/tool/page/popup_renewal.html",
|
data: {},
|
delta: {},
|
sceneCode: "add", //"add"//"browse",
|
callback: function(popupobj, popupcallback) {
|
callback(popupobj.row);
|
if (popupcallback) {
|
popupcallback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
|
|
selectionChange(obj){
|
var me = this;
|
me.selectTabObj.selectedrows = obj;
|
},
|
saveShoppingcart(list) {
|
var me = this;
|
me.selectTabObj.selectedrows = list;
|
},
|
onDownload() {
|
let me = this;
|
var ioname = ""
|
var filename = '协议导出' + String(new Date().getTime());
|
var filter_ = "1 = 1";
|
filter_ = this.getFilterData(filter_);
|
if (me.selectTabObj.code == "Input") {
|
ioname = "export_agm"
|
filename = '协议申请导出' + String(new Date().getTime());
|
}
|
else if (me.selectTabObj.code == "Open") {
|
ioname = "export_agm_apply"
|
}
|
let param = {
|
sign: "agm_agreement",
|
filename: filename,
|
filter: filter_,
|
ioname:ioname,
|
orderby: "",
|
token: Root.getToken()
|
}
|
window.top.vue.textdownloadForm(param);
|
},
|
|
editLogisticsCode() {
|
var me = this;
|
var config = {
|
totab: false, //true: 以Tab导航的方式打开
|
width: "500px",
|
height: "300px",
|
icon: "icon-product",
|
text: "编辑物流单号",
|
id: "delivery_info_expresscode" + me.selectTabObj.selectedrow.id,//totab: true时需设置,用于判断是否已打开此页面
|
url: "module/md/page/customer/page/agreement-popup/delivery_info_expresscode.html",
|
data: me.selectTabObj.selectedrow,
|
delta: {},
|
sceneCode: "edit",//"refuseedit",//"approval", //"add"//"browse",
|
callback: function(obj, callback) {
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
|
openAgreement(sceneCode, obj) {
|
let me = this;
|
var row = {}
|
if (sceneCode == "edit" || sceneCode == "browse" || sceneCode == "change") {
|
row = me.selectTabObj.selectedrow;
|
if(!row){
|
Root.message({
|
type: 'warning',
|
message: '请选择一条数据'
|
});
|
return;
|
}
|
}
|
|
var config = {
|
totab: true, //true: 以Tab导航的方式打开
|
width: "1100px",
|
height: "520px",
|
icon: "icon-product",
|
text: "协议详情" + (row.customer_name ? ("-" + row.customer_name) : ""),
|
id: "customer_list_agreement_edit" + row.id + sceneCode,//totab: true时需设置,用于判断是否已打开此页面
|
url: "module/md/page/customer/page/customer_list_agreement_edit.html",
|
data: row,
|
delta: {},
|
sceneCode: sceneCode,//"refuseedit",//"approval", //"add"//"browse",
|
callback: function(obj, callback) {
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
me.doPopupByPublic(config);
|
},
|
DownloadTemplate() {
|
var pathurl = "";
|
if (this.selectTabObj.code == "Input") {
|
pathurl = "template/1.导入模板/0_协议申请导入.xlsx";
|
}
|
handleDownload(pathurl);
|
},
|
|
|
onPopupByUploadFileToDB() {
|
var me = this;
|
var delta_ = {
|
filetypelist: [],
|
isToDB: true,
|
dataname: this.selectTabObj.dataname,
|
tableFields: this.selectTabObj.tableFields,
|
otherSave: "salesBizLogic/saveDealerTargetByImport",
|
}
|
var config = {
|
totab: false,
|
width: "500px",
|
icon: "icon-product",
|
text: "数据文件上传",
|
id: "popup_uploadFileToDB",
|
url: "module/tool/page/popup_uploadFileToDB.html",
|
data: {
|
uploadType: "dealertarget",
|
tempTable: "temp_target_dealer",
|
operate_type: "dealertarget",
|
userid: me.userid,
|
ioname:"",
|
// position_id: me.position_id,
|
},
|
delta: delta_,
|
callback: function(obj, callback) {
|
me.$message({
|
showClose: true,
|
message: '上传成功!',
|
type: 'success'
|
});
|
me.onQuery();
|
if (callback) {
|
callback();
|
}
|
}
|
};
|
this.doPopupByPublic(config);
|
},
|
|
}
|
});
|
};
|
|
loadJsCss(function () {
|
initVue();
|
});
|
</script>
|
<style>
|
/* 在vue.js中 v-cloak 这个指令是防止页面加载时出现 vuejs 的变量名而设计的 */
|
[v-cloak] {
|
display: none !important;
|
}
|
.el-tabs__nav-scroll {
|
overflow: hidden;
|
position: relative;
|
padding-left: 20px;
|
}
|
</style>
|
|
</head>
|
|
<body style="margin: 0px;">
|
<div v-cloak id="vbody">
|
<div id="page_root">
|
<div class="topbar">
|
<span :class="page_title == 'right' ? 'h_page_title_right' : 'h_page_title_left'"><span class="h_page_title_txt">{{title}}</span></span>
|
|
<div :class="page_title == 'right' ? 'h_page_button_left' : 'h_page_button_right'">
|
<!-- <el-button v-show="cbuttons_r.logisticsCode && (selectTabObj.code == 'Open' || selectTabObj.code == 'All')" type="primary" @click="editLogisticsCode" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id && selectTabObj.selectedrow.state_code == 'Open') || (selectedrows.length > 0)">编辑物流单号</el-button> -->
|
|
<!-- <el-button-group v-show= "selectTabObj.code == 'Input'" style="margin-left: 3px;">
|
<el-button v-show="cbuttons_r.Add" @click="addData" :icon="buttonsconfig.add.icon">{{buttonsconfig.add.name}}</el-button>
|
<el-button v-show="cbuttons_r.Edit" @click="onEditData" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id)" :icon="buttonsconfig.edit.icon">{{buttonsconfig.edit.name}}</el-button>
|
<el-button type="danger" @click="onDelData" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id)" :icon="buttonsconfig.delete.icon">{{buttonsconfig.delete.name}}</el-button>
|
</el-button-group> -->
|
|
<!-- <el-button-group v-show= "selectTabObj.code == 'Open'" style="margin-left: 3px;">
|
<el-button v-show="cbuttons_r.PDFFile" @click="showFileImgByFileId(selectTabObj.selectedrow, 'template_attachment_name', 'template_attachment_id')" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id && selectTabObj.selectedrow.template_attachment_id) || (selectedrows.length > 0)">协议打印</el-button>
|
<el-button v-show="cbuttons_r.uploadFilePDF" @click="onPopupByUploadFile(selectTabObj.selectedrow, 'contract_attachment_name', 'contract_attachment_id', dataname)" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id) || (selectedrows.length > 0)">协议回挂</el-button>
|
<el-button v-show="cbuttons_r.repeal" type="danger" @click="cancelConfirm" :disabled="!(selectTabObj.selectedrow && selectTabObj.selectedrow.id) || (selectedrows.length > 0)">作 废</el-button>
|
<el-button v-show="cbuttons_r.agmCopy" @click="onCopy" :disabled="!(selectedrows.length > 0)">协议续签</el-button>
|
</el-button-group> -->
|
|
<!-- <el-button-group v-show= "selectTabObj.code == 'Overdue'" style="margin-left: 3px;">
|
<el-button v-show="cbuttons_r.Renew" @click="onCopy" :disabled="!(selectedrows.length > 0)">协议续签</el-button>
|
</el-button-group> -->
|
<el-button-group style="margin-left: 3px;">
|
<el-button v-show="cbuttons_r.downloadTemplate && selectTabObj.code == 'Input'" @click="DownloadTemplate">模板下载</el-button>
|
<el-button v-show="cbuttons_r.import && selectTabObj.code == 'Input'" @click="onPopupByUploadFileToDB":icon="buttonsconfig.import.icon">{{buttonsconfig.import.name}}</el-button>
|
<el-button v-show="cbuttons_r.export && (selectTabObj.code == 'Input' || selectTabObj.code == 'Open')" type="primary" @click="onDownload" :icon="buttonsconfig.export.icon">{{buttonsconfig.export.name}}</el-button>
|
</el-button-group>
|
</div>
|
</div>
|
<div>
|
<el-tabs v-model="activeTabName" @tab-click="handleClick">
|
<el-tab-pane v-for="(tab, k) in tabs" :label="tab.name" :name="tab.code" :key="k"></el-tab-pane>
|
</el-tabs>
|
</div>
|
|
<!-- <div class="topbar-line">
|
<div class="query-icon">
|
<i class="iconfont icon-query"></i>
|
</div>
|
<div class="query-bar">
|
<h-form-filter v-if="selectTabObj.filterFields" ref="form1"
|
:form-attr="filterAttr"
|
:table-fields="selectTabObj.filterFields"
|
:form-data="selectTabObj.filterObj"
|
:table-field-click="selectTabObj.filterfieldClick"
|
|
v-on:on-query="onQuery"
|
v-on:on-init-query="onInitFilter"
|
v-on:on-edit-query="onEditFilter"
|
>
|
</h-form-filter>
|
</div>
|
</div> -->
|
|
<div class="h_dialog__body">
|
<h-table
|
v-if="isRefresh && selectTabObj.tableFields && selectTabObj.tableFields.length"
|
:ref="selectTabObj.code"
|
:table-fields="selectTabObj.tableFields"
|
:table-data="selectTabObj.tableData"
|
:is-edit-table-data="selectTabObj.isEditTableData"
|
:pagesize="selectTabObj.pagesize"
|
:pagenum="selectTabObj.pagenum"
|
:total="selectTabObj.total"
|
:table-height="selectTabObj.tableHeight"
|
:table-field-click="selectTabObj.tablefieldClick"
|
:is-show-index="false"
|
:is-highlight-row="true"
|
:tableloading="tableloading"
|
:table-buttons-click="selectTabObj.tablebuttonClick"
|
:filtersobj="selectTabObj.filterObj"
|
|
v-on:get-data="getData"
|
v-on:edit-data="editData"
|
v-on:del-data="delData"
|
v-on:row-click="rowClick"
|
|
:select-table-data="selectTabObj.selectedrows"
|
:is-selection="(selectTabObj.code == 'Open' || selectTabObj.code == 'Close')"
|
:isshow-shoppingcart="(selectTabObj.code == 'Open' || selectTabObj.code == 'Close')"
|
v-on:selection-change="selectionChange"
|
v-on:save-shoppingcart="saveShoppingcart"
|
|
>
|
</h-table>
|
</div>
|
</div>
|
</div>
|
|
<div id="page_loading" style="position: absolute; top:0px; width: 100vw; height: 50vh;">
|
<div class="spinner">
|
<div class="cube1"></div>
|
<div class="cube2"></div>
|
</div>
|
</div>
|
|
</body>
|
</html>
|