527 lines
22 KiB
HTML
527 lines
22 KiB
HTML
<!DOCTYPE html>
|
||
<html>
|
||
<head>
|
||
<title>应用管理</title>
|
||
<meta charset="utf-8">
|
||
<!-- 指定以IE8的方式来渲染 -->
|
||
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE8"/>
|
||
<link rel="shortcut icon" href="/images/favicon.ico" type="image/x-icon"/>
|
||
<link rel="stylesheet" type="text/css" href="/js/easyui-1.3.5/themes/default/easyui.css"/>
|
||
<link rel="stylesheet" type="text/css" href="/js/easyui-1.3.5/themes/icon.css"/>
|
||
<link type="text/css" rel="stylesheet" href="/css/common.css"/>
|
||
<link href="/js/fileUploadQT/css/iconfont.css" rel="stylesheet" type="text/css"/>
|
||
<link href="/js/fileUploadQT/css/fileUpload.css" rel="stylesheet" type="text/css"/>
|
||
<script type="text/javascript" src="/js/jquery-1.8.0.min.js"></script>
|
||
<script type="text/javascript" src="/js/easyui-1.3.5/jquery.easyui.min.js"></script>
|
||
<script type="text/javascript" src="/js/easyui-1.3.5/locale/easyui-lang-zh_CN.js"></script>
|
||
<script src="/js/fileUploadQT/js/fileUpload.js"></script>
|
||
<script type="text/javascript" src="/js/common/common.js"></script>
|
||
</head>
|
||
<body>
|
||
<!-- 查询 -->
|
||
<div id="searchPanel" class="easyui-panel" style="padding:10px;" title="查询窗口" iconCls="icon-search" collapsible="true"
|
||
closable="false">
|
||
<table id="searchTable">
|
||
<tr>
|
||
<td>名称:</td>
|
||
<td>
|
||
<input type="text" name="searchName" id="searchName" style="width:100px;"/>
|
||
</td>
|
||
<td> </td>
|
||
<td> </td>
|
||
<td>种类:</td>
|
||
<td>
|
||
<input type="text" name="searchType" id="searchType" style="width:100px;"/>
|
||
</td>
|
||
<td> </td>
|
||
<td> </td>
|
||
<td> </td>
|
||
<td>
|
||
<a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-search" id="searchBtn">查询</a>
|
||
<a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-redo" id="searchResetBtn">重置</a>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<!-- 数据显示table -->
|
||
<div id="tablePanel" class="easyui-panel" style="padding:1px;top:300px;" title="应用列表" iconCls="icon-list"
|
||
collapsible="true" closable="false">
|
||
<table id="tableData" style="top:300px;border-bottom-color:#FFFFFF"></table>
|
||
</div>
|
||
|
||
<div id="appDlg" class="easyui-dialog" style="width:600px;padding:10px 20px;top:20px"
|
||
closed="true" buttons="#dlg-buttons" modal="true" cache="false" collapsible="false" closable="true">
|
||
<form id="appFM" method="post" enctype="multipart/form-data">
|
||
<table>
|
||
<tr>
|
||
<td style="width: 50px;height: 20px">代号</td>
|
||
<td style="padding:1px"><input name="Number" id="Number" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td style="width: 50px;height: 20px">名称</td>
|
||
<td style="padding:1px"><input name="Name" id="Name" class="easyui-validatebox"
|
||
data-options="required:true,validType:'length[2,30]'" style="width: 150px;height: 20px"/></td>
|
||
<td style="width: 50px;height: 20px">拉伸</td>
|
||
<td style="padding:1px"><input name="ReSize" id="ReSize" type="checkbox" style="width: 50px;height: 20px"/></td>
|
||
</tr>
|
||
<tr>
|
||
<td>类型</td>
|
||
<td style="padding:1px"><input name="Type" id="Type" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>链接</td>
|
||
<td style="padding:1px"><input name="URL" id="URL" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>最大化</td>
|
||
<td style="padding:1px"><input name="OpenMax" id="OpenMax" type="checkbox" style="width: 50px;height: 20px"/></td>
|
||
</tr>
|
||
<tr>
|
||
<td>宽度</td>
|
||
<td style="padding:1px"><input name="Width" id="Width" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>高度</td>
|
||
<td style="padding:1px"><input name="Height" id="Height" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>Flash</td>
|
||
<td style="padding:1px"><input name="Flash" id="Flash" type="checkbox" style="width: 50px;height: 20px"/></td>
|
||
</tr>
|
||
<tr>
|
||
<td>排序号</td>
|
||
<td style="padding:1px"><input name="Sort" id="Sort" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>种类</td>
|
||
<td style="padding:1px"><input name="ZL" id="ZL" class="easyui-textbox" style="width: 150px;height: 20px"/></td>
|
||
<td>启用</td>
|
||
<td style="padding:1px"><input name="Enabled" id="Enabled" type="checkbox" style="width: 50px;height: 20px"/></td>
|
||
</tr>
|
||
<tr>
|
||
<td>备注</td>
|
||
<td style="padding:1px" colspan="5"><input name="Remark" id="Remark" class="easyui-textbox" style="width: 480px;height: 20px"/></td>
|
||
</tr>
|
||
<tr>
|
||
<td>图标</td>
|
||
<td style="padding:1px" colspan="5">
|
||
<div id="Icon" class="fileUploadContent"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</form>
|
||
</div>
|
||
<div id="dlg-buttons">
|
||
<a href="javascript:void(0)" id="saveApp" class="easyui-linkbutton" iconCls="icon-ok">保存</a>
|
||
<a href="javascript:void(0)" id="cancelApp" class="easyui-linkbutton" iconCls="icon-cancel"
|
||
onclick="javascript:$('#appDlg').dialog('close')">取消</a>
|
||
</div>
|
||
|
||
<script type="text/javascript">
|
||
//初始化界面
|
||
$(function () {
|
||
initTableData();
|
||
ininPager();
|
||
initForm();
|
||
});
|
||
|
||
|
||
//防止表单提交重复
|
||
function initForm() {
|
||
$('#appFM').form({
|
||
onSubmit: function () {
|
||
return false;
|
||
}
|
||
});
|
||
}
|
||
|
||
//初始化表格数据
|
||
function initTableData() {
|
||
$('#tableData').datagrid({
|
||
//title:'应用列表',
|
||
//iconCls:'icon-save',
|
||
//width:700,
|
||
height: heightInfo,
|
||
nowrap: false,
|
||
rownumbers: false,
|
||
//动画效果
|
||
animate: false,
|
||
//选中单行
|
||
singleSelect: true,
|
||
collapsible: false,
|
||
selectOnCheck: false,
|
||
//fitColumns:true,
|
||
//单击行是否选中
|
||
checkOnSelect: false,
|
||
pagination: true,
|
||
//交替出现背景
|
||
striped: true,
|
||
//loadFilter: pagerFilter,
|
||
pageSize: initPageSize,
|
||
pageList: initPageNum,
|
||
columns: [[
|
||
{field: 'id', width: 35, align: "center", checkbox: true},
|
||
{title: '代号', field: 'number', width: 50},
|
||
{title: '应用名称', field: 'name', width: 100},
|
||
{title: '类型', field: 'type', width: 50},
|
||
{
|
||
title: '图标', field: 'icon', width: 100, formatter: function (value, row) {
|
||
if (value != null) {
|
||
return "<img alt='图标' style='width:32px;height:32px;' src=\"../../upload/images/deskIcon/" + value + "\" />";
|
||
}
|
||
}
|
||
},
|
||
{title: '链接', field: 'url', width: 100},
|
||
{title: '宽度', field: 'width', width: 50},
|
||
{title: '高度', field: 'height', width: 50},
|
||
{
|
||
title: '拉伸', field: 'resize', width: 50, formatter: function (value) {
|
||
return value ? "开" : "关";
|
||
}
|
||
},
|
||
{
|
||
title: '最大化', field: 'openmax', width: 50, formatter: function (value) {
|
||
return value ? "开" : "关";
|
||
}
|
||
},
|
||
{
|
||
title: 'Flash', field: 'flash', width: 50, formatter: function (value) {
|
||
return value ? "开" : "关";
|
||
}
|
||
},
|
||
{title: '种类', field: 'zl', width: 50},
|
||
{title: '排序号', field: 'sort', width: 50},
|
||
{title: '备注', field: 'remark', width: 50},
|
||
{
|
||
title: '启用', field: 'enabled', width: 50, formatter: function (value) {
|
||
return value ? "开" : "关";
|
||
}
|
||
},
|
||
{
|
||
title: '操作', field: 'op', align: "center", width: 130, formatter: function (value, rec) {
|
||
var str = '';
|
||
var rowInfo = rec.id + 'AaBb' + rec.number + 'AaBb' + rec.name + 'AaBb' + rec.type + 'AaBb' + rec.icon
|
||
+ 'AaBb' + rec.url + 'AaBb' + rec.width + 'AaBb' + rec.height + 'AaBb' + rec.resize + 'AaBb' + rec.openmax
|
||
+ 'AaBb' + rec.flash + 'AaBb' + rec.zl + 'AaBb' + rec.sort + 'AaBb' + rec.remark + 'AaBb' + rec.enabled;
|
||
str += '<img src="/js/easyui-1.3.5/themes/icons/pencil.png" style="cursor: pointer;" onclick="editApp(\'' + rowInfo + '\');"/> <a onclick="editApp(\'' + rowInfo + '\');" style="text-decoration:none;color:black;" href="javascript:void(0)">编辑</a> ';
|
||
str += '<img src="/js/easyui-1.3.5/themes/icons/edit_remove.png" style="cursor: pointer;" onclick="deleteApp(' + rec.id + ');"/> <a onclick="deleteApp(' + rec.id + ');" style="text-decoration:none;color:black;" href="javascript:void(0)">删除</a> ';
|
||
return str;
|
||
}
|
||
}
|
||
]],
|
||
toolbar: [
|
||
{
|
||
id: 'addApp',
|
||
text: '增加',
|
||
iconCls: 'icon-add',
|
||
handler: function () {
|
||
addApp();
|
||
}
|
||
},
|
||
{
|
||
id: 'deleteApp',
|
||
text: '删除',
|
||
iconCls: 'icon-remove',
|
||
handler: function () {
|
||
batDeleteApp();
|
||
}
|
||
}
|
||
],
|
||
onLoadError: function () {
|
||
$.messager.alert('页面加载提示', '页面加载异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
showAppDetails(1, initPageSize);
|
||
}
|
||
|
||
//初始化键盘enter事件
|
||
$(document).keydown(function (event) {
|
||
//兼容 IE和firefox 事件
|
||
var e = window.event || event;
|
||
var k = e.keyCode || e.which || e.charCode;
|
||
//兼容 IE,firefox 兼容
|
||
var obj = e.srcElement ? e.srcElement : e.target;
|
||
//绑定键盘事件为 id是指定的输入框才可以触发键盘事件 13键盘事件 ---遗留问题 enter键效验 对话框会关闭问题
|
||
if (k == "13" && (obj.id == "Number" || obj.id == "Name" || obj.id == "Type" || obj.id == "Icon" || obj.id == "URL"
|
||
|| obj.id == "Width" || obj.id == "Height" || obj.id == "ZL" || obj.id == "Sort" || obj.id == "Remark")) {
|
||
$("#saveApp").click();
|
||
}
|
||
//搜索按钮添加快捷键
|
||
if (k == "13" && (obj.id == "searchName" || obj.id == "searchType")) {
|
||
$("#searchBtn").click();
|
||
}
|
||
});
|
||
|
||
//分页信息处理
|
||
function ininPager() {
|
||
try {
|
||
var opts = $("#tableData").datagrid('options');
|
||
var pager = $("#tableData").datagrid('getPager');
|
||
pager.pagination({
|
||
onSelectPage: function (pageNum, pageSize) {
|
||
opts.pageNumber = pageNum;
|
||
opts.pageSize = pageSize;
|
||
pager.pagination('refresh', {
|
||
pageNumber: pageNum,
|
||
pageSize: pageSize
|
||
});
|
||
showAppDetails(pageNum, pageSize);
|
||
}
|
||
});
|
||
}
|
||
catch (e) {
|
||
$.messager.alert('异常处理提示', "分页信息异常 : " + e.name + ": " + e.message, 'error');
|
||
}
|
||
}
|
||
|
||
//删除应用信息
|
||
function deleteApp(appID) {
|
||
$.messager.confirm('删除确认', '确定要删除此应用信息吗?', function (r) {
|
||
if (r) {
|
||
$.ajax({
|
||
type: "post",
|
||
url: "/app/" + appID + "/delete",
|
||
dataType: "json",
|
||
success: function (res) {
|
||
if(res && res.code == 200) {
|
||
$("#searchBtn").click();
|
||
} else {
|
||
$.messager.alert('删除提示', '删除应用信息失败,请稍后再试!', 'error');
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error: function () {
|
||
$.messager.alert('删除提示', '删除应用信息异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
});
|
||
}
|
||
|
||
//批量删除
|
||
function batDeleteApp() {
|
||
var row = $('#tableData').datagrid('getChecked');
|
||
if (row.length == 0) {
|
||
$.messager.alert('删除提示', '没有记录被选中!', 'info');
|
||
return;
|
||
}
|
||
if (row.length > 0) {
|
||
$.messager.confirm('删除确认', '确定要删除选中的' + row.length + '条应用信息吗?', function (r) {
|
||
if (r) {
|
||
var ids = "";
|
||
for (var i = 0; i < row.length; i++) {
|
||
if (i == row.length - 1) {
|
||
ids += row[i].id;
|
||
break;
|
||
}
|
||
ids += row[i].id + ",";
|
||
}
|
||
$.ajax({
|
||
type: "post",
|
||
url: "/app/batchDelete",
|
||
dataType: "json",
|
||
async: false,
|
||
data: ({
|
||
ids: ids
|
||
}),
|
||
success: function (res) {
|
||
if(res && res.code === 200) {
|
||
$("#searchBtn").click();
|
||
$(":checkbox").attr("checked", false);
|
||
} else {
|
||
$.messager.alert('删除提示', '删除应用信息失败,请稍后再试!', 'error');
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error: function () {
|
||
$.messager.alert('删除提示', '删除应用信息异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
});
|
||
}
|
||
}
|
||
|
||
//增加
|
||
var url;
|
||
var appID = 0;
|
||
//保存编辑前的名称
|
||
var orgApp = "";
|
||
|
||
function addApp() {
|
||
$('#appFM').form('clear');
|
||
$('#appDlg').dialog('open').dialog('setTitle', '<img src="/js/easyui-1.3.5/themes/icons/edit_add.png"/> 增加应用信息');
|
||
$(".window-mask").css({width: webW, height: webH});
|
||
$("#name").val("").focus();
|
||
|
||
orgApp = "";
|
||
appID = 0;
|
||
url = '/app/add';
|
||
$("#Icon").empty();//清除上传控件数据
|
||
$(".fileUploadContent").initUpload({
|
||
"uploadUrl": "/app/uploadImg",//上传文件信息地址
|
||
"progressUrl": "#",//获取进度信息地址,可选,注意需要返回的data格式如下({bytesRead: 102516060, contentLength: 102516060, items: 1, percent: 100, startTime: 1489223136317, useTime: 2767})
|
||
//"showSummerProgress":false,//总进度条,默认限制
|
||
//"size":350,//文件大小限制,单位kb,默认不限制
|
||
"maxFileNumber": 1,//文件个数限制,为整数
|
||
//"filelSavePath":"",//文件上传地址,后台设置的根目录
|
||
//"beforeUpload":beforeUploadFun,//在上传前执行的函数
|
||
//"onUpload":onUploadFun, //在上传后执行的函数
|
||
autoCommit: true, //文件是否自动上传
|
||
"fileType": ['png', 'jpg']//文件类型限制,默认不限制,注意写的是文件后缀
|
||
});
|
||
}
|
||
|
||
//保存信息
|
||
$("#saveApp").off("click").on("click", function () {
|
||
if (checkAppName()) {
|
||
return;
|
||
}
|
||
var infoObj = $("#appFM").serializeObject();
|
||
if($("#Icon .fileItem .fileName").length){
|
||
infoObj.Icon = $.trim($("#Icon .fileItem .fileName").text());
|
||
}
|
||
infoObj.ReSize = $("#ReSize").is(':checked');
|
||
infoObj.OpenMax = $("#OpenMax").is(':checked');
|
||
infoObj.Flash = $("#Flash").is(':checked');
|
||
infoObj.Enabled = $("#Enabled").is(':checked');
|
||
$.ajax({
|
||
url: url,
|
||
type: "post",
|
||
dataType: "json",
|
||
data: ({
|
||
info: JSON.stringify(infoObj)
|
||
}),
|
||
success: function(res) {
|
||
if(res && res.code === 200) {
|
||
$('#appDlg').dialog('close');
|
||
//加载完以后重新初始化
|
||
var opts = $("#tableData").datagrid('options');
|
||
showAppDetails(opts.pageNumber, opts.pageSize);
|
||
} else {
|
||
$.messager.alert('提示', '保存应用信息异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error: function () {
|
||
$.messager.alert('提示', '保存应用信息异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
});
|
||
|
||
//编辑信息
|
||
function editApp(appTotalInfo) {
|
||
var appInfo = appTotalInfo.split("AaBb");
|
||
$("#Number").focus().val(appInfo[1]);
|
||
$("#Name").val(appInfo[2]);
|
||
$("#Type").val(appInfo[3]);
|
||
//$("#Icon").val(appInfo[4]);
|
||
$("#URL").val(appInfo[5]);
|
||
$("#Width").val(appInfo[6]);
|
||
$("#Height").val(appInfo[7]);
|
||
$("#ReSize").attr("checked", appInfo[8] == 'true' ? true : false);
|
||
$("#OpenMax").attr("checked", appInfo[9] == 'true' ? true : false);
|
||
$("#Flash").attr("checked", appInfo[10] == 'true' ? true : false);
|
||
$("#ZL").val(appInfo[11]);
|
||
$("#Sort").val(appInfo[12]);
|
||
$("#Remark").val(appInfo[13]);
|
||
$("#Enabled").attr("checked", appInfo[14] == 'true' ? true : false);
|
||
|
||
orgApp = appInfo[2];
|
||
$('#appDlg').dialog('open').dialog('setTitle', '<img src="/js/easyui-1.3.5/themes/icons/pencil.png"/> 编辑应用信息');
|
||
$(".window-mask").css({width: webW, height: webH});
|
||
appID = appInfo[0];
|
||
//焦点在名称输入框==定焦在输入文字后面
|
||
$("#name").val("").focus().val(appInfo[1]);
|
||
url = '/app/update?id=' + appInfo[0];
|
||
}
|
||
|
||
//检查名称是否存在 ++ 重名无法提示问题需要跟进
|
||
function checkAppName() {
|
||
var name = $.trim($("#Name").val());
|
||
//表示是否存在 true == 存在 false = 不存在
|
||
var flag = false;
|
||
//开始ajax名称检验,不能重名
|
||
if (name.length > 0 && (orgApp.length == 0 || name != orgApp)) {
|
||
$.ajax({
|
||
type: "get",
|
||
url: "/app/checkIsNameExist",
|
||
dataType: "json",
|
||
async: false,
|
||
data: ({
|
||
id: appID,
|
||
name: name
|
||
}),
|
||
success: function (res) {
|
||
if(res && res.code === 200) {
|
||
if(res.data && res.data.status) {
|
||
flag = res.data.status;
|
||
if (flag) {
|
||
$.messager.alert('提示', '应用名称已经存在', 'info');
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error: function () {
|
||
$.messager.alert('提示', '检查应用名称是否存在异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
return flag;
|
||
}
|
||
|
||
//搜索处理
|
||
$("#searchBtn").unbind().bind({
|
||
click: function () {
|
||
showAppDetails(1, initPageSize);
|
||
var opts = $("#tableData").datagrid('options');
|
||
var pager = $("#tableData").datagrid('getPager');
|
||
opts.pageNumber = 1;
|
||
opts.pageSize = initPageSize;
|
||
pager.pagination('refresh', {
|
||
pageNumber: 1,
|
||
pageSize: initPageSize
|
||
});
|
||
}
|
||
});
|
||
|
||
function showAppDetails(pageNo, pageSize) {
|
||
var searchName = $.trim($("#searchName").val());
|
||
var searchType = $.trim($("#searchType").val());
|
||
$.ajax({
|
||
type: "get",
|
||
url: "/app/list",
|
||
dataType: "json",
|
||
data: ({
|
||
search: JSON.stringify({
|
||
name: searchName,
|
||
type: searchType
|
||
}),
|
||
currentPage: pageNo,
|
||
pageSize: pageSize
|
||
}),
|
||
success: function (res) {
|
||
if(res && res.code === 200){
|
||
if(res.data && res.data.page) {
|
||
$("#tableData").datagrid('loadData', res.data.page);
|
||
}
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error: function () {
|
||
$.messager.alert('查询提示', '查询数据后台异常,请稍后再试!', 'error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
|
||
//重置按钮
|
||
$("#searchResetBtn").unbind().bind({
|
||
click: function () {
|
||
$("#searchName").val("");
|
||
$("#searchType").val("");
|
||
|
||
//加载完以后重新初始化
|
||
$("#searchBtn").click();
|
||
}
|
||
});
|
||
</script>
|
||
</body>
|
||
</html> |