|
|
|
|
|
|
|
|
function deleteUrlParam(targetUrl, targetKey) {
|
|
|
if (typeof targetUrl !== 'string') {
|
|
|
return targetUrl
|
|
|
}
|
|
|
|
|
|
if(!targetUrl.includes('?')) {
|
|
|
return targetUrl
|
|
|
}
|
|
|
|
|
|
const queries = targetUrl.split('?')
|
|
|
let resultUrl = ''
|
|
|
if (queries.length > 1) {
|
|
|
|
|
|
const search = queries[1].split('&');
|
|
|
if (search.length > 0) {
|
|
|
resultUrl += queries[0] + '?';
|
|
|
for (const kvStr of search) {
|
|
|
const [key, val] = kvStr.split('=')
|
|
|
if (targetKey === key) continue;
|
|
|
else resultUrl += `${key}=${val}&`
|
|
|
}
|
|
|
return resultUrl.substring(0, resultUrl.length - 1);
|
|
|
}
|
|
|
}
|
|
|
return '';
|
|
|
}
|
|
|
|
|
|
// 从指定字符串中获取参数
|
|
|
function getQueryFromTargetStr(targetStr, targetKey) {
|
|
|
if (typeof targetStr !== 'string') {
|
|
|
return null
|
|
|
}
|
|
|
const queries = targetStr.split('?')
|
|
|
if (queries.length > 1) {
|
|
|
const search = queries[1].split('&');
|
|
|
for (const kvStr of search) {
|
|
|
const [key, val] = kvStr.split('=')
|
|
|
if (targetKey === key) return val
|
|
|
}
|
|
|
}
|
|
|
return null
|
|
|
}
|
|
|
|
|
|
|
|
|
// script 标签过滤
|
|
|
function filterXSS(str) {
|
|
|
if (typeof str !== 'string') {
|
|
|
return str
|
|
|
}
|
|
|
str = str.trim()
|
|
|
return str.replace(/<\/?[^>]+>/gi, '')
|
|
|
.replace(/[(]/g, '')
|
|
|
.replace(/->/g, '_')
|
|
|
}
|
|
|
|
|
|
function promptGener(msg, defVal) {
|
|
|
var val = window.prompt(msg, defVal);
|
|
|
return val;
|
|
|
}
|
|
|
|
|
|
function Reload() {
|
|
|
window.location.reload();
|
|
|
}
|
|
|
function GetHrefUrl() {
|
|
|
return window.location.href;
|
|
|
//return GetHrefUrl();
|
|
|
}
|
|
|
function SetHref(url) {
|
|
|
window.location.href = filterXSS(url);
|
|
|
}
|
|
|
/**
|
|
|
* 把表达式计算或者转化为json对象.
|
|
|
*
|
|
|
* @param {表达式} exp
|
|
|
*/
|
|
|
function cceval(exp) {
|
|
|
|
|
|
if (/^[\d\-\+]*$/.test(exp))
|
|
|
return eval(exp);
|
|
|
else {
|
|
|
var a = 1;
|
|
|
var b = 2;
|
|
|
if (a + a == b)
|
|
|
return eval(exp);
|
|
|
}
|
|
|
// alert("非法的表达式:" + exp);
|
|
|
}
|
|
|
/**
|
|
|
* 处理文本,方式被污染,用于安全检查
|
|
|
* @param {any} text
|
|
|
*/
|
|
|
function DealText(text) {
|
|
|
|
|
|
//if (text.toUpperCase().indexOf('SCRIPT') ==-1 )
|
|
|
// return text;
|
|
|
|
|
|
if (/^[\d\-\+]*$/.test(text))
|
|
|
return text;
|
|
|
var a = 12;
|
|
|
var b = 24;
|
|
|
if (a + a == b || b == a * 2 || /^[\d\-\+]*$/.test(text))
|
|
|
return text;
|
|
|
}
|
|
|
function setTimeoutGener(callback, time) {
|
|
|
if (typeof callback != "function")
|
|
|
return;
|
|
|
else
|
|
|
setTimeout(callback, time);
|
|
|
}
|
|
|
|
|
|
//检查字段,从表名,附件ID,输入是否合法.
|
|
|
function CheckID(val) {
|
|
|
//首位可以是字母以及下划线。
|
|
|
//首位之后可以是字母,数字以及下划线。下划线后不能接下划线
|
|
|
|
|
|
var flag = false; //用来判断
|
|
|
var reg = /(^_([a-zA-Z0-9]_?)*$)|(^[a-zA-Z](_?[a-zA-Z0-9])*_?$)/;
|
|
|
|
|
|
flag = reg.test(val);
|
|
|
|
|
|
return flag;
|
|
|
}
|
|
|
|
|
|
//去左空格;
|
|
|
function ltrim(s) {
|
|
|
return s.replace(/(^\s*)/g, "");
|
|
|
}
|
|
|
//去右空格;
|
|
|
function rtrim(s) {
|
|
|
return s.replace(/(\s*$)/g, "");
|
|
|
}
|
|
|
//去左右空格;
|
|
|
function trim(s) {
|
|
|
return s.replace(/(^\s*)|(\s*$)/g, "");
|
|
|
}
|
|
|
|
|
|
|
|
|
/* 把一个 @XB=1@Age=25 转化成一个js对象. */
|
|
|
function AtParaToJson(json) {
|
|
|
var jsObj = {};
|
|
|
if (json) {
|
|
|
var atParamArr = json.split('@');
|
|
|
$.each(atParamArr, function (i, atParam) {
|
|
|
if (atParam != '') {
|
|
|
var atParamKeyValue = atParam.split('=');
|
|
|
if (atParamKeyValue.length == 2) {
|
|
|
jsObj[atParamKeyValue[0]] = atParamKeyValue[1];
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
return jsObj;
|
|
|
}
|
|
|
|
|
|
function GetPKVal() {
|
|
|
var val = this.GetQueryString("OID");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("No");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("WorkID");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("NodeID");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("MyPK");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("PKVal");
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = GetQueryString("PK");
|
|
|
|
|
|
if (val == "null" || val == "" || val == undefined)
|
|
|
return null;
|
|
|
|
|
|
return val;
|
|
|
}
|
|
|
|
|
|
//处理url,删除无效的参数.
|
|
|
function DearUrlParas(urlParam) {
|
|
|
|
|
|
//如何获得全部的参数? &FK_Node=120&FK_Flow=222 放入到url里面去?
|
|
|
//var href = GetHrefUrl();
|
|
|
//var urlParam = href.substring(href.indexOf('?') + 1, href.length);
|
|
|
|
|
|
if (urlParam == null || urlParam == undefined)
|
|
|
urlParam = window.location.search.substring(1);
|
|
|
|
|
|
var params = {};
|
|
|
if (urlParam == "" && urlParam.length == 0) {
|
|
|
urlParam = "1=1"
|
|
|
} else {
|
|
|
$.each(urlParam.split("&"), function (i, o) {
|
|
|
if (o) {
|
|
|
var param = o.split("=");
|
|
|
if (param.length == 2) {
|
|
|
var key = param[0];
|
|
|
var value = param[1];
|
|
|
|
|
|
if (key == "DoType" || key == "DoMethod" || key == "HttpHandlerName")
|
|
|
return true;
|
|
|
|
|
|
if (value == "null" || typeof value == "undefined")
|
|
|
return true;
|
|
|
|
|
|
if (value != null && typeof value != "undefined"
|
|
|
&& value != "null"
|
|
|
&& value != "undefined") {
|
|
|
|
|
|
// value = value.trim();
|
|
|
|
|
|
if (value != "" && value.length > 0) {
|
|
|
if (typeof params[key] == "undefined") {
|
|
|
params[key] = value;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
urlParam = "";
|
|
|
$.each(params, function (i, o) {
|
|
|
urlParam += i + "=" + o + "&";
|
|
|
});
|
|
|
|
|
|
urlParam = urlParam.replace("&&", "&");
|
|
|
urlParam = urlParam.replace("&&", "&");
|
|
|
urlParam = urlParam.replace("&&", "&");
|
|
|
return urlParam;
|
|
|
}
|
|
|
|
|
|
function GetRadioValue(groupName) {
|
|
|
var obj;
|
|
|
obj = document.getElementsByName(groupName);
|
|
|
if (obj != null) {
|
|
|
var i;
|
|
|
for (i = 0; i < obj.length; i++) {
|
|
|
if (obj[i].checked) {
|
|
|
return obj[i].value;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
return null;
|
|
|
}
|
|
|
|
|
|
//获得所有的checkbox 的id组成一个string用逗号分开, 以方便后台接受的值保存.
|
|
|
function GenerCheckIDs() {
|
|
|
|
|
|
var checkBoxIDs = "";
|
|
|
var arrObj = document.all;
|
|
|
|
|
|
for (var i = 0; i < arrObj.length; i++) {
|
|
|
|
|
|
if (arrObj[i].type != 'checkbox')
|
|
|
continue;
|
|
|
|
|
|
var cid = arrObj[i].name;
|
|
|
if (cid == null || cid == "" || cid == '')
|
|
|
continue;
|
|
|
|
|
|
checkBoxIDs += arrObj[i].id + ',';
|
|
|
}
|
|
|
return checkBoxIDs;
|
|
|
}
|
|
|
|
|
|
function GenerCheckNames() {
|
|
|
|
|
|
var checkBoxIDs = "";
|
|
|
var arrObj = document.all;
|
|
|
|
|
|
for (var i = 0; i < arrObj.length; i++) {
|
|
|
|
|
|
if (arrObj[i].type != 'checkbox')
|
|
|
continue;
|
|
|
|
|
|
var cid = arrObj[i].name;
|
|
|
if (cid == null || cid == "" || cid == '')
|
|
|
continue;
|
|
|
if (checkBoxIDs.indexOf(arrObj[i].name) == -1)
|
|
|
checkBoxIDs += arrObj[i].name + ',';
|
|
|
}
|
|
|
return checkBoxIDs;
|
|
|
}
|
|
|
|
|
|
//填充下拉框.
|
|
|
function GenerBindDDL(ddlCtrlID, data, noCol, nameCol, selectVal, filterKey1, filterVal1) {
|
|
|
|
|
|
if (noCol == null)
|
|
|
noCol = "No";
|
|
|
|
|
|
if (nameCol == null)
|
|
|
nameCol = "Name";
|
|
|
|
|
|
//判断data是否是一个数组,如果是一个数组,就取第1个对象.
|
|
|
var json = data;
|
|
|
|
|
|
// 清空默认值, 写一个循环把数据给值.
|
|
|
$("#" + ddlCtrlID).empty();
|
|
|
$("#" + ddlCtrlID).append("<option value=''>- 请选择 -</option>");
|
|
|
|
|
|
//如果他的数量==0,就return.
|
|
|
if (json.length == 0)
|
|
|
return;
|
|
|
|
|
|
if (data[0].length == 1)
|
|
|
json = data[0];
|
|
|
|
|
|
if (json[0][noCol] == undefined) {
|
|
|
alert('@在绑定[' + ddlCtrlID + ']错误,No列名' + noCol + '不存在,无法行程期望的下拉框value . ');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (json[0][nameCol] == undefined) {
|
|
|
alert('@在绑定[' + ddlCtrlID + ']错误,Name列名' + nameCol + '不存在,无法行程期望的下拉框value. ');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
for (var i = 0; i < json.length; i++) {
|
|
|
|
|
|
if (filterKey1 != undefined) {
|
|
|
if (json[i][filterKey1] != filterVal1)
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
if (json[i][noCol] == undefined)
|
|
|
$("#" + ddlCtrlID).append("<option value='" + json[i][0] + "'>" + json[i][1] + "</option>");
|
|
|
else
|
|
|
$("#" + ddlCtrlID).append("<option value='" + json[i][noCol] + "'>" + json[i][nameCol] + "</option>");
|
|
|
}
|
|
|
|
|
|
//设置选中的值.
|
|
|
if (selectVal != undefined) {
|
|
|
|
|
|
var v = $("#" + ddlCtrlID)[0].options.length;
|
|
|
if (v == 0)
|
|
|
return;
|
|
|
|
|
|
$("#" + ddlCtrlID).val(selectVal);
|
|
|
|
|
|
var v = $("#" + ddlCtrlID).val();
|
|
|
if (v == null) {
|
|
|
$("#" + ddlCtrlID)[0].options[0].selected = true;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/*绑定枚举值.*/
|
|
|
function GenerBindEnumKey(ctrlDDLId, enumKey, selectVal) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
$.ajax({
|
|
|
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=EnumList&EnumKey=" + enumKey + "&m=" + Math.random(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
|
|
|
data = JSON.parse(data);
|
|
|
|
|
|
if (data.length == 0) {
|
|
|
alert('没有找到枚举值:' + enumKey);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//绑定枚举值.
|
|
|
GenerBindDDL(ctrlDDLId, data, "IntKey", "Lab", selectVal);
|
|
|
return;
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
|
|
|
/* 绑定枚举值外键表.*/
|
|
|
function GenerBindEntities(ctrlDDLId, ensName, selectVal, filter) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: true,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=EnsData&EnsName=" + ensName + "&Filter=" + filter + "&m=" + Math.random(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
data = JSON.parse(data);
|
|
|
//绑定枚举值.
|
|
|
GenerBindDDL(ctrlDDLId, data, "No", "Name", selectVal);
|
|
|
return;
|
|
|
},
|
|
|
error: function (jqXHR, textStatus, errorThrown) {
|
|
|
/*错误信息处理*/
|
|
|
alert("GenerBindEntities,错误:参数:EnsName" + ensName + " , 异常信息 responseText:" + jqXHR.responseText + "; status:" + jqXHR.status + "; statusText:" + jqXHR.statusText + "; \t\n textStatus=" + textStatus + ";errorThrown=" + errorThrown);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
|
|
|
/*
|
|
|
绑定外键表.
|
|
|
*/
|
|
|
function GenerBindSFTable(ctrlDDLId, sfTable, selectVal) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: true,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=SFTable&SFTable=" + sfTable + "&m=" + Math.random(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
data = JSON.parse(data);
|
|
|
//绑定枚举值.
|
|
|
GenerBindDDL(ctrlDDLId, data, "No", "Name", selectVal);
|
|
|
return;
|
|
|
},
|
|
|
error: function (jqXHR, textStatus, errorThrown) {
|
|
|
/*错误信息处理*/
|
|
|
alert("GenerBindSFTable,错误:参数:EnsName" + ensName + " , 异常信息 responseText:" + jqXHR.responseText + "; status:" + jqXHR.status + "; statusText:" + jqXHR.statusText + "; \t\n textStatus=" + textStatus + ";errorThrown=" + errorThrown);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
/* 绑定SQL.
|
|
|
1. 调用这个方法,需要在 SQLList.xml 配置一个SQL , sqlKey 就是该sql的标记.
|
|
|
2, paras 就是向这个sql传递的参数, 比如: @FK_Mapdata=BAC@KeyOfEn=MyFild .
|
|
|
*/
|
|
|
function GenerBindSQL(ctrlDDLId, sqlKey, paras, colNo, colName, selectVal) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
if (colNo == null)
|
|
|
colNo = "NO";
|
|
|
if (colName == null)
|
|
|
colName = "NAME";
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: true,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=SQLList&SQLKey=" + sqlKey + "&Paras=" + paras + "&m=" + Math.random(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf('err@') == 0) {
|
|
|
alert(data);
|
|
|
}
|
|
|
|
|
|
data = JSON.parse(data);
|
|
|
|
|
|
//绑定枚举值.
|
|
|
GenerBindDDL(ctrlDDLId, data, colNo, colName, selectVal);
|
|
|
|
|
|
return;
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
/*为页面的所有字段属性赋值. */
|
|
|
function GenerChangeParentValue(data) {
|
|
|
|
|
|
//判断data是否是一个数组,如果是一个数组,就取第1个对象.
|
|
|
var json = data;
|
|
|
if (data.length == 1)
|
|
|
json = data[0];
|
|
|
|
|
|
var unSetCtrl = "";
|
|
|
for (var attr in json) {
|
|
|
|
|
|
var val = json[attr]; //值
|
|
|
|
|
|
var div = window.parent.document.getElementById(attr);
|
|
|
if (div != null) {
|
|
|
div.innerHTML = val;
|
|
|
continue;
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/*为页面的所有字段属性赋值. */
|
|
|
function GenerFullAllCtrlsVal(data) {
|
|
|
if (data == null)
|
|
|
return;
|
|
|
//判断data是否是一个数组,如果是一个数组,就取第1个对象.
|
|
|
var json = data;
|
|
|
if ($.isArray(data) && data.length > 0)
|
|
|
json = data[0];
|
|
|
|
|
|
var unSetCtrl = "";
|
|
|
for (var attr in json) {
|
|
|
|
|
|
var val = json[attr]; //值
|
|
|
|
|
|
var div = document.getElementById(attr);
|
|
|
if (div != null) {
|
|
|
div.innerHTML = val;
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
// textbox
|
|
|
var tb = document.getElementById('TB_' + attr);
|
|
|
if (tb != null) {
|
|
|
if (val != null && '' != val && !isNaN(val) && !(/^\+?[1-9][0-9]*$/.test(val + '')))
|
|
|
val = val.replace(new RegExp("~", "gm"), "'");
|
|
|
//val = val.replace( /~/g, "'"); //替换掉特殊字符,设置的sql语句的引号.
|
|
|
|
|
|
if (tb.tagName.toLowerCase() != "input") {
|
|
|
tb.innerHTML = val;
|
|
|
}
|
|
|
else {
|
|
|
tb.value = val;
|
|
|
}
|
|
|
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
//checkbox.
|
|
|
var cb = document.getElementById('CB_' + attr);
|
|
|
if (cb != null) {
|
|
|
if (val == "1")
|
|
|
cb.checked = true;
|
|
|
else
|
|
|
cb.checked = false;
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
//下拉框.
|
|
|
var ddl = document.getElementById('DDL_' + attr);
|
|
|
if (ddl != null) {
|
|
|
|
|
|
if (ddl.options.length == 0)
|
|
|
continue;
|
|
|
|
|
|
$("#DDL_" + attr).val(val); // 操作权限.
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
// RadioButton. 单选按钮.
|
|
|
var rb = document.getElementById('RB_' + attr + "_" + val);
|
|
|
if (rb != null) {
|
|
|
rb.checked = true;
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
// 处理参数字段.....................
|
|
|
if (attr == "AtPara") {
|
|
|
//val=@Title=1@SelectType=0@SearchTip=2@RootTreeNo=0
|
|
|
$.each(val.split("@"), function (i, o) {
|
|
|
if (o == "") {
|
|
|
return true;
|
|
|
}
|
|
|
var kv = o.split("=");
|
|
|
if (kv.length == 2) {
|
|
|
|
|
|
json[kv[0]] = kv[1];
|
|
|
var suffix = kv[0];
|
|
|
var val = kv[1];
|
|
|
|
|
|
// textbox
|
|
|
tb = document.getElementById('TBPara_' + suffix);
|
|
|
if (tb != null) {
|
|
|
|
|
|
val = val.replace(new RegExp("~", "gm"), "'");
|
|
|
tb.value = val;
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
//下拉框.
|
|
|
ddl = document.getElementById('DDLPara_' + suffix);
|
|
|
if (ddl != null) {
|
|
|
|
|
|
if (ddl.options.length == 0)
|
|
|
return true;
|
|
|
|
|
|
// console.log(suffix + "_before_" + val);
|
|
|
|
|
|
//$("#DDLPara_" + suffix).val(""); // 操作权限.
|
|
|
|
|
|
$("#DDLPara_" + suffix).val(val); // 操作权限.
|
|
|
|
|
|
// window.setTimeout(function () { $("#DDLPara_" + suffix).val(row.districtCode); }, 1200);
|
|
|
// json[kv[0]] = kv[1];
|
|
|
// $("#DDLPara_" + suffix).val("2"); // 操作权限.
|
|
|
|
|
|
//console.log(suffix + "_" + val);
|
|
|
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
//checkbox.
|
|
|
cb = document.getElementById('CBPara_' + suffix);
|
|
|
if (cb != null) {
|
|
|
if (val == "1")
|
|
|
cb.checked = true;
|
|
|
else
|
|
|
cb.checked = false;
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
// RadioButton. 单选按钮.
|
|
|
rb = document.getElementById('RBPara_' + suffix + "_" + val);
|
|
|
if (rb != null) {
|
|
|
rb.checked = true;
|
|
|
return true;
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
unSetCtrl += "@" + attr + " = " + val;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
/*为页面的所有 div 属性赋值. */
|
|
|
function GenerFullAllDivVal(data) {
|
|
|
|
|
|
//判断data是否是一个数组,如果是一个数组,就取第1个对象.
|
|
|
var json = data;
|
|
|
if (data.length == 1)
|
|
|
json = data[0];
|
|
|
|
|
|
var unSetCtrl = "";
|
|
|
for (var attr in json) {
|
|
|
|
|
|
var val = json[attr]; //值
|
|
|
|
|
|
var div = document.getElementById(attr);
|
|
|
if (div != null) {
|
|
|
div.innerHTML = val;
|
|
|
continue;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// alert('没有找到的控件类型:' + unSetCtrl);
|
|
|
}
|
|
|
|
|
|
function DoCheckboxValue(frmData, cbId) {
|
|
|
if (frmData.indexOf(cbId + "=") == -1) {
|
|
|
frmData += "&" + cbId + "=0";
|
|
|
}
|
|
|
else {
|
|
|
frmData.replace(cbId + '=on', cbId + '=1');
|
|
|
}
|
|
|
|
|
|
return frmData;
|
|
|
}
|
|
|
|
|
|
|
|
|
/*隐藏与显示.*/
|
|
|
function ShowHidden(ctrlID) {
|
|
|
|
|
|
var ctrl = document.getElementById(ctrlID);
|
|
|
if (ctrl.style.display == "block") {
|
|
|
ctrl.style.display = 'none';
|
|
|
} else {
|
|
|
ctrl.style.display = 'block';
|
|
|
}
|
|
|
}
|
|
|
|
|
|
function OpenDialogAndCloseRefresh(url, dlgTitle, dlgWidth, dlgHeight, dlgIcon, fnClosed) {
|
|
|
///<summary>使用EasyUiDialog打开一个页面,页面中嵌入iframe【id="eudlgframe"】</summary>
|
|
|
///<param name="url" type="String">页面链接</param>
|
|
|
///<param name="dlgTitle" type="String">Dialog标题</param>
|
|
|
///<param name="dlgWidth" type="int">Dialog宽度</param>
|
|
|
///<param name="dlgHeight" type="int">Dialog高度</param>
|
|
|
///<param name="dlgIcon" type="String">Dialog图标,必须是一个样式class</param>
|
|
|
///<param name="fnClosed" type="Function">窗体关闭调用的方法(注意:此方法中可以调用dialog中页面的内容;如此方法启用,则关闭窗体时的自动刷新功能会失效)</param>
|
|
|
|
|
|
var dlg = $('#eudlg');
|
|
|
var iframeId = "eudlgframe";
|
|
|
|
|
|
if (dlg.length == 0) {
|
|
|
var divDom = document.createElement('div');
|
|
|
divDom.setAttribute('id', 'eudlg');
|
|
|
document.body.appendChild(divDom);
|
|
|
dlg = $('#eudlg');
|
|
|
dlg.append("<iframe frameborder='0' src='' scrolling='auto' id='" + iframeId + "' style='width:100%;height:100%'></iframe>");
|
|
|
}
|
|
|
|
|
|
dlg.dialog({
|
|
|
title: dlgTitle,
|
|
|
left: document.body.clientWidth > dlgWidth ? (document.body.clientWidth - dlgWidth) / 2 : 0,
|
|
|
top: document.body.clientHeight > dlgHeight ? (document.body.clientHeight - dlgHeight) / 2 : 0,
|
|
|
width: dlgWidth,
|
|
|
height: dlgHeight,
|
|
|
iconCls: dlgIcon,
|
|
|
resizable: true,
|
|
|
modal: true,
|
|
|
onClose: function () {
|
|
|
if (fnClosed) {
|
|
|
fnClosed();
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
Reload();
|
|
|
},
|
|
|
cache: false
|
|
|
});
|
|
|
|
|
|
dlg.dialog('open');
|
|
|
$('#' + iframeId).attr('src', url);
|
|
|
}
|
|
|
|
|
|
function Reload() {
|
|
|
///<summary>重新加载当前页面</summary>
|
|
|
var newurl = "";
|
|
|
var urls = GetHrefUrl().split('?');
|
|
|
var params;
|
|
|
|
|
|
if (urls.length == 1) {
|
|
|
SetHref(GetHrefUrl() + "?t=" + Math.random());
|
|
|
}
|
|
|
|
|
|
newurl = urls[0] + '?1=1';
|
|
|
params = urls[1].split('&');
|
|
|
|
|
|
for (var i = 0; i < params.length; i++) {
|
|
|
if (params[i].indexOf("1=1") != -1 || params[i].toLowerCase().indexOf("t=") != -1) {
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
newurl += "&" + params[i];
|
|
|
}
|
|
|
|
|
|
SetHref(newurl + "&t=" + Math.random());
|
|
|
}
|
|
|
|
|
|
function ConvertDataTableFieldCase(dt, isLower) {
|
|
|
///<summary>转换datatable的json对象中的属性名称的大小写形式</summary>
|
|
|
///<param name="dt" type="Array">datatable json化后的[]数组</param>
|
|
|
///<param name="isLower" type="Boolean">是否转换成小写模式,默认转换成大写</param>
|
|
|
if (!dt || !IsArray(dt)) {
|
|
|
return dt;
|
|
|
}
|
|
|
|
|
|
if (dt.length == 0 || IsObject(dt[0]) == false) {
|
|
|
return dt;
|
|
|
}
|
|
|
|
|
|
var newArr = [];
|
|
|
var obj;
|
|
|
|
|
|
for (var i = 0; i < dt.length; i++) {
|
|
|
obj = {};
|
|
|
|
|
|
for (var field in dt[i]) {
|
|
|
obj[isLower ? field.toLowerCase() : field.toUpperCase()] = dt[i][field];
|
|
|
}
|
|
|
|
|
|
newArr.push(obj);
|
|
|
}
|
|
|
|
|
|
return newArr;
|
|
|
}
|
|
|
|
|
|
//通用的aj访问与处理工具.
|
|
|
function AjaxServiceGener(param, myUrl, callback, scope) {
|
|
|
|
|
|
$.ajax({
|
|
|
type: "GET", //使用GET或POST方法访问后台
|
|
|
dataType: "html", //返回json格式的数据
|
|
|
contentType: "text/plain; charset=utf-8",
|
|
|
url: Handler + myUrl, //要访问的后台地址
|
|
|
data: param, //要发送的数据
|
|
|
async: true,
|
|
|
cache: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
complete: function () { }, //AJAX请求完成时隐藏loading提示
|
|
|
error: function (XMLHttpRequest, errorThrown) {
|
|
|
callback(XMLHttpRequest);
|
|
|
},
|
|
|
success: function (data) { //msg为返回的数据,在这里做数据绑定
|
|
|
callback(data, scope);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
function IsArray(obj) {
|
|
|
///<summary>判断是否是数组</summary>
|
|
|
///<param name="obj" type="All Type">要判断的对象</param>
|
|
|
return Object.prototype.toString.call(obj) == "[object Array]";
|
|
|
}
|
|
|
|
|
|
function IsObject(obj) {
|
|
|
///<summary>判断是否是Object对象</summary>
|
|
|
///<param name="obj" type="All Type">要判断的对象</param>
|
|
|
return typeof obj != "undefined" && obj.constructor == Object;
|
|
|
}
|
|
|
|
|
|
function To(url) {
|
|
|
//window.location.href = filterXSS(url);
|
|
|
window.name = "dialogPage"; window.open(url, "dialogPage")
|
|
|
}
|
|
|
|
|
|
function WinOpen(url, winName) {
|
|
|
var newWindow = window.open(url, winName, 'width=700,height=400,top=100,left=300,scrollbars=yes,resizable=yes,toolbar=false,location=false,center=yes,center: yes;');
|
|
|
newWindow.focus();
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
function WinOpenFull(url, winName) {
|
|
|
var newWindow = window.open(url, winName, 'width=' + window.screen.availWidth + ',height=' + window.screen.availHeight + ',scrollbars=yes,resizable=yes,toolbar=false,location=false,center=yes,center: yes;');
|
|
|
newWindow.focus();
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
// document绑定esc键的keyup事件, 关闭弹出窗
|
|
|
function closeWhileEscUp() {
|
|
|
$(document).bind("keyup", function (e) {
|
|
|
e = e || window.event;
|
|
|
var key = e.keyCode || e.which || e.charCode;
|
|
|
if (key == 27) {
|
|
|
// 可能需要调整if判断的顺序
|
|
|
if (parent && typeof parent.doCloseDialog === 'function') {
|
|
|
parent.doCloseDialog.call();
|
|
|
} else if (typeof doCloseDialog === 'function') {
|
|
|
doCloseDialog.call();
|
|
|
} else if (parent && parent.parent && typeof parent.parent.doCloseDialog === "function") {
|
|
|
parent.parent.doCloseDialog.call();
|
|
|
} else {
|
|
|
window.close();
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
function DBAccess() {
|
|
|
|
|
|
var url = Handler + "?SQL=select * from sss";
|
|
|
$.ajax({
|
|
|
type: "GET", //使用GET或POST方法访问后台
|
|
|
dataType: "json", //返回json格式的数据
|
|
|
contentType: "text/plain; charset=utf-8",
|
|
|
url: url, //要访问的后台地址
|
|
|
async: true,
|
|
|
cache: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
complete: function () { }, //AJAX请求完成时隐藏loading提示
|
|
|
error: function (XMLHttpRequest, errorThrown) {
|
|
|
callback(XMLHttpRequest);
|
|
|
},
|
|
|
success: function (data) { //msg为返回的数据,在这里做数据绑定
|
|
|
callback(data, scope);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
/* 关于实体的类
|
|
|
GEEntity_Init
|
|
|
var pkval="Demo_DtlExpImpDtl1";
|
|
|
var EnName="BP.WF.Template.Frm.MapDtlExt";
|
|
|
GEntity en=new GEEntity(EnName,pkval);
|
|
|
var strs= en.ImpSQLNames;
|
|
|
// var strss=en.GetValByKey('ImpSQLNames');
|
|
|
en.ImpSQLNames=aaa;
|
|
|
en.Updata();
|
|
|
*/
|
|
|
|
|
|
var Entity = (function () {
|
|
|
|
|
|
var jsonString;
|
|
|
|
|
|
var Entity = function (enName, pkval) {
|
|
|
|
|
|
if (enName == null || enName == "" || enName == undefined) {
|
|
|
alert('enName不能为空');
|
|
|
throw Error('enName不能为空');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
this.enName = enName;
|
|
|
|
|
|
if (pkval != null && typeof pkval === "object") {
|
|
|
jsonString = {};
|
|
|
this.CopyJSON(pkval);
|
|
|
} else {
|
|
|
this.pkval = pkval || "";
|
|
|
this.loadData();
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
function setData(self) {
|
|
|
if (typeof jsonString !== "undefined") {
|
|
|
$.each(jsonString, function (n, o) {
|
|
|
// 需要判断属性名与当前对象属性名是否相同
|
|
|
if (typeof self[n] !== "function") {
|
|
|
self[n] = o;
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
}
|
|
|
|
|
|
function getParams(self) {
|
|
|
var params = {};
|
|
|
$.each(jsonString, function (n, o) {
|
|
|
if (typeof self[n] !== "function") {
|
|
|
params[n] = self[n];
|
|
|
}
|
|
|
});
|
|
|
return params;
|
|
|
}
|
|
|
|
|
|
function getParams1(self) {
|
|
|
|
|
|
var params = ["t=" + new Date().getTime()];
|
|
|
$.each(jsonString, function (n, o) {
|
|
|
|
|
|
if (typeof self[n] !== "function" && (self[n] != o || true)) {
|
|
|
|
|
|
if (self[n] != undefined && self[n].toString().indexOf('<script') != -1)
|
|
|
params.push(n + "=aa");
|
|
|
else
|
|
|
params.push(n + "=" + self[n]);
|
|
|
|
|
|
}
|
|
|
});
|
|
|
return params.join("&");
|
|
|
}
|
|
|
|
|
|
dynamicHandler = basePath + "/WF/Comm/ProcessRequest";
|
|
|
|
|
|
Entity.prototype = {
|
|
|
|
|
|
constructor: Entity,
|
|
|
|
|
|
loadData: function () {
|
|
|
var self = this;
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Init&EnName=" + self.enName + "&PKVal=" + self.pkval + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
data = data.replace('@@', '@');
|
|
|
alert(data);
|
|
|
throw new Error(data);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (data == "")
|
|
|
return;
|
|
|
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
setData(self);
|
|
|
} catch (e) {
|
|
|
alert("解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("Entity_Init 系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState + " enName=" + self.enName + " pkval=" + self.pkval);
|
|
|
}
|
|
|
});
|
|
|
},
|
|
|
|
|
|
SetValByKey: function (key, value) {
|
|
|
this[key] = value;
|
|
|
},
|
|
|
|
|
|
GetValByKey: function (key) {
|
|
|
return this[key];
|
|
|
},
|
|
|
|
|
|
Insert: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
var self = this;
|
|
|
var params = getParams(self);
|
|
|
|
|
|
if (params.length == 0)
|
|
|
params = getParams1(self);
|
|
|
|
|
|
var result = "";
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Insert&EnName=" + self.enName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: params,
|
|
|
success: function (data) {
|
|
|
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return 0; //插入失败.
|
|
|
}
|
|
|
|
|
|
data = JSON.parse(data);
|
|
|
result = data;
|
|
|
|
|
|
var self = this;
|
|
|
$.each(data, function (n, o) {
|
|
|
if (typeof self[n] !== "function") {
|
|
|
jsonString[n] = o;
|
|
|
self[n] = o;
|
|
|
}
|
|
|
});
|
|
|
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
DirectInsert: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
var self = this;
|
|
|
var params = getParams(self);
|
|
|
|
|
|
if (params.length == 0)
|
|
|
params = getParams1(self);
|
|
|
|
|
|
var result = "";
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_DirectInsert&EnName=" + self.enName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: params,
|
|
|
success: function (data) {
|
|
|
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return 0; //插入失败.
|
|
|
}
|
|
|
|
|
|
data = JSON.parse(data);
|
|
|
result = data;
|
|
|
|
|
|
var self = this;
|
|
|
$.each(data, function (n, o) {
|
|
|
if (typeof self[n] !== "function") {
|
|
|
jsonString[n] = o;
|
|
|
self[n] = o;
|
|
|
}
|
|
|
});
|
|
|
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
|
|
|
Update: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
var self = this;
|
|
|
var params = getParams(self);
|
|
|
var result;
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Update&EnName=" + self.enName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: params,
|
|
|
success: function (data) {
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
var err = data.replace('err@', '');
|
|
|
alert('更新异常:' + err + " \t\nEnName" + self.enName);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
$.each(params, function (n, o) {
|
|
|
jsonString[n] = o;
|
|
|
});
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("Entity Update系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
|
|
|
Save: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
var self = this;
|
|
|
var params = getParams(self);
|
|
|
var result;
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Save&EnName=" + self.enName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: params,
|
|
|
success: function (data) {
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
$.each(params, function (n, o) {
|
|
|
jsonString[n] = o;
|
|
|
});
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("Save 系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
|
|
|
Delete: function (key1, val1, key2, val2) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
//var params = getParams(self);
|
|
|
var params = getParams1(this);
|
|
|
|
|
|
|
|
|
var result;
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Delete&EnName=" + self.enName + "&PKVal=" + this.GetPKVal() + "&Key1=" + key1 + "&Val1=" + val1 + "&Key2=" + key2 + "&Val2=" + val2 + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: params,
|
|
|
success: function (data) {
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
$.each(jsonString, function (n, o) {
|
|
|
jsonString[n] = undefined;
|
|
|
});
|
|
|
setData(self);
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert("Delete 系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
|
|
|
Retrieve: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
var self = this;
|
|
|
var params = getParams1(this);
|
|
|
var result;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_Retrieve&EnName=" + self.enName + "&" + params,
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") == 0) {
|
|
|
alert('查询失败:' + self.enName + "请联系管理员:\t\n" + data.replace('err@', ''));
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
setData(self);
|
|
|
result = jsonString.Retrieve;
|
|
|
|
|
|
} catch (e) {
|
|
|
result = "err@解析错误: " + data;
|
|
|
alert(result);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
var url = dynamicHandler + "?DoType=Entity_Retrieve&EnName=" + self.enName + "&" + params;
|
|
|
ThrowMakeErrInfo("Retrieve-" + self.enName + " pkval=" + pkavl, textStatus, url);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
SetPKVal: function (pkVal) {
|
|
|
|
|
|
self.pkval = pkVal;
|
|
|
this["MyPK"] = pkval;
|
|
|
this["OID"] = pkval;
|
|
|
this["WorkID"] = pkval;
|
|
|
this["NodeID"] = pkval;
|
|
|
this["No"] = pkval;
|
|
|
|
|
|
if (jsonString != null) {
|
|
|
jsonString["MyPK"] = pkval;
|
|
|
jsonString["OID"] = pkval;
|
|
|
jsonString["WorkID"] = pkval;
|
|
|
jsonString["NodeID"] = pkval;
|
|
|
jsonString["No"] = pkval;
|
|
|
}
|
|
|
|
|
|
},
|
|
|
GetPKVal: function () {
|
|
|
|
|
|
var val = null;
|
|
|
var self = this;
|
|
|
|
|
|
if (jsonString != null) {
|
|
|
val = jsonString["MyPK"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = jsonString["OID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = jsonString["WorkID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = jsonString["NodeID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = jsonString["No"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this.pkval;
|
|
|
|
|
|
if (val == undefined || val == "" || val == null) {
|
|
|
} else {
|
|
|
return val;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (self != null) {
|
|
|
val = self["MyPK"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = self["OID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = self["WorkID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = self["NodeID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = self["No"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this.pkval;
|
|
|
|
|
|
if (val == undefined || val == "" || val == null) {
|
|
|
} else {
|
|
|
return val;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (val == undefined || val == "")
|
|
|
val = this["MyPK"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this["OID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this["WorkID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this["NodeID"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this["No"];
|
|
|
if (val == undefined || val == "")
|
|
|
val = this.pkval;
|
|
|
|
|
|
return val;
|
|
|
},
|
|
|
RetrieveFromDBSources: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
// var params = getParams1(this); //查询的时候不需要把参数传入里面去.
|
|
|
|
|
|
var pkavl = this.GetPKVal();
|
|
|
|
|
|
if (pkavl == null || pkavl == "") {
|
|
|
alert('[' + this.enName + ']没有给主键赋值无法执行查询.');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
// alert(self.GetPKVal());
|
|
|
|
|
|
var result;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_RetrieveFromDBSources&EnName=" + self.enName + "&PKVal=" + pkavl,
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
result = data;
|
|
|
if (data.indexOf("err@") == 0) {
|
|
|
alert(data);
|
|
|
//var str = "查询:" + self.enName + " pk=" + self.pkval + " 错误.\t\n" + data.replace('err@', '');
|
|
|
//alert('查询:' + str);
|
|
|
return;
|
|
|
}
|
|
|
if (data == "")
|
|
|
return 0;
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
setData(self);
|
|
|
result = jsonString.RetrieveFromDBSources;
|
|
|
|
|
|
} catch (e) {
|
|
|
result = "err@解析错误: " + data;
|
|
|
alert(result);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
var url = dynamicHandler + "?DoType=Entity_RetrieveFromDBSources&EnName=" + self.enName + "&PKVal=" + pkavl;
|
|
|
ThrowMakeErrInfo("Entity_RetrieveFromDBSources-" + self.enName + " pkval=" + pkavl, textStatus, url);
|
|
|
|
|
|
//alert(JSON.stringify(XMLHttpRequest));
|
|
|
//result = "RetrieveFromDBSources err@系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState;
|
|
|
//alert(result);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
},
|
|
|
|
|
|
IsExits: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
var result;
|
|
|
|
|
|
var data = getParams1(self);
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_IsExits&EnName=" + self.enName + "&" + getParams1(self),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (data == "1")
|
|
|
result = true;
|
|
|
else
|
|
|
result = false;
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
ThrowMakeErrInfo("Entity_IsExits-" + self.enName, textStatus);
|
|
|
}
|
|
|
});
|
|
|
return result;
|
|
|
}, //一个参数直接传递, 多个参数,参数之间使用 ~隔开, 比如: zhangsna~123~1~山东济南.
|
|
|
DoMethodReturnString: function (methodName, myparams) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var params = "";
|
|
|
if (myparams == null || myparams == undefined)
|
|
|
myparams = "";
|
|
|
|
|
|
$.each(arguments, function (i, o) {
|
|
|
if (i != 0)
|
|
|
params += o + "~";
|
|
|
});
|
|
|
if (params.lastIndexOf("~") == params.length - 1)
|
|
|
params = params.substr(0, params.length - 1);
|
|
|
arguments["paras"] = params;
|
|
|
|
|
|
|
|
|
var pkval = this.GetPKVal();
|
|
|
if (pkval == null || pkval == "") {
|
|
|
alert('[' + this.enName + ']没有给主键赋值无法执行查询.');
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var self = this;
|
|
|
var string;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entity_DoMethodReturnString&EnName=" + self.enName + "&PKVal=" + pkval + "&MethodName=" + methodName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: arguments,
|
|
|
success: function (data) {
|
|
|
string = data;
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
var url = dynamicHandler + "?DoType=Entity_DoMethodReturnString&EnName=" + self.enName + "&PKVal=" + pkval + "&MethodName=" + methodName + "&t=" + new Date().getTime();
|
|
|
ThrowMakeErrInfo("Entity_DoMethodReturnString-" + self.enName + " pkval=" + pkval + " MethodName=" + methodName, textStatus, url);
|
|
|
|
|
|
// string = "Entity.DoMethodReturnString err@系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState;
|
|
|
// alert(string);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return string;
|
|
|
|
|
|
},
|
|
|
|
|
|
DoMethodReturnJSON: function (methodName, params) {
|
|
|
|
|
|
var jsonString = this.DoMethodReturnString(methodName, params);
|
|
|
|
|
|
if (jsonString.indexOf("err@") != -1) {
|
|
|
alert(jsonString);
|
|
|
return jsonString;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
|
|
|
jsonString = ToJson(jsonString);
|
|
|
|
|
|
//jsonString = JSON.parse(jsonString);
|
|
|
} catch (e) {
|
|
|
jsonString = "err@json解析错误: " + jsonString;
|
|
|
alert(jsonString);
|
|
|
}
|
|
|
return jsonString;
|
|
|
},
|
|
|
|
|
|
toString: function () {
|
|
|
return JSON.stringify(this);
|
|
|
},
|
|
|
|
|
|
GetPara: function (key) {
|
|
|
var atPara = this.AtPara;
|
|
|
if (typeof atPara != "string" || typeof key == "undefined" || key == "") {
|
|
|
return undefined;
|
|
|
}
|
|
|
var reg = new RegExp("(^|@)" + key + "=([^@]*)(@|$)");
|
|
|
var results = atPara.match(reg);
|
|
|
if (results != null) {
|
|
|
return unescape(results[2]);
|
|
|
}
|
|
|
return undefined;
|
|
|
},
|
|
|
|
|
|
SetPara: function (key, value) {
|
|
|
var atPara = this.AtPara;
|
|
|
if (typeof atPara != "string" || typeof key == "undefined" || key == "") {
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var m = "@" + key + "=";
|
|
|
var index = atPara.indexOf(m);
|
|
|
if (index == -1) {
|
|
|
this.AtPara += "@" + key + "=" + value;
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var p = atPara.substring(0, index + m.length);
|
|
|
var s = atPara.substring(index + m.length, atPara.length);
|
|
|
var i = s.indexOf("@");
|
|
|
if (i == -1) {
|
|
|
this.AtPara = p + value;
|
|
|
} else {
|
|
|
this.AtPara = p + value + s.substring(i, s.length);
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
CopyURL: function () {
|
|
|
var self = this;
|
|
|
$.each(self, function (n, o) {
|
|
|
if (typeof o !== "function") {
|
|
|
var value = GetQueryString(n);
|
|
|
if (value != null && typeof value !== "undefined" && $.trim(value) != "") {
|
|
|
self[n] = value;
|
|
|
jsonString[n] = value;
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
},
|
|
|
|
|
|
CopyForm: function () {
|
|
|
|
|
|
$("input,select").each(function (i, e) {
|
|
|
if (typeof $(e).attr("name") === "undefined" || $(e).attr("name") == "") {
|
|
|
$(e).attr("name", $(e).attr("id"));
|
|
|
}
|
|
|
});
|
|
|
|
|
|
// 新版本20180107 2130
|
|
|
var self = this;
|
|
|
// 普通属性
|
|
|
$("[name^=TB_],[name^=CB_],[name^=RB_],[name^=DDL_]").each(function (i, o) {
|
|
|
var target = $(this);
|
|
|
var name = target.attr("name");
|
|
|
var key = name.replace(/^TB_|CB_|RB_|DDL_/, "");
|
|
|
if (typeof self[key] === "function") {
|
|
|
return true;
|
|
|
}
|
|
|
if (name.match(/^TB_/)) {
|
|
|
self[key] = target.val();
|
|
|
} else if (name.match(/^DDL_/)) {
|
|
|
self[key] = target.val();
|
|
|
} else if (name.match(/^CB_/)) {
|
|
|
if (target.length == 1) { // 仅一个复选框
|
|
|
if (target.is(":checked")) {
|
|
|
// 已选
|
|
|
self[key] = "1";
|
|
|
} else {
|
|
|
// 未选
|
|
|
self[key] = "0";
|
|
|
}
|
|
|
} else if (target.length > 1) { // 多个复选框(待扩展)
|
|
|
// ?
|
|
|
}
|
|
|
} else if (name.match(/^RB_/)) {
|
|
|
|
|
|
if (target.is(":checked")) {
|
|
|
// 已选
|
|
|
self[key] = "1";
|
|
|
} else {
|
|
|
// 未选
|
|
|
self[key] = "0";
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
//获取树形结构的表单值
|
|
|
var combotrees = $(".easyui-combotree");
|
|
|
$.each(combotrees, function (i, combotree) {
|
|
|
var name = $(combotree).attr('id');
|
|
|
var tree = $('#' + name).combotree('tree');
|
|
|
//获取当前选中的节点
|
|
|
var data = tree.tree('getSelected');
|
|
|
if (data != null) {
|
|
|
self[name.replace("DDL_", "")] = data.id;
|
|
|
self[name.replace("DDL_", "") + "T"] = data.text;
|
|
|
}
|
|
|
});
|
|
|
// 参数属性
|
|
|
$("[name^=TBPara_],[name^=CBPara_],[name^=RBPara_],[name^=DDLPara_]").each(function (i, o) {
|
|
|
var target = $(this);
|
|
|
var name = target.attr("name");
|
|
|
var value;
|
|
|
if (name.match(/^TBPara_/)) {
|
|
|
value = target.val();
|
|
|
value = value.replace('@', ''); //替换掉@符号.
|
|
|
} else if (name.match(/^DDLPara_/)) {
|
|
|
value = target.val();
|
|
|
value = value.replace('@', ''); //替换掉@符号.
|
|
|
} else if (name.match(/^CBPara_/)) {
|
|
|
if (target.length == 1) { // 仅一个复选框
|
|
|
if (target.is(":checked")) {
|
|
|
// 已选
|
|
|
value = "1";
|
|
|
} else {
|
|
|
// 未选
|
|
|
value = "0";
|
|
|
}
|
|
|
} else if (target.length > 1) { // 多个复选框(待扩展)
|
|
|
// ?
|
|
|
}
|
|
|
} else if (name.match(/^RBPara_/)) {
|
|
|
if (target.is(":checked")) {
|
|
|
// 已选
|
|
|
value = "1";
|
|
|
} else {
|
|
|
// 未选
|
|
|
value = "0";
|
|
|
}
|
|
|
}
|
|
|
var key = name.replace(/^TBPara_|CBPara_|RBPara_|DDLPara_/, "");
|
|
|
self.SetPara(key, value);
|
|
|
});
|
|
|
},
|
|
|
|
|
|
CopyJSON: function (json) {
|
|
|
var count = 0;
|
|
|
if (json) {
|
|
|
var self = this;
|
|
|
$.each(json, function (n, o) {
|
|
|
if (typeof self[n] !== "function") {
|
|
|
|
|
|
if (n == 'enName' || n == 'MyPK')
|
|
|
return;
|
|
|
|
|
|
self[n] = o;
|
|
|
jsonString[n] = o;
|
|
|
count++;
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
return count;
|
|
|
},
|
|
|
|
|
|
ToJsonWithParas: function () {
|
|
|
var json = {};
|
|
|
$.each(this, function (n, o) {
|
|
|
if (typeof o !== "undefined") {
|
|
|
json[n] = o;
|
|
|
}
|
|
|
});
|
|
|
if (typeof this.AtPara == "string") {
|
|
|
$.each(this.AtPara.split("@"), function (i, o) {
|
|
|
if (o == "") {
|
|
|
return true;
|
|
|
}
|
|
|
var kv = o.split("=");
|
|
|
if (kv.length == 2) {
|
|
|
json[kv[0]] = kv[1];
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
return json;
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
return Entity;
|
|
|
|
|
|
})();
|
|
|
|
|
|
var Entities = (function () {
|
|
|
|
|
|
var jsonString;
|
|
|
|
|
|
var Entities = function () {
|
|
|
this.ensName = arguments[0];
|
|
|
this.Paras = getParameters(arguments);
|
|
|
if (arguments.length >= 3) {
|
|
|
this.loadData();
|
|
|
}
|
|
|
};
|
|
|
|
|
|
function getParameters(args, divisor) {
|
|
|
var params = "";
|
|
|
var length;
|
|
|
var orderBy;
|
|
|
if (divisor == null || divisor == undefined)
|
|
|
divisor = 2;
|
|
|
|
|
|
if (divisor == 2) {
|
|
|
if (args.length % 2 == 0) {
|
|
|
orderBy = args[args.length - 1];
|
|
|
length = args.length - 1;
|
|
|
} else {
|
|
|
length = args.length;
|
|
|
}
|
|
|
for (var i = 1; i < length; i += 2) {
|
|
|
params += "@" + args[i] + "=" + args[i + 1];
|
|
|
}
|
|
|
if (typeof orderBy !== "undefined") {
|
|
|
params += "@OrderBy=" + orderBy;
|
|
|
}
|
|
|
return params;
|
|
|
}
|
|
|
|
|
|
if (divisor == 3) {
|
|
|
if ((args.length - 1) % divisor != 0) {
|
|
|
orderBy = args[args.length - 1];
|
|
|
length = args.length - 1;
|
|
|
} else {
|
|
|
length = args.length;
|
|
|
}
|
|
|
for (var i = 1; i < length; i += 3) { //args[i+1]是操作符
|
|
|
params += "@" + args[i] + "|" + args[i + 1] + "|" + args[i + 2];
|
|
|
}
|
|
|
if (typeof orderBy !== "undefined") {
|
|
|
params += "@OrderBy||" + orderBy;
|
|
|
}
|
|
|
return params;
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
Entities.prototype = {
|
|
|
constructor: Entities,
|
|
|
loadData: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
|
|
|
if (self.ensName == null || self.ensName == "" || self.ensName == "") {
|
|
|
alert("在初始化实体期间EnsName没有赋值");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entities_Init&EnsName=" + self.ensName + "&Paras=" + self.Paras + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
data = data.replace('err@', '');
|
|
|
data += "\t\n参数信息:";
|
|
|
data += "\t\nDoType=Entities_Init";
|
|
|
data += "\t\EnsName=" + self.ensName;
|
|
|
data += "\t\Paras=" + self.Paras;
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
if ($.isArray(jsonString)) {
|
|
|
self.length = jsonString.length;
|
|
|
$.extend(self, jsonString);
|
|
|
} else {
|
|
|
alert("解析失败, 返回值不是集合");
|
|
|
}
|
|
|
} catch (e) {
|
|
|
alert("json解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
ThrowMakeErrInfo("Entities_Init-" + self.ensName, textStatus);
|
|
|
|
|
|
}
|
|
|
});
|
|
|
},
|
|
|
deleteIt: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
if (self.ensName == null || self.ensName == "" || self.ensName == "") {
|
|
|
alert("在初始化实体期间EnsName没有赋值");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entities_Delete&EnsName=" + self.ensName + "&Paras=" + self.Paras + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
|
ThrowMakeErrInfo("Entities_Delte-" + self.ensName, textStatus);
|
|
|
|
|
|
}
|
|
|
});
|
|
|
},
|
|
|
|
|
|
Retrieve: function () {
|
|
|
var args = [""];
|
|
|
$.each(arguments, function (i, o) {
|
|
|
args.push(o);
|
|
|
});
|
|
|
this.Paras = getParameters(args);
|
|
|
this.loadData();
|
|
|
},
|
|
|
RetrieveCond: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var args = [""];
|
|
|
$.each(arguments, function (i, o) {
|
|
|
args.push(o);
|
|
|
});
|
|
|
this.Paras = getParameters(args, 3);
|
|
|
var self = this;
|
|
|
|
|
|
if (self.ensName == null || self.ensName == "" || self.ensName == "") {
|
|
|
alert("在初始化实体期间EnsName没有赋值");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entities_RetrieveCond&EnsName=" + self.ensName + "&Paras=" + self.Paras + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
if ($.isArray(jsonString)) {
|
|
|
self.length = jsonString.length;
|
|
|
$.extend(self, jsonString);
|
|
|
} else {
|
|
|
alert("解析失败, 返回值不是集合");
|
|
|
}
|
|
|
} catch (e) {
|
|
|
alert("json解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
|
ThrowMakeErrInfo("Entities_RetrieveCond-" + self.ensName, textStatus);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
},
|
|
|
TurnToArry: function () {
|
|
|
|
|
|
var ens = this;
|
|
|
delete ens.Paras;
|
|
|
delete ens.ensName;
|
|
|
delete ens.length;
|
|
|
var arr = [];
|
|
|
for (var key in ens) {
|
|
|
if (Object.hasOwnProperty.call(ens, key)) {
|
|
|
var en = ens[key];
|
|
|
arr.push(en);
|
|
|
}
|
|
|
}
|
|
|
return arr
|
|
|
},
|
|
|
Delete: function () {
|
|
|
var args = [""];
|
|
|
$.each(arguments, function (i, o) {
|
|
|
args.push(o);
|
|
|
});
|
|
|
this.Paras = getParameters(args);
|
|
|
|
|
|
this.deleteIt();
|
|
|
},
|
|
|
DoMethodReturnString: function (methodName) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var params = "";
|
|
|
$.each(arguments, function (i, o) {
|
|
|
if (i != 0)
|
|
|
params += o + "~";
|
|
|
});
|
|
|
|
|
|
params = params.substr(0, params.length - 1);
|
|
|
|
|
|
var self = this;
|
|
|
var string;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=Entities_DoMethodReturnString&EnsName=" + self.ensName + "&MethodName=" + methodName + "¶s=" + params + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
string = data;
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
ThrowMakeErrInfo("Entities_DoMethodReturnString-" + methodName, textStatus);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return string;
|
|
|
|
|
|
},
|
|
|
GetEns: function () {
|
|
|
// { data: [{}, {}, {}], length: 3, name: 'xxx' };
|
|
|
var result = [];
|
|
|
for (var key in this) {
|
|
|
console.log(typeof this[key]);
|
|
|
if (typeof this[key] === 'object') {
|
|
|
result.push(this[key]);
|
|
|
}
|
|
|
}
|
|
|
this.data = result;
|
|
|
console.log('data', this);
|
|
|
return this;
|
|
|
},
|
|
|
|
|
|
DoMethodReturnJSON: function (methodName, params) {
|
|
|
|
|
|
var jsonString = this.DoMethodReturnString(methodName);
|
|
|
|
|
|
if (jsonString.indexOf("err@") != -1) {
|
|
|
alert(jsonString);
|
|
|
return jsonString;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
jsonString = ToJson(jsonString);
|
|
|
|
|
|
//jsonString = JSON.parse(jsonString);
|
|
|
} catch (e) {
|
|
|
jsonString = "err@json解析错误: " + jsonString;
|
|
|
alert(jsonString);
|
|
|
}
|
|
|
return jsonString;
|
|
|
},
|
|
|
RetrieveAll: function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var pathRe = "";
|
|
|
if (plant == "JFlow" && (basePath == null || basePath == '')) {
|
|
|
var rowUrl = GetHrefUrl();
|
|
|
pathRe = rowUrl.substring(0, rowUrl.indexOf('/SDKFlowDemo') + 1);
|
|
|
}
|
|
|
var self = this;
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: pathRe + dynamicHandler + "?DoType=Entities_RetrieveAll&EnsName=" + self.ensName + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
try {
|
|
|
|
|
|
jsonString = ToJson(data);
|
|
|
|
|
|
if ($.isArray(jsonString)) {
|
|
|
self.length = jsonString.length;
|
|
|
$.extend(self, jsonString);
|
|
|
} else {
|
|
|
alert("解析失败, 返回值不是集合");
|
|
|
}
|
|
|
} catch (e) {
|
|
|
alert("json解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
|
ThrowMakeErrInfo("Entities_RetrieveAll-", textStatus);
|
|
|
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
return Entities;
|
|
|
|
|
|
})();
|
|
|
|
|
|
|
|
|
function ToJson(data) {
|
|
|
|
|
|
try {
|
|
|
data = JSON.parse(data);
|
|
|
return data;
|
|
|
} catch (e) {
|
|
|
return cceval(data);
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
var DBAccess = (function () {
|
|
|
|
|
|
function DBAccess() {
|
|
|
}
|
|
|
|
|
|
dynamicHandler = basePath + "/WF/Comm/ProcessRequest";
|
|
|
|
|
|
DBAccess.RunSQL = function (sql, dbSource) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var count = 0;
|
|
|
sql = sql.replace(/'/g, '~');
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=DBAccess_RunSQL&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: { "SQL": encodeURIComponent(sql), "DBSrc": dbSource },
|
|
|
success: function (data) {
|
|
|
count = parseInt(data);
|
|
|
if (isNaN(count)) {
|
|
|
count = -1;
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
ThrowMakeErrInfo("DBAccess_RunSQL-", textStatus);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return count;
|
|
|
|
|
|
};
|
|
|
//执行数据源返回json.
|
|
|
DBAccess.RunDBSrc = function (dbSrc, dbType, dbSource) {
|
|
|
|
|
|
if (dbSrc == "" || dbSrc == null || dbSrc == undefined) {
|
|
|
alert("数据源为空..");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (dbType == undefined) {
|
|
|
dbType = 0; //默认为sql.
|
|
|
|
|
|
if (dbSrc.length <= 20) {
|
|
|
dbType = 2; //可能是一个方法名称.
|
|
|
}
|
|
|
|
|
|
if (dbSrc.indexOf('/') != -1) {
|
|
|
dbType = 1; //是一个url.
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/*if (dbSrc.indexOf('@') != -1) {
|
|
|
//val = val.replace(/~/g, "'"); //替换掉特殊字符,设置的sql语句的引号.
|
|
|
var alt = "如果关键字有多个,可以使用. /myword/g 作为通配符替换。 ";
|
|
|
alert("数据源参数没有替换" + dbSrc + " \t\n" + alt);
|
|
|
return;
|
|
|
}*/
|
|
|
|
|
|
|
|
|
//执行的SQL
|
|
|
if (dbType == 0) {
|
|
|
return DBAccess.RunSQLReturnTable(dbSrc, dbSource);
|
|
|
}
|
|
|
|
|
|
//执行URL
|
|
|
if (dbType == 1 || dbType == "1") {
|
|
|
return DBAccess.RunUrlReturnJSON(dbSrc);
|
|
|
}
|
|
|
|
|
|
//执行方法名称返回json.
|
|
|
if (dbType == 2 || dbType == "2") {
|
|
|
|
|
|
var str = DBAccess.RunFunctionReturnStr(dbSrc);
|
|
|
if (str == null || str == undefined || str == "")
|
|
|
return null;
|
|
|
|
|
|
return JSON.parse(str);
|
|
|
}
|
|
|
//@谢 如何执行一个方法,
|
|
|
// alert("@没有处理执行方法。"); RunFunctionReturnJSON
|
|
|
};
|
|
|
|
|
|
//执行方法名返回str.
|
|
|
DBAccess.RunFunctionReturnStr = function (funcName) {
|
|
|
|
|
|
try {
|
|
|
funcName = funcName.replace(/~/g, "'");
|
|
|
if (funcName.indexOf('(') == -1)
|
|
|
return cceval(funcName + "()");
|
|
|
else
|
|
|
return cceval(funcName);
|
|
|
|
|
|
} catch (e) {
|
|
|
if (e.message)
|
|
|
alert("执行方法[" + funcName + "]错误:" + e.message);
|
|
|
}
|
|
|
};
|
|
|
|
|
|
//执行方法名返回str.
|
|
|
DBAccess.RunSQLReturnVal = function (sql, dbSource) {
|
|
|
var dt = DBAccess.RunSQLReturnTable(sql, dbSource);
|
|
|
if (dt.length == 0)
|
|
|
return null;
|
|
|
var firItem = dt[0];
|
|
|
var firAttr = "";
|
|
|
for (var k in firItem) {
|
|
|
firAttr = k;
|
|
|
break;
|
|
|
}
|
|
|
return firItem[firAttr];
|
|
|
};
|
|
|
|
|
|
DBAccess.RunSQLReturnTable = function (sql, dbSource) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
|
|
|
sql = sql.replace(/~/g, "'");
|
|
|
sql = sql.replace(/[+]/g, "/#");
|
|
|
sql = sql.replace(/-/g, '/$');
|
|
|
|
|
|
|
|
|
|
|
|
var jsonString;
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=DBAccess_RunSQLReturnTable" + "&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
data: { "SQL": encodeURIComponent(sql), "DBSrc": dbSource },
|
|
|
success: function (data) {
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
try {
|
|
|
jsonString = JSON.parse(data);
|
|
|
} catch (e) {
|
|
|
alert("json解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
ThrowMakeErrInfo("DBAccess_RunSQLReturnTable-", textStatus);
|
|
|
}
|
|
|
});
|
|
|
return jsonString;
|
|
|
};
|
|
|
|
|
|
DBAccess.RunUrlReturnString = function (url) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
if (url == null || typeof url === "undefined") {
|
|
|
alert("err@url无效");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (url.indexOf("http") == -1)
|
|
|
url = basePath + url;
|
|
|
if (url.match(/^http:\/\//) == false) {
|
|
|
alert("err@url无效");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
var string;
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
url: url,
|
|
|
dataType: 'html',
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
success: function (data) {
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
return;
|
|
|
}
|
|
|
string = data;
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
|
|
|
alert(url);
|
|
|
ThrowMakeErrInfo("HttpHandler-RunUrlCrossReturnString-", textStatus);
|
|
|
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return string;
|
|
|
};
|
|
|
|
|
|
DBAccess.RunUrlReturnJSON = function (url) {
|
|
|
|
|
|
var jsonString = DBAccess.RunUrlReturnString(url);
|
|
|
if (typeof jsonString === "undefined") {
|
|
|
alert("执行错误:\t\n URL:" + url);
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
if (jsonString.indexOf("err@") != -1) {
|
|
|
alert(jsonString + "\t\n URL:" + url);
|
|
|
return jsonString;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
|
|
|
jsonString = JSON.parse(jsonString);
|
|
|
|
|
|
} catch (e) {
|
|
|
jsonString = "err@json,RunUrlReturnJSON解析错误:" + jsonString;
|
|
|
alert(jsonString);
|
|
|
}
|
|
|
return jsonString;
|
|
|
};
|
|
|
|
|
|
return DBAccess;
|
|
|
|
|
|
})();
|
|
|
|
|
|
var HttpHandler = (function () {
|
|
|
|
|
|
var parameters = {};
|
|
|
|
|
|
var formData;
|
|
|
|
|
|
function HttpHandler(handlerName) {
|
|
|
this.handlerName = handlerName;
|
|
|
parameters = {};
|
|
|
formData = undefined;
|
|
|
}
|
|
|
|
|
|
function validate(s) {
|
|
|
if (s == null || typeof s === "undefined") {
|
|
|
return false;
|
|
|
}
|
|
|
s = s.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, "");
|
|
|
if (s == "" || s == "null" || s == "undefined") {
|
|
|
return false;
|
|
|
}
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
dynamicHandler = basePath + "/WF/Comm/ProcessRequest";
|
|
|
|
|
|
HttpHandler.prototype = {
|
|
|
|
|
|
constructor: HttpHandler,
|
|
|
AddUrlData: function (url) {
|
|
|
var queryString = url;
|
|
|
if (url == null || url == undefined || url == "")
|
|
|
queryString = document.location.search.substr(1);
|
|
|
queryString = decodeURI(queryString);
|
|
|
var self = this;
|
|
|
$.each(queryString.split("&"), function (i, o) {
|
|
|
var param = o.split("=");
|
|
|
if (param.length == 2 && validate(param[1])) {
|
|
|
|
|
|
(function (key, value) {
|
|
|
|
|
|
if (key == "DoType" || key == "DoMethod" || key == "HttpHandlerName")
|
|
|
return;
|
|
|
|
|
|
self.AddPara(key, value);
|
|
|
|
|
|
})(param[0], param[1]);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
AddFile(file) {
|
|
|
if (file instanceof File) {
|
|
|
parameters.append("file", file)
|
|
|
}
|
|
|
},
|
|
|
|
|
|
AddFormData: function () {
|
|
|
if ($("form").length == 0)
|
|
|
throw Error('必须是Form表单才可以使用该方法');
|
|
|
|
|
|
formData = $("form").serialize();
|
|
|
//序列化时把空格转成+,+转义成%2B,在保存时需要把+转成空格
|
|
|
formData = formData.replace(/\+/g, " ");
|
|
|
//form表单序列化时调用了encodeURLComponent方法将数据编码了
|
|
|
// formData = decodeURIComponent(formData, true);
|
|
|
if (formData.length > 0) {
|
|
|
var self = this;
|
|
|
$.each(formData.split("&"), function (i, o) {
|
|
|
var param = o.split("=");
|
|
|
if (param.length == 2 && validate(param[1])) {
|
|
|
(function (key, value) {
|
|
|
self.AddPara(key, decodeURIComponent(value, true));
|
|
|
})(param[0], param[1]);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
},
|
|
|
|
|
|
AddPara: function (key, value) {
|
|
|
parameters[key] = value;
|
|
|
},
|
|
|
|
|
|
AddJson: function (json) {
|
|
|
|
|
|
for (var key in json) {
|
|
|
parameters[key] = json[key];
|
|
|
}
|
|
|
},
|
|
|
|
|
|
Clear: function () {
|
|
|
parameters = {};
|
|
|
formData = undefined;
|
|
|
},
|
|
|
|
|
|
getParams: function () {
|
|
|
var params = [];
|
|
|
$.each(parameters, function (key, value) {
|
|
|
|
|
|
if (value.indexOf('<script') != -1)
|
|
|
value = '';
|
|
|
|
|
|
params.push(key + "=" + value);
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return params.join("&");
|
|
|
},
|
|
|
|
|
|
DoMethodReturnString: function (methodName) {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
var self = this;
|
|
|
var jsonString;
|
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=HttpHandler&DoMethod=" + methodName + "&HttpHandlerName=" + self.handlerName + "&t=" + Math.random(),
|
|
|
data: parameters,
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
if (methodName === 'Login_Submit') {
|
|
|
localStorage.setItem('Token', getQueryFromTargetStr(data, 'Token'))
|
|
|
jsonString = deleteUrlParam(data, 'Token')
|
|
|
} else {
|
|
|
jsonString = data;
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
var url = dynamicHandler + "?DoType=HttpHandler&DoMethod=" + methodName + "&HttpHandlerName=" + self.handlerName + "&t=" + Math.random();
|
|
|
ThrowMakeErrInfo("HttpHandler-DoMethodReturnString-" + methodName, textStatus, url, XMLHttpRequest, errorThrown);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return jsonString;
|
|
|
|
|
|
},
|
|
|
|
|
|
DoMethodReturnJSON: function (methodName) {
|
|
|
|
|
|
var jsonString = this.DoMethodReturnString(methodName);
|
|
|
|
|
|
if (jsonString.indexOf("err@") == 0) {
|
|
|
alert(jsonString);
|
|
|
|
|
|
//alert('请查看控制台(DoMethodReturnJSON):' + jsonString);
|
|
|
console.log(jsonString);
|
|
|
return jsonString;
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
|
|
|
jsonString = ToJson(jsonString);
|
|
|
|
|
|
//jsonString = JSON.parse(jsonString);
|
|
|
} catch (e) {
|
|
|
jsonString = "err@json解析错误: " + jsonString;
|
|
|
alert(jsonString);
|
|
|
// console.log(jsonString);
|
|
|
}
|
|
|
return jsonString;
|
|
|
}
|
|
|
}
|
|
|
return HttpHandler;
|
|
|
|
|
|
})();
|
|
|
|
|
|
var webUserJsonString = null;
|
|
|
var WebUser = function () {
|
|
|
if (dynamicHandler == "")
|
|
|
return;
|
|
|
if (webUserJsonString != null) {
|
|
|
var self = this;
|
|
|
$.each(webUserJsonString, function (n, o) {
|
|
|
self[n] = o;
|
|
|
});
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
|
|
|
dynamicHandler = basePath + "/WF/Comm/ProcessRequest";
|
|
|
|
|
|
|
|
|
var token = GetQueryString("Token");
|
|
|
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
url: dynamicHandler + "?DoType=WebUser_Init&t=" + new Date().getTime(),
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
if (token) {
|
|
|
if (data.indexOf('登录信息丢失') != -1) {
|
|
|
alert("登录信息丢失,请重新登录。");
|
|
|
return false;
|
|
|
} else {
|
|
|
alert(data.replace("err@", ""));
|
|
|
}
|
|
|
}
|
|
|
SetHref(basePath + "/CCMobilePortal/Login.htm");
|
|
|
}
|
|
|
|
|
|
try {
|
|
|
webUserJsonString = JSON.parse(data);
|
|
|
|
|
|
} catch (e) {
|
|
|
alert("json解析错误: " + data);
|
|
|
}
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
var url = dynamicHandler + "?DoType=WebUser_Init&t=" + new Date().getTime();
|
|
|
ThrowMakeErrInfo("WebUser-WebUser_Init", textStatus, url);
|
|
|
}
|
|
|
});
|
|
|
var self = this;
|
|
|
$.each(webUserJsonString, function (n, o) {
|
|
|
self[n] = o;
|
|
|
});
|
|
|
|
|
|
};
|
|
|
|
|
|
function ThrowMakeErrInfo(funcName, textStatus, url, XMLHttpRequest, errorThrown) {
|
|
|
|
|
|
var msg = "1. " + funcName + " err@系统发生异常.";
|
|
|
msg += "\t\n2.检查请求的URL连接是否错误:" + url;
|
|
|
msg += "\t\n3.估计是数据库连接错误或者是系统环境问题. ";
|
|
|
msg += "\t\n4.技术信息:";
|
|
|
|
|
|
if (textStatus != null && textStatus != undefined)
|
|
|
msg += " \t\mtextStatus: " + JSON.stringify(textStatus);
|
|
|
|
|
|
if (errorThrown != null && errorThrown != undefined)
|
|
|
msg += " \t\mtextStatus: " + JSON.stringify(errorThrown);
|
|
|
|
|
|
if (XMLHttpRequest != null && XMLHttpRequest != undefined)
|
|
|
msg += " \t\mtextStatus: " + JSON.stringify(XMLHttpRequest);
|
|
|
|
|
|
msg += "\t\n5.您要打开执行的handler查看错误吗? ";
|
|
|
// msg += "\t\n5 您可以执行一下http://127.0.0.1/WF/Default.aspx/jsp/php 测试一下,动态文件是否可以被执行。";
|
|
|
|
|
|
if (url != null) {
|
|
|
if (window.confirm(msg) == true) {
|
|
|
WinOpen(url);
|
|
|
return;
|
|
|
}
|
|
|
return;
|
|
|
}
|
|
|
alert(msg);
|
|
|
}
|
|
|
|
|
|
//替换全部.
|
|
|
function replaceAll(str, oldKey, newKey) {
|
|
|
|
|
|
if (str == undefined || str == null) {
|
|
|
alert("要替换的原始字符串为空.");
|
|
|
return str;
|
|
|
}
|
|
|
str = str.replace(new RegExp(oldKey, "gm"), newKey);
|
|
|
return str;
|
|
|
}
|
|
|
|
|
|
|
|
|
//date = new Date();
|
|
|
//date = FormatDate(date, "yyyy-MM-dd");
|
|
|
function FormatDate(now, mask) {
|
|
|
var d = now;
|
|
|
var zeroize = function (value, length) {
|
|
|
if (!length) length = 2;
|
|
|
value = String(value);
|
|
|
for (var i = 0, zeros = ''; i < (length - value.length); i++) {
|
|
|
zeros += '0';
|
|
|
}
|
|
|
return zeros + value;
|
|
|
}
|
|
|
|
|
|
return mask.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])\1?|[lLZ])\b/g, function ($0) {
|
|
|
switch ($0) {
|
|
|
case 'd': return d.getDate();
|
|
|
case 'dd': return zeroize(d.getDate());
|
|
|
case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][d.getDay()];
|
|
|
case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][d.getDay()];
|
|
|
case 'M': return d.getMonth() + 1;
|
|
|
case 'MM': return zeroize(d.getMonth() + 1);
|
|
|
case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][d.getMonth()];
|
|
|
case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][d.getMonth()];
|
|
|
case 'yy': return String(d.getFullYear()).substr(2);
|
|
|
case 'yyyy': return d.getFullYear();
|
|
|
case 'h': return d.getHours() % 12 || 12;
|
|
|
case 'hh': return zeroize(d.getHours() % 12 || 12);
|
|
|
case 'H': return d.getHours();
|
|
|
case 'HH': return zeroize(d.getHours());
|
|
|
case 'm': return d.getMinutes();
|
|
|
case 'mm': return zeroize(d.getMinutes());
|
|
|
case 's': return d.getSeconds();
|
|
|
case 'ss': return zeroize(d.getSeconds());
|
|
|
case 'l': return zeroize(d.getMilliseconds(), 3);
|
|
|
case 'L': var m = d.getMilliseconds();
|
|
|
if (m > 99) m = Math.round(m / 10);
|
|
|
return zeroize(m);
|
|
|
case 'tt': return d.getHours() < 12 ? 'am' : 'pm';
|
|
|
case 'TT': return d.getHours() < 12 ? 'AM' : 'PM';
|
|
|
case 'Z': return d.toUTCString().match(/[A-Z]+$/);
|
|
|
// Return quoted strings with the surrounding quotes removed
|
|
|
default: return $0.substr(1, $0.length - 2);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
|
|
|
//表达式的替换.
|
|
|
function DealExp(expStr, webUser) {
|
|
|
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return expStr;
|
|
|
|
|
|
if (webUser == null || webUser == undefined)
|
|
|
webUser = new WebUser();
|
|
|
|
|
|
//替换表达式常用的用户信息
|
|
|
expStr = expStr.replace('@WebUser.No', webUser.No);
|
|
|
expStr = expStr.replace('@WebUser.Name', webUser.Name);
|
|
|
expStr = expStr.replace("@WebUser.FK_DeptNameOfFull", webUser.FK_DeptNameOfFull);
|
|
|
expStr = expStr.replace('@WebUser.FK_DeptName', webUser.FK_DeptName);
|
|
|
expStr = expStr.replace('@WebUser.FK_Dept', webUser.FK_Dept);
|
|
|
expStr = expStr.replace('@WebUser.OrgNo', webUser.OrgNo);
|
|
|
expStr = expStr.replace('@WebUser.OrgName', webUser.OrgName);
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return expStr;
|
|
|
//替换页面中的input框,select下拉框
|
|
|
|
|
|
|
|
|
|
|
|
//select框
|
|
|
var selects = $("select");
|
|
|
$.each(selects, function (i, obj) {
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return false;
|
|
|
var nodeValue = decodeURI(obj.value);
|
|
|
var nodeId = obj.getAttribute("id");
|
|
|
var key = "@" + nodeId.substring(nodeId.indexOf("_") + 1);
|
|
|
|
|
|
expStr = expStr.replace(new RegExp(key + "@", 'g'), nodeValue);
|
|
|
|
|
|
});
|
|
|
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return expStr;
|
|
|
|
|
|
//获取input框
|
|
|
var inputs = $("input");
|
|
|
$.each(inputs, function (i, obj) {
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return false;
|
|
|
var nodeId = obj.getAttribute("id");
|
|
|
if (nodeId == null || nodeId == undefined)
|
|
|
return true;
|
|
|
var nodeType = obj.getAttribute("type");
|
|
|
var nodeValue = "";
|
|
|
|
|
|
nodeValue = obj.value;
|
|
|
if (nodeType == "checkbox") {
|
|
|
nodeValue = 0;
|
|
|
var isChecked = $("#" + nodeId).is(":checked");
|
|
|
if (isChecked == true)
|
|
|
nodeValue = 1;
|
|
|
}
|
|
|
if (nodeType == "radio") {
|
|
|
var nodeName = obj.getAttribute("name");
|
|
|
nodeValue = $("input:radio[name='" + nodeName + "']:checked").val();
|
|
|
}
|
|
|
var key = "@" + nodeId.substring(nodeId.indexOf("_") + 1);
|
|
|
expStr = expStr.replace(new RegExp(key + "@", 'g'), nodeValue);
|
|
|
|
|
|
|
|
|
});
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return expStr;
|
|
|
$.each(selects, function (i, obj) {
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return false;
|
|
|
var nodeValue = decodeURI(obj.value);
|
|
|
var nodeId = obj.getAttribute("id");
|
|
|
var key = "@" + nodeId.substring(nodeId.indexOf("_") + 1);
|
|
|
|
|
|
expStr = expStr.replace(new RegExp(key, 'g'), nodeValue);
|
|
|
|
|
|
});
|
|
|
$.each(inputs, function (i, obj) {
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return false;
|
|
|
var nodeId = obj.getAttribute("id");
|
|
|
if (nodeId == null || nodeId == undefined)
|
|
|
return true;
|
|
|
var nodeType = obj.getAttribute("type");
|
|
|
var nodeValue = "";
|
|
|
|
|
|
nodeValue = obj.value;
|
|
|
if (nodeType == "checkbox") {
|
|
|
nodeValue = 0;
|
|
|
var isChecked = $("#" + nodeId).is(":checked");
|
|
|
if (isChecked == true)
|
|
|
nodeValue = 1;
|
|
|
}
|
|
|
if (nodeType == "radio") {
|
|
|
var nodeName = obj.getAttribute("name");
|
|
|
nodeValue = $("input:radio[name='" + nodeName + "']:checked").val();
|
|
|
}
|
|
|
var key = "@" + nodeId.substring(nodeId.indexOf("_") + 1);
|
|
|
expStr = expStr.replace(new RegExp(key, 'g'), nodeValue);
|
|
|
});
|
|
|
|
|
|
|
|
|
return expStr;
|
|
|
}
|
|
|
|
|
|
function DealJsonExp(json, expStr, webUser) {
|
|
|
if (webUser == null || webUser == undefined)
|
|
|
webUser = new WebUser();
|
|
|
|
|
|
//替换表达式常用的用户信息
|
|
|
expStr = expStr.replace('@WebUser.No', webUser.No);
|
|
|
expStr = expStr.replace('@WebUser.Name', webUser.Name);
|
|
|
expStr = expStr.replace("@WebUser.FK_DeptNameOfFull", webUser.FK_DeptNameOfFull);
|
|
|
expStr = expStr.replace('@WebUser.FK_DeptName', webUser.FK_DeptName);
|
|
|
expStr = expStr.replace('@WebUser.FK_Dept', webUser.FK_Dept);
|
|
|
expStr = expStr.replace('@WebUser.OrgNo', webUser.OrgNo);
|
|
|
expStr = expStr.replace('@WebUser.OrgName', webUser.OrgName);
|
|
|
|
|
|
if (expStr.indexOf('@') == -1)
|
|
|
return expStr;
|
|
|
|
|
|
$.each(json, function (n, val) {
|
|
|
if (expStr.indexOf("@") == -1)
|
|
|
return;
|
|
|
expStr = expStr.replace("@" + n, val);
|
|
|
});
|
|
|
return expStr;
|
|
|
}
|
|
|
|
|
|
//根据AtPara例如AtPara=@Helpurl=XXX@Count=XXX,获取HelpUrl的值
|
|
|
function GetPara(atPara, key) {
|
|
|
if (typeof atPara != "string" || typeof key == "undefined" || key == "") {
|
|
|
return undefined;
|
|
|
}
|
|
|
var reg = new RegExp("(^|@)" + key + "=([^@]*)(@|$)");
|
|
|
var results = atPara.match(reg);
|
|
|
if (results != null) {
|
|
|
return unescape(results[2]);
|
|
|
}
|
|
|
return undefined;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
function SFTaleHandler(url) {
|
|
|
//获取当前网址,如: http://localhost:80/jflow-web/index.jsp
|
|
|
var curPath = GetHrefUrl();
|
|
|
//获取主机地址之后的目录,如: jflow-web/index.jsp
|
|
|
var pathName = window.document.location.pathname;
|
|
|
var pos = curPath.indexOf(pathName);
|
|
|
//获取主机地址,如: http://localhost:80
|
|
|
var localhostPaht = curPath.substring(0, pos);
|
|
|
//获取带"/"的项目名,如:/jflow-web
|
|
|
var projectName = pathName.substring(0, pathName.substr(1).indexOf('/') + 1);
|
|
|
|
|
|
var localpath = localhostPaht + projectName;
|
|
|
if (plant == "CCFlow") {
|
|
|
// CCFlow
|
|
|
dynamicHandler = localhostPaht + "/DataUser/SFTableHandler.ashx";
|
|
|
} else {
|
|
|
// JFlow
|
|
|
dynamicHandler = localpath + "/DataUser/SFTableHandler/";
|
|
|
}
|
|
|
var jsonString = "";
|
|
|
|
|
|
if (url.indexOf("?") == -1)
|
|
|
url = url + "?1=1";
|
|
|
|
|
|
url = dynamicHandler + url + "&t=" + new Date().getTime();
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
async: false,
|
|
|
url: url,
|
|
|
xhrFields: {
|
|
|
withCredentials: true
|
|
|
},
|
|
|
crossDomain: true,
|
|
|
dataType: 'html',
|
|
|
success: function (data) {
|
|
|
if (data.indexOf("err@") != -1) {
|
|
|
alert(data);
|
|
|
jsonString = "false";
|
|
|
}
|
|
|
|
|
|
jsonString = data;
|
|
|
},
|
|
|
error: function (XMLHttpRequest, textStatus, errorThrown) {
|
|
|
alert(URL + "err@系统发生异常, status: " + XMLHttpRequest.status + " readyState: " + XMLHttpRequest.readyState);
|
|
|
}
|
|
|
});
|
|
|
|
|
|
return jsonString;
|
|
|
}
|
|
|
|
|
|
function validate(s) {
|
|
|
if (s == null || typeof s === "undefined") {
|
|
|
return false;
|
|
|
}
|
|
|
s = s.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, "");
|
|
|
if (s == "" || s == "null" || s == "undefined") {
|
|
|
return false;
|
|
|
}
|
|
|
return true;
|
|
|
}
|
|
|
var loadWebUser = null;
|
|
|
var url = GetHrefUrl().toLowerCase();
|
|
|
if (url.indexOf('login.htm') == -1 && url.indexOf('dbinstall.htm') == -1 && url.indexOf('index.htm') == -1) {
|
|
|
loadWebUser = new WebUser();
|
|
|
}
|
|
|
|
|
|
//初始化页面
|
|
|
$(function () {
|
|
|
dynamicHandler = basePath + "/WF/Comm/ProcessRequest";
|
|
|
//判断登录权限.
|
|
|
|
|
|
if (url.indexOf('login.htm') == -1
|
|
|
&& url.indexOf('dbinstall.htm') == -1
|
|
|
&& url.indexOf('loginwebsite.htm') == -1
|
|
|
&& url.indexOf('default.htm') == -1
|
|
|
&& url.indexOf('gotomyflow.htm') == -1
|
|
|
&& url.indexOf('reguser.htm') == -1
|
|
|
&& url.indexOf('port.htm') == -1
|
|
|
&& url.indexOf('index.htm') == -1) {
|
|
|
|
|
|
if (loadWebUser != null && (loadWebUser.No == "" || loadWebUser.No == undefined || loadWebUser.No == null)) {
|
|
|
dynamicHandler = "";
|
|
|
alert(" 登录信息丢失,请重新登录.");
|
|
|
|
|
|
//return;
|
|
|
}
|
|
|
|
|
|
//如果进入了管理员目录.
|
|
|
if (url.indexOf("/admin/") != -1 && loadWebUser.IsAdmin != 1) {
|
|
|
dynamicHandler = "";
|
|
|
alert("管理员登录信息丢失,请重新登录,当前用户[" + loadWebUser.No + "]不能操作管理员目录功能.");
|
|
|
return;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
/**
|
|
|
* 按照MapAttrs的规范去,处理jsonDT的大小写.
|
|
|
* @param {数据集合} jsonDT
|
|
|
* @param {属性集合} mapAttrs
|
|
|
*/
|
|
|
function DealDataTableColName(jsonDT, mapAttrs) {
|
|
|
var data = {};
|
|
|
//遍历数据源的列.
|
|
|
for (colName in jsonDT) {
|
|
|
//找到。
|
|
|
for (var i = 0; i < mapAttrs.length; i++) {
|
|
|
var mapAttr = mapAttrs[i];
|
|
|
|
|
|
if (mapAttr.KeyOfEn.toUpperCase() == colName.toUpperCase()) {
|
|
|
data[mapAttr.KeyOfEn] = jsonDT[colName];
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
}
|
|
|
return data;
|
|
|
}
|
|
|
|
|
|
|
|
|
/**
|
|
|
* 通用配置的获取
|
|
|
* @param {any} key 变量
|
|
|
* @param {any} defVal 默认值
|
|
|
*/
|
|
|
function getConfigByKey(key, defVal) {
|
|
|
|
|
|
if (typeof CommonConfig == "undefined") {
|
|
|
CommonConfig = {};
|
|
|
CommonConfig[key] = defVal;
|
|
|
return defVal;
|
|
|
}
|
|
|
if (CommonConfig[key] == undefined)
|
|
|
CommonConfig[key] = defVal;
|
|
|
|
|
|
if (key == "IsHideMobileBack" && CommonConfig[key] == true)
|
|
|
$(".back-hidden").remove();
|
|
|
return CommonConfig[key];
|
|
|
}
|
|
|
|
|
|
getConfigByKey("IsHideMobileBack", false); |