educode_sales 0.9.66 → 0.9.67
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/controllers/educode_sales/activities_controller.rb +72 -4
- data/app/controllers/educode_sales/businesses_controller.rb +82 -1
- data/app/models/educode_sales/activity.rb +17 -4
- data/app/models/educode_sales/activity_follow_up.rb +13 -0
- data/app/models/educode_sales/activity_staff.rb +1 -1
- data/app/models/educode_sales/business.rb +3 -0
- data/app/models/educode_sales/business_level.rb +11 -0
- data/app/models/educode_sales/business_watch.rb +6 -0
- data/app/views/educode_sales/activities/_follows.html.erb +208 -0
- data/app/views/educode_sales/activities/_index.html.erb +418 -0
- data/app/views/educode_sales/activities/edit.html.erb +99 -0
- data/app/views/educode_sales/activities/follow_ups.json.jbuilder +19 -0
- data/app/views/educode_sales/activities/index.html.erb +13 -349
- data/app/views/educode_sales/activities/index.json.jbuilder +9 -1
- data/app/views/educode_sales/activities/new.html.erb +80 -0
- data/app/views/educode_sales/activities/new_follow_up.html.erb +56 -0
- data/app/views/educode_sales/businesses/edit.html.erb +48 -6
- data/app/views/educode_sales/businesses/index.html.erb +10 -0
- data/app/views/educode_sales/businesses/no_permission.html.erb +2 -0
- data/config/routes.rb +3 -0
- data/db/migrate/20230329135141_create_educode_sales_business_watches.rb +17 -0
- data/db/migrate/20230330141213_create_educode_sales_activity_follow_ups.rb +25 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +15 -6
- data/app/assets/images/educode_sales/indexlogo.png +0 -0
@@ -1,350 +1,14 @@
|
|
1
|
-
<
|
2
|
-
<
|
3
|
-
<
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
</
|
10
|
-
<div
|
11
|
-
|
12
|
-
<div class="layui-form-item">
|
13
|
-
<div class="layui-inline ">
|
14
|
-
<label class="layui-form-label">活动名称</label>
|
15
|
-
<div class="layui-input-inline">
|
16
|
-
<input type="text" class="layui-input" name="name" autocomplete="off">
|
17
|
-
</div>
|
18
|
-
</div>
|
19
|
-
<div class="layui-inline">
|
20
|
-
<label class="layui-form-label">会议类型</label>
|
21
|
-
<div class="layui-input-inline">
|
22
|
-
<%= select_tag "clazz_id", options_for_select(['全国会议', '区域会议', '单校会议', '国赛', '省赛', '夏令营'], ""), { include_blank: true } %>
|
23
|
-
</div>
|
24
|
-
</div>
|
25
|
-
<div class="layui-inline">
|
26
|
-
<label class="layui-form-label">销售经理</label>
|
27
|
-
<div class="layui-input-inline">
|
28
|
-
<%= select_tag "staff_id", options_for_select(@staffs, ""), { include_blank: true } %>
|
29
|
-
</div>
|
30
|
-
</div>
|
31
|
-
<div class="layui-inline">
|
32
|
-
<label class="layui-form-label">生态经理</label>
|
33
|
-
<div class="layui-input-inline">
|
34
|
-
<%= select_tag "manage", options_for_select(@staffs, ""), { include_blank: true } %>
|
35
|
-
</div>
|
36
|
-
</div>
|
37
|
-
<div class="layui-inline">
|
38
|
-
<label class="layui-form-label">协助人员</label>
|
39
|
-
<div class="layui-input-inline">
|
40
|
-
<%= select_tag "assists", options_for_select(@staffs, ""), { include_blank: true } %>
|
41
|
-
</div>
|
42
|
-
</div>
|
43
|
-
<div class="layui-inline">
|
44
|
-
<label class="layui-form-label">报告专家</label>
|
45
|
-
<div class="layui-input-inline">
|
46
|
-
<input type="text" class="layui-input" name="expert" autocomplete="off">
|
47
|
-
</div>
|
48
|
-
</div>
|
49
|
-
<div class="layui-inline">
|
50
|
-
<button type="reset" class="layui-btn layui-btn-primary" lay-submit lay-filter="reset_activity_search">重置
|
51
|
-
</button>
|
52
|
-
<button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="search_activity">搜 索
|
53
|
-
</button>
|
54
|
-
</div>
|
1
|
+
<div class="layui-tab" lay-filter="operation_tab">
|
2
|
+
<ul class="layui-tab-title">
|
3
|
+
<li class="layui-this follows_li">跟进动态</li>
|
4
|
+
<li class="businesses_list_li" >活动列表</li>
|
5
|
+
</ul>
|
6
|
+
<div class="layui-tab-content">
|
7
|
+
<div class="layui-tab-item layui-show">
|
8
|
+
<%= render 'follows' %>
|
9
|
+
</div>
|
10
|
+
<div class="layui-tab-item follows_div">
|
11
|
+
<%= render 'index' %>
|
55
12
|
</div>
|
56
|
-
</
|
57
|
-
</div>
|
58
|
-
<div class="min-height-table">
|
59
|
-
<table class="layui-hide" id="activities_table" lay-filter="activities_table"></table>
|
60
|
-
</div>
|
61
|
-
|
62
|
-
<script type="text/html" id="currentTableBar">
|
63
|
-
<% if can? :update, EducodeSales::Activity %>
|
64
|
-
<a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">编辑</a>
|
65
|
-
<% end %>
|
66
|
-
<% if can? :destroy, EducodeSales::Activity %>
|
67
|
-
<a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
|
68
|
-
<% end %>
|
69
|
-
</script>
|
70
|
-
|
71
|
-
<script type="text/html" id="teachers">
|
72
|
-
<a href="javascript:void(0);" lay-event="teachers" class="layui-table-link">{{ d.name}}</a>
|
73
|
-
</script>
|
74
|
-
<script type="text/html" id="teachers_count">
|
75
|
-
<a href="javascript:void(0);" lay-event="teachers_count" class="layui-table-link">{{ d.teachers_count}}</a>
|
76
|
-
</script>
|
77
|
-
<script type="text/html" id="schools_count">
|
78
|
-
<a href="javascript:void(0);" lay-event="schools_count" class="layui-table-link">{{ d.schools_count}}</a>
|
79
|
-
</script>
|
80
|
-
<script>
|
81
|
-
layui.use(['form', 'table', 'miniPage', 'element', 'request'], function () {
|
82
|
-
var $ = layui.jquery,
|
83
|
-
form = layui.form,
|
84
|
-
table = layui.table,
|
85
|
-
request = layui.request,
|
86
|
-
miniPage = layui.miniPage;
|
87
|
-
|
88
|
-
table.render({
|
89
|
-
elem: '#activities_table',
|
90
|
-
url: '/missions/activities',
|
91
|
-
toolbar: '#activity_toolbar',
|
92
|
-
totalRow:true,
|
93
|
-
defaultToolbar: [],
|
94
|
-
cols: [
|
95
|
-
[
|
96
|
-
{
|
97
|
-
field: 'id',
|
98
|
-
title:'序号',type: 'numbers',
|
99
|
-
totalRowText:'合计',
|
100
|
-
width: 60
|
101
|
-
},
|
102
|
-
{
|
103
|
-
field: 'name',
|
104
|
-
title: '活动名称',
|
105
|
-
width: 180,
|
106
|
-
templet: '#teachers'
|
107
|
-
},
|
108
|
-
{
|
109
|
-
field: 'clazz_id',
|
110
|
-
width: 120,
|
111
|
-
title: '会议类型'
|
112
|
-
},
|
113
|
-
{
|
114
|
-
field: 'staff',
|
115
|
-
width: 120,
|
116
|
-
title: '销售经理'
|
117
|
-
},
|
118
|
-
{
|
119
|
-
field: 'staff_manage',
|
120
|
-
width: 180,
|
121
|
-
title: '生态经理'
|
122
|
-
},
|
123
|
-
{
|
124
|
-
field: 'staff_assist',
|
125
|
-
width: 180,
|
126
|
-
title: '协助人员'
|
127
|
-
},
|
128
|
-
{
|
129
|
-
field: 'expert',
|
130
|
-
width: 180,
|
131
|
-
title: '报告专家'
|
132
|
-
},
|
133
|
-
{
|
134
|
-
field: 'start_at',
|
135
|
-
width: 200,
|
136
|
-
title: '时间',
|
137
|
-
sort: true,
|
138
|
-
},
|
139
|
-
{
|
140
|
-
field: 'days',
|
141
|
-
title: '天数',
|
142
|
-
width: 200
|
143
|
-
},
|
144
|
-
{
|
145
|
-
field: 'schools_count',
|
146
|
-
title: '学校数',
|
147
|
-
width: 200,
|
148
|
-
totalRow: true,
|
149
|
-
templet: '#schools_count'
|
150
|
-
},
|
151
|
-
{
|
152
|
-
field: 'teachers_count',
|
153
|
-
title: '教师数',
|
154
|
-
width: 200,
|
155
|
-
totalRow:true,
|
156
|
-
templet: '#teachers_count'
|
157
|
-
},
|
158
|
-
{
|
159
|
-
field: 'students_count',
|
160
|
-
title: '学生数',
|
161
|
-
totalRow:'{{ parseInt(d.TOTAL_NUMS) }}',
|
162
|
-
width: 200
|
163
|
-
},
|
164
|
-
{
|
165
|
-
title: '操作',
|
166
|
-
width: 120,
|
167
|
-
fixed: 'right',
|
168
|
-
toolbar: '#currentTableBar',
|
169
|
-
align: "center"
|
170
|
-
}
|
171
|
-
]
|
172
|
-
],
|
173
|
-
limit: 20,
|
174
|
-
limits: [10,15,20,30,40,50,60,70,80,90],
|
175
|
-
page: true
|
176
|
-
});
|
177
|
-
|
178
|
-
var sort = {};
|
179
|
-
table.on('sort(activities_table)', function (obj) {
|
180
|
-
sort.field = obj.field;
|
181
|
-
sort.order = obj.type;
|
182
|
-
table.reload('activities_table', {
|
183
|
-
initSort: obj,
|
184
|
-
where: {
|
185
|
-
sort: sort
|
186
|
-
}
|
187
|
-
});
|
188
|
-
})
|
189
|
-
// 监听搜索操作
|
190
|
-
form.on('submit(search_activity)', function (data) {
|
191
|
-
search = data.field
|
192
|
-
table.reload('activities_table', {
|
193
|
-
page: {
|
194
|
-
curr: 1
|
195
|
-
},
|
196
|
-
where: {q: search, sort: sort}
|
197
|
-
}, 'data');
|
198
|
-
return false;
|
199
|
-
});
|
200
|
-
table.on('toolbar(activities_table)', function (obj) {
|
201
|
-
if (obj.event === 'add') { // 监听添加操作
|
202
|
-
var content = miniPage.getHrefContent('/missions/activities/new');
|
203
|
-
var openWH = miniPage.getOpenWidthHeight();
|
204
|
-
index = layer.open({
|
205
|
-
title: '添加活动',
|
206
|
-
type: 1,
|
207
|
-
shade: 0.2,
|
208
|
-
maxmin: true,
|
209
|
-
shadeClose: true,
|
210
|
-
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
211
|
-
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
212
|
-
content: content,
|
213
|
-
success: function (layero, index) {
|
214
|
-
form.render('select');
|
215
|
-
}
|
216
|
-
});
|
217
|
-
$(window).on("resize", function () {
|
218
|
-
layer.full(index);
|
219
|
-
});
|
220
|
-
}
|
221
|
-
else if (obj.event === 'import') { //
|
222
|
-
var content = miniPage.getHrefContent('/missions/teachers/import');
|
223
|
-
var openWH = miniPage.getOpenWidthHeight();
|
224
|
-
import_index = layer.open({
|
225
|
-
title: '导入数据',
|
226
|
-
type: 1,
|
227
|
-
shade: 0.2,
|
228
|
-
shadeClose: true,
|
229
|
-
area: ['200px', '100px'],
|
230
|
-
offset: 'auto',
|
231
|
-
closeBtn: 0,
|
232
|
-
content: content,
|
233
|
-
});
|
234
|
-
$(window).on("resize", function () {
|
235
|
-
layer.full(index);
|
236
|
-
});
|
237
|
-
}
|
238
|
-
});
|
239
|
-
|
240
|
-
table.on('tool(activities_table)', function (obj) {
|
241
|
-
var data = obj.data;
|
242
|
-
var id = data.id
|
243
|
-
if (obj.event === 'edit') {
|
244
|
-
var content = miniPage.getHrefContent('/missions/activities/' + id + '/edit');
|
245
|
-
var openWH = miniPage.getOpenWidthHeight();
|
246
|
-
var index = layer.open({
|
247
|
-
title: '编辑',
|
248
|
-
type: 1,
|
249
|
-
shade: 0.2,
|
250
|
-
maxmin: true,
|
251
|
-
shadeClose: true,
|
252
|
-
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
253
|
-
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
254
|
-
content: content,
|
255
|
-
success: function (layero, index) {
|
256
|
-
console.log(data);
|
257
|
-
// $("#name").val(data.name);
|
258
|
-
// 重新渲染弹层中的下拉选择框select
|
259
|
-
form.render('select');
|
260
|
-
},
|
261
|
-
});
|
262
|
-
$(window).on("resize", function () {
|
263
|
-
layer.full(index);
|
264
|
-
});
|
265
|
-
return false;
|
266
|
-
} else if (obj.event === 'delete') {
|
267
|
-
layer.confirm('确定删除' + data.name, function (index) {
|
268
|
-
request.delete('missions/activities/' + data.id, {}, function (res) {
|
269
|
-
layer.close(index);
|
270
|
-
table.reload("activities_table")
|
271
|
-
})
|
272
|
-
});
|
273
|
-
} else if (obj.event === 'teachers') {
|
274
|
-
activity_id = obj.data.id
|
275
|
-
var content = miniPage.getHrefContent('/missions/activities/show_teachers');
|
276
|
-
openWH = miniPage.getOpenWidthHeight();
|
277
|
-
index = layer.open({
|
278
|
-
title: '活动列表/' + data.name,
|
279
|
-
type: 1,
|
280
|
-
shade: 0.2,
|
281
|
-
maxmin: true,
|
282
|
-
shadeClose: true,
|
283
|
-
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
284
|
-
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
285
|
-
content: content,
|
286
|
-
success: function (layero, index) {
|
287
|
-
form.render('select');
|
288
|
-
},
|
289
|
-
});
|
290
|
-
$(window).on("resize", function () {
|
291
|
-
layer.full(index);
|
292
|
-
});
|
293
|
-
return false;
|
294
|
-
}
|
295
|
-
else if (obj.event === 'teachers_count') {
|
296
|
-
activity_id = obj.data.id;
|
297
|
-
school_id = '';
|
298
|
-
content = miniPage.getHrefContent('/missions/activities/show_teachers');
|
299
|
-
openWH = miniPage.getOpenWidthHeight();
|
300
|
-
index2 = layer.open({
|
301
|
-
title: '活动列表/' + data.name,
|
302
|
-
type: 1,
|
303
|
-
shade: 0.2,
|
304
|
-
maxmin: true,
|
305
|
-
shadeClose: true,
|
306
|
-
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
307
|
-
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
308
|
-
content: content,
|
309
|
-
success: function (layero, index) {
|
310
|
-
form.render('select');
|
311
|
-
},
|
312
|
-
});
|
313
|
-
$(window).on("resize", function () {
|
314
|
-
layer.full(index);
|
315
|
-
});
|
316
|
-
return false;
|
317
|
-
} else if (obj.event == 'schools_count') {
|
318
|
-
activity_id = obj.data.id;
|
319
|
-
activity_name = data.name;
|
320
|
-
school_id = '';
|
321
|
-
content = miniPage.getHrefContent('/missions/activities/' + obj.data.id +'/show_schools');
|
322
|
-
openWH = miniPage.getOpenWidthHeight();
|
323
|
-
index2 = layer.open({
|
324
|
-
title: '活动列表/' + data.name,
|
325
|
-
type: 1,
|
326
|
-
shade: 0.2,
|
327
|
-
maxmin: true,
|
328
|
-
shadeClose: true,
|
329
|
-
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
330
|
-
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
331
|
-
content: content,
|
332
|
-
success: function (layero, index) {
|
333
|
-
form.render('select');
|
334
|
-
},
|
335
|
-
});
|
336
|
-
$(window).on("resize", function () {
|
337
|
-
layer.full(index);
|
338
|
-
});
|
339
|
-
return false;
|
340
|
-
}
|
341
|
-
});
|
342
|
-
|
343
|
-
});
|
344
|
-
</script>
|
345
|
-
<style>
|
346
|
-
.layui-table-tool-temp{
|
347
|
-
padding-right: 30px; !important;
|
348
|
-
}
|
349
|
-
|
350
|
-
</style>
|
13
|
+
</div>
|
14
|
+
</div>
|
@@ -12,10 +12,18 @@ json.data do
|
|
12
12
|
json.course_rate d.course_rate
|
13
13
|
json.start_at d.start_at ? d.start_at.to_s(:date) : ''
|
14
14
|
json.clazz_id d.clazz_id
|
15
|
-
json.staff d.staff&.user&.real_name
|
15
|
+
json.staff d.sales&.user&.real_name || d.staff&.user&.real_name
|
16
16
|
json.staff_manage d.manages.map { |d| d.staff.user.real_name}.uniq.join("、")
|
17
17
|
json.staff_assist d.assists.map { |d| d.staff.user.real_name}.uniq.join("、")
|
18
18
|
json.expert d.experts.pluck(:name).join("、")
|
19
|
+
json.invitations d.invitations.pluck(:name).join("、")
|
20
|
+
json.sponsor d.sponsor
|
21
|
+
json.linkman d.linkman
|
22
|
+
json.phone d.phone
|
23
|
+
json.scale d.scale
|
24
|
+
json.address d.address
|
25
|
+
json.meeting_form d.meeting_form
|
26
|
+
json.state_id d.state_id
|
19
27
|
|
20
28
|
json.schools_count EducodeSales::ActivityTeacher.joins(teacher: :department).where(activity_id: d.id).select("distinct(school_id)").count
|
21
29
|
schools_count += EducodeSales::ActivityTeacher.joins(teacher: :department).where(activity_id: d.id).select("distinct(school_id)").count
|
@@ -14,6 +14,12 @@
|
|
14
14
|
<%= select_tag "clazz_id", options_for_select(@clazz), { 'lay-filter': 'clazz_id', class: 'required' } %>
|
15
15
|
</div>
|
16
16
|
</div>
|
17
|
+
<div class="layui-inline">
|
18
|
+
<label class="layui-form-label required">活动状态</label>
|
19
|
+
<div class="layui-input-block">
|
20
|
+
<%= select_tag "state_id", options_for_select(EducodeSales::Activity.state_ids.keys), { 'lay-filter': 'clazz_id', class: 'required' } %>
|
21
|
+
</div>
|
22
|
+
</div>
|
17
23
|
<div class="layui-inline">
|
18
24
|
<label class="layui-form-label required">活动时间</label>
|
19
25
|
<div class="layui-input-block">
|
@@ -38,6 +44,48 @@
|
|
38
44
|
<div id="staff_assist_list" style="width: 193px;"></div>
|
39
45
|
</div>
|
40
46
|
</div>
|
47
|
+
<div class="layui-inline">
|
48
|
+
<label class="layui-form-label">主办方</label>
|
49
|
+
<div class="layui-input-block">
|
50
|
+
<input type="text" name="sponsor" class="layui-input">
|
51
|
+
</div>
|
52
|
+
</div>
|
53
|
+
<div class="layui-inline">
|
54
|
+
<label class="layui-form-label">联系人</label>
|
55
|
+
<div class="layui-input-block">
|
56
|
+
<input type="text" name="linkman" class="layui-input">
|
57
|
+
</div>
|
58
|
+
</div>
|
59
|
+
<div class="layui-inline">
|
60
|
+
<label class="layui-form-label">联系电话</label>
|
61
|
+
<div class="layui-input-block">
|
62
|
+
<input type="text" name="phone" class="layui-input">
|
63
|
+
</div>
|
64
|
+
</div>
|
65
|
+
<div class="layui-inline">
|
66
|
+
<label class="layui-form-label">规模</label>
|
67
|
+
<div class="layui-input-block">
|
68
|
+
<input type="text" name="scale" class="layui-input">
|
69
|
+
</div>
|
70
|
+
</div>
|
71
|
+
<div class="layui-inline">
|
72
|
+
<label class="layui-form-label">会议地点</label>
|
73
|
+
<div class="layui-input-block">
|
74
|
+
<input type="text" name="address" class="layui-input">
|
75
|
+
</div>
|
76
|
+
</div>
|
77
|
+
<div class="layui-inline">
|
78
|
+
<label class="layui-form-label">会议形式</label>
|
79
|
+
<div class="layui-input-block">
|
80
|
+
<input type="text" name="meeting_form" class="layui-input">
|
81
|
+
</div>
|
82
|
+
</div>
|
83
|
+
<div class="layui-inline">
|
84
|
+
<label class="layui-form-label">邀请专家</label>
|
85
|
+
<div class="layui-input-block">
|
86
|
+
<div id="invitation_list" style="width: 600px;"></div>
|
87
|
+
</div>
|
88
|
+
</div>
|
41
89
|
<div class="layui-inline">
|
42
90
|
<label class="layui-form-label">报告专家</label>
|
43
91
|
<div class="layui-input-block">
|
@@ -115,6 +163,27 @@
|
|
115
163
|
data: []
|
116
164
|
})
|
117
165
|
|
166
|
+
var invitation_select = xmSelect.render({
|
167
|
+
el: '#invitation_list',
|
168
|
+
filterable: true,
|
169
|
+
name: 'invitation_list',
|
170
|
+
remoteSearch: true,
|
171
|
+
remoteMethod: function(val, cb, show){
|
172
|
+
if(!val){
|
173
|
+
return cb([]);
|
174
|
+
}
|
175
|
+
request.get('missions/search_edu_user?q=' + val, {}, function (res) {
|
176
|
+
if (res.data.length == 0) {
|
177
|
+
cb([{value: val, name: val}])
|
178
|
+
} else {
|
179
|
+
cb(res.data);
|
180
|
+
}
|
181
|
+
|
182
|
+
})
|
183
|
+
},
|
184
|
+
data: []
|
185
|
+
})
|
186
|
+
|
118
187
|
|
119
188
|
upload.render({
|
120
189
|
elem: '#upload_file',
|
@@ -163,6 +232,17 @@
|
|
163
232
|
|
164
233
|
}
|
165
234
|
})
|
235
|
+
|
236
|
+
var invitation_ids = [];
|
237
|
+
invitation_select.getValue().forEach(function(d) {
|
238
|
+
if (typeof(d.value) == 'number') {
|
239
|
+
invitation_ids.push([d.value, d.name]);
|
240
|
+
} else {
|
241
|
+
invitation_ids.push(['', d.name]);
|
242
|
+
|
243
|
+
}
|
244
|
+
})
|
245
|
+
data.field.invitation_ids = invitation_ids;
|
166
246
|
data.field.expert_ids = expertids;
|
167
247
|
request.authPost("missions/activities", data.field, function (res) {
|
168
248
|
if (res.success === false) {
|
@@ -0,0 +1,56 @@
|
|
1
|
+
<form class="layui-form " action="">
|
2
|
+
<div class="layui-form-item" style="padding: 25px">
|
3
|
+
<div class="layui-inline">
|
4
|
+
<label class="layui-form-label">信息类型</label>
|
5
|
+
<div class="layui-input-inline">
|
6
|
+
<%= select_tag "info_id",options_for_select(EducodeSales::ActivityFollowUp.info_ids.keys)%>
|
7
|
+
</div>
|
8
|
+
</div>
|
9
|
+
<br>
|
10
|
+
<div class="layui-form-item layui-form-text">
|
11
|
+
<label class="layui-form-label">最新进展</label>
|
12
|
+
<div class="layui-input-block">
|
13
|
+
<textarea name="description" placeholder="填写最新进展:" class="layui-textarea"></textarea>
|
14
|
+
</div>
|
15
|
+
</div>
|
16
|
+
<div class="layui-inline" style="padding-left: 50px">
|
17
|
+
<button type="submit" class="layui-btn layui-btn-normal" lay-submit lay-filter="add_follow_up">提交
|
18
|
+
</button>
|
19
|
+
</div>
|
20
|
+
</div>
|
21
|
+
</form>
|
22
|
+
|
23
|
+
|
24
|
+
|
25
|
+
|
26
|
+
<script>
|
27
|
+
layui.use(['form', 'table', 'upload', 'layer', 'laytpl', 'request', 'laydate'], function () {
|
28
|
+
var form = layui.form,
|
29
|
+
layer = layui.layer,
|
30
|
+
table = layui.table,
|
31
|
+
laytpl = layui.laytpl,
|
32
|
+
request = layui.request,
|
33
|
+
laydate = layui.laydate,
|
34
|
+
$ = layui.$;
|
35
|
+
|
36
|
+
form.render();
|
37
|
+
|
38
|
+
form.on('submit(add_follow_up)', function (data) {
|
39
|
+
data.field.activity_id = "<%= @activity.id %>";
|
40
|
+
request.authPost("missions/activities/" + data.field.activity_id + "/follow_up", data.field, function (res) {
|
41
|
+
if (res.success == false) {
|
42
|
+
layer.alert(res.msg)
|
43
|
+
} else {
|
44
|
+
layer.close(parent.followup_index);
|
45
|
+
parent.layer.close(parent.layer.getFrameIndex(window.name))
|
46
|
+
table.reload('activity_followp_table');
|
47
|
+
table.reload('activities_table')
|
48
|
+
}
|
49
|
+
})
|
50
|
+
|
51
|
+
|
52
|
+
return false;
|
53
|
+
});
|
54
|
+
|
55
|
+
});
|
56
|
+
</script>
|
@@ -33,6 +33,20 @@
|
|
33
33
|
</div>
|
34
34
|
</div>
|
35
35
|
<% end %>
|
36
|
+
<% if @current_admin.is_admin? %>
|
37
|
+
<div class="layui-form-item m-t-20">
|
38
|
+
<label class="layui-form-label">商机等级</label>
|
39
|
+
<div class="layui-input-inline">
|
40
|
+
<div id="levels" style="width: 300px;"></div>
|
41
|
+
</div>
|
42
|
+
</div>
|
43
|
+
<div class="layui-form-item m-t-20 layui-hide" id="watch_ids_wraper">
|
44
|
+
<label class="layui-form-label">指定查看人员</label>
|
45
|
+
<div class="layui-input-inline">
|
46
|
+
<div id="watch_ids" style="width: 300px;"></div>
|
47
|
+
</div>
|
48
|
+
</div>
|
49
|
+
<% end %>
|
36
50
|
<div class="layui-form-item m-t-20">
|
37
51
|
<div class="layui-input-block">
|
38
52
|
<button class="layui-btn layui-btn-normal" lay-submit lay-filter="edit_business">提交</button>
|
@@ -51,6 +65,35 @@
|
|
51
65
|
$ = layui.$;
|
52
66
|
selectInput = layui.selectInput;
|
53
67
|
|
68
|
+
var levels_select = xmSelect.render({
|
69
|
+
el: '#levels',
|
70
|
+
name: 'level_ids',
|
71
|
+
data: gon.levels,
|
72
|
+
on: function(data) {
|
73
|
+
var is_secret = false;
|
74
|
+
data.arr.forEach(function(i) {
|
75
|
+
if (i.name == '战略型' || i.name == '保密型') {
|
76
|
+
is_secret = true;
|
77
|
+
}
|
78
|
+
})
|
79
|
+
if (is_secret) {
|
80
|
+
$("#watch_ids_wraper").removeClass('layui-hide')
|
81
|
+
} else {
|
82
|
+
$("#watch_ids_wraper").addClass('layui-hide')
|
83
|
+
}
|
84
|
+
}
|
85
|
+
})
|
86
|
+
|
87
|
+
var watch_id_select = xmSelect.render({
|
88
|
+
el: '#watch_ids',
|
89
|
+
name: 'watch_ids',
|
90
|
+
data: gon.watche_ids,
|
91
|
+
filterable: true,
|
92
|
+
})
|
93
|
+
if (gon.is_secret) {
|
94
|
+
$("#watch_ids_wraper").removeClass("layui-hide")
|
95
|
+
}
|
96
|
+
|
54
97
|
form.render();
|
55
98
|
var department_id = gon.value;
|
56
99
|
var department = selectInput.render({
|
@@ -99,12 +142,11 @@
|
|
99
142
|
layer.alert("请选择单位部门")
|
100
143
|
return false;
|
101
144
|
} else {
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
}, function (res) {
|
145
|
+
var field = data.field;
|
146
|
+
console.log('field', field)
|
147
|
+
field.department_id = department.getValue() || department_id;
|
148
|
+
field.merge_business_ids = data.field.merge_business_ids;
|
149
|
+
request.authPut("missions/businesses/" + parent.id, field, function (res) {
|
108
150
|
if (res.success == false) {
|
109
151
|
layer.alert(res.msg)
|
110
152
|
} else {
|
@@ -120,6 +120,16 @@
|
|
120
120
|
</select>
|
121
121
|
</div>
|
122
122
|
</div>
|
123
|
+
<div class="layui-inline show_item" style="<%= params[:name] || params[:type] ? '' : 'display:none;' %>">
|
124
|
+
<label class="layui-form-label">商机等级</label>
|
125
|
+
<div class="layui-input-inline">
|
126
|
+
<select name="level_id">
|
127
|
+
<option value=""></option>
|
128
|
+
<option value="1">保密型</option>
|
129
|
+
<option value="2">战略型</option>
|
130
|
+
</select>
|
131
|
+
</div>
|
132
|
+
</div>
|
123
133
|
<div class="layui-inline">
|
124
134
|
<button type="reset" class="layui-btn layui-btn-primary" lay-submit lay-filter="reset_business_search">重置
|
125
135
|
</button>
|
data/config/routes.rb
CHANGED
@@ -0,0 +1,17 @@
|
|
1
|
+
class CreateEducodeSalesBusinessWatches < ActiveRecord::Migration[5.2]
|
2
|
+
def change
|
3
|
+
create_table :educode_sales_business_watches do |t|
|
4
|
+
t.references :business
|
5
|
+
t.references :staff
|
6
|
+
|
7
|
+
t.timestamps
|
8
|
+
end
|
9
|
+
|
10
|
+
create_table :educode_sales_business_levels do |t|
|
11
|
+
t.references :business
|
12
|
+
t.integer :level_id
|
13
|
+
|
14
|
+
t.timestamps
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|