返回列表 上一筆 下一筆

目前格式:HTML/XML

🧾 資料內容 (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>

🔐 Base64 編碼內容

<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>

返回列表 上一筆 下一筆