574 lines
21 KiB
Plaintext
574 lines
21 KiB
Plaintext
<%@page import="com.jsh.util.common.Tools"%>
|
||
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
|
||
<%
|
||
String path = request.getContextPath();
|
||
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
|
||
String clientIp = Tools.getCurrentUserIP();
|
||
%>
|
||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||
<head>
|
||
<title>供应商信息</title>
|
||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||
<!-- 指定以IE8的方式来渲染 -->
|
||
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE8"/>
|
||
<link rel="shortcut icon" href="<%=path%>/images/favicon.ico" type="image/x-icon" />
|
||
<link rel="stylesheet" type="text/css" href="<%=path %>/js/easyui-1.3.5/themes/default/easyui.css"/>
|
||
<link rel="stylesheet" type="text/css" href="<%=path %>/js/easyui-1.3.5/themes/icon.css"/>
|
||
<link type="text/css" rel="stylesheet" href="<%=path %>/css/common.css" />
|
||
<script type="text/javascript" src="<%=path %>/js/jquery-1.8.0.min.js"></script>
|
||
<script type="text/javascript" src="<%=path %>/js/easyui-1.3.5/jquery.easyui.min.js"></script>
|
||
<script type="text/javascript" src="<%=path %>/js/easyui-1.3.5/locale/easyui-lang-zh_CN.js"></script>
|
||
<script type="text/javascript" src="<%=path %>/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="searchSupplier" id="searchSupplier" style="width:150px;"/>
|
||
</td>
|
||
|
||
<td> </td>
|
||
<td> </td>
|
||
<td id="searchTypeLabel">类 型:</td>
|
||
<td>
|
||
<select name="searchType" id="searchType" style="width:150px;">
|
||
<option value="">全部</option>
|
||
<option value="供应商">供应商</option>
|
||
<option value="客户">客户</option>
|
||
</select>
|
||
</td>
|
||
<td> </td>
|
||
<td> </td>
|
||
<td>联系电话:</td>
|
||
<td>
|
||
<input type="text" name="searchPhonenum" id="searchPhonenum" style="width:150px;"/>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>电子邮箱:</td>
|
||
<td>
|
||
<input type="text" name="searchEmail" id="searchEmail" style="width:150px;"/>
|
||
</td>
|
||
<td> </td>
|
||
<td> </td>
|
||
<td id="searchDescLabel">描 述:</td>
|
||
<td>
|
||
<input type="text" name="searchDesc" id="searchDesc" style="width:150px;"/>
|
||
</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="supplierDlg" class="easyui-dialog" style="width:380px;padding:10px 20px"
|
||
closed="true" buttons="#dlg-buttons" modal="true" collapsible="false" closable="true">
|
||
<form id="supplierFM" method="post" novalidate>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="supplierLabel">名 称</label>
|
||
<input name="supplier" id="supplier" class="easyui-validatebox" data-options="required:true,validType:'length[2,30]'" style="width: 230px;height: 20px"/>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="typeLabel">类 型</label>
|
||
<select name="type" id="type" style="width:230px;">
|
||
<option value="供应商">供应商</option>
|
||
<option value="客户">客户</option>
|
||
</select>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="contactsLabel">联 系 人 </label>
|
||
<input name="contacts" id="contacts" class="easyui-validatebox" style="width: 230px;height: 20px"/>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="phonenumLabel">联系电话 </label>
|
||
<input name="phonenum" id="phonenum" class="easyui-numberbox" style="width: 230px;height: 20px"/>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="emailLabel">电子邮箱 </label>
|
||
<input name="email" id="email" class="easyui-validatebox" validType="email" style="width: 230px;height: 20px"/>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="descriptionLabel">描 述 </label>
|
||
<textarea name="description" id="description" rows="2" cols="2" style="width: 230px;"></textarea>
|
||
</div>
|
||
<div class="fitem" style="padding:5px">
|
||
<label id="enabledLabel">启 动 </label>
|
||
<input name="enabled" id="enabled" type="checkbox" style="width: 230px;height: 20px"/>
|
||
</div>
|
||
<input type="hidden" name="clientIp" id="clientIp" value="<%=clientIp %>"/>
|
||
</form>
|
||
</div>
|
||
<div id="dlg-buttons">
|
||
<a href="javascript:void(0)" id="saveSupplier" class="easyui-linkbutton" iconCls="icon-ok">保存</a>
|
||
<a href="javascript:void(0)" id="cancelSupplier" class="easyui-linkbutton" iconCls="icon-cancel" onclick="javascript:$('#supplierDlg').dialog('close')">取消</a>
|
||
</div>
|
||
|
||
<script type="text/javascript">
|
||
//初始化界面
|
||
$(function()
|
||
{
|
||
initTableData();
|
||
ininPager();
|
||
browserFit();
|
||
});
|
||
|
||
//浏览器适配
|
||
function browserFit()
|
||
{
|
||
if(getOs()=='MSIE')
|
||
{
|
||
$("#searchContactsLabel").empty().append("联 系 人:");
|
||
$("#searchDescLabel").empty().append("描 述:");
|
||
$("#supplierLabel").empty().append("名 称");
|
||
$("#contactsLabel").empty().append("联 系 人 ");
|
||
$("#phonenumLabel").empty().append("联系电话 ");
|
||
$("#emailLabel").empty().append("电子邮箱 ");
|
||
$("#descriptionLabel").empty().append("描 述 ");
|
||
}
|
||
else
|
||
{
|
||
$("#searchContactsLabel").empty().append("联 系 人:");
|
||
$("#searchDescLabel").empty().append("描 述:");
|
||
$("#supplierLabel").empty().append("名 称");
|
||
$("#contactsLabel").empty().append("联 系 人");
|
||
$("#phonenumLabel").empty().append("联系电话");
|
||
$("#emailLabel").empty().append("电子邮箱");
|
||
$("#descriptionLabel").empty().append("描 述");
|
||
}
|
||
}
|
||
|
||
//初始化表格数据
|
||
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,
|
||
//交替出现背景
|
||
striped : true,
|
||
url:'<%=path %>/supplier/findBy.action?pageSize=' + initPageSize,
|
||
pagination: true,
|
||
//自动截取数据
|
||
//nowrap : true,
|
||
//loadFilter: pagerFilter,
|
||
pageSize: initPageSize,
|
||
pageList: initPageNum,
|
||
columns:[[
|
||
{ field: 'id',width:35,align:"center",checkbox:true},
|
||
{ title: '名称',field: 'supplier',width:200},
|
||
{ title: '联系人', field: 'contacts',width:100,align:"center"},
|
||
{ title: '联系电话', field: 'phonenum',width:115,align:"center"},
|
||
{ title: '电子邮箱',field: 'email',width:180,align:"center"},
|
||
//{ title: '是否系统',field: 'isystem',width:70,align:"center"},
|
||
{ title: '描述',field: 'description',width:100},
|
||
{ title: '类型',field: 'type',width:100},
|
||
{ title: '启动',field: 'enabled',width:100},
|
||
{ title: '操作',field: 'op',align:"center",width:130,formatter:function(value,rec)
|
||
{
|
||
var str = '';
|
||
var rowInfo = rec.id + 'AaBb' + rec.supplier +'AaBb' + rec.contacts + 'AaBb'+ rec.phonenum + 'AaBb'+ rec.email + 'AaBb' + rec.isystem + 'AaBb' + rec.description+ 'AaBb' + rec.type+ 'AaBb' + rec.enabled;
|
||
if(1 == value)
|
||
{
|
||
str += '<img src="<%=path%>/js/easyui-1.3.5/themes/icons/pencil.png" style="cursor: pointer;" onclick="editSupplier(\'' + rowInfo + '\');"/> <a onclick="editSupplier(\'' + rowInfo + '\');" style="text-decoration:none;color:black;" href="javascript:void(0)">编辑</a> ';
|
||
str += '<img src="<%=path%>/js/easyui-1.3.5/themes/icons/edit_remove.png" style="cursor: pointer;" onclick="deleteSupplier(\'' + rowInfo + '\');"/> <a onclick="deleteSupplier(\'' + rowInfo + '\');" style="text-decoration:none;color:black;" href="javascript:void(0)">删除</a> ';
|
||
}
|
||
return str;
|
||
}
|
||
}
|
||
]],
|
||
toolbar:[
|
||
{
|
||
id:'addSupplier',
|
||
text:'增加',
|
||
iconCls:'icon-add',
|
||
handler:function()
|
||
{
|
||
addSuppler();
|
||
}
|
||
},
|
||
{
|
||
id:'deleteSupplier',
|
||
text:'删除',
|
||
iconCls:'icon-remove',
|
||
handler:function()
|
||
{
|
||
batDeleteSupplier();
|
||
}
|
||
}
|
||
],
|
||
onLoadError:function()
|
||
{
|
||
$.messager.alert('页面加载提示','页面加载异常,请稍后再试!','error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
|
||
//初始化键盘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键盘事件
|
||
if(k == "13"&&(obj.id=="supplier" || obj.id=="contacts"|| obj.id=="phonenum"
|
||
|| obj.id=="email" || obj.id=="description" ))
|
||
{
|
||
$("#saveSupplier").click();
|
||
}
|
||
|
||
//搜索按钮添加快捷键
|
||
if(k == "13"&&(obj.id=="searchSupplier" || obj.id=="searchContacts"|| obj.id=="searchPhonenum"
|
||
|| obj.id=="searchEmail" || obj.id=="searchDesc" ))
|
||
{
|
||
$("#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
|
||
});
|
||
showSupplierDetails(pageNum,pageSize);
|
||
}
|
||
});
|
||
}
|
||
catch (e)
|
||
{
|
||
$.messager.alert('异常处理提示',"分页信息异常 : " + e.name + ": " + e.message,'error');
|
||
}
|
||
}
|
||
|
||
//删除供应商信息
|
||
function deleteSupplier(supplierInfo)
|
||
{
|
||
$.messager.confirm('删除确认','确定要删除此供应商信息吗?',function(r)
|
||
{
|
||
if (r)
|
||
{
|
||
var supplierTotalInfo = supplierInfo.split("AaBb");
|
||
$.ajax({
|
||
type:"post",
|
||
url: "<%=path %>/supplier/delete.action",
|
||
dataType: "json",
|
||
data: ({
|
||
supplierID : supplierTotalInfo[0],
|
||
supplier:supplierTotalInfo[1],
|
||
clientIp:'<%=clientIp %>'
|
||
}),
|
||
success: function (tipInfo)
|
||
{
|
||
var msg = tipInfo.showModel.msgTip;
|
||
if(msg == '成功')
|
||
//加载完以后重新初始化
|
||
$("#searchBtn").click();
|
||
else
|
||
$.messager.alert('删除提示','删除供应商信息失败,请稍后再试!','error');
|
||
},
|
||
//此处添加错误处理
|
||
error:function()
|
||
{
|
||
$.messager.alert('删除提示','删除供应商信息异常,请稍后再试!','error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
});
|
||
}
|
||
|
||
//批量删除供应商
|
||
function batDeleteSupplier()
|
||
{
|
||
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: "<%=path %>/supplier/batchDelete.action",
|
||
dataType: "json",
|
||
async : false,
|
||
data: ({
|
||
supplierIDs : ids,
|
||
clientIp:'<%=clientIp %>'
|
||
}),
|
||
success: function (tipInfo)
|
||
{
|
||
var msg = tipInfo.showModel.msgTip;
|
||
if(msg == '成功')
|
||
{
|
||
//加载完以后重新初始化
|
||
$("#searchBtn").click();
|
||
$(":checkbox").attr("checked",false);
|
||
}
|
||
else
|
||
$.messager.alert('删除提示','删除供应商信息失败,请稍后再试!','error');
|
||
},
|
||
//此处添加错误处理
|
||
error:function()
|
||
{
|
||
$.messager.alert('删除提示','删除供应商信息异常,请稍后再试!','error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
});
|
||
}
|
||
}
|
||
|
||
//增加供应商
|
||
var url;
|
||
var supplierID = 0;
|
||
//保存编辑前的名称
|
||
var orgSupplier = "";
|
||
|
||
function addSuppler()
|
||
{
|
||
$('#supplierDlg').dialog('open').dialog('setTitle','<img src="<%=path%>/js/easyui-1.3.5/themes/icons/edit_add.png"/> 增加供应商');
|
||
$(".window-mask").css({ width: webW ,height: webH});
|
||
$('#supplierFM').form('clear');
|
||
|
||
var row = {
|
||
clientIp:'<%=clientIp %>'
|
||
};
|
||
$('#supplierFM').form('load',row);
|
||
|
||
$("#supplier").focus();
|
||
orgSupplier = "";
|
||
supplierID = 0;
|
||
url = '<%=path %>/supplier/create.action';
|
||
}
|
||
|
||
//保存供应商信息
|
||
$("#saveSupplier").unbind().bind({
|
||
click:function()
|
||
{
|
||
if(checkSupplierName())
|
||
return;
|
||
|
||
var reg = /^([0-9])+$/;
|
||
var phonenum = $.trim($("#phonenum").val());
|
||
if(phonenum.length>0 && !reg.test(phonenum))
|
||
{
|
||
$.messager.alert('提示','电话号码只能是数字','info');
|
||
$("#phonenum").val("").focus();
|
||
return;
|
||
}
|
||
|
||
$('#supplierFM').form('submit',{
|
||
url: url,
|
||
onSubmit: function()
|
||
{
|
||
return $(this).form('validate');
|
||
},
|
||
success: function(result)
|
||
{
|
||
var result = eval('('+result+')');
|
||
if (!result)
|
||
{
|
||
$.messager.show({
|
||
title: '错误提示',
|
||
msg: '保存供应商信息失败,请稍后重试!'
|
||
});
|
||
}
|
||
else
|
||
{
|
||
$('#supplierDlg').dialog('close');
|
||
//$('#tableData').datagrid('reload');
|
||
//加载完以后重新初始化
|
||
//$("#searchBtn").click();
|
||
var opts = $("#tableData").datagrid('options');
|
||
showSupplierDetails(opts.pageNumber,opts.pageSize);
|
||
}
|
||
}
|
||
});
|
||
}
|
||
});
|
||
|
||
//编辑供应商信息
|
||
function editSupplier(supplierTotalInfo)
|
||
{
|
||
var supplierInfo = supplierTotalInfo.split("AaBb");
|
||
var row = {
|
||
supplier : supplierInfo[1],
|
||
contacts : supplierInfo[2],
|
||
phonenum : supplierInfo[3],
|
||
email : supplierInfo[4],
|
||
description : supplierInfo[6],
|
||
type : supplierInfo[7],
|
||
enabled : supplierInfo[8],
|
||
clientIp:'<%=clientIp %>'
|
||
};
|
||
orgSupplier = supplierInfo[1];
|
||
$('#supplierDlg').dialog('open').dialog('setTitle','<img src="<%=path%>/js/easyui-1.3.5/themes/icons/pencil.png"/> 编辑供应商信息');
|
||
$(".window-mask").css({ width: webW ,height: webH});
|
||
$('#supplierFM').form('load',row);
|
||
supplierID = supplierInfo[0];
|
||
//焦点在名称输入框==定焦在输入文字后面
|
||
$("#supplier").val("").focus().val(supplierInfo[1]);
|
||
url = '<%=path %>/supplier/update.action?supplierID=' + supplierInfo[0];
|
||
}
|
||
|
||
//$("#supplier").unbind().bind({
|
||
//blur:checkSupplierName
|
||
//});
|
||
|
||
//检查供应商 名称是否存在 ++ 重名无法提示问题需要跟进
|
||
function checkSupplierName()
|
||
{
|
||
var supplierName = $.trim($("#supplier").val());
|
||
//表示是否存在 true == 存在 false = 不存在
|
||
var flag = false;
|
||
//开始ajax名称检验,不能重名
|
||
if(supplierName.length > 0 &&( orgSupplier.length ==0 || supplierName != orgSupplier))
|
||
{
|
||
$.ajax({
|
||
type:"post",
|
||
url: "<%=path %>/supplier/checkIsNameExist.action",
|
||
dataType: "json",
|
||
async : false,
|
||
data: ({
|
||
supplierID : supplierID,
|
||
supplier : supplierName
|
||
}),
|
||
success: function (tipInfo)
|
||
{
|
||
flag = tipInfo;
|
||
if(tipInfo)
|
||
{
|
||
$.messager.alert('提示','供应商名称已经存在','info');
|
||
//alert("供应商名称已经存在");
|
||
//$("#supplier").val("");
|
||
return;
|
||
}
|
||
},
|
||
//此处添加错误处理
|
||
error:function()
|
||
{
|
||
$.messager.alert('提示','检查供应商名称是否存在异常,请稍后再试!','error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
return flag;
|
||
}
|
||
|
||
//搜索处理
|
||
$("#searchBtn").unbind().bind({
|
||
click:function()
|
||
{
|
||
showSupplierDetails(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 showSupplierDetails(pageNo,pageSize)
|
||
{
|
||
$.ajax({
|
||
type:"post",
|
||
url: "<%=path %>/supplier/findBy.action",
|
||
dataType: "json",
|
||
data: ({
|
||
supplier:$.trim($("#searchSupplier").val()),
|
||
type:$.trim($("#searchType").val()),
|
||
phonenum:$.trim($("#searchPhonenum").val()),
|
||
email:$.trim($("#searchEmail").val()),
|
||
description:$.trim($("#searchDesc").val()),
|
||
pageNo:pageNo,
|
||
pageSize:pageSize
|
||
}),
|
||
success: function (data)
|
||
{
|
||
$("#tableData").datagrid('loadData',data);
|
||
//$('#tableData').datagrid('reload');
|
||
},
|
||
//此处添加错误处理
|
||
error:function()
|
||
{
|
||
$.messager.alert('查询提示','查询数据后台异常,请稍后再试!','error');
|
||
return;
|
||
}
|
||
});
|
||
}
|
||
|
||
//重置按钮
|
||
$("#searchResetBtn").unbind().bind({
|
||
click:function(){
|
||
$("#searchSupplier").val("");
|
||
$("#searchType").val("");
|
||
$("#searchPhonenum").val("");
|
||
$("#searchEmail").val("");
|
||
$("#searchDesc").val("");
|
||
|
||
//加载完以后重新初始化
|
||
$("#searchBtn").click();
|
||
}
|
||
});
|
||
</script>
|
||
</body>
|
||
</html> |