目前格式:HTML/XML
<script type="text/javascript" th:inline="javascript" layout:fragment="contentScript"
th:object="${@sessionAccessor.user}">
var app = new Vue({
el: "#app",
data: {
// 準增員資料
userData: {
isNew: true,
/* 文件上傳 */
uploadDefines: [
/*
{
jobType: "A1",
fileType: "Head2inch",
fileDesc: "二吋彩色大頭貼",
fileHead: "二吋彩色大頭貼",
uploaded: 1,
alertMark: null,
notAlertMarked: false,
alertMarked: false
}
*/
],
/* 基本資料 */
// 準增員主檔
user: {
// 使用者系統編號 Integer
sysCode: "",
// 身分證字號/帳號
userId: "",
// 姓名
userName: "",
// 羅馬拚音
romanName: "",
// 電子郵件
email: "",
// 手機號碼
mobilePhone: "",
// 出生日期 yyyyMMdd
birthday: "",
// 直屬主管登錄證號
dsRegisterId: "",
// 直屬主管
dsAgent: {
userId: "",
userName: "",
agentCode: "",
registerNo: "",
lineCode: "",
agentChannel: "",
mobilePhone: "",
email: "",
branchCode: "",
branchName: "",
branchManager: "",
branchManagerEmail: "",
branchManagerMobile: "",
branchAssistant: "",
centerCode: "",
centerName: "",
centerManager: "",
centerManagerEmail: "",
centerManagerMobile: "",
levelCode: "",
levelTitle: "",
agentStatusCode: "",
agentStatus: "",
leaveDate: "",
aguiCenter: "",
aguiManager: "",
aguiCenterName: "",
createTime: ""
},
// 推薦人登錄證號
refRegisterId: "",
// 推薦人
refAgent: {
userId: "",
userName: "",
agentCode: "",
registerNo: "",
lineCode: "",
agentChannel: "",
mobilePhone: "",
email: "",
branchCode: "",
branchName: "",
branchManager: "",
branchManagerEmail: "",
branchManagerMobile: "",
branchAssistant: "",
centerCode: "",
centerName: "",
centerManager: "",
centerManagerEmail: "",
centerManagerMobile: "",
levelCode: "",
levelTitle: "",
agentStatusCode: "",
agentStatus: "",
leaveDate: "",
aguiCenter: "",
aguiManager: "",
aguiCenterName: "",
createTime: ""
},
// 通訊處代號
commCode: "",
// 通訊處
commUnit: {
agentChannel: "",
commCode: "",
commName: "",
areaCenter: {
agentChannel: "",
centerCode: "",
centerName: "",
isDelete: false
},
assistant: {
employeeNo: "",
employeeName: "",
enableSendSms: false,
enableSendEmail: false,
email: "",
mobilePhone: "",
modifyTime: ""
},
isDelete: false
},
// 職務代碼
jobId: "",
// 職務類別
jobType: "",
// 新增時間 yyyy-MM-dd'T'HH:mm:ss
createTime: "",
// 修改時間 yyyy-MM-dd'T'HH:mm:ss
modifyTime: "",
// 狀態
status: "",
// 是否結案
isClose: false,
// 是否已簽署聲明事項
agreementSigned: false
},
// 準增員詳細資料檔
userDetail: {
// 準增員主要key值
sysCode: "",
// 新增時間 yyyy-MM-dd'T'HH:mm:ss
addDate: "",
// 更新時間 yyyy-MM-dd'T'HH:mm:ss
updDate: "",
//
enName: "",
// 英文姓名
eegName: "",
// 報聘單位/推薦人/增員者
myReferrer: "",
// 同業經歷
mySameExperience: "",
// 是否有親屬在本公司任職
isWorkHere: "",
// Line ID
lineID: "",
// 性別
sex: "",
// 婚姻
marry: "",
// 血型
blood: "",
// 子女人數
brood: "",
// 住家電話
tel1: "",
// 行動電話
tel2: "",
// 電子郵件
mail: "",
// 原住民姓名
romanName: "",
// 緊急聯絡人姓名
criName: "",
// 緊急聯絡人關係 0:配偶 1:子女 2:父母 3:兄弟姐妹 4:朋友 5:其他
criRel: "",
// 緊急聯絡人電話
criTel: "",
// 學歷 0:其他 1:研究所 2:大學 3:專科 4:高中/職 5:國中 6:小學
degree: "",
// 最高學歷學校名稱
school: "",
// 科系
major: "",
// 畢業 0:畢業 1:肄業 2:其他
grade: "",
// 學校社團經驗 0:無 1:有
asso: "",
// 學校社團擔任幹部名稱
assoName: "",
// 公司名稱1
com1: "",
// 任職期間年(起)
fdateY1: "",
// 任職期間月(起)
fdateM1: "",
// 任職期間年(迄)
tdateY1: "",
// 任職期間月(迄)
tdateM1: "",
// 年資 ex:1.2(年)
expt1: "",
// 職稱
title1: "",
// 工作屬性 0:業務性 1:非業務性
property1: "",
// 年收入 萬元
income1: "",
// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業
industry1: "",
// 公司名稱2
com2: "",
// 任職期間年(起)
fdateY2: "",
// 任職期間月(起)
fdateM2: "",
// 任職期間年(迄)
tdateY2: "",
// 任職期間月(迄)
tdateM2: "",
// 年資 ex:1.2(年)
expt2: "",
// 職稱
title2: "",
// 工作屬性 0:業務性 1:非業務性
property2: "",
// 年收入 萬元
income2: "",
// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業
industry2: "",
// 公司名稱3
com3: "",
// 任職期間年(起)
fdateY3: "",
// 任職期間月(起)
fdateM3: "",
// 任職期間年(迄)
tdateY3: "",
// 任職期間月(迄)
tdateM3: "",
// 年資 ex:1.2(年)
expt3: "",
// 職稱
title3: "",
// 工作屬性 0:業務性 1:非業務性
property3: "",
// 年收入 萬元
income3: "",
// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業
industry3: "",
// 配偶職業
partnerJob: "",
// 壽險證照
cert1: "",
// 產險證照
cert2: "",
// 投資型證照
cert3: "",
// 配偶其他
certElse: "",
// 外幣證照
cert4: "",
// 身份證字號
pid: "",
// 戶籍地址
addr1: "",
// 戶籍地址-郵遞區號
addr1PostalCode: "",
// 戶籍地址-縣市
addr1City: "",
// 戶籍地址-鄉鎮市區
addr1Towns: "",
// 戶籍地址-路/段/道/街/村/里
addr1Village: "",
// 戶籍地址-鄰
addr1RoadStreet: "",
// 戶籍地址-巷
addr1Lane: "",
// 戶籍地址-弄
addr1Alley: "",
// 戶籍地址-衖
addr1Section: "",
// 戶籍地址-號
addr1Number: "",
// 戶籍地址-樓
addr1Floor: "",
// 戶籍地址-備註
addr1Remark: "",
// 通訊地址
addr2: "",
// 通訊地址-郵遞區號
addr2PostalCode: "",
// 通訊地址-縣市
addr2City: "",
// 通訊地址-鄉鎮市區
addr2Towns: "",
// 通訊地址-路/段/道/街/村/里
addr2Village: "",
// 通訊地址-鄰
addr2RoadStreet: "",
// 通訊地址-巷
addr2Lane: "",
// 通訊地址-弄
addr2Alley: "",
// 通訊地址-衖
addr2Section: "",
// 通訊地址-號
addr2Number: "",
// 通訊地址-樓
addr2Floor: "",
// 通訊地址-備註
addr2Remark: "",
// 兵役調查
army: "",
// 中信銀台幣帳務-分行名稱
ctbcAccountBranch: "",
// 中信銀台幣帳戶-帳號號碼
ctbcAccountAccountNumber: "",
// 是否有其他工作經歷 YN
workOther: "",
// 是否擔任過業務人員
usedtobeAgent: "",
// 是否曾任職本公司業務員(包含台灣/宏利/大都會人壽)
usedtobeAgentTW: ""
},
/* 學經歷 */
// 工作經驗
userWorks: [
/*
{
// 流水號
seq: Integer,
// 準增員主要key值
sysCode: Integer,
// 公司名稱
companyName: String,
// 工作期間-起 YYYY-MM-DD
workStartDate: String,
// 工作期間-迄 YYYY-MM-DD
workEndDate: String,
// 通訊處名稱-非必填
branchName: String
}
*/
],
// 其他工作經歷
userWorkOthers: [
/*
{
// 流水號
seq: Integer,
// 準增員主要key值
sysCode: Integer,
// 公司名稱
companyName: String,
// 工作期間-起 YYYY-MM-DD
workStartDate: String,
// 工作期間-迄 YYYY-MM-DD
workEndDate: String,
// 職稱
title: String,
// 行業別
jobkind: String,
// 工作內容
jobDesc: String
}
*/
],
/* 背景聲明 */
userBackground: {
// 準增員唯一值
sysCode: "",
// 信用報告分數 Integer
creditRptDegree: "",
// 信用報告日期 yyyy-MM-dd'T'HH:mm:ss
creditRptDate: "",
// 人身保險合格證號
lifeRegisterId: "",
// 人身保險登錄狀況 Integer
lifeRegStatus: "",
// 金融常識合格證號
fincRegisterId: "",
// 財產登錄狀況(TableL SystemCodeDef,CodeType:GenRegStatus)
genRegStatus: "",
// 是否有親屬在本公司擔任業務員YN
parentAgent: "",
// 親屬姓名
parentName: "",
// 親屬關係(TableL SystemCodeDef,CodeType:ParentReal)
parentRela: "",
// 業務人員管理規則懲處紀錄(Y: 有 N:無)
punishHistory: "",
// 業務人員管理規則懲處紀錄詳細說明
punishHisDetail: "",
// 是否有犯罪紀錄(Y: 有 N:無)
crimeHistory: "",
// 犯罪紀錄詳細說明
crimeDetail: "",
// 公會懲處紀錄 (Y: 有 N:無)
liaPunishHistory: "",
// 公會懲處紀錄詳細說明
liaPunishHisDetail: ""
}
},
// hasWorkExp: false,
// hasWorkOtherExp: false,
alert: {
form01: false,
form02: false,
form03: false,
form04: false
},
link: {
// 壽險公會連結
lifeOrg: "http://public.liaroc.org.tw/lia-public/indexUsr.jsp",
// 產險公會連結
generalOrg: "http://salesinfo.nlia.org.tw/index.php"
}
},
beforeMount() {
// 準增員資料
var vm = this;
var userData = /*[[${@requestAccessor.getAttribute(T(com.taiwanlife.recruit.enums.ModelKey).USER_DATA)}]]*/ {};
// 初始值
var nestedEmptyValue = function(value) {
if ($.isArray(value)) {
for (var val of value) {
if ("string" === typeof(val)) {
val = val || "";
} else {
nestedEmptyValue(val);
}
}
} else if ($.isPlainObject(value)) {
for (var key in value) {
if ("string" === typeof(value[key]) || undefined == value[key] || null == value[key]) {
value[key] = value[key] || "";
} else {
nestedEmptyValue(value[key]);
}
}
}
};
nestedEmptyValue(userData);
this.userData = $.extend(true, {}, this.userData, userData);
// if (this.userData.userWorks && this.userData.userWorks.length > 0) {
// this.hasWorkExp = true;
// }
if (!this.userData.userDetail.workOther) {
if (this.userData.userWorkOthers && this.userData.userWorkOthers.length > 0) {
this.userData.userDetail.workOther = "Y";
} else {
this.userData.userDetail.workOther = "N";
}
}
// this.hasWorkOtherExp = "Y" == this.userData.userDetail.workOther;
},
mounted() {
setTab("tablist");
this.init();
},
methods: {
init() {
this.initRule();
if (false === this.userData.isNew) {
this.showTabAlert();
}
},
initRule() {
var errorPlacement = function (error, element) {
var ename = element.attr("name");
if (/^uploadFile/.test(ename)) {
$(element).closest("table").next().append(error);
} else if (/^addr/.test(ename) || /History/.test(ename) || /^parent[Name|Rela]/.test(ename)) {
$(element).closest("td").parent().children().last().append(error);
} else {
$(element).parent().children().last().after(error);
}
};
var defaultSettings = {
errorElement: "div",
errorPlacement: errorPlacement
}
var form01Settings = {
rules: {},
messages: {}
};
for (var index in this.userData.uploadDefines) {
if (this.userData.uploadDefines[index].mustFlag == "Y") {
form01Settings.rules[`uploadFile${parseInt(index) + 1}`] = {
required: {
depends: function(element) {
return "0" == $(element).prev().val();
}
}
};
form01Settings.messages[`uploadFile${parseInt(index) + 1}`] = { required: `請上傳${this.userData.uploadDefines[index].fileHead}${"Head2inch" == this.userData.uploadDefines[index].fileType ? "(上傳格式限 JPG)" : ""}` };
}
}
$("#form01").validate($.extend(true, {}, defaultSettings, form01Settings));
$("#form02").validate($.extend(true, {}, defaultSettings, {
rules: {
userName: {
required: true,
maxlength: 200
},
romanName: {
maxlength: 200,
format: ego.validator.pattern.romanName
},
birthday: {
required: true,
maxlength: 8
},
mobilePhone: {
maxlength: 20,
required: true,
mobilePhone: true
},
tel1: {
maxlength: 20,
format: ego.validator.pattern.telephone
},
email: {
required: true,
email: true,
blockEmail: true,
maxlength: 50
},
army: {
required: true
},
ctbcAccountBranch: {
required: true
},
ctbcAccountAccountNumber: {
required: true,
digits: true,
format: ego.validator.pattern.accountNumber
}
}, messages: {
userName: {
required: "請輸入姓名",
},
romanName: {
format: "原住民姓名不符合條件,請重新輸入",
},
birthday: {
required: "請選擇出生年月日"
},
mobilePhone: {
required: "請輸入手機號碼",
mobilePhone: "手機號碼不符合條件,請重新輸入",
},
tel1: {
format: "住家電話不符合條件,請重新輸入"
},
email: {
required: "請輸入電子郵件",
email: "電子郵件不符合條件,請重新輸入"
},
army: {
required: "請選擇兵役調查",
},
ctbcAccountBranch: {
required: "請輸入中信銀台幣銀行帳戶-分行",
},
ctbcAccountAccountNumber: {
required: "請輸入中信銀台幣銀行帳戶-帳號",
digits: "中信銀台幣銀行帳戶-帳號不符合條件,請重新輸入",
format: "中信銀台幣銀行帳戶-帳號不符合條件,請重新輸入"
}
}
}));
$("#form04").validate($.extend(true, {}, defaultSettings, {
rules: {
creditRptDegree: {
required: true,
creditRptDegree: true
},
creditRptDate: {
required: true
},
lifeRegisterId: {
required: true,
format: ego.validator.pattern.lifeRegisterId
},
lifeRegStatus: {
required: true
},
genRegStatus: {
required: true
},
parentName: {
required: {
depends: function(element) {
return "Y" == $("input[name=parentAgent]:checked").val();
}
}
},
parentRela: {
required: {
depends: function(element) {
return "Y" == $("input[name=parentAgent]:checked").val();
}
}
},
punishHistory: {
required: true
},
punishHisDetail: {
required: {
depends: function(element) {
return "Y" == $("input[name=punishHistory]:checked").val();
}
}
},
liaPunishHistory: {
required: true
},
liaPunishHisDetail: {
required: {
depends: function(element) {
return "Y" == $("input[name=liaPunishHistory]:checked").val();
}
}
},
crimeHistory: {
required: true
},
crimeDetail: {
required: {
depends: function(element) {
return "Y" == $("input[name=crimeHistory]:checked").val();
}
}
}
}, messages: {
creditRptDegree: {
required: "請輸入信用報告分數或無法評分",
creditRptDegree: "請輪入分數或無法評分"
},
creditRptDate: {
required: "請選擇信用報告日期"
},
lifeRegisterId: {
required: "請輸入人身保險合格證號"
},
lifeRegStatus: {
required: "請勾選人身保險登錄狀況"
},
genRegStatus: {
required: "請勾選財產保險登錄狀況"
},
parentName: {
required: "請輸入親屬姓名"
},
parentRela: {
required: "請選擇親屬關係"
},
punishHistory: {
required: "請勾選是否曾違反業務人員管理規則而受懲處紀錄"
},
punishHisDetail: {
required: "請輸入受懲處紀錄詳細說明"
},
liaPunishHistory: {
required: "請勾選是否曾受公會懲處紀錄"
},
liaPunishHisDetail: {
required: "請輸入公會懲處紀錄詳細說明"
},
crimeHistory: {
required: "請勾選是否有刑事犯罪紀錄"
},
crimeDetail: {
required: "請輸入刑事犯罪紀錄詳細說明"
}
}
}));
},
showTabAlert() {
for (var form in this.alert) {
this.alert[`${form}`] = !$(`#${form}`).valid();
}
},
// generateKey(key, index) {
// if (index || $.isNumeric(index)) {
// return `${key}${index + 1}`;
// }
// return key;
// },
handleCreditRptDegree(event) {
if (/^0/.test(event.target.value)) {
this.userData.userBackground.creditRptDegree = event.target.value.substring(1);
}
},
handleDate(target, date) {
let form = $(target).closest("form").attr("id");
let element = $(target).attr("id");
switch (element) {
case "birthday":
this.userData.user.birthday = date;
break;
case "creditRptDate":
this.userData.userBackground.creditRptDate = date;
break;
default:
let index = element.substr(-1);
let work = this.userData[element.split('_')[0]][index];
if (!work){
work = {};
this.userData[element.split('_')[0]][index] = work;
}
work[element.split('_')[1]] = date;
if ($(target).prevAll('input.hasMonthpicker')) {
$(target).prevAll('input.hasMonthpicker').monthpicker("option", "maxDate", date);
}
if ($(target).nextAll('input.hasMonthpicker')) {
$(target).nextAll('input.hasMonthpicker').monthpicker("option", "minDate", date);
}
break;
}
},
handleDependency(event) {
var form = $(event.target).closest("form").attr("id");
var elements = Array.prototype.slice.call(arguments, 1)
elements.forEach(function(item, index) {
$(`#${form}`).validate().element(`#${item}`);
});
},
handleChange(e) {
let formId = $(e.target).closest("form").attr("id");
let el = e.target;
this.$nextTick(() => {
if (el) {
$(`#${formId}`).validate().element(el);
}
});
},
handleAddress(e){
let form = $(e.target).closest("form").attr("id");
let element = $(e.target).attr("id");
if (/\d/g.test(e.target.value)){
let tempStr = '';
for(let i=0;i<e.target.value.toString().length;i++){
let numCode = e.target.value.toString().charCodeAt(i);
if (numCode <= 0x007E && numCode >= 0x0021){
numCode += 0xFEE0;
}
tempStr += String.fromCharCode(numCode);
}
e.target.value = tempStr;
}
this.userData.userDetail[element] = e.target.value;
this.$nextTick(()=>$(`#${form}`).validate().element(`#${element}`));
},
handleWork(event){
let element = event.target.id;
let index = element.substr(-1);
let work = this.userData[element.split('_')[0]][index];
if (!work){
work = {};
this.userData[element.split('_')[0]][index] = work;
}
work[element.split('_')[1]] = event.target.value;
},
focusoutName(event) {
let formId = $(event.target).closest("form").attr("id");
let el = event.target;
switch (event.target.id) {
case 'userName':
this.userData.user.userName = event.target.value;
break;
case 'romanName':
this.userData.user.romanName = event.target.value;
break;
case 'criName':
this.userData.userDetail.criName = event.target.value;
break;
}
this.$nextTick(() => {
if (el) {
$(`#${formId}`).validate().element(el);
}
});
},
save(event) {
// 暫存
this.showTabAlert();
if (!ego.ajax.updateUserDataTemp(this.userData)) {
ego.dialog.error("暫存失敗,請稍候再試", window.location.href);
} else {
ego.dialog.alert("暫存成功", window.location.href);
}
},
handleFile(target, status) {
$(target).closest("form").validate().element(`#${$(target).attr("id")}`);
},
apply(event) {
this.showTabAlert();
for (var form in this.alert) {
if (!$(`#${form}`).valid()) {
ego.dialog.error("請確認報聘資料填寫完整,再行遞交申請。");
return;
}
}
if (!ego.ajax.updateUserDataTemp(this.userData)) { // 暫存
ego.dialog.error("遞交申請失敗,請稍候再試", window.location.href);
} else if (!ego.ajax.applyUserData(this.userData.user.sysCode)) { // 遞交申請
ego.dialog.error("遞交申請失敗,請稍候再試", window.location.href);
} else {
if (this.userData.user.commUnit.agentChannel == "A1") {
ego.dialog.alert(`恭喜您已完成報聘文件遞交,審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷<br/>5. 自費參加團體保險申請書<br/>6. 報聘SR須另繳交行銷代表備忘錄、SR商品及法規課程訓練紀錄${"3" == this.userData.userBackground.genRegStatus ? "<br/>7. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);
} else {
if (this.userData.user.jobType == "A2S" ) {
ego.dialog.alert(`恭喜您已完成報聘文件遞交,審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷${"3" == this.userData.userBackground.genRegStatus ? "<br/>5. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);
}
else {
ego.dialog.alert(`恭喜您已完成報聘文件遞交,審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷<br/>5. 公費團體眷屬加入表(聘僱合約)${"3" == this.userData.userBackground.genRegStatus ? "<br/>6. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);
}
}
}
}
}
});
</script>
<script type="text/javascript" th:inline="javascript" layout:fragment="contentScript"

		th:object="${@sessionAccessor.user}">



		var app = new Vue({

			el: "#app",

			data: {

				// 準增員資料

				userData: {

					isNew: true,

					/* 文件上傳 */

					uploadDefines: [

						/*

						{

							jobType: "A1",

							fileType: "Head2inch",

							fileDesc: "二吋彩色大頭貼",

							fileHead: "二吋彩色大頭貼",

							uploaded: 1,

							alertMark: null,

							notAlertMarked: false,

							alertMarked: false

						}

						*/

					],

					/* 基本資料 */

					// 準增員主檔

					user: {

						// 使用者系統編號 Integer

						sysCode: "",

						// 身分證字號/帳號

						userId: "",

						// 姓名

						userName: "",

						// 羅馬拚音

						romanName: "",

						// 電子郵件

						email: "",

						// 手機號碼

						mobilePhone: "",

						// 出生日期 yyyyMMdd

						birthday: "",

						// 直屬主管登錄證號

						dsRegisterId: "",

						// 直屬主管

						dsAgent: {

							userId: "",

							userName: "",

							agentCode: "",

							registerNo: "",

							lineCode: "",

							agentChannel: "",

							mobilePhone: "",

							email: "",

							branchCode: "",

							branchName: "",

							branchManager: "",

							branchManagerEmail: "",

							branchManagerMobile: "",

							branchAssistant: "",

							centerCode: "",

							centerName: "",

							centerManager: "",

							centerManagerEmail: "",

							centerManagerMobile: "",

							levelCode: "",

							levelTitle: "",

							agentStatusCode: "",

							agentStatus: "",

							leaveDate: "",

							aguiCenter: "",

							aguiManager: "",

							aguiCenterName: "",

							createTime: ""

						},

						// 推薦人登錄證號

						refRegisterId: "",

						// 推薦人

						refAgent: {

							userId: "",

							userName: "",

							agentCode: "",

							registerNo: "",

							lineCode: "",

							agentChannel: "",

							mobilePhone: "",

							email: "",

							branchCode: "",

							branchName: "",

							branchManager: "",

							branchManagerEmail: "",

							branchManagerMobile: "",

							branchAssistant: "",

							centerCode: "",

							centerName: "",

							centerManager: "",

							centerManagerEmail: "",

							centerManagerMobile: "",

							levelCode: "",

							levelTitle: "",

							agentStatusCode: "",

							agentStatus: "",

							leaveDate: "",

							aguiCenter: "",

							aguiManager: "",

							aguiCenterName: "",

							createTime: ""

						},

						// 通訊處代號

						commCode: "",

						// 通訊處

						commUnit: {

							agentChannel: "",

							commCode: "",

							commName: "",

							areaCenter: {

								agentChannel: "",

								centerCode: "",

								centerName: "",

								isDelete: false

							},

							assistant: {

								employeeNo: "",

								employeeName: "",

								enableSendSms: false,

								enableSendEmail: false,

								email: "",

								mobilePhone: "",

								modifyTime: ""

							},

							isDelete: false

						},

						// 職務代碼

						jobId: "",

						// 職務類別

						jobType: "",

						// 新增時間 yyyy-MM-dd'T'HH:mm:ss

						createTime: "",

						// 修改時間 yyyy-MM-dd'T'HH:mm:ss

						modifyTime: "",

						// 狀態

						status: "",

						// 是否結案

						isClose: false,

						// 是否已簽署聲明事項

						agreementSigned: false

					},

					// 準增員詳細資料檔

					userDetail: {

						// 準增員主要key值

						sysCode: "",

						// 新增時間 yyyy-MM-dd'T'HH:mm:ss

						addDate: "",

						// 更新時間 yyyy-MM-dd'T'HH:mm:ss

						updDate: "",

						// 

						enName: "",

						// 英文姓名

						eegName: "",

						// 報聘單位/推薦人/增員者

						myReferrer: "",

						// 同業經歷

						mySameExperience: "",

						// 是否有親屬在本公司任職

						isWorkHere: "",

						// Line ID

						lineID: "",

						// 性別

						sex: "",

						// 婚姻

						marry: "",

						// 血型

						blood: "",

						// 子女人數

						brood: "",

						// 住家電話

						tel1: "",

						// 行動電話

						tel2: "",

						// 電子郵件

						mail: "",

						// 原住民姓名

						romanName: "",

						// 緊急聯絡人姓名

						criName: "",

						// 緊急聯絡人關係 0:配偶 1:子女 2:父母 3:兄弟姐妹 4:朋友 5:其他

						criRel: "",

						// 緊急聯絡人電話

						criTel: "",

						// 學歷 0:其他 1:研究所 2:大學 3:專科 4:高中/職 5:國中 6:小學

						degree: "",

						// 最高學歷學校名稱

						school: "",

						// 科系

						major: "",

						// 畢業 0:畢業 1:肄業 2:其他

						grade: "",

						// 學校社團經驗 0:無 1:有

						asso: "",

						// 學校社團擔任幹部名稱

						assoName: "",

						// 公司名稱1

						com1: "",

						// 任職期間年(起)

						fdateY1: "",

						// 任職期間月(起)

						fdateM1: "",

						// 任職期間年(迄)

						tdateY1: "",

						// 任職期間月(迄)

						tdateM1: "",

						// 年資 ex:1.2(年)

						expt1: "",

						// 職稱

						title1: "",

						// 工作屬性 0:業務性 1:非業務性

						property1: "",

						// 年收入 萬元

						income1: "",

						// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業

						industry1: "",

						// 公司名稱2

						com2: "",

						// 任職期間年(起)

						fdateY2: "",

						// 任職期間月(起)

						fdateM2: "",

						// 任職期間年(迄)

						tdateY2: "",

						// 任職期間月(迄)

						tdateM2: "",

						// 年資 ex:1.2(年)

						expt2: "",

						// 職稱

						title2: "",

						// 工作屬性 0:業務性 1:非業務性

						property2: "",

						// 年收入 萬元

						income2: "",

						// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業

						industry2: "",

						// 公司名稱3

						com3: "",

						// 任職期間年(起)

						fdateY3: "",

						// 任職期間月(起)

						fdateM3: "",

						// 任職期間年(迄)

						tdateY3: "",

						// 任職期間月(迄)

						tdateM3: "",

						// 年資 ex:1.2(年)

						expt3: "",

						// 職稱

						title3: "",

						// 工作屬性 0:業務性 1:非業務性

						property3: "",

						// 年收入 萬元

						income3: "",

						// 行業別 0:保險業 1:金融業 2:醫療業 3:其他行業

						industry3: "",

						// 配偶職業

						partnerJob: "",

						// 壽險證照

						cert1: "",

						// 產險證照

						cert2: "",

						// 投資型證照

						cert3: "",

						// 配偶其他

						certElse: "",

						// 外幣證照

						cert4: "",

						// 身份證字號

						pid: "",

						// 戶籍地址

						addr1: "",

						// 戶籍地址-郵遞區號

						addr1PostalCode: "",

						// 戶籍地址-縣市

						addr1City: "",

						// 戶籍地址-鄉鎮市區

						addr1Towns: "",

						// 戶籍地址-路/段/道/街/村/里

						addr1Village: "",

						// 戶籍地址-鄰

						addr1RoadStreet: "",

						// 戶籍地址-巷

						addr1Lane: "",

						// 戶籍地址-弄

						addr1Alley: "",

						// 戶籍地址-衖

						addr1Section: "",

						// 戶籍地址-號

						addr1Number: "",

						// 戶籍地址-樓

						addr1Floor: "",

						// 戶籍地址-備註

						addr1Remark: "",

						// 通訊地址

						addr2: "",

						// 通訊地址-郵遞區號

						addr2PostalCode: "",

						// 通訊地址-縣市

						addr2City: "",

						// 通訊地址-鄉鎮市區

						addr2Towns: "",

						// 通訊地址-路/段/道/街/村/里

						addr2Village: "",

						// 通訊地址-鄰

						addr2RoadStreet: "",

						// 通訊地址-巷

						addr2Lane: "",

						// 通訊地址-弄

						addr2Alley: "",

						// 通訊地址-衖

						addr2Section: "",

						// 通訊地址-號

						addr2Number: "",

						// 通訊地址-樓

						addr2Floor: "",

						// 通訊地址-備註

						addr2Remark: "",

						// 兵役調查

						army: "",

						// 中信銀台幣帳務-分行名稱

						ctbcAccountBranch: "",

						// 中信銀台幣帳戶-帳號號碼

						ctbcAccountAccountNumber: "",

						// 是否有其他工作經歷 YN

						workOther: "",

						// 是否擔任過業務人員

						usedtobeAgent: "",

						// 是否曾任職本公司業務員(包含台灣/宏利/大都會人壽)

						usedtobeAgentTW: ""

					},

					/* 學經歷 */

					// 工作經驗

					userWorks: [

						/*

						{

							// 流水號

							seq: Integer,

							// 準增員主要key值

							sysCode: Integer,

							// 公司名稱

							companyName: String,

							// 工作期間-起 YYYY-MM-DD

							workStartDate: String,

							// 工作期間-迄 YYYY-MM-DD

							workEndDate: String,

							// 通訊處名稱-非必填

							branchName: String

						}

						*/

					],

					// 其他工作經歷

					userWorkOthers: [

						/*

						{

							// 流水號

							seq: Integer,

							// 準增員主要key值

							sysCode: Integer,

							// 公司名稱

							companyName: String,

							// 工作期間-起 YYYY-MM-DD

							workStartDate: String,

							// 工作期間-迄 YYYY-MM-DD

							workEndDate: String,

							// 職稱

							title: String,

							// 行業別

							jobkind: String,

							// 工作內容

							jobDesc: String

						}

						*/

					],

					/* 背景聲明 */

					userBackground: {

						// 準增員唯一值

						sysCode: "",

						// 信用報告分數 Integer

						creditRptDegree: "",

						// 信用報告日期 yyyy-MM-dd'T'HH:mm:ss

						creditRptDate: "",

						// 人身保險合格證號

						lifeRegisterId: "",

						// 人身保險登錄狀況 Integer

						lifeRegStatus: "",

						// 金融常識合格證號

						fincRegisterId: "",

						// 財產登錄狀況(TableL SystemCodeDef,CodeType:GenRegStatus)

						genRegStatus: "",

						// 是否有親屬在本公司擔任業務員YN

						parentAgent: "",

						// 親屬姓名

						parentName: "",

						// 親屬關係(TableL SystemCodeDef,CodeType:ParentReal)

						parentRela: "",

						// 業務人員管理規則懲處紀錄(Y: 有 N:無)

						punishHistory: "",

						// 業務人員管理規則懲處紀錄詳細說明

						punishHisDetail: "",

						// 是否有犯罪紀錄(Y: 有 N:無)

						crimeHistory: "",

						// 犯罪紀錄詳細說明

						crimeDetail: "",

						// 公會懲處紀錄 (Y: 有 N:無)

						liaPunishHistory: "",

						// 公會懲處紀錄詳細說明

						liaPunishHisDetail: ""

					}

				},

// 				hasWorkExp: false,

// 				hasWorkOtherExp: false,

				alert: {

					form01: false,

					form02: false,

					form03: false,

					form04: false

				},

				link: {

					// 壽險公會連結

					lifeOrg: "http://public.liaroc.org.tw/lia-public/indexUsr.jsp",

					// 產險公會連結

					generalOrg: "http://salesinfo.nlia.org.tw/index.php"

				}

			},

			beforeMount() {

				// 準增員資料

				var vm = this;

				var userData = /*[[${@requestAccessor.getAttribute(T(com.taiwanlife.recruit.enums.ModelKey).USER_DATA)}]]*/ {};

				// 初始值

				var nestedEmptyValue = function(value) {

					if ($.isArray(value)) {

						for (var val of value) {

							if ("string" === typeof(val)) {

								val = val || "";

							} else {

								nestedEmptyValue(val);

							}

						}

					} else if ($.isPlainObject(value)) {

						for (var key in value) {

							if ("string" === typeof(value[key]) || undefined == value[key] || null == value[key]) {

								value[key] = value[key] || "";

							} else {

								nestedEmptyValue(value[key]);

							}

						}

					}

				};

				nestedEmptyValue(userData);

				this.userData = $.extend(true, {}, this.userData, userData);

// 				if (this.userData.userWorks && this.userData.userWorks.length > 0) {

// 					this.hasWorkExp = true;

// 				}

				if (!this.userData.userDetail.workOther) {

					if (this.userData.userWorkOthers && this.userData.userWorkOthers.length > 0) {

						this.userData.userDetail.workOther = "Y";

					} else {

						this.userData.userDetail.workOther = "N";

					}

				}

// 				this.hasWorkOtherExp = "Y" == this.userData.userDetail.workOther;

			},

			mounted() {

				setTab("tablist");

				this.init();

			},

			methods: {

				init() {

					this.initRule();

					if (false === this.userData.isNew) {

						this.showTabAlert();

					}

				},

				initRule() {

					var errorPlacement = function (error, element) {

						var ename = element.attr("name");

						if (/^uploadFile/.test(ename)) {

							$(element).closest("table").next().append(error);

						} else if (/^addr/.test(ename) || /History/.test(ename) || /^parent[Name|Rela]/.test(ename)) {

							$(element).closest("td").parent().children().last().append(error);

						} else {

							$(element).parent().children().last().after(error);

						}

					};

					var defaultSettings = {

						errorElement: "div",

						errorPlacement: errorPlacement

					}

					var form01Settings = {

						rules: {},

						messages: {}

					};

					for (var index in this.userData.uploadDefines) {

						if (this.userData.uploadDefines[index].mustFlag == "Y") {

							form01Settings.rules[`uploadFile${parseInt(index) + 1}`] = {

									required: {

										depends: function(element) {

											return "0" == $(element).prev().val();

										}

									}

								};

								form01Settings.messages[`uploadFile${parseInt(index) + 1}`] = { required: `請上傳${this.userData.uploadDefines[index].fileHead}${"Head2inch" == this.userData.uploadDefines[index].fileType ? "(上傳格式限 JPG)" : ""}` };

							

						}

					}

					$("#form01").validate($.extend(true, {}, defaultSettings, form01Settings));

					$("#form02").validate($.extend(true, {}, defaultSettings, {

						rules: {

							userName: {

								required: true,

								maxlength: 200

							},

							romanName: {

								maxlength: 200,

								format: ego.validator.pattern.romanName

							},

							birthday: {

								required: true,

								maxlength: 8

							},

							mobilePhone: {

								maxlength: 20,

								required: true,

								mobilePhone: true

							},

							tel1: {

								maxlength: 20,

								format: ego.validator.pattern.telephone

							},

							email: {

								required: true,

								email: true,

								blockEmail: true,

								maxlength: 50

							},

							army: {

								required: true

							},

							ctbcAccountBranch: {

								required: true

							},

							ctbcAccountAccountNumber: {

								required: true,

								digits: true,

								format: ego.validator.pattern.accountNumber

							}

						}, messages: {

							userName: {

								required: "請輸入姓名",

							},

							romanName: {

								format: "原住民姓名不符合條件，請重新輸入",

							},

							birthday: {

								required: "請選擇出生年月日"

							},

							mobilePhone: {

								required: "請輸入手機號碼",

								mobilePhone: "手機號碼不符合條件，請重新輸入",

							},

							tel1: {

								format: "住家電話不符合條件，請重新輸入"

							},

							email: {

								required: "請輸入電子郵件",

								email: "電子郵件不符合條件，請重新輸入"

							},

							army: {

								required: "請選擇兵役調查",

							},

							ctbcAccountBranch: {

								required: "請輸入中信銀台幣銀行帳戶-分行",

							},

							ctbcAccountAccountNumber: {

								required: "請輸入中信銀台幣銀行帳戶-帳號",

								digits: "中信銀台幣銀行帳戶-帳號不符合條件，請重新輸入",

								format: "中信銀台幣銀行帳戶-帳號不符合條件，請重新輸入"

							}

						}

					}));

					$("#form04").validate($.extend(true, {}, defaultSettings, {

						rules: {

							creditRptDegree: {

								required: true,

								creditRptDegree: true

							},

							creditRptDate: {

								required: true

							},

							lifeRegisterId: {

								required: true,

								format: ego.validator.pattern.lifeRegisterId

							},

							lifeRegStatus: {

								required: true

							},

							genRegStatus: {

								required: true

							},

							parentName: {

								required: {

									depends: function(element) {

										return "Y" == $("input[name=parentAgent]:checked").val();

									}

								}

							},

							parentRela: {

								required: {

									depends: function(element) {

										return "Y" == $("input[name=parentAgent]:checked").val();

									}

								}

							},

							punishHistory: {

								required: true

							},

							punishHisDetail: {

								required: {

									depends: function(element) {

										return "Y" == $("input[name=punishHistory]:checked").val();

									}

								}

							},

							liaPunishHistory: {

								required: true

							},

							liaPunishHisDetail: {

								required: {

									depends: function(element) {

										return "Y" == $("input[name=liaPunishHistory]:checked").val();

									}

								}

							},

							crimeHistory: {

								required: true

							},

							crimeDetail: {

								required: {

									depends: function(element) {

										return "Y" == $("input[name=crimeHistory]:checked").val();

									}

								}

							}

						}, messages: {

							creditRptDegree: {

								required: "請輸入信用報告分數或無法評分",

								creditRptDegree: "請輪入分數或無法評分"

							},

							creditRptDate: {

								required: "請選擇信用報告日期"

							},

							lifeRegisterId: {

								required: "請輸入人身保險合格證號"

							},

							lifeRegStatus: {

								required: "請勾選人身保險登錄狀況"

							},

							genRegStatus: {

								required: "請勾選財產保險登錄狀況"

							},

							parentName: {

								required: "請輸入親屬姓名"

							},

							parentRela: {

								required: "請選擇親屬關係"

							},

							punishHistory: {

								required: "請勾選是否曾違反業務人員管理規則而受懲處紀錄"

							},

							punishHisDetail: {

								required: "請輸入受懲處紀錄詳細說明"

							},

							liaPunishHistory: {

								required: "請勾選是否曾受公會懲處紀錄"

							},

							liaPunishHisDetail: {

								required: "請輸入公會懲處紀錄詳細說明"

							},

							crimeHistory: {

								required: "請勾選是否有刑事犯罪紀錄"

							},

							crimeDetail: {

								required: "請輸入刑事犯罪紀錄詳細說明"

							}

						}

					}));

				},

				showTabAlert() {

					for (var form in this.alert) {

						this.alert[`${form}`] = !$(`#${form}`).valid();

					}

				},

// 				generateKey(key, index) {

// 					if (index || $.isNumeric(index)) {

// 						return `${key}${index + 1}`;

// 					}

// 					return key;

// 				},

				handleCreditRptDegree(event) {

					if (/^0/.test(event.target.value)) {

						this.userData.userBackground.creditRptDegree = event.target.value.substring(1);

					}

				},

				handleDate(target, date) {

					let form = $(target).closest("form").attr("id");

					let element = $(target).attr("id");

					switch (element) {

						case "birthday":

							this.userData.user.birthday = date;

							break;

						case "creditRptDate":

							this.userData.userBackground.creditRptDate = date;

							break;

						default:

							let index = element.substr(-1);

							let work = this.userData[element.split('_')[0]][index];

							if (!work){

								work = {};

								this.userData[element.split('_')[0]][index] = work;

							}

							work[element.split('_')[1]] = date;

							if ($(target).prevAll('input.hasMonthpicker')) {

								$(target).prevAll('input.hasMonthpicker').monthpicker("option", "maxDate", date);

							}

							if ($(target).nextAll('input.hasMonthpicker')) {

								$(target).nextAll('input.hasMonthpicker').monthpicker("option", "minDate", date);

							}

							break;

					}

				},

				handleDependency(event) {

					var form = $(event.target).closest("form").attr("id");

					var elements = Array.prototype.slice.call(arguments, 1)

					elements.forEach(function(item, index) {

						$(`#${form}`).validate().element(`#${item}`);

					});

				},

				handleChange(e) {

					let formId = $(e.target).closest("form").attr("id");

					let el = e.target;

					this.$nextTick(() => {

						if (el) {

					    	$(`#${formId}`).validate().element(el);

					    }

					});

				},

				handleAddress(e){

					let form = $(e.target).closest("form").attr("id");

					let element = $(e.target).attr("id");

					if (/\d/g.test(e.target.value)){

						let tempStr = '';

						for(let i=0;i<e.target.value.toString().length;i++){

							let numCode = e.target.value.toString().charCodeAt(i);

							if (numCode <= 0x007E && numCode >= 0x0021){

								numCode += 0xFEE0;

							}

							tempStr += String.fromCharCode(numCode);

						}

						e.target.value = tempStr;

					}

					this.userData.userDetail[element] = e.target.value;

					this.$nextTick(()=>$(`#${form}`).validate().element(`#${element}`));

				},

				handleWork(event){

					let element = event.target.id;

					let index = element.substr(-1);

					let work = this.userData[element.split('_')[0]][index];

					if (!work){

						work = {};

						this.userData[element.split('_')[0]][index] = work;

					}

					work[element.split('_')[1]] = event.target.value;

				},

				focusoutName(event) {

					let formId = $(event.target).closest("form").attr("id");

					let el = event.target;

					switch (event.target.id) {

						case 'userName':

					    	this.userData.user.userName = event.target.value;

					    	break;

					    case 'romanName':

					    	this.userData.user.romanName = event.target.value;

					    	break;

					    case 'criName':

					    	this.userData.userDetail.criName = event.target.value;

					    	break;

					}

					this.$nextTick(() => {

						if (el) {

					    	$(`#${formId}`).validate().element(el);

					    }

					});

				},

				save(event) {

					// 暫存

					this.showTabAlert();

					if (!ego.ajax.updateUserDataTemp(this.userData)) {

						ego.dialog.error("暫存失敗，請稍候再試", window.location.href);

					} else {

						ego.dialog.alert("暫存成功", window.location.href);

					}

				},

				handleFile(target, status) {

					$(target).closest("form").validate().element(`#${$(target).attr("id")}`);

				},

				apply(event) {

					this.showTabAlert();

					for (var form in this.alert) {

						if (!$(`#${form}`).valid()) {

							ego.dialog.error("請確認報聘資料填寫完整，再行遞交申請。");

							return;

						}

					}

					if (!ego.ajax.updateUserDataTemp(this.userData)) { // 暫存

						ego.dialog.error("遞交申請失敗，請稍候再試", window.location.href);

					} else if (!ego.ajax.applyUserData(this.userData.user.sysCode)) { // 遞交申請

						ego.dialog.error("遞交申請失敗，請稍候再試", window.location.href);

					} else {

						if (this.userData.user.commUnit.agentChannel == "A1") {

							ego.dialog.alert(`恭喜您已完成報聘文件遞交，審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷<br/>5. 自費參加團體保險申請書<br/>6. 報聘SR須另繳交行銷代表備忘錄、SR商品及法規課程訓練紀錄${"3" == this.userData.userBackground.genRegStatus ? "<br/>7. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);							

						} else {

							if (this.userData.user.jobType == "A2S" ) {

								ego.dialog.alert(`恭喜您已完成報聘文件遞交，審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷${"3" == this.userData.userBackground.genRegStatus ? "<br/>5. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);

							}

							else {

								ego.dialog.alert(`恭喜您已完成報聘文件遞交，審核結果將會另行通知。 <br/><br/>以下正本文件請您交給各地區行政助理。<br/>1. 合約書<br/>2. 聯徵個人信用報告<br/>3. 二吋彩色照片1張<br/>4. 信用卡共銷承諾聲明書及試卷<br/>5. 公費團體眷屬加入表(聘僱合約)${"3" == this.userData.userBackground.genRegStatus ? "<br/>6. 人身保險業務員登錄申請書正本" : ""}`, url.user.portal);	

							}

						}

					}

				}

			}

		});

	</script>
