正在显示
8 个修改的文件
包含
463 行增加
和
0 行删除
1 | +<?php | ||
2 | + | ||
3 | +namespace app\admin\controller; | ||
4 | + | ||
5 | +use app\common\controller\Backend; | ||
6 | + | ||
7 | +/** | ||
8 | + * 河道流量管理 | ||
9 | + * | ||
10 | + * @icon fa fa-circle-o | ||
11 | + */ | ||
12 | +class ReservoirRainFlow extends Backend | ||
13 | +{ | ||
14 | + | ||
15 | + /** | ||
16 | + * ReservoirRainFlow模型对象 | ||
17 | + * @var \app\admin\model\ReservoirRainFlow | ||
18 | + */ | ||
19 | + protected $model = null; | ||
20 | + | ||
21 | + public function _initialize() | ||
22 | + { | ||
23 | + parent::_initialize(); | ||
24 | + $this->model = new \app\admin\model\ReservoirRainFlow; | ||
25 | + $this->view->assign("statusList", $this->model->getStatusList()); | ||
26 | + $this->view->assign("waterLevelWarningList", $this->model->getWaterLevelWarningList()); | ||
27 | + } | ||
28 | + | ||
29 | + public function import() | ||
30 | + { | ||
31 | + parent::import(); | ||
32 | + } | ||
33 | + | ||
34 | + /** | ||
35 | + * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 | ||
36 | + * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 | ||
37 | + * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 | ||
38 | + */ | ||
39 | + | ||
40 | + | ||
41 | + /** | ||
42 | + * 查看 | ||
43 | + */ | ||
44 | + public function index() | ||
45 | + { | ||
46 | + //当前是否为关联查询 | ||
47 | + $this->relationSearch = true; | ||
48 | + //设置过滤方法 | ||
49 | + $this->request->filter(['strip_tags', 'trim']); | ||
50 | + if ($this->request->isAjax()) { | ||
51 | + //如果发送的来源是Selectpage,则转发到Selectpage | ||
52 | + if ($this->request->request('keyField')) { | ||
53 | + return $this->selectpage(); | ||
54 | + } | ||
55 | + list($where, $sort, $order, $offset, $limit) = $this->buildparams(); | ||
56 | + | ||
57 | + $list = $this->model | ||
58 | + ->with(['reservoirlist']) | ||
59 | + ->where($where) | ||
60 | + ->order($sort, $order) | ||
61 | + ->paginate($limit); | ||
62 | + | ||
63 | + foreach ($list as $row) { | ||
64 | + $row->visible(['id','number','flow','accumulate_flow']); | ||
65 | + $row->visible(['reservoirlist']); | ||
66 | + $row->getRelation('reservoirlist')->visible(['name']); | ||
67 | + } | ||
68 | + | ||
69 | + $result = array("total" => $list->total(), "rows" => $list->items()); | ||
70 | + | ||
71 | + return json($result); | ||
72 | + } | ||
73 | + return $this->view->fetch(); | ||
74 | + } | ||
75 | + | ||
76 | +} |
1 | +<?php | ||
2 | + | ||
3 | +return [ | ||
4 | + 'Number' => '设备编号', | ||
5 | + 'Status' => '设备状态', | ||
6 | + 'Status 0' => '启用', | ||
7 | + 'Status 1' => '停用', | ||
8 | + 'Flow' => '瞬时流量', | ||
9 | + 'Accumulate_flow' => '累计流量', | ||
10 | + 'Velocity_flow' => '流速', | ||
11 | + 'Water_level' => '水位', | ||
12 | + 'Water_level_warning' => '水位预警', | ||
13 | + 'Water_level_warning 0' => '正常', | ||
14 | + 'Water_level_warning 1' => '异常', | ||
15 | + 'Createtime' => '创建时间', | ||
16 | + 'Reporttime' => '采集时间', | ||
17 | + 'Reservoir_id' => '水库id', | ||
18 | + 'Reservoirlist.name' => '名称' | ||
19 | +]; |
1 | +<?php | ||
2 | + | ||
3 | +namespace app\admin\model; | ||
4 | + | ||
5 | +use think\Model; | ||
6 | + | ||
7 | + | ||
8 | +class ReservoirRainFlow extends Model | ||
9 | +{ | ||
10 | + | ||
11 | + | ||
12 | + | ||
13 | + | ||
14 | + | ||
15 | + // 表名 | ||
16 | + protected $name = 'reservoir_rain_flow'; | ||
17 | + | ||
18 | + // 自动写入时间戳字段 | ||
19 | + protected $autoWriteTimestamp = 'int'; | ||
20 | + | ||
21 | + // 定义时间戳字段名 | ||
22 | + protected $createTime = 'createtime'; | ||
23 | + protected $updateTime = 'updatetime'; | ||
24 | + protected $deleteTime = false; | ||
25 | + | ||
26 | + // 追加属性 | ||
27 | + protected $append = [ | ||
28 | + 'status_text', | ||
29 | + 'water_level_warning_text', | ||
30 | + 'reporttime_text' | ||
31 | + ]; | ||
32 | + | ||
33 | + | ||
34 | + | ||
35 | + public function getStatusList() | ||
36 | + { | ||
37 | + return ['0' => __('Status 0'), '1' => __('Status 1')]; | ||
38 | + } | ||
39 | + | ||
40 | + public function getWaterLevelWarningList() | ||
41 | + { | ||
42 | + return ['0' => __('Water_level_warning 0'), '1' => __('Water_level_warning 1')]; | ||
43 | + } | ||
44 | + | ||
45 | + | ||
46 | + public function getStatusTextAttr($value, $data) | ||
47 | + { | ||
48 | + $value = $value ? $value : (isset($data['status']) ? $data['status'] : ''); | ||
49 | + $list = $this->getStatusList(); | ||
50 | + return isset($list[$value]) ? $list[$value] : ''; | ||
51 | + } | ||
52 | + | ||
53 | + | ||
54 | + public function getWaterLevelWarningTextAttr($value, $data) | ||
55 | + { | ||
56 | + $value = $value ? $value : (isset($data['water_level_warning']) ? $data['water_level_warning'] : ''); | ||
57 | + $list = $this->getWaterLevelWarningList(); | ||
58 | + return isset($list[$value]) ? $list[$value] : ''; | ||
59 | + } | ||
60 | + | ||
61 | + | ||
62 | + public function getReporttimeTextAttr($value, $data) | ||
63 | + { | ||
64 | + $value = $value ? $value : (isset($data['reporttime']) ? $data['reporttime'] : ''); | ||
65 | + return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value; | ||
66 | + } | ||
67 | + | ||
68 | + protected function setReporttimeAttr($value) | ||
69 | + { | ||
70 | + return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); | ||
71 | + } | ||
72 | + | ||
73 | + | ||
74 | + public function reservoirlist() | ||
75 | + { | ||
76 | + return $this->belongsTo('app\admin\model\reservoir\Reservoirlist', 'reservoir_id', 'id', [], 'LEFT')->setEagerlyType(0); | ||
77 | + } | ||
78 | +} |
1 | +<?php | ||
2 | + | ||
3 | +namespace app\admin\validate; | ||
4 | + | ||
5 | +use think\Validate; | ||
6 | + | ||
7 | +class ReservoirRainFlow extends Validate | ||
8 | +{ | ||
9 | + /** | ||
10 | + * 验证规则 | ||
11 | + */ | ||
12 | + protected $rule = [ | ||
13 | + ]; | ||
14 | + /** | ||
15 | + * 提示消息 | ||
16 | + */ | ||
17 | + protected $message = [ | ||
18 | + ]; | ||
19 | + /** | ||
20 | + * 验证场景 | ||
21 | + */ | ||
22 | + protected $scene = [ | ||
23 | + 'add' => [], | ||
24 | + 'edit' => [], | ||
25 | + ]; | ||
26 | + | ||
27 | +} |
1 | +<form id="add-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action=""> | ||
2 | + | ||
3 | + <div class="form-group"> | ||
4 | + <label class="control-label col-xs-12 col-sm-2">{:__('Number')}:</label> | ||
5 | + <div class="col-xs-12 col-sm-8"> | ||
6 | + <input id="c-number" class="form-control" name="row[number]" type="text"> | ||
7 | + </div> | ||
8 | + </div> | ||
9 | + <div class="form-group"> | ||
10 | + <label class="control-label col-xs-12 col-sm-2">{:__('Status')}:</label> | ||
11 | + <div class="col-xs-12 col-sm-8"> | ||
12 | + | ||
13 | + <div class="radio"> | ||
14 | + {foreach name="statusList" item="vo"} | ||
15 | + <label for="row[status]-{$key}"><input id="row[status]-{$key}" name="row[status]" type="radio" value="{$key}" {in name="key" value="0"}checked{/in} /> {$vo}</label> | ||
16 | + {/foreach} | ||
17 | + </div> | ||
18 | + | ||
19 | + </div> | ||
20 | + </div> | ||
21 | + <div class="form-group"> | ||
22 | + <label class="control-label col-xs-12 col-sm-2">{:__('Flow')}:</label> | ||
23 | + <div class="col-xs-12 col-sm-8"> | ||
24 | + <input id="c-flow" class="form-control" step="0.001" name="row[flow]" type="number"> | ||
25 | + </div> | ||
26 | + </div> | ||
27 | + <div class="form-group"> | ||
28 | + <label class="control-label col-xs-12 col-sm-2">{:__('Accumulate_flow')}:</label> | ||
29 | + <div class="col-xs-12 col-sm-8"> | ||
30 | + <input id="c-accumulate_flow" class="form-control" step="0.001" name="row[accumulate_flow]" type="number"> | ||
31 | + </div> | ||
32 | + </div> | ||
33 | + <div class="form-group"> | ||
34 | + <label class="control-label col-xs-12 col-sm-2">{:__('Velocity_flow')}:</label> | ||
35 | + <div class="col-xs-12 col-sm-8"> | ||
36 | + <input id="c-velocity_flow" class="form-control" step="0.001" name="row[velocity_flow]" type="number"> | ||
37 | + </div> | ||
38 | + </div> | ||
39 | + <div class="form-group"> | ||
40 | + <label class="control-label col-xs-12 col-sm-2">{:__('Water_level')}:</label> | ||
41 | + <div class="col-xs-12 col-sm-8"> | ||
42 | + <input id="c-water_level" class="form-control" step="0.001" name="row[water_level]" type="number"> | ||
43 | + </div> | ||
44 | + </div> | ||
45 | + <div class="form-group"> | ||
46 | + <label class="control-label col-xs-12 col-sm-2">{:__('Water_level_warning')}:</label> | ||
47 | + <div class="col-xs-12 col-sm-8"> | ||
48 | + | ||
49 | + <select id="c-water_level_warning" class="form-control selectpicker" name="row[water_level_warning]"> | ||
50 | + {foreach name="waterLevelWarningList" item="vo"} | ||
51 | + <option value="{$key}" {in name="key" value="0"}selected{/in}>{$vo}</option> | ||
52 | + {/foreach} | ||
53 | + </select> | ||
54 | + | ||
55 | + </div> | ||
56 | + </div> | ||
57 | + <div class="form-group"> | ||
58 | + <label class="control-label col-xs-12 col-sm-2">{:__('Reporttime')}:</label> | ||
59 | + <div class="col-xs-12 col-sm-8"> | ||
60 | + <input id="c-reporttime" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[reporttime]" type="text" value="{:date('Y-m-d H:i:s')}"> | ||
61 | + </div> | ||
62 | + </div> | ||
63 | + <div class="form-group"> | ||
64 | + <label class="control-label col-xs-12 col-sm-2">{:__('Reservoir_id')}:</label> | ||
65 | + <div class="col-xs-12 col-sm-8"> | ||
66 | + <input id="c-reservoir_id" data-rule="required" data-source="reservoir/index" class="form-control selectpage" name="row[reservoir_id]" type="text" value=""> | ||
67 | + </div> | ||
68 | + </div> | ||
69 | + <div class="form-group"> | ||
70 | + <label class="control-label col-xs-12 col-sm-2">{:__('Issend')}:</label> | ||
71 | + <div class="col-xs-12 col-sm-8"> | ||
72 | + <input id="c-issend" class="form-control" name="row[issend]" type="number" value="0"> | ||
73 | + </div> | ||
74 | + </div> | ||
75 | + <div class="form-group layer-footer"> | ||
76 | + <label class="control-label col-xs-12 col-sm-2"></label> | ||
77 | + <div class="col-xs-12 col-sm-8"> | ||
78 | + <button type="submit" class="btn btn-success btn-embossed disabled">{:__('OK')}</button> | ||
79 | + <button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button> | ||
80 | + </div> | ||
81 | + </div> | ||
82 | +</form> |
1 | +<form id="edit-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action=""> | ||
2 | + | ||
3 | + <div class="form-group"> | ||
4 | + <label class="control-label col-xs-12 col-sm-2">{:__('Number')}:</label> | ||
5 | + <div class="col-xs-12 col-sm-8"> | ||
6 | + <input id="c-number" class="form-control" name="row[number]" type="text" value="{$row.number|htmlentities}"> | ||
7 | + </div> | ||
8 | + </div> | ||
9 | + <div class="form-group"> | ||
10 | + <label class="control-label col-xs-12 col-sm-2">{:__('Status')}:</label> | ||
11 | + <div class="col-xs-12 col-sm-8"> | ||
12 | + | ||
13 | + <div class="radio"> | ||
14 | + {foreach name="statusList" item="vo"} | ||
15 | + <label for="row[status]-{$key}"><input id="row[status]-{$key}" name="row[status]" type="radio" value="{$key}" {in name="key" value="$row.status"}checked{/in} /> {$vo}</label> | ||
16 | + {/foreach} | ||
17 | + </div> | ||
18 | + | ||
19 | + </div> | ||
20 | + </div> | ||
21 | + <div class="form-group"> | ||
22 | + <label class="control-label col-xs-12 col-sm-2">{:__('Flow')}:</label> | ||
23 | + <div class="col-xs-12 col-sm-8"> | ||
24 | + <input id="c-flow" class="form-control" step="0.001" name="row[flow]" type="number" value="{$row.flow|htmlentities}"> | ||
25 | + </div> | ||
26 | + </div> | ||
27 | + <div class="form-group"> | ||
28 | + <label class="control-label col-xs-12 col-sm-2">{:__('Accumulate_flow')}:</label> | ||
29 | + <div class="col-xs-12 col-sm-8"> | ||
30 | + <input id="c-accumulate_flow" class="form-control" step="0.001" name="row[accumulate_flow]" type="number" value="{$row.accumulate_flow|htmlentities}"> | ||
31 | + </div> | ||
32 | + </div> | ||
33 | + <div class="form-group"> | ||
34 | + <label class="control-label col-xs-12 col-sm-2">{:__('Velocity_flow')}:</label> | ||
35 | + <div class="col-xs-12 col-sm-8"> | ||
36 | + <input id="c-velocity_flow" class="form-control" step="0.001" name="row[velocity_flow]" type="number" value="{$row.velocity_flow|htmlentities}"> | ||
37 | + </div> | ||
38 | + </div> | ||
39 | + <div class="form-group"> | ||
40 | + <label class="control-label col-xs-12 col-sm-2">{:__('Water_level')}:</label> | ||
41 | + <div class="col-xs-12 col-sm-8"> | ||
42 | + <input id="c-water_level" class="form-control" step="0.001" name="row[water_level]" type="number" value="{$row.water_level|htmlentities}"> | ||
43 | + </div> | ||
44 | + </div> | ||
45 | + <div class="form-group"> | ||
46 | + <label class="control-label col-xs-12 col-sm-2">{:__('Water_level_warning')}:</label> | ||
47 | + <div class="col-xs-12 col-sm-8"> | ||
48 | + | ||
49 | + <select id="c-water_level_warning" class="form-control selectpicker" name="row[water_level_warning]"> | ||
50 | + {foreach name="waterLevelWarningList" item="vo"} | ||
51 | + <option value="{$key}" {in name="key" value="$row.water_level_warning"}selected{/in}>{$vo}</option> | ||
52 | + {/foreach} | ||
53 | + </select> | ||
54 | + | ||
55 | + </div> | ||
56 | + </div> | ||
57 | + <div class="form-group"> | ||
58 | + <label class="control-label col-xs-12 col-sm-2">{:__('Reporttime')}:</label> | ||
59 | + <div class="col-xs-12 col-sm-8"> | ||
60 | + <input id="c-reporttime" class="form-control datetimepicker" data-date-format="YYYY-MM-DD HH:mm:ss" data-use-current="true" name="row[reporttime]" type="text" value="{:$row.reporttime?datetime($row.reporttime):''}"> | ||
61 | + </div> | ||
62 | + </div> | ||
63 | + <div class="form-group"> | ||
64 | + <label class="control-label col-xs-12 col-sm-2">{:__('Reservoir_id')}:</label> | ||
65 | + <div class="col-xs-12 col-sm-8"> | ||
66 | + <input id="c-reservoir_id" data-rule="required" data-source="reservoir/index" class="form-control selectpage" name="row[reservoir_id]" type="text" value="{$row.reservoir_id|htmlentities}"> | ||
67 | + </div> | ||
68 | + </div> | ||
69 | + <div class="form-group"> | ||
70 | + <label class="control-label col-xs-12 col-sm-2">{:__('Issend')}:</label> | ||
71 | + <div class="col-xs-12 col-sm-8"> | ||
72 | + <input id="c-issend" class="form-control" name="row[issend]" type="number" value="{$row.issend|htmlentities}"> | ||
73 | + </div> | ||
74 | + </div> | ||
75 | + <div class="form-group layer-footer"> | ||
76 | + <label class="control-label col-xs-12 col-sm-2"></label> | ||
77 | + <div class="col-xs-12 col-sm-8"> | ||
78 | + <button type="submit" class="btn btn-success btn-embossed disabled">{:__('OK')}</button> | ||
79 | + <button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button> | ||
80 | + </div> | ||
81 | + </div> | ||
82 | +</form> |
1 | +<div class="panel panel-default panel-intro"> | ||
2 | + | ||
3 | + <div class="panel-heading"> | ||
4 | + {:build_heading(null,FALSE)} | ||
5 | + <ul class="nav nav-tabs" data-field="status"> | ||
6 | + <li class="{:$Think.get.status === null ? 'active' : ''}"><a href="#t-all" data-value="" data-toggle="tab">{:__('All')}</a></li> | ||
7 | + {foreach name="statusList" item="vo"} | ||
8 | + <li class="{:$Think.get.status === (string)$key ? 'active' : ''}"><a href="#t-{$key}" data-value="{$key}" data-toggle="tab">{$vo}</a></li> | ||
9 | + {/foreach} | ||
10 | + </ul> | ||
11 | + </div> | ||
12 | + | ||
13 | + | ||
14 | + <div class="panel-body"> | ||
15 | + <div id="myTabContent" class="tab-content"> | ||
16 | + <div class="tab-pane fade active in" id="one"> | ||
17 | + <div class="widget-body no-padding"> | ||
18 | + <div id="toolbar" class="toolbar"> | ||
19 | + <a href="javascript:;" class="btn btn-primary btn-refresh" title="{:__('Refresh')}" ><i class="fa fa-refresh"></i> </a> | ||
20 | + <a href="javascript:;" class="btn btn-success btn-add {:$auth->check('reservoir_rain_flow/add')?'':'hide'}" title="{:__('Add')}" ><i class="fa fa-plus"></i> {:__('Add')}</a> | ||
21 | + <a href="javascript:;" class="btn btn-success btn-edit btn-disabled disabled {:$auth->check('reservoir_rain_flow/edit')?'':'hide'}" title="{:__('Edit')}" ><i class="fa fa-pencil"></i> {:__('Edit')}</a> | ||
22 | + <a href="javascript:;" class="btn btn-danger btn-del btn-disabled disabled {:$auth->check('reservoir_rain_flow/del')?'':'hide'}" title="{:__('Delete')}" ><i class="fa fa-trash"></i> {:__('Delete')}</a> | ||
23 | + <a href="javascript:;" class="btn btn-danger btn-import {:$auth->check('reservoir_rain_flow/import')?'':'hide'}" title="{:__('Import')}" id="btn-import-file" data-url="ajax/upload" data-mimetype="csv,xls,xlsx" data-multiple="false"><i class="fa fa-upload"></i> {:__('Import')}</a> | ||
24 | + | ||
25 | + <div class="dropdown btn-group {:$auth->check('reservoir_rain_flow/multi')?'':'hide'}"> | ||
26 | + <a class="btn btn-primary btn-more dropdown-toggle btn-disabled disabled" data-toggle="dropdown"><i class="fa fa-cog"></i> {:__('More')}</a> | ||
27 | + <ul class="dropdown-menu text-left" role="menu"> | ||
28 | + <li><a class="btn btn-link btn-multi btn-disabled disabled" href="javascript:;" data-params="status=normal"><i class="fa fa-eye"></i> {:__('Set to normal')}</a></li> | ||
29 | + <li><a class="btn btn-link btn-multi btn-disabled disabled" href="javascript:;" data-params="status=hidden"><i class="fa fa-eye-slash"></i> {:__('Set to hidden')}</a></li> | ||
30 | + </ul> | ||
31 | + </div> | ||
32 | + | ||
33 | + | ||
34 | + </div> | ||
35 | + <table id="table" class="table table-striped table-bordered table-hover table-nowrap" | ||
36 | + data-operate-edit="{:$auth->check('reservoir_rain_flow/edit')}" | ||
37 | + data-operate-del="{:$auth->check('reservoir_rain_flow/del')}" | ||
38 | + width="100%"> | ||
39 | + </table> | ||
40 | + </div> | ||
41 | + </div> | ||
42 | + | ||
43 | + </div> | ||
44 | + </div> | ||
45 | +</div> |
1 | +define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) { | ||
2 | + | ||
3 | + var Controller = { | ||
4 | + index: function () { | ||
5 | + // 初始化表格参数配置 | ||
6 | + Table.api.init({ | ||
7 | + extend: { | ||
8 | + index_url: 'reservoir_rain_flow/index' + location.search, | ||
9 | + add_url: 'reservoir_rain_flow/add', | ||
10 | + edit_url: 'reservoir_rain_flow/edit', | ||
11 | + del_url: 'reservoir_rain_flow/del', | ||
12 | + multi_url: 'reservoir_rain_flow/multi', | ||
13 | + import_url: 'reservoir_rain_flow/import', | ||
14 | + table: 'reservoir_rain_flow', | ||
15 | + } | ||
16 | + }); | ||
17 | + | ||
18 | + var table = $("#table"); | ||
19 | + | ||
20 | + // 初始化表格 | ||
21 | + table.bootstrapTable({ | ||
22 | + url: $.fn.bootstrapTable.defaults.extend.index_url, | ||
23 | + pk: 'id', | ||
24 | + sortName: 'id', | ||
25 | + columns: [ | ||
26 | + [ | ||
27 | + {checkbox: true}, | ||
28 | + {field: 'id', title: __('Id')}, | ||
29 | + {field: 'number', title: __('Number'), operate: 'LIKE'}, | ||
30 | + {field: 'flow', title: __('Flow'), operate:'BETWEEN'}, | ||
31 | + {field: 'accumulate_flow', title: __('Accumulate_flow'), operate:'BETWEEN'}, | ||
32 | + {field: 'reservoirlist.name', title: __('Reservoirlist.name'), operate: 'LIKE'}, | ||
33 | + {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate} | ||
34 | + ] | ||
35 | + ] | ||
36 | + }); | ||
37 | + | ||
38 | + // 为表格绑定事件 | ||
39 | + Table.api.bindevent(table); | ||
40 | + }, | ||
41 | + add: function () { | ||
42 | + Controller.api.bindevent(); | ||
43 | + }, | ||
44 | + edit: function () { | ||
45 | + Controller.api.bindevent(); | ||
46 | + }, | ||
47 | + api: { | ||
48 | + bindevent: function () { | ||
49 | + Form.api.bindevent($("form[role=form]")); | ||
50 | + } | ||
51 | + } | ||
52 | + }; | ||
53 | + return Controller; | ||
54 | +}); |
-
请 注册 或 登录 后发表评论