educode_sales 0.6.2 → 0.6.6
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/money_plans.png +0 -0
- data/app/controllers/educode_sales/businesses_controller.rb +26 -6
- data/app/controllers/educode_sales/customers_controller.rb +1 -0
- data/app/controllers/educode_sales/follow_ups_controller.rb +1 -1
- data/app/controllers/educode_sales/money_plans_controller.rb +65 -0
- data/app/controllers/educode_sales/roles_controller.rb +4 -1
- data/app/controllers/educode_sales/sale_trends_controller.rb +40 -12
- data/app/controllers/educode_sales/staffs_controller.rb +3 -4
- data/app/models/educode_sales/permission.rb +2 -1
- data/app/models/educode_sales/role_area.rb +1 -0
- data/app/views/educode_sales/businesses/_follows.html.erb +15 -15
- data/app/views/educode_sales/businesses/edit.html.erb +3 -0
- data/app/views/educode_sales/businesses/edit_follow_record.html.erb +12 -3
- data/app/views/educode_sales/businesses/file.html.erb +8 -4
- data/app/views/educode_sales/businesses/index.html.erb +57 -11
- data/app/views/educode_sales/businesses/index.json.jbuilder +3 -2
- data/app/views/educode_sales/businesses/new_follow_record.html.erb +6 -2
- data/app/views/educode_sales/businesses/show_follow.html.erb +1 -0
- data/app/views/educode_sales/customers/edit.html.erb +695 -16
- data/app/views/educode_sales/customers/edit_follow_record.html.erb +1 -1
- data/app/views/educode_sales/customers/index.html.erb +6 -7
- data/app/views/educode_sales/customers/index.json.jbuilder +2 -1
- data/app/views/educode_sales/customers/new.html.erb +696 -17
- data/app/views/educode_sales/customers/new_follow_record.html.erb +1 -1
- data/app/views/educode_sales/customers/show_follow.html.erb +1 -1
- data/app/views/educode_sales/money_plans/index.html.erb +222 -0
- data/app/views/educode_sales/money_plans/index.json.jbuilder +21 -0
- data/app/views/educode_sales/places/index.html.erb +16 -2
- data/app/views/educode_sales/places/index.json.jbuilder +3 -1
- data/app/views/educode_sales/plans/_monthPlan.html.erb +2 -1
- data/app/views/educode_sales/plans/_weekPlan.html.erb +2 -1
- data/app/views/educode_sales/recycles/business.json.jbuilder +2 -2
- data/app/views/educode_sales/roles/edit.html.erb +8 -0
- data/app/views/educode_sales/sale_trends/trends.html.erb +73 -13
- data/app/views/educode_sales/sale_trends/trends.json.jbuilder +3 -14
- data/app/views/educode_sales/sales/index.html.erb +18 -16
- data/app/views/educode_sales/sales/index.json.jbuilder +4 -4
- data/app/views/educode_sales/sales/operations.json.jbuilder +2 -2
- data/app/views/educode_sales/teachers/index.html.erb +15 -7
- data/app/views/layouts/educode_sales/application.html.erb +18 -2
- data/config/routes.rb +2 -0
- data/db/migrate/20210902064109_create_educode_sales_role_permissions.rb +8 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +6 -2
@@ -19,44 +19,44 @@
|
|
19
19
|
<%= select_tag "professional_title", options_for_select(['教授', '研究员', '副教授', '副研究员', '讲师', '助理研究员', '助理教授'], @person&.professional_title), { include_blank: true } %>
|
20
20
|
</div>
|
21
21
|
</div>
|
22
|
-
<div class="layui-inline">
|
22
|
+
<div class="layui-inline show_item" style="display:none;">
|
23
23
|
<label class="layui-form-label">导流来源</label>
|
24
24
|
<div class="layui-input-inline">
|
25
25
|
<%= select_tag "teacher_source", options_for_select(EducodeSales::Common.where(clazz: 'teacher_source').pluck(:name, :id)), { include_blank: true } %>
|
26
26
|
</div>
|
27
27
|
</div>
|
28
|
-
<div class="layui-inline">
|
28
|
+
<div class="layui-inline show_item" style="display:none;">
|
29
29
|
<label class="layui-form-label">态度</label>
|
30
30
|
<div class="layui-input-inline">
|
31
31
|
|
32
32
|
<%= select_tag "attitude", options_for_select(EducodeSales::Common.where(clazz: 'teacher_attitude').pluck(:name, :id)), { include_blank: true } %>
|
33
33
|
</div>
|
34
34
|
</div>
|
35
|
-
<div class="layui-inline">
|
35
|
+
<div class="layui-inline show_item" style="display:none;">
|
36
36
|
<label class="layui-form-label">注册时间</label>
|
37
37
|
<div class="layui-input-inline">
|
38
38
|
<input type="text" class="layui-input" id="time" placeholder="请选择时间" autocomplete="off" name="regist_at">
|
39
39
|
</div>
|
40
40
|
</div>
|
41
|
-
<div class="layui-inline">
|
41
|
+
<div class="layui-inline show_item" style="display:none;">
|
42
42
|
<label class="layui-form-label">注册状态</label>
|
43
43
|
<div class="layui-input-inline">
|
44
44
|
<%= select_tag "status", options_for_select([["已注册","1"],["未注册","0"]]), { include_blank: true } %>
|
45
45
|
</div>
|
46
46
|
</div>
|
47
|
-
<div class="layui-inline">
|
47
|
+
<div class="layui-inline show_item" style="display:none;">
|
48
48
|
<label class="layui-form-label">区域</label>
|
49
49
|
<div class="layui-input-inline">
|
50
50
|
<%= select_tag "area", options_for_select(EducodeSales::Common.where(clazz: 'area').pluck(:name, :id)), { include_blank: true } %>
|
51
51
|
</div>
|
52
52
|
</div>
|
53
|
-
<div class="layui-inline">
|
53
|
+
<div class="layui-inline show_item" style="display:none;">
|
54
54
|
<label class="layui-form-label">起止时间</label>
|
55
55
|
<div class="layui-input-inline">
|
56
56
|
<input type="text" class="layui-input" id="date" name="date" autocomplete="off" placeholder=" - ">
|
57
57
|
</div>
|
58
58
|
</div>
|
59
|
-
<div class="layui-inline">
|
59
|
+
<div class="layui-inline show_item" style="display:none;">
|
60
60
|
<label class="layui-form-label">教研助理</label>
|
61
61
|
<div class="layui-input-inline">
|
62
62
|
<%= select_tag "assist", options_for_select(@staffs, params[:assist]), { 'lay-filter': 'assist', include_blank: true } %>
|
@@ -68,6 +68,8 @@
|
|
68
68
|
</button>
|
69
69
|
<button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="search_teachers">搜 索
|
70
70
|
</button>
|
71
|
+
<a style="padding-left: 20px;color: #0000FF" href="javascript:;" type="submit" class="" lay-submit lay-filter="show_hide">展开/收起
|
72
|
+
</a>
|
71
73
|
</div>
|
72
74
|
</div>
|
73
75
|
</form>
|
@@ -150,12 +152,14 @@
|
|
150
152
|
width: 60,
|
151
153
|
title:'序号',type: 'numbers',
|
152
154
|
totalRowText:'合计',
|
155
|
+
fixed: 'left'
|
153
156
|
|
154
157
|
},
|
155
158
|
{
|
156
159
|
field: 'name',
|
157
160
|
width: 80,
|
158
161
|
title: '姓名',
|
162
|
+
fixed: 'left',
|
159
163
|
templet: "#name"
|
160
164
|
},
|
161
165
|
{
|
@@ -409,6 +413,10 @@
|
|
409
413
|
})
|
410
414
|
return false;
|
411
415
|
});
|
416
|
+
form.on('submit(show_hide)', function (data) {
|
417
|
+
$(".show_item").toggle()
|
418
|
+
return false;
|
419
|
+
});
|
412
420
|
/**
|
413
421
|
* toolbar事件监听
|
414
422
|
*/
|
@@ -9,12 +9,15 @@
|
|
9
9
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no"/>
|
10
10
|
<%= stylesheet_link_tag "educode_sales/application", media: "all" %>
|
11
11
|
<%= javascript_include_tag "educode_sales/application" %>
|
12
|
+
<script src="https://cdn.jsdelivr.net/npm/cxselect@1.4.0/js/jquery.cxselect.js"></script>
|
13
|
+
<script src="https://cdn.jsdelivr.net/npm/cxselect@1.4.0/js/jquery.cxselect.min.js"></script>
|
14
|
+
<script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.js"></script>
|
12
15
|
</head>
|
13
16
|
<body class="" id="body">
|
14
17
|
<div class="layui-layout layui-layout-admin " >
|
15
18
|
<div class="layui-header">
|
16
19
|
<a href="/missions">
|
17
|
-
<div class="layui-
|
20
|
+
<div class="layui-bg-black layuimini-logo layui-logo" id="head_a">
|
18
21
|
<%= image_tag "educode_sales/logo.png", class: 'header-logo' %>
|
19
22
|
<span class="app-title">营销系统</span>
|
20
23
|
</div>
|
@@ -22,6 +25,7 @@
|
|
22
25
|
|
23
26
|
|
24
27
|
<ul class="layui-nav i_class" style="left: 200px">
|
28
|
+
<%= image_tag "educode_sales/logo.png", class: 'header-logo tubiao layui-hide-sm layui-hide-xs' %>
|
25
29
|
<li class="layui-nav-item layui-show-xs-inline-block " lay-header-event="menuLeft">
|
26
30
|
<a href="javascript:;"> <i id="leftEnumIcon" class="layui-icon layui-icon-shrink-right"></i></a>
|
27
31
|
</li>
|
@@ -45,7 +49,7 @@
|
|
45
49
|
</ul>
|
46
50
|
</div>
|
47
51
|
|
48
|
-
<div class="layui-side layui-bg-black">
|
52
|
+
<div class="layui-side layui-bg-black" id="head_b">
|
49
53
|
<div class="layui-side-scroll ">
|
50
54
|
<!-- 左侧导航区域(可配合layui已有的垂直导航) -->
|
51
55
|
<ul class="layui-nav layui-nav-tree ul"
|
@@ -66,6 +70,10 @@
|
|
66
70
|
<dd><a href="/missions/businesses" class="<%= current?('layui-this', businesses_path) %>"><i style="padding-right: 35px"></i><%= image_tag "educode_sales/4.商机管理.png",size:"15"%><i style="font-size: 25px; padding-right: 15px"></i>商机管理</a>
|
67
71
|
</dd>
|
68
72
|
<% end %>
|
73
|
+
<% if can? :read, EducodeSales::MoneyPlan %>
|
74
|
+
<dd><a href="/missions/money_plans" class="<%= current?('layui-this', money_plans_path) %>"><i style="padding-right: 35px"></i><%= image_tag "educode_sales/money_plans.png",size:"15"%><i style="font-size: 25px; padding-right: 15px"></i>回款管理</a>
|
75
|
+
</dd>
|
76
|
+
<% end %>
|
69
77
|
<% if can? :read, EducodeSales::Customer %>
|
70
78
|
<dd><a href="/missions/customers" class="<%= current?('layui-this', customers_path) %>"><i style="padding-right: 35px"></i><%= image_tag "educode_sales/客户管理.png",size:"15"%><i style="font-size: 25px; padding-right: 15px"></i>客户管理</a>
|
71
79
|
</dd>
|
@@ -205,6 +213,10 @@
|
|
205
213
|
$(".i_class").animate({left: '200px'},"fast");
|
206
214
|
$(".layui-nav-item").addClass('layui-nav-itemed')
|
207
215
|
$("#logout").removeClass('layui-nav-itemed')
|
216
|
+
$("#head_b").removeClass('layui-hide-xs')
|
217
|
+
$("#head_a").removeClass('layui-hide-xs')
|
218
|
+
$(".tubiao").addClass('layui-hide')
|
219
|
+
$(".tubiao").addClass('layui-hide-xs')
|
208
220
|
}
|
209
221
|
|
210
222
|
function menuHide(btn) {
|
@@ -212,6 +224,10 @@
|
|
212
224
|
btn.removeClass('layui-icon-shrink-right').addClass('layui-icon-spread-left');
|
213
225
|
body.addClass('layuimini-mini');
|
214
226
|
$(".i_class").animate({left: '60px'});
|
227
|
+
$("#head_b").addClass('layui-hide-xs')
|
228
|
+
$("#head_a").addClass('layui-hide-xs')
|
229
|
+
$(".tubiao").removeClass('layui-hide')
|
230
|
+
$(".tubiao").removeClass('layui-hide-xs')
|
215
231
|
}
|
216
232
|
}
|
217
233
|
});
|
data/config/routes.rb
CHANGED
@@ -8,6 +8,14 @@ class CreateEducodeSalesRolePermissions < ActiveRecord::Migration[5.2]
|
|
8
8
|
end
|
9
9
|
if EducodeSales::Permission.last.nil?
|
10
10
|
|
11
|
+
#附件管理权限
|
12
|
+
EducodeSales::Permission.create(name: '查看附件', subject: 'Business', action: 'show_file', clazz: 'business', position: '11')
|
13
|
+
EducodeSales::Permission.create(name: '上传附件', subject: 'Business', action: 'upload_file', clazz: 'business', position: '11')
|
14
|
+
EducodeSales::Permission.create(name: '下载附件', subject: 'Business', action: 'download_file', clazz: 'business', position: '11')
|
15
|
+
EducodeSales::Permission.create(name: '删除附件', subject: 'Business', action: 'delete_file', clazz: 'business', position: '11')
|
16
|
+
#回款管理权限
|
17
|
+
EducodeSales::Permission.create(name: '查看回款列表', subject: 'MoneyPlan', action: 'read', clazz: 'money_plan', position: '15')
|
18
|
+
|
11
19
|
#客户管理权限
|
12
20
|
EducodeSales::Permission.create(name: '查看客户', subject: 'Customer', action: 'read', clazz: 'customer')
|
13
21
|
EducodeSales::Permission.create(name: '添加客户', subject: 'Customer', action: 'create', clazz: 'customer')
|
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.6.
|
4
|
+
version: 0.6.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- anke1460
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-01-14 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -109,6 +109,7 @@ files:
|
|
109
109
|
- app/assets/images/educode_sales/loading-2.gif
|
110
110
|
- app/assets/images/educode_sales/loginbg.png
|
111
111
|
- app/assets/images/educode_sales/logo.png
|
112
|
+
- app/assets/images/educode_sales/money_plans.png
|
112
113
|
- app/assets/images/educode_sales/回收站.png
|
113
114
|
- app/assets/images/educode_sales/客户管理.png
|
114
115
|
- app/assets/javascripts/educode_sales/application.js
|
@@ -145,6 +146,7 @@ files:
|
|
145
146
|
- app/controllers/educode_sales/home_controller.rb
|
146
147
|
- app/controllers/educode_sales/import_teachers_controller.rb
|
147
148
|
- app/controllers/educode_sales/key_person_controller.rb
|
149
|
+
- app/controllers/educode_sales/money_plans_controller.rb
|
148
150
|
- app/controllers/educode_sales/operation_plans_controller.rb
|
149
151
|
- app/controllers/educode_sales/operation_reports_controller.rb
|
150
152
|
- app/controllers/educode_sales/operations_controller.rb
|
@@ -253,6 +255,8 @@ files:
|
|
253
255
|
- app/views/educode_sales/home/search_teacher.json.jbuilder
|
254
256
|
- app/views/educode_sales/home/search_users.json.jbuilder
|
255
257
|
- app/views/educode_sales/home/statistics.html.erb
|
258
|
+
- app/views/educode_sales/money_plans/index.html.erb
|
259
|
+
- app/views/educode_sales/money_plans/index.json.jbuilder
|
256
260
|
- app/views/educode_sales/operation_plans/_monthPlan.html.erb
|
257
261
|
- app/views/educode_sales/operation_plans/_monthly.html.erb
|
258
262
|
- app/views/educode_sales/operation_plans/_weekPlan.html.erb
|