educode_sales 0.3.3 → 0.3.7
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 +5 -5
- data/app/controllers/educode_sales/businesses_controller.rb +21 -8
- data/app/controllers/educode_sales/follow_ups_controller.rb +1 -1
- data/app/controllers/educode_sales/key_person_controller.rb +1 -1
- data/app/controllers/educode_sales/plans_controller.rb +1 -1
- data/app/controllers/educode_sales/sale_trends_controller.rb +6 -6
- data/app/controllers/educode_sales/teachers_controller.rb +13 -1
- data/app/models/educode_sales/key_person.rb +1 -1
- data/app/views/educode_sales/activities/edit.html.erb +1 -1
- data/app/views/educode_sales/activities/index.html.erb +6 -7
- data/app/views/educode_sales/activities/new.html.erb +1 -1
- data/app/views/educode_sales/activities/show_teachers.html.erb +12 -12
- data/app/views/educode_sales/businesses/edit.html.erb +15 -4
- data/app/views/educode_sales/businesses/edit_follow_record.html.erb +11 -5
- data/app/views/educode_sales/businesses/edit_plan.html.erb +4 -4
- data/app/views/educode_sales/businesses/index.html.erb +163 -24
- data/app/views/educode_sales/businesses/index.json.jbuilder +1 -0
- data/app/views/educode_sales/businesses/new.html.erb +13 -3
- data/app/views/educode_sales/businesses/new_follow_record.html.erb +11 -5
- data/app/views/educode_sales/businesses/show_follow.html.erb +13 -14
- data/app/views/educode_sales/businesses/show_follow_record.html.erb +1 -1
- data/app/views/educode_sales/businesses/show_keys.html.erb +1 -1
- data/app/views/educode_sales/commons/edit.html.erb +3 -3
- data/app/views/educode_sales/commons/index.html.erb +3 -4
- data/app/views/educode_sales/commons/new.html.erb +1 -1
- data/app/views/educode_sales/follow_ups/teachers.json.jbuilder +3 -2
- data/app/views/educode_sales/operation_plans/_monthPlan.html.erb +7 -7
- data/app/views/educode_sales/operation_plans/_monthly.html.erb +7 -7
- data/app/views/educode_sales/operation_plans/_weekPlan.html.erb +7 -7
- data/app/views/educode_sales/operation_plans/_weekly.html.erb +7 -7
- data/app/views/educode_sales/operation_plans/edit_month.html.erb +1 -1
- data/app/views/educode_sales/operation_plans/edit_week.html.erb +1 -1
- data/app/views/educode_sales/operation_plans/new_month.html.erb +1 -1
- data/app/views/educode_sales/operation_plans/new_monthly.html.erb +7 -7
- data/app/views/educode_sales/operation_plans/new_week.html.erb +1 -1
- data/app/views/educode_sales/operation_plans/new_weekly.html.erb +7 -7
- data/app/views/educode_sales/operation_reports/audit.html.erb +3 -3
- data/app/views/educode_sales/operation_reports/edit.html.erb +7 -7
- data/app/views/educode_sales/operation_reports/show.html.erb +6 -6
- data/app/views/educode_sales/operations/trends.html.erb +2 -2
- data/app/views/educode_sales/places/edit.html.erb +1 -1
- data/app/views/educode_sales/places/index.html.erb +5 -6
- data/app/views/educode_sales/places/index.json.jbuilder +1 -1
- data/app/views/educode_sales/places/new.html.erb +1 -1
- data/app/views/educode_sales/plans/_monthPlan.html.erb +7 -7
- data/app/views/educode_sales/plans/_monthly.html.erb +7 -7
- data/app/views/educode_sales/plans/_weekPlan.html.erb +7 -7
- data/app/views/educode_sales/plans/_weekly.html.erb +7 -7
- data/app/views/educode_sales/plans/edit_month.html.erb +1 -1
- data/app/views/educode_sales/plans/edit_week.html.erb +1 -1
- data/app/views/educode_sales/plans/edit_weekly.html.erb +7 -7
- data/app/views/educode_sales/plans/new_month.html.erb +3 -3
- data/app/views/educode_sales/plans/new_monthly.html.erb +7 -7
- data/app/views/educode_sales/plans/new_week.html.erb +1 -1
- data/app/views/educode_sales/plans/new_weekly.html.erb +7 -7
- data/app/views/educode_sales/roles/edit.html.erb +2 -2
- data/app/views/educode_sales/roles/index.html.erb +5 -6
- data/app/views/educode_sales/roles/new.html.erb +1 -1
- data/app/views/educode_sales/sale_reports/audit.html.erb +3 -3
- data/app/views/educode_sales/sale_reports/edit.html.erb +7 -7
- data/app/views/educode_sales/sale_reports/show.html.erb +2 -2
- data/app/views/educode_sales/sale_trends/trends.html.erb +2 -2
- data/app/views/educode_sales/sales/index.html.erb +3 -4
- data/app/views/educode_sales/sales/index.json.jbuilder +1 -1
- data/app/views/educode_sales/sales/operations.html.erb +3 -4
- data/app/views/educode_sales/sales/school.html.erb +1 -1
- data/app/views/educode_sales/sales/trends.html.erb +2 -2
- data/app/views/educode_sales/sales/xschool.html.erb +1 -1
- data/app/views/educode_sales/sessions/login.html.erb +2 -2
- data/app/views/educode_sales/staffs/edit.html.erb +1 -1
- data/app/views/educode_sales/staffs/index.html.erb +5 -6
- data/app/views/educode_sales/staffs/new.html.erb +2 -2
- data/app/views/educode_sales/teachers/add_courses.html.erb +4 -4
- data/app/views/educode_sales/teachers/add_event.html.erb +1 -1
- data/app/views/educode_sales/teachers/add_keys.html.erb +58 -13
- data/app/views/educode_sales/teachers/edit.html.erb +6 -4
- data/app/views/educode_sales/teachers/edit_follow_record.html.erb +1 -1
- data/app/views/educode_sales/teachers/index.html.erb +130 -34
- data/app/views/educode_sales/teachers/new.html.erb +4 -3
- data/app/views/educode_sales/teachers/new_follow_record.html.erb +1 -1
- data/app/views/educode_sales/teachers/search_new.html.erb +1 -1
- data/app/views/educode_sales/teachers/show_class.html.erb +1 -1
- data/app/views/educode_sales/teachers/show_follow.html.erb +14 -14
- data/app/views/layouts/educode_sales/application.html.erb +14 -14
- data/db/migrate/20211009031109_add_tel_key_peoples.rb +5 -0
- data/db/migrate/20211009063423_add_source_businesses.rb +5 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +9 -8
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: c5f62ecb1fb5d2f9b42761618eae0525dd789bb69fc2522c108749eacfa26f05
|
4
|
+
data.tar.gz: a0ec504c642dfe71bc8bd513140d96bc82b9de444a48945ee245bb812bc4884b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d27c931c74c8ca700c4710d0b3fbd702152adbeb780de114324a07b4bca8de66cbc1b1f13fc82d11d873ec43ae2c8eb83422c98169e47c3c76f997e58c73a83a
|
7
|
+
data.tar.gz: bdd71543da8fc7cf0687374af51870da0c2950ebb10d7db232af4a58b8f26e13c1b31777b95d1c636125a8dbcc17b79317bcdcd682242080d5783604f332d155
|
@@ -9,6 +9,18 @@ module EducodeSales
|
|
9
9
|
format.html do
|
10
10
|
common = Common.find_by(clazz: 'staff_type', name: '销售')
|
11
11
|
@staffs = Staff.joins(:user).where(job_type: common.id).map { |d| [d.user.real_name, d.id]}
|
12
|
+
@more = can?(:create, EducodeSales::SalePlan) || can?(:update, EducodeSales::Business) || can?(:destroy, EducodeSales::Business)
|
13
|
+
gon.menus = []
|
14
|
+
if can?(:create, EducodeSales::SalePlan)
|
15
|
+
gon.menus << { title: '添加周计划', event: 'week' }
|
16
|
+
gon.menus << { title: '添加月计划', event: 'month' }
|
17
|
+
end
|
18
|
+
if can?(:update, EducodeSales::Business)
|
19
|
+
gon.menus << { title: '编辑', event: 'edit' }
|
20
|
+
end
|
21
|
+
if can?(:destroy, EducodeSales::Business)
|
22
|
+
gon.menus << { title: '删除', event: 'delete' }
|
23
|
+
end
|
12
24
|
end
|
13
25
|
format.json do
|
14
26
|
if @current_admin.is_admin?
|
@@ -25,7 +37,7 @@ module EducodeSales
|
|
25
37
|
@businesses = Business
|
26
38
|
end
|
27
39
|
end
|
28
|
-
|
40
|
+
|
29
41
|
@businesses = @businesses
|
30
42
|
if params[:q].present? && params[:q][:name].present?
|
31
43
|
@businesses = @businesses.where("educode_sales_businesses.name like ?", "%#{params[:q][:name]}%")
|
@@ -43,21 +55,22 @@ module EducodeSales
|
|
43
55
|
").where("educode_sales_follow_ups.clazz_id = ?", params[:q][:business_type])
|
44
56
|
end
|
45
57
|
if params[:q].present? && params[:q][:business_step].present?
|
46
|
-
@businesses = @businesses.joins("
|
58
|
+
@businesses = @businesses.joins("
|
47
59
|
JOIN educode_sales_follow_ups ON educode_sales_businesses.last_follow_up_id = educode_sales_follow_ups.id
|
48
60
|
").where("educode_sales_follow_ups.stage_id = ?", params[:q][:business_step])
|
49
61
|
end
|
50
62
|
if params[:q].present? && params[:q][:place_id].present?
|
51
|
-
@businesses = @businesses.joins("
|
63
|
+
@businesses = @businesses.joins("
|
52
64
|
JOIN educode_sales_follow_ups ON educode_sales_businesses.last_follow_up_id = educode_sales_follow_ups.id
|
53
65
|
").where("educode_sales_follow_ups.place_id = ?", params[:q][:place_id])
|
54
66
|
end
|
55
67
|
|
56
68
|
if params[:q].present? && params[:q][:area].present?
|
69
|
+
p = EducodeSales::Common.find(params[:q][:area]).name
|
57
70
|
@businesses = @businesses.joins("
|
58
71
|
JOIN departments ON educode_sales_businesses.department_id = departments.id
|
59
72
|
JOIN schools ON departments.school_id = schools.id
|
60
|
-
").where("province = ?",
|
73
|
+
").where("province = ?", p)
|
61
74
|
end
|
62
75
|
|
63
76
|
if params[:q].present? && params[:q][:date].present?
|
@@ -73,12 +86,12 @@ module EducodeSales
|
|
73
86
|
end
|
74
87
|
|
75
88
|
@business_count = @businesses.count
|
76
|
-
|
89
|
+
|
77
90
|
@businesses = @businesses.select("
|
78
91
|
educode_sales_businesses.*,
|
79
92
|
last_follow.invitation_at,
|
80
93
|
last_follow.reception_at,
|
81
|
-
last_follow.total_amount").joins("
|
94
|
+
last_follow.total_amount").joins("
|
82
95
|
LEFT JOIN educode_sales_follow_ups AS last_follow ON educode_sales_businesses.last_follow_up_id = last_follow.id
|
83
96
|
").page(params[:page]).per(params[:limit])
|
84
97
|
end
|
@@ -87,7 +100,7 @@ module EducodeSales
|
|
87
100
|
|
88
101
|
def create
|
89
102
|
department = Department.find(params[:department_id])
|
90
|
-
business = @current_admin.businesses.build(name: params[:name], department_id: department.id)
|
103
|
+
business = @current_admin.businesses.build(name: params[:name], department_id: department.id, source: params[:source])
|
91
104
|
if business.save
|
92
105
|
render_success
|
93
106
|
else
|
@@ -109,7 +122,7 @@ module EducodeSales
|
|
109
122
|
def update
|
110
123
|
business = Business.find(params[:id])
|
111
124
|
department = Department.find(params[:department_id])
|
112
|
-
if business.update(name: params[:name], department_id: department.id)
|
125
|
+
if business.update(name: params[:name], department_id: department.id, source: params[:source])
|
113
126
|
render_success
|
114
127
|
else
|
115
128
|
render_failure business
|
@@ -151,7 +151,7 @@ module EducodeSales
|
|
151
151
|
end
|
152
152
|
|
153
153
|
def teacher_params
|
154
|
-
params.permit(:professional_title, :job, :attitude_id, :sex, :birth_date, :remark)
|
154
|
+
params.permit(:professional_title, :job, :attitude_id, :sex, :birth_date, :remark, :tel)
|
155
155
|
end
|
156
156
|
end
|
157
157
|
end
|
@@ -59,7 +59,7 @@ module EducodeSales
|
|
59
59
|
def create
|
60
60
|
plan = @current_admin.sale_plans.build(plan_params)
|
61
61
|
plan.month = params["month"] + "-1"
|
62
|
-
plan.
|
62
|
+
plan.business = @current_admin.businesses.find_by(id: params[:business_id])
|
63
63
|
if plan.save
|
64
64
|
render_success
|
65
65
|
else
|
@@ -10,16 +10,16 @@ module EducodeSales
|
|
10
10
|
@years = (1..(Time.now.year - 2020)).map { |d| 2020 + d }
|
11
11
|
year_time = "#{@year}-01-01 00:00:00"
|
12
12
|
@sale_trend = SaleTrend.find_or_create_by(year: @year)
|
13
|
-
@business_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ?", year_time).sum(:total_amount)
|
13
|
+
@business_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ?", year_time).sum(:total_amount).round(2)
|
14
14
|
stage_ids = Common.where(clazz: '商机阶段', name: ['已中标','已签单','已验收','回款中', '服务中','已结束']).pluck(:id)
|
15
|
-
@goal_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.stage_id IN (?)", year_time, stage_ids).sum(:total_amount)
|
15
|
+
@goal_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.stage_id IN (?)", year_time, stage_ids).sum(:total_amount).round(2)
|
16
16
|
s_stage_ids = Common.where(clazz: '商机阶段', name: ['已签单','已验收','回款中', '服务中','已结束']).pluck(:id)
|
17
|
-
@service_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.stage_id IN (?)", year_time, s_stage_ids).sum(:total_amount)
|
18
|
-
@return_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ?", year_time).sum(:return_money)
|
17
|
+
@service_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.stage_id IN (?)", year_time, s_stage_ids).sum(:total_amount).round(2)
|
18
|
+
@return_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ?", year_time).sum(:return_money).round(2)
|
19
19
|
a = Common.where(clazz: '商机类型', name: 'A类').pluck(:id)
|
20
|
-
@a_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.clazz_id IN (?)", year_time, a).sum(:total_amount)
|
20
|
+
@a_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.clazz_id IN (?)", year_time, a).sum(:total_amount).round(2)
|
21
21
|
b = Common.where(clazz: '商机类型', name: 'B类').pluck(:id)
|
22
|
-
@b_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.clazz_id IN (?)", year_time, b).sum(:total_amount)
|
22
|
+
@b_amount = Business.joins(:last_follow_up).where("educode_sales_follow_ups.created_at >= ? AND educode_sales_follow_ups.clazz_id IN (?)", year_time, b).sum(:total_amount).round(2)
|
23
23
|
end
|
24
24
|
|
25
25
|
def sale_trends
|
@@ -21,6 +21,18 @@ module EducodeSales
|
|
21
21
|
def index
|
22
22
|
respond_to do |format|
|
23
23
|
format.html do
|
24
|
+
@more = can?(:create, EducodeSales::OperationPlan) || can?(:update, EducodeSales::Teacher) || can?(:destroy, EducodeSales::Teacher)
|
25
|
+
gon.menus = []
|
26
|
+
if can?(:create, EducodeSales::OperationPlan)
|
27
|
+
gon.menus << { title: '添加周计划', event: 'week' }
|
28
|
+
gon.menus << { title: '添加月计划', event: 'month' }
|
29
|
+
end
|
30
|
+
if can?(:update, EducodeSales::Teacher)
|
31
|
+
gon.menus << { title: '编辑', event: 'edit' }
|
32
|
+
end
|
33
|
+
if can?(:destroy, EducodeSales::Teacher)
|
34
|
+
gon.menus << { title: '删除', event: 'delete' }
|
35
|
+
end
|
24
36
|
end
|
25
37
|
format.json do
|
26
38
|
if @current_admin.is_admin?
|
@@ -59,7 +71,7 @@ module EducodeSales
|
|
59
71
|
@teachers = @teachers.joins(:department).where("departments.id in (?)", departments_ids)
|
60
72
|
end
|
61
73
|
if params[:q].present? && params[:q][:area].present?
|
62
|
-
p = EducodeSales::Common.
|
74
|
+
p = EducodeSales::Common.find(params[:q][:area]).name
|
63
75
|
@teachers = @teachers.joins("
|
64
76
|
JOIN departments ON educode_sales_teachers.department_id = departments.id
|
65
77
|
JOIN schools ON departments.school_id = schools.id
|
@@ -68,7 +68,7 @@
|
|
68
68
|
//监听提交
|
69
69
|
form.on('submit(data-reset-btn)', function (data) {
|
70
70
|
console.log(data.field);
|
71
|
-
request.authPut("
|
71
|
+
request.authPut("missions/activities/" + <%= @activity.id %>, data.field, function (res) {
|
72
72
|
if (res.success === false) {
|
73
73
|
layer.alert(res.msg)
|
74
74
|
} else {
|
@@ -35,7 +35,7 @@
|
|
35
35
|
|
36
36
|
table.render({
|
37
37
|
elem: '#activities_table',
|
38
|
-
url: '/
|
38
|
+
url: '/missions/activities',
|
39
39
|
toolbar: '#activity_toolbar',
|
40
40
|
defaultToolbar: [],
|
41
41
|
cols: [
|
@@ -81,7 +81,6 @@
|
|
81
81
|
}
|
82
82
|
]
|
83
83
|
],
|
84
|
-
height: 700,
|
85
84
|
limit: 20,
|
86
85
|
page: true
|
87
86
|
});
|
@@ -99,7 +98,7 @@
|
|
99
98
|
})
|
100
99
|
table.on('toolbar(activities_table)', function (obj) {
|
101
100
|
if (obj.event === 'add') { // 监听添加操作
|
102
|
-
var content = miniPage.getHrefContent('/
|
101
|
+
var content = miniPage.getHrefContent('/missions/activities/new');
|
103
102
|
var openWH = miniPage.getOpenWidthHeight();
|
104
103
|
index = layer.open({
|
105
104
|
title: '添加活动',
|
@@ -124,7 +123,7 @@
|
|
124
123
|
var data = obj.data;
|
125
124
|
var id = data.id
|
126
125
|
if (obj.event === 'edit') {
|
127
|
-
var content = miniPage.getHrefContent('/
|
126
|
+
var content = miniPage.getHrefContent('/missions/activities/' + id + '/edit');
|
128
127
|
var openWH = miniPage.getOpenWidthHeight();
|
129
128
|
var index = layer.open({
|
130
129
|
title: '编辑',
|
@@ -148,14 +147,14 @@
|
|
148
147
|
return false;
|
149
148
|
} else if (obj.event === 'delete') {
|
150
149
|
layer.confirm('确定删除' + data.name, function (index) {
|
151
|
-
request.delete('
|
150
|
+
request.delete('missions/activities/' + data.id, {}, function (res) {
|
152
151
|
layer.close(index);
|
153
152
|
table.reload("activities_table")
|
154
153
|
})
|
155
154
|
});
|
156
155
|
} else if (obj.event === 'teachers') {
|
157
156
|
activity_id = obj.data.id
|
158
|
-
var content = miniPage.getHrefContent('/
|
157
|
+
var content = miniPage.getHrefContent('/missions/activities/show_teachers');
|
159
158
|
openWH = miniPage.getOpenWidthHeight();
|
160
159
|
index = layer.open({
|
161
160
|
title: '活动列表/' + data.name,
|
@@ -177,7 +176,7 @@
|
|
177
176
|
}
|
178
177
|
else if (obj.event === 'teachers_count') {
|
179
178
|
activity_id = obj.data.id
|
180
|
-
content = miniPage.getHrefContent('/
|
179
|
+
content = miniPage.getHrefContent('/missions/activities/show_teachers');
|
181
180
|
openWH = miniPage.getOpenWidthHeight();
|
182
181
|
index2 = layer.open({
|
183
182
|
title: '活动列表/' + data.name,
|
@@ -69,7 +69,7 @@
|
|
69
69
|
|
70
70
|
//监听提交
|
71
71
|
form.on('submit(data-reset-btn)', function (data) {
|
72
|
-
request.authPost("
|
72
|
+
request.authPost("missions/activities", data.field, function (res) {
|
73
73
|
if (res.success === false) {
|
74
74
|
layer.alert(res.msg)
|
75
75
|
} else {
|
@@ -51,7 +51,7 @@
|
|
51
51
|
table = layui.table;
|
52
52
|
table.render({
|
53
53
|
elem: '#show_teachers_table',
|
54
|
-
url: '/
|
54
|
+
url: '/missions/teachers?activity_id=' + parent.activity_id,
|
55
55
|
toolbar: '#teacher_toolbar',
|
56
56
|
defaultToolbar: [],
|
57
57
|
cols: [
|
@@ -176,7 +176,7 @@
|
|
176
176
|
*/
|
177
177
|
table.on('toolbar(teachers_table)', function (obj) {
|
178
178
|
if (obj.event === 'add') { // 手动添加
|
179
|
-
var content = miniPage.getHrefContent('/
|
179
|
+
var content = miniPage.getHrefContent('/missions/teachers/new');
|
180
180
|
var openWH = miniPage.getOpenWidthHeight();
|
181
181
|
index = layer.open({
|
182
182
|
title: '手动添加',
|
@@ -192,8 +192,8 @@
|
|
192
192
|
layer.full(index);
|
193
193
|
});
|
194
194
|
} else if (obj.event === 'search_new') { // 搜索添加
|
195
|
-
var content = miniPage.getHrefContent('/
|
196
|
-
// var content = miniPage.getHrefContent('/
|
195
|
+
var content = miniPage.getHrefContent('/missions/teachers/new');
|
196
|
+
// var content = miniPage.getHrefContent('/missions/teachers/search_new');
|
197
197
|
var openWH = miniPage.getOpenWidthHeight();
|
198
198
|
activity_id = parent.activity_id;
|
199
199
|
index = layer.open({
|
@@ -221,7 +221,7 @@
|
|
221
221
|
var data = obj.data;
|
222
222
|
id = data.id
|
223
223
|
if (obj.event === 'edit') { //编辑
|
224
|
-
var content = miniPage.getHrefContent('/
|
224
|
+
var content = miniPage.getHrefContent('/missions/teachers/' + id + '/edit');
|
225
225
|
var openWH = miniPage.getOpenWidthHeight();
|
226
226
|
sindex = layer.open({
|
227
227
|
title: '编辑',
|
@@ -245,14 +245,14 @@
|
|
245
245
|
} else if (obj.event === 'delete') {
|
246
246
|
console.log(data);
|
247
247
|
layer.confirm('确定删除' + data.name, function (index) {
|
248
|
-
request.delete('
|
248
|
+
request.delete('missions/teachers/' + data.id, {activity_id: activity_id}, function (res) {
|
249
249
|
layer.close(index);
|
250
250
|
table.reload("activities_table")
|
251
251
|
table.reload("show_teachers_table")
|
252
252
|
})
|
253
253
|
});
|
254
254
|
} else if (obj.event === 'addWeek') {
|
255
|
-
var content = miniPage.getHrefContent('/
|
255
|
+
var content = miniPage.getHrefContent('/missions/operation_plans/new_week');
|
256
256
|
var openWH = miniPage.getOpenWidthHeight();
|
257
257
|
|
258
258
|
sindex = layer.open({
|
@@ -269,7 +269,7 @@
|
|
269
269
|
layer.full(sindex);
|
270
270
|
});
|
271
271
|
} else if (obj.event === 'addMonth') {
|
272
|
-
var content = miniPage.getHrefContent('/
|
272
|
+
var content = miniPage.getHrefContent('/missions/operation_plans/new_month');
|
273
273
|
var openWH = miniPage.getOpenWidthHeight();
|
274
274
|
sindex = layer.open({
|
275
275
|
title: '添加月计划',
|
@@ -287,7 +287,7 @@
|
|
287
287
|
|
288
288
|
} else if (obj.event === 'courses') {
|
289
289
|
teacher_id = data.id
|
290
|
-
content = miniPage.getHrefContent('/
|
290
|
+
content = miniPage.getHrefContent('/missions/teachers/add_courses?id='+data.id);
|
291
291
|
openWH = miniPage.getOpenWidthHeight();
|
292
292
|
index = layer.open({
|
293
293
|
title: '课程方向',
|
@@ -307,7 +307,7 @@
|
|
307
307
|
layer.full(index);
|
308
308
|
});
|
309
309
|
}else if (obj.event === 'event') {
|
310
|
-
content = miniPage.getHrefContent('/
|
310
|
+
content = miniPage.getHrefContent('/missions/teachers/add_event');
|
311
311
|
openWH = miniPage.getOpenWidthHeight();
|
312
312
|
teacher_id = obj.data.id
|
313
313
|
index = layer.open({
|
@@ -324,7 +324,7 @@
|
|
324
324
|
layer.full(index);
|
325
325
|
});
|
326
326
|
} else if (obj.event === 'class') {
|
327
|
-
content = miniPage.getHrefContent('/
|
327
|
+
content = miniPage.getHrefContent('/missions/teachers/show_class');
|
328
328
|
openWH = miniPage.getOpenWidthHeight();
|
329
329
|
user_id = obj.data.user_id
|
330
330
|
index = layer.open({
|
@@ -345,7 +345,7 @@
|
|
345
345
|
layer.full(index);
|
346
346
|
});
|
347
347
|
} else if (obj.event === 'follow') {
|
348
|
-
content = miniPage.getHrefContent('/
|
348
|
+
content = miniPage.getHrefContent('/missions/teachers/show_follow?id=' + data.id);
|
349
349
|
openWH = miniPage.getOpenWidthHeight();
|
350
350
|
index = layer.open({
|
351
351
|
title: '跟进记录',
|
@@ -11,6 +11,14 @@
|
|
11
11
|
<label class="layui-form-label required">单位部门</label>
|
12
12
|
<div class="layui-input-block" id="department" style="width: 300px;"></div>
|
13
13
|
</div>
|
14
|
+
<br>
|
15
|
+
<div class="layui-inline" style="padding-top: 20px">
|
16
|
+
<label class="layui-form-label ">商机来源</label>
|
17
|
+
<input id="source" type="text" name="source" autocomplete="off" class="layui-input" value="<%=@business.source %>" style="width: 300px;" placeholder="请输入商机来源">
|
18
|
+
</div>
|
19
|
+
<div class="layui-inline" style="padding-top: 20px">
|
20
|
+
<p style="padding-left: 40px">请填写提供本商机的人名(如‘张明’);如果为非头歌用户,请增加单位信息(如‘张明,华为公司’)</p>
|
21
|
+
</div>
|
14
22
|
<div class="layui-form-item m-t-20">
|
15
23
|
<div class="layui-input-block">
|
16
24
|
<button class="layui-btn layui-btn-normal" lay-submit lay-filter="edit_business">提交</button>
|
@@ -47,7 +55,7 @@
|
|
47
55
|
department_id = "";
|
48
56
|
return cb([]);
|
49
57
|
}
|
50
|
-
request.get('
|
58
|
+
request.get('missions/search?type=department&q=' + value, {}, function (res) {
|
51
59
|
return cb(res)
|
52
60
|
})
|
53
61
|
}
|
@@ -62,16 +70,19 @@
|
|
62
70
|
layer.alert("请选择单位部门")
|
63
71
|
return false;
|
64
72
|
} else {
|
65
|
-
request.authPut("
|
73
|
+
request.authPut("missions/businesses/" + parent.id, {
|
66
74
|
department_id: department.getValue() || department_id,
|
67
|
-
name: data.field.name
|
75
|
+
name: data.field.name,
|
76
|
+
source: data.field.source
|
68
77
|
}, function (res) {
|
69
78
|
if (res.success == false) {
|
70
79
|
layer.alert(res.msg)
|
71
80
|
} else {
|
72
81
|
layer.close(parent.sindex);
|
73
82
|
parent.layer.close(parent.layer.getFrameIndex(window.name))
|
74
|
-
parent.table.reload('businesses_table')
|
83
|
+
parent.table.reload('businesses_table', {done: function() {
|
84
|
+
parent.drowpdwonRender()
|
85
|
+
}});
|
75
86
|
}
|
76
87
|
})
|
77
88
|
}
|
@@ -16,9 +16,15 @@
|
|
16
16
|
<br>
|
17
17
|
<div class="layui-inline">
|
18
18
|
<label class="layui-form-label required">项目类型</label>
|
19
|
-
|
20
|
-
|
21
|
-
|
19
|
+
<%if EducodeSales::FollowUp.where(business_id: @follow_up.business.id,clazz_id: EducodeSales::Common.find_by(name: "O类").id).count >= 2 %>
|
20
|
+
<div class="layui-input-inline">
|
21
|
+
<%= select_tag "clazz_id", options_for_select([['O类',EducodeSales::Common.find_by(name: "O类").id]]),:disabled => true, class: 'required' %>
|
22
|
+
</div>
|
23
|
+
<%else %>
|
24
|
+
<div class="layui-input-inline">
|
25
|
+
<%= select_tag "clazz_id", options_for_select(@clazz, @follow_up&.clazz_id), class: 'required' %>
|
26
|
+
</div>
|
27
|
+
<%end %>
|
22
28
|
</div>
|
23
29
|
<div class="layui-inline">
|
24
30
|
<label class="layui-form-label required">项目阶段</label>
|
@@ -69,7 +75,7 @@
|
|
69
75
|
<span style="margin-top: 10px; float:left;">%</span>
|
70
76
|
</div>
|
71
77
|
<div class="layui-form-item layui-form-text">
|
72
|
-
<label class="layui-form-label required"
|
78
|
+
<label class="layui-form-label required">商机说明</label>
|
73
79
|
<div class="layui-input-block">
|
74
80
|
<textarea name="description" lay-verify="required" placeholder="此处可以填写:
|
75
81
|
1、有无预算;
|
@@ -120,7 +126,7 @@
|
|
120
126
|
|
121
127
|
form.render();
|
122
128
|
form.on('submit(update_follow_up)', function (data) {
|
123
|
-
request.authPut("
|
129
|
+
request.authPut("missions/follow_ups/<%= @follow_up.id%>", data.field, function (res) {
|
124
130
|
if (res.success == false) {
|
125
131
|
layer.alert(res.msg)
|
126
132
|
} else {
|
@@ -81,7 +81,7 @@
|
|
81
81
|
|
82
82
|
//监听提交
|
83
83
|
form.on('submit(add_return_money)', function (data) {
|
84
|
-
request.authPost("
|
84
|
+
request.authPost("missions/follow_ups/" + parent.follow_up_id + "/add_money", data.field, function (
|
85
85
|
res) {
|
86
86
|
if (res.success == false) {
|
87
87
|
layer.alert(res.msg)
|
@@ -97,7 +97,7 @@
|
|
97
97
|
|
98
98
|
table.render({
|
99
99
|
elem: '#return_money_list',
|
100
|
-
url: '/
|
100
|
+
url: '/missions/follow_ups/' + parent.follow_up_id + '/money_plans',
|
101
101
|
cols: [
|
102
102
|
[{
|
103
103
|
field: 'id',
|
@@ -155,7 +155,7 @@
|
|
155
155
|
data.clazz = clazz ? clazz : obj.data.clazz;
|
156
156
|
data.plan_id = obj.data.id
|
157
157
|
if (obj.event === 'edit') {
|
158
|
-
request.authPut('
|
158
|
+
request.authPut('missions/follow_ups/' + parent.follow_up_id + "/update_money", data,
|
159
159
|
function (res) {
|
160
160
|
if (res.success) {
|
161
161
|
layer.alert('保存成功');
|
@@ -168,7 +168,7 @@
|
|
168
168
|
})
|
169
169
|
} else if (obj.event == 'delete') {
|
170
170
|
layer.confirm('确定删除回款金额为' + data.amount + "的计划", function (index) {
|
171
|
-
request.delete('
|
171
|
+
request.delete('missions/follow_ups/' + parent.follow_up_id + "/delete_money?plan_id=" + data.id, {}, function (res) {
|
172
172
|
layer.close(index);
|
173
173
|
table.reload("return_money_list");
|
174
174
|
table.reload("sale_plan_follow_table");
|