educode_sales 0.9.47 → 0.9.49

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.
Files changed (76) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/images/educode_sales/indexlogo.png +0 -0
  3. data/app/controllers/educode_sales/idea_recycles_controller.rb +100 -0
  4. data/app/controllers/educode_sales/ideas_controller.rb +130 -0
  5. data/app/controllers/educode_sales/logs_controller.rb +21 -0
  6. data/app/controllers/educode_sales/teacher_follows_controller.rb +82 -2
  7. data/app/controllers/educode_sales/teachers_controller.rb +18 -3
  8. data/app/models/educode_sales/common.rb +2 -0
  9. data/app/models/educode_sales/idea.rb +87 -0
  10. data/app/models/educode_sales/idea_history.rb +8 -0
  11. data/app/views/educode_sales/businesses/get_export_data.json.jbuilder +18 -13
  12. data/app/views/educode_sales/businesses/index.json.jbuilder +4 -4
  13. data/app/views/educode_sales/idea_recycles/activities.json.jbuilder +9 -0
  14. data/app/views/educode_sales/idea_recycles/add_courses.html.erb +133 -0
  15. data/app/views/educode_sales/idea_recycles/add_event.html.erb +49 -0
  16. data/app/views/educode_sales/idea_recycles/add_keys.html.erb +334 -0
  17. data/app/views/educode_sales/idea_recycles/course_list.json.jbuilder +23 -0
  18. data/app/views/educode_sales/idea_recycles/course_subject.json.jbuilder +10 -0
  19. data/app/views/educode_sales/idea_recycles/daily_paper.html.erb +68 -0
  20. data/app/views/educode_sales/idea_recycles/detail.html.erb +144 -0
  21. data/app/views/educode_sales/idea_recycles/edit.html.erb +193 -0
  22. data/app/views/educode_sales/idea_recycles/edit_follow_record.html.erb +87 -0
  23. data/app/views/educode_sales/idea_recycles/history.html.erb +41 -0
  24. data/app/views/educode_sales/idea_recycles/import.html.erb +41 -0
  25. data/app/views/educode_sales/idea_recycles/index.html.erb +321 -0
  26. data/app/views/educode_sales/idea_recycles/index.json.jbuilder +16 -0
  27. data/app/views/educode_sales/idea_recycles/new.html.erb +204 -0
  28. data/app/views/educode_sales/idea_recycles/new_follow_record.html.erb +93 -0
  29. data/app/views/educode_sales/idea_recycles/search_new.html.erb +138 -0
  30. data/app/views/educode_sales/idea_recycles/show_class.html.erb +107 -0
  31. data/app/views/educode_sales/idea_recycles/show_follow.html.erb +504 -0
  32. data/app/views/educode_sales/idea_recycles/show_follow.json.jbuilder +23 -0
  33. data/app/views/educode_sales/idea_recycles/show_follow_record.html.erb +36 -0
  34. data/app/views/educode_sales/idea_recycles/unfinish_plans.json.jbuilder +14 -0
  35. data/app/views/educode_sales/ideas/activities.json.jbuilder +9 -0
  36. data/app/views/educode_sales/ideas/add_courses.html.erb +133 -0
  37. data/app/views/educode_sales/ideas/add_event.html.erb +49 -0
  38. data/app/views/educode_sales/ideas/add_keys.html.erb +334 -0
  39. data/app/views/educode_sales/ideas/course_list.json.jbuilder +23 -0
  40. data/app/views/educode_sales/ideas/course_subject.json.jbuilder +10 -0
  41. data/app/views/educode_sales/ideas/daily_paper.html.erb +68 -0
  42. data/app/views/educode_sales/ideas/detail.html.erb +144 -0
  43. data/app/views/educode_sales/ideas/edit.html.erb +182 -0
  44. data/app/views/educode_sales/ideas/edit_follow_record.html.erb +87 -0
  45. data/app/views/educode_sales/ideas/history.html.erb +41 -0
  46. data/app/views/educode_sales/ideas/import.html.erb +41 -0
  47. data/app/views/educode_sales/ideas/index.html.erb +335 -0
  48. data/app/views/educode_sales/ideas/index.json.jbuilder +16 -0
  49. data/app/views/educode_sales/ideas/new.html.erb +182 -0
  50. data/app/views/educode_sales/ideas/new_follow_record.html.erb +93 -0
  51. data/app/views/educode_sales/ideas/search_new.html.erb +138 -0
  52. data/app/views/educode_sales/ideas/show_class.html.erb +107 -0
  53. data/app/views/educode_sales/ideas/show_follow.html.erb +504 -0
  54. data/app/views/educode_sales/ideas/show_follow.json.jbuilder +23 -0
  55. data/app/views/educode_sales/ideas/show_follow_record.html.erb +36 -0
  56. data/app/views/educode_sales/ideas/unfinish_plans.json.jbuilder +14 -0
  57. data/app/views/educode_sales/logs/index.html.erb +48 -0
  58. data/app/views/educode_sales/logs/index.json.jbuilder +16 -0
  59. data/app/views/educode_sales/staffs/edit.html.erb +0 -1
  60. data/app/views/educode_sales/teacher_follows/index.json.jbuilder +20 -0
  61. data/app/views/educode_sales/teachers/_follows.html.erb +256 -0
  62. data/app/views/educode_sales/teachers/_index.html.erb +677 -0
  63. data/app/views/educode_sales/teachers/daily_paper.html.erb +22 -22
  64. data/app/views/educode_sales/teachers/index.html.erb +11 -651
  65. data/app/views/educode_sales/teachers/index.json.jbuilder +10 -0
  66. data/app/views/educode_sales/teachers/new.html.erb +9 -3
  67. data/app/views/educode_sales/teachers/new_follow_record.html.erb +6 -0
  68. data/app/views/layouts/educode_sales/application.html.erb +36 -7
  69. data/config/routes.rb +19 -0
  70. data/db/migrate/20230227061043_create_educode_sales_ideas.rb +28 -0
  71. data/db/migrate/20230227070206_change_to_educode_sales_ideas.rb +5 -0
  72. data/db/migrate/20230227125936_add_follow_at_to_teachers.rb +6 -0
  73. data/db/migrate/20230228063555_create_educode_sales_idea_histories.rb +10 -0
  74. data/db/migrate/20230302074324_change_manager_for_ideas.rb +6 -0
  75. data/lib/educode_sales/version.rb +1 -1
  76. metadata +66 -6
@@ -0,0 +1,321 @@
1
+ <div style="margin: 10px 10px 10px 10px">
2
+ <form class="layui-form layui-form-pane" lay-filter="search_idea_recycles">
3
+ <div class="layui-form-item">
4
+ <div class="layui-inline ">
5
+ <label class="layui-form-label">创建时间</label>
6
+ <div class="layui-input-inline">
7
+ <input type="text" class="layui-input" id="created_at" name="created_at" placeholder=" - " autocomplete="off">
8
+ </div>
9
+ </div>
10
+ <div class="layui-inline">
11
+ <label class="layui-form-label">发布人</label>
12
+ <div class="layui-input-inline">
13
+ <%= select_tag "creator_id", options_for_select(@creator_arr, ""), { include_blank: true } %>
14
+ </div>
15
+ </div>
16
+ <div class="layui-inline">
17
+ <label class="layui-form-label">指派人</label>
18
+ <div class="layui-input-inline">
19
+ <%= select_tag "staff_id", options_for_select(@staff_arr, ""), { include_blank: true } %>
20
+ </div>
21
+ </div>
22
+ <div class="layui-inline">
23
+ <label class="layui-form-label">状态</label>
24
+ <div class="layui-input-inline">
25
+ <%= select_tag "status", options_for_select(EducodeSales::Idea.statuses.keys, ""), { include_blank: true } %>
26
+ </div>
27
+ </div>
28
+ <div class="layui-inline">
29
+ <label class="layui-form-label">类型</label>
30
+ <div class="layui-input-inline">
31
+ <%= select_tag "types", options_for_select(EducodeSales::Idea.types.keys, ""), { include_blank: true } %>
32
+ </div>
33
+ </div>
34
+ <div class="layui-inline">
35
+ <label class="layui-form-label">部署模式</label>
36
+ <div class="layui-input-inline">
37
+ <%= select_tag "model", options_for_select(EducodeSales::Idea.models.keys, ""), { include_blank: true } %>
38
+ </div>
39
+ </div>
40
+ <div class="layui-inline">
41
+ <label class="layui-form-label">历史合作</label>
42
+ <div class="layui-input-inline">
43
+ <%= select_tag "history_type", options_for_select([["无", 0], ["有", 1]], ""), { include_blank: true } %>
44
+ </div>
45
+ </div>
46
+ <div class="layui-inline">
47
+ <label class="layui-form-label">优先级</label>
48
+ <div class="layui-input-inline">
49
+ <%= select_tag "level", options_for_select(EducodeSales::Idea.levels.keys, ""), { include_blank: true } %>
50
+ </div>
51
+ </div>
52
+ <div class="layui-inline">
53
+ <label class="layui-form-label">项目名称</label>
54
+ <div class="layui-input-inline">
55
+ <input type="text" class="layui-input" id="name" name="name" placeholder=" - " autocomplete="off">
56
+ </div>
57
+ </div>
58
+ <div class="layui-inline">
59
+ <label class="layui-form-label">学校/单位</label>
60
+ <div class="layui-input-inline">
61
+ <input type="text" class="layui-input" id="school" name="school" placeholder=" - " autocomplete="off">
62
+ </div>
63
+ </div>
64
+
65
+ <div class="layui-inline">
66
+ <button type="reset" class="layui-btn layui-btn-primary" lay-submit lay-filter="reset_business_search">重置
67
+ </button>
68
+ <button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="search_idea_recycles">搜 索
69
+ </button>
70
+ </div>
71
+ </div>
72
+ </form>
73
+ </div>
74
+
75
+ <script type="text/html" id="toolbarDemo">
76
+ <div class="layui-btn-container">
77
+ <span class="table-label">回收站</span>
78
+ </div>
79
+ </script>
80
+ <div class="">
81
+ <table class="layui-hide" id="idea_recycles_table" style="min-height: 300px;" lay-filter="idea_recycles_table"></table>
82
+ </div>
83
+ <script type="text/html" id="currentTableBar">
84
+ <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edita" lay-event="add_event">详情</a>
85
+ <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="idea_recycle">恢复</a>
86
+ </script>
87
+ <script>
88
+ layui.use(['form', 'table', 'miniPage', 'element', 'request', 'laydate'], function () {
89
+ var $ = layui.jquery,
90
+ form = layui.form,
91
+ request = layui.request,
92
+ dropdown = layui.dropdown,
93
+ miniPage = layui.miniPage,
94
+ laydate = layui.laydate;
95
+
96
+ var laydate = layui.laydate;
97
+
98
+ laydate.render({
99
+ elem: '#created_at',
100
+ range: true
101
+ });
102
+
103
+ table = layui.table;
104
+ table.render({
105
+ elem: '#idea_recycles_table',
106
+ url: '/missions/idea_recycles',
107
+ where: {q: form.val('search_form')},
108
+ toolbar: '#toolbarDemo',
109
+ totalRow: true,
110
+ defaultToolbar: ['filter'],
111
+ cols: [
112
+ [
113
+ {
114
+ field: 'school',
115
+ width: 160,
116
+ title: '学校/单位名称'
117
+ },
118
+ {
119
+ field: 'name',
120
+ width: 160,
121
+ title: '项目名称'
122
+ },
123
+ {
124
+ field: 'level',
125
+ width: 100,
126
+ title: '优先级'
127
+ },
128
+ {
129
+ field: 'staff',
130
+ title: '指派人',
131
+ width: 100
132
+ },
133
+ {
134
+ field: 'status',
135
+ width: 100,
136
+ title: '状态'
137
+ },
138
+ {
139
+ field: 'types',
140
+ width: 100,
141
+ title: '类型',
142
+ },
143
+ {
144
+ field: 'model',
145
+ width: 100,
146
+ title: '部署模式',
147
+ },
148
+ {
149
+ field: 'hardware',
150
+ width: 100,
151
+ title: '硬件规模(万)'
152
+ },
153
+ {
154
+ field: 'project',
155
+ width: 100,
156
+ title: '项目规模(人)'
157
+ },
158
+ {
159
+ field: 'money',
160
+ width: 100,
161
+ title: '项目预算(万)'
162
+ },
163
+ {
164
+ field: 'creator',
165
+ width: 100,
166
+ title: '发布人'
167
+ },
168
+ {
169
+ field: 'end_time',
170
+ width: 200,
171
+ title: '截止时间'
172
+ },
173
+ {
174
+ field: 'history_type',
175
+ width: 150,
176
+ title: '历史合作'
177
+ },
178
+ {
179
+ field: 'content',
180
+ width: 200,
181
+ title: '反馈情况'
182
+ },
183
+ {
184
+ field: 'deleter',
185
+ width: 100,
186
+ title: '删除人'
187
+ },
188
+ {
189
+ title: '操作',
190
+ minWidth: 170,
191
+ toolbar: '#currentTableBar',
192
+ align: "center",
193
+ fixed: 'right'
194
+ }
195
+ ]
196
+ ],
197
+ limit: 20,
198
+ limits: [10, 15, 20, 30, 40, 50, 60, 70, 80, 90],
199
+ page: true,
200
+ done: function (res) {
201
+ }
202
+ });
203
+
204
+ function deleteBusiness(id, name) {
205
+ layer.confirm('确定删除' + name, function (index) {
206
+ request.delete('missions/idea_recycles/' + id, {}, function (res) {
207
+ layer.close(index);
208
+ table.reload("idea_recycles_table")
209
+ })
210
+ });
211
+ }
212
+
213
+ var sort = {}, search = {};
214
+ table.on('sort(idea_recycles_table)', function (obj) {
215
+ sort.field = obj.field;
216
+ sort.order = obj.type;
217
+ table.reload('idea_recycles_table', {
218
+ initSort: obj,
219
+ where: {
220
+ sort: sort,
221
+ q: search
222
+ }
223
+ });
224
+ })
225
+
226
+ // 监听搜索操作
227
+ form.on('submit(search_idea_recycles)', function (data) {
228
+ search = data.field
229
+ table.reload('idea_recycles_table', {
230
+ page: {
231
+ curr: 1
232
+ },
233
+ where: {q: search, sort: sort}
234
+ }, 'data');
235
+ return false;
236
+ });
237
+
238
+ form.on('submit(reset_business_search)', function (data) {
239
+ var field = data.field;
240
+ form.val('search_idea_recycles', {
241
+ created_at: "",
242
+ creator_id: "",
243
+ staff_id: "",
244
+ name: "",
245
+ school: "",
246
+ status: "",
247
+ model: "",
248
+ types: "",
249
+ level: "",
250
+ history_type: ""
251
+ })
252
+ return false;
253
+ });
254
+ // form.on('submit(show_hide)', function (data) {
255
+ // $(".show_item").toggle()
256
+ // return false;
257
+ // });
258
+ /**
259
+ * toolbar事件监听
260
+ */
261
+ table.on('toolbar(idea_recycles_table)', function (obj) {
262
+ if (obj.event === 'add') { // 手动添加
263
+ var content = miniPage.getHrefContent('/missions/idea_recycles/new');
264
+ var openWH = miniPage.getOpenWidthHeight();
265
+ index = layer.open({
266
+ title: '添加老师',
267
+ type: 1,
268
+ shade: 0.2,
269
+ maxmin: true,
270
+ shadeClose: true,
271
+ area: [openWH[0] + 'px', openWH[1] + 'px'],
272
+ offset: [openWH[2] + 'px', openWH[3] + 'px'],
273
+ content: content,
274
+ });
275
+ $(window).on("resize", function () {
276
+ layer.full(index);
277
+ });
278
+ }
279
+ });
280
+
281
+ //监听表格复选框选择
282
+ // table.on('checkbox(idea_recycles_table)', function (obj) {
283
+ // console.log(obj)
284
+ // });
285
+
286
+ table.on('tool(idea_recycles_table)', function (obj) {
287
+ var data = obj.data;
288
+ id = data.id
289
+ if (obj.event === 'add_event') { // 监听添加操作
290
+ var content = miniPage.getHrefContent('/missions/idea_recycles/detail?id=' + data.id);
291
+ var openWH = miniPage.getOpenWidthHeight();
292
+ show_index = layer.open({
293
+ title: '详情',
294
+ type: 1,
295
+ shade: 0.2,
296
+ maxmin: true,
297
+ shadeClose: true,
298
+ area: [openWH[0] + 'px', openWH[1] + 'px'],
299
+ offset: [openWH[2] + 'px', openWH[3] + 'px'],
300
+ content: content
301
+ });
302
+ $(window).on("resize", function () {
303
+ layer.full(index);
304
+ });
305
+ } else if (obj.event === 'idea_recycle') {
306
+ layer.confirm('确定恢复' + data.name, function (index) {
307
+ request.delete('missions/idea_recycles/' + id, {}, function (res) {
308
+ layer.close(index);
309
+ table.reload("idea_recycles_table")
310
+ })
311
+ });
312
+ }
313
+ });
314
+
315
+ });
316
+ </script>
317
+ <style>
318
+ .layui-table-tool-temp{
319
+ padding-right: 30px; !important;
320
+ }
321
+ </style>
@@ -0,0 +1,16 @@
1
+ json.data do
2
+ json.array! @ideas do |d|
3
+ json.(d, :id, :name, :level, :status, :types, :model, :content)
4
+ json.school d.school&.name
5
+ json.staff d.staff&.user&.real_name
6
+ json.hardware d.hardware.to_f.round(2)
7
+ json.project d.project.to_i
8
+ json.money d.money.to_f.round(2)
9
+ json.end_time d.end_time.to_s
10
+ json.creator d.creator&.user&.real_name
11
+ json.deleter d.deleter&.user&.real_name
12
+ json.history_type d.history_type.to_i == 0 ? "无" : "有"
13
+ end
14
+ end
15
+ json.code 0
16
+ json.count @ideas.total_count
@@ -0,0 +1,204 @@
1
+ <div class="layui-form layuimini-form">
2
+ <div class="layui-form-item" style="padding: 25px">
3
+ <div class="layui-block">
4
+ <div class="layui-inline">
5
+ <label class="layui-form-label required">姓名</label>
6
+ <div class="layui-input-block" id="add_teacher" style="width: 400px"></div>
7
+ </div>
8
+ </div>
9
+ <div class="layui-block">
10
+ <div class="layui-inline">
11
+ <label class="layui-form-label required">单位/部门</label>
12
+ <div class="layui-input-block" id="add_department" style="width: 400px"></div>
13
+ </div>
14
+ </div>
15
+ <div class="layui-block">
16
+ <div class="layui-inline">
17
+ <label class="layui-form-label ">职称</label>
18
+ <div class="layui-input-block">
19
+ <%= select_tag "professional_title", options_for_select(['教授', '研究员', '副教授', '副研究员', '讲师', '助理研究员', '助理教授'], @person&.professional_title), { include_blank: true} %>
20
+ </div>
21
+ </div>
22
+ <div class="layui-inline">
23
+ <label class="layui-form-label ">职务</label>
24
+ <div class="layui-input-block" style="width: 188px;">
25
+ <input type="text" name="job" autocomplete="off" class="layui-input" placeholder="请输入职务">
26
+ </div>
27
+ </div>
28
+ </div>
29
+ <div class="layui-block">
30
+ <div class="layui-inline">
31
+ <label class="layui-form-label ">来源</label>
32
+ <div class="layui-input-block">
33
+ <%= select_tag "source_id", options_for_select(EducodeSales::Common.where(clazz: 'teacher_source').pluck(:name, :id)), { include_blank: true } %>
34
+ </div>
35
+ </div>
36
+ <div class="layui-inline">
37
+ <label class="layui-form-label ">微信号</label>
38
+ <div class="layui-input-block">
39
+ <input type="text" name="wechat" autocomplete="off" class="layui-input" placeholder="请输入微信号">
40
+ </div>
41
+ </div>
42
+ </div>
43
+ <div class="layui-form-item">
44
+ <label class="layui-form-label">教研助理</label>
45
+ <div class="layui-input-inline" style="z-index: 100">
46
+ <div id="teacher_assist" style="width: 400px;"></div>
47
+ </div>
48
+ </div>
49
+ <div class="layui-form-item m-t-20">
50
+ <div class="layui-input-block">
51
+ <button type="submit" class="layui-btn layui-btn-normal" lay-submit lay-filter="create_teachers"
52
+ style="margin-left: 18px">提交
53
+ </button>
54
+ </div>
55
+ </div>
56
+ </div>
57
+ </div>
58
+ <script>
59
+ layui.use(['form', 'table', 'upload', 'layer', 'laytpl', 'request', 'selectInput'], function () {
60
+ var form = layui.form,
61
+ layer = layui.layer,
62
+ table = layui.table,
63
+ laytpl = layui.laytpl,
64
+ xmSelect = layui.xmSelect,
65
+ request = layui.request,
66
+ $ = layui.$;
67
+ selectInput = layui.selectInput;
68
+
69
+ form.render();
70
+
71
+ var teacher_assist_list = xmSelect.render({
72
+ el: '#teacher_assist',
73
+ remoteSearch: true,
74
+ clickClose: true,
75
+ delay: 1000,
76
+ paging: true,
77
+ pageRemote: true,
78
+ filterable: true,
79
+ remoteMethod: function (val, cb, show, pageIndex) {
80
+ $.ajax( '/missions/sales_staff?teacher_assist=true', {
81
+ method: 'get',
82
+ data: {
83
+ q: val,
84
+ page: pageIndex
85
+ },
86
+ dataType: 'json',
87
+ success: function (res) {
88
+ var data = res.data;
89
+ if (res.code == 0) {
90
+ cb(res.data, res.count);
91
+ } else {
92
+ layer.msg(res.msg, {time: 2000, icon: 2, shade: 0.01});
93
+ }
94
+
95
+ }
96
+ })
97
+ }
98
+ })
99
+
100
+ var add_teacher = selectInput.render({
101
+ elem: '#add_teacher',
102
+ name: 'name', // 渲染的input的name值
103
+ layFilter: 'teacher_id', //同layui form参数lay-filter
104
+ layVerify: 'required', //同layui form参数lay-verify
105
+ layVerType: 'tips', // 同layui form参数lay-verType
106
+ layReqText: '请填写文本', //同layui form参数lay-ReqText
107
+ initValue: '', // 渲染初始化默认值
108
+ hasSelectIcon: false,
109
+ placeholder: '支持姓名/手机号/邮箱搜索', // 渲染的inputplaceholder值
110
+ data: [],
111
+ remoteSearch: true, // 是否启用远程搜索 默认是false,和远程搜索回调保存同步
112
+ remoteMethod: function (value, cb) { // 远程搜索的回调函数
113
+ if (!value) {
114
+ return cb([]);
115
+ }
116
+ request.get('missions/search_edu_teacher?q=' + value, {}, function (res) {
117
+ return cb(res)
118
+ })
119
+ }
120
+ });
121
+ var add_department = selectInput.render({
122
+ elem: '#add_department',
123
+ name: 'department_id',
124
+ layFilter: 'department_id',
125
+ layVerify: 'required',
126
+ layVerType: 'tips',
127
+ layReqText: '请填写文本',
128
+ initValue: '',
129
+ hasSelectIcon: false,
130
+ placeholder: '搜索平台上单位/部门',
131
+ data: [],
132
+ remoteSearch: true, // 是否启用远程搜索 默认是false,和远程搜索回调保存同步
133
+ remoteMethod: function (value, cb) { // 远程搜索的回调函数
134
+ if (!value) {
135
+ return cb([]);
136
+ }
137
+ request.get('missions/search?type=department&q=' + value, {}, function (res) {
138
+ return cb(res)
139
+ })
140
+ }
141
+ });
142
+
143
+ var department_id, user_id;
144
+ add_teacher.on('itemInput(add_teacher)', function (obj) {
145
+ department_id = '';
146
+ user_id = '';
147
+ });
148
+
149
+ add_department.on('itemClear(add_department)', function() {
150
+ if (department_id == "" || add_department == undefined) {
151
+ add_department.setValue("");
152
+ } else {
153
+ add_department.setValue("");
154
+ }
155
+ })
156
+
157
+ add_teacher.on('itemClear(add_teacher)', function() {
158
+ add_department.setValue("")
159
+ })
160
+
161
+ add_teacher.on('itemSelect(add_teacher)', function (obj) {
162
+ user_id = obj.data;
163
+ var name = obj.textContent.split("--")[0]
164
+ add_teacher.setValue(name)
165
+ if (obj.extras.split("---")[1]) {
166
+ department_id = obj.extras.split("---")[0];
167
+ add_department.setValue(obj.extras.split("---")[1])
168
+ }
169
+ });
170
+
171
+ add_department.on('itemSelect(add_department)', function (obj) {
172
+ department_id = obj.data;
173
+ })
174
+
175
+ //监听提交
176
+ form.on('submit(create_teachers)', function (data) {
177
+ var teacher_assist = [];
178
+ teacher_assist_list.getValue().forEach(function(d) {
179
+ teacher_assist.push(d.value);
180
+ })
181
+ data.field.teacher_assist = teacher_assist;
182
+ data.field.user_id = user_id;
183
+ data.field.department_id = department_id;
184
+ data.field.activity_id = parent.activity_id;
185
+ if (department_id == "") {
186
+ return layer.alert("请选择单位部门")
187
+ }
188
+ request.authPost("missions/teachers", data.field, function (res) {
189
+ if (res.success == false) {
190
+ layer.alert(res.msg)
191
+ } else {
192
+ table.reload('show_teachers_table');
193
+ table.reload('activities_table');
194
+ table.reload('teachers_table');
195
+ layer.close(parent.index)
196
+ layer.close(parent.sindex)
197
+ layer.close(parent.teacher_uni_index)
198
+ }
199
+ })
200
+ return false;
201
+ });
202
+
203
+ });
204
+ </script>
@@ -0,0 +1,93 @@
1
+ <form class="layui-form " action="">
2
+ <div class="layui-form-item" style="padding: 25px">
3
+ <div class="layui-inline">
4
+ <label class="layui-form-label">教师态度</label>
5
+ <div class="layui-input-inline">
6
+ <%= select_tag "attitude_id",options_for_select(EducodeSales::Common.where(clazz: "teacher_attitude").pluck(:name, :id))%>
7
+ </div>
8
+ </div>
9
+ <div class="layui-inline">
10
+ <label class="layui-form-label">开课计划</label>
11
+ <div class="layui-input-inline">
12
+ <%= select_tag "course_plan_id",options_for_select(EducodeSales::Common.where(clazz: "course_plan").pluck(:name, :id))%>
13
+ </div>
14
+ </div>
15
+ <br>
16
+ <div class="layui-inline">
17
+ <label class="layui-form-label">课堂建设</label>
18
+ <div class="layui-input-inline">
19
+ <%= select_tag "course_build_id",options_for_select(EducodeSales::Common.where(clazz: "course_build").pluck(:name, :id))%>
20
+ </div>
21
+ </div>
22
+ <div class="layui-inline">
23
+ <label class="layui-form-label">跟进手段</label>
24
+ <div class="layui-input-inline">
25
+ <%= select_tag "follow_id",options_for_select(EducodeSales::Common.where(clazz: "contact").pluck(:name, :id))%>
26
+ </div>
27
+ </div>
28
+ <br>
29
+ <div class="layui-form-item layui-form-text">
30
+ <label class="layui-form-label">跟进小结</label>
31
+ <div class="layui-input-block">
32
+ <textarea name="description" placeholder="此处可以填写:
33
+ 1、教师关注的痛点问题;
34
+ 2、教师关注的教学项目、教学成果类型;
35
+ 3、其他个性化需求,以及应对情况说明;
36
+ 4、目前态度的产生原因等。
37
+ " class="layui-textarea"></textarea>
38
+ </div>
39
+ </div>
40
+ <div class="layui-inline" style="padding-left: 50px">
41
+ <button type="submit" class="layui-btn layui-btn-normal" lay-submit lay-filter="add_follow_up">提交
42
+ </button>
43
+ </div>
44
+ </div>
45
+ </form>
46
+
47
+
48
+
49
+
50
+ <script>
51
+ layui.use(['form', 'table', 'upload', 'layer', 'laytpl', 'request', 'laydate'], function () {
52
+ var form = layui.form,
53
+ layer = layui.layer,
54
+ table = layui.table,
55
+ laytpl = layui.laytpl,
56
+ request = layui.request,
57
+ laydate = layui.laydate,
58
+ $ = layui.$;
59
+
60
+ // laydate.render({
61
+ // elem: '#invitation_at_add'
62
+ // })
63
+ //
64
+ // laydate.render({
65
+ // elem: '#reception_at_add'
66
+ // });
67
+
68
+ form.render();
69
+
70
+ form.on('submit(add_follow_up)', function (data) {
71
+ data.field.teacher_id = "<%= @teacher.id %>";
72
+ request.authPost("missions/teacher_follows", data.field, function (res) {
73
+ if (res.success == false) {
74
+ layer.alert(res.msg)
75
+ } else {
76
+ layer.close(parent.sale_plan_index);
77
+ parent.layer.close(parent.layer.getFrameIndex(window.name))
78
+ parent.table.reload('sale_plan_follow_table')
79
+ parent.table.reload('teachers_table')
80
+ parent.table.reload('weekPlanTable1')
81
+ parent.table.reload('monthPlanTable')
82
+ parent.table.reload('monthlyTable')
83
+ parent.table.reload('weeklyTable')
84
+ table.reload('show_teachers_table')
85
+ }
86
+ })
87
+
88
+
89
+ return false;
90
+ });
91
+
92
+ });
93
+ </script>