|
@@ -5,6 +5,7 @@ import styles from '../style/GoodsList.less';
|
5
|
5
|
import moment from 'moment';
|
6
|
6
|
import router from 'umi/router';
|
7
|
7
|
import BuildSelect from '../../components/SelectButton/BuildSelect'
|
|
8
|
+import CitySelect from '../../components/SelectButton/CitySelect'
|
8
|
9
|
import { FieldTypes, createForm } from '../../components/XForm';
|
9
|
10
|
import Wangedit from '../../components/Wangedit/Wangedit';
|
10
|
11
|
import SelectActivity from './SelectActivity';
|
|
@@ -13,7 +14,7 @@ import apis from '../../services/apis';
|
13
|
14
|
import request from '../../utils/request'
|
14
|
15
|
import SelectHelp from './SelectHelp';
|
15
|
16
|
import SelectGroup from './SelectGroup';
|
16
|
|
-
|
|
17
|
+import SelectH5 from './SelectH5';
|
17
|
18
|
/**
|
18
|
19
|
*
|
19
|
20
|
*
|
|
@@ -27,8 +28,13 @@ import SelectGroup from './SelectGroup';
|
27
|
28
|
let helpVisible = false
|
28
|
29
|
let groupVisible = false
|
29
|
30
|
let buildingId = ''
|
|
31
|
+ let isHaveActive=true
|
30
|
32
|
|
31
|
33
|
const setExtraData = (data) => {
|
|
34
|
+ isHaveActive=data.isHaveActive
|
|
35
|
+ if(!isHaveActive) {
|
|
36
|
+ data.contentType=null
|
|
37
|
+ }
|
32
|
38
|
contentVisible = data.contentType === 'other';
|
33
|
39
|
activityVisible = data.contentType === 'activity';
|
34
|
40
|
newsVisible = data.contentType === 'news';
|
|
@@ -37,7 +43,7 @@ import SelectGroup from './SelectGroup';
|
37
|
43
|
|
38
|
44
|
buildingId = data.buildingId
|
39
|
45
|
}
|
40
|
|
-
|
|
46
|
+
|
41
|
47
|
const handleFormValueChange = (props, changedValues, allValues) => {
|
42
|
48
|
setExtraData(allValues)
|
43
|
49
|
}
|
|
@@ -48,12 +54,12 @@ import SelectGroup from './SelectGroup';
|
48
|
54
|
const [ tab, changeTab ] = useState('basic')
|
49
|
55
|
const contentId = props.location.query.contentId
|
50
|
56
|
const [ data, setData ] = useState({})
|
51
|
|
-
|
|
57
|
+
|
52
|
58
|
if(contentId){
|
53
|
59
|
useEffect(() => {
|
54
|
60
|
getDetail(contentId);
|
55
|
61
|
},[])
|
56
|
|
-
|
|
62
|
+
|
57
|
63
|
// 查询列表
|
58
|
64
|
const getDetail = (contentId) => {
|
59
|
65
|
request({ ...apis.carsuseFigure.getExtendContent,urlData:{id: contentId}}).then((data) => {
|
|
@@ -62,23 +68,43 @@ import SelectGroup from './SelectGroup';
|
62
|
68
|
})
|
63
|
69
|
}
|
64
|
70
|
}
|
65
|
|
-
|
|
71
|
+
|
66
|
72
|
const cancelPage = () =>{
|
67
|
73
|
router.push({
|
68
|
74
|
pathname: '/carouselFigure/advertisingList',
|
69
|
75
|
});
|
70
|
76
|
}
|
71
|
|
-
|
|
77
|
+
|
72
|
78
|
const fields = [
|
|
79
|
+ {
|
|
80
|
+ label: '项目活动',
|
|
81
|
+ name: 'isHaveActive',
|
|
82
|
+ type: FieldTypes.Switch,
|
|
83
|
+ value:isHaveActive,
|
|
84
|
+ rules: [
|
|
85
|
+ { required: true,message: '是否城市活动' },
|
|
86
|
+ ],
|
|
87
|
+ },
|
73
|
88
|
{
|
74
|
89
|
label: '所属项目',
|
75
|
90
|
name: 'buildingId',
|
76
|
91
|
render: <BuildSelect />,
|
77
|
92
|
value: data.buildingId,
|
|
93
|
+ hidden: () => !isHaveActive,
|
78
|
94
|
rules: [
|
79
|
95
|
{ required: true, message: '请选择所属项目' },
|
80
|
96
|
],
|
81
|
97
|
},
|
|
98
|
+ {
|
|
99
|
+ label: '展示城市',
|
|
100
|
+ name: 'cityId',
|
|
101
|
+ render: <CitySelect />,
|
|
102
|
+ hidden: () => isHaveActive,
|
|
103
|
+ value: data.cityId,
|
|
104
|
+ rules: [
|
|
105
|
+ { required: true, message: '请选择展示城市' },
|
|
106
|
+ ],
|
|
107
|
+ },
|
82
|
108
|
{
|
83
|
109
|
label: '开屏广告',
|
84
|
110
|
name: 'image',
|
|
@@ -89,10 +115,21 @@ import SelectGroup from './SelectGroup';
|
89
|
115
|
{ required: true, message: '请上传图片' },
|
90
|
116
|
],
|
91
|
117
|
},
|
|
118
|
+ {
|
|
119
|
+ label: '是否发布H5',
|
|
120
|
+ name: 'targetId',
|
|
121
|
+ render: <SelectH5/>,
|
|
122
|
+ hidden: () => isHaveActive,
|
|
123
|
+ value: data.targetId,
|
|
124
|
+ rules: [
|
|
125
|
+ { required: false, message: '请选择发布H5' },
|
|
126
|
+ ],
|
|
127
|
+ },
|
92
|
128
|
{
|
93
|
129
|
label: '标题',
|
94
|
130
|
name: 'title',
|
95
|
131
|
type: FieldTypes.Text,
|
|
132
|
+ hidden: () => !isHaveActive,
|
96
|
133
|
value: data.title,
|
97
|
134
|
rules: [
|
98
|
135
|
{ required: true, message: '请输入标题' },
|
|
@@ -101,6 +138,7 @@ import SelectGroup from './SelectGroup';
|
101
|
138
|
{
|
102
|
139
|
label: '类型',
|
103
|
140
|
name: 'contentType',
|
|
141
|
+ hidden: () => !isHaveActive,
|
104
|
142
|
type: FieldTypes.Select,
|
105
|
143
|
dict: [{
|
106
|
144
|
label: '常规活动',
|
|
@@ -185,6 +223,7 @@ import SelectGroup from './SelectGroup';
|
185
|
223
|
label: '状态',
|
186
|
224
|
name: 'status',
|
187
|
225
|
type: FieldTypes.Select,
|
|
226
|
+ hidden: () => !isHaveActive,
|
188
|
227
|
dict: [{
|
189
|
228
|
label: "启用",
|
190
|
229
|
value: 1
|
|
@@ -196,9 +235,12 @@ import SelectGroup from './SelectGroup';
|
196
|
235
|
value: data.status != null ? data.status : 1,
|
197
|
236
|
},
|
198
|
237
|
]
|
199
|
|
-
|
200
|
|
- const handleSubmit = val => {
|
|
238
|
+
|
|
239
|
+ const handleSubmit = val => {
|
201
|
240
|
val.showType = 'screen'
|
|
241
|
+ if(!val.isHaveActive&&val.targetId) {
|
|
242
|
+ val.contentType='h5'
|
|
243
|
+ }
|
202
|
244
|
if(contentId){
|
203
|
245
|
request({ ...apis.carsuseFigure.updataExtendContent,urlData:{id: contentId}, data: val,}).then((data) => {
|
204
|
246
|
cancelPage()
|
|
@@ -213,12 +255,12 @@ import SelectGroup from './SelectGroup';
|
213
|
255
|
})
|
214
|
256
|
}
|
215
|
257
|
}
|
216
|
|
-
|
217
|
|
-
|
|
258
|
+
|
|
259
|
+
|
218
|
260
|
return (
|
219
|
261
|
<XForm onSubmit={handleSubmit} onCancel={cancelPage} onValuesChange={handleFormValueChange} fields={fields}></XForm>
|
220
|
262
|
);
|
221
|
263
|
}
|
222
|
264
|
}
|
223
|
|
-
|
|
265
|
+
|
224
|
266
|
export default createEditor()
|