educode_sales 0.9.66 → 0.9.68
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/controllers/educode_sales/activities_controller.rb +122 -40
- data/app/controllers/educode_sales/businesses_controller.rb +83 -2
- data/app/controllers/educode_sales/operation_plans_controller.rb +8 -4
- data/app/controllers/educode_sales/plans_controller.rb +173 -11
- data/app/controllers/educode_sales/recycles_controller.rb +11 -1
- data/app/controllers/educode_sales/teachers_controller.rb +4 -4
- data/app/controllers/educode_sales/upload_files_controller.rb +9 -2
- data/app/models/educode_sales/activity.rb +21 -4
- data/app/models/educode_sales/activity_follow_up.rb +13 -0
- data/app/models/educode_sales/activity_staff.rb +1 -1
- data/app/models/educode_sales/assessments_setting.rb +2 -2
- data/app/models/educode_sales/business.rb +3 -0
- data/app/models/educode_sales/business_info.rb +9 -0
- data/app/models/educode_sales/business_level.rb +11 -0
- data/app/models/educode_sales/business_watch.rb +6 -0
- data/app/models/educode_sales/sale_plan.rb +3 -1
- data/app/models/educode_sales/staff.rb +2 -0
- data/app/views/educode_sales/activities/_follows.html.erb +222 -0
- data/app/views/educode_sales/activities/_index.html.erb +491 -0
- data/app/views/educode_sales/activities/edit.html.erb +109 -53
- data/app/views/educode_sales/activities/files.html.erb +157 -0
- data/app/views/educode_sales/activities/files.json.jbuilder +13 -0
- data/app/views/educode_sales/activities/follow_ups.json.jbuilder +19 -0
- data/app/views/educode_sales/activities/index.html.erb +13 -349
- data/app/views/educode_sales/activities/index.json.jbuilder +11 -3
- data/app/views/educode_sales/activities/new.html.erb +87 -46
- data/app/views/educode_sales/activities/new_follow_up.html.erb +56 -0
- data/app/views/educode_sales/activities/upload_file.html.erb +43 -0
- data/app/views/educode_sales/businesses/edit.html.erb +48 -6
- data/app/views/educode_sales/businesses/get_export_data.json.jbuilder +3 -0
- data/app/views/educode_sales/businesses/index.html.erb +10 -0
- data/app/views/educode_sales/businesses/new.html.erb +1 -1
- data/app/views/educode_sales/businesses/no_permission.html.erb +2 -0
- data/app/views/educode_sales/plans/_yearPlan.html.erb +234 -0
- data/app/views/educode_sales/plans/business_infos.json.jbuilder +23 -0
- data/app/views/educode_sales/plans/edit_bussiness_info.html.erb +79 -0
- data/app/views/educode_sales/plans/edit_bussiness_info_extra.html.erb +260 -0
- data/app/views/educode_sales/plans/edit_year_plan.html.erb +237 -0
- data/app/views/educode_sales/plans/index.html.erb +8 -0
- data/app/views/educode_sales/plans/new_year.html.erb +204 -0
- data/app/views/educode_sales/plans/plan_business_infos.json.jbuilder +42 -0
- data/app/views/educode_sales/plans/years_plan.json.jbuilder +17 -0
- data/app/views/educode_sales/recycles/_monthly.html.erb +1 -1
- data/app/views/educode_sales/recycles/_yearPlan.html.erb +118 -0
- data/app/views/educode_sales/recycles/index.html.erb +26 -22
- data/app/views/educode_sales/recycles/monthPlan.json.jbuilder +0 -1
- data/app/views/educode_sales/recycles/yearPlan.json.jbuilder +14 -0
- data/config/routes.rb +22 -0
- data/db/migrate/20230329135141_create_educode_sales_business_watches.rb +17 -0
- data/db/migrate/20230330141213_create_educode_sales_activity_follow_ups.rb +31 -0
- data/db/migrate/20230405074036_add_year_to_sale_plans.rb +38 -0
- data/lib/educode_sales/version.rb +1 -1
- metadata +31 -7
- data/app/assets/images/educode_sales/indexlogo.png +0 -0
@@ -0,0 +1,43 @@
|
|
1
|
+
<div style="padding-left: 50px">
|
2
|
+
<button type="button" class="layui-btn" id="get_file"><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
|
+
laytpl = layui.laytpl,
|
10
|
+
upload = layui.upload,
|
11
|
+
request = layui.request,
|
12
|
+
$ = layui.$;
|
13
|
+
selectInput = layui.selectInput;
|
14
|
+
|
15
|
+
form.render();
|
16
|
+
|
17
|
+
//指定允许上传的文件类型
|
18
|
+
var activity_id = parent.activity_id
|
19
|
+
var renderObj = upload.render({
|
20
|
+
elem: '#get_file'
|
21
|
+
,url: '/missions/upload_files?activity_id='+activity_id //此处配置你自己的上传接口即可
|
22
|
+
,accept: 'file' //普通文件
|
23
|
+
,headers: {
|
24
|
+
'X-CSRF-Token': $('meta[name=csrf-token]').attr('content')
|
25
|
+
}
|
26
|
+
,before: function(obj){ //obj参数包含的信息,跟 choose回调完全一致,可参见上文。
|
27
|
+
layer.load(); //上传loading
|
28
|
+
}
|
29
|
+
,done: function(res){
|
30
|
+
layer.msg('导入成功');
|
31
|
+
table.reload('file');
|
32
|
+
layer.closeAll('loading'); //关闭loading
|
33
|
+
layer.close(parent.import_index)
|
34
|
+
}
|
35
|
+
,error: function(index, upload){
|
36
|
+
table.reload('file');
|
37
|
+
layer.closeAll('loading'); //关闭loading
|
38
|
+
layer.alert('导入失败,请检查文件格式')
|
39
|
+
layer.close(parent.import_index)
|
40
|
+
}
|
41
|
+
});
|
42
|
+
});
|
43
|
+
</script>
|
@@ -33,6 +33,20 @@
|
|
33
33
|
</div>
|
34
34
|
</div>
|
35
35
|
<% end %>
|
36
|
+
<% if @current_admin.is_admin? %>
|
37
|
+
<div class="layui-form-item m-t-20">
|
38
|
+
<label class="layui-form-label">商机等级</label>
|
39
|
+
<div class="layui-input-inline">
|
40
|
+
<div id="levels" style="width: 300px;"></div>
|
41
|
+
</div>
|
42
|
+
</div>
|
43
|
+
<div class="layui-form-item m-t-20 layui-hide" id="watch_ids_wraper">
|
44
|
+
<label class="layui-form-label">指定查看人员</label>
|
45
|
+
<div class="layui-input-inline">
|
46
|
+
<div id="watch_ids" style="width: 300px;"></div>
|
47
|
+
</div>
|
48
|
+
</div>
|
49
|
+
<% end %>
|
36
50
|
<div class="layui-form-item m-t-20">
|
37
51
|
<div class="layui-input-block">
|
38
52
|
<button class="layui-btn layui-btn-normal" lay-submit lay-filter="edit_business">提交</button>
|
@@ -51,6 +65,35 @@
|
|
51
65
|
$ = layui.$;
|
52
66
|
selectInput = layui.selectInput;
|
53
67
|
|
68
|
+
var levels_select = xmSelect.render({
|
69
|
+
el: '#levels',
|
70
|
+
name: 'level_ids',
|
71
|
+
data: gon.levels,
|
72
|
+
on: function(data) {
|
73
|
+
var is_secret = false;
|
74
|
+
data.arr.forEach(function(i) {
|
75
|
+
if (i.name == '战略型' || i.name == '保密型') {
|
76
|
+
is_secret = true;
|
77
|
+
}
|
78
|
+
})
|
79
|
+
if (is_secret) {
|
80
|
+
$("#watch_ids_wraper").removeClass('layui-hide')
|
81
|
+
} else {
|
82
|
+
$("#watch_ids_wraper").addClass('layui-hide')
|
83
|
+
}
|
84
|
+
}
|
85
|
+
})
|
86
|
+
|
87
|
+
var watch_id_select = xmSelect.render({
|
88
|
+
el: '#watch_ids',
|
89
|
+
name: 'watch_ids',
|
90
|
+
data: gon.watche_ids,
|
91
|
+
filterable: true,
|
92
|
+
})
|
93
|
+
if (gon.is_secret) {
|
94
|
+
$("#watch_ids_wraper").removeClass("layui-hide")
|
95
|
+
}
|
96
|
+
|
54
97
|
form.render();
|
55
98
|
var department_id = gon.value;
|
56
99
|
var department = selectInput.render({
|
@@ -99,12 +142,11 @@
|
|
99
142
|
layer.alert("请选择单位部门")
|
100
143
|
return false;
|
101
144
|
} else {
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
}, function (res) {
|
145
|
+
var field = data.field;
|
146
|
+
console.log('field', field)
|
147
|
+
field.department_id = department.getValue() || department_id;
|
148
|
+
field.merge_business_ids = data.field.merge_business_ids;
|
149
|
+
request.authPut("missions/businesses/" + parent.id, field, function (res) {
|
108
150
|
if (res.success == false) {
|
109
151
|
layer.alert(res.msg)
|
110
152
|
} else {
|
@@ -24,6 +24,9 @@ json.data do
|
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
|
+
json.created_at d.created_at.to_s
|
28
|
+
json.no_followup_days (d['latest_time'] ? DateTime.parse(Time.now.strftime("%Y-%m-%d")) - DateTime.parse(d['latest_time'].strftime("%Y-%m-%d")) : DateTime.parse(Time.now.strftime("%Y-%m-%d")) - DateTime.parse(d.created_at.strftime("%Y-%m-%d"))).to_i
|
29
|
+
|
27
30
|
json.staff_manages d.last_follow_up&.assign_follow_ups.present? ? (d.last_follow_up.assign_follow_ups.map{ |d| d.staff.user.real_name}.join("、")) : d.staff&.user&.real_name
|
28
31
|
json.divide_rate d.divide_rate
|
29
32
|
json.divide_money d.divide_amount
|
@@ -120,6 +120,16 @@
|
|
120
120
|
</select>
|
121
121
|
</div>
|
122
122
|
</div>
|
123
|
+
<div class="layui-inline show_item" style="<%= params[:name] || params[:type] ? '' : 'display:none;' %>">
|
124
|
+
<label class="layui-form-label">商机等级</label>
|
125
|
+
<div class="layui-input-inline">
|
126
|
+
<select name="level_id">
|
127
|
+
<option value=""></option>
|
128
|
+
<option value="1">保密型</option>
|
129
|
+
<option value="2">战略型</option>
|
130
|
+
</select>
|
131
|
+
</div>
|
132
|
+
</div>
|
123
133
|
<div class="layui-inline">
|
124
134
|
<button type="reset" class="layui-btn layui-btn-primary" lay-submit lay-filter="reset_business_search">重置
|
125
135
|
</button>
|
@@ -25,7 +25,7 @@
|
|
25
25
|
<div class="layui-inline" style="padding-top: 20px">
|
26
26
|
<label class="layui-form-label required">项目类型</label>
|
27
27
|
<div class="layui-input-inline">
|
28
|
-
<%= select_tag "clazz_id", options_for_select(@clazz), { 'lay-filter': 'clazz_id', class: 'required' } %>
|
28
|
+
<%= select_tag "clazz_id", options_for_select(@clazz), { 'lay-filter': 'clazz_id', class: 'required', include_blank: true } %>
|
29
29
|
</div>
|
30
30
|
</div>
|
31
31
|
<div class="layui-form-item m-t-20">
|
@@ -0,0 +1,234 @@
|
|
1
|
+
<script type="text/html" id="yearPlanToolbar">
|
2
|
+
<div class="layui-btn-container">
|
3
|
+
<span class="table-label">年计划列表</span>
|
4
|
+
<% if can? :create, EducodeSales::SalePlan %>
|
5
|
+
<button class="layui-btn layui-btn-normal layui-btn-sm data-add-btn pull-right" lay-event="add"> 添加年计划</button>
|
6
|
+
<% end %>
|
7
|
+
</div>
|
8
|
+
</script>
|
9
|
+
<!--搜索-->
|
10
|
+
<div class="layuimini-main min-height-table" id="year_table_wraper">
|
11
|
+
<form class="layui-form layui-form-pane" lay-filter="month_plan_search_form">
|
12
|
+
<div class="layui-form-item">
|
13
|
+
<div class="layui-inline">
|
14
|
+
<label class="layui-form-label">人员</label>
|
15
|
+
<div class="layui-input-inline large-select">
|
16
|
+
<%= select_tag "staff_id", options_for_select(@staffs), { id: 'month_plan_staff_id', include_blank: true} %>
|
17
|
+
</div>
|
18
|
+
</div>
|
19
|
+
<div class="layui-inline">
|
20
|
+
<label class="layui-form-label">年度</label>
|
21
|
+
<div class="layui-input-inline">
|
22
|
+
<input type="text" class="layui-input" id="year_plan_date" autocomplete="off" name="year">
|
23
|
+
</div>
|
24
|
+
</div>
|
25
|
+
<div class="layui-inline">
|
26
|
+
<button type="reseet" class="layui-btn layui-btn-primary" lay-submit lay-filter="month_plan_reset_btn">重置
|
27
|
+
</button>
|
28
|
+
<button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="month_plan_seach_btn">检索
|
29
|
+
</button>
|
30
|
+
</div>
|
31
|
+
</div>
|
32
|
+
</form>
|
33
|
+
<table class="layui-hide" id="yearPlanTable" lay-filter="yearPlanTable"></table>
|
34
|
+
</div>
|
35
|
+
<script type="text/html" id="currentYearTableBar">
|
36
|
+
<% if can? :update, EducodeSales::SalePlan %>
|
37
|
+
<a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">编辑</a>
|
38
|
+
<% end %>
|
39
|
+
<% if can? :destroy, EducodeSales::SalePlan %>
|
40
|
+
<a class="layui-btn layui-btn-danger layui-btn-xs data-count-delete" lay-event="delete">删除</a>
|
41
|
+
<% end %>
|
42
|
+
</script>
|
43
|
+
|
44
|
+
<script>
|
45
|
+
layui.use(['form', 'table', 'miniPage', 'element', 'rate', 'laydate', 'request'], function () {
|
46
|
+
var $ = layui.jquery,
|
47
|
+
form = layui.form,
|
48
|
+
request = layui.request,
|
49
|
+
laydate = layui.laydate,
|
50
|
+
table = layui.table,
|
51
|
+
rate = layui.rate,
|
52
|
+
miniPage = layui.miniPage;
|
53
|
+
|
54
|
+
laydate.render({
|
55
|
+
elem: '#year_plan_date',
|
56
|
+
type: 'year'
|
57
|
+
});
|
58
|
+
table.render({
|
59
|
+
elem: '#yearPlanTable',
|
60
|
+
url: '/missions/plans/years_plan',
|
61
|
+
toolbar: '#yearPlanToolbar',
|
62
|
+
defaultToolbar: ['filter'],
|
63
|
+
initSort: {
|
64
|
+
field: 'updated_at',
|
65
|
+
type: 'desc'
|
66
|
+
},
|
67
|
+
cols: [
|
68
|
+
[
|
69
|
+
{
|
70
|
+
field: 'id',
|
71
|
+
width: 60,
|
72
|
+
title:'序号',
|
73
|
+
type: 'numbers',
|
74
|
+
fixed: 'left'
|
75
|
+
},
|
76
|
+
{
|
77
|
+
field: 'staff',
|
78
|
+
width: 120,
|
79
|
+
title: '姓名',
|
80
|
+
fixed: 'left'
|
81
|
+
},
|
82
|
+
{
|
83
|
+
field: 'clazz',
|
84
|
+
width: 160,
|
85
|
+
title: '目标类型',
|
86
|
+
},
|
87
|
+
{
|
88
|
+
field: 'year',
|
89
|
+
width: 120,
|
90
|
+
title: '年份'
|
91
|
+
},
|
92
|
+
{
|
93
|
+
field: 'target_money',
|
94
|
+
width: 120,
|
95
|
+
title: '目标额'
|
96
|
+
},
|
97
|
+
{
|
98
|
+
field: 'plan_money',
|
99
|
+
width: 120,
|
100
|
+
title: '计划额',
|
101
|
+
},
|
102
|
+
{
|
103
|
+
field: 'minimum_money',
|
104
|
+
width: 120,
|
105
|
+
title: '保底额',
|
106
|
+
},
|
107
|
+
{
|
108
|
+
field: 'finish_money',
|
109
|
+
width: 120,
|
110
|
+
title: '完成额',
|
111
|
+
},
|
112
|
+
{
|
113
|
+
field: 'finish_rate',
|
114
|
+
width: 120,
|
115
|
+
title: '完成率',
|
116
|
+
},
|
117
|
+
{
|
118
|
+
field: 'updated_at',
|
119
|
+
width: 170,
|
120
|
+
title: '更新时间',
|
121
|
+
sort: true,
|
122
|
+
},
|
123
|
+
{
|
124
|
+
title: '操作',
|
125
|
+
width: 200,
|
126
|
+
toolbar: '#currentYearTableBar',
|
127
|
+
align: "center",
|
128
|
+
fixed: 'right'
|
129
|
+
}
|
130
|
+
]
|
131
|
+
],
|
132
|
+
|
133
|
+
limit: 20,
|
134
|
+
limits: [10,15,20,30,40,50,60,70,80,90],
|
135
|
+
page: true,
|
136
|
+
});
|
137
|
+
|
138
|
+
var sort = {}, search = {};
|
139
|
+
table.on('sort(yearPlanTable)', function(obj) {
|
140
|
+
sort.field = obj.field;
|
141
|
+
sort.order = obj.type;
|
142
|
+
table.reload('yearPlanTable', {
|
143
|
+
initSort: obj,
|
144
|
+
where: {
|
145
|
+
sort: sort,
|
146
|
+
q: search
|
147
|
+
}
|
148
|
+
});
|
149
|
+
})
|
150
|
+
|
151
|
+
// 监听搜索操作
|
152
|
+
form.on('submit(month_plan_seach_btn)', function (data) {
|
153
|
+
search = data.field
|
154
|
+
table.reload('yearPlanTable', {
|
155
|
+
page: {
|
156
|
+
curr: 1
|
157
|
+
},
|
158
|
+
where: {q: search, sort : sort}
|
159
|
+
}, 'data');
|
160
|
+
|
161
|
+
return false;
|
162
|
+
});
|
163
|
+
|
164
|
+
form.on('submit(month_plan_reset_btn)', function(data){
|
165
|
+
var field = data.field;
|
166
|
+
form.val('month_plan_search_form', { staff_id: '', year: '', month: '', year: ''})
|
167
|
+
return false;
|
168
|
+
});
|
169
|
+
|
170
|
+
|
171
|
+
table.on('toolbar(yearPlanTable)', function (obj) {
|
172
|
+
if (obj.event === 'add') { // 监听添加操作
|
173
|
+
var content = miniPage.getHrefContent('/missions/plans/new_year');
|
174
|
+
var openWH = miniPage.getOpenWidthHeight();
|
175
|
+
from_sales = true
|
176
|
+
yindex = layer.open({
|
177
|
+
title: '添加年计划',
|
178
|
+
type: 1,
|
179
|
+
shade: 0.2,
|
180
|
+
maxmin: true,
|
181
|
+
shadeClose: true,
|
182
|
+
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
183
|
+
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
184
|
+
content: content,
|
185
|
+
success: function (layero, index) {
|
186
|
+
// 重新渲染弹层中的下拉选择框select
|
187
|
+
form.render('select');
|
188
|
+
}
|
189
|
+
});
|
190
|
+
$(window).on("resize", function () {
|
191
|
+
layer.full(sindex);
|
192
|
+
});
|
193
|
+
}
|
194
|
+
});
|
195
|
+
|
196
|
+
table.on('tool(yearPlanTable)', function (obj) {
|
197
|
+
var data = obj.data;
|
198
|
+
if (obj.event === 'edit') {
|
199
|
+
year = data.year;
|
200
|
+
content = miniPage.getHrefContent('/missions/plans/edit_year_plan?id=' + data.id);
|
201
|
+
openWH = miniPage.getOpenWidthHeight();
|
202
|
+
from_sales = true;
|
203
|
+
plan_id = data.id
|
204
|
+
sindex = layer.open({
|
205
|
+
title: '编辑年计划',
|
206
|
+
type: 1,
|
207
|
+
shade: 0.2,
|
208
|
+
maxmin: true,
|
209
|
+
shadeClose: true,
|
210
|
+
area: [openWH[0] + 'px', openWH[1] + 'px'],
|
211
|
+
offset: [openWH[2] + 'px', openWH[3] + 'px'],
|
212
|
+
content: content
|
213
|
+
});
|
214
|
+
$(window).on("resize", function () {
|
215
|
+
layer.full(sindex);
|
216
|
+
});
|
217
|
+
return false;
|
218
|
+
} else if (obj.event === 'delete') {
|
219
|
+
layer.confirm('确定删除' + data.staff + data.clazz, function (index) {
|
220
|
+
request.delete('missions/plans/' + data.id, {year: data.year, clazz: data.clazz}, function (res) {
|
221
|
+
layer.close(index);
|
222
|
+
table.reload("yearPlanTable")
|
223
|
+
})
|
224
|
+
});
|
225
|
+
}
|
226
|
+
});
|
227
|
+
|
228
|
+
});
|
229
|
+
</script>
|
230
|
+
<style>
|
231
|
+
.layui-table-fixed .layui-table-body {
|
232
|
+
height: auto!important;
|
233
|
+
}
|
234
|
+
</style>
|
@@ -0,0 +1,23 @@
|
|
1
|
+
json.data do
|
2
|
+
json.array! @data do |d|
|
3
|
+
json.id d.id
|
4
|
+
json.staff d.staff.user.real_name
|
5
|
+
json.clazz EducodeSales::SalePlan::CLAZZ_NAME.invert[d.clazz]
|
6
|
+
json.year d.year
|
7
|
+
json.business_name d.business.name
|
8
|
+
json.department d.business.department&.name
|
9
|
+
json.school d.business.department&.school&.name
|
10
|
+
json.stage d.business.last_follow_up&.stage&.name
|
11
|
+
json.staff_manages d.business.last_follow_up&.assign_follow_ups.present? ? (d.business.last_follow_up.assign_follow_ups.map{ |d| d.staff.user.real_name}.join("、")) : d.business.staff&.user&.real_name
|
12
|
+
json.created_at d.created_at.to_s
|
13
|
+
json.sale_way d.business.last_follow_up&.place&.name.present? ? '渠道' : '直销'
|
14
|
+
json.budget_amount d.business&.last_follow_up ? d.business.last_follow_up.budget_amount.to_f.round(2) : 0
|
15
|
+
json.plan_bid_on d.plan_bid_on
|
16
|
+
json.plan_sign_on d.plan_sign_on
|
17
|
+
json.prepayment_plan_on d.prepayment_plan_on
|
18
|
+
json.prepayment_amount d.prepayment_amount
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
json.code 0
|
23
|
+
json.count @data.total_count
|
@@ -0,0 +1,79 @@
|
|
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 required" style="width: 180px;">计划投标时间</label>
|
5
|
+
<div class="layui-input-inline">
|
6
|
+
<input type="text" class="layui-input" id="plan_bid_on" autocomplete="off" name="plan_bid_on">
|
7
|
+
</div>
|
8
|
+
</div>
|
9
|
+
<div class="layui-inline">
|
10
|
+
<label class="layui-form-label required" style="width: 180px;">计划签单时间</label>
|
11
|
+
<div class="layui-input-inline">
|
12
|
+
<input type="text" class="layui-input" id="plan_sign_on" autocomplete="off" name="plan_sign_on">
|
13
|
+
</div>
|
14
|
+
</div>
|
15
|
+
<div class="layui-inline">
|
16
|
+
<label class="layui-form-label required" style="width: 180px;">计划回款时间</label>
|
17
|
+
<div class="layui-input-inline">
|
18
|
+
<input type="text" class="layui-input" id="prepayment_plan_on" autocomplete="off" name="prepayment_plan_on">
|
19
|
+
</div>
|
20
|
+
</div>
|
21
|
+
<div class="layui-inline">
|
22
|
+
<label class="layui-form-label required" style="width: 180px;">计划回款额</label>
|
23
|
+
<div class="layui-input-inline">
|
24
|
+
<input type="text" class="layui-input" autocomplete="off" name="prepayment_amount" value="<%= @business_info.prepayment_amount %>">
|
25
|
+
</div>
|
26
|
+
</div>
|
27
|
+
|
28
|
+
<div class="layui-form-item m-t-20">
|
29
|
+
<div class="layui-input-block">
|
30
|
+
<button type="submit" class="layui-btn layui-btn-normal" lay-submit lay-filter="update_bussiness_info">提交</button>
|
31
|
+
</div>
|
32
|
+
</div>
|
33
|
+
</div>
|
34
|
+
</form>
|
35
|
+
<script>
|
36
|
+
layui.use(['form', 'table', 'laytpl', 'request', 'laydate'], function () {
|
37
|
+
var form = layui.form,
|
38
|
+
layer = layui.layer,
|
39
|
+
laydate = layui.laydate,
|
40
|
+
table = layui.table,
|
41
|
+
request = layui.request,
|
42
|
+
$ = layui.$;
|
43
|
+
|
44
|
+
laydate.render({
|
45
|
+
elem: '#plan_bid_on',
|
46
|
+
value: "<%= @business_info.plan_bid_on.to_s %>",
|
47
|
+
type: 'date'
|
48
|
+
});
|
49
|
+
|
50
|
+
laydate.render({
|
51
|
+
elem: '#plan_sign_on',
|
52
|
+
value: "<%= @business_info.plan_sign_on.to_s %>",
|
53
|
+
type: 'date'
|
54
|
+
});
|
55
|
+
laydate.render({
|
56
|
+
elem: '#prepayment_plan_on',
|
57
|
+
value: "<%= @business_info.prepayment_plan_on.to_s %>",
|
58
|
+
type: 'date'
|
59
|
+
});
|
60
|
+
|
61
|
+
|
62
|
+
form.render();
|
63
|
+
|
64
|
+
form.on('submit(update_bussiness_info)', function (data) {
|
65
|
+
request.authPost("missions/plans/update_business_info?id=" + parent.id, data.field, function (res) {
|
66
|
+
if (res.success == false) {
|
67
|
+
layer.alert(res.msg)
|
68
|
+
} else {
|
69
|
+
layer.close(parent.sindex);
|
70
|
+
parent.table.reload('yearTable', {
|
71
|
+
where: {year: parent.year }
|
72
|
+
})
|
73
|
+
}
|
74
|
+
})
|
75
|
+
return false;
|
76
|
+
});
|
77
|
+
|
78
|
+
});
|
79
|
+
</script>
|