2025年9月3日 星期三

V20305L-[上下層同時提料需求申請]鈕- PK_LIST –勾選資料傳至後端 - 全部匯出 - Email附檔 -New

 目的: V20305L-[上下層同時提料需求申請]

            - PK_LIST –勾選資料傳至後端-全部匯出- Email附檔

處理說明:

              1>勾選資料傳至後端
          for (var i = 0; i < CHK_PK_OBJ.PK_LIST.length; i++) {
                cur_rec = CHK_PK_OBJ.ALL_LIST[i];
                 Tmp_DataAry1.push(cur_rec);
           }

          let Tmp_DataString1 = JSON.stringify(Tmp_DataAry1);
          var np= {};
          np["DataString1"] = Tmp_DataString1;
           Tmp_url = '../../api/V20305LAPI/CHECK_EXIST_UPDOWN_LCN';
           Tmp_RtnStr = getUrlStr(Tmp_url, np, "檢核 [交修單號] 是否存存上下層提料件號");

              2>全部資料傳至後端
           for (var i = 0; i < Tmp_Grid.store.getCount(); i++) {
                 cur_rec = Tmp_Grid.store.getAt(i);
                 console.log("cur_rec :", cur_rec);
                 console.log("cur_rec.data :", cur_rec.data);
                 if (!(JSON.stringify(cur_rec.data) === '{}')) {
                        Tmp_DataAry2.push(cur_rec.data);
            }
           let Tmp_DataString2 = JSON.stringify(Tmp_DataAry2);  //子畫面所有資料

              3>Email 附檔 - 套表
                      套表檔案名稱(*.xlsx)和匯出檔案名稱(*_yyyyMMdd.xlsx)不可相同,
                       否則會Error      



1>*.js
1>>勾選資料傳至後端
var cur_rec;
let Tmp_DataAry1 = [];
var Tmp_DTSOR,Tmp_AMMNO;
var Tmp_Str;
for (var i = 0; i < CHK_PK_OBJ.PK_LIST.length; i++) {
     cur_rec = CHK_PK_OBJ.ALL_LIST[i];
     Tmp_AMMNO = cur_rec.AMMNO.toString();
     Tmp_DTSOR = cur_rec.DTSOR.toString();
     if (!(JSON.stringify(cur_rec) === '{}')) {
             Tmp_DataAry1.push(cur_rec);
}
}
//主畫面勾選資料
let Tmp_DataString1 = JSON.stringify(Tmp_DataAry1);
var np= {};
np["DataString1"] = Tmp_DataString1;

//新增 AMM_TLSAR & AMM_AR
//STEP2: 若 AMM_TLSAR & AMM_AR of FMNO 不存在, 則新增該檔案資料(AMM_TLSAR, AMM_AR)
Tmp_url = '../../api/V20305LAPI/CHECK_EXIST_UPDOWN_LCN';
Tmp_RtnStr = getUrlStr(Tmp_url, np, "檢核 [交修單號] 是否存存上下層提料件號");
if (!checkRtnOK(Tmp_RtnStr)) {
mywarnalert(Tmp_RtnStr);
return;
}


2>>全部資料傳至後端
function V20305L_OK() {
//STEP1 : 更新[上下層需求說明(AMM_UOCD.UDRQSN)]
var Tmp_Grid = Ext.getCmp('sub_Grid');
var cur_rec;
let Tmp_DataAry2 = []; //目前子畫面的資料,傳至後端
var Tmp_Str = "";
var Tmp_RtnMsg = "";
if (Tmp_Grid.store.length == 0) {
mywarnalert("目前無[上下層同時提料]資料,無法確認送出");
return;
}
//取得目前子畫面所有資料
for (var i = 0; i < Tmp_Grid.store.getCount(); i++) {
cur_rec = Tmp_Grid.store.getAt(i);
console.log("cur_rec :", cur_rec);
console.log("cur_rec.data :", cur_rec.data);
if (!(JSON.stringify(cur_rec.data) === '{}')) {
Tmp_DataAry2.push(cur_rec.data);
}
}
let Tmp_DataString2 = JSON.stringify(Tmp_DataAry2); //子畫面所有資料


var np = {};
np["DataString1"] = Tmp_DataString1; //主畫面勾選皫資料
np["UDRQSN"] = Ext.getCmp("sub_UPDOWN_DESCP").getValue();
np["STAUOCD"] = Ext.getCmp("s_STAUOCD").getValue(); //主畫面的[是否提料] - 過濾修件
//np["DataString1"] = Tmp_DataString1;
var Tmp_url = "../../api/V20305LAPI/UPDATE_UDRQSN";
Tmp_RtnMsg = getUrlStr(Tmp_url, np, "更新[上下層需求說明(AMM_UOCD.UDRQSN)]欄位值");
if (!checkRtnOK(Tmp_RtnMsg)) {
myalert(Tmp_RtnMsg);
return;
} // end of SelAllBtn_click


3>>Email - 套表
           string Tmp_FName = "V20305_上下層同時提料申請清單.xlsx";      //套表的檔案名稱 : 
            string documentPath = HttpContext.Current.Server.MapPath("~") + "document\\";
            string pathFName = documentPath + "V20305_上下層同時提料申請清單_" +DateTime.Now.ToString("yyyyMMdd") + ".xlsx";
            FileStream fs = null;
            Workbook wk = null;
            fs = myfunc.get_SS_FILES(Tmp_FName);
            wk = new Workbook();
            wk.LoadFromStream(fs);
            Worksheet ws1 = wk.Worksheets[0];//獲取第一個工作表            
            try
           {
                
                ws1.AllocatedRange.AutoFitColumns();
                wk.SaveToStream(stream, FileFormat.Version2007); 
                 wk.SaveToFile(pathFName, FileFormat.Version2007);

2025年9月1日 星期一

V20305M – [匯入PDM BOM檔]鈕 - Panel隱藏

 目的: V20305M – [匯入PDM BOM] - Panel隱藏

處理說明: 1>var cmp_sub_panel1 = get_cmp_panel1(200);
                                             cmp_sub_panel1.id = "sub_panel1";
                            2>Panel隱藏
                                    Ext.getCmp("sub_panel1").hide();


1>*.js
 var cmp_sub_panel1 = get_cmp_panel1(200);
    cmp_sub_panel1.id = "sub_panel1";
    var cmp_sub_PN = get_cmp_txt1('件號', 'sub_PN', 110, 120);
    var cmp_sub_EONO = get_cmp_txt1('ECNO', 'sub_EONO', 110, 100);
    var cmp_sub_CDCODE = get_cmp_txt1('情況碼', 'sub_CDCODE', 110, 100);
    cmp_sub_panel1.items.push(cmp_sub_PN, cmp_sub_EONO, cmp_sub_CDCODE);

win.show();
Ext.getCmp("sub_panel1").hide();