educode_sales 1.10.1 → 1.10.3
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/assets/images/educode_sales/indexlogo.png +0 -0
- data/app/controllers/educode_sales/assessments_controller.rb +101 -0
- data/app/controllers/educode_sales/customers_controller.rb +5 -7
- data/app/controllers/educode_sales/home_controller.rb +2 -1
- data/app/controllers/educode_sales/teachers_controller.rb +10 -5
- data/app/models/educode_sales/attendance.rb +4 -0
- data/app/models/educode_sales/idea.rb +1 -1
- data/app/views/educode_sales/assessments/_attendances.html.erb +238 -0
- data/app/views/educode_sales/assessments/attendances.js.erb +1 -0
- data/app/views/educode_sales/assessments/attendances.json.jbuilder +21 -0
- data/app/views/educode_sales/assessments/edit_attendance.html.erb +77 -0
- data/app/views/educode_sales/assessments/import.html.erb +38 -0
- data/app/views/educode_sales/assessments/index.html.erb +24 -2
- data/app/views/educode_sales/teachers/_index.html.erb +1 -196
- data/app/views/educode_sales/teachers/add_courses.html.erb +22 -5
- data/config/routes.rb +8 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +12 -5
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 86f8364fd145617cb033ff7034197314eb267e79bf716e14200046c24551fad5
|
4
|
+
data.tar.gz: 70caf8f362c4bf1b40d205f2a44370c7fd930e791f74a934ecef7a9abddc8321
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5ecece08fea07f8ed2213187dc596092fc1961640751a01301416ab97bf0587efbfd2fe2158e13c2becbe6f2eb3c19fa941b67a9c6ff6f2ed528ff61c911f1f0
|
7
|
+
data.tar.gz: 95170fda46d59cf757bbc5c5518a3e6a96a09872d4cb296c5344138e91d5baf9ab12bc64b321d3e50345bf2ae0e927001547a2fb0edcb8e12f0f2a9aaa424403
|
Binary file
|
@@ -376,13 +376,114 @@ module EducodeSales
|
|
376
376
|
end
|
377
377
|
|
378
378
|
|
379
|
+
#签到记录
|
380
|
+
def attendances
|
381
|
+
respond_to do |format|
|
382
|
+
format.html do
|
383
|
+
end
|
384
|
+
format.js do
|
385
|
+
end
|
386
|
+
format.json do
|
387
|
+
@attendances = EducodeSales::Attendance
|
388
|
+
if params[:q].present? && params[:q][:name].present?
|
389
|
+
@attendances = @attendances.where("name like ?", "%#{params[:q][:name].strip}%")
|
390
|
+
end
|
391
|
+
if params[:q].present? && params[:q][:attendance_date].present?
|
392
|
+
date = params[:q][:attendance_date].split(" - ")
|
393
|
+
@attendances = @attendances.where("attendance_date >= ? and attendance_date <= ?", date[0] + ' 00:00:00', date[1] + ' 23:59:59')
|
394
|
+
end
|
395
|
+
if params[:q].present? && params[:q][:customer].present?
|
396
|
+
@attendances = @attendances.where("customer like ?", "%#{params[:q][:customer]}%")
|
397
|
+
end
|
398
|
+
@attendances = @attendances.page(params[:page]).per(params[:limit])
|
399
|
+
end
|
400
|
+
end
|
401
|
+
end
|
402
|
+
|
403
|
+
#编辑签到记录界面
|
404
|
+
def edit_attendance
|
405
|
+
@attendance = EducodeSales::Attendance.find(params[:id])
|
406
|
+
render layout: false
|
407
|
+
end
|
408
|
+
|
409
|
+
#更新签到记录信息
|
410
|
+
def update_attendance
|
411
|
+
ActiveRecord::Base.transaction do
|
412
|
+
@attendance = EducodeSales::Attendance.find(params[:id])
|
413
|
+
@attendance.attendance_date = params[:attendance_datetime]
|
414
|
+
@attendance.update_attributes(attendance_update)
|
415
|
+
render_success
|
416
|
+
end
|
417
|
+
end
|
418
|
+
|
419
|
+
#删除签到记录
|
420
|
+
def delete_attendance
|
421
|
+
begin
|
422
|
+
ActiveRecord::Base.transaction do
|
423
|
+
attendance = EducodeSales::Attendance.find(params[:id])
|
424
|
+
attendance.destroy!
|
425
|
+
render_success
|
426
|
+
end
|
427
|
+
rescue Exception => e
|
428
|
+
render_failure(e.message)
|
429
|
+
end
|
430
|
+
end
|
379
431
|
|
432
|
+
#跳转导入界面
|
433
|
+
def import
|
434
|
+
render layout: false
|
435
|
+
end
|
380
436
|
|
437
|
+
#导入签到记录接口
|
438
|
+
def import_attendances
|
439
|
+
render_failure("文件不存在或格式错误") if params[:file].blank? || !params[:file].is_a?(ActionDispatch::Http::UploadedFile)
|
440
|
+
begin
|
441
|
+
ActiveRecord::Base.transaction do
|
442
|
+
doc = SimpleXlsxReader.open(params[:file])
|
443
|
+
size = doc.sheets.size
|
444
|
+
attendance_attrs = %i[name attendance_date longitude latitude location address mobile_id ip_address customer target created_at updated_at]
|
445
|
+
attendance_vales = []
|
446
|
+
(0..size - 1).each do |index|
|
447
|
+
doc.sheets[index].rows.each_with_index do |d, i|
|
448
|
+
next if i <= 2
|
449
|
+
name = d[0]
|
450
|
+
attendance_date_time = "#{d[1]} #{d[2]}"
|
451
|
+
attendance_date = attendance_date_time.strip
|
452
|
+
longitude = d[3]
|
453
|
+
latitude = d[4]
|
454
|
+
location = d[5]
|
455
|
+
address = d[6]
|
456
|
+
mobile_id = d[7]
|
457
|
+
ip_address = d[8]
|
458
|
+
customer = d[9]
|
459
|
+
target = d[10]
|
460
|
+
attendance_vales << {name: name, attendance_date: attendance_date, longitude: longitude, latitude: latitude, location: location,
|
461
|
+
address: address, mobile_id: mobile_id, ip_address: ip_address, customer: customer, target: target}
|
462
|
+
|
463
|
+
end
|
464
|
+
end
|
465
|
+
EducodeSales::Attendance.bulk_insert(*attendance_attrs) do |worker|
|
466
|
+
attendance_vales.each do |attendance|
|
467
|
+
worker.add(name: attendance[:name], attendance_date: attendance[:attendance_date].to_datetime, longitude: attendance[:longitude], latitude: attendance[:latitude],
|
468
|
+
location: attendance[:location], address: attendance[:address], mobile_id: attendance[:mobile_id], ip_address: attendance[:ip_address], customer: attendance[:customer], target: attendance[:target])
|
469
|
+
end
|
470
|
+
end
|
471
|
+
render_success
|
472
|
+
end
|
473
|
+
rescue Exception => e
|
474
|
+
render_failure(e.message)
|
475
|
+
end
|
476
|
+
end
|
381
477
|
|
382
478
|
|
383
479
|
|
384
480
|
|
385
481
|
private
|
482
|
+
|
483
|
+
def attendance_update
|
484
|
+
params.permit(:name, :mobile_id, :ip_address, :customer, :target)
|
485
|
+
end
|
486
|
+
|
386
487
|
def params_create
|
387
488
|
params.permit( :annual, :assessment,:assessment_year, :first_quarter, :second_quarter, :third_quarter, :fourth_quarter,
|
388
489
|
:january, :february, :march, :april, :may, :june, :july, :august, :september, :october, :november, :december,
|
@@ -195,8 +195,6 @@ module EducodeSales
|
|
195
195
|
LEFT JOIN educode_sales_businesses AS d ON d.department_id = departments.id AND d.deleted_at is NULL
|
196
196
|
GROUP BY schools.id, departments.id
|
197
197
|
) AS de ON m.id = de.id AND m.department_id = de.department_id
|
198
|
-
|
199
|
-
|
200
198
|
) AS s")
|
201
199
|
if @current_admin.is_admin?
|
202
200
|
# @customers = School.all
|
@@ -230,10 +228,10 @@ module EducodeSales
|
|
230
228
|
LEFT JOIN departments ON s.department_id = departments.id
|
231
229
|
")
|
232
230
|
|
233
|
-
part_a_ids = CustomerFollow.all.pluck(:school_id)
|
234
|
-
part_b_ids = Business.pluck(:school_id)
|
235
|
-
ids = part_a_ids + part_b_ids + CustomerAdd.all.pluck(:school_id)
|
236
|
-
@customers = @customers.where(id: ids.uniq)
|
231
|
+
# part_a_ids = CustomerFollow.all.pluck(:school_id)
|
232
|
+
# part_b_ids = Business.pluck(:school_id)
|
233
|
+
# ids = part_a_ids + part_b_ids + CustomerAdd.all.pluck(:school_id)
|
234
|
+
# @customers = @customers.where(id: ids.uniq)
|
237
235
|
if params[:q].present? && params[:q][:name].present?
|
238
236
|
@customers = @customers.where("schools.name like ?", "%#{params[:q][:name]}%")
|
239
237
|
end
|
@@ -246,7 +244,7 @@ module EducodeSales
|
|
246
244
|
end
|
247
245
|
if params[:q].present? && params[:q][:property].present?
|
248
246
|
property = params[:q][:property].split(",").map(&:to_i)
|
249
|
-
@customers = @customers.joins(
|
247
|
+
@customers = @customers.joins("JOIN school_tag_middles ON school_tag_middles.school_id = s.id INNER JOIN school_tags ON school_tags.id = school_tag_middles.school_tag_id").where("school_tags.id in (?)", property).distinct
|
250
248
|
end
|
251
249
|
|
252
250
|
if params[:q].present? && params[:q][:date].present?
|
@@ -119,7 +119,8 @@ module EducodeSales
|
|
119
119
|
end
|
120
120
|
|
121
121
|
def search_money_plans
|
122
|
-
@data = MoneyPlan.joins(business: :school)
|
122
|
+
# @data = MoneyPlan.joins(business: [:school, :last_follow_up])
|
123
|
+
@data = MoneyPlan.joins("JOIN educode_sales_businesses ON educode_sales_businesses.last_follow_up_id = educode_sales_money_plans.follow_up_id JOIN schools ON schools.id = educode_sales_businesses.school_id")
|
123
124
|
if params[:q].present?
|
124
125
|
@data = @data.where("educode_sales_businesses.name like :q OR educode_sales_businesses.number like :q OR schools.name like :q ", q: "%#{params[:q]}%").limit(20)
|
125
126
|
end
|
@@ -325,18 +325,23 @@ module EducodeSales
|
|
325
325
|
|
326
326
|
def add_courses
|
327
327
|
load_teacher
|
328
|
+
subject_names = %w[程序设计语言 计算机基础 算法设计 计算机系统能力 大数据 人工智能 数据库 电子信息 Web技术 软件工程 网络与安全 区块链 数学与统计 物联网 云计算 虚拟仿真].map{|d| {value: d, name: d}}
|
329
|
+
gon.subject_names = subject_names
|
328
330
|
render layout: false
|
329
331
|
end
|
330
332
|
|
331
333
|
|
332
334
|
def create_course
|
333
335
|
load_teacher
|
334
|
-
|
335
|
-
|
336
|
-
|
336
|
+
names = params[:select_subject_names].split(",")
|
337
|
+
begin
|
338
|
+
names.each do |name|
|
339
|
+
course_subject = @teacher.course_subjects.build(name: name, role_name: params[:role_name])
|
340
|
+
course_subject.save!
|
341
|
+
end
|
337
342
|
render_success
|
338
|
-
|
339
|
-
render_failure
|
343
|
+
rescue Exception => ex
|
344
|
+
render_failure(ex.message)
|
340
345
|
end
|
341
346
|
end
|
342
347
|
|
@@ -23,7 +23,7 @@ module EducodeSales
|
|
23
23
|
enum status: %w[未完成 已完成]
|
24
24
|
enum types: %w[低定制 非定制 高定制 全定制]
|
25
25
|
enum model: %w[本地版 线上版 混合版]
|
26
|
-
enum idea_type: %w[
|
26
|
+
enum idea_type: %w[建设方案 申报论证 市场调研 课程建设 报价清单 交流汇报 招标参数 资质申报 产品手册 宣传海报 课题论文 投标支持 其他类]
|
27
27
|
|
28
28
|
serialize :assist_staff_ids,Array
|
29
29
|
serialize :attachment_ids, Array
|
@@ -0,0 +1,238 @@
|
|
1
|
+
<div style="padding-right: 50px" id="tab_2">
|
2
|
+
<div class=" layui-show" style="padding-left: 0">
|
3
|
+
<div style="margin: 10px 10px 10px 10px">
|
4
|
+
<form class="layui-form layui-form-pane" lay-filter="search_form">
|
5
|
+
<div class="layui-form-item">
|
6
|
+
<div class="layui-inline">
|
7
|
+
<label class="layui-form-label">姓名</label>
|
8
|
+
<div class="layui-input-inline">
|
9
|
+
<input type="text" class="layui-input" id="name" name="name">
|
10
|
+
</div>
|
11
|
+
</div>
|
12
|
+
<div class="layui-inline">
|
13
|
+
<label class="layui-form-label">签到时间</label>
|
14
|
+
<div class="layui-input-inline">
|
15
|
+
<input type="text" class="layui-input" id="attendance_date" name="attendance_date" autocomplete="off" placeholder=" - ">
|
16
|
+
</div>
|
17
|
+
</div>
|
18
|
+
<div class="layui-inline">
|
19
|
+
<label class="layui-form-label">拜访客户</label>
|
20
|
+
<div class="layui-input-inline">
|
21
|
+
<input type="text" class="layui-input" id="customer" name="customer">
|
22
|
+
</div>
|
23
|
+
</div>
|
24
|
+
<div class="layui-inline">
|
25
|
+
<button type="reset" class="layui-btn layui-btn-primary" lay-submit lay-filter="reset_search">重置</button>
|
26
|
+
<button type="button" id="search_bt" class="layui-btn layui-btn-primary" lay-submit lay-filter="search_attendance">确定</button>
|
27
|
+
</div>
|
28
|
+
</div>
|
29
|
+
</form>
|
30
|
+
</div>
|
31
|
+
</div>
|
32
|
+
</div>
|
33
|
+
|
34
|
+
<script type="text/html" id="toolbarDemo">
|
35
|
+
<div class="layui-btn-container">
|
36
|
+
<span class="table-label">签到列表</span>
|
37
|
+
<button class="layui-btn layui-btn-normal layui-btn-sm data-add-btn pull-right" lay-event="import_attendances">批量导入签到数据</button>
|
38
|
+
</div>
|
39
|
+
</script>
|
40
|
+
|
41
|
+
<div class="">
|
42
|
+
<table class="layui-hide" id="attendance_table" style="min-height: 300px;" lay-filter="attendance_table"></table>
|
43
|
+
</div>
|
44
|
+
|
45
|
+
<script type="text/html" id="currentTableBar">
|
46
|
+
<a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">编辑</a>
|
47
|
+
<a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
|
48
|
+
</script>
|
49
|
+
|
50
|
+
<script>
|
51
|
+
layui.use(['form', 'table', 'miniPage', 'element', 'request', 'laydate'], function () {
|
52
|
+
var $ = layui.jquery,
|
53
|
+
form = layui.form,
|
54
|
+
request = layui.request,
|
55
|
+
miniPage = layui.miniPage,
|
56
|
+
laydate = layui.laydate;
|
57
|
+
|
58
|
+
form.render();
|
59
|
+
|
60
|
+
laydate.render({
|
61
|
+
elem: '#attendance_date',
|
62
|
+
range: true
|
63
|
+
});
|
64
|
+
|
65
|
+
table = layui.table;
|
66
|
+
table.render({
|
67
|
+
elem: '#attendance_table',
|
68
|
+
url: '/missions/assessments/attendances',
|
69
|
+
where: {q: form.val('search_form')},
|
70
|
+
toolbar: '#toolbarDemo',
|
71
|
+
defaultToolbar: ['filter'],
|
72
|
+
cols: [
|
73
|
+
[
|
74
|
+
{
|
75
|
+
field: 'id',
|
76
|
+
width: 100,
|
77
|
+
title:'序号',
|
78
|
+
type: 'numbers',
|
79
|
+
fixed: 'left'
|
80
|
+
},
|
81
|
+
{
|
82
|
+
field: 'name',
|
83
|
+
width: 120,
|
84
|
+
title: '姓名',
|
85
|
+
fixed: 'left',
|
86
|
+
templet: "#name"
|
87
|
+
},
|
88
|
+
{
|
89
|
+
field: 'attendance_date',
|
90
|
+
width: 120,
|
91
|
+
title: '日期',
|
92
|
+
},
|
93
|
+
{
|
94
|
+
field: 'attendance_time',
|
95
|
+
width: 150,
|
96
|
+
title: '时间',
|
97
|
+
},
|
98
|
+
{
|
99
|
+
field: 'longitude',
|
100
|
+
width: 150,
|
101
|
+
title: '经度',
|
102
|
+
},
|
103
|
+
{
|
104
|
+
field: 'latitude',
|
105
|
+
width: 120,
|
106
|
+
title: '纬度',
|
107
|
+
},
|
108
|
+
{
|
109
|
+
field: 'location',
|
110
|
+
width: 120,
|
111
|
+
title: '地点',
|
112
|
+
},
|
113
|
+
{
|
114
|
+
field: 'address',
|
115
|
+
width: 150,
|
116
|
+
title: '详细地址',
|
117
|
+
},
|
118
|
+
{
|
119
|
+
field: 'mobile_id',
|
120
|
+
width: 150,
|
121
|
+
title: '手机标识',
|
122
|
+
},
|
123
|
+
{
|
124
|
+
field: 'ip_address',
|
125
|
+
width: 150,
|
126
|
+
title: 'ip地址',
|
127
|
+
},
|
128
|
+
{
|
129
|
+
field: 'customer',
|
130
|
+
width: 120,
|
131
|
+
title: '拜访客户',
|
132
|
+
},
|
133
|
+
{
|
134
|
+
field: 'target',
|
135
|
+
width: 120,
|
136
|
+
title: '拜访对象',
|
137
|
+
},
|
138
|
+
{
|
139
|
+
title: '操作',
|
140
|
+
minWidth: 150,
|
141
|
+
toolbar: '#currentTableBar',
|
142
|
+
align: "center",
|
143
|
+
fixed: 'right'
|
144
|
+
}
|
145
|
+
]
|
146
|
+
],
|
147
|
+
limit: 20,
|
148
|
+
limits: [10, 20, 30, 40, 50, 60, 70, 80, 90],
|
149
|
+
page: true
|
150
|
+
});
|
151
|
+
|
152
|
+
//重置
|
153
|
+
form.on('submit(reset_search)', function () {
|
154
|
+
form.val('search_form', {
|
155
|
+
name: "",
|
156
|
+
attendance_date: "",
|
157
|
+
customer: ""
|
158
|
+
});
|
159
|
+
return false;
|
160
|
+
});
|
161
|
+
|
162
|
+
var sort = {}, search = {};
|
163
|
+
table.on('sort(attendance_table)', function (obj) {
|
164
|
+
sort.field = obj.field;
|
165
|
+
sort.order = obj.type;
|
166
|
+
table.reload('attendance_table', {
|
167
|
+
initSort: obj,
|
168
|
+
where: {
|
169
|
+
sort: sort,
|
170
|
+
q: search
|
171
|
+
}
|
172
|
+
});
|
173
|
+
});
|
174
|
+
|
175
|
+
// 监听搜索操作
|
176
|
+
form.on('submit(search_attendance)', function (data) {
|
177
|
+
search = data.field;
|
178
|
+
table.reload('attendance_table', {
|
179
|
+
page: {
|
180
|
+
curr: 1
|
181
|
+
},
|
182
|
+
where: {q: search, sort: sort}
|
183
|
+
}, 'data');
|
184
|
+
return false;
|
185
|
+
});
|
186
|
+
|
187
|
+
//toorbar事件监听
|
188
|
+
table.on('toolbar(attendance_table)', function (obj) {
|
189
|
+
if (obj.event === 'import_attendances') { //批量导入签到记录
|
190
|
+
var content = miniPage.getHrefContent('/missions/assessments/import');
|
191
|
+
var openWH = miniPage.getOpenWidthHeight();
|
192
|
+
import_index = layer.open({
|
193
|
+
title: '导入签到记录数据',
|
194
|
+
type: 1,
|
195
|
+
shade: 0.2,
|
196
|
+
shadeClose: true,
|
197
|
+
area: ['400px', '200px'],
|
198
|
+
offset: 'auto',
|
199
|
+
closeBtn: 0,
|
200
|
+
content: content,
|
201
|
+
});
|
202
|
+
$(window).on("resize", function () {
|
203
|
+
layer.full(index);
|
204
|
+
});
|
205
|
+
}
|
206
|
+
});
|
207
|
+
|
208
|
+
//tool事件监听
|
209
|
+
table.on('tool(attendance_table)', function (obj) {
|
210
|
+
var data = obj.data;
|
211
|
+
var id = data.id;
|
212
|
+
if (obj.event === 'edit'){ //编辑签到记录
|
213
|
+
var content = miniPage.getHrefContent('/missions/assessments/' + id + '/edit_attendance');
|
214
|
+
var openWH = miniPage.getOpenWidthHeight();
|
215
|
+
var index = layer.open({
|
216
|
+
title: '编辑签到记录',
|
217
|
+
type: 1,
|
218
|
+
shade: 0.2,
|
219
|
+
maxmin: true,
|
220
|
+
shadeClose: true,
|
221
|
+
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
222
|
+
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
223
|
+
content: content
|
224
|
+
});
|
225
|
+
$(window).on("resize", function () {
|
226
|
+
layer.full(index);
|
227
|
+
});
|
228
|
+
}else if (obj.event === 'delete'){
|
229
|
+
layer.confirm('确定删除该签到记录吗?', function (index) {
|
230
|
+
request.delete('missions/assessments/' + id + "/delete_attendance", {}, function (res) {
|
231
|
+
layer.close(index);
|
232
|
+
table.reload("attendance_table")
|
233
|
+
})
|
234
|
+
});
|
235
|
+
}
|
236
|
+
});
|
237
|
+
})
|
238
|
+
</script>
|
@@ -0,0 +1 @@
|
|
1
|
+
$("#page_1").html("<%= j render 'attendances' %>");
|
@@ -0,0 +1,21 @@
|
|
1
|
+
json.data do
|
2
|
+
json.array! @attendances do |d|
|
3
|
+
json.id d.id
|
4
|
+
json.name d.name
|
5
|
+
date = d.attendance_date.to_s.strip
|
6
|
+
attendance_date = date&.split(" ")[0]
|
7
|
+
attendance_time = date&.split(" ")[1]
|
8
|
+
json.attendance_date attendance_date #签到日期
|
9
|
+
json.attendance_time attendance_time #签到时间
|
10
|
+
json.longitude d.longitude #经度
|
11
|
+
json.latitude d.latitude #纬度
|
12
|
+
json.location d.location #签到地点
|
13
|
+
json.address d.address #详细地址
|
14
|
+
json.mobile_id d.mobile_id #手机标识
|
15
|
+
json.ip_address d.ip_address #ip地址
|
16
|
+
json.customer d.customer #拜访客户
|
17
|
+
json.target d.target #拜访对象
|
18
|
+
end
|
19
|
+
end
|
20
|
+
json.code 0
|
21
|
+
json.count @attendances&.total_count
|
@@ -0,0 +1,77 @@
|
|
1
|
+
<form class="layui-form layuimini-form" lay-filter="attendance_form">
|
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-block" style="width: 400px;">
|
6
|
+
<input type="text" name="name" value="<%= @attendance&.name %>" placeholder="请输入姓名" autocomplete="off" class="layui-input">
|
7
|
+
</div>
|
8
|
+
</div>
|
9
|
+
<div class="layui-inline">
|
10
|
+
<label class="layui-form-label">签到时间:</label>
|
11
|
+
<div class="layui-input-inline" style="width: 400px;">
|
12
|
+
<input type="text" class="layui-input" id="attendance_datetime" name="attendance_datetime" value="<%= @attendance&.attendance_date %>" autocomplete="off">
|
13
|
+
</div>
|
14
|
+
</div>
|
15
|
+
<br/>
|
16
|
+
<div class="layui-inline">
|
17
|
+
<label class="layui-form-label">手机标识:</label>
|
18
|
+
<div class="layui-input-block" style="width: 400px;">
|
19
|
+
<input type="text" name="mobile_id" value="<%= @attendance&.mobile_id %>" placeholder="请输入手机标识" autocomplete="off" class="layui-input">
|
20
|
+
</div>
|
21
|
+
</div>
|
22
|
+
<div class="layui-inline">
|
23
|
+
<label class="layui-form-label">ip地址:</label>
|
24
|
+
<div class="layui-input-block" style="width: 400px;">
|
25
|
+
<input type="text" name="ip_address" value="<%= @attendance&.ip_address %>" placeholder="请输入ip地址" autocomplete="off" class="layui-input">
|
26
|
+
</div>
|
27
|
+
</div>
|
28
|
+
<br/>
|
29
|
+
<div class="layui-inline">
|
30
|
+
<label class="layui-form-label">拜访客户:</label>
|
31
|
+
<div class="layui-input-block" style="width: 400px;">
|
32
|
+
<input type="text" name="customer" value="<%= @attendance&.customer %>" placeholder="请输入拜访客户" autocomplete="off" class="layui-input">
|
33
|
+
</div>
|
34
|
+
</div>
|
35
|
+
<div class="layui-inline">
|
36
|
+
<label class="layui-form-label">拜访对象:</label>
|
37
|
+
<div class="layui-input-block" style="width: 400px;">
|
38
|
+
<input type="text" name="target" value="<%= @attendance&.target %>" placeholder="请输入拜访对象" autocomplete="off" class="layui-input">
|
39
|
+
</div>
|
40
|
+
</div>
|
41
|
+
<br/>
|
42
|
+
<div class="layui-inline" style="padding-left: 110px">
|
43
|
+
<button type="submit" class="layui-btn layui-btn-normal" lay-submit lay-filter="attendance_reset">提交</button>
|
44
|
+
</div>
|
45
|
+
</div>
|
46
|
+
</form>
|
47
|
+
|
48
|
+
<script>
|
49
|
+
layui.use(['form', 'element', 'laydate', 'request'], function () {
|
50
|
+
var $ = layui.jquery,
|
51
|
+
form = layui.form,
|
52
|
+
request = layui.request,
|
53
|
+
laydate = layui.laydate;
|
54
|
+
|
55
|
+
form.render();
|
56
|
+
|
57
|
+
laydate.render({
|
58
|
+
elem: '#attendance_datetime',
|
59
|
+
type: 'datetime',
|
60
|
+
fullPanel: true
|
61
|
+
});
|
62
|
+
|
63
|
+
//监听提交
|
64
|
+
form.on('submit(attendance_reset)', function (data) {
|
65
|
+
request.authPut("missions/assessments/"+ <%= @attendance.id %> + "/update_attendance", data.field, function (res) {
|
66
|
+
if (res.success === false) {
|
67
|
+
layer.alert(res.msg)
|
68
|
+
} else {
|
69
|
+
layer.closeAll(); //关闭所有层
|
70
|
+
table.reload('attendance_table')
|
71
|
+
}
|
72
|
+
});
|
73
|
+
return false;
|
74
|
+
});
|
75
|
+
});
|
76
|
+
</script>
|
77
|
+
|
@@ -0,0 +1,38 @@
|
|
1
|
+
<div style="padding-left: 135px; padding-top: 50px">
|
2
|
+
<button type="button" class="layui-btn layui-btn-lg layui-btn-radius layui-btn-normal" id="import_attendance"><i class="layui-icon"></i>选择文件</button>
|
3
|
+
</div>
|
4
|
+
<script>
|
5
|
+
layui.use(['form', 'table', 'upload', 'layer', 'laytpl', 'request', 'selectInput'], function () {
|
6
|
+
var form = layui.form,
|
7
|
+
layer = layui.layer,
|
8
|
+
table = layui.table,
|
9
|
+
upload = layui.upload,
|
10
|
+
$ = layui.$;
|
11
|
+
selectInput = layui.selectInput;
|
12
|
+
|
13
|
+
form.render();
|
14
|
+
|
15
|
+
//指定允许上传的文件类型
|
16
|
+
upload.render({
|
17
|
+
elem: '#import_attendance',
|
18
|
+
url: '/missions/assessments/import_attendances', //此处配置你自己的上传接口即可
|
19
|
+
accept: 'file', //普通文件
|
20
|
+
headers: {
|
21
|
+
'X-CSRF-Token': $('meta[name=csrf-token]').attr('content')
|
22
|
+
},
|
23
|
+
before: function(obj){ //obj参数包含的信息,跟 choose回调完全一致,可参见上文。
|
24
|
+
layer.load(); //上传loading
|
25
|
+
},
|
26
|
+
done: function(res){
|
27
|
+
layer.msg('导入成功');
|
28
|
+
table.reload('attendance_table');
|
29
|
+
layer.close(parent.import_index);
|
30
|
+
layer.closeAll('loading'); //关闭loading
|
31
|
+
},
|
32
|
+
error: function(res){
|
33
|
+
layer.closeAll('loading'); //关闭loading
|
34
|
+
layer.msg(res.responseJSON.msg);
|
35
|
+
}
|
36
|
+
});
|
37
|
+
});
|
38
|
+
</script>
|
@@ -6,6 +6,7 @@
|
|
6
6
|
<% if can?(:show, EducodeSales::AssessmentsSetting) %>
|
7
7
|
<li data="assessments" > 考核指标设置</li>
|
8
8
|
<%end %>
|
9
|
+
<li class="">签到记录</li>
|
9
10
|
</ul>
|
10
11
|
<!--<div class="layuimini-main min-height-table"></div>-->
|
11
12
|
<div class="layui-tab-content">
|
@@ -31,17 +32,26 @@
|
|
31
32
|
</div>
|
32
33
|
<%end %>
|
33
34
|
<%end %>
|
35
|
+
|
36
|
+
<div class="layui-tab-item">
|
37
|
+
<div id="page_1"></div>
|
34
38
|
</div>
|
39
|
+
|
35
40
|
</div>
|
41
|
+
</div>
|
36
42
|
|
37
43
|
<script>
|
38
44
|
layui.use(['element', 'table', 'jquery','laydate'], function () {
|
39
45
|
var $ = layui.jquery,
|
40
46
|
table = layui.table,
|
41
|
-
laydate = layui.laydate
|
47
|
+
laydate = layui.laydate,
|
42
48
|
element = layui.element;
|
43
49
|
|
44
|
-
|
50
|
+
element.render();
|
51
|
+
element.on('tab(sale_tab)', function (data) {
|
52
|
+
if (data.index === 2 && $("#tab_2").length === 0) {
|
53
|
+
loadPage('/missions/assessments/attendances')
|
54
|
+
}
|
45
55
|
// var status = $(this).attr('data')
|
46
56
|
// switch (status) {
|
47
57
|
// case 'progress':
|
@@ -67,6 +77,18 @@
|
|
67
77
|
// });
|
68
78
|
// return false;
|
69
79
|
// });
|
80
|
+
|
81
|
+
function loadPage(url) {
|
82
|
+
var layer_index = layer.load(0, {shade: [0.1, '#fff']});
|
83
|
+
Rails.ajax({
|
84
|
+
url: url,
|
85
|
+
type: 'GET',
|
86
|
+
dataType: "script",
|
87
|
+
success: function () {
|
88
|
+
layer.close(layer_index);
|
89
|
+
}
|
90
|
+
});
|
91
|
+
}
|
70
92
|
})
|
71
93
|
</script>
|
72
94
|
|
@@ -399,202 +399,7 @@
|
|
399
399
|
toolbar: '#toolbarDemo',
|
400
400
|
totalRow:true,
|
401
401
|
defaultToolbar: ['filter'],
|
402
|
-
cols:
|
403
|
-
[
|
404
|
-
{
|
405
|
-
field: 'id',
|
406
|
-
width: 60,
|
407
|
-
title:'序号',type: 'numbers',
|
408
|
-
totalRowText:'合计',
|
409
|
-
fixed: 'left'
|
410
|
-
|
411
|
-
},
|
412
|
-
{
|
413
|
-
field: 'name',
|
414
|
-
width: 100,
|
415
|
-
title: '姓名',
|
416
|
-
fixed: 'left',
|
417
|
-
templet: "#name"
|
418
|
-
},
|
419
|
-
{
|
420
|
-
field: 'realname',
|
421
|
-
width: 100,
|
422
|
-
title: '真实姓名',
|
423
|
-
},
|
424
|
-
{
|
425
|
-
field: 'school',
|
426
|
-
width: 160,
|
427
|
-
title: '单位',
|
428
|
-
templet:'<div><span title="{{d.school}}">{{d.school}}</span></div>'
|
429
|
-
|
430
|
-
},
|
431
|
-
{
|
432
|
-
field: 'department',
|
433
|
-
width: 130,
|
434
|
-
title: '部门',
|
435
|
-
templet:'<div><span title="{{d.department}}">{{d.department}}</span></div>'
|
436
|
-
},
|
437
|
-
{
|
438
|
-
field: 'majors',
|
439
|
-
width: 160,
|
440
|
-
title: '专业',
|
441
|
-
},
|
442
|
-
{
|
443
|
-
field: 'area',
|
444
|
-
width: 80,
|
445
|
-
title: '区域',
|
446
|
-
},
|
447
|
-
{
|
448
|
-
field: 'business_count',
|
449
|
-
width: 120,
|
450
|
-
title: '单位商机数',
|
451
|
-
},
|
452
|
-
{
|
453
|
-
field: 'professional_title',
|
454
|
-
title: '职称',
|
455
|
-
width: 80,
|
456
|
-
templet: '#show_follow'
|
457
|
-
},
|
458
|
-
{
|
459
|
-
field: 'job',
|
460
|
-
width: 80,
|
461
|
-
title: '职务',
|
462
|
-
templet: '#show_keys'
|
463
|
-
|
464
|
-
},
|
465
|
-
{
|
466
|
-
field: 'source',
|
467
|
-
width: 90,
|
468
|
-
title: '来源',
|
469
|
-
},
|
470
|
-
{
|
471
|
-
field: 'attitude',
|
472
|
-
width: 60,
|
473
|
-
title: '态度',
|
474
|
-
},
|
475
|
-
{
|
476
|
-
field: 'course_subjects_count',
|
477
|
-
width: 90,
|
478
|
-
title: '课程方向',
|
479
|
-
templet: "#courses"
|
480
|
-
},
|
481
|
-
{
|
482
|
-
field: 'teacher_follows_count',
|
483
|
-
width: 90,
|
484
|
-
title: '跟进情况',
|
485
|
-
totalRow:true,
|
486
|
-
templet: "#follow"
|
487
|
-
},
|
488
|
-
{
|
489
|
-
field: 'sales_manage',
|
490
|
-
width: 160,
|
491
|
-
title: '销售经理',
|
492
|
-
},
|
493
|
-
{
|
494
|
-
field: 'staff_manage',
|
495
|
-
width: 160,
|
496
|
-
title: '生态经理',
|
497
|
-
},
|
498
|
-
{
|
499
|
-
field: 'follow_person',
|
500
|
-
width: 120,
|
501
|
-
title: '最新跟进人',
|
502
|
-
},
|
503
|
-
{
|
504
|
-
field: 'followup_at',
|
505
|
-
width: 180,
|
506
|
-
title: '最新跟进时间',
|
507
|
-
},
|
508
|
-
{
|
509
|
-
field: 'latest_time',
|
510
|
-
width: 120,
|
511
|
-
title: '无跟进天数',
|
512
|
-
sort: true,
|
513
|
-
},
|
514
|
-
{
|
515
|
-
field: 'teacher_used',
|
516
|
-
width: 120,
|
517
|
-
title: '学院渗透率',
|
518
|
-
},
|
519
|
-
{
|
520
|
-
field: 'students',
|
521
|
-
width: 60,
|
522
|
-
totalRow:'{{ parseInt(d.TOTAL_NUMS) }}',
|
523
|
-
title: '学生',
|
524
|
-
},
|
525
|
-
{
|
526
|
-
field: 'courses_count',
|
527
|
-
width: 60,
|
528
|
-
title: '课堂',
|
529
|
-
totalRow:true,
|
530
|
-
templet: "#class"
|
531
|
-
},
|
532
|
-
{
|
533
|
-
field: 'activities_count',
|
534
|
-
width: 100,
|
535
|
-
title: '参与活动',
|
536
|
-
templet: "#event"
|
537
|
-
},
|
538
|
-
{
|
539
|
-
field: 'created_on',
|
540
|
-
width: 120,
|
541
|
-
title: '注册时间',
|
542
|
-
sort: true,
|
543
|
-
},
|
544
|
-
{
|
545
|
-
field: 'last_login_on',
|
546
|
-
width: 120,
|
547
|
-
title: '最近登录',
|
548
|
-
sort: true,
|
549
|
-
},
|
550
|
-
{
|
551
|
-
field: 'created_at',
|
552
|
-
width: 120,
|
553
|
-
title: '添加时间',
|
554
|
-
sort: true,
|
555
|
-
},
|
556
|
-
{
|
557
|
-
field: 'experience',
|
558
|
-
width: 120,
|
559
|
-
title: '经验值',
|
560
|
-
sort: true,
|
561
|
-
},
|
562
|
-
{
|
563
|
-
field: 'grade',
|
564
|
-
width: 120,
|
565
|
-
title: '金币',
|
566
|
-
sort: true,
|
567
|
-
},
|
568
|
-
{
|
569
|
-
field: 'mobile',
|
570
|
-
width: 120,
|
571
|
-
title: '联系电话',
|
572
|
-
},
|
573
|
-
{
|
574
|
-
field: 'wechat',
|
575
|
-
width: 120,
|
576
|
-
title: '微信号',
|
577
|
-
},
|
578
|
-
{
|
579
|
-
field: 'teacher_assist',
|
580
|
-
width: 120,
|
581
|
-
title: '教研助理',
|
582
|
-
},
|
583
|
-
{
|
584
|
-
field: 'is_contact',
|
585
|
-
width: 120,
|
586
|
-
title: '是否联系上'
|
587
|
-
},
|
588
|
-
{
|
589
|
-
title: '操作',
|
590
|
-
minWidth: 270,
|
591
|
-
toolbar: '#currentTableBar',
|
592
|
-
align: "center",
|
593
|
-
fixed: 'right'
|
594
|
-
}
|
595
|
-
]
|
596
|
-
],
|
597
|
-
|
402
|
+
cols: cols_table,
|
598
403
|
limit: 20,
|
599
404
|
limits: [10,15,20,30,40,50,60,70,80,90],
|
600
405
|
page: true,
|
@@ -1,16 +1,17 @@
|
|
1
|
+
<%= Gon::Base.render_data %>
|
1
2
|
<div class="layuimini-main" style="height: 100%;">
|
2
3
|
<div class="layui-form layuimini-form" lay-filter="common_edit">
|
3
4
|
<fieldset class="table-search-fieldset">
|
4
5
|
<legend>添加课程方向</legend>
|
5
6
|
<div class="layui-form-item">
|
6
7
|
<label class="layui-form-label required" >课程名称</label>
|
7
|
-
<div class="layui-input-
|
8
|
-
<
|
8
|
+
<div class="layui-input-inline">
|
9
|
+
<div id="subject_name" style="width: 1000px"></div>
|
9
10
|
</div>
|
10
11
|
</div>
|
11
12
|
<div class="layui-form-item">
|
12
13
|
<label class="layui-form-label required" >教学角色</label>
|
13
|
-
<div class="layui-input-block">
|
14
|
+
<div class="layui-input-block" style="width: 1000px">
|
14
15
|
<input type="text" name="role_name" autocomplete="off" class="layui-input" placeholder="请输入" required lay-verify="required">
|
15
16
|
</div>
|
16
17
|
</div>
|
@@ -42,12 +43,28 @@
|
|
42
43
|
|
43
44
|
form.render();
|
44
45
|
|
46
|
+
//课程名称复选框
|
47
|
+
if (document.getElementById("subject_name")) {
|
48
|
+
var subject_list = xmSelect.render({
|
49
|
+
el: '#subject_name',
|
50
|
+
data: gon.subject_names,
|
51
|
+
filterable: true
|
52
|
+
})
|
53
|
+
}
|
54
|
+
|
45
55
|
// 当前弹出层,防止ID被覆盖
|
46
56
|
var parentIndex = layer.index;
|
47
57
|
|
48
58
|
|
49
59
|
//监听提交
|
50
60
|
form.on('submit(add_course)', function (data) {
|
61
|
+
var subject_names = [];
|
62
|
+
if (document.getElementById("subject_name")) {
|
63
|
+
subject_list.getValue().forEach(function (d) {
|
64
|
+
subject_names.push(d.value);
|
65
|
+
})
|
66
|
+
}
|
67
|
+
data.field['select_subject_names'] = subject_names.join(",");
|
51
68
|
request.authPost('missions/teachers/'+parent.teacher_id +'/create_course', data.field, function (res) {
|
52
69
|
if (res.success == false) {
|
53
70
|
layer.alert(res.msg)
|
@@ -55,11 +72,11 @@
|
|
55
72
|
table.reload('teachers_table');
|
56
73
|
table.reload('coursesTable');
|
57
74
|
form.val('common_edit', {
|
58
|
-
'
|
75
|
+
'subject_name': '',
|
59
76
|
'role_name':''
|
60
77
|
})
|
61
78
|
}
|
62
|
-
})
|
79
|
+
});
|
63
80
|
return false;
|
64
81
|
});
|
65
82
|
|
data/config/routes.rb
CHANGED
@@ -266,6 +266,14 @@ EducodeSales::Engine.routes.draw do
|
|
266
266
|
get :progress # 考核完成情况
|
267
267
|
post :get_export_data # 导出数据
|
268
268
|
get :finished
|
269
|
+
get :attendances
|
270
|
+
get :import
|
271
|
+
post :import_attendances
|
272
|
+
end
|
273
|
+
member do
|
274
|
+
get :edit_attendance
|
275
|
+
put :update_attendance
|
276
|
+
delete :delete_attendance
|
269
277
|
end
|
270
278
|
end
|
271
279
|
|
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: 1.10.
|
4
|
+
version: 1.10.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- anke1460
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-06-
|
11
|
+
date: 2023-06-13 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -105,6 +105,7 @@ files:
|
|
105
105
|
- app/assets/images/educode_sales/icon-login.png
|
106
106
|
- app/assets/images/educode_sales/icon.png
|
107
107
|
- app/assets/images/educode_sales/indexLogo.png
|
108
|
+
- app/assets/images/educode_sales/indexlogo.png
|
108
109
|
- app/assets/images/educode_sales/loading-0.gif
|
109
110
|
- app/assets/images/educode_sales/loading-1.gif
|
110
111
|
- app/assets/images/educode_sales/loading-2.gif
|
@@ -203,6 +204,7 @@ files:
|
|
203
204
|
- app/models/educode_sales/assessments_setting.rb
|
204
205
|
- app/models/educode_sales/assign_follow_up.rb
|
205
206
|
- app/models/educode_sales/assign_staff.rb
|
207
|
+
- app/models/educode_sales/attendance.rb
|
206
208
|
- app/models/educode_sales/business.rb
|
207
209
|
- app/models/educode_sales/business_clazz_change.rb
|
208
210
|
- app/models/educode_sales/business_export_record.rb
|
@@ -275,12 +277,17 @@ files:
|
|
275
277
|
- app/views/educode_sales/activities/show_schools.json.jbuilder
|
276
278
|
- app/views/educode_sales/activities/show_teachers.html.erb
|
277
279
|
- app/views/educode_sales/activities/upload_file.html.erb
|
280
|
+
- app/views/educode_sales/assessments/_attendances.html.erb
|
278
281
|
- app/views/educode_sales/assessments/_finished.html.erb
|
279
282
|
- app/views/educode_sales/assessments/_progress.html.erb
|
280
283
|
- app/views/educode_sales/assessments/_setup.html.erb
|
284
|
+
- app/views/educode_sales/assessments/attendances.js.erb
|
285
|
+
- app/views/educode_sales/assessments/attendances.json.jbuilder
|
281
286
|
- app/views/educode_sales/assessments/edit.html.erb
|
287
|
+
- app/views/educode_sales/assessments/edit_attendance.html.erb
|
282
288
|
- app/views/educode_sales/assessments/finished.json.jbuilder
|
283
289
|
- app/views/educode_sales/assessments/get_export_data.json.jbuilder
|
290
|
+
- app/views/educode_sales/assessments/import.html.erb
|
284
291
|
- app/views/educode_sales/assessments/index.html.erb
|
285
292
|
- app/views/educode_sales/assessments/index.json.jbuilder
|
286
293
|
- app/views/educode_sales/assessments/new.html.erb
|
@@ -727,7 +734,7 @@ homepage: https://www.educoder.net
|
|
727
734
|
licenses:
|
728
735
|
- MIT
|
729
736
|
metadata: {}
|
730
|
-
post_install_message:
|
737
|
+
post_install_message:
|
731
738
|
rdoc_options: []
|
732
739
|
require_paths:
|
733
740
|
- lib
|
@@ -743,7 +750,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
743
750
|
version: '0'
|
744
751
|
requirements: []
|
745
752
|
rubygems_version: 3.0.9
|
746
|
-
signing_key:
|
753
|
+
signing_key:
|
747
754
|
specification_version: 4
|
748
755
|
summary: Summary of EducodeSales.
|
749
756
|
test_files: []
|