返回列表 上一筆 下一筆

目前格式:HTML/XML

🧾 資料內容 (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 可仿此添加註解

  }

});

```

🔐 Base64 編碼內容

```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 可仿此添加註解

  }

});

```

返回列表 上一筆 下一筆