123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229 |
- /* ---------------------------------------------------------------------
-
- SMRSD00400_물품청구관리.xrw (SMRSD00400.xfm - JScript )
- - Version :
- 1) : Ver.1.00.01
- : Create By Francis Choi
- : 2015.05.02
- ---------------------------------------------------------------------- */
-
- var xAuth = !(checkAuth("X"));
- var pAuth = !(checkAuth("P"));
-
- var vPurcAuth = "1";
- var gInstcd = ""; // 기관코드
- var gReqdd = ""; // 청구일자
- var gReqdeptcd = ""; // 청구부서
- var gWorkflag = ""; // 작업구분
- var gReqpridflag = ""; // 청구주기구분
- var gPurcdeptflag = ""; //구매부서구분 : P
- var gPurcDeptCd = "";
- // --------------------------------------------------
- // Tree정보 가져오기
- // --------------------------------------------------
- function fInit() {
-
- // 화면 Control을 초기화한다
- fCheckAuth();
- fInitialize();
-
- return;
- }
-
- //------------------------------------------------
- // 화면 권한관리 CHECK
- //------------------------------------------------
- function fCheckAuth() {
- btn_search.disabled = !checkAuth("R") ;
- //btn_save.disabled = !checkAuth("X") ;
- //btn_prt.disabled = !checkAuth("P") ;
- }
-
- // --------------------------------------------------------------
- // 화면 open시와 초기화 버튼 클릭시 화면 초기화 기능을 수행한다.
- // --------------------------------------------------------------
- function fInitialize() {
- model.resetInstanceNode("/root/send");
-
- btn_save.disabled = true;
- btn_accept.disabled = true;
- ckb_accept.attribute("visibility") ="hidden";
- misfGridInit(grd_goodreq);
- misfMsterDetailSet(grd_goodreq,null, "TRRSD00411" ,"Y");
-
- //기관코드, 명 설정.
- opt_instcd.value = getUserInfo("dutplceinstcd");
- opt_instcdnm.value = getUserInfo("dutplceinstnm");
- model.setValue(opt_requser.attribute("ref" ), getUserInfo("userid"));
- model.setValue(opt_requsernm.attribute("ref"), getUserInfo("usernm"));
-
-
- rszfUserReqFlagList(cmb_reqflag,getUserInfo("dutplceinstcd"),model.getValue(opt_requser.attribute("ref")), "1", "S" ); // preqpgmgubun : '1' :구매재고
-
-
- model.setValue(ipt_reqdd.attribute("ref") , getCurrentDate());
- model.setValue(ipt_reqddnew.attribute("ref") , getCurrentDate());
-
- // 입력방식 선택 및 col 제어
- // 일반청구:청구량입력 , 정량보충:재고량입력
- model.setValue(rdo_inputmethod.attribute("ref") , "1");
-
- // grd_goodreq.colDisabled(grd_goodreq.colRef("stocqty")) = true;
- // grd_goodreq.colDisabled(grd_goodreq.colRef("reqqty" )) = false;
-
- if (cmb_workflag.length> 0) cmb_workflag.selectedindex= 0; // 작업구분
- grd_goodlist.fixedcellcheckbox(0,grd_goodlist.colRef("select"),false) = true;
- // if(cmb_bugtflag.length> 0) cmb_bugtflag.selectedindex= 0;
-
- grd_goodreq.explorerbar = "sortshow";
- // 해당 사용자의 청구&승인 목록을 가져오는 submit
- model.setValue("/root/send/reqpsn/instcd", opt_instcd.value );
- model.setValue("/root/send/reqpsn/emplno", opt_requser.value);
- submit("TRRSD00407");
- fReqdeptCopy();
-
- // misfComboComCdList('R0025', cmb_goodflag, "N"); //물품구분
-
- // fSetReqAuth(); // 청구권한설정 [20090129] YYJ fReqdeptCopy() 함수에서 호출 하기 때문에 제외 처리
- //부서가 구매팀인지 확인해서 구매팀일 경우 부서찾기 항목을 visibility true 아니면 false
- gPurcDeptCd = rszfGetPurcDeptCd( getUserInfo("dutplceinstcd")); //구매 부서코드
-
- gPurcdeptflag = "X" ; //구매부서구분 : P
- // gPurcdeptflag = (gPurcDeptCd == getUserInfo("dutplcecd"))? "P" : "X"; //구매부서구분 : P
- model.setValue("/root/send/goodlist/purcdeptflag", gPurcdeptflag); //구매부서구분 : P
-
- fSetTempDept(); //부서찾기 기능 설정(구매팀일경우에만)
- //fReqFlagCheck();
-
- model.refresh();
- }
-
- // -----------------------------------------------
- // 청구주기가 일청구이면 권한체크하지 않는다.
- // -----------------------------------------------
- function fSetReqAuth() {
-
- var vCheckFlag = 0;
- vCheckFlag = (model.getValue(opt_instcd.attribute("ref") ).length==0) ? 1 : vCheckFlag; // 기관코드
- vCheckFlag = (model.getValue(cmb_reqdeptcd.attribute("ref") ).length==0) ? 1 : vCheckFlag; // 청구부서
- vCheckFlag = (model.getValue(cmb_reqpridflag.attribute("ref")).length==0) ? 1 : vCheckFlag; // 청구주기
-
- //
- ckb_accept.value = "N"; // 동시승인
- btn_accept.disabled = true; // 동시승인
- ckb_accept.attribute("visibility") ="hidden" ; // 동시승인
- //
- if (vCheckFlag == 1) {
- btn_save.disabled = true; // 저장
- btn_excel.disabled = true; // 엑셀
- // btn_reqset.disabled = true; // 청구 Set 목록
-
- btn_insert.disabled = true; // 행추가
- btn_delete.disabled = true; // 행삭제
- btn_choice.disabled = true; // 승인전체/접수전체취소
- return;
- } else {
- btn_save.disabled = false; // 저장
- btn_excel.disabled = false; // 엑셀
-
- btn_insert.disabled = false; // 행추가
- btn_delete.disabled = false; // 행삭제
- btn_choice.disabled = false; // 승인전체/접수전체취소
- }
- // -----------------------------------------------
- // 청구주기가 일청구이면 권한체크하지 않는다.
- // 구매부서는 동시승인을 할 수 있게한다.
- // -----------------------------------------------
- if ((gPurcdeptflag == "P") ||
- (model.getValue(cmb_reqpridflag.attribute("ref")) == "1")) {
- ckb_accept.value = "Y";
- btn_accept.disabled = false;
- ckb_accept.attribute("visibility") = "visible" ;
- // rszfGetPurcReqFnlDeptcd(model.getValue(opt_instcd.attribute("ref")), model.getValue(cmb_reqflag.attribute("ref")) , model.getValue(cmb_reqdeptcd.attribute("ref")));
- } else {
- if (vPurcAuth == "2") { //1:청구자, 2:승인자
- btn_accept.disabled = false;
- ckb_accept.value = "Y";
- ckb_accept.attribute("visibility") = "visible" ;
- }
- }
-
- // 로그인자의 부서와 취합부서정보가 같으면 청구부서를 open한다.
- // if (model.getValue(cmb_reqdeptcd.attribute("ref")) == model.getValue(opt_reqfinaldept.attribute("ref"))) {
- // cmb_reqdeptcd.disabled=false;
- // }
-
- fDeptReqNoQuery(); // 청구부서별 청구번호를 조회한다
-
- model.refresh();
- }
-
- // -----------------------------------------------
- // 청구주기가 일청구이면 권한체크하지 않는다.
- // -----------------------------------------------
- function fSetReqAuth_bak() {
-
- var vCheckFlag = 0;
- vCheckFlag = (model.getValue(opt_instcd.attribute("ref") ).length==0) ? 1 : vCheckFlag; // 기관코드
- vCheckFlag = (model.getValue(cmb_reqdeptcd.attribute("ref") ).length==0) ? 1 : vCheckFlag; // 청구부서
- vCheckFlag = (model.getValue(cmb_reqpridflag.attribute("ref")).length==0) ? 1 : vCheckFlag; // 청구주기
-
- //
- ckb_accept.value = "N"; // 동시승인
- btn_accept.disabled = true; // 동시승인
- ckb_accept.attribute("visibility") ="hidden" ; // 동시승인
- //
- if (vCheckFlag == 1) {
- btn_save.disabled = true; // 저장
- btn_excel.disabled = true; // 엑셀
- // btn_reqset.disabled = true; // 청구 Set 목록
-
- btn_insert.disabled = true; // 행추가
- btn_delete.disabled = true; // 행삭제
- btn_choice.disabled = true; // 승인전체/접수전체취소
- ckb_accept.value = "N"; // 동시승인
- btn_accept.disabled = true; // 동시승인
- ckb_accept.attribute("visibility") ="hidden" ; // 동시승인
- return;
- } else {
- btn_save.disabled = false; // 저장
- btn_excel.disabled = false; // 엑셀
- // btn_reqset.disabled = false; // 청구 Set 목록
-
- btn_insert.disabled = false; // 행추가
- btn_delete.disabled = false; // 행삭제
- btn_choice.disabled = false; // 승인전체/접수전체취소
- }
-
- if (model.getValue(opt_instcd.attribute("ref") ).length==0) return; // 기관코드
- // if (model.getValue(cmb_reqflag.attribute("ref") ).length==0) return; // 청구구분
- if (model.getValue(cmb_reqdeptcd.attribute("ref") ).length==0) return; // 청구부서
- if (model.getValue(cmb_reqpridflag.attribute("ref")).length==0) return; // 청구주기
- // -----------------------------------------------
- // 청구주기가 일청구이면 권한체크하지 않는다.
- // -----------------------------------------------
- // if (gPurcdeptflag == "P" ) { //구매부서구분 : P
-
- btn_insert.disabled = false; // 행추가
- btn_delete.disabled = false; // 행삭제
- btn_choice.disabled = false; // 승인전체/접수전체취소
-
- btn_save.disabled = false; // 저장
- btn_excel.disabled = false; // 엑셀
-
- if (model.getValue(cmb_reqpridflag.attribute("ref")) == "1") {
-
- // rszfGetPurcReqFnlDeptcd(model.getValue(opt_instcd.attribute("ref")), model.getValue(cmb_reqflag.attribute("ref")) , model.getValue(cmb_reqdeptcd.attribute("ref")));
-
- btn_accept.disabled = false;
- ckb_accept.value = "Y"; // 동시승인여부
- ckb_accept.attribute("visibility") = "visible" ;
-
- } else {
- fPurcAuthInfo(); // 청구승인자 Check
- if (vPurcAuth == "2") { //1:청구자, 2:승인자
- btn_accept.disabled = false;
- ckb_accept.value = "Y";
- ckb_accept.attribute("visibility") = "visible" ;
- }
- }
-
- //
- if (gPurcdeptflag == "P") { //구매부서구분 : P
- btn_accept.disabled = false;
- ckb_accept.value = "Y";
- ckb_accept.attribute("visibility") = "visible" ;
- }
-
- // 로그인자의 부서와 취합부서정보가 같으면 청구부서를 open한다. 2007.09.27 HBH
- // if (model.getValue(cmb_reqdeptcd.attribute("ref")) == model.getValue(opt_reqfinaldept.attribute("ref"))) {
- // cmb_reqdeptcd.disabled=false;
- // }
- fDeptReqNoQuery(); // 청구부서별 청구번호를 조회한다
-
- model.refresh();
- }
-
- // --------------------------------------------------------------
- // 불출부서 청구마지막 일자를 불러온다.청구마감일자 조회
- // --------------------------------------------------------------
- function fLastDaySearch() {
- model.setValue("/root/send/lastdatesearch/instcd" , opt_instcd.value );
- model.setValue("/root/send/lastdatesearch/deldeptcd", cmb_reqdeptcd.value );
- // model.setValue("/root/send/lastdatesearch/deldeptcd", opt_reqfinaldept.value );
- model.setValue("/root/send/lastdatesearch/reqym" , ipt_reqdd.value.substr(0,6));
-
- submit("TRRSC01701"); // 청구마감일자 조회 purcbaseweb
- }
-
- // --------------------------------------------------------------
- // 청구일자가 불출부서의 청구마지막 일자안에 있는지 확인,
- // --------------------------------------------------------------
- function fLastDayCheck() {
-
- var fbool = false;
-
- if (ipt_todd.value != '') {
- if (ipt_reqdd.value > ipt_todd.value ) {
- fbool = true;
- }
- }
-
- return fbool;
- }
-
- // --------------------------------------------------------------
- // 기본자료 SET
- // --------------------------------------------------------------
- function fDefaultSetting(prow) {
-
- // --------------------------------------------------------
- // 일반청구 와 정량보충에 따라서 col을 control한다.
- // --------------------------------------------------------
- grd_goodreq.colDisabled(grd_goodreq.colRef("stocqty")) = false;
- grd_goodreq.colDisabled(grd_goodreq.colRef("reqqty")) = false;
-
- // if (model.getValue(rdo_inputmethod.attribute("ref"))=="1") {
- // grd_goodreq.colDisabled(grd_goodreq.colRef("stocqty")) = true;
- // grd_goodreq.colDisabled(grd_goodreq.colRef("reqqty")) = false;
- // } else {
- // grd_goodreq.colDisabled(grd_goodreq.colRef("stocqty")) = false;
- // grd_goodreq.colDisabled(grd_goodreq.colRef("reqqty")) = true;
- // }
-
- model.setValue(grd_goodreq.nodeset +"[" + prow+ "]/workflag" , model.getValue(cmb_workflag.attribute("ref" )));
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/instcd" , model.getValue(opt_instcd.attribute("ref" )));
- // model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqflag" , model.getValue(cmb_reqflag.attribute("ref" )));
- // 불출구분 없앰... 기본값('1') settting한다
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/deliveflag" , '1' );
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqdd" , model.getValue(ipt_reqdd.attribute("ref" )));
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqpridflag" , model.getValue(cmb_reqpridflag.attribute("ref" )));
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqdeptcd" , model.getValue(cmb_reqdeptcd.attribute("ref" )));
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqpsnid" , model.getValue(opt_requser.attribute("ref" )));
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqseqno" , fGetMaxReqNo() );
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/reqno" , model.getValue(cmb_reqno.attribute("ref" )));
- // model.setValue(grd_goodreq.nodeset +"[" + prow + "]/stdysubjno" , model.getValue(ipt_stdysubjno.attribute("ref" )));
-
- //-----------------------------------------------------------------------------------------------------------
- // 비승인자가 승인처리시 에러와 함꼐 OLD값을 넣어준다.
- // 행추가시 OLD값을 'N'으로 셋팅함으로 에러처리시 제대로 된다. HBH
- //-----------------------------------------------------------------------------------------------------------
- model.setValue(grd_goodreq.nodeset +"[" + prow + "]/predeptaprvyn","N");
-
- /*------------------------------------------------------------------------------------------------------------
- * 화면 상단 계정을 bugtcd에 넣는다.
- ------------------------------------------------------------------------------------------------------------*/
- // model.setValue(grd_goodreq.nodeset +"[" + prow + "]/bugtcd",model.getValue(cmb_bugtflag.attribute("ref")));
- }
-
- // --------------------------------------------------------------
- // 최종 청구번호 가져오기
- // --------------------------------------------------------------
- function fGetMaxReqNo() {
- var vMax = 0;
- var maxreqseqno = "0";
-
- for (var currow = grd_goodreq.fixedRows ; currow < grd_goodreq.rows; currow++) {
- if (maxreqseqno < grd_goodreq.valueMatrix(currow, grd_goodreq.colRef("reqseqno"))) {
- maxreqseqno = grd_goodreq.valueMatrix(currow, grd_goodreq.colRef("reqseqno"));
- }
- }
-
- vMax = parseInt(maxreqseqno, 10);
- // alert(vMax+"::"+maxreqseqno);
-
- vMax += 1;
-
- maxreqseqno = "" + vMax;
- return maxreqseqno.getLeftPad(3,"0");
- }
-
- // --------------------------------------------------------------
- //
- // --------------------------------------------------------------
- function fSettingGoodList(pnode, nodename, userqtynm) {
-
- var vTarget = "";
- var vSource = "";
-
- var codynode = instance1.selectNodes(pnode + "/*");
- var addRow = grd_goodreq.rows - grd_goodreq.fixedRows;
-
- if (model.getValue(grd_goodreq.nodeset + "[" + addRow + "]/goodcd").length > 0) addRow = addRow + 1;
-
- //
- for (var j = 1; j <= codynode.length ; j++) {
- if((grd_goodreq.rows - grd_goodreq.fixedRows == 0) || (addRow > grd_goodreq.rows - grd_goodreq.fixedRows)) {
- misfGridIUD(grd_goodreq,"A" );
- addRow = grd_goodreq.rows - grd_goodreq.fixedRows;
- fDefaultSetting(addRow);
- }
-
- vTarget = grd_goodreq.nodeset + "[" + addRow + "]/";
- vSource = pnode +"/" + nodename + "[" + j + "]/";
-
- fSettingGoodData(vTarget, vSource, userqtynm, "deliveunit");
-
- // 2009.02.04 CHR
- AprFlag = fReqAprvCheck(1, model.getValue(vTarget + "/reqflag")); // 청구/승인자권한 Check
-
- if (AprFlag == "1") {
- if (gPurcdeptflag == "P" ) { //구매부서구분 : P
- grd_goodreq.isReadOnly(addRow, grd_goodreq.colRef("deptaprvyn")) = true;
- }
- }else{
- grd_goodreq.isReadOnly(addRow, grd_goodreq.colRef("deptaprvyn")) = false;
- }
-
- if (model.getValue(vSource + "allsizeyn") == "Y") {
-
- grd_goodreq.cellstyle("background-color" , addRow, 9) = "#FFFF00";
- model.setValue(vTarget + "allsizespecid" , model.getValue(vSource + "allsizespecid" ));
- model.setValue(vTarget + "allsizespecidnm" , model.getValue(vSource + "allsizespecidnm"));
-
- if (model.getValue(vSource + "allsizespecid").length > 0 ) {
- model.setValue(vTarget + "goodspec" , model.getValue(vSource + "allsizespecidnm"));
- } else {
- model.setValue(vTarget + "allsizespecid" , "-");
- }
- }
- addRow = addRow + 1;
- }
-
-
- //model.removenode(pnode);
- model.refresh();
- }
-
- function fCheckRetrieveData(pmsg)
- {
- if(model.getValue(cmb_workflag.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("작업구분을 " ,"C002");
- model.setFocus("cmb_workflag");
- }
- return false;
- }
- if(model.getValue(opt_instcd.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("기관코드를 " ,"C002");
- model.setFocus("opt_instcd");
- }
- return false;
- }
- // if(model.getValue(cmb_reqflag.attribute("ref")).length== 0 )
- // {
- // if(pmsg == true)
- // {
- // messageBox("청구구분을 " ,"C002");
- // model.setFocus("cmb_reqflag");
- // }
- // return false;
- // }
-
- if(model.getValue(ipt_reqdd.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("청구일자를 " ,"C001");
- model.setFocus("ipt_reqdd");
- }
- return false;
- }
- if(model.getValue(cmb_reqpridflag.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("청구주기를 " ,"C002");
- model.setFocus("cmb_reqpridflag");
- }
- return false;
- }
- if(model.getValue(cmb_reqdeptcd.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("청구부서를 " ,"C002");
- model.setFocus("cmb_reqdeptcd");
- }
- return false;
- }
- if(model.getValue(opt_requser.attribute("ref")).length== 0 )
- {
- if(pmsg == true)
- {
- messageBox("청구자를 " ,"C002");
- model.setFocus("opt_requser");
- }
- return false;
- }
- return true;
- }
-
-
- //
- // AprFlag = fReqAprvCheck(1, model.getValue(grd_goodreq.nodeset + "[" + liRow + "]/reqflag")); // 청구/승인자권한 Check
- //
- // if ((AprFlag == "2") || // 승인권
- // (gPurcdeptflag == "P") ) { // 구매부서구분 : P
- // if (grd_goodreq.rowStatus(liRow) == "0") {
- // grd_goodreq.rowStatus(liRow) = "2";
- // }
- //
- //
- // Data를 저장한다.
- function fSaveData() {
-
- // 저장전 Data를 Check한다.
- if (fCheckSaveData() == false) return;
- model.setValue("/root/send/save/autoaprv/instcd" , model.getValue(opt_instcd.attribute("ref") )); // 기관코드
- model.setValue("/root/send/save/autoaprv/reqdeptcd", model.getValue(cmb_reqdeptcd.attribute("ref"))); // 청구부서
-
- // 신규청구 구분
- if (model.getValue(chk_reqnonew.attribute("ref")) == "Y") {
- model.setValue("/root/send/save/autoaprv/reqdd", model.getValue(ipt_reqddnew.attribute("ref"))); // 신규청구일자
- } else {
- model.setValue("/root/send/save/autoaprv/reqdd", model.getValue(ipt_reqdd.attribute("ref"))); // 청구일자
- }
-
- // 수정된 자료를 전송대상에 Copy한다.
- model.setValue("/root/send/save/goodreqlist", grd_goodreq.getUpdateData());
-
- // 동시 승인여부 일청구는 동시 승인한다.
- if (model.getValue(cmb_reqpridflag.attribute("ref"))=="1") model.setValue("/root/send/save/autoaprv/autoaprvyn","Y");
-
- // 동시 승인여부 Check
- if (ckb_accept.value == "Y") {
- model.setValue("/root/send/save/autoaprv/autoaprvyn", "Y");
- } else {
- model.setValue("/root/send/save/autoaprv/autoaprvyn", "N");
- } // end if
- submit("TXRSD00411"); // 입력 수정된 내용을 저장한다.
-
- // Error Check 한다.
- if (model.getValue(gvErrorMsgPath + "/type") == "error") return;
-
- // 신규인경우
- if (chk_reqnonew.value == "Y") {
- // 신규청구일자와 청구일자가 같은경우
- if (model.getValue(ipt_reqdd.attribute("ref")) == model.getValue(ipt_reqddnew.attribute("ref"))) {
- fDeptReqNoQuery(); // 부서청구내역 읽어오기
- } else {
- model.setValue(ipt_reqdd.attribute("ref"), model.getValue(ipt_reqddnew.attribute("ref")));
- ipt_reqdd.refresh();
- }
-
- // chk_reqnonew.value = "N";
- fNewReqNoVisibility();
- btn_search.dispatch("DOMActivate");
-
- } else {
- btn_search.dispatch("DOMActivate");
-
- if (grd_goodreq.rows < 2) {
- fDeptReqNoQuery(); // 청구부서별 청구번호를 조회한다
- fNewReqNoVisibility();
- }
- }
- }
-
- // 저장전 Data를 Check한다.
- function fCheckSaveData(){
-
- if (model.getValue(cmb_workflag.attribute("ref")).length== 0 ) {
- messageBox("작업구분을 " ,"C002");
- model.setFocus("cmb_workflag");
- return false;
- }
- //
- if (model.getValue(opt_instcd.attribute("ref")).length== 0 ) {
- messageBox("기관코드를 " ,"C002");
- model.setFocus("opt_instcd");
- return false;
- }
-
- // if (model.getValue(cmb_reqflag.attribute("ref")).length== 0 ) {
- // messageBox("청구구분을 " ,"C002");
- // model.setFocus("cmb_reqflag");
- // return false;
- // }
-
- if (model.getValue(ipt_reqdd.attribute("ref")).length== 0 ) {
- messageBox("청구일자를 " ,"C001");
- model.setFocus("ipt_reqdd");
- return false;
- }
-
- if (model.getValue(cmb_reqpridflag.attribute("ref")).length== 0 ) {
- messageBox("청구주기를 " ,"C002");
- model.setFocus("cmb_reqpridflag");
- return false;
- }
-
- //
- var basevol = 0; // 안전재고
- var stocqty = 0; // 현재고
- var reqqty = 0; // 청구량
- var minexch = 0; // 최소청구
-
- for (var currow = grd_goodreq.fixedRows ; currow < grd_goodreq.rows ; currow++) {
- if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("goodcd")).length == 0) {
- messageBox(currow + " 번째 물품코드를 " ,"C001");
- grd_goodreq.row = currow;
- grd_goodreq.col = grd_goodreq.colRef("goodcd");
- grd_goodreq.editCell();
- return false;
- } else {
- for (srcrow = currow + 1 ; srcrow < grd_goodreq.rows ; srcrow++) {
- if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("goodcd" )) == grd_goodreq.valueMatrix(srcrow , grd_goodreq.colRef("goodcd" )) &&
- grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("allsizeyn")) == "N" ){
- messageBox("동일 물품코드가1 [" + currow + "," +srcrow + "->" + grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("goodcd")) + "] 존재하여 저장 " ,"E001");
- return false;
- }
- else if (grd_goodreq.valueMatrix(currow ,grd_goodreq.colRef("goodcd" )) == grd_goodreq.valueMatrix(srcrow , grd_goodreq.colRef("goodcd" )) &&
- grd_goodreq.valueMatrix(currow ,grd_goodreq.colRef("allsizespecid")) == grd_goodreq.valueMatrix(srcrow , grd_goodreq.colRef("allsizespecid")) ) {
- messageBox("동일 물품코드가 (ALL SIZE) [" + currow + "," +srcrow + "->" + grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("goodcd")) + "] 존재하여 저장 " ,"E001");
- return false;
- }
- }
- }
-
- // 청구량이 0보다 작은 경우
- // if(grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("reqqty")) == 0)
- if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("reqqty")) <= 0) {
- if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("reqqty")) == 0 )
- messageBox(currow + " 번째 청구량을 " ,"C001");
- else
- messageBox(currow + " 번째 올바른 청구량을 " ,"C001");
- grd_goodreq.row = currow;
- grd_goodreq.col = grd_goodreq.colRef("reqqty");
- grd_goodreq.editCell();
- return false;
- } // End Of if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("reqqty")) <= 0)
-
- basevol = grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("basevol")); // 안전재고
- stocqty = grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("stocqty")); // 현재고
- reqqty = grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("reqqty" )); // 청구량
- minexch = grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("minexch")); // 최소청구
-
- // 최소청구량 CHECK
- if (minexch > 0 && (reqqty%minexch != 0)) {
- messageBox((currow) + "번째 물품은 최소청구량에 ["+ minexch + "]맞춰서" , "C001");
- grd_goodreq.row = currow;
- grd_goodreq.col = grd_goodreq.colRef("reqqty");
- grd_goodreq.editCell();
- return false;
- } // End Of if (minexch > 0 && (reqqty%minexch != 0)) {
-
- // all size 미입력분 체크 2007.09.
- // allsizeyn = 'Y' 인데.... allsizespecid선택을 안한경우
- if(grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("allsizeyn")) == "Y" ) {
- if (grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("allsizespecid")).length == 0 ||
- grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("allsizespecid")) == '-' ) {
- messageBox(currow + " 번째 물품의 ALLSIZE선택을 " ,"C001");
- grd_goodreq.row = currow;
- grd_goodreq.col = grd_goodreq.colRef("goodspec");
- grd_goodreq.editCell();
- return false;
- }
- } else {
- grd_goodreq.valueMatrix(currow , grd_goodreq.colRef("allsizespecid")) = "-";
- }
- } // for (var currow = grd_goodreq.fixedRows ; currow < grd_goodreq.rows ; currow++)
-
- // 청구 번호가 없는 경우 즉 신규인 상황에서 신규체크를 하지 않았을 경우
- // 임의로 신규 체크 여부를 지정한다. [20081126] YYJ
-
- if (model.getValue(cmb_reqno.attribute("ref")).length== 0 ) {
- chk_reqnonew.value = 'Y';
- chk_reqnonew.refresh();
- }
-
- return true;
- }
-
- //
- function fSetControlDisabled(pDisabled) {
- cmb_reqno.disabled = pDisabled;
- }
-
- //
- function fAfterRetr() {
-
- if (model.getValue("/root/main/list/goodreq/goodmaxreqno/reqfix") == "Y") {
- fSetControlDisabled("true");
- }
- else {
- fSetControlDisabled("false");
- }
-
- // model.setValue(cmb_reqno.attribute("ref"),model.getValue("/root/main/list/goodreq/goodmaxreqno/reqno"));
- model.refresh();
- }
-
- function fRetrByReqNo()
- {
-
- if(fCheckRetrieveData(false) == false)return;
-
- model.removenode("/root/main/tmplist");
- model.makeNode("/root/main/tmplist/goodreq/goodreqlist");
- model.makeNode("/root/main/tmplist/goodreq/goodmaxreqno");
- model.copyNode("/root/main/tmplist", "/root/main/list");
-
- model.setValue("/root/send/goodreq/retrmaxreqnoyn","N");
-
- misfMsterDetailRetrieve();
-
- var rtncount = grd_goodreq.rows - grd_goodreq.fixedRows;
- if(rtncount == 0)
- {
- model.copyNode("/root/main/list","/root/main/tmplist");
- }
-
- return rtncount;
- }
- //
- function fSetReqNo(pReqControl,pAdd)
- {
- if(pAdd == "Y")
- {
- var reqno = model.getValue(cmb_reqno.attribute("ref"));
- reqno = parseInt(reqno) + 1;
- reqno = "" + reqno;
- reqno = reqno.getLeftPad(4,"0");
- }
- else
- {
- var reqno = model.getValue(cmb_reqno.attribute("ref"));
- reqno = parseInt(reqno) - 1;
- if(reqno == 0) reqno = 1;
- reqno = "" + reqno;
- reqno = reqno.getLeftPad(4,"0");
- }
- model.setValue(pReqControl.attribute("ref"), reqno);
- model.refresh();
- }
-
- //
- function fArrangeControl()
- {
- //fSetControlDisabled("false");
- misfGridInit(grd_goodreq);
- // model.setValue(cmb_reqflag.attribute("ref") ,"");
- model.setValue(cmb_reqno.attribute("ref") ,"");
- model.setValue(ipt_reqdd.attribute("ref") ,"");
- model.setValue(cmb_reqdeptcd.attribute("ref") ,"");
- // model.setValue(ipt_reqdeptnm.attribute("ref") ,"");
- model.setValue(opt_requser.attribute("ref") ,"");
- model.setValue(opt_requsernm.attribute("ref") ,"");
- model.setValue(opt_reqfinaldept.attribute("ref") ,"");
- model.setValue(opt_reqfinaldeptnm.attribute("ref"),"");
- model.refresh();
- }
- // 승인전체/접수전체취소 CHR 2009.02.05
- function fSettingReqAprv() {
- var AprFlag = "";
-
- for (var liRow = grd_goodreq.fixedRows ; liRow < grd_goodreq.rows ; liRow++) {
- // 발주승인건 제외
- if (model.getValue(grd_goodreq.nodeset + "[" + liRow + "]/aprvyn") != "Y")
- {
- AprFlag = fReqAprvCheck(1, model.getValue(grd_goodreq.nodeset + "[" + liRow + "]/reqflag")); // 청구/승인자권한 Check
-
- if ((AprFlag == "2") || // 승인권
- (gPurcdeptflag == "P") ) { // 구매부서구분 : P
- if (grd_goodreq.rowStatus(liRow) == "0") {
- grd_goodreq.rowStatus(liRow) = "2";
- }
- //
- if (model.getValue(grd_goodreq.nodeset + "[" + liRow + "]/deptaprvyn") == "Y") {
- model.setValue(grd_goodreq.nodeset + "[" + liRow + "]/deptaprvyn","N");
- model.setValue(grd_goodreq.nodeset + "[" + liRow + "]/deptaprvdd","" );
- } else {
- model.setValue(grd_goodreq.nodeset + "[" + liRow + "]/deptaprvyn","Y");
- model.setValue(grd_goodreq.nodeset + "[" + liRow + "]/deptaprvdd",getCurrentDate());
- }
- } // End if ((AprFlag == "2") || // 승인권
- } // End if 발주승인건 제외
- } // End Of for
-
- model.refresh();
- }
-
- // 승인/미승인 저장
- function fSaveReqAprv()
- {
- model.removenode("/root/send/reqaprvlist");
- model.makeNode("/root/send/reqaprvlist" );
- model.setValue("/root/send/reqaprvlist", grd_goodreq.getUpdateData());
-
- submit("TXRSD07002");
-
- if (model.getValue(gvErrorMsgPath + "/type") != "error") misfMsterDetailRetrieve();
- }
-
- //
- function fGrantsCheck()
- {
- if(vPurcAuth == "2" || model.getValue(cmb_reqpridflag.attribute("ref")) =="1" )
- {
- misfSetReadOnlyCol(grd_goodreq, "deptaprvyn", false);
- }else{
- misfSetReadOnlyCol(grd_goodreq, "deptaprvyn", true);
- }
-
- }
-
- // --------------------------------------------------
- // 물품청구 버튼 Click 처리하는 함수
- // --------------------------------------------------
- function fGoodreqButtonClick() {
- grp_allsize.attribute("visibility") ="hidden" ;
-
- if (grd_goodreq.col == grd_goodreq.colRef("goodcd") &&
- grd_goodreq.rowStatus(grd_goodreq.row) == "1" ) { //구성물품코드를 눌렀을 경우
-
- fViewToggle(2); // 1 :늘리기, 2 : 줄이기
-
- cmb_reqflag.select(0);
-
- fReqFagChange(cmb_reqflag.value);
- fGoodListReady(grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.col),""); // 물품찾기 처리하는 함수
- model.toggle("gd_find");
-
- bbt_good.selected = "true";
- }
- else if (grd_goodreq.col == grd_goodreq.colRef("goodspec") && grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("allsizeyn")) == "Y" )
- {
- fAllSizeRead(grd_goodreq.row ,grd_goodreq.col, event.clientY);
- }
- model.refresh();
-
- }
-
- // --------------------------------------------------
- // 물품청구 내용이 바뀌었을때 처리하는 함수
- // --------------------------------------------------
- function fGoodreqOnChange() {
-
- // basevol = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("basevol"));
- // stocqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("stocqty"));
- //
- // reqqty = basevol - stocqty;
-
- // grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty")) = reqqty;
-
- // vMax = parseInt(maxreqseqno, 10);
- //reqqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty"));
-
- if (grd_goodreq.col == grd_goodreq.colRef("reqqty") ) {
- if (model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/acptflag") == "Y")
- {
- messageBox("구매접수된 내역은 수정","E001");
- return;
- }
-
-
- if(model.getValue(cmb_reqpridflag.attribute("ref")) !="1")
- {
- if(vPurcAuth == "1" &&
- model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("청구승인되었으므로 청구량을 수정" ,"E001");
- return;
- }
- }
- basevol = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("basevol"));
- stocqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("stocqty"));
-
- reqqty = basevol - stocqty;
-
- grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty")) =reqqty;
- // vMax = parseInt(maxreqseqno, 10);
- //reqqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty"));
-
- minexch = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("minexch"));
-
- if(minexch > 0 && (reqqty%minexch != 0))
- {
- messageBox((grd_goodreq.row )+ "번째 물품은 최소청구량["+ minexch + "] 에 맞춰서" , "C001");
- grd_goodreq.row = grd_goodreq.row;
- grd_goodreq.col= grd_goodreq.colRef("reqqty");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty","");
- grd_goodreq.editCell();
- return;
- }
- }
-
- /*-------------------------------------------------------------------------------------
- * 청구수량을 정량보충으로 변경함. ( 재고/ 기준량을 입력한다) .2007.08.
- -------------------------------------------------------------------------------------*/
- else if (grd_goodreq.col == grd_goodreq.colRef("stocqty") || grd_goodreq.col == grd_goodreq.colRef("basevol") ) {//재고량조절할경우
-
- if (model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/acptflag") == "Y")
- {
- messageBox("구매접수된 내역은 수정","E001");
- return;
- }
-
-
- if(model.getValue(cmb_reqpridflag.attribute("ref")) !="1")
- {
- if(vPurcAuth =="1" &&
- model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("청구승인되었으므로 재고량을 수정" ,"E001");
- return;
- }
- }
- basevol = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("basevol"));
- stocqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("stocqty"));
- reqqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty"));
- minexch = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("minexch"));
-
- calc_reqqty = basevol - stocqty;
-
- // if ( calc_reqqty < minexch ) calc_reqqty = minexch;
- // if ( calc_reqqty < minexch ) calc_reqqty = 0;
-
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty",calc_reqqty);
- }
-
- else if(grd_goodreq.col == grd_goodreq.colRef("goodcd") && grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.colRef("goodcd")).length> 0) {
-
- model.removenode("/root/copynode");
- model.removenode(gvParamPath +"/SMRSD00400_/SMRSD00400_value");
- model.makeNode("/root/copynode");
-
-
- // rszfValidationCheck("TRRSD00191", "goodlist" , "refcond,instcd,goodflag,goodcd,goodnm,indexgb,indexnm,reqflag,reqdeptcd,reqprid","goodcd," + model.getValue(opt_instcd.attribute("ref")) + "," +model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodflag") + "," + model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd") + ",,,," + model.getValue(cmb_reqflag.attribute("ref")) + "," + model.getValue(cmb_reqdeptcd.attribute("ref")) + "," + model.getValue(cmb_reqpridflag.attribute("ref")) ,"","goodcd,goodnm,goodspec,goodmodel,prodcmpynm,purcunit,stocqty,minexch,goodflag,ddavguseqty,reqflag,allsizeyn",grd_goodreq,"SPRSD00190","instcd,goodflag,reqflag,reqdeptcd,reqprid","opt_instcd,opt_goodflag,cmb_reqflag,cmb_reqdeptcd,cmb_reqpridflag","Y");
- model.refresh();
-
- if( grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("goodnm")).length> 0)
- {
-
- if(model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/minexch") > 0) model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty",model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/minexch") );
- else model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty","1");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/basevol",model.getValue("/root/init/main/goodlist/minexch"));
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/requnit",model.getValue("/root/init/main/goodlist/deliveunit"));
-
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/exchqty",model.getValue("/root/init/main/goodlist/exchqty"));
- // model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqmthdflag",model.getValue("/root/init/main/goodlist/reqmthd"));
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqmthdflag","3");
- }
-
- model.refresh();
-
- var cur_row = grd_goodreq.row;
- var status = grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("m"));
- var CSV = model.getValue(gvParamPath +"/SMRSD00400_/SMRSD00400_value");
-
- if(CSV.length == 0 && grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("goodnm")).length == 0)
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodcd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodnm" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodspec" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodflag" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodmodel" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/prodcmpynm" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/purcunit" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/basevol" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/stocqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/reqqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/requnit" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/minexch" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/ddavguseqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/allsizeyn" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/allsizespecid" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/exchqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/rgstqty" , "");
-
- grd_goodreq.col = grd_goodreq.colRef("goodcd");
- grd_goodreq.editCell();
- }
- else if (CSV.length > 0)
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd","");
- setCSVToNode("/root/copynode", CSV, "goodreqlist");
-
- fSettingGoodList("/root/copynode", "goodreqlist" , "userqty");
- }
- }
-
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // 영양팀은 품목명칭에서 값을 입력할수 있다..
- // 입력값과 일치건이 1일경우 코드 REPLACE
- // 없을경우 FIND
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- else if(grd_goodreq.col == grd_goodreq.colRef("goodnm") && grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.colRef("goodnm")).length> 0
- && grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.colRef("goodcd")).length== 0 )
- {
-
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // validation을 하기 위해 임시 column 을 둔다.
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- model.setValue(tmp_goodcd.attribute("ref") ,"%" );
- model.setValue(tmp_goodnm.attribute("ref") ,grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.colRef("goodnm")) );
- model.removenode("/root/copynode");
- model.removenode(gvParamPath +"/SMRSD00400_/SMRSD00400_value");
- model.makeNode("/root/copynode");
-
- // rszfValidationCheck("TRRSD00191", "goodlist" , "refcond,instcd,goodflag,goodcd,goodnm,indexgb,indexnm,reqflag,reqdeptcd,reqprid","goodcd," + model.getValue(opt_instcd.attribute("ref")) + "," + model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodflag") + ","+model.getValue(tmp_goodcd.attribute("ref")) +","+model.getValue(tmp_goodnm.attribute("ref")) + ",,," + model.getValue(cmb_reqflag.attribute("ref")) + "," + model.getValue(cmb_reqdeptcd.attribute("ref")) + "," + model.getValue(cmb_reqpridflag.attribute("ref")) ,"","goodcd,goodnm,goodspec,goodmodel,prodcmpynm,purcunit,stocqty,minexch,goodflag,ddavguseqty,maincustlastsuplplce,suppcustcd,goodunitcost,deliveunit,exchqty",grd_goodreq,"SPRSD00210","instcd,reqflag,reqdeptcd,goodnm,reqprid","opt_instcd,cmb_reqflag,cmb_reqdeptcd,tmp_goodnm,cmb_reqpridflag","Y");
-
- model.refresh();
-
- if(grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.colRef("goodcd")).length> 0)
- {
- model.removenode("/root/copynode");
- model.removenode(gvParamPath +"/SMRSD00400_/SMRSD00400_value");
- model.makeNode("/root/copynode");
-
-
- // rszfValidationCheck("TRRSD00191", "goodlist" , "refcond,instcd,goodflag,goodcd,goodnm,indexgb,indexnm,reqflag,reqdeptcd,reqprid","goodcd," + model.getValue(opt_instcd.attribute("ref")) + "," +model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodflag") + "," + model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd") + ",,,," + model.getValue(cmb_reqflag.attribute("ref")) + "," + model.getValue(cmb_reqdeptcd.attribute("ref")) + "," + model.getValue(cmb_reqpridflag.attribute("ref")) ,"","goodcd,goodnm,goodspec,goodmodel,prodcmpynm,purcunit,stocqty,minexch,goodflag,ddavguseqty,reqflag,allsizeyn",grd_goodreq,"SPRSD00190","instcd,goodflag,reqflag,reqdeptcd,reqprid","opt_instcd,opt_goodflag,cmb_reqflag,cmb_reqdeptcd,cmb_reqpridflag","Y");
- model.refresh();
-
- if( grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("goodnm")).length> 0)
- {
-
- if(model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/minexch") > 0) model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty",model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/minexch") );
- else model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqqty","1");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/basevol",model.getValue("/root/init/main/goodlist/minexch"));
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/requnit",model.getValue("/root/init/main/goodlist/deliveunit"));
-
- // model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqmthdflag",model.getValue("/root/init/main/goodlist/reqmthd"));
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/reqmthdflag","3");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/allsizespecid","YYY");
- }
-
- model.refresh();
-
- var cur_row = grd_goodreq.row;
- var status = grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("m"));
-
- var CSV = model.getValue(gvParamPath +"/SMRSD00400_/SMRSD00400_value");
-
- if(CSV.length == 0 && grd_goodreq.valueMatrix(cur_row, grd_goodreq.colRef("goodnm")).length == 0)
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodcd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodnm" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodspec" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodflag" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/goodmodel" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/prodcmpynm" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/purcunit" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/basevol" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/stocqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/reqqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/requnit" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/minexch" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/ddavguseqty" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/allsizeyn" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/allsizespecid" , "");
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1) + "]/rgstqty" , "");
-
- grd_goodreq.col = grd_goodreq.colRef("goodcd");
- grd_goodreq.editCell();
- }
- else if (CSV.length > 0)
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/goodcd","");
- setCSVToNode("/root/copynode", CSV, "goodreqlist");
-
- fSettingGoodList("/root/copynode", "goodreqlist" , "userqty");
- }
-
- }
- }
-
- else if((grd_goodreq.col == grd_goodreq.colRef("deptaprvyn")))
- {
- if(vPurcAuth != "2" && model.getValue(cmb_reqpridflag.attribute("ref")) != "1" )
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/deptaprvyn",model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") );
- // insert 가 아니면..
- if ( grd_goodreq.rowStatus(grd_goodreq.row) != '3')
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- }
- messageBox("청구승인권한이 없으므로 수정" ,"E001");
- }
- else if(model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/aprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("발주승인이 되었으므로 수정" ,"E001");
- }
- else model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/deptaprvdd" ,getCurrentDate());
- }
- }
- // --------------------------------------------------
- // 물품청구 내용이 바뀌었을때 처리하는 함수
- // --------------------------------------------------
- function fGoodreqOnKeyDown() {
-
- if(event.keyCode == 13)
- {
- if(grd_goodreq.col == grd_goodreq.colRef("reqqty"))
- {
- if(grd_goodreq.row < grd_goodreq.rows - grd_goodreq.fixedRows)
- {
- grd_goodreq.row = grd_goodreq.row + 1;
- grd_goodreq.select(grd_goodreq.row, grd_goodreq.colRef("reqqty")) = true;
- }
- }
- }
-
- if(event.keyCode == 9)
- {
- if(event.shiftKey)
- {
- if(grd_goodreq.colAttribute(grd_goodreq.col + 1, "type").indexOf ("input") > -1)
- {
- for(curcol = grd_goodreq.col -1 ; curcol > -1 ; curcol--)
- {
- if(grd_goodreq.colAttribute(curcol, "type").indexOf ("input") > -1)
- {
- grd_goodreq.col = curcol;
- grd_goodreq.editCell();
- return;
- }
- }
- }
- }
- else
- {
- if(grd_goodreq.colAttribute(grd_goodreq.col, "type").indexOf ("input") == -1)
- {
- if(grd_goodreq.col - 1 == grd_goodreq.colRef("goodcd") && grd_goodreq.valueMatrix(grd_goodreq.row, grd_goodreq.col - 1).length == 0)
- {
- grd_goodreq.col = grd_goodreq.colRef("goodcd");
- grd_goodreq.editCell();
- return;
- }
- for(curcol = grd_goodreq.col ; curcol <grd_goodreq.cols ; curcol++)
- {
- if(grd_goodreq.colAttribute(curcol, "type").indexOf ("input") > -1)
- {
- grd_goodreq.col = curcol;
- grd_goodreq.editCell();
- return;
- }
- }
- }
- }
- }
-
- }
-
- // --------------------------------------------------
- // 물품청구 Cell 내용이 바뀌었을때 처리하는 함수
- // --------------------------------------------------
- function fGoodreqOnEnterCell() {
-
- if((grd_goodreq.col == grd_goodreq.colRef("deptaprvyn")))
- {
- if(vPurcAuth != "2" && model.getValue(cmb_reqpridflag.attribute("ref")) !="1" )
- {
- model.setValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/deptaprvyn",model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") );
- // insert 가 아니면..
- if ( grd_goodreq.rowStatus(grd_goodreq.row) != '3')
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- }
- messageBox("청구승인권한이 없으므로 수정" ,"E001");
- }
- else
- {
- if(model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/aprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("발주승인이 되었으므로 수정" ,"E001");
- }
- }
- }
- else if(grd_goodreq.col == grd_goodreq.colRef("stocqty"))
- // else if(grd_goodreq.col == grd_goodreq.colRef("reqqty"))
- {
- if (model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/acptflag") == "Y")
- {
- messageBox("구매접수된 내역은 수정","E001");
- return;
- }
-
- if(model.getValue(cmb_reqpridflag.attribute("ref")) !="1")
- {
- if(vPurcAuth =="1" &&
- model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("청구승인되었으므로 재고량을 수정" ,"E001");
- return;
- }
- }
- }
- else if(grd_goodreq.col == grd_goodreq.colRef("reqqty"))
- {
- if (model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/acptflag") == "Y")
- {
- messageBox("구매접수된 내역은 수정","E001");
- return;
- }
-
- if(model.getValue(cmb_reqpridflag.attribute("ref")) !="1")
- {
- if(vPurcAuth =="1" &&
- model.getValue(grd_goodreq.nodeset + "[" + (grd_goodreq.row - grd_goodreq.fixedRows + 1)+ "]/predeptaprvyn") == "Y")
- {
- grd_goodreq.rowStatus(grd_goodreq.row) = "0";
- messageBox("청구승인되었으므로 청구량을 수정" ,"E001");
- return;
- }
- }
- }
-
- }
-
- // --------------------------------------------------
- // Switch 속성변경 처리하는 함수
- // --------------------------------------------------
- function fViewToggle(pCls) {
- if (pCls == 1) { // 늘리기
- // 메인 Grup
- grp_main.attribute("left" ) = "1" ;
- grp_main.attribute("top" ) = "90" ;
- grp_main.attribute("width" ) = "1188";
- grp_main.attribute("height" ) = "663" ;
-
- // Data Grid
- grd_goodreq.attribute("left" ) = "3" ;
- grd_goodreq.attribute("top" ) = "29" ;
- grd_goodreq.attribute("width" ) = "1180";
- grd_goodreq.attribute("height") = "628" ;
- lin_main.attribute("x2" ) = "1182" ;
- bbt_large.attribute("visibility") = "hidden" ;
- bbt_right.attribute("visibility") = "hidden" ;
- grp_button.attribute("left" ) = "589" ;
- grp_allsize.attribute("left" ) = "544" ;
-
- } else { // 줄이기
- // 메인 Grup
- grp_main.attribute("left" ) = "593" ;
- grp_main.attribute("top" ) = "90" ;
- grp_main.attribute("width" ) = "602" ;
- grp_main.attribute("height" ) = "663" ;
-
- // Data Grid
- grd_goodreq.attribute("left" ) = "3" ;
- grd_goodreq.attribute("top" ) = "29" ;
- grd_goodreq.attribute("width" ) = "592" ;
- grd_goodreq.attribute("height") = "628" ;
- lin_main.attribute("x2" ) = "593";
- bbt_large.attribute("visibility") = "visible" ;
- bbt_right.attribute("visibility") = "visible" ;
- grp_button.attribute("left" ) = "3" ;
- grp_allsize.attribute("left" ) = "174" ;
- }
- // swt_search.refresh();
- grp_main.refresh();
- }
-
- // --------------------------------------------------
- // 물품 찾기 속성변경 처리하는 함수
- // --------------------------------------------------
- function fGoodSearchToggle() {
- if (cpt_cls.attribute("text") =="0") { // 상세접근 조회
- // 메인 Grup
- grd_goodlist.attribute("left" ) = "2" ;
- grd_goodlist.attribute("top" ) = "83" ;
- grd_goodlist.attribute("width" ) = "576";
- grd_goodlist.attribute("height" ) = "574" ;
-
- btn_dtail.attribute("top" ) = "56" ;
- bbt_apply2.attribute("top" ) = "56" ;
- lin_goodlist.attribute("y1" ) = "78";
- lin_goodlist.attribute("y2" ) = "78";
- grp_dtail.attribute("visibility") ="hidden" ;
- cpt_cls.attribute("text") = "1";
-
- } else { // 줄이기
- // 메인 Grup
- grd_goodlist.attribute("left" ) = "2" ;
- grd_goodlist.attribute("top" ) = "285" ;
- grd_goodlist.attribute("width" ) = "576";
- grd_goodlist.attribute("height" ) = "372" ;
- btn_dtail.attribute("top" ) = "258" ;
- bbt_apply2.attribute("top" ) = "258" ;
- lin_goodlist.attribute("y1" ) = "280";
- lin_goodlist.attribute("y2" ) = "280";
- grp_dtail.attribute("visibility") ="visible" ;
-
- cpt_cls.attribute("text") = "0";
- }
-
- grd_goodlist.refresh();
- }
- // --------------------------------------------------
- // 물품 찾기 속성변경 처리하는 함수
- // --------------------------------------------------
- var vInstcd = "";
- var vReqdeptcd = "";
-
- function fReqSetList() {
- var vReqSetFlag = "N";
- if (model.getValue(opt_instcd.attribute("ref")) == "") {
- messageBox("기관을 " ,"C002");
- return;
- }
- //
- if (model.getValue(cmb_reqdeptcd.attribute("ref" )) == ""){
- messageBox("청구 부서를 " ,"C002");
- return;
- }
-
- //
- if (vInstcd != model.getValue(opt_instcd.attribute("ref" ))) vReqSetFlag = "Y";
- if (vReqdeptcd != model.getValue(cmb_reqdeptcd.attribute("ref" ))) vReqSetFlag = "Y";
-
- if (vReqSetFlag == "N") return;
-
- vInstcd = model.getValue(opt_instcd.attribute("ref" ));
- vReqdeptcd = model.getValue(cmb_reqdeptcd.attribute("ref" ));
- model.setValue("/root/send/reqmst/instcd" , model.getValue(opt_instcd.attribute("ref" )));
- model.setValue("/root/send/reqmst/reqdeptcd" , model.getValue(cmb_reqdeptcd.attribute("ref" )));
- grd_reqset.fixedcellcheckbox(0, grd_reqset.colRef("select"),false) = true;
-
- misfGridInit(grd_reqset);
- misfGridInit(grd_setlist);
-
- submit("TRRSD00211");
-
- if (grd_setlist.rows < 2) return;
-
- if (model.getValue(grd_setlist.nodeset + "["+ 1 + "]/reqdeptcd" ) =="") return;
-
- grd_setlist.row = 1;
- fReqSetRead(grd_setlist.row);
- misfMsterDetailRetrieve();
- }
-
- // 부서 청구SET 물품
- function fReqSetRead(pRow) {
- model.setValue("/root/send/reqset/instcd" , model.getValue(grd_setlist.nodeset + "["+ pRow + "]/instcd" ));
- model.setValue("/root/send/reqset/reqdeptcd" , model.getValue(grd_setlist.nodeset + "["+ pRow + "]/reqdeptcd" ));
- model.setValue("/root/send/reqset/reqprid" , model.getValue(grd_setlist.nodeset + "["+ pRow + "]/reqprid" ));
- model.setValue("/root/send/reqset/goodsetcd" , model.getValue(grd_setlist.nodeset + "["+ pRow + "]/goodsetcd" ));
- model.setValue("/root/send/reqset/goodsetnm" , model.getValue(grd_setlist.nodeset + "["+ pRow + "]/goodsetnm" ));
-
- misfGridInit(grd_reqset);
- submit("TRRSD00210"); // 청구마감일자 조회 purcbaseweb
- }
- // --------------------------------------------------
- // 선택물품을 적용하는 처리하는 함수
- // --------------------------------------------------
- function fSelectDataApply(pGridSource, pGridTarget, pGridNm, pQtyNm) {
- var vCopyNode = "/root/copynode";
-
- model.removenode(vCopyNode);
-
- var vSelect = 0 ;
- var AprFlag = ""; // 청구권한 Check
-
- for (var row = pGridSource.fixedRows ; row < pGridSource.rows; row++) {
- if (model.getValue(pGridSource.nodeset + "[" + row + "]/select" ) == "true") {
- // 2009.02.04 CHR
- AprFlag = fReqAprvCheck(0, model.getValue(pGridSource.nodeset + "[" + row + "]/reqflag")); // 물품청구 권한 Check
- // alert("===>>>"+AprFlag+"<<<===");
- if (AprFlag != "" ) {
- vSelect++;
- } else {
- model.setValue(pGridSource.nodeset + "[" + row + "]/select" , "false");
- }
- } else {
- model.setValue(pGridSource.nodeset + "[" + row + "]/select" , "false");
- }
- }
-
- //
- if (vSelect < 1) {
- pGridSource.refresh();
- return;
- }
-
- //
- var nodelist = instance1.selectNodes(pGridSource.nodeset + "[select='true']");
-
- // var nodelist = instance1.selectNodes(pGridSource.nodeset + "[select='true' and reqprid='"+cmb_reqpridflag.value+"']");
- var rCVS = getNodeListCSV(nodelist);
- var cur_row = pGridTarget.row;
-
- var status = pGridTarget.valueMatrix(cur_row, pGridTarget.colRef("m"));
- model.makeNode(vCopyNode);
-
- setCSVToNode(vCopyNode , rCVS , pGridNm);
- fSettingGoodList(vCopyNode, pGridNm , pQtyNm );
- //----------------------------------------------------------
- // 2008.07.08 YYJ 추가 물품 조회시 선택한 항목을 Clear 시켜준다.
- //----------------------------------------------------------
-
- for (var row = pGridSource.fixedRows ; row < pGridSource.rows; row++) {
- model.setValue(pGridSource.nodeset + "[" + row + "]/select" , "false");
- }
-
- }
-
- // --------------------------------------------------
- // All Size 읽어오는 함수
- // --------------------------------------------------
- var vAllSizeCol = 0;
- var vAllSizeRow = 0;
- var vAllSizePath = "/root/main/codelist";
- var vGoodReqPath = "/root/main/list/goodreq/goodreqlist";
-
- function fAllSizeRead(pRow, pCol, pPos) {
- var iClickY = pPos - 100;
-
- vAllSizeCol = pCol;
- vAllSizeRow = pRow;
-
- if (iClickY > 375) iClickY = iClickY - 319;
-
- grp_allsize.attribute("top") = iClickY+ "px";
- grp_allsize.attribute("visibility") = "visible" ;
- model.setValue("/root/send/allsize/instcd", model.getValue(opt_instcd.attribute("ref" )));
- model.setValue("/root/send/allsize/goodcd", model.getValue(grd_goodreq.nodeset + "[" + pRow + "]/goodcd"));
-
- submit("TRRSD00281");
-
- grp_allsize.refresh();
- }
-
- // All Size 선택
- function fAllSizeSelect() {
- grp_allsize.attribute("visibility") = "hidden" ;
-
- var vQty = "0";
- var vSize = "";
- var vSpec = "";
- var vModel = "";
- var vCheck = "";
- var vPath = "";
- var vTarget = "";
- var vSource = "";
-
- var vGoodcd = model.getValue(vGoodReqPath+"["+(vAllSizeRow)+"]/goodcd");
-
-
- for (var i = 1; i < grd_codelist.rows; i++) {
-
- if (model.getValue(vAllSizePath+"["+i+"]/chk") == "true") {
- vSize = model.getValue(vAllSizePath+"["+ i +"]/allsizespecid");
- vSpec = model.getValue(vAllSizePath+"["+ i +"]/goodspec" );
- vModel = model.getValue(vAllSizePath+"["+ i +"]/goodmodel" );
- vQty = model.getValue(vAllSizePath+"["+ i +"]/qty" );
-
- if (model.getValue(vGoodReqPath+"["+"[goodcd='"+ vGoodcd+"' and allsizespecid='"+vSize+"']" +"/goodcd") == "") {
- if (vCheck == "") {
- vCheck = "Y";
- vTarget = vGoodReqPath+"["+(vAllSizeRow)+"]" ;
- if (grd_goodreq.rowStatus(vAllSizeRow) == 0)
- grd_goodreq.rowStatus(vAllSizeRow) = 2 ;
-
- } else {
-
- misfGridIUD(grd_goodreq,"A");
-
- addRow = grd_goodreq.rows - grd_goodreq.fixedRows;
- fDefaultSetting(addRow);
- vTarget = grd_goodreq.nodeset + "[" + addRow + "]/";
- vSource = vGoodReqPath + "[" + vAllSizeRow + "]/";
-
- fSettingGoodData(vTarget, vSource, "basevol", "requnit", "S");
-
- grd_goodreq.cellstyle("background-color" , addRow, 9) = "#FFFF00";
- }
- } else {
- vPath = vGoodReqPath+"["+"[goodcd='"+ vGoodcd+"' and allsizespecid='"+vSize+"']";
- }
-
- // alert(vPath);
- //
- model.setValue(vTarget + "/allsizeyn" , "Y" );
- model.setValue(vTarget + "/allsizespecid" , vSize );
- model.setValue(vTarget + "/goodspec" , vSpec );
- model.setValue(vTarget + "/goodmodel" , vModel);
-
- if (vQty != "" && vQty != "0") {
- // model.setValue(vTarget + "/reqqty" , vQty );
- model.setValue(vTarget + "/stocqty" , vQty );
- }
- }
- }
-
- grd_goodreq.refresh();
- }
- // 신규생성
- function fNewReqNo() {
-
- fNewReqNoVisibility(); //청구일자 및 청구순번 을 신규여부에 따라 셋팅한다.
-
- if (chk_reqnonew.value == "Y" )
- {
- if (grd_goodreq.rows < 2) return;
- RetCls = messageBox("조회된 자료를 현재일자로 신규 생성합니다","S001");
- if ( RetCls == 6) //Yes
- {
- //model.resetInstanceNode("/root/send/save/autoaprv/reqnonew");
- //chk_reqnonew.value = "";
- chk_reqnonew.value = "Y"; // reqnonew 인스턴스값이 <> N Y </> 으로 나와서 해당부분에서 처리함(문제발생시 if문 삭제)
- fNewReqNoVisibility();
-
- for (var i = 1; i < grd_goodreq.rows; i++) {
- grd_goodreq.rowStatus(i) = 3 ;
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/deptaprvyn", "N");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/deptaprvdd", "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/deptaprvnm", "");
-
- //구매승인이 난 물품에 대해서도 신규생성시에 구매승인(acptflag)을 'N'로 셋팅해주어야 한다.
- //나머지 노드도 처음 청구낼때와 같게 셋팅해 준다(acptflagnm , acptdd , acptcharid , purcdmnddd , purcdmndno , purcdmndseq , aprvyn , deliveprcsflag)
- if ( model.getValue( grd_goodreq.nodeset + "[" + i + "]/acptflag" ) == "Y") {
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/acptflag" , "N");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/acptflagnm" , "미접수");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/acptdd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/acptcharid" , "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/purcdmnddd" , "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/purcdmndno" , "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/purcdmndseq" , "");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/aprvyn" , "N");
- model.setValue(grd_goodreq.nodeset + "[" + i + "]/deliveprcsflag" , "1");
-
- misfSetReadOnlyCol(grd_goodreq, "deptaprvyn", false); //승인체크란 ReadOnly false
-
- grd_goodreq.isReadOnly( i , grd_goodreq.fixedCols-1, i , grd_goodreq.cols-1) = false; //전체 Grid ReadOnly false
- }
- }
- }else if ( RetCls == 7) //No
- {
- // chk_reqnonew.value = "N";
- fNewReqNoVisibility();
- //데이터 그리드 클리어
- misfGridInit(grd_goodreq);
- }else{ //취소일경우
- return;
- }
- }else
- {
- btn_search.dispatch("DOMActivate");
- if (grd_goodreq.rows < 2) {
- return;
- }
- }
- grd_goodreq.refresh();
- //alert(grd_goodreq.rows);
- }
-
- // 신규 Check 시 작업구분
- function fNewReqNoVisibility() {
- if (chk_reqnonew.value == "Y") {
- // cmb_reqno.disabled = true;
- ipt_reqdd.attribute("visibility") = "hidden";
- ipt_reqddnew.attribute("visibility") = "visible" ;
- // cmb_reqno.attribute("visibility") = "hidden" ;
- // cmb_hidden.attribute("visibility") = "visible" ;
-
- ipt_reqddnew.value = getCurrentDate(); //신규로 체크되면 무조건 오늘날짜로 셋팅된다
- } else {
- // cmb_reqno.disabled = false;
- ipt_reqddnew.attribute("visibility") = "hidden";
- ipt_reqdd.attribute("visibility") = "visible" ;
- // cmb_reqno.attribute("visibility") = "visible" ;
- // cmb_hidden.attribute("visibility") = "hidden" ;
- }
- }
-
- //
- function fSettingGoodData(pTarget, pSource, pUserqtynm, pRequnit, pCls) {
-
- model.setValue(pTarget + "goodcd" , model.getValue(pSource + "goodcd" ));
- model.setValue(pTarget + "goodnm" , model.getValue(pSource + "goodnm" ));
- model.setValue(pTarget + "goodspec" , model.getValue(pSource + "goodspec" ));
- model.setValue(pTarget + "reqflag" , model.getValue(pSource + "reqflag" ));
- model.setValue(pTarget + "goodflag" , model.getValue(pSource + "goodflag" ));
- model.setValue(pTarget + "goodmodel" , model.getValue(pSource + "goodmodel" ));
- model.setValue(pTarget + "prodcmpynm" , model.getValue(pSource + "prodcmpynm" ));
- model.setValue(pTarget + "purcunit" , model.getValue(pSource + "purcunit" ));
- model.setValue(pTarget + "purcunit" , model.getValue(pSource + "purcunit" ));
- model.setValue(pTarget + "basevol" , model.getValue(pSource + pUserqtynm ));
- model.setValue(pTarget + "stocqty" , 0 );
- model.setValue(pTarget + "reqqty" , model.getValue(pSource + pUserqtynm ));
- // 청구량 계산
- // model.setValue(pTarget + "basevol" , model.getValue(pSource + "minexch" ));
- // basevol = model.getValue(pTarget + "basevol");
- // stocqty = grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("stocqty"));
- // reqqty = basevol - stocqty;
- // grd_goodreq.valueMatrix(grd_goodreq.row , grd_goodreq.colRef("reqqty")) =reqqty;
-
- model.setValue(pTarget + "requnit" , model.getValue(pSource + pRequnit ));
- model.setValue(pTarget + "minexch" , model.getValue(pSource + "minexch" ));
- model.setValue(pTarget + "ddavguseqty" , model.getValue(pSource + "ddavguseqty" ));
- model.setValue(pTarget + "exchqty" , model.getValue(pSource + "exchqty" ));
- //model.setValue(pTarget + "reqmthdflag" , model.getValue(pSource + "reqmthd" ));
- model.setValue(pTarget + "reqmthdflag" , "3" );
- model.setValue(pTarget + "allsizeyn" , model.getValue(pSource + "allsizeyn" ));
- model.setValue(pTarget + "reqcollcdeptcd", model.getValue(pSource + "reqcollcdeptcd"));
-
- model.setValue(pTarget + "setunit" , model.getValue(pSource + "setunit" ));
-
- if (pCls == "S") {
- model.setValue(pTarget + "delivedeptcd", model.getValue(pSource + "delivedeptcd"));
- } else {
- model.setValue(pTarget + "delivedeptcd", model.getValue(pSource + "reqfnldeptcd"));
- }
-
- model.setValue(pTarget + "rgstqty" , "0" );
- }
-
- // --------------------------------------------------
- // 물품찾기 처리하는 함수
- // --------------------------------------------------
- function fGoodListReady(pGoodCd, pGoodName) {
- misfGridInit(grd_goodlist);
- //misfComboComCdList('R0025', cmb_goodflag,"Y"); //물품구분
- fGoodListKeySet(); // 물품검색 기본 KEY SET
-
- // -------------------------------------------------------------------------------------------
- // sql문에 청구부서별 안전재고를 가져와야한다.
- // 프로그램 call시 변경해야한다. 인자값이 없을경우 해당 user값으로 setting한다.
- // -------------------------------------------------------------------------------------------
- if (model.getValue(PURTARGET_NODE + "/reqdeptcd").length == 0 )
- model.setValue("/root/send/goodlist/reqdeptcd", getUserInfo("dutplcecd"));
- else model.setValue("/root/send/goodlist/reqdeptcd", model.getValue(cmb_reqdeptcd.attribute("ref")));
- // --------------------------------------------------------------------------
- // 영양팀 명칭검색으로 이 window 가 open시 기본값 셋팅한다.
- // --------------------------------------------------------------------------
-
- if (pGoodCd.length > 0) {
- model.setValue("/root/send/goodlist/goodcd", pGoodCd);
- model.refresh();
- }
- else if (pGoodName.length > 0)
- {
- model.setValue("/root/send/goodlist/goodnm", pGoodName);
- model.refresh();
- }
- }
-
- // 물품검색 기본 KEY SET
- function fGoodListKeySet() {
- model.setValue("/root/send/goodlist/lrgcd" , "");
- model.setValue("/root/send/goodlist/mdlcd" , "");
- model.setValue("/root/send/goodlist/instcd" , model.getValue(opt_instcd.attribute("ref" )));
- // model.setValue("/root/send/goodlist/goodflag", model.getValue(opt_goodflag.attribute("ref" )));
- // model.setValue("/root/send/goodlist/reqflag" , model.getValue(cmb_reqflag.attribute("ref" )));
- model.setValue("/root/send/goodlist/reqprid" , model.getValue(cmb_reqpridflag.attribute("ref")));
-
- rszfLMSComboList(model.getValue(cmb_goodflag.attribute("ref")), "", "", "ipt_lrgcd", "", "L","Y");
- ipt_lrgcd.select(0);
- model.setValue("/root/send/goodlist/instcdnm" , opt_instcdnm.value );
- model.setValue("/root/send/goodlist/reqflagnm" , cmb_reqflag.label );
- model.setValue("/root/send/goodlist/reqpridnm" , cmb_reqpridflag.label);
-
- }
-
- // --------------------------------------------------
- // 물품찾기 처리하는 함수
- // --------------------------------------------------
- function fGoodListSearch() {
- misfGridInit(grd_goodlist);
-
- model.setValue( tmpreqdeptcd.attribute("ref") , model.getValue(cmb_reqdeptcd.attribute("ref")) ); //청구부서 물품조회시 추가하는 부분
-
- if(model.getValue(opt_instcd.attribute("ref")).length == 0 )return;
-
- if (cmb_reqflag.value == ""){
- messageBox("청구구분을 선택하십시요!!", "");
- return;
- }
-
- //
- if (model.getValue("/root/send/goodnm") != "") {
- model.setValue("/root/send/indexnm","");
- }
- model.setValue("/root/send/goodlist/reqprid" , "");
- model.setValue("/root/send/goodlist/instcd" , model.getValue(opt_instcd.attribute("ref")));
- model.setValue("/root/send/goodlist/reqflag" , model.getValue(cmb_reqflag.attribute("ref")));
- // model.setValue("/root/send/goodlist/reqprid" , model.getValue(cmb_reqpridflag.attribute("ref")));
-
- //작업구분에 따라서 일반청구인지 처방집계인지 구분
- //청구와 반납일경우는 일반청구 즉 reqcheck Y
- //상비품청구 와 상비품반납일 경우는 처방집계 즉 reqcheck null
-
- model.setValue("/root/send/goodlist/workflag" , "N");
- if (cmb_workflag.value ==3 || cmb_workflag.value ==4 || cmb_workflag.value ==5) {
- model.setValue("/root/send/goodlist/workflag" , "A");
- }
-
- // if (cmb_workflag.value ==1 || cmb_workflag.value ==2 ) {
- // model.setValue("/root/send/goodlist/reqcheck" , "Y"); //청구화면임을 서버에 알리는 Key 값
- // } else if (cmb_workflag.value ==3 || cmb_workflag.value ==4 || cmb_workflag.value ==5) {
- // model.setValue("/root/send/goodlist/reqcheck" , ""); //청구화면임을 서버에 알리는 Key 값
- // model.setValue("/root/send/goodlist/workflag" , "A");
- // } else {
- // model.setValue("/root/send/goodlist/reqcheck" , "Y"); //청구화면임을 서버에 알리는 Key 값
- // }
-
- submit("TRRSD00406");
-
- model.setValue("/root/send/goodlist/reqflag", "");
- grd_goodlist.refresh();
- }
- // 청구부서 Set
- function fReqdeptCopy(){
- var cPath = "/root/init/CopyData"
- var sPath = "/root/main/ReqpsnLists/reqpsnlist";
- var tPath = "/root/init/ReqDeptLists/reqdeptlist";
-
- var iDataCnt = getNodesetCount(sPath);
- if (iDataCnt < 1) {
- return;
- }
-
- model.removeNodeset(tPath);
-
- var Idx = 1;
- var iDataCnt = getNodesetCount(sPath);
- // 청구부서를 세션의 부서와 비교해서 cmb_reqdeptcd.select()를
- // 해당부서와 동일하게 해서 보여지도록 한다. 부서가 없을 경우 0번째 부서가 콤보에 보여짐
- // 사용자의 세션부서가 청구부서의 젤 상단에 위치하도록 노드셋 데이터 수정 하는 부분
-
- if ( model.getValue(sPath+"[reqdeptcd='"+ getUserInfo("dutplcecd") + "']" +"/reqdeptnm") !="") {
- model.setValue(cPath+"/value",model.getValue(sPath+"[reqdeptcd='"+ getUserInfo("dutplcecd") + "']" +"/reqdeptcd"));
- model.setValue(cPath+"/label",model.getValue(sPath+"[reqdeptcd='"+ getUserInfo("dutplcecd") + "']" +"/reqdeptnm"));
-
- model.makeNode(tPath+"["+ Idx +"]" );
- model.copyNode(tPath+"["+ Idx +"]", cPath);
- Idx++;
- }
-
- // 청구부서 Set
- for (var k = 1; k <= iDataCnt; k++){
-
- vReqDept = model.getValue(sPath+"["+k+"]/reqdeptcd");
- vReqDeptNm = model.getValue(sPath+"["+k+"]/reqdeptnm");
-
- if ((vReqDeptNm != "" ) &&
- (model.getValue(tPath+"[value='"+ vReqDept + "']" +"/value") == "") ) {
-
- model.setValue(cPath+"/value",vReqDept );
- model.setValue(cPath+"/label",vReqDeptNm);
-
- model.makeNode(tPath+"["+ Idx +"]" );
- model.copyNode(tPath+"["+ Idx +"]", cPath);
-
- Idx++;
-
- } //end if
- // alert("model.getValue("+tPath+"[value='"+ vReqDept + "']" +"/label) =="+ model.getValue(tPath+"[value='"+ vReqDept + "']" +"/label"));
- } //end for
-
- cmb_reqdeptcd.refresh();
-
- cmb_reqdeptcd.select(0);
-
- fReqpridCopy(); // 청구 주기Set
-
- // fDeptReqNoQuery(); // 청구부서별 청구번호를 조회한다 fReqpridCopy 안에서 실행 제외 시킴 [20090129 YYJ]
- }
- // 청구 주기Set
- function fReqpridCopy(){
- var cPath = "/root/init/CopyData"
- var sPath = "/root/main/ReqpsnLists/reqpsnlist";
- var tPath = "/root/init/ReqpridLists/reqpridlist";
- if (model.getValue(cmb_reqdeptcd.attribute("ref")).length== 0 ) {
- messageBox("청구부서를 " ,"C002");
- model.setFocus("cmb_reqdeptcd");
- return;
- }
-
- var iDataCnt = getNodesetCount(sPath);
- if (iDataCnt < 1) {
- return;
- }
-
- model.removeNodeset(tPath);
-
- var Idx = 1;
- var iDataCnt = getNodesetCount(sPath);
- var tReqDept = model.getValue(cmb_reqdeptcd.attribute("ref"));
-
- for (var k = 1; k <= iDataCnt; k++){
- vReqDept = model.getValue(sPath+"["+k+"]/reqdeptcd");
- if (vReqDept == tReqDept) {
-
- vReqPrid = model.getValue(sPath+"["+k+"]/reqprid"); // 청구주기
- vReqPridNm = model.getValue(sPath+"["+k+"]/reqpridnm"); // 청구주기명
-
- if ((vReqPridNm != "" ) &&
- (model.getValue(tPath+"[value='"+ vReqPrid + "']" +"/value") == "") ) {
- model.setValue(cPath+"/value" ,vReqPrid ); // 청구주기
- model.setValue(cPath+"/label" ,vReqPridNm ); // 청구주기명
-
- model.makeNode(tPath+"["+ Idx +"]" );
- model.copyNode(tPath+"["+ Idx +"]", cPath);
-
- Idx++;
- }
- }
- }
- if (gPurcdeptflag == "P" ) { //구매부서구분 : P
- var codynode = instance1.selectNodes(tPath + "/*");
-
- if (codynode.length < 1) {
- model.setValue(cPath+"/value","1" );
- model.setValue(cPath+"/label","일");
- model.makeNode(tPath+"[1]" );
- model.copyNode(tPath+"[1]" , cPath);
-
- model.setValue(cPath+"/value","4" );
- model.setValue(cPath+"/label","월");
- model.makeNode(tPath+"[2]" );
- model.copyNode(tPath+"[2]" , cPath);
-
- model.setValue(cPath+"/value","2" );
- model.setValue(cPath+"/label","주");
- model.makeNode(tPath+"[3]" );
- model.copyNode(tPath+"[3]" , cPath);
- }
- }
- cmb_reqpridflag.select(0);
-
- cmb_reqpridflag.refresh();
- }
- // 청구승인자 Check
- function fPurcAuthInfo() {
-
- var sPath = "/root/main/ReqpsnLists/reqpsnlist";
-
- var iDataCnt = getNodesetCount(sPath);
-
- if (iDataCnt < 1) {
- return;
- }
-
- model.removeNodeset(tPath);
-
- var iDataCnt = getNodesetCount(sPath);
- var tReqDept = model.getValue(cmb_reqdeptcd.attribute("ref" )); // 청구부서
- var tReqprid = model.getValue(cmb_reqpridflag.attribute("ref")); // 청구주기
-
- for (var k = 1; k <= iDataCnt; k++){
- vReqDept = model.getValue(sPath+"["+k+"]/reqdeptcd");
- vReqprid = model.getValue(sPath+"["+k+"]/reqprid" );
- if ((vReqDept == tReqDept) &&
- (vReqprid == tReqprid) ) {
-
- if (model.getValue(sPath+"["+k+"]/reqaprvflag") == "2") {
- vPurcAuth = "2";
- ckb_accept.value = "Y";
- break;
- }
- }
- }
- }
-
- // 청구부서별 청구번호를 조회한다
- function fDeptReqNoQuery() {
- var vPrintFlag = 0;
-
- // 값이 모두 있을 때 청구 번호를 가져온다.
- vPrintFlag = (ipt_reqdd.value == "" )? 1 : vPrintFlag; // 청구일자
- vPrintFlag = (cmb_reqdeptcd.value == "" )? 1 : vPrintFlag; // 청구부서
- vPrintFlag = (cmb_workflag.value == "" )? 1 : vPrintFlag; // 작업구분
- vPrintFlag = (cmb_reqpridflag.value == "" )? 1 : vPrintFlag; // 청구주기
-
- if (vPrintFlag == 1) return;
- vPrintFlag = (ipt_reqdd.value != gReqdd )? 1 : vPrintFlag; // 청구일자
- vPrintFlag = (cmb_reqdeptcd.value != gReqdeptcd )? 1 : vPrintFlag; // 청구부서
- vPrintFlag = (cmb_workflag.value != gWorkflag )? 1 : vPrintFlag; // 작업구분
- vPrintFlag = (cmb_reqpridflag.value != gReqpridflag)? 1 : vPrintFlag; // 청구주기
-
- if (vPrintFlag == 0) return;
- gReqdd = ipt_reqdd.value ; // 청구일자
- gReqdeptcd = cmb_reqdeptcd.value ; // 청구부서
- gWorkflag = cmb_workflag.value ; // 작업구분
- gReqpridflag = cmb_reqpridflag.value; // 청구주기구분
-
- submit("TRRSD00408");
-
- if (getNodesetCount("/root/main/DeptReqnoLists/reqnolist") < 1 ){
- chk_reqnonew.value = "Y";
- fNewReqNoVisibility();
- } else {
- chk_reqnonew.value = "";
- fNewReqNoVisibility();
-
- cmb_reqno.refresh();
- cmb_reqno.select(0);
- }
- }
- // 청구 구분 Check
- function fReqFlagCheck(){
- if(cmb_reqflag.value == 'H'){
- grd_goodreq.colHidden(grd_goodreq.colRef("rgstqty")) = false;
- }else{
- grd_goodreq.colHidden(grd_goodreq.colRef("rgstqty")) = true;
- }
-
- /* 위의 select(0); 에서 cmb_reqpridflag value가 있으면 reqpridflag xforms-value_changed 가 발생한다.
- */
-
- // opt_goodflag.value = rszfGetGoodFlagByReqFlag(opt_instcd.value,cmb_reqflag.value);
- fGoodListKeySet(); // 물품검색 기본 KEY SET
-
- if (cmb_reqpridflag.value.length == 0 )
- {
- fSetReqAuth();
- btn_search.dispatch("DOMActivate");
- }
-
- //청구 마지막 일자 조회.
- fLastDaySearch();
- //청구일자 기한체크.
- if(fLastDayCheck())
- {
- messageBox("불출부서의 청구일자기한을 벗어났습니다. \n 다시 입력 하세요.", "");
- ipt_reqdd.value = ipt_todd.value;
- return;
- }
- }
- // 청구구분
- var tReqFlagData = "A." // 01 Y 의료소모품
- + "B." // 02 Z 일반소모품
- + "C." // 03 K 의료비품
- + "D." // 04 G 일반비품
- + "E." // 05 P 약품및재료
- + "F." // 06 P 제제약품
- + "G." // 07 E 장비
- + "H." // 08 P 수액
- + "I." // 09 P 조영제
- + "S." // 10 B 수리관리
- + "X." // 11 T 교환물품
- + "Y." // 12 T 청구물품
- + "Z" ; // 13 T 멸균의뢰
-
- var tReqFlag = tReqFlagData.split(".");
-
- // 물품구분
- var tGoodFlagData = "Y." // 01 의료소모품
- + "Z." // 02 일반소모품
- + "U." // 03 의료비품
- + "G." // 04 일반비품
- + "P." // 05 약품
- + "P." // 06 약품
- + "P." // 07 약품및재료
- + "P." // 08 약품
- + "P." // 09 약품
- + "B." // 10 수리부품
- + "T." // 11 공급실물품
- + "T." // 12 공급실물품
- + "T" ; // 13 공급실물품
- var tGoodFlag = tGoodFlagData.split(".");
- var tPath = "/root/init/cmb_goodflag";
- var sPath = "/root/init/cmb_goodflagcopy";
-
- //
- function fReqFagChange(pReqFlag) {
-
- for (i = 0; i < tReqFlag.length; i++) {
- if (tReqFlag[i] == pReqFlag) {
- cmb_goodflag.value = tGoodFlag[i];
- // alert(tGoodFlag[i]);
- cmb_goodflag.refresh();
- break;
- }
- }
-
- // cmb_goodflag.select(0); //청구구분
- }
-
- //부서찾기 기능 설정
- function fSetTempDept() { //부서찾기 기능 설정(구매팀일경우에만)
- if ( gPurcdeptflag == "P"){
- cpt_dept.attribute("visibility") = "visible";
- ipt_tempdeptcd.attribute("visibility") = "visible";
- ipt_tempdeptnm.attribute("visibility") = "visible";
- btn_tempdeptcd.attribute("visibility") = "visible";
-
- }else {
- cpt_dept.attribute("visibility") = "hidden";
- ipt_tempdeptcd.attribute("visibility") = "hidden";
- ipt_tempdeptnm.attribute("visibility") = "hidden";
- btn_tempdeptcd.attribute("visibility") = "hidden"
- }
- }
- //조회해온 부서를 청구부서 콤보에 붙이는 함수
- function fAddReqDeptcdCombo() {
- //tempdeptcd에 값을 reqdetpcd(청구부서) 콤보에 값을 부어준다 (makevaluie)
- var cPath = "/root/init/CopyData" //임시카피노드
- var sPath = "/root/tempdept"; //서버에서가져온부서정보노드
- var tPath = "/root/init/ReqDeptLists/reqdeptlist"; //청구부서 콤보노드
- var iDataCnt = getNodesetCount(sPath); //서버에서 가져온 부서정보노드(무조건 1 아님 0)
- if ( iDataCnt < 1)
- {
- return;
- }
- //model.removeNodeset(tPath);
- var ComboDataCnt = parseInt( getNodesetCount(tPath) ) +1 ; //콤보에 노드길이(숫자형으로형변환)
-
- var vTempDeptCd = model.getValue(sPath+"[1]/tempdeptcd");
- var vTempDeptNm = model.getValue(sPath+"[1]/tempdeptnm");
- if ( vTempDeptCd != "" )
- {
- model.setValue(cPath+"/value" , vTempDeptCd );
- model.setValue(cPath+"/label" , vTempDeptNm );
- model.makeNode(tPath+"["+ComboDataCnt +"]" );
- model.copyNode(tPath + "[" +ComboDataCnt +"]", cPath); //노드에 데이터 부어줌
- cmb_reqdeptcd.refresh();
- cmb_reqdeptcd.select(ComboDataCnt-1);
- }
- cmb_reqdeptcd.refresh();
- }
-
- // 청구내역 조회
- function fQueryReqData() {
-
- if (fCheckRetrieveData(false) == false) return;
-
- misfGridInit(grd_goodreq);
-
- if(model.getValue(cmb_reqno.attribute("ref")).length == 0)
- model.setValue(ipt_reqdd.attribute("ref") , getCurrentDate());
-
- // model.setValue("/root/send/goodreq/retrmaxreqnoyn","Y");
- if (model.getValue(cmb_reqno.attribute("ref")) == "") return;
-
- misfMsterDetailRetrieve();
-
- // 권한여부에 따른 승인체크 설정.
- // fGrantsCheck();
-
- fAfterRetr();
-
- var AprFlag = ""; // 승인구분
-
- for (var fRow = grd_goodreq.fixedRows; fRow < grd_goodreq.rows ; fRow++ ) {
- if (model.getValue(grd_goodreq.nodeset + "[" + fRow + "]/allsizeyn") =="Y") {
- grd_goodreq.cellstyle("background-color" , fRow, 9) = "#FFFF00";
- }
-
- if (grd_goodreq.valueMatrix(fRow, grd_goodreq.colRef("acptflag")) == "Y")
- {
- grd_goodreq.isReadOnly(fRow, grd_goodreq.fixedCols-1, fRow, grd_goodreq.cols-1) = true;
- }
-
- // 2009.02.04 CHR
- AprFlag = fReqAprvCheck(1, model.getValue(grd_goodreq.nodeset + "[" + fRow + "]/reqflag")); // 청구/승인자권한 Check
-
- if (AprFlag == "1") {
- if (gPurcdeptflag == "P" ) { //구매부서구분 : P
- grd_goodreq.isReadOnly(fRow, grd_goodreq.colRef("deptaprvyn")) = true;
- }
- }else{
- grd_goodreq.isReadOnly(fRow, grd_goodreq.colRef("deptaprvyn")) = false;
- }
-
- }
-
- model.refresh();
- }
-
- // 청구/승인자권한 Check 2009.02.04 CHR
- function fReqAprvCheck(pCls, pReqFlag) {
- var sPath = "/root/main/ReqpsnLists/reqpsnlist";
- // gReqdeptcd 청구부서
- // pReqFlag 청구구분
- // gReqpridflag 청구주기이 같은 승인여부
-
- var rAprvflag = model.getValue(sPath+"["+"reqdeptcd ='"+ gReqdeptcd + "' and "
- +"reqprid ='"+ gReqpridflag + "' and "
- +"reqflag ='"+ pReqFlag + "']/reqaprvflag");
- // alert("var "+ rAprvflag+" = model.getValue("+sPath+"["+"reqdeptcd ='"+ gReqdeptcd + "' and "
- // +"reqprid ='"+ gReqpridflag + "' and "
- // +"reqflag ='"+ pReqFlag + "']/reqaprvflag)");
- //
- if (pCls == 0) return rAprvflag;
-
- if (rAprvflag == ""){
- rAprvflag ="1";
- }
-
- return rAprvflag;
- }
-
- // 물품선택 On Click 2009.02.04 CHR
- function fSearchGoodOnClick(pGrid, pRow) {
-
- if (pGrid.row < 1 ) return;
- if (model.getValue(pGrid.nodeset + "[" + pRow + "]/select" ) == "true") {
- AprFlag = fReqAprvCheck(0, model.getValue(pGrid.nodeset + "[" + pRow + "]/reqflag")); // 물품청구 권한 Check
- if ((AprFlag == "" ) ||
- (model.getValue(pGrid.nodeset + "[" + pRow + "]/reqprid") != gReqpridflag)
- )
- {
- if (gPurcdeptflag == "P" ) { //구매부서구분 : P
- model.setValue(pGrid.nodeset + "[" + pRow + "]/select" , "false");
- alert("청구 불가능!! 청구권한(청구주기,청구구분)을 확인하십시요 !!");
- return;
- }
- }
- }
-
- // reqmthd 청구방법 1:처방,2:정량,3:일반
- // purcflag 구매구분 1:구매,2:수탁,3:가납
-
- if (cmb_workflag.value ==3 || cmb_workflag.value ==4 || cmb_workflag.value ==5 ) {
- if ((model.getValue(pGrid.nodeset + "[" + pRow + "]/reqmthd" ) != "1") &&
- (model.getValue(pGrid.nodeset + "[" + pRow + "]/purcflag") != "2") ) {
-
- model.setValue(pGrid.nodeset + "[" + pRow + "]/select" , "false");
-
- alert("상비품이 아닙니다. 확인하십시요!!");
- }
- }
-
- return;
- }
-
- /* ------------------------------------------------- */
- /* ------End Of List ------------------------------- */
- /* -------------------------------------------------- */
|