You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

171 lines
6.9 KiB

'use strict';
var fnPageInit = function () {
var canDo = new CanDo({
//當前程式所有ID名稱集合
idKeys: ['OrgID', 'CityID', 'CountryID', 'LangType', 'RegionID'],
//當前程式所有參數名稱集合
paramKeys: ['CityID', 'CountryID', 'LangType', 'RegionID'],
/**客製化驗證規則
* @param {Object} pargs CanDo 對象*/
validRulesCus: function (pargs) {
$.validator.addMethod("cityclassidrule", function (value) { //驗證城市編號是否重複
var bRetn = true;
if (value) {
g_api.ConnectLite(pargs.ProgramId, 'QueryOrder',
{
CountryID: $('#CountryID').val(),
CityID: value
},
function (res) {
if (res.RESULT && res.DATA.rel > 0) {
bRetn = false;
}
}, null, false);
}
return bRetn;
});
},
//驗證規則
validRules: function (pargs) {
return {
onfocusout: false,
rules: {
CityID: { cityclassidrule: pargs.action === 'add' ? true : false },
},
messages: {
CityID: { cityclassidrule: i18next.t("message.Data_Repeat") },
}
};
},
getOneBack: function (pargs, data) {
var oRes = data;
oRes.Contactors = $.parseJSON(oRes.Contactors || '[]');
disableInput(pargs._form, '#CityID', false);
},
/**頁面初始化
* @param {Object} pargs CanDo 對象*/
pageInit: function (pargs) {
var postArray = [];
if (pargs.action === 'upd') {
$('#CityID', '#CountryID').prop('disabled', true);
postArray.push(pargs._getOne());
}
postArray.push(fnLanguageDrop());
$.whenArray(postArray).done(function (res) {
if (pargs.action === 'upd' && res[0].RESULT) {
var oRes = res[0].DATA.rel;
pargs._setFormVal(oRes);
if (oRes.LangType) {
$('#LangType').val(oRes.LangType);
fnSetRegionIDdrop().done(function () {
$('#RegionID').val(oRes.RegionID);
fnCountryDrop().done(function () {
$('#CountryID').val(oRes.CountryID);
fnSetOrderByValueDrop().done(function () {
$('#OrderByValue').val(oRes.OrderByValue);
});
});
});
pargs._setFormVal(oRes);
}
else {
pargs._setFormVal(oRes);
}
}
});
$('#RegionID').select2();
$('#CountryID').select2();
}
}),
/**國家下拉選單
* @return {Object} Ajax 物件*/
fnCountryDrop = function () {
var data = {
RegionID: $('#RegionID').val(),
LangType: $('#LangType').val(),
};
if ($('#RegionID').val()) {
return g_api.ConnectLite(canDo.ProgramId, "QueryCountryList", data,
function (res) {
if (res.RESULT) {
var saList = res.DATA.rel;
if (saList.length > 0) {
var sOptions = createOptions(saList, 'CountryID', 'CountryName', false);
$('#CountryID').html(sOptions).on('change', function () {
fnSetOrderByValueDrop();
$('#OrderByValue').val("");
});
}
}
});
}
},
/**洲別下拉選單
* @return {Object} Ajax 物件*/
fnSetRegionIDdrop = function () {
return g_api.ConnectLite(canDo.ProgramId, "QueryRegionList", {
LangType: $("#LangType").val()
},
function (res) {
if (res.RESULT) {
var regionList = res.DATA.rel;
$('#RegionID').html(createOptions(regionList, 'RegionID', 'RegionName', false)).on('change', function () {
$('#CountryID').empty();
if ($('#RegionID').val()) { //監聽RegionID,若RegionID值改變,執行fnCountryDrop()
$('#CountryID').val("");
fnCountryDrop(); //選取不同的洲別,國家下拉選單也會出現相應的國家,如選擇亞洲,國家下拉選單內都會是亞洲的國家
}
});
}
});
},
//排序下拉選單
fnSetOrderByValueDrop = function () {
var data = {
CountryID: $("#CountryID").val(), //排序會因選擇不同的CountryID改變
LangType: $('#LangType').val()
};
return g_api.ConnectLite(canDo.ProgramId, "QueryOrder",data,
function (res) {
if (res.RESULT) {
var iCount = res.DATA.rel; //取得目前的城市資料總筆數
if (canDo.action === 'add') { //若為新增
iCount++; //城市資料總筆數+1
}
$('#OrderByValue').html(createOptions(iCount));
if (canDo.action === 'add') {
$('#OrderByValue').val(iCount);
}
}
});
},
//語系下拉選單
fnLanguageDrop = function () {
return g_api.ConnectLite(canDo.ProgramId, "GetLanguage",
{},
function (res) {
if (res.RESULT) {
var saList = res.DATA.rel;
$('#LangType').html(createOptions(saList, 'LanguageID', 'LanguageName', false)).on('change', function () {
if ($('#LangType').val()) { //監聽RegionID,若RegionID值改變,執行fnSetOrderByValueDrop()
fnSetRegionIDdrop();
}
}).select2();
}
});
};
};
require(['base', 'cando', 'select2', 'jsgrid'], fnPageInit);