目前格式:HTML/XML
```javascript
// Vue 實例初始化
var app = new Vue({
// 掛載到 <div id="app"> ...</div>
el: "#app",
// 資料模型
data: {
user: {
// 使用者 ID: 依 userType 決定要顯示 agentCode 或 userId
userId: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? agentCode : userId}]],
// 業務員專屬註冊號
registerNo: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? registerNo : ""}]],
// 使用者類型代碼
userType: [[*{T(com.taiwanlife.recruit.enums.UserType).valueOf(userType).code}]],
// 類型名稱
userTypeName: [[*{userType.name()}]],
// 業務員通路
agentChannel: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? agentChannel : ""}]],
// 內勤角色類型
roleType: [[*{T(com.taiwanlife.recruit.enums.UserType).STAFF == userType ? roleType : ""}]],
},
// 下拉清單資料
areaCenters: [], // 區域中心
commUnits: [], // 通訊處
substituteList: [], // 代理人清單
// 時分陣列 (用於代理人時間選擇)
hour: [],
minute: [],
// 查詢條件
query: {
areaCenter: "",
commUnit: "",
recruitName: "",
recruitId: "",
startCreateDate: "",
endCreateDate: ""
},
// 代理人查詢條件
substituteQuery: {
centerCode: "",
agentCode: "",
userName: "",
substituteAgentCode: "",
substituteName: "",
startSubstituteDate: "",
startSubstituteHour: "",
startSubstituteMinute: "",
endSubstituteDate: "",
endSubstituteHour: "",
endSubstituteMinute: "",
// 預設 N,否則按鈕不顯示
substituteStatus: "N"
},
// 表格與列表資料
users: [],
table: {
// 定義欄位屬性: 可否排序、欄位 key、標題、排序方向
columns: [
{ sortable: true, field: "sysCode", title: "編號", direction: "" },
{ sortable: true, field: "createTime", title: "帳號申請日", direction: "", defaultSort: { direction: "desc" } },
{ sortable: true, field: "userName", title: "準增員", direction: "" },
{ sortable: true, field: "statusText", title: "目前進度", direction: "" },
{ sortable: true, field: "statusDocText", title: "報聘狀態", direction: "" },
{ sortable: true, field: "jobType", title: "類別", direction: "" },
{ sortable: true, field: "jobId", title: "擬任用職稱", direction: "" },
{ sortable: true, field: "commCode", title: "通訊處", direction: "" },
{ sortable: true, field: "dsRegisterId", title: "直屬主管", direction: "" },
{ sortable: true, field: "refRegisterId", title: "推薦人", direction: "" },
{ sortable: true, field: "buttonText", title: "待工作事項", direction: "" }
]
},
// 單筆流程資料,用於顯示進度
recruit: {
applyDocDate: "",
approveWindowCheckDate: "",
assistantCheckDate: "",
cbsAreaCenterManagerDate: "",
cbsBranchManagerDate: "",
cbsTestDate: "",
dsRegisterDate: "",
elearningStartaDate: "",
guildClassStatus: "",
guildExamStatus: "",
jobTypeDate: "",
preJobId: "",
preJobIdDate: "",
registerDate: "",
sysCode: "",
totalFinishDate: "",
userId: "",
userName: ""
},
// 步驟圖陣列,每步驟有狀態 status
charts: [
{ step: 1, title: "帳號申請", field: "registerDate", status: 0 },
{ step: 2, title: "直屬主管<br>帳號認證", field: "dsRegisterDate", status: 0 },
{ step: 3, title: "CBS<br>適性測驗", field: "cbsTestDate", status: 0 },
{ step: 4, title: "處經理<br>CBS面談", field: "cbsBranchManagerDate", status: 0 },
{ step: 5, title: "區域中心<br>CBS面談", field: "cbsAreaCenterManagerDate", status: 0,
subSteps: [
{ step: 1, title: "A. 公輔班 <br><span>(上課狀態)</span>", field: "guildClassStatus", status: 0 },
{ step: 2, title: "B. 公會考試<br><span>(報考狀態)</span>", field: "guildExamStatus", status: 0 }
]
},
{ step: 6, title: "處經理<br>職級初審", field: "jobTypeDate", status: 0 },
{ step: 7, title: "報聘文件<br>填寫", field: "applyDocDate", status: 0 },
{ step: 8, title: "處經理<br>職級複審", field: "preJobIdDate", status: 0 },
{ step: 9, title: "報聘文件<br>審核", field: "assistantCheckDate", status: 0 }
]
},
// 元件掛載前 (未用)
beforeMount() {},
// 掛載後呼叫 init
// 掛載後呼叫 init,此時 DOM 已準備好,可安全發起 AJAX 請求
mounted() {
// 在此階段呼叫 init(),開始第一次 AJAX 請求
this.init();
},
// 顯示用過濾器
filters: {
// 空值顯示「-」
formatEmpty(value, defaultValue) {
return value ? value : (defaultValue ? defaultValue : "-");
},
// 呼叫 ego.format.date 格式化
formatDate(value, delim) {
if (!value) return value;
return ego.format.date(value, delim);
},
// 按鈕文字
formatAction(buttonType) {
switch (buttonType) {
case 0: return "認證";
case 1: return "面談";
case 2: return "檢查";
case 3: return "簽核";
case 4: return "初審";
case 5: return "複審";
}
return "";
}
},
// 計算屬性
computed: {
// 取得預設排序欄
defaultColumn() {
var cols = this.table.columns.filter(c => c.defaultSort);
return cols.length ? cols[0] : this.table.columns[0];
},
// 目前排序欄位
sortedColumn() {
var col = this.table.columns.find(c => c.direction);
if (!col) {
col = this.defaultColumn;
col.direction = col.defaultSort.direction;
}
return col;
},
// 傳回排序後的 users
sortedUsers() {
var col = this.sortedColumn;
var data = this.users.concat().sort((a, b) => {
var v1 = a[col.field], v2 = b[col.field];
if (v1 == v2) return 0;
if (v1 == null) return 1;
if (v2 == null) return -1;
return v1 > v2 ? 1 : -1;
});
return col.direction === "desc" ? data.reverse() : data;
}
},
// 方法
methods: {
// 初始化:載入區域中心並搜尋
init() {
this.areaCenters = ego.ajax.getAreaCenters(this.user.agentChannel);
this.search();
},
// 區域中心變動時,重載通訊處
changeAreaCenter() {
this.query.commUnit = "";
if (this.query.areaCenter) {
this.commUnits = ego.ajax.getCommUnits(
this.query.areaCenter.agentChannel,
this.query.areaCenter.centerCode
);
} else {
this.commUnits = [];
}
},
// 處理日期選擇
handleDate(target, date) {
var id = $(target).attr("id");
this.query[id] = date;
// 同步限制前後日期
$(target).prev().datepicker("option", "maxDate", date);
$(target).next().datepicker("option", "minDate", date);
},
// 其他方法略...
// 主搜尋,並處理按鈕顯示邏輯
search() {
this.resetTable();
this.$nextTick(() => {
this.users = ego.ajax.queryDashBoard(this.getQueryModel());
// 依 buttonType/status 判斷 showButton, link, text
this.users.forEach((user, idx) => {
// ... 複雜邏輯,請參考原 code ...
});
});
},
// 重設表格
resetTable() {
this.users = [];
this.table.columns.forEach(c => c.direction = c.defaultSort ? c.defaultSort.direction : "");
}
// 其他 methods 可仿此添加註解
}
});
```
```javascript

// Vue 實例初始化

var app = new Vue({

  // 掛載到 <div id="app"> ...</div>

  el: "#app",



  // 資料模型

  data: {

    user: {

      // 使用者 ID: 依 userType 決定要顯示 agentCode 或 userId

      userId: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? agentCode : userId}]],

      // 業務員專屬註冊號

      registerNo: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? registerNo : ""}]],

      // 使用者類型代碼

      userType: [[*{T(com.taiwanlife.recruit.enums.UserType).valueOf(userType).code}]],

      // 類型名稱

      userTypeName: [[*{userType.name()}]],

      // 業務員通路

      agentChannel: [[*{T(com.taiwanlife.recruit.enums.UserType).AGENT == userType ? agentChannel : ""}]],

      // 內勤角色類型

      roleType: [[*{T(com.taiwanlife.recruit.enums.UserType).STAFF == userType ? roleType : ""}]],

    },



    // 下拉清單資料

    areaCenters: [],       // 區域中心

    commUnits: [],         // 通訊處

    substituteList: [],    // 代理人清單



    // 時分陣列 (用於代理人時間選擇)

    hour: [],

    minute: [],



    // 查詢條件

    query: {

      areaCenter: "",

      commUnit: "",

      recruitName: "",

      recruitId: "",

      startCreateDate: "",

      endCreateDate: ""

    },



    // 代理人查詢條件

    substituteQuery: {

      centerCode: "",

      agentCode: "",

      userName: "",

      substituteAgentCode: "",

      substituteName: "",

      startSubstituteDate: "",

      startSubstituteHour: "",

      startSubstituteMinute: "",

      endSubstituteDate: "",

      endSubstituteHour: "",

      endSubstituteMinute: "",

      // 預設 N，否則按鈕不顯示

      substituteStatus: "N"

    },



    // 表格與列表資料

    users: [],

    table: {

      // 定義欄位屬性: 可否排序、欄位 key、標題、排序方向

      columns: [

        { sortable: true, field: "sysCode", title: "編號", direction: "" },

        { sortable: true, field: "createTime", title: "帳號申請日", direction: "", defaultSort: { direction: "desc" } },

        { sortable: true, field: "userName", title: "準增員", direction: "" },

        { sortable: true, field: "statusText", title: "目前進度", direction: "" },

        { sortable: true, field: "statusDocText", title: "報聘狀態", direction: "" },

        { sortable: true, field: "jobType", title: "類別", direction: "" },

        { sortable: true, field: "jobId", title: "擬任用職稱", direction: "" },

        { sortable: true, field: "commCode", title: "通訊處", direction: "" },

        { sortable: true, field: "dsRegisterId", title: "直屬主管", direction: "" },

        { sortable: true, field: "refRegisterId", title: "推薦人", direction: "" },

        { sortable: true, field: "buttonText", title: "待工作事項", direction: "" }

      ]

    },



    // 單筆流程資料，用於顯示進度

    recruit: {

      applyDocDate: "",

      approveWindowCheckDate: "",

      assistantCheckDate: "",

      cbsAreaCenterManagerDate: "",

      cbsBranchManagerDate: "",

      cbsTestDate: "",

      dsRegisterDate: "",

      elearningStartaDate: "",

      guildClassStatus: "",

      guildExamStatus: "",

      jobTypeDate: "",

      preJobId: "",

      preJobIdDate: "",

      registerDate: "",

      sysCode: "",

      totalFinishDate: "",

      userId: "",

      userName: ""

    },



    // 步驟圖陣列，每步驟有狀態 status

    charts: [

      { step: 1, title: "帳號申請", field: "registerDate", status: 0 },

      { step: 2, title: "直屬主管<br>帳號認證", field: "dsRegisterDate", status: 0 },

      { step: 3, title: "CBS<br>適性測驗", field: "cbsTestDate", status: 0 },

      { step: 4, title: "處經理<br>CBS面談", field: "cbsBranchManagerDate", status: 0 },

      { step: 5, title: "區域中心<br>CBS面談", field: "cbsAreaCenterManagerDate", status: 0,

        subSteps: [

          { step: 1, title: "A. 公輔班 <br><span>(上課狀態)</span>", field: "guildClassStatus", status: 0 },

          { step: 2, title: "B. 公會考試<br><span>(報考狀態)</span>", field: "guildExamStatus", status: 0 }

        ]

      },

      { step: 6, title: "處經理<br>職級初審", field: "jobTypeDate", status: 0 },

      { step: 7, title: "報聘文件<br>填寫", field: "applyDocDate", status: 0 },

      { step: 8, title: "處經理<br>職級複審", field: "preJobIdDate", status: 0 },

      { step: 9, title: "報聘文件<br>審核", field: "assistantCheckDate", status: 0 }

    ]

  },



  // 元件掛載前 (未用)

  beforeMount() {},



  // 掛載後呼叫 init

    // 掛載後呼叫 init，此時 DOM 已準備好，可安全發起 AJAX 請求

  mounted() {

    // 在此階段呼叫 init()，開始第一次 AJAX 請求

    this.init();

  },





  // 顯示用過濾器

  filters: {

    // 空值顯示「-」

    formatEmpty(value, defaultValue) {

      return value ? value : (defaultValue ? defaultValue : "-");

    },

    // 呼叫 ego.format.date 格式化

    formatDate(value, delim) {

      if (!value) return value;

      return ego.format.date(value, delim);

    },

    // 按鈕文字

    formatAction(buttonType) {

      switch (buttonType) {

        case 0: return "認證";

        case 1: return "面談";

        case 2: return "檢查";

        case 3: return "簽核";

        case 4: return "初審";

        case 5: return "複審";

      }

      return "";

    }

  },



  // 計算屬性

  computed: {

    // 取得預設排序欄

    defaultColumn() {

      var cols = this.table.columns.filter(c => c.defaultSort);

      return cols.length ? cols[0] : this.table.columns[0];

    },

    // 目前排序欄位

    sortedColumn() {

      var col = this.table.columns.find(c => c.direction);

      if (!col) {

        col = this.defaultColumn;

        col.direction = col.defaultSort.direction;

      }

      return col;

    },

    // 傳回排序後的 users

    sortedUsers() {

      var col = this.sortedColumn;

      var data = this.users.concat().sort((a, b) => {

        var v1 = a[col.field], v2 = b[col.field];

        if (v1 == v2) return 0;

        if (v1 == null) return 1;

        if (v2 == null) return -1;

        return v1 > v2 ? 1 : -1;

      });

      return col.direction === "desc" ? data.reverse() : data;

    }

  },



  // 方法

  methods: {

    // 初始化：載入區域中心並搜尋

    init() {

      this.areaCenters = ego.ajax.getAreaCenters(this.user.agentChannel);

      this.search();

    },

    // 區域中心變動時，重載通訊處

    changeAreaCenter() {

      this.query.commUnit = "";

      if (this.query.areaCenter) {

        this.commUnits = ego.ajax.getCommUnits(

          this.query.areaCenter.agentChannel,

          this.query.areaCenter.centerCode

        );

      } else {

        this.commUnits = [];

      }

    },

    // 處理日期選擇

    handleDate(target, date) {

      var id = $(target).attr("id");

      this.query[id] = date;

      // 同步限制前後日期

      $(target).prev().datepicker("option", "maxDate", date);

      $(target).next().datepicker("option", "minDate", date);

    },

    // 其他方法略...



    // 主搜尋，並處理按鈕顯示邏輯

    search() {

      this.resetTable();

      this.$nextTick(() => {

        this.users = ego.ajax.queryDashBoard(this.getQueryModel());

        // 依 buttonType/status 判斷 showButton, link, text

        this.users.forEach((user, idx) => {

          // ... 複雜邏輯，請參考原 code ...

        });

      });

    },

    // 重設表格

    resetTable() {

      this.users = [];

      this.table.columns.forEach(c => c.direction = c.defaultSort ? c.defaultSort.direction : "");

    }

    // 其他 methods 可仿此添加註解

  }

});

```
