Commit 7242423dc7576210eebd8709818a6b314c62c888
1 parent
f8d83f1f
添加固件管理
Showing
15 changed files
with
2294 additions
and
45 deletions
WebRoot/WEB-INF/jsp/software/firm/firm_edit.jsp
0 → 100644
1 | +<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> | ||
2 | +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> | ||
3 | +<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%> | ||
4 | +<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> | ||
5 | +<% | ||
6 | + String path = request.getContextPath(); | ||
7 | + String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; | ||
8 | +%> | ||
9 | +<!DOCTYPE html> | ||
10 | +<html lang="en"> | ||
11 | + <head> | ||
12 | + <base href="<%=basePath%>"> | ||
13 | + <!-- 下拉框 --> | ||
14 | + <link rel="stylesheet" href="static/ace/css/chosen.css" /> | ||
15 | + <!-- jsp文件头和头部 --> | ||
16 | + <%@ include file="../../system/index/top.jsp"%> | ||
17 | + <!-- 日期框 --> | ||
18 | + <link rel="stylesheet" href="static/ace/css/datepicker.css" /> | ||
19 | +</head> | ||
20 | +<body class="no-skin"> | ||
21 | +<!-- /section:basics/navbar.layout --> | ||
22 | +<div class="main-container" id="main-container"> | ||
23 | + <!-- /section:basics/sidebar --> | ||
24 | + <div class="main-content"> | ||
25 | + <div class="main-content-inner"> | ||
26 | + <div class="page-content"> | ||
27 | + <div class="row"> | ||
28 | + <div class="col-xs-12"> | ||
29 | + | ||
30 | + <form action="firm/${msg }.do" name="Form" id="Form" method="post" enctype="multipart/form-data"> | ||
31 | + <input type="hidden" name="FIRM_ID" id="FIRM_ID" value="${pd.FIRM_ID}"/> | ||
32 | + <div id="zhongxin" style="padding-top: 13px;"> | ||
33 | + <table id="table_report" class="table table-striped table-bordered table-hover"> | ||
34 | + <tr> | ||
35 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品名称:</td> | ||
36 | + <td> | ||
37 | + <select class="chosen-select form-control" name="PRODUCT_NAME" id="PRODUCT_NAME" data-placeholder="产品名称"> | ||
38 | + <c:forEach var="item" items="${productList}"> | ||
39 | + <option value="${item.PRODUCT_NAME}" <c:if test="${pd.PRODUCT_NAME==item.PRODUCT_NAME}">selected="true"</c:if>>${item.PRODUCT_NAME}</option> | ||
40 | + </c:forEach> | ||
41 | + </select> | ||
42 | + </td> | ||
43 | + </tr> | ||
44 | + <tr> | ||
45 | + <td style="width:75px;text-align: right;padding-top: 13px;">固件版本:</td> | ||
46 | + <td><input type="text" name="FIRM_VERSION" id="FIRM_VERSION" value="${pd.FIRM_VERSION}" maxlength="255" placeholder="这里输入固件版本" title="固件版本" style="width:98%;"/></td> | ||
47 | + </tr> | ||
48 | + <tr> | ||
49 | + <td style="width:75px;text-align: right;padding-top: 13px;">固件版本号:</td> | ||
50 | + <td><input type="number" name="FRIM_CODE" id="FRIM_CODE" value="${pd.FRIM_CODE}" maxlength="32" placeholder="这里输入固件版本号" title="固件版本号" style="width:98%;"/></td> | ||
51 | + </tr> | ||
52 | + <tr> | ||
53 | + <td style="width:75px;text-align: right;padding-top: 13px;">固件路径:</td> | ||
54 | + <td><input type="file" name="FIRM_PATH" style="width:98%;"/></td> | ||
55 | + </tr> | ||
56 | + <tr> | ||
57 | + <td style="width:75px;text-align: right;padding-top: 13px;">固件描述:</td> | ||
58 | + <td><input type="text" name="FIRM_DESC" id="FIRM_DESC" value="${pd.FIRM_DESC}" maxlength="255" placeholder="这里输入固件描述" title="固件描述" style="width:98%;"/></td> | ||
59 | + </tr> | ||
60 | + <tr> | ||
61 | + <td style="text-align: center;" colspan="10"> | ||
62 | + <a class="btn btn-mini btn-primary" onclick="save();">保存</a> | ||
63 | + <a class="btn btn-mini btn-danger" onclick="top.Dialog.close();">取消</a> | ||
64 | + </td> | ||
65 | + </tr> | ||
66 | + </table> | ||
67 | + </div> | ||
68 | + <div id="zhongxin2" class="center" style="display:none"><br/><br/><br/><br/><br/><img src="static/images/jiazai.gif" /><br/><h4 class="lighter block green">提交中...</h4></div> | ||
69 | + </form> | ||
70 | + </div> | ||
71 | + <!-- /.col --> | ||
72 | + </div> | ||
73 | + <!-- /.row --> | ||
74 | + </div> | ||
75 | + <!-- /.page-content --> | ||
76 | + </div> | ||
77 | + </div> | ||
78 | + <!-- /.main-content --> | ||
79 | +</div> | ||
80 | +<!-- /.main-container --> | ||
81 | + | ||
82 | + | ||
83 | + <!-- 页面底部js¨ --> | ||
84 | + <%@ include file="../../system/index/foot.jsp"%> | ||
85 | + <!-- 下拉框 --> | ||
86 | + <script src="static/ace/js/chosen.jquery.js"></script> | ||
87 | + <!-- 日期框 --> | ||
88 | + <script src="static/ace/js/date-time/bootstrap-datepicker.js"></script> | ||
89 | + <!--提示框--> | ||
90 | + <script type="text/javascript" src="static/js/jquery.tips.js"></script> | ||
91 | + <script type="text/javascript"> | ||
92 | + $(top.hangge()); | ||
93 | + //保存 | ||
94 | + function save(){ | ||
95 | + if($("#PRODUCT_NAME").val()==""){ | ||
96 | + $("#PRODUCT_NAME").tips({ | ||
97 | + side:3, | ||
98 | + msg:'请输入产品名称', | ||
99 | + bg:'#AE81FF', | ||
100 | + time:2 | ||
101 | + }); | ||
102 | + $("#PRODUCT_NAME").focus(); | ||
103 | + return false; | ||
104 | + } | ||
105 | + if($("#FIRM_VERSION").val()==""){ | ||
106 | + $("#FIRM_VERSION").tips({ | ||
107 | + side:3, | ||
108 | + msg:'请输入固件版本', | ||
109 | + bg:'#AE81FF', | ||
110 | + time:2 | ||
111 | + }); | ||
112 | + $("#FIRM_VERSION").focus(); | ||
113 | + return false; | ||
114 | + } | ||
115 | + if($("#FRIM_CODE").val()==""){ | ||
116 | + $("#FRIM_CODE").tips({ | ||
117 | + side:3, | ||
118 | + msg:'请输入固件版本号', | ||
119 | + bg:'#AE81FF', | ||
120 | + time:2 | ||
121 | + }); | ||
122 | + $("#FRIM_CODE").focus(); | ||
123 | + return false; | ||
124 | + } | ||
125 | + if($("#FIRM_PATH").val()==""){ | ||
126 | + $("#FIRM_PATH").tips({ | ||
127 | + side:3, | ||
128 | + msg:'请输入固件路径', | ||
129 | + bg:'#AE81FF', | ||
130 | + time:2 | ||
131 | + }); | ||
132 | + $("#FIRM_PATH").focus(); | ||
133 | + return false; | ||
134 | + } | ||
135 | + if($("#FIRM_DESC").val()==""){ | ||
136 | + $("#FIRM_DESC").tips({ | ||
137 | + side:3, | ||
138 | + msg:'请输入固件描述', | ||
139 | + bg:'#AE81FF', | ||
140 | + time:2 | ||
141 | + }); | ||
142 | + $("#FIRM_DESC").focus(); | ||
143 | + return false; | ||
144 | + } | ||
145 | + $("#Form").submit(); | ||
146 | + $("#zhongxin").hide(); | ||
147 | + $("#zhongxin2").show(); | ||
148 | + } | ||
149 | + | ||
150 | + $(function() { | ||
151 | + //日期框 | ||
152 | + $('.date-picker').datepicker({autoclose: true,todayHighlight: true}); | ||
153 | + }); | ||
154 | + </script> | ||
155 | +</body> | ||
156 | +</html> | ||
0 | \ No newline at end of file | 157 | \ No newline at end of file |
WebRoot/WEB-INF/jsp/software/firm/firm_list.jsp
0 → 100644
1 | +<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> | ||
2 | +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> | ||
3 | +<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%> | ||
4 | +<% | ||
5 | + String path = request.getContextPath(); | ||
6 | + String basePath = request.getScheme() + "://" | ||
7 | + + request.getServerName() + ":" + request.getServerPort() | ||
8 | + + path + "/"; | ||
9 | +%> | ||
10 | +<!DOCTYPE html> | ||
11 | +<html lang="en"> | ||
12 | +<head> | ||
13 | +<base href="<%=basePath%>"> | ||
14 | +<!-- 下拉框 --> | ||
15 | +<link rel="stylesheet" href="static/ace/css/chosen.css" /> | ||
16 | +<!-- jsp文件头和头部 --> | ||
17 | +<%@ include file="../../system/index/top.jsp"%> | ||
18 | +<!-- 日期框 --> | ||
19 | +<link rel="stylesheet" href="static/ace/css/datepicker.css" /> | ||
20 | +</head> | ||
21 | +<body class="no-skin"> | ||
22 | + | ||
23 | + <!-- /section:basics/navbar.layout --> | ||
24 | + <div class="main-container" id="main-container"> | ||
25 | + <!-- /section:basics/sidebar --> | ||
26 | + <div class="main-content"> | ||
27 | + <div class="main-content-inner"> | ||
28 | + <div class="page-content"> | ||
29 | + <div class="row"> | ||
30 | + <div class="col-xs-12"> | ||
31 | + | ||
32 | + <!-- 检索 --> | ||
33 | + <form action="firm/list.do" method="post" name="Form" id="Form"> | ||
34 | + <table style="margin-top:5px;"> | ||
35 | + <tr> | ||
36 | + <td style="vertical-align:top;padding-left:2px;"> | ||
37 | + <select class="chosen-select form-control" name="PRODUCT_NAME" id="PRODUCT_NAME" data-placeholder="请选择" style="vertical-align:top;width: 120px;"> | ||
38 | + <option value="">全部</option> | ||
39 | + <c:forEach var="item" items="${productList}"> | ||
40 | + <option value="${item.PRODUCT_NAME}" >${item.PRODUCT_NAME}</option> | ||
41 | + </c:forEach> | ||
42 | + </select> | ||
43 | + </td> | ||
44 | + <c:if test="${QX.cha == 1 }"> | ||
45 | + <td style="vertical-align:top;padding-left:2px"><a class="btn btn-light btn-xs" onclick="tosearch();" title="检索"><i id="nav-search-icon" class="ace-icon fa fa-search bigger-110 nav-search-icon blue"></i></a></td> | ||
46 | + </c:if> | ||
47 | + </tr> | ||
48 | + </table> | ||
49 | + <!-- 检索 --> | ||
50 | + | ||
51 | + <table id="simple-table" class="table table-striped table-bordered table-hover" style="margin-top:5px;"> | ||
52 | + <thead> | ||
53 | + <tr> | ||
54 | + <th class="center" style="width:35px;"> | ||
55 | + <label class="pos-rel"><input type="checkbox" class="ace" id="zcheckbox" /><span class="lbl"></span></label> | ||
56 | + </th> | ||
57 | + <th class="center" style="width:50px;">序号</th> | ||
58 | + <th class="center">产品名称</th> | ||
59 | + <th class="center">固件版本</th> | ||
60 | + <th class="center">固件版本号</th> | ||
61 | + <th class="center">固件文件</th> | ||
62 | + <th class="center">固件描述</th> | ||
63 | + <th class="center">操作</th> | ||
64 | + </tr> | ||
65 | + </thead> | ||
66 | + | ||
67 | + <tbody> | ||
68 | + <!-- 开始循环 --> | ||
69 | + <c:choose> | ||
70 | + <c:when test="${not empty varList}"> | ||
71 | + <c:if test="${QX.cha == 1 }"> | ||
72 | + <c:forEach items="${varList}" var="var" varStatus="vs"> | ||
73 | + <tr> | ||
74 | + <td class='center'> | ||
75 | + <label class="pos-rel"><input type='checkbox' name='ids' value="${var.FIRM_ID}" class="ace" /><span class="lbl"></span></label> | ||
76 | + </td> | ||
77 | + <td class='center' style="width: 30px;">${vs.index+1}</td> | ||
78 | + <td class='center'>${var.PRODUCT_NAME}</td> | ||
79 | + <td class='center'>${var.FIRM_VERSION}</td> | ||
80 | + <td class='center'>${var.FRIM_CODE}</td> | ||
81 | + <td class='center'><a target= '_blank' href='<%=basePath %>uploadFiles/uploadFile/${var.FIRM_PATH}'>下载</a> </td> | ||
82 | + <td class='center'>${var.FIRM_DESC}</td> | ||
83 | + <td class="center"> | ||
84 | + <c:if test="${QX.edit != 1 && QX.del != 1 }"> | ||
85 | + <span class="label label-large label-grey arrowed-in-right arrowed-in"><i class="ace-icon fa fa-lock" title="无权限"></i></span> | ||
86 | + </c:if> | ||
87 | + <div class="hidden-sm hidden-xs btn-group"> | ||
88 | + <c:if test="${QX.edit == 1 }"> | ||
89 | + <a class="btn btn-xs btn-success" title="编辑" onclick="edit('${var.FIRM_ID}');"> | ||
90 | + <i class="ace-icon fa fa-pencil-square-o bigger-120" title="编辑"></i> | ||
91 | + </a> | ||
92 | + </c:if> | ||
93 | + <c:if test="${QX.del == 1 }"> | ||
94 | + <a class="btn btn-xs btn-danger" onclick="del('${var.FIRM_ID}','${var.FIRM_PATH}');"> | ||
95 | + <i class="ace-icon fa fa-trash-o bigger-120" title="删除"></i> | ||
96 | + </a> | ||
97 | + </c:if> | ||
98 | + </div> | ||
99 | + <div class="hidden-md hidden-lg"> | ||
100 | + <div class="inline pos-rel"> | ||
101 | + <button class="btn btn-minier btn-primary dropdown-toggle" data-toggle="dropdown" data-position="auto"> | ||
102 | + <i class="ace-icon fa fa-cog icon-only bigger-110"></i> | ||
103 | + </button> | ||
104 | + | ||
105 | + <ul class="dropdown-menu dropdown-only-icon dropdown-yellow dropdown-menu-right dropdown-caret dropdown-close"> | ||
106 | + <c:if test="${QX.edit == 1 }"> | ||
107 | + <li> | ||
108 | + <a style="cursor:pointer;" onclick="edit('${var.FIRM_ID}');" class="tooltip-success" data-rel="tooltip" title="修改"> | ||
109 | + <span class="green"> | ||
110 | + <i class="ace-icon fa fa-pencil-square-o bigger-120"></i> | ||
111 | + </span> | ||
112 | + </a> | ||
113 | + </li> | ||
114 | + </c:if> | ||
115 | + <c:if test="${QX.del == 1 }"> | ||
116 | + <li> | ||
117 | + <a style="cursor:pointer;" onclick="del('${var.FIRM_ID}','${var.FIRM_PATH}');" class="tooltip-error" data-rel="tooltip" title="删除"> | ||
118 | + <span class="red"> | ||
119 | + <i class="ace-icon fa fa-trash-o bigger-120"></i> | ||
120 | + </span> | ||
121 | + </a> | ||
122 | + </li> | ||
123 | + </c:if> | ||
124 | + </ul> | ||
125 | + </div> | ||
126 | + </div> | ||
127 | + </td> | ||
128 | + </tr> | ||
129 | + | ||
130 | + </c:forEach> | ||
131 | + </c:if> | ||
132 | + <c:if test="${QX.cha == 0 }"> | ||
133 | + <tr> | ||
134 | + <td colspan="100" class="center">您无权查看</td> | ||
135 | + </tr> | ||
136 | + </c:if> | ||
137 | + </c:when> | ||
138 | + <c:otherwise> | ||
139 | + <tr class="main_info"> | ||
140 | + <td colspan="100" class="center" >没有相关数据</td> | ||
141 | + </tr> | ||
142 | + </c:otherwise> | ||
143 | + </c:choose> | ||
144 | + </tbody> | ||
145 | + </table> | ||
146 | + <div class="page-header position-relative"> | ||
147 | + <table style="width:100%;"> | ||
148 | + <tr> | ||
149 | + <td style="vertical-align:top;"> | ||
150 | + <c:if test="${QX.add == 1 }"> | ||
151 | + <a class="btn btn-mini btn-success" onclick="add();">新增</a> | ||
152 | + </c:if> | ||
153 | + <c:if test="${QX.del == 1 }"> | ||
154 | + <a class="btn btn-mini btn-danger" onclick="makeAll('确定要删除选中的数据吗?');" title="批量删除" ><i class='ace-icon fa fa-trash-o bigger-120'></i></a> | ||
155 | + </c:if> | ||
156 | + </td> | ||
157 | + <td style="vertical-align:top;"><div class="pagination" style="float: right;padding-top: 0px;margin-top: 0px;">${page.pageStr}</div></td> | ||
158 | + </tr> | ||
159 | + </table> | ||
160 | + </div> | ||
161 | + </form> | ||
162 | + | ||
163 | + </div> | ||
164 | + <!-- /.col --> | ||
165 | + </div> | ||
166 | + <!-- /.row --> | ||
167 | + </div> | ||
168 | + <!-- /.page-content --> | ||
169 | + </div> | ||
170 | + </div> | ||
171 | + <!-- /.main-content --> | ||
172 | + | ||
173 | + <!-- 返回顶部 --> | ||
174 | + <a href="#" id="btn-scroll-up" class="btn-scroll-up btn btn-sm btn-inverse"> | ||
175 | + <i class="ace-icon fa fa-angle-double-up icon-only bigger-110"></i> | ||
176 | + </a> | ||
177 | + | ||
178 | + </div> | ||
179 | + <!-- /.main-container --> | ||
180 | + | ||
181 | + <!-- basic scripts --> | ||
182 | + <!-- 页面底部js¨ --> | ||
183 | + <%@ include file="../../system/index/foot.jsp"%> | ||
184 | + <!-- 删除时确认窗口 --> | ||
185 | + <script src="static/ace/js/bootbox.js"></script> | ||
186 | + <!-- ace scripts --> | ||
187 | + <script src="static/ace/js/ace/ace.js"></script> | ||
188 | + <!-- 下拉框 --> | ||
189 | + <script src="static/ace/js/chosen.jquery.js"></script> | ||
190 | + <!-- 日期框 --> | ||
191 | + <script src="static/ace/js/date-time/bootstrap-datepicker.js"></script> | ||
192 | + <!--提示框--> | ||
193 | + <script type="text/javascript" src="static/js/jquery.tips.js"></script> | ||
194 | + <script type="text/javascript"> | ||
195 | + $(top.hangge());//关闭加载状态 | ||
196 | + //检索 | ||
197 | + function tosearch(){ | ||
198 | + top.jzts(); | ||
199 | + $("#Form").submit(); | ||
200 | + } | ||
201 | + $(function() { | ||
202 | + | ||
203 | + //日期框 | ||
204 | + $('.date-picker').datepicker({ | ||
205 | + autoclose: true, | ||
206 | + todayHighlight: true | ||
207 | + }); | ||
208 | + | ||
209 | + //下拉框 | ||
210 | + if(!ace.vars['touch']) { | ||
211 | + $('.chosen-select').chosen({allow_single_deselect:true}); | ||
212 | + $(window) | ||
213 | + .off('resize.chosen') | ||
214 | + .on('resize.chosen', function() { | ||
215 | + $('.chosen-select').each(function() { | ||
216 | + var $this = $(this); | ||
217 | + $this.next().css({'width': $this.parent().width()}); | ||
218 | + }); | ||
219 | + }).trigger('resize.chosen'); | ||
220 | + $(document).on('settings.ace.chosen', function(e, event_name, event_val) { | ||
221 | + if(event_name != 'sidebar_collapsed') return; | ||
222 | + $('.chosen-select').each(function() { | ||
223 | + var $this = $(this); | ||
224 | + $this.next().css({'width': $this.parent().width()}); | ||
225 | + }); | ||
226 | + }); | ||
227 | + $('#chosen-multiple-style .btn').on('click', function(e){ | ||
228 | + var target = $(this).find('input[type=radio]'); | ||
229 | + var which = parseInt(target.val()); | ||
230 | + if(which == 2) $('#form-field-select-4').addClass('tag-input-style'); | ||
231 | + else $('#form-field-select-4').removeClass('tag-input-style'); | ||
232 | + }); | ||
233 | + } | ||
234 | + | ||
235 | + | ||
236 | + //复选框全选控制 | ||
237 | + var active_class = 'active'; | ||
238 | + $('#simple-table > thead > tr > th input[type=checkbox]').eq(0).on('click', function(){ | ||
239 | + var th_checked = this.checked;//checkbox inside "TH" table header | ||
240 | + $(this).closest('table').find('tbody > tr').each(function(){ | ||
241 | + var row = this; | ||
242 | + if(th_checked) $(row).addClass(active_class).find('input[type=checkbox]').eq(0).prop('checked', true); | ||
243 | + else $(row).removeClass(active_class).find('input[type=checkbox]').eq(0).prop('checked', false); | ||
244 | + }); | ||
245 | + }); | ||
246 | + }); | ||
247 | + | ||
248 | + //新增 | ||
249 | + function add(){ | ||
250 | + top.jzts(); | ||
251 | + var diag = new top.Dialog(); | ||
252 | + diag.Drag=true; | ||
253 | + diag.Title ="新增"; | ||
254 | + diag.URL = '<%=basePath%>firm/goAdd.do'; | ||
255 | + diag.Width = 450; | ||
256 | + diag.Height = 355; | ||
257 | + diag.Modal = true; //有无遮罩窗口 | ||
258 | + diag. ShowMaxButton = true; //最大化按钮 | ||
259 | + diag.ShowMinButton = true; //最小化按钮 | ||
260 | + diag.CancelEvent = function(){ //关闭事件 | ||
261 | + if(diag.innerFrame.contentWindow.document.getElementById('zhongxin').style.display == 'none'){ | ||
262 | + if('${page.currentPage}' == '0'){ | ||
263 | + tosearch(); | ||
264 | + }else{ | ||
265 | + tosearch(); | ||
266 | + } | ||
267 | + } | ||
268 | + diag.close(); | ||
269 | + }; | ||
270 | + diag.show(); | ||
271 | + } | ||
272 | + | ||
273 | + //删除 | ||
274 | + function del(Id,path){ | ||
275 | + bootbox.confirm("确定要删除吗?", function(result) { | ||
276 | + if(result) { | ||
277 | + top.jzts(); | ||
278 | + var url = "<%=basePath%>firm/delete.do?FIRM_ID="+Id+"&firm_path=" + path + "&tm="+new Date().getTime(); | ||
279 | + $.get(url,function(data){ | ||
280 | + tosearch(); | ||
281 | + }); | ||
282 | + } | ||
283 | + }); | ||
284 | + } | ||
285 | + | ||
286 | + //修改 | ||
287 | + function edit(Id){ | ||
288 | + top.jzts(); | ||
289 | + var diag = new top.Dialog(); | ||
290 | + diag.Drag=true; | ||
291 | + diag.Title ="编辑"; | ||
292 | + diag.URL = '<%=basePath%>firm/goEdit.do?FIRM_ID='+Id; | ||
293 | + diag.Width = 450; | ||
294 | + diag.Height = 355; | ||
295 | + diag.Modal = true; //有无遮罩窗口 | ||
296 | + diag. ShowMaxButton = true; //最大化按钮 | ||
297 | + diag.ShowMinButton = true; //最小化按钮 | ||
298 | + diag.CancelEvent = function(){ //关闭事件 | ||
299 | + if(diag.innerFrame.contentWindow.document.getElementById('zhongxin').style.display == 'none'){ | ||
300 | + tosearch(); | ||
301 | + } | ||
302 | + diag.close(); | ||
303 | + }; | ||
304 | + diag.show(); | ||
305 | + } | ||
306 | + | ||
307 | + //批量操作 | ||
308 | + function makeAll(msg){ | ||
309 | + bootbox.confirm(msg, function(result) { | ||
310 | + if(result) { | ||
311 | + var str = ''; | ||
312 | + for(var i=0;i < document.getElementsByName('ids').length;i++){ | ||
313 | + if(document.getElementsByName('ids')[i].checked){ | ||
314 | + if(str=='') str += document.getElementsByName('ids')[i].value; | ||
315 | + else str += ',' + document.getElementsByName('ids')[i].value; | ||
316 | + } | ||
317 | + } | ||
318 | + if(str==''){ | ||
319 | + bootbox.dialog({ | ||
320 | + message: "<span class='bigger-110'>您没有选择任何内容!</span>", | ||
321 | + buttons: | ||
322 | + { "button":{ "label":"确定", "className":"btn-sm btn-success"}} | ||
323 | + }); | ||
324 | + $("#zcheckbox").tips({ | ||
325 | + side:1, | ||
326 | + msg:'点这里全选', | ||
327 | + bg:'#AE81FF', | ||
328 | + time:8 | ||
329 | + }); | ||
330 | + return; | ||
331 | + }else{ | ||
332 | + if(msg == '确定要删除选中的数据吗?'){ | ||
333 | + top.jzts(); | ||
334 | + $.ajax({ | ||
335 | + type: "POST", | ||
336 | + url: '<%=basePath%>firm/deleteAll.do?tm='+new Date().getTime(), | ||
337 | + data: {DATA_IDS:str}, | ||
338 | + dataType:'json', | ||
339 | + //beforeSend: validateData, | ||
340 | + cache: false, | ||
341 | + success: function(data){ | ||
342 | + $.each(data.list, function(i, list){ | ||
343 | + tosearch(); | ||
344 | + }); | ||
345 | + } | ||
346 | + }); | ||
347 | + } | ||
348 | + } | ||
349 | + } | ||
350 | + }); | ||
351 | + }; | ||
352 | + | ||
353 | + //导出excel | ||
354 | + function toExcel(){ | ||
355 | + window.location.href='<%=basePath%>firm/excel.do'; | ||
356 | + } | ||
357 | + </script> | ||
358 | + | ||
359 | + | ||
360 | +</body> | ||
361 | +</html> | ||
0 | \ No newline at end of file | 362 | \ No newline at end of file |
WebRoot/WEB-INF/jsp/software/firmware/firmware_edit.jsp
0 → 100644
1 | +<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> | ||
2 | +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> | ||
3 | +<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%> | ||
4 | +<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %> | ||
5 | +<% | ||
6 | + String path = request.getContextPath(); | ||
7 | + String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; | ||
8 | +%> | ||
9 | +<!DOCTYPE html> | ||
10 | +<html lang="en"> | ||
11 | + <head> | ||
12 | + <base href="<%=basePath%>"> | ||
13 | + <!-- 下拉框 --> | ||
14 | + <link rel="stylesheet" href="static/ace/css/chosen.css" /> | ||
15 | + <!-- jsp文件头和头部 --> | ||
16 | + <%@ include file="../../system/index/top.jsp"%> | ||
17 | + <!-- 日期框 --> | ||
18 | + <link rel="stylesheet" href="static/ace/css/datepicker.css" /> | ||
19 | +</head> | ||
20 | +<body class="no-skin"> | ||
21 | +<!-- /section:basics/navbar.layout --> | ||
22 | +<div class="main-container" id="main-container"> | ||
23 | + <!-- /section:basics/sidebar --> | ||
24 | + <div class="main-content"> | ||
25 | + <div class="main-content-inner"> | ||
26 | + <div class="page-content"> | ||
27 | + <div class="row"> | ||
28 | + <div class="col-xs-12"> | ||
29 | + | ||
30 | + <form action="firmware/${msg }.do" name="Form" id="Form" method="post" enctype="multipart/form-data"> | ||
31 | + <input type="hidden" name="FIRMWARE_ID" id="FIRMWARE_ID" value="${pd.FIRMWARE_ID}"/> | ||
32 | + <div id="zhongxin" style="padding-top: 13px;"> | ||
33 | + <table id="table_report" class="table table-striped table-bordered table-hover"> | ||
34 | + <tr> | ||
35 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品名称:</td> | ||
36 | + <td><input type="text" name="PRODUCT_NAME" id="PRODUCT_NAME" value="${pd.PRODUCT_NAME}" maxlength="255" placeholder="这里输入产品名称" title="产品名称" style="width:98%;"/></td> | ||
37 | + </tr> | ||
38 | + <tr> | ||
39 | + <td style="width:75px;text-align: right;padding-top: 13px;">货品编号:</td> | ||
40 | + <td><input type="text" name="PRODUCT_NO" id="PRODUCT_NO" value="${pd.PRODUCT_NO}" maxlength="255" placeholder="这里输入货品编号" title="货品编号" style="width:98%;"/></td> | ||
41 | + </tr> | ||
42 | + <tr> | ||
43 | + <td style="width:75px;text-align: right;padding-top: 13px;">应用行业:</td> | ||
44 | + <td> | ||
45 | + <select class="chosen-select form-control" name="INDUSTRY" id="INDUSTRY" data-placeholder="请选择" style="vertical-align:top;width:98%;"> | ||
46 | + <option value="教育" <c:if test="${pd.INDUSTRY eq '教育'}">selected="true"</c:if>>教育</option> | ||
47 | + <option value="企业" <c:if test="${pd.INDUSTRY eq '企业'}">selected="true"</c:if>>企业</option> | ||
48 | + <option value="政府" <c:if test="${pd.INDUSTRY eq '政府'}">selected="true"</c:if>>政府</option> | ||
49 | + <option value="其他" <c:if test="${pd.INDUSTRY eq '其他'}">selected="true"</c:if>>其他</option> | ||
50 | + </select> | ||
51 | + </td> | ||
52 | + </tr> | ||
53 | + <tr> | ||
54 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品状态:</td> | ||
55 | + <td> | ||
56 | + <select class="chosen-select form-control" name="PRODUCT_STATE" id="PRODUCT_STATE" data-placeholder="请选择" style="vertical-align:top;width:98%;"> | ||
57 | + <option value="产品销售" <c:if test="${pd.PRODUCT_STATE eq '产品销售'}">selected="true"</c:if>>产品销售</option> | ||
58 | + <option value="产品发布" <c:if test="${pd.PRODUCT_STATE eq '产品发布'}">selected="true"</c:if>>产品发布</option> | ||
59 | + <option value="产品研制" <c:if test="${pd.PRODUCT_STATE eq '产品研制'}">selected="true"</c:if>>产品研制</option> | ||
60 | + <option value="其他" <c:if test="${pd.PRODUCT_STATE eq '其他'}">selected="true"</c:if>>其他</option> | ||
61 | + </select> | ||
62 | + </td> | ||
63 | + </tr> | ||
64 | + <tr> | ||
65 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品规格:</td> | ||
66 | + <td><input type="text" name="PRODUCT_SPEC" id="PRODUCT_SPEC" value="${pd.PRODUCT_SPEC}" maxlength="255" placeholder="这里输入产品规格" title="产品规格" style="width:98%;"/></td> | ||
67 | + </tr> | ||
68 | + <tr> | ||
69 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品功能:</td> | ||
70 | + <td><input type="text" name="PRODUCT_FUNC" id="PRODUCT_FUNC" value="${pd.PRODUCT_FUNC}" maxlength="1000" placeholder="这里输入产品功能" title="产品功能" style="width:98%;"/></td> | ||
71 | + </tr> | ||
72 | + <tr> | ||
73 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品性能:</td> | ||
74 | + <td><input type="text" name="PRODUCT_PERF" id="PRODUCT_PERF" value="${pd.PRODUCT_PERF}" maxlength="255" placeholder="这里输入产品性能" title="产品性能" style="width:98%;"/></td> | ||
75 | + </tr> | ||
76 | + <tr> | ||
77 | + <td style="width:75px;text-align: right;padding-top: 13px;">适配硬件:</td> | ||
78 | + <td><input type="text" name="ADAPTABLE_HARDWARE" id="ADAPTABLE_HARDWARE" value="${pd.ADAPTABLE_HARDWARE}" maxlength="500" placeholder="这里输入适配硬件" title="适配硬件" style="width:98%;"/></td> | ||
79 | + </tr> | ||
80 | + <tr> | ||
81 | + <td style="width:75px;text-align: right;padding-top: 13px;">适配软件:</td> | ||
82 | + <td><input type="text" name="ADAPTABLE_SOFTWARE" id="ADAPTABLE_SOFTWARE" value="${pd.ADAPTABLE_SOFTWARE}" maxlength="255" placeholder="这里输入适配软件" title="适配软件" style="width:98%;"/></td> | ||
83 | + </tr> | ||
84 | + <tr> | ||
85 | + <td style="width:75px;text-align: right;padding-top: 13px;">产品认证:</td> | ||
86 | + <td><input type="text" name="PRODUCT_CERT" id="PRODUCT_CERT" value="${pd.PRODUCT_CERT}" maxlength="255" placeholder="这里输入产品认证" title="产品认证" style="width:98%;"/></td> | ||
87 | + </tr> | ||
88 | + <tr> | ||
89 | + <td style="width:75px;text-align: right;padding-top: 13px;">注意事项:</td> | ||
90 | + <td><input type="text" name="REMARK" id="REMARK" value="${pd.REMARK}" maxlength="255" placeholder="这里输入注意事项" title="注意事项" style="width:98%;"/> | ||
91 | + </td> | ||
92 | + </tr> | ||
93 | + <tr> | ||
94 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片1:</td> | ||
95 | + <td> | ||
96 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[0]}"/>${pd.PRODUCT_IMAGE[0]} | ||
97 | + <input type="hidden" name="PRODUCT_IMAGE0" id="PRODUCT_IMAGE0" value="${pd.PRODUCT_IMAGE[0]}"/> | ||
98 | + </td> | ||
99 | + </tr> | ||
100 | + <tr> | ||
101 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片2:</td> | ||
102 | + <td> | ||
103 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[1]}"/>${pd.PRODUCT_IMAGE[1]} | ||
104 | + <input type="hidden" name="PRODUCT_IMAGE1" id="PRODUCT_IMAGE1" value="${pd.PRODUCT_IMAGE[1]}"/> | ||
105 | + </td> | ||
106 | + </tr> | ||
107 | + <tr> | ||
108 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片3:</td> | ||
109 | + <td> | ||
110 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[2]}"/>${pd.PRODUCT_IMAGE[2]} | ||
111 | + <input type="hidden" name="PRODUCT_IMAGE2" id="PRODUCT_IMAGE2" value="${pd.PRODUCT_IMAGE[2]}"/> | ||
112 | + </td> | ||
113 | + </tr> | ||
114 | + <tr> | ||
115 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片4:</td> | ||
116 | + <td> | ||
117 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[3]}"/>${pd.PRODUCT_IMAGE[3]} | ||
118 | + <input type="hidden" name="PRODUCT_IMAGE3" id="PRODUCT_IMAGE3" value="${pd.PRODUCT_IMAGE[3]}"/> | ||
119 | + </td> | ||
120 | + | ||
121 | + </tr> | ||
122 | + <tr> | ||
123 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片5:</td> | ||
124 | + <td> | ||
125 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[4]}"/>${pd.PRODUCT_IMAGE[4]} | ||
126 | + <input type="hidden" name="PRODUCT_IMAGE4" id="PRODUCT_IMAGE4" value="${pd.PRODUCT_IMAGE[4]}"/> | ||
127 | + </td> | ||
128 | + </tr> | ||
129 | + <tr> | ||
130 | + <td style="width:75px;text-align: right;padding-top: 13px;">照片6:</td> | ||
131 | + <td> | ||
132 | + <input type="file" name="PRODUCT_IMAGE" id="PRODUCT_IMAGE" value="${pd.PRODUCT_IMAGE[5]}"/>${pd.PRODUCT_IMAGE[5]} | ||
133 | + <input type="hidden" name="PRODUCT_IMAGE5" id="PRODUCT_IMAGE5" value="${pd.PRODUCT_IMAGE[5]}"/> | ||
134 | + </td> | ||
135 | + </tr> | ||
136 | + <tr> | ||
137 | + <td style="text-align: center;" colspan="10"> | ||
138 | + <a class="btn btn-mini btn-primary" onclick="save();">保存</a> | ||
139 | + <a class="btn btn-mini btn-danger" onclick="top.Dialog.close();">取消</a> | ||
140 | + </td> | ||
141 | + </tr> | ||
142 | + </table> | ||
143 | + </div> | ||
144 | + <div id="zhongxin2" class="center" style="display:none"><br/><br/><br/><br/><br/><img src="static/images/jiazai.gif" /><br/><h4 class="lighter block green">提交中...</h4></div> | ||
145 | + </form> | ||
146 | + </div> | ||
147 | + <!-- /.col --> | ||
148 | + </div> | ||
149 | + <!-- /.row --> | ||
150 | + </div> | ||
151 | + <!-- /.page-content --> | ||
152 | + </div> | ||
153 | + </div> | ||
154 | + <!-- /.main-content --> | ||
155 | +</div> | ||
156 | +<!-- /.main-container --> | ||
157 | + | ||
158 | + | ||
159 | + <!-- 页面底部js¨ --> | ||
160 | + <%@ include file="../../system/index/foot.jsp"%> | ||
161 | + <!-- 下拉框 --> | ||
162 | + <script src="static/ace/js/chosen.jquery.js"></script> | ||
163 | + <!-- 日期框 --> | ||
164 | + <script src="static/ace/js/date-time/bootstrap-datepicker.js"></script> | ||
165 | + <!--提示框--> | ||
166 | + <script type="text/javascript" src="static/js/jquery.tips.js"></script> | ||
167 | + <script type="text/javascript"> | ||
168 | + $(top.hangge()); | ||
169 | + //保存 | ||
170 | + function save(){ | ||
171 | + if($("#PRODUCT_NAME").val()==""){ | ||
172 | + $("#PRODUCT_NAME").tips({ | ||
173 | + side:3, | ||
174 | + msg:'请输入产品名称', | ||
175 | + bg:'#AE81FF', | ||
176 | + time:2 | ||
177 | + }); | ||
178 | + $("#PRODUCT_NAME").focus(); | ||
179 | + return false; | ||
180 | + } | ||
181 | + if($("#PRODUCT_NO").val()==""){ | ||
182 | + $("#PRODUCT_NO").tips({ | ||
183 | + side:3, | ||
184 | + msg:'请输入货品编号', | ||
185 | + bg:'#AE81FF', | ||
186 | + time:2 | ||
187 | + }); | ||
188 | + $("#PRODUCT_NO").focus(); | ||
189 | + return false; | ||
190 | + } | ||
191 | + if($("#INDUSTRY").val()==""){ | ||
192 | + $("#INDUSTRY").tips({ | ||
193 | + side:3, | ||
194 | + msg:'请输入应用行业', | ||
195 | + bg:'#AE81FF', | ||
196 | + time:2 | ||
197 | + }); | ||
198 | + $("#INDUSTRY").focus(); | ||
199 | + return false; | ||
200 | + } | ||
201 | + if($("#PRODUCT_STATE").val()==""){ | ||
202 | + $("#PRODUCT_STATE").tips({ | ||
203 | + side:3, | ||
204 | + msg:'请输入产品状态', | ||
205 | + bg:'#AE81FF', | ||
206 | + time:2 | ||
207 | + }); | ||
208 | + $("#PRODUCT_STATE").focus(); | ||
209 | + return false; | ||
210 | + } | ||
211 | + if($("#PRODUCT_SPEC").val()==""){ | ||
212 | + $("#PRODUCT_SPEC").tips({ | ||
213 | + side:3, | ||
214 | + msg:'请输入产品规格', | ||
215 | + bg:'#AE81FF', | ||
216 | + time:2 | ||
217 | + }); | ||
218 | + $("#PRODUCT_SPEC").focus(); | ||
219 | + return false; | ||
220 | + } | ||
221 | + if($("#PRODUCT_FUNC").val()==""){ | ||
222 | + $("#PRODUCT_FUNC").tips({ | ||
223 | + side:3, | ||
224 | + msg:'请输入产品功能', | ||
225 | + bg:'#AE81FF', | ||
226 | + time:2 | ||
227 | + }); | ||
228 | + $("#PRODUCT_FUNC").focus(); | ||
229 | + return false; | ||
230 | + } | ||
231 | + if($("#PRODUCT_PERF").val()==""){ | ||
232 | + $("#PRODUCT_PERF").tips({ | ||
233 | + side:3, | ||
234 | + msg:'请输入产品性能', | ||
235 | + bg:'#AE81FF', | ||
236 | + time:2 | ||
237 | + }); | ||
238 | + $("#PRODUCT_PERF").focus(); | ||
239 | + return false; | ||
240 | + } | ||
241 | + if($("#ADAPTABLE_HARDWARE").val()==""){ | ||
242 | + $("#ADAPTABLE_HARDWARE").tips({ | ||
243 | + side:3, | ||
244 | + msg:'请输入适配硬件', | ||
245 | + bg:'#AE81FF', | ||
246 | + time:2 | ||
247 | + }); | ||
248 | + $("#ADAPTABLE_HARDWARE").focus(); | ||
249 | + return false; | ||
250 | + } | ||
251 | + if($("#ADAPTABLE_SOFTWARE").val()==""){ | ||
252 | + $("#ADAPTABLE_SOFTWARE").tips({ | ||
253 | + side:3, | ||
254 | + msg:'请输入适配软件', | ||
255 | + bg:'#AE81FF', | ||
256 | + time:2 | ||
257 | + }); | ||
258 | + $("#ADAPTABLE_SOFTWARE").focus(); | ||
259 | + return false; | ||
260 | + } | ||
261 | + if($("#PRODUCT_CERT").val()==""){ | ||
262 | + $("#PRODUCT_CERT").tips({ | ||
263 | + side:3, | ||
264 | + msg:'请输入产品认证', | ||
265 | + bg:'#AE81FF', | ||
266 | + time:2 | ||
267 | + }); | ||
268 | + $("#PRODUCT_CERT").focus(); | ||
269 | + return false; | ||
270 | + } | ||
271 | + if($("#REMARK").val()==""){ | ||
272 | + $("#REMARK").tips({ | ||
273 | + side:3, | ||
274 | + msg:'请输入注意事项', | ||
275 | + bg:'#AE81FF', | ||
276 | + time:2 | ||
277 | + }); | ||
278 | + $("#REMARK").focus(); | ||
279 | + return false; | ||
280 | + } | ||
281 | + | ||
282 | + $("#Form").submit(); | ||
283 | + $("#zhongxin").hide(); | ||
284 | + $("#zhongxin2").show(); | ||
285 | + } | ||
286 | + | ||
287 | + $(function() { | ||
288 | + //日期框 | ||
289 | + $('.date-picker').datepicker({autoclose: true,todayHighlight: true}); | ||
290 | + }); | ||
291 | + </script> | ||
292 | +</body> | ||
293 | +</html> | ||
0 | \ No newline at end of file | 294 | \ No newline at end of file |
WebRoot/WEB-INF/jsp/software/firmware/firmware_list.jsp
0 → 100644
1 | +<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> | ||
2 | +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> | ||
3 | +<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%> | ||
4 | +<% | ||
5 | + String path = request.getContextPath(); | ||
6 | + String basePath = request.getScheme() + "://" | ||
7 | + + request.getServerName() + ":" + request.getServerPort() | ||
8 | + + path + "/"; | ||
9 | +%> | ||
10 | +<!DOCTYPE html> | ||
11 | +<html lang="en"> | ||
12 | +<head> | ||
13 | +<base href="<%=basePath%>"> | ||
14 | +<!-- 下拉框 --> | ||
15 | +<link rel="stylesheet" href="static/ace/css/chosen.css" /> | ||
16 | +<!-- jsp文件头和头部 --> | ||
17 | +<%@ include file="../../system/index/top.jsp"%> | ||
18 | +<!-- 日期框 --> | ||
19 | +<link rel="stylesheet" href="static/ace/css/datepicker.css" /> | ||
20 | +</head> | ||
21 | +<body class="no-skin"> | ||
22 | + | ||
23 | + <!-- /section:basics/navbar.layout --> | ||
24 | + <div class="main-container" id="main-container"> | ||
25 | + <!-- /section:basics/sidebar --> | ||
26 | + <div class="main-content"> | ||
27 | + <div class="main-content-inner"> | ||
28 | + <div class="page-content"> | ||
29 | + <div class="row"> | ||
30 | + <div class="col-xs-12"> | ||
31 | + | ||
32 | + <!-- 检索 --> | ||
33 | + <form action="firmware/list.do" method="post" name="Form" id="Form"> | ||
34 | + <table style="margin-top:5px;"> | ||
35 | + <tr> | ||
36 | + | ||
37 | + <td style="vertical-align:top;padding-left:2px;"> | ||
38 | + <select class="chosen-select form-control" name="INDUSTRY" id="INDUSTRY" data-placeholder="请选择" style="vertical-align:top;"> | ||
39 | + <option value="">应用行业</option> | ||
40 | + <option value="教育">教育</option> | ||
41 | + <option value="企业">企业</option> | ||
42 | + <option value="政府">政府</option> | ||
43 | + <option value="其他">其他</option> | ||
44 | + </select> | ||
45 | + </td> | ||
46 | + <td style="vertical-align:top;padding-left:2px;"> | ||
47 | + <select class="chosen-select form-control" name="PRODUCT_STATE" id="PRODUCT_STATE" data-placeholder="请选择" style="vertical-align:top;width:98%;"> | ||
48 | + <option value="" >产品状态</option> | ||
49 | + <option value="产品销售" <c:if test="${pd.PRODUCT_STATE eq '产品销售'}">selected="true"</c:if>>销售</option> | ||
50 | + <option value="产品发布" <c:if test="${pd.PRODUCT_STATE eq '产品发布'}">selected="true"</c:if>>发布</option> | ||
51 | + <option value="产品研制" <c:if test="${pd.PRODUCT_STATE eq '产品研制'}">selected="true"</c:if>>研制</option> | ||
52 | + <option value="其他" <c:if test="${pd.PRODUCT_STATE eq '其他'}">selected="true"</c:if>>其他</option> | ||
53 | + </select> | ||
54 | + </td> | ||
55 | + <td> | ||
56 | + <div class="nav-search"> | ||
57 | + <span class="input-icon"> | ||
58 | + <input type="text" placeholder="这里输入关键词" class="nav-search-input" id="nav-search-input" autocomplete="off" name="keywords" value="${pd.keywords }" placeholder="这里输入关键词"/> | ||
59 | + <i class="ace-icon fa fa-search nav-search-icon"></i> | ||
60 | + </span> | ||
61 | + </div> | ||
62 | + </td> | ||
63 | + <c:if test="${QX.cha == 1 }"> | ||
64 | + <td style="vertical-align:top;padding-left:2px"><a class="btn btn-light btn-xs" onclick="tosearch();" title="检索"><i id="nav-search-icon" class="ace-icon fa fa-search bigger-110 nav-search-icon blue"></i></a></td> | ||
65 | + </c:if> | ||
66 | + <c:if test="${QX.toExcel == 1 }"><td style="vertical-align:top;padding-left:2px;"><a class="btn btn-light btn-xs" onclick="toExcel();" title="导出到EXCEL"><i id="nav-search-icon" class="ace-icon fa fa-download bigger-110 nav-search-icon blue"></i></a></td></c:if> | ||
67 | + </tr> | ||
68 | + </table> | ||
69 | + <!-- 检索 --> | ||
70 | + | ||
71 | + <table id="simple-table" class="table table-striped table-bordered table-hover" style="margin-top:5px;"> | ||
72 | + <thead> | ||
73 | + <tr> | ||
74 | + <th class="center" style="width:35px;"> | ||
75 | + <label class="pos-rel"><input type="checkbox" class="ace" id="zcheckbox" /><span class="lbl"></span></label> | ||
76 | + </th> | ||
77 | + <th class="center" style="width:50px;">序号</th> | ||
78 | + <th class="center">产品名称</th> | ||
79 | + <th class="center">货品编号</th> | ||
80 | + <th class="center">应用行业</th> | ||
81 | + <th class="center">产品状态</th> | ||
82 | + <th class="center">操作</th> | ||
83 | + </tr> | ||
84 | + </thead> | ||
85 | + | ||
86 | + <tbody> | ||
87 | + <!-- 开始循环 --> | ||
88 | + <c:choose> | ||
89 | + <c:when test="${not empty varList}"> | ||
90 | + <c:if test="${QX.cha == 1 }"> | ||
91 | + <c:forEach items="${varList}" var="var" varStatus="vs"> | ||
92 | + <tr> | ||
93 | + <td class='center'> | ||
94 | + <label class="pos-rel"><input type='checkbox' name='ids' value="${var.FIRMWARE_ID}" class="ace" /><span class="lbl"></span></label> | ||
95 | + </td> | ||
96 | + <td class='center' style="width: 30px;">${vs.index+1}</td> | ||
97 | + <td class='center'><a href="javascrip:;">${var.PRODUCT_NAME}</a></td> | ||
98 | + <td class='center'>${var.PRODUCT_NO}</td> | ||
99 | + <td class='center'>${var.INDUSTRY}</td> | ||
100 | + <td class='center'>${var.PRODUCT_STATE}</td> | ||
101 | + <td class="center"> | ||
102 | + <c:if test="${QX.edit != 1 && QX.del != 1 }"> | ||
103 | + <span class="label label-large label-grey arrowed-in-right arrowed-in"><i class="ace-icon fa fa-lock" title="无权限"></i></span> | ||
104 | + </c:if> | ||
105 | + <div class="hidden-sm hidden-xs btn-group"> | ||
106 | + <c:if test="${QX.edit == 1 }"> | ||
107 | + <a class="btn btn-xs btn-success" title="编辑" onclick="edit('${var.FIRMWARE_ID}');"> | ||
108 | + <i class="ace-icon fa fa-pencil-square-o bigger-120" title="编辑"></i> | ||
109 | + </a> | ||
110 | + </c:if> | ||
111 | + <c:if test="${QX.del == 1 }"> | ||
112 | + <a class="btn btn-xs btn-danger" onclick="del('${var.FIRMWARE_ID}');"> | ||
113 | + <i class="ace-icon fa fa-trash-o bigger-120" title="删除"></i> | ||
114 | + </a> | ||
115 | + </c:if> | ||
116 | + </div> | ||
117 | + <div class="hidden-md hidden-lg"> | ||
118 | + <div class="inline pos-rel"> | ||
119 | + <button class="btn btn-minier btn-primary dropdown-toggle" data-toggle="dropdown" data-position="auto"> | ||
120 | + <i class="ace-icon fa fa-cog icon-only bigger-110"></i> | ||
121 | + </button> | ||
122 | + | ||
123 | + <ul class="dropdown-menu dropdown-only-icon dropdown-yellow dropdown-menu-right dropdown-caret dropdown-close"> | ||
124 | + <c:if test="${QX.edit == 1 }"> | ||
125 | + <li> | ||
126 | + <a style="cursor:pointer;" onclick="edit('${var.FIRMWARE_ID}');" class="tooltip-success" data-rel="tooltip" title="修改"> | ||
127 | + <span class="green"> | ||
128 | + <i class="ace-icon fa fa-pencil-square-o bigger-120"></i> | ||
129 | + </span> | ||
130 | + </a> | ||
131 | + </li> | ||
132 | + </c:if> | ||
133 | + <c:if test="${QX.del == 1 }"> | ||
134 | + <li> | ||
135 | + <a style="cursor:pointer;" onclick="del('${var.FIRMWARE_ID}');" class="tooltip-error" data-rel="tooltip" title="删除"> | ||
136 | + <span class="red"> | ||
137 | + <i class="ace-icon fa fa-trash-o bigger-120"></i> | ||
138 | + </span> | ||
139 | + </a> | ||
140 | + </li> | ||
141 | + </c:if> | ||
142 | + </ul> | ||
143 | + </div> | ||
144 | + </div> | ||
145 | + </td> | ||
146 | + </tr> | ||
147 | + | ||
148 | + </c:forEach> | ||
149 | + </c:if> | ||
150 | + <c:if test="${QX.cha == 0 }"> | ||
151 | + <tr> | ||
152 | + <td colspan="100" class="center">您无权查看</td> | ||
153 | + </tr> | ||
154 | + </c:if> | ||
155 | + </c:when> | ||
156 | + <c:otherwise> | ||
157 | + <tr class="main_info"> | ||
158 | + <td colspan="100" class="center" >没有相关数据</td> | ||
159 | + </tr> | ||
160 | + </c:otherwise> | ||
161 | + </c:choose> | ||
162 | + </tbody> | ||
163 | + </table> | ||
164 | + <div class="page-header position-relative"> | ||
165 | + <table style="width:100%;"> | ||
166 | + <tr> | ||
167 | + <td style="vertical-align:top;"> | ||
168 | + <c:if test="${QX.add == 1 }"> | ||
169 | + <a class="btn btn-mini btn-success" onclick="add();">新增</a> | ||
170 | + </c:if> | ||
171 | + <c:if test="${QX.del == 1 }"> | ||
172 | + <a class="btn btn-mini btn-danger" onclick="makeAll('确定要删除选中的数据吗?');" title="批量删除" ><i class='ace-icon fa fa-trash-o bigger-120'></i></a> | ||
173 | + </c:if> | ||
174 | + </td> | ||
175 | + <td style="vertical-align:top;"><div class="pagination" style="float: right;padding-top: 0px;margin-top: 0px;">${page.pageStr}</div></td> | ||
176 | + </tr> | ||
177 | + </table> | ||
178 | + </div> | ||
179 | + </form> | ||
180 | + | ||
181 | + </div> | ||
182 | + <!-- /.col --> | ||
183 | + </div> | ||
184 | + <!-- /.row --> | ||
185 | + </div> | ||
186 | + <!-- /.page-content --> | ||
187 | + </div> | ||
188 | + </div> | ||
189 | + <!-- /.main-content --> | ||
190 | + | ||
191 | + <!-- 返回顶部 --> | ||
192 | + <a href="#" id="btn-scroll-up" class="btn-scroll-up btn btn-sm btn-inverse"> | ||
193 | + <i class="ace-icon fa fa-angle-double-up icon-only bigger-110"></i> | ||
194 | + </a> | ||
195 | + | ||
196 | + </div> | ||
197 | + <!-- /.main-container --> | ||
198 | + | ||
199 | + <!-- basic scripts --> | ||
200 | + <!-- 页面底部js¨ --> | ||
201 | + <%@ include file="../../system/index/foot.jsp"%> | ||
202 | + <!-- 删除时确认窗口 --> | ||
203 | + <script src="static/ace/js/bootbox.js"></script> | ||
204 | + <!-- ace scripts --> | ||
205 | + <script src="static/ace/js/ace/ace.js"></script> | ||
206 | + <!-- 下拉框 --> | ||
207 | + <script src="static/ace/js/chosen.jquery.js"></script> | ||
208 | + <!-- 日期框 --> | ||
209 | + <script src="static/ace/js/date-time/bootstrap-datepicker.js"></script> | ||
210 | + <!--提示框--> | ||
211 | + <script type="text/javascript" src="static/js/jquery.tips.js"></script> | ||
212 | + <script type="text/javascript"> | ||
213 | + $(top.hangge());//关闭加载状态 | ||
214 | + //检索 | ||
215 | + function tosearch(){ | ||
216 | + top.jzts(); | ||
217 | + $("#Form").submit(); | ||
218 | + } | ||
219 | + $(function() { | ||
220 | + | ||
221 | + //日期框 | ||
222 | + $('.date-picker').datepicker({ | ||
223 | + autoclose: true, | ||
224 | + todayHighlight: true | ||
225 | + }); | ||
226 | + | ||
227 | + //下拉框 | ||
228 | + if(!ace.vars['touch']) { | ||
229 | + $('.chosen-select').chosen({allow_single_deselect:true}); | ||
230 | + $(window) | ||
231 | + .off('resize.chosen') | ||
232 | + .on('resize.chosen', function() { | ||
233 | + $('.chosen-select').each(function() { | ||
234 | + var $this = $(this); | ||
235 | + $this.next().css({'width': $this.parent().width()}); | ||
236 | + }); | ||
237 | + }).trigger('resize.chosen'); | ||
238 | + $(document).on('settings.ace.chosen', function(e, event_name, event_val) { | ||
239 | + if(event_name != 'sidebar_collapsed') return; | ||
240 | + $('.chosen-select').each(function() { | ||
241 | + var $this = $(this); | ||
242 | + $this.next().css({'width': $this.parent().width()}); | ||
243 | + }); | ||
244 | + }); | ||
245 | + $('#chosen-multiple-style .btn').on('click', function(e){ | ||
246 | + var target = $(this).find('input[type=radio]'); | ||
247 | + var which = parseInt(target.val()); | ||
248 | + if(which == 2) $('#form-field-select-4').addClass('tag-input-style'); | ||
249 | + else $('#form-field-select-4').removeClass('tag-input-style'); | ||
250 | + }); | ||
251 | + } | ||
252 | + | ||
253 | + | ||
254 | + //复选框全选控制 | ||
255 | + var active_class = 'active'; | ||
256 | + $('#simple-table > thead > tr > th input[type=checkbox]').eq(0).on('click', function(){ | ||
257 | + var th_checked = this.checked;//checkbox inside "TH" table header | ||
258 | + $(this).closest('table').find('tbody > tr').each(function(){ | ||
259 | + var row = this; | ||
260 | + if(th_checked) $(row).addClass(active_class).find('input[type=checkbox]').eq(0).prop('checked', true); | ||
261 | + else $(row).removeClass(active_class).find('input[type=checkbox]').eq(0).prop('checked', false); | ||
262 | + }); | ||
263 | + }); | ||
264 | + }); | ||
265 | + | ||
266 | + //新增 | ||
267 | + function add(){ | ||
268 | + top.jzts(); | ||
269 | + var diag = new top.Dialog(); | ||
270 | + diag.Drag=true; | ||
271 | + diag.Title ="新增"; | ||
272 | + diag.URL = '<%=basePath%>firmware/goAdd.do'; | ||
273 | + diag.Width = 600; | ||
274 | + diag.Height = 600; | ||
275 | + diag.Modal = true; //有无遮罩窗口 | ||
276 | + diag. ShowMaxButton = true; //最大化按钮 | ||
277 | + diag.ShowMinButton = true; //最小化按钮 | ||
278 | + diag.CancelEvent = function(){ //关闭事件 | ||
279 | + if(diag.innerFrame.contentWindow.document.getElementById('zhongxin').style.display == 'none'){ | ||
280 | + if('${page.currentPage}' == '0'){ | ||
281 | + tosearch(); | ||
282 | + }else{ | ||
283 | + tosearch(); | ||
284 | + } | ||
285 | + } | ||
286 | + diag.close(); | ||
287 | + }; | ||
288 | + diag.show(); | ||
289 | + } | ||
290 | + | ||
291 | + //删除 | ||
292 | + function del(Id){ | ||
293 | + bootbox.confirm("确定要删除吗?", function(result) { | ||
294 | + if(result) { | ||
295 | + top.jzts(); | ||
296 | + var url = "<%=basePath%>firmware/delete.do?FIRMWARE_ID="+Id+"&tm="+new Date().getTime(); | ||
297 | + $.get(url,function(data){ | ||
298 | + tosearch(); | ||
299 | + }); | ||
300 | + } | ||
301 | + }); | ||
302 | + } | ||
303 | + | ||
304 | + //修改 | ||
305 | + function edit(Id){ | ||
306 | + top.jzts(); | ||
307 | + var diag = new top.Dialog(); | ||
308 | + diag.Drag=true; | ||
309 | + diag.Title ="编辑"; | ||
310 | + diag.URL = '<%=basePath%>firmware/goEdit.do?FIRMWARE_ID='+Id; | ||
311 | + diag.Width = 600; | ||
312 | + diag.Height = 600; | ||
313 | + diag.Modal = true; //有无遮罩窗口 | ||
314 | + diag. ShowMaxButton = true; //最大化按钮 | ||
315 | + diag.ShowMinButton = true; //最小化按钮 | ||
316 | + diag.CancelEvent = function(){ //关闭事件 | ||
317 | + if(diag.innerFrame.contentWindow.document.getElementById('zhongxin').style.display == 'none'){ | ||
318 | + tosearch(); | ||
319 | + } | ||
320 | + diag.close(); | ||
321 | + }; | ||
322 | + diag.show(); | ||
323 | + <%-- var href = ("<%=basePath%>firmware/goEdit.do?FIRMWARE_ID="+Id); | ||
324 | + window.location.href = href ; --%> | ||
325 | + } | ||
326 | + | ||
327 | + //批量操作 | ||
328 | + function makeAll(msg){ | ||
329 | + bootbox.confirm(msg, function(result) { | ||
330 | + if(result) { | ||
331 | + var str = ''; | ||
332 | + for(var i=0;i < document.getElementsByName('ids').length;i++){ | ||
333 | + if(document.getElementsByName('ids')[i].checked){ | ||
334 | + if(str=='') str += document.getElementsByName('ids')[i].value; | ||
335 | + else str += ',' + document.getElementsByName('ids')[i].value; | ||
336 | + } | ||
337 | + } | ||
338 | + if(str==''){ | ||
339 | + bootbox.dialog({ | ||
340 | + message: "<span class='bigger-110'>您没有选择任何内容!</span>", | ||
341 | + buttons: | ||
342 | + { "button":{ "label":"确定", "className":"btn-sm btn-success"}} | ||
343 | + }); | ||
344 | + $("#zcheckbox").tips({ | ||
345 | + side:1, | ||
346 | + msg:'点这里全选', | ||
347 | + bg:'#AE81FF', | ||
348 | + time:8 | ||
349 | + }); | ||
350 | + return; | ||
351 | + }else{ | ||
352 | + if(msg == '确定要删除选中的数据吗?'){ | ||
353 | + top.jzts(); | ||
354 | + $.ajax({ | ||
355 | + type: "POST", | ||
356 | + url: '<%=basePath%>firmware/deleteAll.do?tm='+new Date().getTime(), | ||
357 | + data: {DATA_IDS:str}, | ||
358 | + dataType:'json', | ||
359 | + //beforeSend: validateData, | ||
360 | + cache: false, | ||
361 | + success: function(data){ | ||
362 | + $.each(data.list, function(i, list){ | ||
363 | + tosearch(); | ||
364 | + }); | ||
365 | + } | ||
366 | + }); | ||
367 | + } | ||
368 | + } | ||
369 | + } | ||
370 | + }); | ||
371 | + }; | ||
372 | + | ||
373 | + //导出excel | ||
374 | + function toExcel(){ | ||
375 | + window.location.href='<%=basePath%>firmware/excel.do'; | ||
376 | + } | ||
377 | + </script> | ||
378 | + | ||
379 | + | ||
380 | +</body> | ||
381 | +</html> | ||
0 | \ No newline at end of file | 382 | \ No newline at end of file |
WebRoot/WEB-INF/jsp/software/software/software_list.jsp
@@ -33,27 +33,6 @@ | @@ -33,27 +33,6 @@ | ||
33 | <form action="software/list.do" method="post" name="Form" id="Form"> | 33 | <form action="software/list.do" method="post" name="Form" id="Form"> |
34 | <table style="margin-top:5px;"> | 34 | <table style="margin-top:5px;"> |
35 | <tr> | 35 | <tr> |
36 | - <td> | ||
37 | - <div class="nav-search"> | ||
38 | - <span class="input-icon"> | ||
39 | - <input type="text" placeholder="这里输入关键词" class="nav-search-input" id="nav-search-input" autocomplete="off" name="keywords" value="${pd.keywords }" placeholder="这里输入关键词"/> | ||
40 | - <i class="ace-icon fa fa-search nav-search-icon"></i> | ||
41 | - </span> | ||
42 | - </div> | ||
43 | - </td> | ||
44 | - <td style="padding-left:2px;"><input class="span10 date-picker" name="lastStart" id="lastStart" value="" type="text" data-date-format="yyyy-mm-dd" readonly="readonly" style="width:88px;" placeholder="开始日期" title="开始日期"/></td> | ||
45 | - <td style="padding-left:2px;"><input class="span10 date-picker" name="lastEnd" name="lastEnd" value="" type="text" data-date-format="yyyy-mm-dd" readonly="readonly" style="width:88px;" placeholder="结束日期" title="结束日期"/></td> | ||
46 | - <td style="vertical-align:top;padding-left:2px;"> | ||
47 | - <select class="chosen-select form-control" name="name" id="id" data-placeholder="请选择" style="vertical-align:top;width: 120px;"> | ||
48 | - <option value=""></option> | ||
49 | - <option value="">全部</option> | ||
50 | - <option value="">1</option> | ||
51 | - <option value="">2</option> | ||
52 | - </select> | ||
53 | - </td> | ||
54 | - <c:if test="${QX.cha == 1 }"> | ||
55 | - <td style="vertical-align:top;padding-left:2px"><a class="btn btn-light btn-xs" onclick="tosearch();" title="检索"><i id="nav-search-icon" class="ace-icon fa fa-search bigger-110 nav-search-icon blue"></i></a></td> | ||
56 | - </c:if> | ||
57 | <c:if test="${QX.toExcel == 1 }"><td style="vertical-align:top;padding-left:2px;"><a class="btn btn-light btn-xs" onclick="toExcel();" title="导出到EXCEL"><i id="nav-search-icon" class="ace-icon fa fa-download bigger-110 nav-search-icon blue"></i></a></td></c:if> | 36 | <c:if test="${QX.toExcel == 1 }"><td style="vertical-align:top;padding-left:2px;"><a class="btn btn-light btn-xs" onclick="toExcel();" title="导出到EXCEL"><i id="nav-search-icon" class="ace-icon fa fa-download bigger-110 nav-search-icon blue"></i></a></td></c:if> |
58 | </tr> | 37 | </tr> |
59 | </table> | 38 | </table> |
WebRoot/WEB-INF/jsp/software/softwareversion/softwareversion_list.jsp
@@ -34,27 +34,6 @@ | @@ -34,27 +34,6 @@ | ||
34 | <form action="softwareversion/list.do" method="post" name="Form" id="Form"> | 34 | <form action="softwareversion/list.do" method="post" name="Form" id="Form"> |
35 | <table style="margin-top:5px;"> | 35 | <table style="margin-top:5px;"> |
36 | <tr> | 36 | <tr> |
37 | - <td> | ||
38 | - <div class="nav-search"> | ||
39 | - <span class="input-icon"> | ||
40 | - <input type="text" placeholder="这里输入关键词" class="nav-search-input" id="nav-search-input" autocomplete="off" name="keywords" value="${pd.keywords }" placeholder="这里输入关键词"/> | ||
41 | - <i class="ace-icon fa fa-search nav-search-icon"></i> | ||
42 | - </span> | ||
43 | - </div> | ||
44 | - </td> | ||
45 | - <td style="padding-left:2px;"><input class="span10 date-picker" name="lastStart" id="lastStart" value="" type="text" data-date-format="yyyy-mm-dd" readonly="readonly" style="width:88px;" placeholder="开始日期" title="开始日期"/></td> | ||
46 | - <td style="padding-left:2px;"><input class="span10 date-picker" name="lastEnd" name="lastEnd" value="" type="text" data-date-format="yyyy-mm-dd" readonly="readonly" style="width:88px;" placeholder="结束日期" title="结束日期"/></td> | ||
47 | - <td style="vertical-align:top;padding-left:2px;"> | ||
48 | - <select class="chosen-select form-control" name="name" id="id" data-placeholder="请选择" style="vertical-align:top;width: 120px;"> | ||
49 | - <option value=""></option> | ||
50 | - <option value="">全部</option> | ||
51 | - <option value="">1</option> | ||
52 | - <option value="">2</option> | ||
53 | - </select> | ||
54 | - </td> | ||
55 | - <c:if test="${QX.cha == 1 }"> | ||
56 | - <td style="vertical-align:top;padding-left:2px"><a class="btn btn-light btn-xs" onclick="tosearch();" title="检索"><i id="nav-search-icon" class="ace-icon fa fa-search bigger-110 nav-search-icon blue"></i></a></td> | ||
57 | - </c:if> | ||
58 | <c:if test="${QX.toExcel == 1 }"><td style="vertical-align:top;padding-left:2px;"><a class="btn btn-light btn-xs" onclick="toExcel();" title="导出到EXCEL"><i id="nav-search-icon" class="ace-icon fa fa-download bigger-110 nav-search-icon blue"></i></a></td></c:if> | 37 | <c:if test="${QX.toExcel == 1 }"><td style="vertical-align:top;padding-left:2px;"><a class="btn btn-light btn-xs" onclick="toExcel();" title="导出到EXCEL"><i id="nav-search-icon" class="ace-icon fa fa-download bigger-110 nav-search-icon blue"></i></a></td></c:if> |
59 | </tr> | 38 | </tr> |
60 | </table> | 39 | </table> |
WebRoot/static/js/control-604.js
@@ -368,10 +368,16 @@ function creatHtml(data){ | @@ -368,10 +368,16 @@ function creatHtml(data){ | ||
368 | } | 368 | } |
369 | } | 369 | } |
370 | } | 370 | } |
371 | + | ||
372 | +var answerLen = 0 ; | ||
371 | /*快速建题中,每输入五个答案就加一个空格*/ | 373 | /*快速建题中,每输入五个答案就加一个空格*/ |
372 | -$("#answer").on("input propertychange",function(){ | ||
373 | - if($("#answer").val().length%5==0) | ||
374 | - $("#answer").val($("#answer").val()+" "); | 374 | +$("#answer").on("input propertychange",function(event){ |
375 | + if($("#answer").val().length > answerLen){ | ||
376 | + if(($("#answer").val().length + 1 )% 6 == 0){ | ||
377 | + $("#answer").val($("#answer").val()+" "); | ||
378 | + } | ||
379 | + } | ||
380 | + answerLen = $("#answer").val().length; | ||
375 | }) | 381 | }) |
376 | 382 | ||
377 | /*数字转汉字数字*/ | 383 | /*数字转汉字数字*/ |
resources/mybatis1/software/FirmMapper.xml
0 → 100644
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||
3 | +<mapper namespace="FirmMapper"> | ||
4 | + | ||
5 | + <!--表名 --> | ||
6 | + <sql id="tableName"> | ||
7 | + SV_FIRM | ||
8 | + </sql> | ||
9 | + | ||
10 | + <!-- 字段 --> | ||
11 | + <sql id="Field"> | ||
12 | + PRODUCT_NAME, | ||
13 | + FIRM_VERSION, | ||
14 | + FRIM_CODE, | ||
15 | + FIRM_PATH, | ||
16 | + FIRM_DESC, | ||
17 | + FIRM_ID | ||
18 | + </sql> | ||
19 | + | ||
20 | + <!-- 字段值 --> | ||
21 | + <sql id="FieldValue"> | ||
22 | + #{PRODUCT_NAME}, | ||
23 | + #{FIRM_VERSION}, | ||
24 | + #{FRIM_CODE}, | ||
25 | + #{FIRM_PATH}, | ||
26 | + #{FIRM_DESC}, | ||
27 | + #{FIRM_ID} | ||
28 | + </sql> | ||
29 | + | ||
30 | + <!-- 新增--> | ||
31 | + <insert id="save" parameterType="pd"> | ||
32 | + insert into | ||
33 | + <include refid="tableName"></include> | ||
34 | + ( | ||
35 | + <include refid="Field"></include> | ||
36 | + ) values ( | ||
37 | + <include refid="FieldValue"></include> | ||
38 | + ) | ||
39 | + </insert> | ||
40 | + | ||
41 | + <!-- 删除--> | ||
42 | + <delete id="delete" parameterType="pd"> | ||
43 | + delete from | ||
44 | + <include refid="tableName"></include> | ||
45 | + where | ||
46 | + FIRM_ID = #{FIRM_ID} | ||
47 | + </delete> | ||
48 | + | ||
49 | + <!-- 修改 --> | ||
50 | + <update id="edit" parameterType="pd"> | ||
51 | + update | ||
52 | + <include refid="tableName"></include> | ||
53 | + set | ||
54 | + PRODUCT_NAME = #{PRODUCT_NAME}, | ||
55 | + FIRM_VERSION = #{FIRM_VERSION}, | ||
56 | + FRIM_CODE = #{FRIM_CODE}, | ||
57 | + FIRM_PATH = #{FIRM_PATH}, | ||
58 | + FIRM_DESC = #{FIRM_DESC}, | ||
59 | + FIRM_ID = FIRM_ID | ||
60 | + where | ||
61 | + FIRM_ID = #{FIRM_ID} | ||
62 | + </update> | ||
63 | + | ||
64 | + <!-- 通过ID获取数据 --> | ||
65 | + <select id="findById" parameterType="pd" resultType="pd"> | ||
66 | + select | ||
67 | + <include refid="Field"></include> | ||
68 | + from | ||
69 | + <include refid="tableName"></include> | ||
70 | + where | ||
71 | + FIRM_ID = #{FIRM_ID} | ||
72 | + </select> | ||
73 | + | ||
74 | + <!-- 列表 --> | ||
75 | + <select id="datalistPage" parameterType="page" resultType="pd"> | ||
76 | + select | ||
77 | + <include refid="Field"></include> | ||
78 | + from | ||
79 | + <include refid="tableName"></include> | ||
80 | + where 1=1 | ||
81 | + <if test="pd.PRODUCT_NAME != null and pd.PRODUCT_NAME != ''"><!-- 关键词检索 --> | ||
82 | + and | ||
83 | + ( | ||
84 | + PRODUCT_NAME = #{pd.PRODUCT_NAME} | ||
85 | + ) | ||
86 | + </if> | ||
87 | + </select> | ||
88 | + | ||
89 | + <!-- 列表(全部) --> | ||
90 | + <select id="listAll" parameterType="pd" resultType="pd"> | ||
91 | + select | ||
92 | + <include refid="Field"></include> | ||
93 | + from | ||
94 | + <include refid="tableName"></include> | ||
95 | + </select> | ||
96 | + | ||
97 | + <!-- 批量删除 --> | ||
98 | + <delete id="deleteAll" parameterType="String"> | ||
99 | + delete from | ||
100 | + <include refid="tableName"></include> | ||
101 | + where | ||
102 | + FIRM_ID in | ||
103 | + <foreach item="item" index="index" collection="array" open="(" separator="," close=")"> | ||
104 | + #{item} | ||
105 | + </foreach> | ||
106 | + </delete> | ||
107 | + | ||
108 | + <!-- fh313596790qq(青苔) --> | ||
109 | +</mapper> | ||
0 | \ No newline at end of file | 110 | \ No newline at end of file |
resources/mybatis1/software/FirmwareMapper.xml
0 → 100644
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||
3 | +<mapper namespace="FirmwareMapper"> | ||
4 | + | ||
5 | + <!--表名 --> | ||
6 | + <sql id="tableName"> | ||
7 | + SV_FIRMWARE | ||
8 | + </sql> | ||
9 | + | ||
10 | + <!-- 字段 --> | ||
11 | + <sql id="Field"> | ||
12 | + PRODUCT_NAME, | ||
13 | + PRODUCT_NO, | ||
14 | + INDUSTRY, | ||
15 | + PRODUCT_STATE, | ||
16 | + PRODUCT_SPEC, | ||
17 | + PRODUCT_FUNC, | ||
18 | + PRODUCT_PERF, | ||
19 | + ADAPTABLE_HARDWARE, | ||
20 | + ADAPTABLE_SOFTWARE, | ||
21 | + PRODUCT_CERT, | ||
22 | + REMARK, | ||
23 | + PRODUCT_IMAGE, | ||
24 | + CREATE_DATE, | ||
25 | + FIRMWARE_ID | ||
26 | + </sql> | ||
27 | + | ||
28 | + <!-- 字段值 --> | ||
29 | + <sql id="FieldValue"> | ||
30 | + #{PRODUCT_NAME}, | ||
31 | + #{PRODUCT_NO}, | ||
32 | + #{INDUSTRY}, | ||
33 | + #{PRODUCT_STATE}, | ||
34 | + #{PRODUCT_SPEC}, | ||
35 | + #{PRODUCT_FUNC}, | ||
36 | + #{PRODUCT_PERF}, | ||
37 | + #{ADAPTABLE_HARDWARE}, | ||
38 | + #{ADAPTABLE_SOFTWARE}, | ||
39 | + #{PRODUCT_CERT}, | ||
40 | + #{REMARK}, | ||
41 | + #{PRODUCT_IMAGE}, | ||
42 | + #{CREATE_DATE}, | ||
43 | + #{FIRMWARE_ID} | ||
44 | + </sql> | ||
45 | + | ||
46 | + <!-- 新增--> | ||
47 | + <insert id="save" parameterType="pd"> | ||
48 | + insert into | ||
49 | + <include refid="tableName"></include> | ||
50 | + ( | ||
51 | + <include refid="Field"></include> | ||
52 | + ) values ( | ||
53 | + <include refid="FieldValue"></include> | ||
54 | + ) | ||
55 | + </insert> | ||
56 | + | ||
57 | + <!-- 删除--> | ||
58 | + <delete id="delete" parameterType="pd"> | ||
59 | + delete from | ||
60 | + <include refid="tableName"></include> | ||
61 | + where | ||
62 | + FIRMWARE_ID = #{FIRMWARE_ID} | ||
63 | + </delete> | ||
64 | + | ||
65 | + <!-- 修改 --> | ||
66 | + <update id="edit" parameterType="pd"> | ||
67 | + update | ||
68 | + <include refid="tableName"></include> | ||
69 | + set | ||
70 | + PRODUCT_NAME = #{PRODUCT_NAME}, | ||
71 | + PRODUCT_NO = #{PRODUCT_NO}, | ||
72 | + INDUSTRY = #{INDUSTRY}, | ||
73 | + PRODUCT_STATE = #{PRODUCT_STATE}, | ||
74 | + PRODUCT_SPEC = #{PRODUCT_SPEC}, | ||
75 | + PRODUCT_FUNC = #{PRODUCT_FUNC}, | ||
76 | + PRODUCT_PERF = #{PRODUCT_PERF}, | ||
77 | + ADAPTABLE_HARDWARE = #{ADAPTABLE_HARDWARE}, | ||
78 | + ADAPTABLE_SOFTWARE = #{ADAPTABLE_SOFTWARE}, | ||
79 | + PRODUCT_CERT = #{PRODUCT_CERT}, | ||
80 | + REMARK = #{REMARK}, | ||
81 | + PRODUCT_IMAGE = #{PRODUCT_IMAGE}, | ||
82 | + FIRMWARE_ID = FIRMWARE_ID | ||
83 | + where | ||
84 | + FIRMWARE_ID = #{FIRMWARE_ID} | ||
85 | + </update> | ||
86 | + | ||
87 | + <!-- 通过ID获取数据 --> | ||
88 | + <select id="findById" parameterType="pd" resultType="pd"> | ||
89 | + select | ||
90 | + <include refid="Field"></include> | ||
91 | + from | ||
92 | + <include refid="tableName"></include> | ||
93 | + where | ||
94 | + FIRMWARE_ID = #{FIRMWARE_ID} | ||
95 | + </select> | ||
96 | + | ||
97 | + <!-- 列表 --> | ||
98 | + <select id="datalistPage" parameterType="page" resultType="pd"> | ||
99 | + select | ||
100 | + <include refid="Field"></include> | ||
101 | + from | ||
102 | + <include refid="tableName"></include> | ||
103 | + where 1=1 | ||
104 | + <if test="pd.KEYWORDS!= null and pd.KEYWORDS != ''"><!-- 关键词检索 --> | ||
105 | + and | ||
106 | + ( | ||
107 | + PRODUCT_NAME LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
108 | + or | ||
109 | + PRODUCT_NO LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
110 | + or | ||
111 | + PRODUCT_SPEC LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
112 | + or | ||
113 | + PRODUCT_FUNC LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
114 | + or | ||
115 | + PRODUCT_PERF LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
116 | + or | ||
117 | + ADAPTABLE_HARDWARE LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
118 | + or | ||
119 | + ADAPTABLE_SOFTWARE LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
120 | + or | ||
121 | + PRODUCT_CERT LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%') | ||
122 | + ) | ||
123 | + </if> | ||
124 | + <if test="pd.INDUSTRY != null and pd.INDUSTRY != ''"> | ||
125 | + and INDUSTRY = #{pd.INDUSTRY} | ||
126 | + </if> | ||
127 | + <if test="pd.PRODUCT_STATE != null and pd.PRODUCT_STATE != ''"> | ||
128 | + and PRODUCT_STATE = #{pd.PRODUCT_STATE} | ||
129 | + </if> | ||
130 | + | ||
131 | + </select> | ||
132 | + | ||
133 | + <!-- 列表(全部) --> | ||
134 | + <select id="listAll" parameterType="pd" resultType="pd"> | ||
135 | + select | ||
136 | + <include refid="Field"></include> | ||
137 | + from | ||
138 | + <include refid="tableName"></include> | ||
139 | + </select> | ||
140 | + | ||
141 | + <!-- 批量删除 --> | ||
142 | + <delete id="deleteAll" parameterType="String"> | ||
143 | + delete from | ||
144 | + <include refid="tableName"></include> | ||
145 | + where | ||
146 | + FIRMWARE_ID in | ||
147 | + <foreach item="item" index="index" collection="array" open="(" separator="," close=")"> | ||
148 | + #{item} | ||
149 | + </foreach> | ||
150 | + </delete> | ||
151 | + | ||
152 | + <!-- fh313596790qq(青苔) --> | ||
153 | +</mapper> | ||
0 | \ No newline at end of file | 154 | \ No newline at end of file |
src/com/fh/controller/software/firm/FirmController.java
0 → 100644
1 | +package com.fh.controller.software.firm; | ||
2 | + | ||
3 | +import java.io.File; | ||
4 | +import java.io.PrintWriter; | ||
5 | +import java.text.DateFormat; | ||
6 | +import java.text.SimpleDateFormat; | ||
7 | +import java.util.ArrayList; | ||
8 | +import java.util.Date; | ||
9 | +import java.util.HashMap; | ||
10 | +import java.util.List; | ||
11 | +import java.util.Map; | ||
12 | + | ||
13 | +import javax.annotation.Resource; | ||
14 | +import javax.servlet.http.HttpServletRequest; | ||
15 | + | ||
16 | +import org.springframework.beans.propertyeditors.CustomDateEditor; | ||
17 | +import org.springframework.stereotype.Controller; | ||
18 | +import org.springframework.web.bind.WebDataBinder; | ||
19 | +import org.springframework.web.bind.annotation.InitBinder; | ||
20 | +import org.springframework.web.bind.annotation.RequestMapping; | ||
21 | +import org.springframework.web.bind.annotation.RequestParam; | ||
22 | +import org.springframework.web.bind.annotation.ResponseBody; | ||
23 | +import org.springframework.web.multipart.MultipartFile; | ||
24 | +import org.springframework.web.servlet.ModelAndView; | ||
25 | + | ||
26 | +import com.fh.controller.base.BaseController; | ||
27 | +import com.fh.controller.sunvote.Myelfun; | ||
28 | +import com.fh.entity.Page; | ||
29 | +import com.fh.service.software.firm.FirmManager; | ||
30 | +import com.fh.service.software.firmware.FirmwareManager; | ||
31 | +import com.fh.util.AppUtil; | ||
32 | +import com.fh.util.Jurisdiction; | ||
33 | +import com.fh.util.ObjectExcelView; | ||
34 | +import com.fh.util.PageData; | ||
35 | + | ||
36 | +/** | ||
37 | + * 说明:固件管理 | ||
38 | + * 创建人:FH Q313596790 | ||
39 | + * 创建时间:2018-07-09 | ||
40 | + */ | ||
41 | +@Controller | ||
42 | +@RequestMapping(value="/firm") | ||
43 | +public class FirmController extends BaseController { | ||
44 | + | ||
45 | + String menuUrl = "firm/list.do"; //菜单地址(权限用) | ||
46 | + @Resource(name="firmService") | ||
47 | + private FirmManager firmService; | ||
48 | + | ||
49 | + @Resource(name="firmwareService") | ||
50 | + private FirmwareManager firmwareService; | ||
51 | + | ||
52 | + /**保存 | ||
53 | + * @param | ||
54 | + * @throws Exception | ||
55 | + */ | ||
56 | + @RequestMapping(value="/save") | ||
57 | + public ModelAndView save(@RequestParam(value="FIRM_PATH",required=false) MultipartFile file, HttpServletRequest request) throws Exception{ | ||
58 | + logBefore(logger, Jurisdiction.getUsername()+"新增Firm"); | ||
59 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "add")){return null;} //校验权限 | ||
60 | + ModelAndView mv = this.getModelAndView(); | ||
61 | + PageData pd = new PageData(request); | ||
62 | + pd.put("FIRM_ID", this.get32UUID()); //主键 | ||
63 | + String path = request.getSession().getServletContext() | ||
64 | + .getRealPath("/uploadFiles/uploadFile/"); | ||
65 | + if (file != null) { | ||
66 | + String name = pd.getString("FIRM_ID") + file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")); | ||
67 | + File pathFile = new File(path); | ||
68 | + pathFile.mkdirs(); | ||
69 | + File saveFile = new File(path + File.separator + name); | ||
70 | + if (saveFile.exists()) { | ||
71 | + saveFile.delete(); | ||
72 | + } | ||
73 | + saveFile.createNewFile(); | ||
74 | + file.transferTo(saveFile); | ||
75 | + pd.put("FIRM_PATH", name); | ||
76 | + } | ||
77 | + firmService.save(pd); | ||
78 | + mv.addObject("msg","success"); | ||
79 | + mv.setViewName("save_result"); | ||
80 | + return mv; | ||
81 | + } | ||
82 | + | ||
83 | + /**删除 | ||
84 | + * @param out | ||
85 | + * @throws Exception | ||
86 | + */ | ||
87 | + @RequestMapping(value="/delete") | ||
88 | + public void delete(PrintWriter out,HttpServletRequest request) throws Exception{ | ||
89 | + logBefore(logger, Jurisdiction.getUsername()+"删除Firm"); | ||
90 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return;} //校验权限 | ||
91 | + PageData pd = new PageData(); | ||
92 | + pd = this.getPageData(); | ||
93 | + firmService.delete(pd); | ||
94 | + String path = request.getSession().getServletContext() | ||
95 | + .getRealPath("/uploadFiles/uploadFile/"); | ||
96 | + File file = new File(path + File.separator + pd.getString("FIRM_PATH")); | ||
97 | + file.deleteOnExit(); | ||
98 | + out.write("success"); | ||
99 | + out.close(); | ||
100 | + } | ||
101 | + | ||
102 | + /**修改 | ||
103 | + * @param | ||
104 | + * @throws Exception | ||
105 | + */ | ||
106 | + @RequestMapping(value="/edit") | ||
107 | + public ModelAndView edit() throws Exception{ | ||
108 | + logBefore(logger, Jurisdiction.getUsername()+"修改Firm"); | ||
109 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){return null;} //校验权限 | ||
110 | + ModelAndView mv = this.getModelAndView(); | ||
111 | + PageData pd = new PageData(); | ||
112 | + pd = this.getPageData(); | ||
113 | + firmService.edit(pd); | ||
114 | + mv.addObject("msg","success"); | ||
115 | + mv.setViewName("save_result"); | ||
116 | + return mv; | ||
117 | + } | ||
118 | + | ||
119 | + /**列表 | ||
120 | + * @param page | ||
121 | + * @throws Exception | ||
122 | + */ | ||
123 | + @RequestMapping(value="/list") | ||
124 | + public ModelAndView list(Page page) throws Exception{ | ||
125 | + logBefore(logger, Jurisdiction.getUsername()+"列表Firm"); | ||
126 | + //if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;} //校验权限(无权查看时页面会有提示,如果不注释掉这句代码就无法进入列表页面,所以根据情况是否加入本句代码) | ||
127 | + ModelAndView mv = this.getModelAndView(); | ||
128 | + PageData pd = new PageData(); | ||
129 | + pd = this.getPageData(); | ||
130 | + String keywords = pd.getString("keywords"); //关键词检索条件 | ||
131 | + if(null != keywords && !"".equals(keywords)){ | ||
132 | + pd.put("keywords", keywords.trim()); | ||
133 | + } | ||
134 | + page.setPd(pd); | ||
135 | + List<PageData> varList = firmService.list(page); //列出Firm列表 | ||
136 | + mv.setViewName("software/firm/firm_list"); | ||
137 | + List<PageData> productList = firmwareService.listAll(pd); | ||
138 | + mv.addObject("productList",productList); | ||
139 | + mv.addObject("varList", varList); | ||
140 | + mv.addObject("pd", pd); | ||
141 | + mv.addObject("QX",Jurisdiction.getHC()); //按钮权限 | ||
142 | + return mv; | ||
143 | + } | ||
144 | + | ||
145 | + /**去新增页面 | ||
146 | + * @param | ||
147 | + * @throws Exception | ||
148 | + */ | ||
149 | + @RequestMapping(value="/goAdd") | ||
150 | + public ModelAndView goAdd()throws Exception{ | ||
151 | + ModelAndView mv = this.getModelAndView(); | ||
152 | + PageData pd = new PageData(); | ||
153 | + pd = this.getPageData(); | ||
154 | + mv.setViewName("software/firm/firm_edit"); | ||
155 | + mv.addObject("msg", "save"); | ||
156 | + List<PageData> productList = firmwareService.listAll(pd); | ||
157 | + mv.addObject("productList",productList); | ||
158 | + mv.addObject("pd", pd); | ||
159 | + return mv; | ||
160 | + } | ||
161 | + | ||
162 | + /**去修改页面 | ||
163 | + * @param | ||
164 | + * @throws Exception | ||
165 | + */ | ||
166 | + @RequestMapping(value="/goEdit") | ||
167 | + public ModelAndView goEdit()throws Exception{ | ||
168 | + ModelAndView mv = this.getModelAndView(); | ||
169 | + PageData pd = new PageData(); | ||
170 | + pd = this.getPageData(); | ||
171 | + pd = firmService.findById(pd); //根据ID读取 | ||
172 | + mv.setViewName("software/firm/firm_edit"); | ||
173 | + List<PageData> productList = firmwareService.listAll(pd); | ||
174 | + mv.addObject("productList",productList); | ||
175 | + mv.addObject("msg", "edit"); | ||
176 | + mv.addObject("pd", pd); | ||
177 | + return mv; | ||
178 | + } | ||
179 | + | ||
180 | + /**批量删除 | ||
181 | + * @param | ||
182 | + * @throws Exception | ||
183 | + */ | ||
184 | + @RequestMapping(value="/deleteAll") | ||
185 | + @ResponseBody | ||
186 | + public Object deleteAll() throws Exception{ | ||
187 | + logBefore(logger, Jurisdiction.getUsername()+"批量删除Firm"); | ||
188 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return null;} //校验权限 | ||
189 | + PageData pd = new PageData(); | ||
190 | + Map<String,Object> map = new HashMap<String,Object>(); | ||
191 | + pd = this.getPageData(); | ||
192 | + List<PageData> pdList = new ArrayList<PageData>(); | ||
193 | + String DATA_IDS = pd.getString("DATA_IDS"); | ||
194 | + if(null != DATA_IDS && !"".equals(DATA_IDS)){ | ||
195 | + String ArrayDATA_IDS[] = DATA_IDS.split(","); | ||
196 | + firmService.deleteAll(ArrayDATA_IDS); | ||
197 | + pd.put("msg", "ok"); | ||
198 | + }else{ | ||
199 | + pd.put("msg", "no"); | ||
200 | + } | ||
201 | + pdList.add(pd); | ||
202 | + map.put("list", pdList); | ||
203 | + return AppUtil.returnObject(pd, map); | ||
204 | + } | ||
205 | + | ||
206 | + /**导出到excel | ||
207 | + * @param | ||
208 | + * @throws Exception | ||
209 | + */ | ||
210 | + @RequestMapping(value="/excel") | ||
211 | + public ModelAndView exportExcel() throws Exception{ | ||
212 | + logBefore(logger, Jurisdiction.getUsername()+"导出Firm到excel"); | ||
213 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;} | ||
214 | + ModelAndView mv = new ModelAndView(); | ||
215 | + PageData pd = new PageData(); | ||
216 | + pd = this.getPageData(); | ||
217 | + Map<String,Object> dataMap = new HashMap<String,Object>(); | ||
218 | + List<String> titles = new ArrayList<String>(); | ||
219 | + titles.add("产品名称"); //1 | ||
220 | + titles.add("固件版本"); //2 | ||
221 | + titles.add("固件版本号"); //3 | ||
222 | + titles.add("固件路径"); //4 | ||
223 | + titles.add("固件描述"); //5 | ||
224 | + dataMap.put("titles", titles); | ||
225 | + List<PageData> varOList = firmService.listAll(pd); | ||
226 | + List<PageData> varList = new ArrayList<PageData>(); | ||
227 | + for(int i=0;i<varOList.size();i++){ | ||
228 | + PageData vpd = new PageData(); | ||
229 | + vpd.put("var1", varOList.get(i).getString("PRODUCT_NAME")); //1 | ||
230 | + vpd.put("var2", varOList.get(i).getString("FIRM_VERSION")); //2 | ||
231 | + vpd.put("var3", varOList.get(i).get("FRIM_CODE").toString()); //3 | ||
232 | + vpd.put("var4", varOList.get(i).getString("FIRM_PATH")); //4 | ||
233 | + vpd.put("var5", varOList.get(i).getString("FIRM_DESC")); //5 | ||
234 | + varList.add(vpd); | ||
235 | + } | ||
236 | + dataMap.put("varList", varList); | ||
237 | + ObjectExcelView erv = new ObjectExcelView(); | ||
238 | + mv = new ModelAndView(erv,dataMap); | ||
239 | + return mv; | ||
240 | + } | ||
241 | + | ||
242 | + @InitBinder | ||
243 | + public void initBinder(WebDataBinder binder){ | ||
244 | + DateFormat format = new SimpleDateFormat("yyyy-MM-dd"); | ||
245 | + binder.registerCustomEditor(Date.class, new CustomDateEditor(format,true)); | ||
246 | + } | ||
247 | +} |
src/com/fh/controller/software/firmware/FirmwareController.java
0 → 100644
1 | +package com.fh.controller.software.firmware; | ||
2 | + | ||
3 | +import java.io.File; | ||
4 | +import java.io.PrintWriter; | ||
5 | +import java.text.DateFormat; | ||
6 | +import java.text.SimpleDateFormat; | ||
7 | +import java.util.ArrayList; | ||
8 | +import java.util.Date; | ||
9 | +import java.util.HashMap; | ||
10 | +import java.util.List; | ||
11 | +import java.util.Map; | ||
12 | + | ||
13 | +import javax.annotation.Resource; | ||
14 | +import javax.servlet.http.HttpServletRequest; | ||
15 | + | ||
16 | +import org.springframework.beans.propertyeditors.CustomDateEditor; | ||
17 | +import org.springframework.stereotype.Controller; | ||
18 | +import org.springframework.web.bind.WebDataBinder; | ||
19 | +import org.springframework.web.bind.annotation.InitBinder; | ||
20 | +import org.springframework.web.bind.annotation.RequestMapping; | ||
21 | +import org.springframework.web.bind.annotation.RequestParam; | ||
22 | +import org.springframework.web.bind.annotation.ResponseBody; | ||
23 | +import org.springframework.web.multipart.MultipartFile; | ||
24 | +import org.springframework.web.servlet.ModelAndView; | ||
25 | + | ||
26 | +import com.fh.controller.base.BaseController; | ||
27 | +import com.fh.entity.Page; | ||
28 | +import com.fh.util.AppUtil; | ||
29 | +import com.fh.util.ObjectExcelView; | ||
30 | +import com.fh.util.PageData; | ||
31 | +import com.fh.util.Jurisdiction; | ||
32 | +import com.fh.util.Tools; | ||
33 | +import com.fh.service.software.firmware.FirmwareManager; | ||
34 | + | ||
35 | +/** | ||
36 | + * 说明:固件管理 | ||
37 | + * 创建人:FH Q313596790 | ||
38 | + * 创建时间:2018-07-09 | ||
39 | + */ | ||
40 | +@Controller | ||
41 | +@RequestMapping(value="/firmware") | ||
42 | +public class FirmwareController extends BaseController { | ||
43 | + | ||
44 | + String menuUrl = "firmware/list.do"; //菜单地址(权限用) | ||
45 | + @Resource(name="firmwareService") | ||
46 | + private FirmwareManager firmwareService; | ||
47 | + | ||
48 | + /**保存 | ||
49 | + * @param | ||
50 | + * @throws Exception | ||
51 | + */ | ||
52 | + @RequestMapping(value="/save") | ||
53 | + public ModelAndView save(@RequestParam(value="PRODUCT_IMAGE",required=false) MultipartFile[] files, HttpServletRequest request) throws Exception{ | ||
54 | + logBefore(logger, Jurisdiction.getUsername()+"新增Firmware"); | ||
55 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "add")){return null;} //校验权限 | ||
56 | + ModelAndView mv = this.getModelAndView(); | ||
57 | + PageData pd = new PageData(request); | ||
58 | + pd.put("FIRMWARE_ID", this.get32UUID()); //主键 | ||
59 | + pd.put("CREATE_DATE", Tools.date2Str(new Date())); | ||
60 | + String path = request.getSession().getServletContext() | ||
61 | + .getRealPath("/uploadFiles/uploadFile/"); | ||
62 | + int index = 0 ; | ||
63 | + String FIRM_PATH = "" ; | ||
64 | + if (files != null) { | ||
65 | + for (MultipartFile file : files) { | ||
66 | + if (file != null) { | ||
67 | + String name = pd.getString("FIRMWARE_ID")+ "_" + index + file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")); | ||
68 | + File pathFile = new File(path); | ||
69 | + pathFile.mkdirs(); | ||
70 | + File saveFile = new File(path + File.separator + name); | ||
71 | + if (saveFile.exists()) { | ||
72 | + saveFile.delete(); | ||
73 | + } | ||
74 | + saveFile.createNewFile(); | ||
75 | + file.transferTo(saveFile); | ||
76 | + FIRM_PATH += name + ";"; | ||
77 | + } | ||
78 | + index++; | ||
79 | + } | ||
80 | + } | ||
81 | + | ||
82 | + pd.put("PRODUCT_IMAGE", FIRM_PATH); | ||
83 | + firmwareService.save(pd); | ||
84 | + mv.addObject("msg","success"); | ||
85 | + mv.setViewName("save_result"); | ||
86 | + return mv; | ||
87 | + } | ||
88 | + | ||
89 | + /**删除 | ||
90 | + * @param out | ||
91 | + * @throws Exception | ||
92 | + */ | ||
93 | + @RequestMapping(value="/delete") | ||
94 | + public void delete(PrintWriter out,HttpServletRequest request) throws Exception{ | ||
95 | + logBefore(logger, Jurisdiction.getUsername()+"删除Firmware"); | ||
96 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return;} //校验权限 | ||
97 | + PageData pd = new PageData(); | ||
98 | + pd = this.getPageData(); | ||
99 | + firmwareService.delete(pd); | ||
100 | + String path = request.getSession().getServletContext() | ||
101 | + .getRealPath("/uploadFiles/uploadFile/"); | ||
102 | + String fileList = pd.getString("PRODUCT_IMAGE"); | ||
103 | + String[] fileName = fileList.split(";"); | ||
104 | + for(String fName:fileName){ | ||
105 | + File file = new File(path + File.separator + fName); | ||
106 | + file.deleteOnExit(); | ||
107 | + } | ||
108 | + out.write("success"); | ||
109 | + out.close(); | ||
110 | + } | ||
111 | + | ||
112 | + /**修改 | ||
113 | + * @param | ||
114 | + * @throws Exception | ||
115 | + */ | ||
116 | + @RequestMapping(value="/edit") | ||
117 | + public ModelAndView edit(@RequestParam(value="PRODUCT_IMAGE",required=false) MultipartFile[] files, HttpServletRequest request) throws Exception{ | ||
118 | + logBefore(logger, Jurisdiction.getUsername()+"修改Firmware"); | ||
119 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "edit")){return null;} //校验权限 | ||
120 | + ModelAndView mv = this.getModelAndView(); | ||
121 | + PageData pd = new PageData(); | ||
122 | + pd = this.getPageData(); | ||
123 | + | ||
124 | + String path = request.getSession().getServletContext() | ||
125 | + .getRealPath("/uploadFiles/uploadFile/"); | ||
126 | + int index = 0 ; | ||
127 | + String FIRM_PATH = "" ; | ||
128 | + if (files != null) { | ||
129 | + for (MultipartFile file : files) { | ||
130 | + System.out.println("filename:" + file.getSize()); | ||
131 | + if (file != null && file.getSize() != 0) { | ||
132 | + String name = pd.getString("FIRMWARE_ID") | ||
133 | + + "_" | ||
134 | + + index | ||
135 | + + file.getOriginalFilename() | ||
136 | + .substring( | ||
137 | + file.getOriginalFilename() | ||
138 | + .lastIndexOf(".")); | ||
139 | + File pathFile = new File(path); | ||
140 | + pathFile.mkdirs(); | ||
141 | + File saveFile = new File(path + File.separator + name); | ||
142 | + if (saveFile.exists()) { | ||
143 | + saveFile.delete(); | ||
144 | + } | ||
145 | + saveFile.createNewFile(); | ||
146 | + file.transferTo(saveFile); | ||
147 | + FIRM_PATH += name + ";"; | ||
148 | + }else{ | ||
149 | + String imagePath = pd.getString("PRODUCT_IMAGE" + index); | ||
150 | + if(imagePath != null){ | ||
151 | + FIRM_PATH += imagePath + ";"; | ||
152 | + }else{ | ||
153 | + FIRM_PATH += ";"; | ||
154 | + } | ||
155 | + } | ||
156 | + index++; | ||
157 | + } | ||
158 | + } | ||
159 | + pd.put("PRODUCT_IMAGE", FIRM_PATH); | ||
160 | + firmwareService.edit(pd); | ||
161 | + mv.addObject("msg","success"); | ||
162 | + mv.setViewName("save_result"); | ||
163 | + return mv; | ||
164 | + } | ||
165 | + | ||
166 | + /**列表 | ||
167 | + * @param page | ||
168 | + * @throws Exception | ||
169 | + */ | ||
170 | + @RequestMapping(value="/list") | ||
171 | + public ModelAndView list(Page page) throws Exception{ | ||
172 | + logBefore(logger, Jurisdiction.getUsername()+"列表Firmware"); | ||
173 | + //if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;} //校验权限(无权查看时页面会有提示,如果不注释掉这句代码就无法进入列表页面,所以根据情况是否加入本句代码) | ||
174 | + ModelAndView mv = this.getModelAndView(); | ||
175 | + PageData pd = new PageData(); | ||
176 | + pd = this.getPageData(); | ||
177 | + String keywords = pd.getString("KEYWORDS"); //关键词检索条件 | ||
178 | + if(null != keywords && !"".equals(keywords)){ | ||
179 | + pd.put("KEYWORDS", keywords.trim()); | ||
180 | + } | ||
181 | + page.setPd(pd); | ||
182 | + List<PageData> varList = firmwareService.list(page); //列出Firmware列表 | ||
183 | + mv.setViewName("software/firmware/firmware_list"); | ||
184 | + mv.addObject("varList", varList); | ||
185 | + mv.addObject("pd", pd); | ||
186 | + mv.addObject("QX",Jurisdiction.getHC()); //按钮权限 | ||
187 | + return mv; | ||
188 | + } | ||
189 | + | ||
190 | + /**去新增页面 | ||
191 | + * @param | ||
192 | + * @throws Exception | ||
193 | + */ | ||
194 | + @RequestMapping(value="/goAdd") | ||
195 | + public ModelAndView goAdd()throws Exception{ | ||
196 | + ModelAndView mv = this.getModelAndView(); | ||
197 | + PageData pd = new PageData(); | ||
198 | + pd = this.getPageData(); | ||
199 | + mv.setViewName("software/firmware/firmware_edit"); | ||
200 | + mv.addObject("msg", "save"); | ||
201 | + mv.addObject("pd", pd); | ||
202 | + return mv; | ||
203 | + } | ||
204 | + | ||
205 | + /**去修改页面 | ||
206 | + * @param | ||
207 | + * @throws Exception | ||
208 | + */ | ||
209 | + @RequestMapping(value="/goEdit") | ||
210 | + public ModelAndView goEdit()throws Exception{ | ||
211 | + ModelAndView mv = this.getModelAndView(); | ||
212 | + PageData pd = new PageData(); | ||
213 | + pd = this.getPageData(); | ||
214 | + pd = firmwareService.findById(pd); //根据ID读取 | ||
215 | + String PRODUCT_IMAGE = pd.getString("PRODUCT_IMAGE"); | ||
216 | + String[] PRODUCT_IMAGEs = PRODUCT_IMAGE.split(";"); | ||
217 | + pd.put("PRODUCT_IMAGE", PRODUCT_IMAGEs); | ||
218 | + mv.setViewName("software/firmware/firmware_edit"); | ||
219 | + mv.addObject("msg", "edit"); | ||
220 | + mv.addObject("pd", pd); | ||
221 | + return mv; | ||
222 | + } | ||
223 | + | ||
224 | + /**批量删除 | ||
225 | + * @param | ||
226 | + * @throws Exception | ||
227 | + */ | ||
228 | + @RequestMapping(value="/deleteAll") | ||
229 | + @ResponseBody | ||
230 | + public Object deleteAll() throws Exception{ | ||
231 | + logBefore(logger, Jurisdiction.getUsername()+"批量删除Firmware"); | ||
232 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "del")){return null;} //校验权限 | ||
233 | + PageData pd = new PageData(); | ||
234 | + Map<String,Object> map = new HashMap<String,Object>(); | ||
235 | + pd = this.getPageData(); | ||
236 | + List<PageData> pdList = new ArrayList<PageData>(); | ||
237 | + String DATA_IDS = pd.getString("DATA_IDS"); | ||
238 | + if(null != DATA_IDS && !"".equals(DATA_IDS)){ | ||
239 | + String ArrayDATA_IDS[] = DATA_IDS.split(","); | ||
240 | + firmwareService.deleteAll(ArrayDATA_IDS); | ||
241 | + pd.put("msg", "ok"); | ||
242 | + }else{ | ||
243 | + pd.put("msg", "no"); | ||
244 | + } | ||
245 | + pdList.add(pd); | ||
246 | + map.put("list", pdList); | ||
247 | + return AppUtil.returnObject(pd, map); | ||
248 | + } | ||
249 | + | ||
250 | + /**导出到excel | ||
251 | + * @param | ||
252 | + * @throws Exception | ||
253 | + */ | ||
254 | + @RequestMapping(value="/excel") | ||
255 | + public ModelAndView exportExcel() throws Exception{ | ||
256 | + logBefore(logger, Jurisdiction.getUsername()+"导出Firmware到excel"); | ||
257 | + if(!Jurisdiction.buttonJurisdiction(menuUrl, "cha")){return null;} | ||
258 | + ModelAndView mv = new ModelAndView(); | ||
259 | + PageData pd = new PageData(); | ||
260 | + pd = this.getPageData(); | ||
261 | + Map<String,Object> dataMap = new HashMap<String,Object>(); | ||
262 | + List<String> titles = new ArrayList<String>(); | ||
263 | + titles.add("产品名称"); //1 | ||
264 | + titles.add("货品编号"); //2 | ||
265 | + titles.add("应用行业"); //3 | ||
266 | + titles.add("产品状态"); //4 | ||
267 | + titles.add("产品规格"); //5 | ||
268 | + titles.add("产品功能"); //6 | ||
269 | + titles.add("产品性能"); //7 | ||
270 | + titles.add("适配硬件"); //8 | ||
271 | + titles.add("适配软件"); //9 | ||
272 | + titles.add("产品认证"); //10 | ||
273 | + titles.add("注意事项"); //11 | ||
274 | + titles.add("产品照片"); //12 | ||
275 | + dataMap.put("titles", titles); | ||
276 | + List<PageData> varOList = firmwareService.listAll(pd); | ||
277 | + List<PageData> varList = new ArrayList<PageData>(); | ||
278 | + for(int i=0;i<varOList.size();i++){ | ||
279 | + PageData vpd = new PageData(); | ||
280 | + vpd.put("var1", varOList.get(i).getString("PRODUCT_NAME")); //1 | ||
281 | + vpd.put("var2", varOList.get(i).getString("PRODUCT_NO")); //2 | ||
282 | + vpd.put("var3", varOList.get(i).getString("INDUSTRY")); //3 | ||
283 | + vpd.put("var4", varOList.get(i).getString("PRODUCT_STATE")); //4 | ||
284 | + vpd.put("var5", varOList.get(i).getString("PRODUCT_SPEC")); //5 | ||
285 | + vpd.put("var6", varOList.get(i).getString("PRODUCT_FUNC")); //6 | ||
286 | + vpd.put("var7", varOList.get(i).getString("PRODUCT_PERF")); //7 | ||
287 | + vpd.put("var8", varOList.get(i).getString("ADAPTABLE_HARDWARE")); //8 | ||
288 | + vpd.put("var9", varOList.get(i).getString("ADAPTABLE_SOFTWARE")); //9 | ||
289 | + vpd.put("var10", varOList.get(i).getString("PRODUCT_CERT")); //10 | ||
290 | + vpd.put("var11", varOList.get(i).getString("REMARK")); //11 | ||
291 | + vpd.put("var12", varOList.get(i).getString("PRODUCT_IMAGE")); //12 | ||
292 | + varList.add(vpd); | ||
293 | + } | ||
294 | + dataMap.put("varList", varList); | ||
295 | + ObjectExcelView erv = new ObjectExcelView(); | ||
296 | + mv = new ModelAndView(erv,dataMap); | ||
297 | + return mv; | ||
298 | + } | ||
299 | + | ||
300 | + @InitBinder | ||
301 | + public void initBinder(WebDataBinder binder){ | ||
302 | + DateFormat format = new SimpleDateFormat("yyyy-MM-dd"); | ||
303 | + binder.registerCustomEditor(Date.class, new CustomDateEditor(format,true)); | ||
304 | + } | ||
305 | +} |
src/com/fh/service/software/firm/FirmManager.java
0 → 100644
1 | +package com.fh.service.software.firm; | ||
2 | + | ||
3 | +import java.util.List; | ||
4 | +import com.fh.entity.Page; | ||
5 | +import com.fh.util.PageData; | ||
6 | + | ||
7 | +/** | ||
8 | + * 说明: 固件管理接口 | ||
9 | + * 创建人:FH Q313596790 | ||
10 | + * 创建时间:2018-07-09 | ||
11 | + * @version | ||
12 | + */ | ||
13 | +public interface FirmManager{ | ||
14 | + | ||
15 | + /**新增 | ||
16 | + * @param pd | ||
17 | + * @throws Exception | ||
18 | + */ | ||
19 | + public void save(PageData pd)throws Exception; | ||
20 | + | ||
21 | + /**删除 | ||
22 | + * @param pd | ||
23 | + * @throws Exception | ||
24 | + */ | ||
25 | + public void delete(PageData pd)throws Exception; | ||
26 | + | ||
27 | + /**修改 | ||
28 | + * @param pd | ||
29 | + * @throws Exception | ||
30 | + */ | ||
31 | + public void edit(PageData pd)throws Exception; | ||
32 | + | ||
33 | + /**列表 | ||
34 | + * @param page | ||
35 | + * @throws Exception | ||
36 | + */ | ||
37 | + public List<PageData> list(Page page)throws Exception; | ||
38 | + | ||
39 | + /**列表(全部) | ||
40 | + * @param pd | ||
41 | + * @throws Exception | ||
42 | + */ | ||
43 | + public List<PageData> listAll(PageData pd)throws Exception; | ||
44 | + | ||
45 | + /**通过id获取数据 | ||
46 | + * @param pd | ||
47 | + * @throws Exception | ||
48 | + */ | ||
49 | + public PageData findById(PageData pd)throws Exception; | ||
50 | + | ||
51 | + /**批量删除 | ||
52 | + * @param ArrayDATA_IDS | ||
53 | + * @throws Exception | ||
54 | + */ | ||
55 | + public void deleteAll(String[] ArrayDATA_IDS)throws Exception; | ||
56 | + | ||
57 | +} | ||
58 | + |
src/com/fh/service/software/firm/impl/FirmService.java
0 → 100644
1 | +package com.fh.service.software.firm.impl; | ||
2 | + | ||
3 | +import java.util.List; | ||
4 | +import javax.annotation.Resource; | ||
5 | +import org.springframework.stereotype.Service; | ||
6 | +import com.fh.dao.DaoSupport; | ||
7 | +import com.fh.entity.Page; | ||
8 | +import com.fh.util.PageData; | ||
9 | +import com.fh.service.software.firm.FirmManager; | ||
10 | + | ||
11 | +/** | ||
12 | + * 说明: 固件管理 | ||
13 | + * 创建人:FH Q313596790 | ||
14 | + * 创建时间:2018-07-09 | ||
15 | + * @version | ||
16 | + */ | ||
17 | +@Service("firmService") | ||
18 | +public class FirmService implements FirmManager{ | ||
19 | + | ||
20 | + @Resource(name = "daoSupport") | ||
21 | + private DaoSupport dao; | ||
22 | + | ||
23 | + /**新增 | ||
24 | + * @param pd | ||
25 | + * @throws Exception | ||
26 | + */ | ||
27 | + public void save(PageData pd)throws Exception{ | ||
28 | + dao.save("FirmMapper.save", pd); | ||
29 | + } | ||
30 | + | ||
31 | + /**删除 | ||
32 | + * @param pd | ||
33 | + * @throws Exception | ||
34 | + */ | ||
35 | + public void delete(PageData pd)throws Exception{ | ||
36 | + dao.delete("FirmMapper.delete", pd); | ||
37 | + } | ||
38 | + | ||
39 | + /**修改 | ||
40 | + * @param pd | ||
41 | + * @throws Exception | ||
42 | + */ | ||
43 | + public void edit(PageData pd)throws Exception{ | ||
44 | + dao.update("FirmMapper.edit", pd); | ||
45 | + } | ||
46 | + | ||
47 | + /**列表 | ||
48 | + * @param page | ||
49 | + * @throws Exception | ||
50 | + */ | ||
51 | + @SuppressWarnings("unchecked") | ||
52 | + public List<PageData> list(Page page)throws Exception{ | ||
53 | + return (List<PageData>)dao.findForList("FirmMapper.datalistPage", page); | ||
54 | + } | ||
55 | + | ||
56 | + /**列表(全部) | ||
57 | + * @param pd | ||
58 | + * @throws Exception | ||
59 | + */ | ||
60 | + @SuppressWarnings("unchecked") | ||
61 | + public List<PageData> listAll(PageData pd)throws Exception{ | ||
62 | + return (List<PageData>)dao.findForList("FirmMapper.listAll", pd); | ||
63 | + } | ||
64 | + | ||
65 | + /**通过id获取数据 | ||
66 | + * @param pd | ||
67 | + * @throws Exception | ||
68 | + */ | ||
69 | + public PageData findById(PageData pd)throws Exception{ | ||
70 | + return (PageData)dao.findForObject("FirmMapper.findById", pd); | ||
71 | + } | ||
72 | + | ||
73 | + /**批量删除 | ||
74 | + * @param ArrayDATA_IDS | ||
75 | + * @throws Exception | ||
76 | + */ | ||
77 | + public void deleteAll(String[] ArrayDATA_IDS)throws Exception{ | ||
78 | + dao.delete("FirmMapper.deleteAll", ArrayDATA_IDS); | ||
79 | + } | ||
80 | + | ||
81 | +} | ||
82 | + |
src/com/fh/service/software/firmware/FirmwareManager.java
0 → 100644
1 | +package com.fh.service.software.firmware; | ||
2 | + | ||
3 | +import java.util.List; | ||
4 | +import com.fh.entity.Page; | ||
5 | +import com.fh.util.PageData; | ||
6 | + | ||
7 | +/** | ||
8 | + * 说明: 固件管理接口 | ||
9 | + * 创建人:FH Q313596790 | ||
10 | + * 创建时间:2018-07-09 | ||
11 | + * @version | ||
12 | + */ | ||
13 | +public interface FirmwareManager{ | ||
14 | + | ||
15 | + /**新增 | ||
16 | + * @param pd | ||
17 | + * @throws Exception | ||
18 | + */ | ||
19 | + public void save(PageData pd)throws Exception; | ||
20 | + | ||
21 | + /**删除 | ||
22 | + * @param pd | ||
23 | + * @throws Exception | ||
24 | + */ | ||
25 | + public void delete(PageData pd)throws Exception; | ||
26 | + | ||
27 | + /**修改 | ||
28 | + * @param pd | ||
29 | + * @throws Exception | ||
30 | + */ | ||
31 | + public void edit(PageData pd)throws Exception; | ||
32 | + | ||
33 | + /**列表 | ||
34 | + * @param page | ||
35 | + * @throws Exception | ||
36 | + */ | ||
37 | + public List<PageData> list(Page page)throws Exception; | ||
38 | + | ||
39 | + /**列表(全部) | ||
40 | + * @param pd | ||
41 | + * @throws Exception | ||
42 | + */ | ||
43 | + public List<PageData> listAll(PageData pd)throws Exception; | ||
44 | + | ||
45 | + /**通过id获取数据 | ||
46 | + * @param pd | ||
47 | + * @throws Exception | ||
48 | + */ | ||
49 | + public PageData findById(PageData pd)throws Exception; | ||
50 | + | ||
51 | + /**批量删除 | ||
52 | + * @param ArrayDATA_IDS | ||
53 | + * @throws Exception | ||
54 | + */ | ||
55 | + public void deleteAll(String[] ArrayDATA_IDS)throws Exception; | ||
56 | + | ||
57 | +} | ||
58 | + |
src/com/fh/service/software/firmware/impl/FirmwareService.java
0 → 100644
1 | +package com.fh.service.software.firmware.impl; | ||
2 | + | ||
3 | +import java.util.List; | ||
4 | +import javax.annotation.Resource; | ||
5 | +import org.springframework.stereotype.Service; | ||
6 | +import com.fh.dao.DaoSupport; | ||
7 | +import com.fh.entity.Page; | ||
8 | +import com.fh.util.PageData; | ||
9 | +import com.fh.service.software.firmware.FirmwareManager; | ||
10 | + | ||
11 | +/** | ||
12 | + * 说明: 固件管理 | ||
13 | + * 创建人:FH Q313596790 | ||
14 | + * 创建时间:2018-07-09 | ||
15 | + * @version | ||
16 | + */ | ||
17 | +@Service("firmwareService") | ||
18 | +public class FirmwareService implements FirmwareManager{ | ||
19 | + | ||
20 | + @Resource(name = "daoSupport") | ||
21 | + private DaoSupport dao; | ||
22 | + | ||
23 | + /**新增 | ||
24 | + * @param pd | ||
25 | + * @throws Exception | ||
26 | + */ | ||
27 | + public void save(PageData pd)throws Exception{ | ||
28 | + dao.save("FirmwareMapper.save", pd); | ||
29 | + } | ||
30 | + | ||
31 | + /**删除 | ||
32 | + * @param pd | ||
33 | + * @throws Exception | ||
34 | + */ | ||
35 | + public void delete(PageData pd)throws Exception{ | ||
36 | + dao.delete("FirmwareMapper.delete", pd); | ||
37 | + } | ||
38 | + | ||
39 | + /**修改 | ||
40 | + * @param pd | ||
41 | + * @throws Exception | ||
42 | + */ | ||
43 | + public void edit(PageData pd)throws Exception{ | ||
44 | + dao.update("FirmwareMapper.edit", pd); | ||
45 | + } | ||
46 | + | ||
47 | + /**列表 | ||
48 | + * @param page | ||
49 | + * @throws Exception | ||
50 | + */ | ||
51 | + @SuppressWarnings("unchecked") | ||
52 | + public List<PageData> list(Page page)throws Exception{ | ||
53 | + return (List<PageData>)dao.findForList("FirmwareMapper.datalistPage", page); | ||
54 | + } | ||
55 | + | ||
56 | + /**列表(全部) | ||
57 | + * @param pd | ||
58 | + * @throws Exception | ||
59 | + */ | ||
60 | + @SuppressWarnings("unchecked") | ||
61 | + public List<PageData> listAll(PageData pd)throws Exception{ | ||
62 | + return (List<PageData>)dao.findForList("FirmwareMapper.listAll", pd); | ||
63 | + } | ||
64 | + | ||
65 | + /**通过id获取数据 | ||
66 | + * @param pd | ||
67 | + * @throws Exception | ||
68 | + */ | ||
69 | + public PageData findById(PageData pd)throws Exception{ | ||
70 | + return (PageData)dao.findForObject("FirmwareMapper.findById", pd); | ||
71 | + } | ||
72 | + | ||
73 | + /**批量删除 | ||
74 | + * @param ArrayDATA_IDS | ||
75 | + * @throws Exception | ||
76 | + */ | ||
77 | + public void deleteAll(String[] ArrayDATA_IDS)throws Exception{ | ||
78 | + dao.delete("FirmwareMapper.deleteAll", ArrayDATA_IDS); | ||
79 | + } | ||
80 | + | ||
81 | +} | ||
82 | + |