Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
W
WebPublic
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
前端开发小组
WebPublic
Commits
79cb4c87
提交
79cb4c87
authored
5月 09, 2020
作者:
徐立
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of
http://scjoyedu.eicp.net:9121/front-team/webPublic
上级
d4de44e2
735df459
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
15 个修改的文件
包含
500 行增加
和
305 行删除
+500
-305
index.js
FormInsertDiy/Export/index.js
+5
-2
ImportUtil.js
FormInsertDiy/ImportUtil/ImportUtil.js
+0
-0
ImportUtil.less
FormInsertDiy/ImportUtil/ImportUtil.less
+207
-178
ExportAndDetail.js
FormInsertDiy/List/ExportAndDetail.js
+5
-1
ExportAndImportAndDetail.js
FormInsertDiy/List/ExportAndImportAndDetail.js
+23
-0
index.js
FormInsertDiy/List/index.js
+69
-61
index.js
FormInsertDiy/config/index.js
+4
-3
Services.js
Services.js
+21
-21
index.jsx
one_stop_public/Table/index.jsx
+2
-0
isNewMobileTable.jsx
one_stop_public/Table/isNewMobileTable.jsx
+6
-1
isNewWebTable.jsx
one_stop_public/Table/isNewWebTable.jsx
+2
-0
TreeList.js
one_stop_public/libs/formList/TreeList.js
+64
-12
index.js
one_stop_public/libs/formList/index.js
+63
-11
index.jsx
one_stop_public/tableCompon/index.jsx
+3
-3
myutils.js
one_stop_public/utils/myutils.js
+26
-12
没有找到文件。
FormInsertDiy/Export/index.js
浏览文件 @
79cb4c87
...
...
@@ -7,6 +7,7 @@ import { getToken } from '@/utils/authority';
import
config
from
'@/config/config'
;
import
QueryItem
from
'./QueryItem'
;
import
OrderItem
from
'./OrderItem'
;
import
ButtonDiy
from
'@/baseComponent/ButtonDiy'
;
import
FormdataWrapper
from
'@/utils/object-to-formdata-custom'
;
...
...
@@ -359,8 +360,10 @@ export default class Index extends React.Component {
}
=
this
.
state
;
return
(
<
span
>
<
Button
shape
=
'round'
onClick
=
{
this
.
open
}
>
自定义导出
<
/Button
>
<
div
id
=
'downloadDiv'
style
=
{{
display
:
'none'
}}
><
/div
>
<
ButtonDiy
handleClick
=
{
this
.
open
}
name
=
{
'自定义导出'
}
/
>
<
div
id
=
'downloadDiv'
style
=
{{
display
:
'none'
}}
>
<
/div
>
<
Modal
width
=
{
670
}
maskClosable
=
{
false
}
...
...
FormInsertDiy/ImportUtil/ImportUtil.js
浏览文件 @
79cb4c87
差异被折叠。
点击展开。
FormInsertDiy/ImportUtil/ImportUtil.less
浏览文件 @
79cb4c87
//.nomal{
// background: #fff;
// padding: 10px;
//}
//.title{
// display: flex;
// margin-bottom: 20px;
//}
//.info{
// text-align: center;
// font-weight: bold;
// font-size: 18px;
//}
//.detail{
// text-align: center;
// margin:30px auto;
//}
//.detail img{
// margin: auto 10px;
//}
//.button{
// display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
// display: -moz-box; /* 老版本语法: Firefox (buggy) */
// display: -ms-flexbox; /* 混合版本语法: IE 10 */
// display: -webkit-flex; /* 新版本语法: Chrome 21+ */
// display: -moz-flex;
// display: flex;
// -moz-box-pack: center; /*Firefox*/
// -webkit-box-pack: center; /*Safari,Opera,Chrome*/
// box-pack: center;
// -moz-justify-content: center;
// -webkit-justify-content: center;
// justify-content: center;
//}
//.operation{
// display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
// display: -moz-box; /* 老版本语法: Firefox (buggy) */
// display: -ms-flexbox; /* 混合版本语法: IE 10 */
// display: -webkit-flex; /* 新版本语法: Chrome 21+ */
// display: -moz-flex;
// display: flex;
// -moz-box-pack: center; /*Firefox*/
// -webkit-box-pack: center; /*Safari,Opera,Chrome*/
// box-pack: center;
// -moz-justify-content: center;
// -webkit-justify-content: center;
// justify-content: center;
//}
//.button Button{
// margin: auto 10px;
//
//}
//.titleInfo p span{
// font-weight: bold;
//}
//.import{
// color: #6ca3c9;
// font-size: 16px;
//}
//.button{
// // background: #eff3f8;
// text-align: center;
// padding:20px;
// margin-top: 20px;
//}
//.tip{
// margin:20px auto;
// padding:10px;
// border-top: 1px solid #ccc;
//}
//.tip span{
// display: block;
// margin:10px;
// font-size: 16px;
//}
//.tip::after{
// content: '';
// position: absolute;
// width: 5px;
// height: 57px;
// background: #e5eaf1;
// margin-top: -141px;
// margin-left: -13px;
//}
//.select button{
// color: #fff;
// padding:10px;
// background: #abbac3;
// border: none;
// margin: 10px;
//}
//.attentionItem{
// background: #f4f5f4;
// padding: 10px;
// box-shadow: 1px 1px 1px #ccc;
//}
//.attentionItem p:nth-child(1){
// font-size: 16px;
// margin-left: 0;
//}
//.attentionItem p{
// font-size: 14px;
// margin-left: 45px;
//}
//.submitButtons{
// margin-left: 34px;
//}
//.contentTable{
// display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
// display: -moz-box; /* 老版本语法: Firefox (buggy) */
// display: -ms-flexbox; /* 混合版本语法: IE 10 */
// display: -webkit-flex; /* 新版本语法: Chrome 21+ */
// display: -moz-flex;
// display: flex;
// -moz-box-pack: justify; /*Firefox*/
// -webkit-box-pack:justify; /*Safari,Opera,Chrome*/
// box-pack: justify;
// -moz-justify-content: space-between;
// -webkit-justify-content: space-between;
// justify-content: space-between;
// margin-top: 20px;
//}
//.left{
// width: 50%;
//}
//.right{
// width: 50%;
// border-left: 1px solid #317ecc;
//}
//.error p{
// color: #fff;
// background: #317ecc;
// // margin: 10px auto;
// text-align: left;
// font-size: 18px;
//}
//.download{
// background: #f5f5f5;
// padding: 5px;
// margin-top: -16px;
//}
//.download img{
// margin-top: -2px;
// margin-right: 5px;
//}
//.download button{
// border: none;
// background: #f5f5f5
//}
//.download button:nth-child(1){
// border-right: 1px solid #ccc;
//}
//.download button:nth-child(2){
// border-right: 1px solid #ccc;
//}
//.buttonDown{
// display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
// display: -moz-box; /* 老版本语法: Firefox (buggy) */
// display: -ms-flexbox; /* 混合版本语法: IE 10 */
// display: -webkit-flex; /* 新版本语法: Chrome 21+ */
// display: -moz-flex;
// display: flex;
// -moz-box-pack: start; /*Firefox*/
// -webkit-box-pack: start; /*Safari,Opera,Chrome*/
// box-pack: start;
// -moz-justify-content: flex-start;
// -webkit-justify-content: flex-start;
// justify-content: flex-start;
// margin-bottom: 20px;
//}
//.buttonDown>button{
// margin-left: 10px;
// background: #abbac3;
// border: none;
// color: #fff;
// padding: 5px 12px;
// border-radius: 5px;
//}
.nomal {
background: #fff;
padding: 10px;
}
.title {
display: flex;
margin-bottom: 20px;
}
.info {
text-align: center;
font-weight: bold;
font-size: 18px;
}
.detail {
text-align: center;
margin: 30px auto;
}
.detail img {
margin: auto 10px;
}
.button {
display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
display: -moz-box; /* 老版本语法: Firefox (buggy) */
display: -ms-flexbox; /* 混合版本语法: IE 10 */
display: -webkit-flex; /* 新版本语法: Chrome 21+ */
display: -moz-flex;
display: flex;
-moz-box-pack: center; /*Firefox*/
-webkit-box-pack: center; /*Safari,Opera,Chrome*/
box-pack: center;
-moz-justify-content: center;
-webkit-justify-content: center;
justify-content: center;
}
.operation {
display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
display: -moz-box; /* 老版本语法: Firefox (buggy) */
display: -ms-flexbox; /* 混合版本语法: IE 10 */
display: -webkit-flex; /* 新版本语法: Chrome 21+ */
display: -moz-flex;
display: flex;
-moz-box-pack: center; /*Firefox*/
-webkit-box-pack: center; /*Safari,Opera,Chrome*/
box-pack: center;
-moz-justify-content: center;
-webkit-justify-content: center;
justify-content: center;
}
.button Button {
margin: auto 10px;
}
.titleInfo p span {
font-weight: bold;
}
.import {
color: #6ca3c9;
font-size: 16px;
}
.button {
// background: #eff3f8;
text-align: center;
padding: 20px;
margin-top: 20px;
}
.tip {
margin: 20px auto;
padding: 10px;
border-top: 1px solid #ccc;
}
.tip span {
display: block;
margin: 10px;
font-size: 16px;
}
.tip::after {
content: '';
position: absolute;
width: 5px;
height: 57px;
background: #e5eaf1;
margin-top: -141px;
margin-left: -13px;
}
.select button {
color: #fff;
padding: 10px;
background: #abbac3;
border: none;
margin: 10px;
}
.attentionItem {
background: #f4f5f4;
padding: 10px;
box-shadow: 1px 1px 1px #ccc;
}
.attentionItem p:nth-child(1) {
font-size: 16px;
margin-left: 0;
}
.attentionItem p {
font-size: 14px;
margin-left: 45px;
}
.submitButtons {
margin-left: 34px;
}
.contentTable {
display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
display: -moz-box; /* 老版本语法: Firefox (buggy) */
display: -ms-flexbox; /* 混合版本语法: IE 10 */
display: -webkit-flex; /* 新版本语法: Chrome 21+ */
display: -moz-flex;
display: flex;
-moz-box-pack: justify; /*Firefox*/
-webkit-box-pack: justify; /*Safari,Opera,Chrome*/
box-pack: justify;
-moz-justify-content: space-between;
-webkit-justify-content: space-between;
justify-content: space-between;
margin-top: 20px;
}
.left {
width: 50%;
}
.right {
width: 50%;
border-left: 1px solid #317ecc;
}
.error p {
color: #fff;
background: #317ecc;
// margin: 10px auto;
text-align: left;
font-size: 18px;
}
.download {
background: #f5f5f5;
padding: 5px;
margin-top: -16px;
}
.download img {
margin-top: -2px;
margin-right: 5px;
}
.download button {
border: none;
background: #f5f5f5
}
.download button:nth-child(1) {
border-right: 1px solid #ccc;
}
.download button:nth-child(2) {
border-right: 1px solid #ccc;
}
.buttonDown {
display: -webkit-box; /* 老版本语法: Safari, iOS, Android browser, older WebKit browsers. */
display: -moz-box; /* 老版本语法: Firefox (buggy) */
display: -ms-flexbox; /* 混合版本语法: IE 10 */
display: -webkit-flex; /* 新版本语法: Chrome 21+ */
display: -moz-flex;
display: flex;
-moz-box-pack: start; /*Firefox*/
-webkit-box-pack: start; /*Safari,Opera,Chrome*/
box-pack: start;
-moz-justify-content: flex-start;
-webkit-justify-content: flex-start;
justify-content: flex-start;
margin-bottom: 20px;
}
.buttonDown > button {
margin-left: 10px;
background: #abbac3;
border: none;
color: #fff;
padding: 5px 12px;
border-radius: 5px;
}
FormInsertDiy/List/ExportAndDetail.js
浏览文件 @
79cb4c87
/***
* 钟是志 权限配置
* 2020年5月8日 16:57:11
* 这个只需要 详情 和 导出 和 流程审核详情
* */
import
React
from
'react'
;
import
List
from
'./index'
;
import
GetIdByPath
from
'./GetIdByPath'
;
const
ExportAndDetail
=
(
props
)
=>
{
...
...
FormInsertDiy/List/ExportAndImportAndDetail.js
0 → 100644
浏览文件 @
79cb4c87
/***
* 钟是志 权限配置
* 2020年5月8日 16:57:11
* 这个只需要 新增 删除 详情 导入 导出 编辑
* */
import
React
from
'react'
;
import
GetIdByPath
from
'./GetIdByPath'
;
const
ExportAndImportAndDetail
=
(
props
)
=>
{
const
Authority
=
{
add
:
true
,
// 新增
delete
:
true
,
// 删除
edit
:
true
,
// 编辑
auditDetail
:
false
,
// 审核详情
exportUtil
:
true
,
// 导出
importUtil
:
true
,
// 导入
};
return
<
GetIdByPath
{...
props
}
Authority
=
{
Authority
}
/>
;
};
export
default
ExportAndImportAndDetail
;
FormInsertDiy/List/index.js
浏览文件 @
79cb4c87
...
...
@@ -8,7 +8,7 @@ import ButtonDiy from '@/baseComponent/ButtonDiy';
import
Shell
from
'../Shell'
;
import
FormArray
from
'../AffairPage/component/FormArray'
;
import
Edit
from
'../Edit/index'
;
//
import ImportUtil from '../ImportUtil/ImportUtil';
import
ImportUtil
from
'../ImportUtil/ImportUtil'
;
import
SearchDom
from
'@/highOrderComponent/SearchDom'
;
import
StandardTable
from
'@/components/StandardTable'
;
import
{
getHead
,
fetchData
,
deleteItem
,
add
,
getDetailId
}
from
'./services'
;
...
...
@@ -80,18 +80,25 @@ class FormList extends React.Component {
}
// 渲染值
componentDidMount
()
{
this
.
getTableHead
();
this
.
getTableHead
();
}
getTableHead
=
()
=>
{
const
{
objId
,
Authority
}
=
this
.
props
;
getHead
({
dataObjId
:
objId
},
datas
=>
{
if
(
!
datas
)
return
;
let
findPrimaryKey
=
datas
.
find
((
x
)
=>
{
return
x
.
isPrimaryKey
===
true
;
});
if
(
findPrimaryKey
)
{
this
.
setState
({
primaryKey
:
findPrimaryKey
.
name
,
});
}
else
{
console
.
error
(
'没有数据主键,无法执行删除操作'
);
}
datas
=
datas
.
filter
((
x
)
=>
{
return
x
.
isHidden
!==
true
;
});
...
...
@@ -99,23 +106,20 @@ class FormList extends React.Component {
item
.
extendType
=
item
.
extendTypeId
;
item
.
dataIndex
=
item
.
name
;
item
.
dataType
=
item
.
type
;
if
(
item
.
isPrimaryKey
)
{
this
.
setState
({
primaryKey
:
item
.
name
,
});
}
}
datas
=
handleColumns
(
datas
);
if
(
Authority
&&
Authority
.
auditDetail
)
{
if
(
Authority
&&
Authority
.
auditDetail
)
{
//流程审核详情 和 编辑,查看 不能 同时存在.
datas
.
push
(
{
dataIndex
:
'
operation
'
,
title
:
'
操作
'
,
dataIndex
:
'
auditProcessDetail
'
,
title
:
'
审核详情
'
,
fixed
:
datas
.
length
>
12
?
'right'
:
false
,
render
:
(
text
,
record
)
=>
{
return
(
<
a
onClick
=
{()
=>
{
this
.
getIdByCode
(
record
.
process_biz_key
)}}
>
return
(
<
a
onClick
=
{()
=>
{
this
.
getIdByCode
(
record
.
process_biz_key
);
}}
>
流程审核详情
<
/a>
)
;
<
/a>
)
;
/*return (<Link to={
{
pathname: './Detail',
...
...
@@ -131,24 +135,9 @@ class FormList extends React.Component {
},
);
}
this
.
columns
=
datas
;
this
.
setState
({
formItem
:
datas
});
/* let i = 0;
for (let t in datas) {
/!* if (i < 10) {
let column = {};
column.title = datas[t].title;
column.dataIndex = datas[t].name;
if (date.includes(datas[t].type)) {
column.render = val => val && moment(val).format('YYYY-MM-DD HH:mm:ss');
}
this.columns.push(column);
i++;
}*!/
if (datas[t].isPrimaryKey) {
}
}*/
let
searchConfig
=
[];
for
(
let
item
of
datas
)
{
if
(
item
.
isShowQuery
)
{
...
...
@@ -164,37 +153,40 @@ class FormList extends React.Component {
this
.
setState
({
searchConfig
,
});
/*let opt = {
title: '操作',
render: (text, record) => (
<Fragment>
<div>
<a onClick={this.modify.bind(this, record)}>
编辑
</a>
</div>
</Fragment>
),
};
this.columns.push(opt);*/
if
(
Authority
&&
Authority
.
edit
)
{
//编辑功能
datas
.
push
(
{
dataIndex
:
'operationEdit'
,
title
:
'编辑'
,
fixed
:
'right'
,
width
:
60
,
render
:
(
text
,
record
)
=>
{
return
(
<
a
onClick
=
{
this
.
modify
.
bind
(
this
,
record
)}
>
编辑
<
/a>
)
;
},
},
);
}
this
.
getPage
();
});
};
getIdByCode
=
(
code
)
=>
{
getDetailId
({
code
},
res
=>
{
getDetailId
({
code
},
res
=>
{
router
.
push
({
pathname
:
'./Detail'
,
state
:
{
record
:
{
id
:
res
.
id
},
}
record
:
{
id
:
res
.
id
},
}
,
});
})
})
;
};
modify
=
record
=>
{
const
{
formItem
}
=
this
.
state
;
if
(
formItem
.
length
<
10
)
{
if
(
formItem
.
length
<
10
||
true
)
{
this
.
setState
({
formData
:
{
...
record
},
modalVisible
:
true
,
...
...
@@ -239,7 +231,7 @@ class FormList extends React.Component {
};
fetchData
({
...
params
,
dataObjId
:
objId
},
res
=>
{
if
(
!
res
.
rows
)
{
console
.
log
(
'分页接口rows返回null报错'
);
console
.
error
(
'分页接口rows返回null报错'
);
}
this
.
setState
({
pageData
:
{
...
...
@@ -293,7 +285,7 @@ class FormList extends React.Component {
add
=
()
=>
{
const
{
formItem
}
=
this
.
state
;
if
(
formItem
.
length
<
10
)
{
if
(
formItem
.
length
<
10
||
true
)
{
this
.
setState
({
modalVisible
:
true
,
formData
:
{},
...
...
@@ -314,14 +306,23 @@ class FormList extends React.Component {
});
};
batchDelete
=
e
=>
{
batchDelete
=
(
e
)
=>
{
const
{
objId
}
=
this
.
props
;
const
{
selectedRows
,
formItem
}
=
this
.
state
;
if
(
!
selectedRows
)
return
;
const
Keys
=
formItem
.
filter
(
i
=>
i
.
isPrimaryKey
).
reduce
((
acc
,
i
)
=>
{
return
{
...
acc
,
[
i
.
name
]:
selectedRows
.
map
(
row
=>
row
[
i
.
name
]).
join
(
','
)
};
if
(
!
selectedRows
||
selectedRows
.
length
<
1
)
{
message
.
warning
(
'请选择您要删除的数据'
);
return
false
;
}
// 找出主键
const
{
primaryKey
}
=
this
.
state
;
let
Keys
=
selectedRows
.
map
((
x
)
=>
{
return
x
[
primaryKey
];
});
deleteItem
({
keys
:
JSON
.
stringify
(
Keys
),
objId
},
()
=>
{
deleteItem
({
keys
:
JSON
.
stringify
({
[
primaryKey
]:
Keys
.
join
(
','
)
}),
objId
,
// isSelf: true,
},
()
=>
{
this
.
setState
({
selectedRows
:
[],
});
...
...
@@ -383,8 +384,11 @@ class FormList extends React.Component {
config
=
{{
condition
:
searchConfig
,
fromTab
:
true
}}
/
>
)
:
null
}
<
Shell
>
<
div
style
=
{{
paddingLeft
:
'10px'
,
marginTop
:
'20px'
}}
<
Shell
styleShell
=
{
searchConfig
.
length
>
0
?
{}
:
{
marginTop
:
0
}}
>
<
div
style
=
{{
paddingLeft
:
'10px'
,
paddingTop
:
'10px'
,
}}
>
{
Authority
&&
Authority
.
add
===
false
?
null
:
...
...
@@ -402,12 +406,16 @@ class FormList extends React.Component {
Authority
&&
Authority
.
exportUtil
===
false
?
null
:
<
ExportInfo
objId
=
{
objId
}
/
>
}
{
/* <ImportUtil objId={objId} />*/
}
{
Authority
&&
Authority
.
importUtil
===
false
?
null
:
<
ImportUtil
objId
=
{
objId
}
callback
=
{
this
.
getPage
}
/
>
}
<
/div
>
<
StandardTable
rowKey
=
"row_id"
rowKey
=
{
primaryKey
}
data
=
{
pageData
}
columns
=
{
this
.
columns
}
selectedRows
=
{
selectedRows
}
...
...
FormInsertDiy/config/index.js
浏览文件 @
79cb4c87
...
...
@@ -37,15 +37,16 @@ const text = [
const
number
=
[
'BIGINT'
,
'DOUBLE'
,
'FLOAT'
,
'INT'
,
'INTEGER'
,
'NUMERIC'
,
'SMALLINT'
,
'TINYINT'
];
const
date
=
[
'DATE'
,
'DATETIME'
,
'TIME'
,
'TIMESTAMP'
,
'YEAR'
];
const
taskNode
=
[
'TASKNODE'
];
const
format
=
{
//欢哥那边定义好的 时间格式类型
//
欢哥那边定义好的 时间格式类型
DATE
:
'YYYY-MM-DD HH:mm'
,
DATETIME
:
'YYYY-MM-DD HH:mm:ss'
,
TIME
:
'HH:mm:ss'
,
TIMESTAMP
:
'HH:mm:ss'
,
YEAR
:
'YYYY'
,
};
const
taskNode
=
[
'TASKNODE'
];
/**
* 将时间格式转化为unix时间戳
...
...
@@ -61,7 +62,7 @@ const transLateTimeTOUnix = (value, dataType) => {
const
getFormArrayConfig
=
header
=>
{
let
config
=
[];
for
(
let
item
of
header
)
{
if
(
item
.
isPrimaryKey
||
item
.
isHidden
)
{
if
(
item
.
isPrimaryKey
||
item
.
isHidden
||
item
.
dataIndex
===
'operationEdit'
)
{
// 主键
continue
;
/* config.push(
...
...
Services.js
浏览文件 @
79cb4c87
...
...
@@ -88,29 +88,29 @@ export const addOrEditTableItem = ({ objId, data, isAdd, isBase = true }) => {
* @param {String} id 申报数据的id
* @param {String} code 申报数据的code
*/
export
const
getHistoryFormDetail
=
({
id
,
code
})
=>
{
return
uaaRequest
(
'/UnifiedAppFormApi/getFormDetail'
,
{
id
,
code
,
});
export
const
getHistoryFormDetail
=
({
id
,
code
})
=>
{
return
uaaRequest
(
'/UnifiedAppFormApi/getFormDetail'
,
{
id
,
code
});
};
export
function
getOnestopKey
(
key
=
''
,
formKey
=
'key_list'
,
formValue
=
'value_list'
){
return
fetchTableData
({
dataObjId
:
config
.
onestopConfigDataObjId
||
'1248169933162938368'
,
pageNo
:
1
,
pageSize
:
5000
,
}).
then
((
x
)
=>
{
if
(
x
&&
x
.
rows
&&
x
.
rows
.
length
){
let
onestopConfigList
=
{};
for
(
let
item
of
x
.
rows
){
onestopConfigList
[
item
[
formKey
]]
=
item
[
formValue
];
}
setOneStopConfig
(
onestopConfigList
);
if
(
key
){
return
onestopConfigList
[
key
];
}
}
else
{
message
.
warning
(
'没有配置服务,无法使用此功能'
);
return
false
;
export
function
getOnestopKey
(
key
=
''
,
formKey
=
'key_list'
,
formValue
=
'value_list'
)
{
return
fetchTableData
({
dataObjId
:
config
.
onestopConfigDataObjId
||
'1248169933162938368'
,
pageNo
:
1
,
pageSize
:
5000
,
}).
then
((
x
)
=>
{
if
(
x
&&
x
.
rows
&&
x
.
rows
.
length
)
{
const
onestopConfigList
=
{};
for
(
const
item
of
x
.
rows
)
{
onestopConfigList
[
item
[
formKey
]]
=
item
[
formValue
];
}
})
setOneStopConfig
(
onestopConfigList
);
if
(
key
)
{
return
onestopConfigList
[
key
];
}
}
else
{
console
.
error
(
'没有配置一站式相关服务,无法使用部分功能'
);
return
false
;
}
});
}
one_stop_public/Table/index.jsx
浏览文件 @
79cb4c87
...
...
@@ -571,6 +571,7 @@ export default class ZdyTable extends Component {
<
TableCom
formCode=
{
formCode
}
// 当前表单code
modalInit=
{
modalInit
}
formId=
{
formId
}
// 当前表单Id
i=
{
i
}
// 当前组件下标
j=
{
j
}
// 当前行数下班
...
...
@@ -657,6 +658,7 @@ export default class ZdyTable extends Component {
})
:
""
}
<
IsNewTable
modalInit=
{
modalInit
}
items=
{
items
}
checkAllHidden=
{
this
.
checkAllHidden
}
isBorder=
{
isBorder
}
...
...
one_stop_public/Table/isNewMobileTable.jsx
浏览文件 @
79cb4c87
...
...
@@ -8,6 +8,7 @@ import { Row, Col } from 'antd';
export
default
class
isNewTable
extends
Component
{
render
()
{
const
{
items
,
checkAllHidden
,
isBorder
,
...
...
@@ -30,7 +31,8 @@ export default class isNewTable extends Component {
formCode
,
formId
,
fatherObj
,
style
style
,
modalInit
}
=
this
.
props
if
(
!
isEdit
){
// 展示栏 暂不做处理
return
<>
...
...
@@ -51,6 +53,7 @@ export default class isNewTable extends Component {
item
.
map
((
ary
,
j
)
=>
{
return
!
allhidden
&&
ary
.
hidden
?
""
:
<><
TableCom
modalInit=
{
modalInit
}
formCode=
{
formCode
}
formId=
{
formId
}
i=
{
i
}
...
...
@@ -176,6 +179,7 @@ export default class isNewTable extends Component {
title=
{
!
allhidden
&&
ary
.
hidden
?
""
:<><
TableCom
modalInit=
{
modalInit
}
formCode=
{
formCode
}
formId=
{
formId
}
i=
{
i
}
...
...
@@ -208,6 +212,7 @@ export default class isNewTable extends Component {
// textAlign:ary.content&&ary.content.comName === 'Table'?"left":'right'
}
}
>
<><
TableCom
modalInit=
{
modalInit
}
formCode=
{
formCode
}
formId=
{
formId
}
i=
{
i
}
...
...
one_stop_public/Table/isNewWebTable.jsx
浏览文件 @
79cb4c87
...
...
@@ -33,6 +33,7 @@ export default class isNewWebTable extends Component {
fatherObj
,
style
,
max
,
modalInit
}
=
this
.
props
return
(
<
div
...
...
@@ -89,6 +90,7 @@ export default class isNewWebTable extends Component {
isEdit=
{
isEdit
}
formKey=
{
currentFormKey
}
init=
{
init
}
modalInit=
{
modalInit
}
get=
{
get
}
// 区分移动端或wen端
json=
{
cell
.
content
}
obj=
{
obj
||
{}
}
// 是否存在默认值
...
...
one_stop_public/libs/formList/TreeList.js
浏览文件 @
79cb4c87
...
...
@@ -32,11 +32,15 @@ import SearchInfo from '../../App/SearchInfo';
import
{
Base16Encode
}
from
"../../Base16/index"
;
import
baseX
from
'base-x'
import
{
isEmpty
}
from
'lodash'
import
FilePreview
from
"@/webPublic/one_stop_public/filePreview"
;
import
{
queryApiActionPath
}
from
"@/webPublic/one_stop_public/utils/queryConfig"
;
import
UploadCom
from
"@/webPublic/one_stop_public/libs/UploadCom"
;
const
BASE16
=
'0123456789abcdef'
const
bs16
=
baseX
(
BASE16
)
const
FormItem
=
Form
.
Item
;
let
AllWidth
=
0
;
// 表格总长度
const
{
RangePicker
}
=
DatePicker
;
const
text
=
[
'BINARY'
,
'BIT'
,
...
...
@@ -104,7 +108,7 @@ const CreateForm = Form.create()(props => {
handleAdd
(
params
,
isAdd
);
});
};
console
.
log
(
"isView"
,
isView
)
//需要获取动态表单
return
(
<
Modal
...
...
@@ -232,6 +236,24 @@ class TreeList extends React.Component {
// }
};
isJSON
=
(
str
)
=>
{
if
(
typeof
str
==
'string'
)
{
try
{
var
obj
=
JSON
.
parse
(
str
);
if
(
typeof
obj
==
'object'
&&
obj
)
{
return
true
;
}
else
{
return
false
;
}
}
catch
(
e
)
{
console
.
log
(
'error:'
+
str
+
'!!!'
+
e
);
return
false
;
}
}
console
.
log
(
'这不是个字符串'
)
}
delete
=
record
=>
{
//找出主键
let
Keys
=
{};
...
...
@@ -361,7 +383,7 @@ class TreeList extends React.Component {
const
b
=
nextProps
.
value
||
{}
const
a
=
this
.
props
.
value
||
{}
if
(
JSON
.
stringify
(
a
)
!=
JSON
.
stringify
(
b
)){
const
params
=
{
...
...
@@ -369,18 +391,17 @@ class TreeList extends React.Component {
pageSize
:
this
.
props
.
pageSize
||
10
,
query
:
JSON
.
stringify
(
this
.
state
.
formValues
),
};
this
.
columns
=
nextProps
.
value
.
columns
if
(
nextProps
.
value
.
columns
!=
null
&&
nextProps
.
value
.
columns
.
length
>
0
){
this
.
columns
=
nextProps
.
value
.
columns
}
this
.
custom
=
Base16Encode
(
JSON
.
stringify
(
b
))
if
(
nextProps
.
value
.
getPage
){
this
.
getPage
(
params
,
null
,
nextProps
.
value
.
getPage
);
}
else
{
if
(
this
.
state
.
objId
)
this
.
getPage
(
params
)
}
}
}
const
x
=
nextProps
.
selects
const
y
=
this
.
props
.
selects
if
(
JSON
.
stringify
(
x
)
!=
JSON
.
stringify
(
y
)){
...
...
@@ -441,7 +462,27 @@ class TreeList extends React.Component {
}
}
else
if
(
datas
[
t
].
name
.
indexOf
(
"process_status"
)
>-
1
){
column
.
render
=
(
val
)
=>
val
?(
val
===
"0"
?
"审核通过"
:
"审核未通过"
):
null
}
else
{
}
else
if
(
datas
[
t
].
extendTypeId
&&
datas
[
t
].
extendTypeId
.
indexOf
(
"file"
)
>-
1
){
//特殊处理附件
column
.
render
=
(
val
)
=>
{
if
(
this
.
isJSON
(
val
)){
val
=
JSON
.
parse
(
val
);
let
files
=
val
.
files
;
let
xx
=
(
<
ul
>
{
files
.
map
((
f
,
index2
)
=>
{
return
<
li
key
=
{
index2
}
><
FilePreview
path
=
{
queryApiActionPath
()
+
f
.
path
}
pathName
=
{
f
.
name
}
/></
li
>
}
)}
<
/ul
>
)
return
xx
;
}
else
{
return
val
;
}
}
}
else
{
column
.
render
=
(
val
)
=>
val
&&
val
.
length
>
100
?
<
Tooltip
title
=
{
val
}
overlayStyle
=
{{
width
:
1000
}}
>
<
span
style
=
{{
width
:
column
.
width
||
200
,
display
:
"block"
,
wordBreak
:
"keep-all"
,
whiteSpace
:
"nowrap"
,
overflow
:
"hidden"
,
textOverflow
:
"ellipsis"
}}
>
{
val
}
<
/span
>
<
/Tooltip>:va
l
...
...
@@ -767,7 +808,18 @@ class TreeList extends React.Component {
<
/FormItem
>
);
}
else
if
(
isQuery
&&
item
.
isGroupQuery
!=
null
&&
item
.
isGroupQuery
){
//如果是查询 并且是组合查询
}
else
if
(
item
.
extendTypeId
&&
item
.
extendTypeId
.
indexOf
(
"file"
)
>-
1
){
//特殊处理附件 如果是查询就 跳过
if
(
isQuery
)
return
;
return
(
<
FormItem
labelCol
=
{
labelCol
}
wrapperCol
=
{
wrapperCol
}
label
=
{
item
.
title
}
key
=
{
item
.
id
}
>
{
form
.
getFieldDecorator
(
item
.
name
,
{
initialValue
:
formData
==
null
?
''
:
(
formData
[
item
.
name
]
&&
this
.
isJSON
(
formData
[
item
.
name
])?
JSON
.
parse
(
formData
[
item
.
name
]):
null
),
rules
:
[{
required
:
!
item
.
isNull
}],
})(
<
UploadCom
/>
)}
<
/FormItem
>
);
}
else
if
(
isQuery
&&
item
.
isGroupQuery
!=
null
&&
item
.
isGroupQuery
){
//如果是查询 并且是组合查询
const
ops
=
groups
[
item
.
id
+
''
]
||
[]
return
(
...
...
@@ -845,7 +897,7 @@ class TreeList extends React.Component {
form
,
get
,
}
=
this
.
props
;
console
.
log
(
get
)
const
{
querys
}
=
this
.
state
if
(
querys
.
length
==
0
)
{
return
''
;
...
...
@@ -962,7 +1014,7 @@ class TreeList extends React.Component {
onClick
=
{
this
.
view
.
bind
(
this
,
record
)}
>
查看详情
<
/a><Divider type="vertical"/
><
/>
}
{
rights
&&
!
rights
.
includes
(
'edit'
)
?
''
:
<><
a
onClick
=
{
this
.
modify
.
bind
(
this
,
record
)}
>
编辑
<
/a><Divider type="vertical"/
><
/>
}
{
rights
&&
rights
.
includes
(
"viewProcess"
)
&&
record
.
process_biz_key
?
<><
a
onClick
=
{
this
.
viewProcess
.
bind
(
this
,
record
)}
>
查看流程详情
<
/a><Divider type="vertical"/
><
/>:''
}
{
rights
&&
rights
.
includes
(
"viewProcess"
)
&&
record
.
process_biz_key
?
<><
a
onClick
=
{
this
.
viewProcess
.
bind
(
this
,
record
)}
>
查看流程详情
<
/a><Divider type="vertical"/
><
/>:''
}
{
rights
&&
!
rights
.
includes
(
'delete'
)
?
''
:
<>
<
Popconfirm
title
=
"确定删除该数据?"
onConfirm
=
{
this
.
delete
.
bind
(
this
,
record
)}
...
...
one_stop_public/libs/formList/index.js
浏览文件 @
79cb4c87
...
...
@@ -32,11 +32,15 @@ import SearchInfo from '../../App/SearchInfo';
import
{
Base16Encode
}
from
"../../Base16/index"
;
import
baseX
from
'base-x'
import
{
isEmpty
}
from
'lodash'
import
FilePreview
from
"@/webPublic/one_stop_public/filePreview"
;
import
{
queryApiActionPath
}
from
"@/webPublic/one_stop_public/utils/queryConfig"
;
import
UploadCom
from
"@/webPublic/one_stop_public/libs/UploadCom"
;
const
BASE16
=
'0123456789abcdef'
const
bs16
=
baseX
(
BASE16
)
const
FormItem
=
Form
.
Item
;
let
AllWidth
=
0
;
// 表格总长度
const
{
RangePicker
}
=
DatePicker
;
const
text
=
[
'BINARY'
,
'BIT'
,
...
...
@@ -104,7 +108,7 @@ const CreateForm = Form.create()(props => {
handleAdd
(
params
,
isAdd
);
});
};
console
.
log
(
"isView"
,
isView
)
//需要获取动态表单
return
(
<
Modal
...
...
@@ -232,6 +236,24 @@ class FormList extends React.Component {
// }
};
isJSON
=
(
str
)
=>
{
if
(
typeof
str
==
'string'
)
{
try
{
var
obj
=
JSON
.
parse
(
str
);
if
(
typeof
obj
==
'object'
&&
obj
)
{
return
true
;
}
else
{
return
false
;
}
}
catch
(
e
)
{
console
.
log
(
'error:'
+
str
+
'!!!'
+
e
);
return
false
;
}
}
console
.
log
(
'这不是个字符串'
)
}
delete
=
record
=>
{
//找出主键
let
Keys
=
{};
...
...
@@ -361,7 +383,7 @@ class FormList extends React.Component {
const
b
=
nextProps
.
value
||
{}
const
a
=
this
.
props
.
value
||
{}
if
(
JSON
.
stringify
(
a
)
!=
JSON
.
stringify
(
b
)){
const
params
=
{
...
...
@@ -369,18 +391,17 @@ class FormList extends React.Component {
pageSize
:
this
.
props
.
pageSize
||
10
,
query
:
JSON
.
stringify
(
this
.
state
.
formValues
),
};
this
.
columns
=
nextProps
.
value
.
columns
if
(
nextProps
.
value
.
columns
!=
null
&&
nextProps
.
value
.
columns
.
length
>
0
){
this
.
columns
=
nextProps
.
value
.
columns
}
this
.
custom
=
Base16Encode
(
JSON
.
stringify
(
b
))
if
(
nextProps
.
value
.
getPage
){
this
.
getPage
(
params
,
null
,
nextProps
.
value
.
getPage
);
}
else
{
if
(
this
.
state
.
objId
)
this
.
getPage
(
params
)
}
}
}
const
x
=
nextProps
.
selects
const
y
=
this
.
props
.
selects
if
(
JSON
.
stringify
(
x
)
!=
JSON
.
stringify
(
y
)){
...
...
@@ -441,7 +462,27 @@ class FormList extends React.Component {
}
}
else
if
(
datas
[
t
].
name
.
indexOf
(
"process_status"
)
>-
1
){
column
.
render
=
(
val
)
=>
val
?(
val
===
"0"
?
"审核通过"
:
"审核未通过"
):
null
}
else
{
}
else
if
(
datas
[
t
].
extendTypeId
&&
datas
[
t
].
extendTypeId
.
indexOf
(
"file"
)
>-
1
){
//特殊处理附件
column
.
render
=
(
val
)
=>
{
if
(
this
.
isJSON
(
val
)){
val
=
JSON
.
parse
(
val
);
let
files
=
val
.
files
;
let
xx
=
(
<
ul
>
{
files
.
map
((
f
,
index2
)
=>
{
return
<
li
key
=
{
index2
}
><
FilePreview
path
=
{
queryApiActionPath
()
+
f
.
path
}
pathName
=
{
f
.
name
}
/></
li
>
}
)}
<
/ul
>
)
return
xx
;
}
else
{
return
val
;
}
}
}
else
{
column
.
render
=
(
val
)
=>
val
&&
val
.
length
>
100
?
<
Tooltip
title
=
{
val
}
overlayStyle
=
{{
width
:
1000
}}
>
<
span
style
=
{{
width
:
column
.
width
||
200
,
display
:
"block"
,
wordBreak
:
"keep-all"
,
whiteSpace
:
"nowrap"
,
overflow
:
"hidden"
,
textOverflow
:
"ellipsis"
}}
>
{
val
}
<
/span
>
<
/Tooltip>:va
l
...
...
@@ -767,7 +808,18 @@ class FormList extends React.Component {
<
/FormItem
>
);
}
else
if
(
isQuery
&&
item
.
isGroupQuery
!=
null
&&
item
.
isGroupQuery
){
//如果是查询 并且是组合查询
}
else
if
(
item
.
extendTypeId
&&
item
.
extendTypeId
.
indexOf
(
"file"
)
>-
1
){
//特殊处理附件 如果是查询就 跳过
if
(
isQuery
)
return
;
return
(
<
FormItem
labelCol
=
{
labelCol
}
wrapperCol
=
{
wrapperCol
}
label
=
{
item
.
title
}
key
=
{
item
.
id
}
>
{
form
.
getFieldDecorator
(
item
.
name
,
{
initialValue
:
formData
==
null
?
''
:
(
formData
[
item
.
name
]
&&
this
.
isJSON
(
formData
[
item
.
name
])?
JSON
.
parse
(
formData
[
item
.
name
]):
null
),
rules
:
[{
required
:
!
item
.
isNull
}],
})(
<
UploadCom
/>
)}
<
/FormItem
>
);
}
else
if
(
isQuery
&&
item
.
isGroupQuery
!=
null
&&
item
.
isGroupQuery
){
//如果是查询 并且是组合查询
const
ops
=
groups
[
item
.
id
+
''
]
||
[]
return
(
...
...
@@ -845,7 +897,7 @@ class FormList extends React.Component {
form
,
get
,
}
=
this
.
props
;
console
.
log
(
get
)
const
{
querys
}
=
this
.
state
if
(
querys
.
length
==
0
)
{
return
''
;
...
...
one_stop_public/tableCompon/index.jsx
浏览文件 @
79cb4c87
...
...
@@ -425,7 +425,7 @@ export default class tableCom extends Component {
componentWillReceiveProps
(
props
)
{
const
{
json
,
mapData
,
obj
}
=
props
;
if
(
json
==
null
)
{
if
(
json
==
null
||
this
.
props
.
safe
)
{
return
;
}
if
(
!
(
this
.
dataFilter
.
includes
(
json
.
comName
)
||
json
.
comName
==
"TableSelect"
)
&&
json
.
isFormulaOnce
)
{
...
...
@@ -1282,9 +1282,9 @@ export default class tableCom extends Component {
}
}
this
.
getData
(
json
,
dataColumn
,
obj
)
if
(
json
.
formula
!=
null
&&
json
.
formula
!=
""
)
{
if
(
json
.
formula
!=
null
&&
json
.
formula
!=
""
&&!
this
.
props
.
safe
)
{
this
.
getFunctionValue
(
json
.
formula
,
dataColumn
,
json
)
}
...
...
one_stop_public/utils/myutils.js
浏览文件 @
79cb4c87
...
...
@@ -59,9 +59,9 @@ export function changeToDraftState(blocks) {
}
if
(
!
x
.
blocks
){
return
EditorState
.
createEmpty
(
decorator
)
}
const
b
=
convertFromRaw
(
x
);
return
EditorState
.
createWithContent
(
b
,
decorator
)
...
...
@@ -90,15 +90,7 @@ export function preHandle(values) {
for
(
var
key
in
values
)
{
if
(
!
values
[
key
])
continue
;
if
(
key
.
indexOf
(
"img"
)
>
-
1
)
{
var
xx
=
key
.
split
(
"$"
)
values
[
xx
[
1
]]
=
values
[
key
].
response
delete
values
[
key
]
}
else
if
(
key
.
indexOf
(
"$"
)
>
-
1
)
{
if
(
key
.
indexOf
(
"$"
)
>
-
1
)
{
var
xx
=
key
.
split
(
"$"
)
for
(
var
i
=
0
;
i
<
xx
.
length
;
i
++
)
{
...
...
@@ -109,7 +101,7 @@ export function preHandle(values) {
}
}
delete
values
[
key
]
}
else
{
}
else
{
if
(
values
[
key
]
!=
null
)
{
if
(
values
[
key
]
instanceof
moment
)
{
...
...
@@ -118,6 +110,28 @@ export function preHandle(values) {
values
[
key
]
=
values
[
key
].
valueOf
()
}
else
if
(
values
[
key
]
instanceof
Boolean
)
{
values
[
key
]
=
values
[
key
]
?
0
:
1
}
else
if
(
values
[
key
]
instanceof
Object
&&
key
!=
'defaultValues'
){
//处理子表单中的日期值
let
objValues
=
values
[
key
];
for
(
let
k
in
objValues
){
if
(
k
!=
''
&&
objValues
[
k
]
instanceof
Object
){
let
childObj
=
objValues
[
k
];
for
(
let
j
in
childObj
){
if
(
childObj
[
j
]
!=
null
){
if
(
childObj
[
j
]
instanceof
moment
)
{
values
[
key
][
k
][
j
]
=
values
[
key
][
k
][
j
].
valueOf
()
}
else
if
(
childObj
[
j
]
instanceof
Date
)
{
values
[
key
][
k
][
j
]
=
values
[
key
][
k
][
j
].
valueOf
()
}
else
if
(
childObj
[
j
]
instanceof
Boolean
)
{
values
[
key
][
k
][
j
]
=
values
[
key
][
k
][
j
]
?
0
:
1
}
}
}
}
}
}
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论