educode_sales 0.8.1 → 0.8.2
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/application_controller.rb +8 -18
- data/app/controllers/educode_sales/assessments_controller.rb +49 -57
- data/app/controllers/educode_sales/businesses_controller.rb +5 -6
- data/app/models/educode_sales/filter.rb +1 -4
- data/app/views/educode_sales/assessments/_setup.html.erb +70 -58
- data/app/views/educode_sales/businesses/index.html.erb +39 -31
- data/app/views/educode_sales/businesses/show_follow.html.erb +1 -3
- data/app/views/educode_sales/money_plans/index.json.jbuilder +1 -1
- data/db/migrate/20220509073936_update_educode_sales_filters_filter_data.rb +9 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +3 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6c7d5af9d8ef299b488469e4641429c5f7ef51411ee9749817d215920ab2eefe
|
4
|
+
data.tar.gz: 8ecea150b2f7ebf1c83b46873d79aad3561a803d45c3d96b28be8d96d6ac6d7e
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 670ed7ce415e605c9d93dd0eaf7f369beed38af7f5f576726181fb2232281e6eafcbbf9678fb97fb7b4263abfe9c857f19d80e81b55e23186d2e5fc0a08fe11a
|
7
|
+
data.tar.gz: cad4aa2546734ae5cc3807c0947c0d194449867d0086efffeb36248040dba564bd145f06cc96bbe87a2c094b9b62abb364a99d98a6149d0eb54ccf31019ec367
|
@@ -28,25 +28,15 @@ module EducodeSales
|
|
28
28
|
end
|
29
29
|
|
30
30
|
def filter
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
end
|
40
|
-
a = a + d + ','
|
31
|
+
params[:check] = params[:check] == "true" ? 0:1
|
32
|
+
begin
|
33
|
+
filter = Filter.find_or_create_by!(staff_id: @current_admin.id, clazz: params[:type])
|
34
|
+
filter.extras["#{params[:name]}"] = params[:check]
|
35
|
+
filter.save!
|
36
|
+
render json: {success: true ,hidden: params[:check]}
|
37
|
+
rescue => e
|
38
|
+
render_failure("操作失败")
|
41
39
|
end
|
42
|
-
if b.include?(params[:name]) == false
|
43
|
-
p "include"
|
44
|
-
a = a + params[:name] + params[:hidden]
|
45
|
-
p a
|
46
|
-
end
|
47
|
-
filter.filter_data = a
|
48
|
-
filter.save
|
49
|
-
render_success
|
50
40
|
end
|
51
41
|
|
52
42
|
|
@@ -18,17 +18,12 @@ module EducodeSales
|
|
18
18
|
gon.staff_ids = Staff.joins(:user).where(job_type: common.id).map do |d|
|
19
19
|
{value: d.id, name: d.user.real_name }
|
20
20
|
end
|
21
|
-
filter = Filter.find_or_create_by(staff_id: @current_admin.id,
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
gon.filter["#{m}"] = d[-1].to_i # 前端的hide注意时int类型 string类型 获取不到
|
21
|
+
filter = Filter.find_or_create_by(staff_id: @current_admin.id, clazz: "assessments_setup")
|
22
|
+
if filter.extras.present?
|
23
|
+
gon.filter = filter.extras
|
24
|
+
else
|
25
|
+
gon.filter = {}
|
27
26
|
end
|
28
|
-
# p gon.filter
|
29
|
-
# gon.filter2 = {:username => false }
|
30
|
-
# gon.filter3 = '1'
|
31
|
-
# p gon.filter
|
32
27
|
end
|
33
28
|
format.json do
|
34
29
|
@year = params[:q].present? && params[:q][:assessment_year].present? ? params[:q][:assessment_year]:'2022'
|
@@ -45,18 +40,18 @@ module EducodeSales
|
|
45
40
|
# 新增
|
46
41
|
def create
|
47
42
|
begin
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
43
|
+
assessment = AssessmentsSetting.new(params_create)
|
44
|
+
assessment.user_id = current_user.user_id
|
45
|
+
assessment.assessment_year = "#{params[:assessment_year]}-01-01"
|
46
|
+
AssessmentsSetting.transaction do
|
52
47
|
params[:staffs_ids].split(",").each do |d|
|
53
|
-
staff =
|
48
|
+
staff = assessment.dup
|
54
49
|
staff.staff_id = d.to_i
|
55
50
|
staff.save
|
56
51
|
end
|
57
52
|
end
|
58
53
|
render_success
|
59
|
-
rescue
|
54
|
+
rescue => e
|
60
55
|
render_failure '增加数据错误'
|
61
56
|
end
|
62
57
|
end
|
@@ -96,7 +91,7 @@ module EducodeSales
|
|
96
91
|
assessment = AssessmentsSetting.find(params[:id])
|
97
92
|
assessment.destroy
|
98
93
|
render_success
|
99
|
-
rescue
|
94
|
+
rescue => e
|
100
95
|
render_failure '暂不能删除'
|
101
96
|
end
|
102
97
|
end
|
@@ -170,14 +165,13 @@ module EducodeSales
|
|
170
165
|
@staff_ids.each do |d|
|
171
166
|
# 注意
|
172
167
|
businesses = @businesses.where(staff_id: d)
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
b << {value: m.actual_amount.to_i, date:m.signed_date.to_s[5..6].to_i}
|
168
|
+
data_count=[]
|
169
|
+
data_list = FollowUp.joins("JOIN educode_sales_businesses ON educode_sales_businesses.last_follow_up_id = educode_sales_follow_ups.id")
|
170
|
+
.where("educode_sales_businesses.id in (?)",businesses.pluck(:id)).map do |m|
|
171
|
+
{value: m.actual_amount.to_i, date:m.signed_date.to_s[5..6].to_i}
|
178
172
|
end
|
179
|
-
count_data(
|
180
|
-
update_assessments_progress(
|
173
|
+
count_data(data_list,data_count) # 统计数据
|
174
|
+
update_assessments_progress(data_count,d) # 批量更新assessment数据 事物 一个commit
|
181
175
|
end
|
182
176
|
end
|
183
177
|
|
@@ -198,20 +192,19 @@ module EducodeSales
|
|
198
192
|
b_ids = Business.where(school_id: school_ids).pluck(:last_follow_up_id)
|
199
193
|
ids = a_ids + b_ids
|
200
194
|
@money_plans = MoneyPlan.joins(:follow_up).where(follow_up_id: ids)
|
201
|
-
|
195
|
+
else
|
202
196
|
@money_plans = MoneyPlan.joins(:follow_up).where(follow_up_id: follow_up_ids)
|
203
197
|
end
|
204
198
|
end
|
205
199
|
# todo 1 :实际回款 0:计划回款 where(clazz: 1 OR 实际回款 )
|
206
200
|
@money_plans = @money_plans.where(clazz: 1).where.not(date_at: nil)
|
207
201
|
@staff_ids.each do |d|
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
b << {date:m.date_at.to_s[5..6].to_i, value:m.amount.to_i}
|
202
|
+
data_count = []
|
203
|
+
data_list = @money_plans.where(staff_id: d).map do |m|
|
204
|
+
{date:m.date_at.to_s[5..6].to_i, value:m.amount.to_i}
|
212
205
|
end
|
213
|
-
count_data(
|
214
|
-
update_assessments_progress(
|
206
|
+
count_data(data_list,data_count)
|
207
|
+
update_assessments_progress(data_count, d)
|
215
208
|
end
|
216
209
|
end
|
217
210
|
|
@@ -247,20 +240,20 @@ module EducodeSales
|
|
247
240
|
def customer_and_busniness_visits
|
248
241
|
@staff_ids.each do |m|
|
249
242
|
customers = @customers.where(id: EducodeSales::CustomerExtension.where(customer_staff_id: m).pluck(:school_id))
|
250
|
-
|
251
|
-
|
243
|
+
data_list = []
|
244
|
+
data_count = []
|
252
245
|
CustomerFollow.joins(:school).where(school_id: customers.pluck(:id))
|
253
246
|
.where("Educode_Sales_customer_follows.created_at >= ? and Educode_Sales_customer_follows.created_at <= ?","#{@assessment_year}-01-01 ","#{@assessment_year}-12-31 23:59:59" )
|
254
247
|
.each do |d|
|
255
|
-
|
248
|
+
data_list << {value: 1, date: d.created_at.to_s[5..6].to_i}
|
256
249
|
end
|
257
250
|
FollowUp.joins(:business).where("Educode_Sales_businesses.id in (?)",EducodeSales::Business.where(school_id: customers.pluck(:id)).pluck(:id))
|
258
251
|
.where("Educode_Sales_follow_ups.created_at >= ? and Educode_Sales_follow_ups.created_at <= ?","#{@assessment_year}-01-01 00:00:00", "#{@assessment_year}-12-31 23:59:59").each do |d|
|
259
|
-
|
252
|
+
data_list << {date: d.created_at.to_s[5..6].to_i, value: 1}
|
260
253
|
end
|
261
|
-
count_data(
|
254
|
+
count_data(data_list,data_count)
|
262
255
|
assessment = @assessments.where(staff_id: m)
|
263
|
-
update_assessments_progress(
|
256
|
+
update_assessments_progress(data_count, assessment)
|
264
257
|
end
|
265
258
|
end
|
266
259
|
|
@@ -274,13 +267,12 @@ module EducodeSales
|
|
274
267
|
@businesses = @businesses.joins("JOIN educode_sales_follow_ups ON educode_sales_businesses.last_follow_up_id = educode_sales_follow_ups.id").where("educode_sales_follow_ups.clazz_id in (?) ",ids)
|
275
268
|
@staff_ids.each do |d|
|
276
269
|
businesses = @businesses.where(staff_id: d)
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
b << {date: m.created_at.to_s[5..6].to_i, value: 1}
|
270
|
+
data_count = []
|
271
|
+
data_list = businesses.map do |m|
|
272
|
+
{date: m.created_at.to_s[5..6].to_i, value: 1}
|
281
273
|
end
|
282
|
-
count_data(
|
283
|
-
update_assessments_progress(
|
274
|
+
count_data(data_list,data_count) # 统计数据
|
275
|
+
update_assessments_progress(data_count, d) # 批量更新assessment数据 事物 一个commit
|
284
276
|
end
|
285
277
|
end
|
286
278
|
|
@@ -309,27 +301,27 @@ module EducodeSales
|
|
309
301
|
|
310
302
|
|
311
303
|
# 更新assessments_settings表中数据
|
312
|
-
def update_assessments_progress(
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
304
|
+
def update_assessments_progress(data_count,staff_id)
|
305
|
+
data_count[12] = data_count[0].to_i + data_count[1].to_i + data_count[2].to_i
|
306
|
+
data_count[13] = data_count[3].to_i + data_count[4].to_i + data_count[5].to_i
|
307
|
+
data_count[14] = data_count[6].to_i + data_count[7].to_i + data_count[8].to_i
|
308
|
+
data_count[15] = data_count[9].to_i + data_count[10].to_i + data_count[11].to_i
|
309
|
+
data_count[16] = data_count[12].to_i + data_count[13].to_i + data_count[14].to_i + data_count[15].to_i
|
318
310
|
# 开启事物 处理 批量修改数据
|
319
311
|
assessments = @assessments.where(staff_id: staff_id)
|
320
|
-
assessments.update(annual_progress:
|
321
|
-
january_progress:
|
322
|
-
july_progress:
|
312
|
+
assessments.update(annual_progress: data_count[16], first_quarter_progress: data_count[12], second_quarter_progress: data_count[13], third_quarter_progress: data_count[14], fourth_quarter_progress: data_count[15],
|
313
|
+
january_progress: data_count[0], february_progress: data_count[1], march_progress: data_count[2], april_progress: data_count[3], may_progress: data_count[4], june_progress: data_count[5],
|
314
|
+
july_progress: data_count[6], august_progress: data_count[7], september_progress: data_count[8], october_progress: data_count[9], november_progress: data_count[10], december_progress: data_count[11])
|
323
315
|
|
324
316
|
end
|
325
317
|
|
326
318
|
# 将统计到的数据转入a中
|
327
|
-
def count_data(
|
328
|
-
|
329
|
-
if
|
330
|
-
|
319
|
+
def count_data(data_list,data_count)
|
320
|
+
data_list.each do |d|
|
321
|
+
if data_count[d[:date]-1].present?
|
322
|
+
data_count[d[:date]-1] = data_count[d[:date]-1] + d[:value]
|
331
323
|
else
|
332
|
-
|
324
|
+
data_count[d[:date]-1] = d[:value]
|
333
325
|
end
|
334
326
|
end
|
335
327
|
end
|
@@ -46,12 +46,11 @@ module EducodeSales
|
|
46
46
|
gon.export_menus << { title: '导出到Excel文件', event: 'export_excel' }
|
47
47
|
end
|
48
48
|
gon.export_menus << { title: '导出记录', event: 'export_records' }
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
gon.business_filter["#{m}"] = d[-1].to_i
|
49
|
+
filter = Filter.find_or_create_by(staff_id: @current_admin.id, clazz: "businesses_list")
|
50
|
+
if filter.extras.present?
|
51
|
+
gon.filter = filter.extras
|
52
|
+
else
|
53
|
+
gon.filter = {}
|
55
54
|
end
|
56
55
|
end
|
57
56
|
format.json do
|
@@ -94,14 +94,13 @@
|
|
94
94
|
width: 100,
|
95
95
|
sort: true,
|
96
96
|
fixed: 'left',
|
97
|
-
// filter: false
|
98
97
|
},
|
99
98
|
{
|
100
99
|
field: 'username',
|
101
100
|
title: '考核人员',
|
102
101
|
width: 100,
|
103
102
|
fixed: 'left',
|
104
|
-
hide: gon.filter["username"]
|
103
|
+
hide: gon.filter["username"],
|
105
104
|
},
|
106
105
|
{
|
107
106
|
field: 'annual',
|
@@ -118,6 +117,7 @@
|
|
118
117
|
{
|
119
118
|
field: 'january',
|
120
119
|
title: '1月',
|
120
|
+
width: 70,
|
121
121
|
hide: gon.filter.january,
|
122
122
|
},
|
123
123
|
{
|
@@ -259,19 +259,6 @@
|
|
259
259
|
|
260
260
|
table.on('tool(assessments)', function (obj) {
|
261
261
|
|
262
|
-
switch (obj.event) {
|
263
|
-
case 'username' :
|
264
|
-
console.log(obj);
|
265
|
-
console.log(obj.data);
|
266
|
-
console.log("username")
|
267
|
-
console.log("=================")
|
268
|
-
break;
|
269
|
-
case 'annual' :
|
270
|
-
console.log("annual")
|
271
|
-
break;
|
272
|
-
|
273
|
-
}
|
274
|
-
|
275
262
|
var data = obj.data;
|
276
263
|
console.log(obj)
|
277
264
|
console.log(data)
|
@@ -310,31 +297,54 @@
|
|
310
297
|
|
311
298
|
// * toolbar事件监听
|
312
299
|
table.on('toolbar(assessments)', function (obj) {
|
313
|
-
switch (obj.event) {
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
}
|
336
|
-
|
337
|
-
if (obj.event === '
|
300
|
+
// switch (obj.event) {
|
301
|
+
// case 'LAYTABLE_COLS':
|
302
|
+
// layui.form.on('checkbox(LAY_TABLE_TOOL_COLS)', function(obj) {
|
303
|
+
// var value = obj.elem.checked
|
304
|
+
// var name = obj.elem.attributes[1].value
|
305
|
+
// $.ajax({
|
306
|
+
// url: "filter",
|
307
|
+
// type: "GET",
|
308
|
+
// data: "type=assessments_setup&name=" + name + "&hidden=" + value,
|
309
|
+
// success: function (data){
|
310
|
+
// let hide_type = "[data-field='"+name+"']"
|
311
|
+
// if (data.hidden === '1'){
|
312
|
+
// $(hide_type).addClass('layui-hide');
|
313
|
+
// }else{
|
314
|
+
// $(hide_type).removeClass('layui-hide');
|
315
|
+
// }
|
316
|
+
// },
|
317
|
+
// dataType: 'Json'
|
318
|
+
// })
|
319
|
+
// });
|
320
|
+
// break;
|
321
|
+
//
|
322
|
+
// }
|
323
|
+
|
324
|
+
if (obj.event === 'LAYTABLE_COLS'){
|
325
|
+
layui.form.on('checkbox(LAY_TABLE_TOOL_COLS)', function(obj) {
|
326
|
+
var value = obj.elem.checked
|
327
|
+
var name = obj.elem.attributes[1].value
|
328
|
+
$.ajax({
|
329
|
+
url: "filter",
|
330
|
+
type: "GET",
|
331
|
+
data: "type=assessments_setup&name=" + name + "&check=" + value,
|
332
|
+
success: function (data){
|
333
|
+
let hide_type = "[data-field='"+name+"']"
|
334
|
+
if (data.hidden === 1){
|
335
|
+
$(hide_type).addClass('layui-hide');
|
336
|
+
}else if (data.hidden === 0){
|
337
|
+
$(hide_type).removeClass('layui-hide');
|
338
|
+
}
|
339
|
+
},
|
340
|
+
error: function (data){
|
341
|
+
layer.msg("操作失败")
|
342
|
+
},
|
343
|
+
dataType: 'Json'
|
344
|
+
})
|
345
|
+
});
|
346
|
+
}else if( obj.event === 'add'){
|
347
|
+
// 监听添加操作
|
338
348
|
var content = miniPage.getHrefContent('/missions/assessments/new');
|
339
349
|
var openWH = miniPage.getOpenWidthHeight();
|
340
350
|
var index = layer.open({
|
@@ -347,28 +357,30 @@
|
|
347
357
|
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
348
358
|
content: content,
|
349
359
|
success: function (layero, index) {
|
350
|
-
|
360
|
+
// 重新加载select下拉框(绩效考核标准)
|
351
361
|
form.render('select')
|
352
|
-
|
353
|
-
staffs.setValue([
|
362
|
+
// clear上次弹层中的多选人员数据 // staffs不清楚为什么要写在单独的script下才有效
|
363
|
+
staffs.setValue([])
|
354
364
|
|
355
365
|
}
|
356
366
|
});
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
367
|
+
// 这样写无法实现 要写在success中记住(open弹出层) 294
|
368
|
+
// document.getElementById('clear_staffs').onclick = function() {
|
369
|
+
// console.log("delete")
|
370
|
+
// staffs.setValue([ {name:'', value:''} ])
|
371
|
+
// // console.log(staffs)
|
372
|
+
// // alert(staffs.setValue([ {name:'', value:''} ]))
|
373
|
+
// // staffs.setValue([ ])
|
374
|
+
// // alert(staffs.setValue([ ]))
|
375
|
+
// clear(staffs)
|
376
|
+
// console.log("ok")
|
377
|
+
// };
|
378
|
+
|
379
|
+
// 目前不清除有什么用
|
380
|
+
// $(window).on("resize", function () {
|
381
|
+
// layer.full(index);
|
382
|
+
// });
|
383
|
+
}
|
372
384
|
});
|
373
385
|
|
374
386
|
|
@@ -280,21 +280,21 @@
|
|
280
280
|
title: '商机名称',
|
281
281
|
templet: '<div><span title="{{d.name}}">{{d.name}}</span></div>',
|
282
282
|
fixed: 'left',
|
283
|
-
hide: gon.
|
283
|
+
hide: gon.filter.name
|
284
284
|
},
|
285
285
|
{
|
286
286
|
field: 'school',
|
287
287
|
width: 150,
|
288
288
|
title: '单位',
|
289
289
|
templet: '#school_name',
|
290
|
-
hide: gon.
|
290
|
+
hide: gon.filter.school
|
291
291
|
},
|
292
292
|
{
|
293
293
|
field: 'department',
|
294
294
|
width: 150,
|
295
295
|
title: '部门',
|
296
296
|
templet: '<div><span title="{{d.department}}">{{d.department}}</span></div>',
|
297
|
-
hide: gon.
|
297
|
+
hide: gon.filter.department
|
298
298
|
},
|
299
299
|
{
|
300
300
|
field: 'follow_ups_count',
|
@@ -302,7 +302,7 @@
|
|
302
302
|
width: 60,
|
303
303
|
templet: '#show_follow',
|
304
304
|
totalRow: true,
|
305
|
-
hide: gon.
|
305
|
+
hide: gon.filter.follow_ups_count
|
306
306
|
},
|
307
307
|
// {
|
308
308
|
// field: 'teachers_count',
|
@@ -315,67 +315,67 @@
|
|
315
315
|
width: 80,
|
316
316
|
title: '类型',
|
317
317
|
templet: '<div><span title="{{d.clazz}}">{{d.clazz}}</span></div>',
|
318
|
-
hide: gon.
|
318
|
+
hide: gon.filter.clazz
|
319
319
|
},
|
320
320
|
{
|
321
321
|
field: 'stage',
|
322
322
|
width: 90,
|
323
323
|
title: '阶段',
|
324
|
-
hide: gon.
|
324
|
+
hide: gon.filter.stage
|
325
325
|
},
|
326
326
|
{
|
327
327
|
field: 'source',
|
328
328
|
width: 90,
|
329
329
|
title: '商机来源',
|
330
|
-
hide: gon.
|
330
|
+
hide: gon.filter.source
|
331
331
|
},
|
332
332
|
{
|
333
333
|
field: 'last_follow_person',
|
334
334
|
width: 100,
|
335
335
|
title: '最新跟进人',
|
336
|
-
hide: gon.
|
336
|
+
hide: gon.filter.last_follow_person
|
337
337
|
},
|
338
338
|
{
|
339
339
|
field: 'latest_time',
|
340
340
|
width: 200,
|
341
341
|
title: '最新跟进时间',
|
342
342
|
sort: true,
|
343
|
-
hide: gon.
|
343
|
+
hide: gon.filter.latest_time
|
344
344
|
},
|
345
345
|
{
|
346
346
|
field: 'invitation_at',
|
347
347
|
width: 105,
|
348
348
|
title: '招标时间',
|
349
349
|
sort: true,
|
350
|
-
hide: gon.
|
350
|
+
hide: gon.filter.invitation_at
|
351
351
|
},
|
352
352
|
{
|
353
353
|
field: 'bidded_date',
|
354
354
|
width: 105,
|
355
355
|
title: '中标时间',
|
356
356
|
sort: true,
|
357
|
-
hide: gon.
|
357
|
+
hide: gon.filter.bidded_date
|
358
358
|
},
|
359
359
|
{
|
360
360
|
field: 'signed_date',
|
361
361
|
width: 105,
|
362
362
|
title: '签单时间',
|
363
363
|
sort: true,
|
364
|
-
hide: gon.
|
364
|
+
hide: gon.filter.signed_date
|
365
365
|
},
|
366
366
|
{
|
367
367
|
field: 'reception_at',
|
368
368
|
width: 105,
|
369
369
|
title: '验收时间',
|
370
370
|
sort: true,
|
371
|
-
hide: gon.
|
371
|
+
hide: gon.filter.reception_at
|
372
372
|
},
|
373
373
|
{
|
374
374
|
field: 'service_end_time',
|
375
375
|
width: 200,
|
376
376
|
title: '服务期',
|
377
377
|
sort: true,
|
378
|
-
hide: gon.
|
378
|
+
hide: gon.filter.service_end_time
|
379
379
|
},
|
380
380
|
{
|
381
381
|
field: 'total_amount',
|
@@ -383,23 +383,23 @@
|
|
383
383
|
title: '总额',
|
384
384
|
totalRow: true,
|
385
385
|
sort: true,
|
386
|
-
hide: gon.
|
386
|
+
hide: gon.filter.total_amount
|
387
387
|
},
|
388
388
|
{
|
389
389
|
field: 'actual_amount',
|
390
390
|
width: 100,
|
391
|
-
|
392
|
-
|
393
|
-
|
394
|
-
hide: gon.
|
391
|
+
title: '合同额',
|
392
|
+
totalRow: true,
|
393
|
+
sort: true,
|
394
|
+
hide: gon.filter.actual_amount
|
395
395
|
},
|
396
396
|
{
|
397
|
-
|
398
|
-
|
399
|
-
|
400
|
-
|
397
|
+
field: 'return_money',
|
398
|
+
width: 100,
|
399
|
+
title: '回款',
|
400
|
+
sort: true,
|
401
401
|
totalRow: true,
|
402
|
-
hide: gon.
|
402
|
+
hide: gon.filter.return_money
|
403
403
|
},
|
404
404
|
{
|
405
405
|
field: 'wait_return_money',
|
@@ -407,26 +407,26 @@
|
|
407
407
|
title: '待回款',
|
408
408
|
sort: true,
|
409
409
|
totalRow: true,
|
410
|
-
hide: gon.
|
410
|
+
hide: gon.filter.wait_return_money
|
411
411
|
},
|
412
412
|
{
|
413
413
|
field: 'return_money_days',
|
414
414
|
width: 150,
|
415
415
|
title: '首次回款周期(天)',
|
416
|
-
hide: gon.
|
416
|
+
hide: gon.filter.return_money_days
|
417
417
|
},
|
418
418
|
{
|
419
419
|
field: 'place',
|
420
420
|
width: 160,
|
421
421
|
title: '渠道',
|
422
|
-
hide: gon.
|
422
|
+
hide: gon.filter.place
|
423
423
|
},
|
424
424
|
{
|
425
425
|
field: 'year',
|
426
426
|
width: 105,
|
427
427
|
title: '所属年度',
|
428
428
|
sort: true,
|
429
|
-
hide: gon.
|
429
|
+
hide: gon.filter.year
|
430
430
|
},
|
431
431
|
{
|
432
432
|
field: 'followed',
|
@@ -441,7 +441,7 @@
|
|
441
441
|
width: 105,
|
442
442
|
title: '关注',
|
443
443
|
align: "center",
|
444
|
-
hide: gon.
|
444
|
+
hide: gon.filter.followed
|
445
445
|
|
446
446
|
},
|
447
447
|
{
|
@@ -861,8 +861,16 @@
|
|
861
861
|
layui.form.on('checkbox(LAY_TABLE_TOOL_COLS)', function(obj) {
|
862
862
|
var value = obj.elem.checked
|
863
863
|
var name = obj.elem.attributes[1].value
|
864
|
-
|
865
|
-
|
864
|
+
request.get('missions/filter?type=businesses_list&name='+name+'&check='+value,{},function (res){
|
865
|
+
let hide_type = "[data-field='"+name+"']"
|
866
|
+
if (res.hidden === 1){
|
867
|
+
$(hide_type).addClass("layui-hide")
|
868
|
+
}else if(res.hidden === 0 ){
|
869
|
+
$(hide_type).removeClass("layui-hide")
|
870
|
+
}else if(res.status === 403){
|
871
|
+
layer.msg("操作失败")
|
872
|
+
}
|
873
|
+
})
|
866
874
|
});
|
867
875
|
}
|
868
876
|
|
@@ -0,0 +1,9 @@
|
|
1
|
+
class UpdateEducodeSalesFiltersFilterData < ActiveRecord::Migration[5.2]
|
2
|
+
def change
|
3
|
+
rename_column :educode_sales_filters, :filter_data , :extras
|
4
|
+
rename_column :educode_sales_filters, :filter_type, :clazz
|
5
|
+
EducodeSales::Filter.find_each do |filter|
|
6
|
+
filter.update_attributes!(:extras => nil )
|
7
|
+
end
|
8
|
+
end
|
9
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: educode_sales
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.8.
|
4
|
+
version: 0.8.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- anke1460
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-05-
|
11
|
+
date: 2022-05-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -456,6 +456,7 @@ files:
|
|
456
456
|
- db/migrate/20220420071909_create_educode_sales_business_relation_ships.rb
|
457
457
|
- db/migrate/20220507020149_create_filter.rb
|
458
458
|
- db/migrate/20220507091959_change_educode_sales_filter_column_length.rb
|
459
|
+
- db/migrate/20220509073936_update_educode_sales_filters_filter_data.rb
|
459
460
|
- lib/educode_sales.rb
|
460
461
|
- lib/educode_sales/engine.rb
|
461
462
|
- lib/educode_sales/version.rb
|