1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729 |
- <?xml version="1.0" encoding="utf-8"?>
- <Script type ="xscript4.0"><![CDATA[// =================================================================================================
- // - 2009.04.27 Creation JHP
- //==================================================================================================
- /* --------------------------------------------------------------------------------------------------
- Fucntion Name || Description
- -----------------------------------------------------------------------------------------------------
- 2009.07.23 JHP
- 심사화면 환자 메세지 여부확인: fGetPatMsgYn
- 환자기준 전송메세지작성 : fPatJudgPatMsgTrsm
- 처방기준 전송메세지작성 : fOrderJudgPatMsgTrsm
- 해당건 환자 전체 메세지 보기 : fJudgPatMsgTrsmRef
- 2009.08.13 JHP
- 처방사유조회 : fPrcpResnRef
- 환자번호 첫자리 문자인경우 환자번호로 인식 fChkPidWordNumber
- */
- // 수정이력 :
- // 20090811 수정추가 JHP, 변경요청 858 재원심사에서 계산처방 조회시 진료과는 전체로 넘겨야함. 하여 기존 것. 주석, 빈값 넘김으로 수정
- // 20090811 수정추가 JHP, 변경요청 858 재원심사에서 계산처방 조회시 진료과는 전체로 넘겨야함. 진료과별 의사를 보기때문에 의사도 일단 전체로 해놓음.
- // 20090817 수정추가 JHP, 수정요청 계산처방시행조회 화면 edicd 조회조건에 존재하기에 추가함. 없으면 singlenode 에러남.
- var VAL_today = utlf_getCurrentDate();
- var VAL_fromdd = VAL_today.toDate().getAddDate(-6,"M").getDateFormat("YYYYMM");
- var VAL_userid = sysf_getUserId();
- var VAL_usernm = sysf_getUserName();
- function fOpenSMPIS00500Detail() {
- dsf_makeValue( ds_hidden_smpis00500_cond, "patunitsrch", "string", ds_main_item1_iteminfo.getColumn(0, "pid"));
- dsf_makeValue( ds_hidden_smpis00500_cond, "code", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));
- dsf_makeValue( ds_hidden_smpis00500_cond, "datecond", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "fromdd", "string", ds_main_item1_iteminfo.getColumn(0, "indd1"));
- dsf_makeValue( ds_hidden_smpis00500_cond, "todd", "string", ds_main_item1_iteminfo.getColumn(0, "dschdd"));
- dsf_makeValue( ds_hidden_smpis00500_cond, "ioflag", "string", "I");
- dsf_makeValue( ds_hidden_smpis00500_cond, "orddeptcd", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "orddrid", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "codecond", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "judgrid", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "cancer", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "large", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "middle", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "small", "string", "");
- dsf_makeValue( ds_hidden_smpis00500_cond, "edicd", "string", "");
- // frmf_modal("SMPIS00500", "SMPIS00500", "ds_hidden_smpis00500_cond""-"ds_send"", "", "1", "10", "10", "", "", "", "", "", "M");
- }
- function fOpenSMPIS00600Detail() {
- fOpenSMPIS00600Call("false");
- }
- function fOpenSMPIS00600Detail2() {
- fOpenSMPIS00600Call("true");
- }
- function fOpenSMPIS00600Call(cutonly) {
- dsf_makeValue( ds_hidden_smpis00600_cond, "patunitsrch", "string", ds_main_item1_iteminfo.getColumn(0, "pid"));
- dsf_makeValue( ds_hidden_smpis00600_cond, "code", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamym", "string", "");
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamymfrom", "string", VAL_fromdd);
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamdgfrom", "string", "");
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamymto", "string", VAL_today);
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamdgto", "string", "");
- dsf_makeValue( ds_hidden_smpis00600_cond, "clamflag", "string", "");
- dsf_makeValue( ds_hidden_smpis00600_cond, "ioflag", "string", "I");
- dsf_makeValue( ds_hidden_smpis00600_cond, "insukind", "string", ds_main_item1_iteminfo.getColumn(0, "insukindcd"));
- dsf_makeValue( ds_hidden_smpis00600_cond, "orddeptcd", "string", ds_main_item1_iteminfo.getColumn(0, "orddeptcd"));
- dsf_makeValue( ds_hidden_smpis00600_cond, "orddrid", "string", ds_main_item1_iteminfo.getColumn(0, "medispclid"));
- dsf_makeValue( ds_hidden_smpis00600_cond, "cutonly", "string", cutonly);
- frmf_modal("SMPIS00600", "SMPIS00600", "ds_hidden_smpis00600_cond""-"ds_send"", "", "1", "10", "10", "", "", "", "", "", "M");
- }
- /* 환자기준 전송메세지작성, JHP. 2009.07.16 */
- function fPatJudgPatMsgTrsm() {
- if (!utlf_isNull(ds_main_item1_iteminfo.getColumn(0, "pid"))) {
- fMsgTrsmMakeNode("P");
- } else {
- sysf_messageBox("기본정보가 ", "I004");
- }
- //model.refresh();
- frmf_modal("SPPIZ01900_심사환자메세지작성", "", "ds_tmp_msgtrsm_info""-"ds_main_patinfo"", "", "", "400", "300", "", "", "", "", "", "M");
- ds_tmp_msgtrsm.clearData();
- }
- /* 처방기준 전송메세지작성, JHP. 2009.07.16 */
- function fOrderJudgPatMsgTrsm() {
- if (!utlf_isNull(ds_main_item1_iteminfo.getColumn(0, "pid"))) {
- if(grd_ordlist.row <= 0){
- return;
- }
- fMsgTrsmMakeNode("O");
- } else {
- sysf_messageBox("기본정보가 ", "I004");
- }
- //model.refresh();
- frmf_modal("SPPIZ01900_심사환자메세지작성", "", "ds_tmp_msgtrsm_info""-"ds_main_patinfo"", "", "", "400", "300", "", "", "", "", "", "M");
- ds_tmp_msgtrsm.clearData();
- }
- function fMsgTrsmMakeNode(kindflag) {
- // 인스턴스생성
- dsf_makeValue( ds_tmp_msgtrsm_info, "instcd", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "msgwrtedd", "string", VAL_today);
- dsf_makeValue( ds_tmp_msgtrsm_info, "msgwrteno", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "msgwrtehistno", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "histstat", "string", "Y");
- dsf_makeValue( ds_tmp_msgtrsm_info, "pid", "string", ds_main_item1_iteminfo.getColumn(0, "pid"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddd", "string", ds_main_item1_iteminfo.getColumn(0, "indd1"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "cretno", "string", ds_main_item1_iteminfo.getColumn(0, "cretno"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "mskind", "string", ds_main_item1_iteminfo.getColumn(0, "mskind"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddeptcd", "string", ds_main_item1_iteminfo.getColumn(0, "orddeptcd"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddrid", "string", ds_main_item1_iteminfo.getColumn(0, "medispclid"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddrnm", "string", ds_main_item1_iteminfo.getColumn(0, "medispclnm"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "ordtype", "string", "I");
- dsf_makeValue( ds_tmp_msgtrsm_info, "ordqty", "string", 0);
- dsf_makeValue( ds_tmp_msgtrsm_info, "ordtims", "string", 0);
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddays", "string", 0);
- dsf_makeValue( ds_tmp_msgtrsm_info, "rgstrid", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "rgstdd", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "rgsttm", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "sendphone", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "anybodyyn", "string", "N");
- dsf_makeValue( ds_tmp_msgtrsm_info, "sendflag", "string", "O");
- dsf_makeValue( ds_tmp_msgtrsm_info, "senddate", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "sendid", "string", VAL_userid);
- dsf_makeValue( ds_tmp_msgtrsm_info, "deliveid", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "recvdate", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "recvid", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "recvcnfmyn", "string", "N");
- dsf_makeValue( ds_tmp_msgtrsm_info, "recvcnfmid", "string", VAL_userid);
- dsf_makeValue( ds_tmp_msgtrsm_info, "sendmsg", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "recvmsg", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "fstrgstrid", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "fstrgstdt", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "lastupdtrid", "string", "");
- dsf_makeValue( ds_tmp_msgtrsm_info, "lastupdtdt", "string", "");
- if (kindflag == "P") {
- dsf_makeValue( ds_tmp_msgtrsm_info, "kindflag", "string", kindflag);
- dsf_makeValue( ds_tmp_msgtrsm_info, "grupcalcscorcd", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "snglcalcscorcd", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcpdd", "string", "-");
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcpno", "string", 0);
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcppayflag", "string", "-");
- } else if (kindflag == "O") {
- dsf_makeValue( ds_tmp_msgtrsm_info, "kindflag", "string", kindflag); // 처방기준 'O', chk
- dsf_makeValue( ds_tmp_msgtrsm_info, "grupcalcscorcd", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("grupcalcscorcd"))); //chk
- dsf_makeValue( ds_tmp_msgtrsm_info, "snglcalcscorcd", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));; //chk
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcpdd", "string", ""); // 서버단에서 조회하여 가져와야함. chk(입원만)
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcpno", "string", ""); // 서버단에서 조회하여 가져와야함. chk(입원만)
- dsf_makeValue( ds_tmp_msgtrsm_info, "prcppayflag", "string", ""); // 서버단에서 조회하여 가져와야함. chk (입원만)
- }
- }
- // 환자 전체 메세지 내용 조회하여 하나씩 보기.
- function fJudgPatMsgTrsmRef(){
- dsf_makeValue( ds_tmp_msgtrsm_info, "refyn", "string", "Y");
- dsf_makeValue( ds_tmp_msgtrsm_info, "pid", "string", ds_main_item1_iteminfo.getColumn(0, "pid"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddd", "string", ds_main_item1_iteminfo.getColumn(0, "indd1"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "cretno", "string", ds_main_item1_iteminfo.getColumn(0, "cretno"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "mskind", "string", ds_main_item1_iteminfo.getColumn(0, "mskind"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddeptcd", "string", ds_main_item1_iteminfo.getColumn(0, "orddeptcd"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "orddrid", "string", ds_main_item1_iteminfo.getColumn(0, "medispclid"));
- dsf_makeValue( ds_tmp_msgtrsm_info, "ordtype", "string", "I");
- frmf_modal("SMPIJ02600_메세지현황", "", "ds_tmp_msgtrsm_info""-"ds_init_openchk"", "", "", "100", "100", "", "", "", "", "", "M");
- ds_tmp_msgtrsm.clearData();
- }
- // 처방사유조회
- // history.. 진료에 있는화면 기본조건으로 팝업사용..YS(윤샘)요청
- function fPrcpResnRef(){
- // 세션값 받기
- dsf_makeValue( ds_tmp_prcpresnref_info, "pid", "string", ds_main_item1_iteminfo.getColumn(0, "pid")); // 등록번호
- dsf_makeValue( ds_tmp_prcpresnref_info, "fromdd", "string", ds_main_item1_iteminfo.getColumn(0, "indd1")); // 처방시작일 default indd
- dsf_makeValue( ds_tmp_prcpresnref_info, "todd", "string", ds_main_item1_iteminfo.getColumn(0, "dschdd")); // 처방종료일 default dschdd
- dsf_makeValue( ds_tmp_prcpresnref_info, "orddeptcd", "string", "-"); // 진료과 : 주진료과
- dsf_makeValue( ds_tmp_prcpresnref_info, "orddrid", "string", "-"); // 주치의 : default "-"
- dsf_makeValue( ds_tmp_prcpresnref_info, "mainjudgid", "string", "-"); // 심사자 : 현재심사자
- dsf_makeValue( ds_tmp_prcpresnref_info, "prcpcd", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("grupcalcscorcd"))); // 수가코드 : 그룹코드
- dsf_makeValue( ds_tmp_prcpresnref_info, "insukind", "string", ds_main_item1_iteminfo.getColumn(0, "insukindcd")); // 보험유형 : 환자보험유형
- dsf_makeValue( ds_tmp_prcpresnref_info, "ioflag", "string", "I"); // 내원유형 : default "-"
- dsf_makeValue( ds_tmp_prcpresnref_info, "resncd", "string", "FF"); // 사유구분 : default "FF" 중복처방
- dsf_makeValue( ds_tmp_prcpresnref_info, "popup", "string", "judg"); // 팝업사용처구분 : judg(심사)
- frmf_modal("SPMMO19000_중복처방사유조회", "", "ds_tmp_prcpresnref_info""-"ds_tmp_prcpresnref_info"", "", "", "400", "300", "", "", "", "", "", "M");
- ds_tmp_prcpresnref.clearData();
- }
- // 환자번호 문자 숫자 여부 판단. (isNaN 숫자가아닐경우 true, isFinite 숫자일경우 true)
- // 성가환자번호중 첫글자가 문자인경우가 있어서 판단함.
- // 현재 재원메인은 적용안함. 대상자조회만 따로 화면에 적용함.
- function fChkPidWordNumber(pid)
- {
- if( typeof( this ) == "undefined" ) return false;
- if( this.length == 0 ) return false;
- var thisSting = pid.toString();
- var firstpid = "";
- for( var i=0; i < thisSting.length; i++ ){
- var thisNumber = thisSting.substring( i, i+1 );
- // 숫자가 아니면
- if( isNaN( thisNumber ) ) firstpid = firstpid + 'W';
- // 숫자면
- if( isNaN( thisNumber ) == false ) firstpid = firstpid + 'N';
- // 공백이면 FALSE 리턴
- if( " " == thisNumber ) firstpid = firstpid + 'L';
- }
- var firstpidYN = firstpid.substring( 0, 2 );
- // 첫번째 두번째 글자 여부
- // 문자숫자, 숫자숫자 : pid로 판단 : true
- // 문자문자, 숫자문자 : 글자로 판단 : false
- // 그외 : 글자로 판단 : false
- if ( firstpidYN == "WN"){ return true}
- else if ( firstpidYN == "NN"){ return true}
- else if ( firstpidYN == "WW"){ return false}
- else if ( firstpidYN == "NW"){ return false}
- else { return false }
- }
- // 처방 Grid 마우스 오른쪽 "처방주석입력"
- function fOrderGridInsertCmt() {
- var rdounitflag = ds_send.getColumn(0, "unitflag");
- var pid = ds_main_item1_iteminfo.getColumn(0, "pid");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var rows = grd_clcjlist.rows;
- if (rdounitflag == "M") {
- // 줄단위로 셋팅하고 처리
- model.setValue(rdo_unitflag.attribute("ref"), "J");
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'J']";
- grd_clcjlist.rebuild();
- // 단위에 에 따라 해당 행있는 특정코드 콤보 재설정
- for (var i=1; i< rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var status = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("status"));
- if (status != "") {
- grd_clcjlist.rowStatus(i) = status;
- }
- if (unitflag == "M") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M'' and cdid != 'MX999']";
- } else if (unitflag == "J") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J']";
- }
- }
- }
- ds_hidden_sppij00500_rslt.clearData(); // SPPIJ00500_특정내역상세관리 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_sppij00500_cond.clearData();
- for (var k=0; k < grd_ordlist.selectedRows; k++ ) {
- var row = grd_ordlist.selectedRow(k);
- var edicd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("edicd"));
- var calcscorcd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("snglcalcscorcd"));
- if (edicd) {
- } else {
- sysf_messageBox("EDI코드가 없는 경우 해당 줄단위 특정내역이", "I004"); ///EDI코드가 없는 경우 해당 줄단위 특정내역이 없습니다.
- return;
- }
- }
- var rowcnt = 1;
- var setrow = 0;
- for (var k=0; k < grd_ordlist.selectedRows; k++ ) {
- var row = grd_ordlist.selectedRow(k);
- var edicd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("edicd"));
- var calcscorcd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("snglcalcscorcd"));
- if (rows == 1) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "edicd", "string", edicd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "J");
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "I");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", "JX999");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", "X(700)");
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd);
- } else if (getNodesetCount(grd_clcjlist.nodeset+"[calcscorcd='"+calcscorcd+"']") == 0) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "edicd", "string", edicd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "J");
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "I");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", "JX999");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", "X(700)");
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "pid", pid);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "indd", indd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "edicd", edicd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "unitflag", "J");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "flag", "I");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcd", "JX999");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcdnm", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclspec", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "remfact", "X(700)");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "rownum", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", calcscorcd);
- rowcnt = rowcnt+1;
- } else {
- for (var i=1; i<rows; i++) {
- var clcjedicd = grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("edicd"));
- var spclcd = grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd"));
- if ( edicd == clcjedicd) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "flag", "U");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "edicd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("edicd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "detldesc", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("detldesc")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcdnm", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclspec", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "remfact", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("remfact")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "rownum", i);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "unitflag", "J")
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclspec", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("calcscorcd")));
- rowcnt = rowcnt+1;
- // 특정내역 상세 화면에 보여줄 특정내역 선택
- setrow = i;
- }
- dsf_makeValue( ds_hidden_sppij00500_cond, "edicd", "string", edicd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "J");
- if ( ds_main_list4_clcjlist.getColumn(setrow, "spclcd")) == "JX999" ) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "U");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("spclcd")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("detldesc")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("spclspec")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("remfact")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", setrow);
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("calcscorcd")));
- } else {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "I");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", "JX999");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", "X(700)");
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd);
- }
- }
- }
- }
- ds_hidden_sppij00500_rslt.clearData();
- frmf_modal("SPPIJ00500", "SPPIJ00500", "ds_hidden_sppij00500""-"ds_hidden_clcj"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIJ00500_특정내역상세관리.xrw
- var rsltcnt = ds_hidden_sppij00500_rslt_list.rowcount;
- // 처리 건수
- if (rsltcnt > 0) {
- for(var i=rsltcnt; i>0; i--) {
- var flag = ds_hidden_sppij00500_rslt_list.getColumn(i, "flag");
- var rownum = ds_hidden_sppij00500_rslt_list.getColumn(i, "rownum");
- var edicd = ds_hidden_sppij00500_rslt_list.getColumn(i, "edicd");
- var newspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcd");
- var newspclcdnm = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcdnm");
- var newspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclspec");
- var newremfact = model.getValue("ds_hidden_sppij00500_rslt_list["+ i +"]_remfact ");
- var newdetldesc = ds_hidden_sppij00500_rslt_list.getColumn(i, "detldesc");
- var newdcalcscorcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "calcscorcd");
- var oldspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclcd");
- var oldspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclspec");
- // 특정코드 추가인 경우
- if (flag == "I") {
- var clcjrow = grd_clcjlist.rows - 1; // 특정내역 Grid 가장 마지막 줄에 추가한다.
- grd_clcjlist.insertRow(clcjrow++, true,false,false);
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("pid")) = ds_send.getColumn(0, "pid");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("indd")) = ds_send.getColumn(0, "indd");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("cretno")) = ds_send.getColumn(0, "cretno");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("fromdd")) = ds_send.getColumn(0, "fromdd");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("mskind")) = ds_send.getColumn(0, "mskind");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("unitflag")) = "J";
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("edicd")) = edicd;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("calcscorcd")) = newdcalcscorcd
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclmemoflag")) = "E";
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("status")) = "3";
- // 처방Grid에서도 해당 줄단위 특정내역의 'T' 컬럼의 "*" 를 표시한다.
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "*");
- //
- //model.refresh();
- 최적화 문제로 변경 - 20080731 박창원
- //model.refreshpart("ds_main_list2_iscllist_text");
- }
- }
- // 특정코드 변경인 경우
- } else if (flag == "U") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("calcscorcd")) = newdcalcscorcd;
- if ( grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) != "3") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "0";
- }
- //
- //model.refresh();
- 최적화 문제로 변경 - 20080731 박창원
- model.refreshpart("ds_main_list4_clcjlist");
- // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
- if (oldspclcd != newspclcd || oldspclspec != newspclspec || grd_clcjlist.rowstatus(row) == 4) {
- var rowstatus = grd_clcjlist.rowstatus(rownum);
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- } else {
- grd_clcjlist.rowstatus(rownum) = 2; // 2 : update 상태로 stat를 변경한다.
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "2";
- }
- }
- // 처방Grid에서도 해당 줄단위 특정내역의 'T' 컬럼의 "*" 를 표시한다.
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "*");
- //
- //model.refresh();
- 최적화 문제로 변경 - 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist_text");
- }
- }
- ds_hidden_item1.setColumn( 0, "message", "특정코드 - "+ newspclcd +" / 특정내역 : "+ newspclspec +" / 기재형식 : "+ newremfact);
- model.refreshpart("ds_hidden_item1_message");
- // 특정코드 삭제인 경우
- } else if (flag == "D" && rownum != "" ) {
- var cnt = 0;
- for (var j = 1; j < grd_clcjlist.rows; j++) {
- var clcjedicd = ds_main_list4_clcjlist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- if (grd_clcjlist.rowstatus(j) != 4) {
- cnt++;
- }
- }
- }
- if (cnt > 0) {
- } else {
- grd_ordlist.valueMatrix(row, grd_ordlist.colref("text")) = "";
- //model.resetInstanceNode("ds_main_list2_iscllist["+ row +"]_text");
- }
- // 특정내역 Grid에서 삭제
- var rowstatus = grd_clcjlist.rowstatus(rownum);
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(rownum, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(rownum) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- grd_clcjlist.row = rownum;
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "");
- //
- //model.refresh();
- 최적화 문제로 변경 - 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist_text");
- }
- }
- } // 특정 코드 상태 따른 if end
- } // for end
- var rdounitflag = ds_send.getColumn(0, "unitflag");
- if (rdounitflag == "-") {
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var delstatus = grd_clcjlist.rowStatus(i);
- var delspclspec = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec"));
- if (delstatus == 1 || delstatus == 3) { // 0 : new, 3 : insert & new
- if (delspclspec == "") {
- grd_clcjlist.deleteItem(i);
- }
- }
- }
- // 입력행 추가
- fSpclGridInsertRow();
- } else if (rdounitflag == "M") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'M']";
- grd_clcjlist.rebuild();
- } else if (rdounitflag == "J") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'J']";
- grd_clcjlist.rebuild();
- }
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var status = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("status"));
- if (status != "") {
- grd_clcjlist.rowStatus(i) = status;
- }
- if (unitflag == "M") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M' and cdid != 'MX999']";
- } else if (unitflag == "J") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J']";
- }
- }
- //fSaveClcjList();
- } // 처리 건수 if end
- //
- //model.refresh();
- 최적화 문제로 변경 - 20080731 박창원
- }
- //재원심사 인적사항, 보험내역, 상병, 금액내역을 갖고 온다.
- function fGetItemInfo(paramFlag){
- // 읽기전용을 위한 변수
- var readonly = ds_send.getColumn(0, "readonly");
- // 오픈일자를 가져옴 - 하드코딩 제거 20090302 박창원, 의정부,여의도,성가,빈센트를 위해서 예외작업함 나중에 제거필요
- var opendd = ds_main_item1_iteminfo.getColumn(0, "opendd");
- fSpclGridInsertRow();
- // 20080811 자동으로 상병줄추가 제외하기로함
- fDiagGridInsertRow();
- //응급 6시간 미만 체크를 위하여 넣어 둔다.
- var ordtype = ds_main_item1_iteminfo.getColumn(0, "ordtype");
- var brateflag = ds_main_item1_iteminfo.getColumn(0, "brateflag");
- ds_send.setColumn( 0, "ordtype",ordtype);
- ds_send.setColumn( 0, "brateflag",brateflag);
- //본인부담율이 20%가 아닌 경우 상단정보에 보조유형정보를 붉은 색으로 표시해준다.
- var insukind = ds_main_item1_iteminfo.getColumn(0, "insukindcd");
- var payownbrate = ds_main_item1_iteminfo.getColumn(0, "ownrate");
- // 마이그레이션 환자는 조회만 되게 한다. - 20080819 박창원
- var mig = ds_main_item1_iteminfo.getColumn(0, "mig");
- var dschjudgprcsstat = ds_main_item1_iteminfo.getColumn(0, "dschjudgprcsstat");
- var indschacptstat = ds_main_item1_iteminfo.getColumn(0, "indschacptstat");
- var dschnotiyn = ds_main_item1_iteminfo.getColumn(0, "dschnotiyn");
- var dschdclrtyn = ds_main_item1_iteminfo.getColumn(0, "dschdclrtyn");
- // AS-IS 데이터가 비정상적인 액팅이 되었을때 alert - 20081013 박창원 - 한시적 루틴
- var abnormalactingyn = ds_main_item1_iteminfo.getColumn(0, "abnormalactingyn");
- var abnormalexip = ds_main_item1_iteminfo.getColumn(0, "abnormalexip");
- var abnormaliscl = ds_main_item1_iteminfo.getColumn(0, "abnormaliscl");
- var indate = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var spcdrugyn = ds_main_item1_iteminfo.getColumn(0, "spcdrugyn") ;
- var dcuc = ds_main_item1_iteminfo.getColumn(0, "dcuc");
- // 명단위, 줄단위에 따라 특정코드 콤보 리스트 변경 및 특정코드에 해당하는 상세설명 적용
- var p0117list = instance1.selectSingleNode("ds_init_P0117list");
- for (var i=0; i<grd_clcjlist.rows; i++) {
- var unitflag = ds_main_list4_clcjlist.getColumn(i, "unitflag");
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- if (unitflag == "M") {
- if (p0117list != null) {
- var p0117 = p0117list.childNodes;
- for (var j = 1; j <= p0117.length; j++) {
- var cdid = ds_init_P0117list_P0117.getColumn(j, "cdid");
- if (cdid == spclcd) {
- ds_main_list4.setColumn( i , "detldesc", ds_init_P0117list_P0117.getColumn(j, "detldesc"));
- j = p0117.length + 1;
- }
- }
- }
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M' and cdid != 'MX999']";
- } else if (unitflag == "J") {
- if (p0117list != null) {
- var p0117 = p0117list.childNodes;
- for (var j = 1; j <= p0117.length; j++) {
- var cdid = ds_init_P0117list_P0117.getColumn(j, "cdid");
- if (cdid == spclcd) {
- ds_main_list4.setColumn( i , "detldesc", ds_init_P0117list_P0117.getColumn(j, "detldesc"));
- j = p0117.length + 1;
- }
- }
- }
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J']";
- }
- }
- }
- // 처방내역을 갖고 온다.
- function fGetIsclList_FromTo(){
- //ds_send.clearData(); ds_send.addRow();
- var ordfromdd = ds_send.getColumn(0, "ordfromdd");
- var ordtodd = ds_send.getColumn(0, "ordtodd");
- //처방조회 시작일자와 종료일자가 없는 경우 보험내역 시작 종료일로 셋팅해 준다.
- if(ordfromdd == ""){
- ds_send.setColumn( 0, "ordfromdd", ds_send.getColumn(0, "fromdd"));
- }
- if(ordtodd == ""){
- ds_send.setColumn( 0, "ordtodd", ds_send.getColumn(0, "todd"));
- }
- if(ipt_pid.text.length >0) {
- var row = grd_ordlist.row;
- ds_main_list2_iscllist.clearData();
- //grd_ordlist.refresh();
- // submit("TRPIJ00302");
- var oParam = {};
- oParam.id = "TRPIJ00302";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqGetInHospJudgIscl";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=iscllist";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00302";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00302(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00302(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00302") > -1
- arErrorCode.pop("TRPIJ00302") < 0
- */
- //
- //model.refresh();
- 최적화 문제로 대체
- //model.refreshpart("ds_main_list2_iscllist");
- grd_ordlist.row = row;
- grd_ordlist.topRow = row - 3;
- //처방조회 옵션에 항목구분에 처방이 있는 것만 Bold로 보여준다.
- fSetItemBold();
- } else {
- sysf_messageBox("환자번호를","C001");
- return;
- }
- }
- // 진료비 계산내역을 갖고 온다.
- function fGetCalc(){
- if(ipt_pid.text.length >0)
- {
- ds_main_item2_itemcalc.clearData(); ds_main_item2_itemcalc.addRow();
- var totalsumflag = ds_send.getColumn(0, "totalsumflag");
- if(!totalsumflag){
- ds_send.setColumn( 0, "totalsumflag","N");
- }
- // submit("TRPIJ00303");
- var oParam = {};
- oParam.id = "TRPIJ00303";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqGetInHospJudgCalc";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=itemcalc";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00303";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00303(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00303(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00303") > -1
- arErrorCode.pop("TRPIJ00303") < 0
- */
- if(!totalsumflag){
- ds_send.setColumn( 0, "totalsumflag","");
- }
- }else
- {
- //sysf_messageBox("환자번호를","C001");
- return;
- }
- }
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //상병처리 관련 코딩 시작 //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // 상병 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "상병순서 위로"
- function fDiagSeqUp() {
- var rowstatus = grd_diaglist.rowstatus(grd_diaglist.row);
- if (rowstatus == 4) { // 4 : delete
- return;
- }
- var diagseq = parseInt(ds_main_list3_diaglist.getColumn(grd_diaglist.row, "seqno"))); // 선택된 줄의 NO
- if (diagseq > 1) { // 첫번째 줄이 아닌 경우
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_seqno", --diagseq);
- if (rowstatus == 0 || rowstatus == 2) {
- grd_diaglist.rowstatus(grd_diaglist.row) = 2; // 2 : update
- }
- // 바로 위 상병순서와 중복되는 경우
- var nextrow = grd_diaglist.row - 1;
- var nextdiagseq = ds_main_list3_diaglist.getColumn(nextrow, "seqno"));
- if (diagseq == nextdiagseq) {
- ds_main_list3.setColumn( nextrow , "seqno", ++diagseq);
- // rowstatus = grd_diaglist.rowstatus(nextrow);
- // if (rowstatus == 0 || rowstatus == 2) {
- // grd_diaglist.rowstatus(nextrow) = 2; // 2 : update
- // }
- }
- fSortDiagNo();
- }
- }
- // 상병 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "상병순서 아래로"
- function fDiagSeqDown() {
- var rowstatus = grd_diaglist.rowstatus(grd_diaglist.row);
- if (rowstatus == 4) { // 4 : delete
- return;
- }
- // 삭제 상태가 아닌 마지막 줄을 찾는다.
- var lastRow = grd_diaglist.rows - 1;
- for (var i = 1; i < grd_diaglist.rows; i++) {
- if (grd_diaglist.rowstatus(i) == 4) { // delete
- lastRow = i - 1;
- i = grd_diaglist.rows;
- }
- }
- var diagseq = parseInt(ds_main_list3_diaglist.getColumn(grd_diaglist.row, "seqno"))); // 선택된 줄의 NO
- if (diagseq < lastRow) { // 마지막 줄이 아닌 경우
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_seqno", ++diagseq);
- if (rowstatus == 0 || rowstatus == 2) {
- grd_diaglist.rowstatus(grd_diaglist.row) = 2; // 2 : update
- }
- // 바로 아래 상병순서와 중복되는 경우
- var nextrow = grd_diaglist.row + 1;
- var nextdiagseq = ds_main_list3_diaglist.getColumn(nextrow, "seqno"));
- if (diagseq == nextdiagseq) {
- ds_main_list3.setColumn( nextrow , "seqno", --diagseq);
- }
- fSortDiagNo();
- }
- }
- // "상병순서 위로_아래로" 순서 변경 후에 상병 순서 NO에 따라 sorting 작업
- function fSortDiag() {
- var maxRow = parseInt(grd_diaglist.rows) - 1; // rows는 타이틀부분 부터 개수를 센다
- grd_diaglist.sort(1, 1, maxRow, 1) = "asc"; // 타이틀을 제외한 data 부분의 첫 줄의 row = 1
- //
- //model.refresh();
- 최적화문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list3_diaglist");
- // Sort 된 Grid 상의 Data 순서와 Instance Node 상의 Data 순서를 동일하게 맞춰준다.
- grd_diaglist.gridToInstance();
- }
- // "상병순서 위로_아래로" 순서 변경 후에 상병 순서 NO에 따라 sorting 작업
- function fSortDiagNo2() {
- var delcnt = 0;
- for (var i = 1; i < grd_diaglist.rows; i++) {
- grd_diaglist.rowHidden(i) = false;
- }
- var cldino = 1;
- for (var i = 1; i < grd_diaglist.rows; i++) {
- ds_main_list3.setColumn( i , "seqno", i);
- rowstatus = grd_diaglist.rowstatus(i);
- }
- var maxRow = parseInt(grd_diaglist.rows) - 1; // rows는 타이틀부분 부터 개수를 센다
- grd_diaglist.sort(1, grd_diaglist.colRef("seqno"), maxRow , grd_diaglist.colRef("seqno")) = "asc"; // 타이틀을 제외한 data 부분의 첫 줄의 row = 1 / col = 3 : no
- if (delcnt > 0) {
- grd_diaglist.sort(1, grd_diaglist.colRef("seqno"), maxRow - delcnt, grd_diaglist.colRef("seqno")) = "asc"; // 타이틀을 제외한 data 부분의 첫 줄의 row = 1 / col = 3 : no
- }
- // Sort 된 Grid 상의 Data 순서와 Instance Node 상의 Data 순서를 동일하게 맞춰준다.
- grd_diaglist.gridToInstance();
- var rowstatus;
- for (var i = 1; i < grd_diaglist.rows; i++) {
- rowstatus = grd_diaglist.rowstatus(i);
- if (rowstatus > 3) { // 삭제상태
- grd_diaglist.rowHidden(i) = true;
- } else {
- grd_diaglist.rowHidden(i) = false;
- }
- }
- }
- function fSortDiagNo() {
- var maxRow = parseInt(grd_diaglist.rows) - 1; // rows는 타이틀부분 부터 개수를 센다
- grd_diaglist.sort(1, 1, maxRow, 1) = "asc"; // 타이틀을 제외한 data 부분의 첫 줄의 row = 1
- //
- //model.refresh();
- 최적화문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list3");
- // Sort 된 Grid 상의 Data 순서와 Instance Node 상의 Data 순서를 동일하게 맞춰준다.
- grd_diaglist.gridToInstance();
- //루핑을 돌면서 순번을 맞춰주고, 모두 insert모드로 바꿔준다.
- //상병은 History를 남기지 않고 그냥 모두 삭제 후 다시 insert로 처리한다.
- //상병 순번이 key라서 update로 하면 바뀐 seq입력시 기존것이 아직 안바뀌었으면 Dup에러 발생함으로.
- for(i =1; i<grd_diaglist.rows;i++){
- ds_main_list3.setColumn( i , "seqno", i);
- grd_diaglist.rowstatus(i) = 1;
- }
- }
- function fDiagGridAddRow(addyn, selectyn) {
- var iInsertRow = 0;
- if (grd_diaglist.rows == 1 || addyn == "Y") {
- iInsertRow = grd_diaglist.row;
- grd_diaglist.addRow(false, false);
- } else {
- iInsertRow = grd_diaglist.row;
- grd_diaglist.insertRow(iInsertRow, "below", false,false);
- }
- var nowRow = 0;
- nowRow = grd_diaglist.row;
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_seqno", grd_diaglist.row);
- // 청구과, 진료개시일은 주상병을 기준으로 부여한다.
- var clamdeptcd = ds_main_list3_diaglist.getColumn(0, "orddeptcd");
- if (clamdeptcd == "") { // 주상병의 진료과가 입력되지 않은 경우 인적사항의 청구과를 입력한다.
- clamdeptcd = ds_main_item1_iteminfo.getColumn(0, "orddeptcd");
- }
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_orddeptcd", clamdeptcd);
- var ordfromdd = model.getValue("ds_main_list3//diaglist_ordfromdd");
- if (ordfromdd) {
- ds_main.setColumn( 0, "list3//diaglist["+ grd_diaglist.row +"]_ordfromdd", ordfromdd);
- } else {
- ds_main.setColumn( 0, "list3//diaglist["+ grd_diaglist.row +"]_ordfromdd", ds_main_item1_iteminfo.getColumn(0, "indd"));
- }
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_toot", "-");
- // 상병이력조회에서 호출된 경우가 아니면
- if (selectyn != "Y") {
- fSortDiagNo2(true);
- }
- // edit mode 설정위한것임 절대 지우지 말것.
- //grd_diaglist.refresh();
- if (addyn != "Y") {
- grd_diaglist.row = nowRow;
- grd_diaglist.col = grd_diaglist.colRef("diagcd");
- grd_diaglist.dispatch("onentercell");
- }
- }
- // 상병 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
- function fDiagGridInsertRow() {
- // 2008.03.06 박지욱 추가 (상병의 진료개시일은 중간청구최종시작일자, 중간청구등록이 없으면 입원일자 세팅)
- ds_hidden_mdlclamrgst.clearData();
- dsf_makeValue( ds_hidden, "mdlclamrgst", "string", "" );
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd");
- var deptcd = ds_main_item1_iteminfo.getColumn(0, "orddeptcd");
- //속도개선 plet2 상병리스트에서 마지막 날짜를 가져오도록.
- //submit("TRPIJ00313");
- var fromdd = model.getXPathValue("ds_main_list3_diaglist[last()]_ordfromdd");
- if (fromdd == "") {
- var indd = ds_send.getColumn(0, "ordfromdd");
- fromdd = indd;
- }
- // 삭제 상태가 아닌 마지막 줄을 찾는다.
- var diagrow = grd_diaglist.rows - grd_diaglist.fixedRows; // 상병 Grid 가장 마지막 줄에 추가한다.
- grd_diaglist.insertRow(diagrow++, true,false,false);
- ds_main_list3.setColumn( diagrow , "seqno", diagrow);
- ds_main_list3.setColumn( diagrow , "ordfromdd", fromdd); // 진료개시일
- ds_main_list3.setColumn( diagrow , "orddeptcd", deptcd); // 진료과
- fSortDiagNo();
- // 행추가 시 맨 밑에 행이 보일 수 있드록 추가 ( 2007.10.09 김건기 )
- grd_diaglist.bottomRow = grd_diaglist.rows;
- // 행추가 후 상병코드 컬럼으로 포커스 이동 ( 2007.10.09 김건기 )
- grd_diaglist.setFocus();
- // edit mode 설정위한것임 절대 지우지 말것.
- //grd_diaglist.refresh();
- grd_diaglist.row = diagrow;
- grd_diaglist.col = grd_diaglist.colref("diagcd");
- //grd_diaglist.dispatch("onentercell");
- //grd_diaglist.editCell();
- }
- // 상병 다섯줄 추가
- function fDiagGridInsertRow5() { // 20080826 박창원 추가
- // 2008.03.06 박지욱 추가 (상병의 진료개시일은 중간청구최종시작일자, 중간청구등록이 없으면 입원일자 세팅)
- ds_hidden_mdlclamrgst.clearData();
- dsf_makeValue( ds_hidden, "mdlclamrgst", "string", "" );
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd");
- var deptcd = ds_main_item1_iteminfo.getColumn(0, "orddeptcd");
- var fromdd = model.getXPathValue("ds_main_list3_diaglist[last()]_ordfromdd");
- if (fromdd == "") {
- var indd = ds_send.getColumn(0, "ordfromdd");
- fromdd = indd;
- }
- for (var i = 1; i <= 5; i++) {
- var lastRow = grd_diaglist.rows - 1;
- var diagrow = lastRow; // 상병 Grid 가장 마지막 줄에 추가한다.
- grd_diaglist.insertRow(diagrow++, true,false,false);
- ds_main_list3.setColumn( diagrow , "seqno", diagrow);
- ds_main_list3.setColumn( diagrow , "ordfromdd", fromdd); // 진료개시일
- ds_main_list3.setColumn( diagrow , "orddeptcd", deptcd); // 진료과
- }
- fSortDiagNo();
- // 행추가 시 맨 밑에 행이 보일 수 있드록 추가 ( 2007.10.09 김건기 )
- grd_diaglist.topRow = grd_diaglist.rows - 6;
- // 행추가 후 상병코드 컬럼으로 포커스 이동 ( 2007.10.09 김건기 )
- grd_diaglist.setFocus();
- grd_diaglist.row = diagrow - 5;
- grd_diaglist.col = grd_diaglist.colref("diagcd");
- grd_diaglist.dispatch("onentercell");
- grd_diaglist.editCell();
- }
- // 상병 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 삭제"
- function fDiagGridDeleteRow() {
- //상병은 삭제시 무조건 삭제를 날려 버린다.
- for( var i = 0; i < grd_diaglist.selectedRows; i++ ){
- var cRrow = grd_diaglist.selectedRow(i);
- grd_diaglist.rowstatus(cRrow) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- var tmp = grd_diaglist.rows;
- for(var k = tmp; k >= 0;k--){
- if(grd_diaglist.rowstatus(k) == "4"){
- grd_diaglist.deleteRow(k, false);
- }
- }
- //
- //model.refresh();
- 최적회 때문에 20080731 박창원
- model.refreshpart("ds_main_list3_diaglist");
- fSortDiagNo();
- }
- // 상병코드 조회 팝업
- function fSearchDiageCode() {
- var row = grd_diaglist.row;
- var diagcd = ds_main_list3_diaglist.getColumn(row, "diagcd"));
- ds_hidden_sppiz00400_rslt.clearData();
- // 상병 Data가 2007년 이후로 설정되어 있으므로 임시로 현재 날짜를 넘긴다.
- //dsf_makeValue( ds_hidden_sppiz00400_cond, "basedd", "string", ds_main_item1_clbs.getColumn(0, "clamdd"));
- ds_hidden_sppiz00400_cond.clearData(); ds_hidden_sppiz00400_cond.addRow();
- dsf_makeValue( ds_hidden_sppiz00400_cond, "basedd", "string", VAL_today); // (dateHelper.js) 현재날짜 반환
- dsf_makeValue( ds_hidden_sppiz00400_cond, "diagcd", "string", diagcd);
- dsf_makeValue( ds_hidden_sppiz00400_cond, "diagnm", "string", "" );
- dsf_makeValue( ds_hidden_sppiz00400_cond, "selectedrdodiagkind", "string", "1");
- if(diagcd){
- // submit("TRPIJ00308",false); // 입력된 상병코드로 emr.mrtmicd10 테이블을 조회한다.
- var oParam = {};
- oParam.id = "TRPIJ00308";
- oParam.service = "aftjudgapp.OutAftJudg";
- oParam.method = "reqGetSickAndWounded";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=rslt";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00308";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00308(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00308(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00308") > -1
- arErrorCode.pop("TRPIJ00308") < 0
- */
- var rsltList = instance1.selectSingleNode("ds_hidden_sppiz00400");
- if (rsltList != null && rsltList.childNodes.length == 1) {
- // 조회된 결과가 1건이면
- fSetDiagCdNm();
- } else {
- // 조회된 결과가 없거나 여러 건이면
- // 상병코드 조회를 위해 SPPIZ00400_상병코드조회.xrw 를 호출한다.
- fSearchSPPIZ00400();
- }
- } else {
- // 상병코드 입력 없이 상병명 선택 시
- fSearchSPPIZ00400();
- }
- }
- // 상병코드 조회를 위해 SPPIZ00400_상병코드조회.xrw 를 호출한다.
- function fSearchSPPIZ00400() {
- ds_hidden_sppiz00400_rslt.clearData();
- dsf_makeValue( ds_hidden_sppiz00400_rslt, "diagcd", "string", "" );
- dsf_makeValue( ds_hidden_sppiz00400_rslt, "diaghngnm", "string", "" );
- dsf_makeValue( ds_hidden_sppiz00400_rslt, "diagengnm", "string", "" );
- ds_hidden_sppiz00400_cond.clearData(); ds_hidden_sppiz00400_cond.addRow();
- dsf_makeValue( ds_hidden_sppiz00400_cond, "basedd", "string", VAL_today); // (dateHelper.js) 현재날짜 반환
- dsf_makeValue( ds_hidden_sppiz00400_cond, "diagcd", "string", ds_main_list3_diaglist.getColumn(grd_diaglist.row, "diagcd")));
- dsf_makeValue( ds_hidden_sppiz00400_cond, "diagnm", "string", "" );
- dsf_makeValue( ds_hidden_sppiz00400_cond, "selectedrdodiagkind", "string", "3"); // 사용자가 직접검색하여 입력 할수 있도록 임의의 값(3)을 넣어줌
- frmf_modal("SPPIZ00400", "SPPIZ00400", "ds_hidden_sppiz00400_cond""-"ds_init"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ00400_상병코드조회.xrw
- }
- // [SPPIZ00400_상병코드조회.xrw 에서 호출] 상병조회 팝업에서 상병을 더블클릭 했을경우 상병 그리드에 반영
- function fSetDiagCdNm() {
- var diagcd = ds_hidden_sppiz00400_rslt.getColumn(0, "diagcd");
- var diaghngnm = ds_hidden_sppiz00400_rslt.getColumn(0, "diaghngnm");
- var diagengnm = ds_hidden_sppiz00400_rslt.getColumn(0, "diagengnm");
- var spclcd = ds_hidden_sppiz00400_rslt.getColumn(0, "spclcd");
- var currRow = grd_diaglist.row;
- //20090810 JHP 수정추가. 상병 조회팝업에서 상병조회 후 적용하려고 할때 인스턴스 증가(행추가)하여 적용시킨다.
- if(grd_diaglist.row <= 0){
- fDiagGridInsertRow();
- grd_diaglist.endEditCell();
- }else{
- var chkdiagcd = ds_main_list3_diaglist.getColumn(currRow, "diagcd"));
- var chkdiagnm = ds_main_list3_diaglist.getColumn(currRow, "diagnm"));
- if((chkdiagcd != "" || chkdiagcd != " " || chkdiagcd != null) &&
- (chkdiagnm == "" || chkdiagnm == " " || chkdiagnm == null)){
- ;
- }else if((chkdiagcd != "" || chkdiagcd != " " || chkdiagcd != null) &&
- (chkdiagnm != "" || chkdiagnm != " " || chkdiagnm != null)){
- ;
- }else{
- fDiagGridInsertRow();
- grd_diaglist.endEditCell();
- }
- }
- if (diagcd) {
- grd_diaglist.endEditCell();
- ds_main_list3.setColumn( currRow , "diagcd", diagcd);
- }
- if (diaghngnm) {
- ds_main_list3.setColumn( currRow , "diagnm", diaghngnm);
- }
- if(diagengnm){
- ds_main_list3.setColumn( currRow , "diagengnm", diagengnm);
- }
- if(spclcd){
- ds_main_list3.setColumn( currRow , "vcode", spclcd);
- }
- var chk_key = ds_main_list3_diaglist.getColumn(currRow, "pid"));
- //신규로 불러온 입력되는 경우는 Insert시 key값이 없으므로 기본 정보에서 읽어다 넣어 준다.
- if(chk_key){
- return;
- }else{
- //Pid
- ds_main_list3.setColumn( currRow , "pid",ds_send.getColumn(0, "pid"));
- //Indd
- ds_main_list3.setColumn( currRow , "indd",ds_send.getColumn(0, "indd"));
- //Cretno
- ds_main_list3.setColumn( currRow , "cretno",ds_send.getColumn(0, "cretno"));
- //fromdd
- ds_main_list3.setColumn( currRow , "fromdd",ds_send.getColumn(0, "fromdd"));
- //mskind
- ds_main_list3.setColumn( currRow , "mskind",ds_send.getColumn(0, "mskind"));
- //drinptyn
- ds_main_list3.setColumn( currRow , "drinptyn","N");
- //addflag
- ds_main_list3.setColumn( currRow , "addflag","Y");
- if(grd_diaglist.row >1){
- //orddeptcd
- ds_main_list3.setColumn( currRow , "orddeptcd",ds_main_list3_diaglist.getColumn(1, "orddeptcd"));
- //ordfromdd
- ds_main_list3.setColumn( currRow , "ordfromdd",ds_main_list3_diaglist.getColumn(1, "ordfromdd"));
- }
- //저장후 빈행을 추가해 준다.
- //20080811 자동으로 줄추가 되는 기능 제외
- fDiagGridInsertRow();
- }
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list3_diaglist");
- }
- function fChangeRate() {
- grp_changeownbrate.visible = true;
- }
- function fUpdDiag() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- if(chk){
- //fGetIsclList
- fRefreshDiag(); // 특정 환자에 대한 전상병 내역을 조회한다.
- // 20080811 제외하기로함(상병줄추가(자동)
- //fDiagGridInsertRow();
- }
- }
- function fChangeRate1() {
- // 6시간 미만 환자는 입원에만 해당하는 요율을 적용할 수 없다. - 20081105 박창원
- var suppkind = cmb_suppkindlist.value;
- var sixtimyn = ds_main_item1_iteminfo.getColumn(0, "sixtimyn");
- var suppkindcd = ds_main_item1_iteminfo.getColumn(0, "suppkindcd");
- //20090325 차상위 2종추가 - 박창원
- if (sixtimyn == "Y" && (suppkind == "05" || suppkind == "08" || suppkind == "09" || suppkind == "31" || suppkind == "39" || suppkind == "41" || suppkind == "42" || suppkind == "43")) {
- sysf_messageBox("6시간 미만환자는 입원에만 적용되는 보조유형으로 변경을","E001");
- grp_changeownbrate.visible = false;
- return;
- }
- // 6세미만, 신생아는 조건에 맞지 않으면 Block - 20090103 박창원
- if (suppkind == "08" || suppkind == "31" || suppkind == "41")
- var age = parseInt(ds_main_item1_iteminfo.getColumn(0, "age"));
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var insukindcd = ds_main_item1_iteminfo.getColumn(0, "insukindcd");
- var inpath = ds_main_item1_iteminfo.getColumn(0, "inpath");
- var orddeptcd = ds_main_item1_iteminfo.getColumn(0, "orddeptcd");
- var rrgstno = ds_main_item1_iteminfo.getColumn(0, "rrgstno");
- var sixtimyn = ds_main_item1_iteminfo.getColumn(0, "sixtimyn");
- var babyyn ="N";
- var end6yn = "N";
- var brthdd = "20" + rrgstno.substr(0,6);
- var readonly = ds_send.getColumn(0, "readonly");
- // 신생아를 구별지음
- if (rrgstno.substr(7,1) == "3" || rrgstno.substr(7,1) == "4" || rrgstno.substr(7,1) == "7" || rrgstno.substr(7,1) == "8") {
- var interval = utlf_getDateInterval(brthdd,indd);
- if (interval < "28") {
- babyyn = "Y";
- }
- }
- // 6세미만 생일 여부를 판단함
- if ((rrgstno.substr(7,1) == "3" || rrgstno.substr(7,1) == "4") && age <= 6) {
- if (age == 6) {
- if (brthdd >= VAL_today) {
- end6yn = "Y";
- }
- } else if (age == 6){
- if (brthdd < VAL_today) {
- end6yn = "N";
- }
- } else if(age < 6) {
- end6yn = "Y";
- } else if (age > 6) {
- end6yn ="N";
- }
- }
- var reqdeptno = model.getValue("ds_hidden_list2_dept[deptcd='"+orddeptcd+"']reqdeptno");
- if (sixtimyn == "N" && babyyn == "Y" &&age == 0 && indd >= "20080101" && reqdeptno == "11" && (insukindcd == "11" || insukindcd == "21" || insukindcd == "22")) {
- if (suppkind != "31") {
- sysf_messageBox("신생아 조건에 맞지 않아 변경을","E001");
- grp_changeownbrate.visible = false;
- return;
- }
- }
- if (sixtimyn == "N" && end6yn == "Y" && babyyn == "N" && age <= 6 && reqdeptno == "11" && (insukindcd == "11" || insukindcd == "21" || insukindcd == "22")) {
- if (suppkind != "08" && suppkind != "41") { // 20090325 차상위 2종 조건 추가 - 박창원
- if (suppkind != "31") {
- sysf_messageBox("6세미만 조건에 맞지 않아 변경을","E001");
- grp_changeownbrate.visible = false;
- return;
- }
- }
- }
- var msg = sysf_messageBox("선택하신 요율을 적용","S001");
- if(msg !=6){
- return;
- }else{
- Insuchange(suppkind);
- }
- }
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //상병조회버튼에 대한 처리 //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // 수가 조회
- function fSetSrchCalcScorCdPop(){
- ds_hidden_smpic00100_cond.setColumn( 0, "calcscorcd", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));
- ds_hidden_smpic00100_cond.setColumn( 0, "judgflag", "Y");
- frmf_modal("SMPIC00100", "SMPIC00100", "ds_hidden_smpic00100_cond""-"ds_temp_item6"", "", "1", "150", "150", "", "", "", "", "", "M");
- }
- // 보험인정기준관리 화면 호출 20091105 수정추가 JHP 요청번호 : 5874
- function fSetSrchInsuRcogBaseMngt(){
- // 1. 보험인정기준관리 해당 코드 인지 확인
- ds_hidden_send.clearData();
- dsf_makeValue( ds_hidden_send, "insurcogbasemngtresult", "string", "" );
- dsf_makeValue( ds_hidden_send_insurcogbasemngtlist, "snglcalcscorcd", "string", grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));
- // submit("TRPIJ00317",false);
- var oParam = {};
- oParam.id = "TRPIJ00317";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqInsuRcogBaseMngtValue";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=insurcogbasemngtresult";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00317";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00317(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00317(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00317") > -1
- arErrorCode.pop("TRPIJ00317") < 0
- */
- // 2. 맞으면 화면 콜 아니면 메세지
- if(ds_hidden_send_insurcogbasemngtresult.getColumn(0, "value") > 0){
- frmf_open("SMPIB00400", "ddd", ""-"", "", "", "", "", "", "", "", "", "", "M");
- }else{
- // 존재하지 않습니다.
- sysf_messageBox("해당코드의 보험인정기준 등록내역이 존재하지","I011");
- }
- }
- // 보험인정기준관리 화면 호출 20091105 수정추가 JHP 요청번호 : 5874 호출함수. - 미사용
- function getOpenInsuRcogBaseMngtChk(){
- var temp = getChildWindow("ddd");
- var nodecnt = 0;
- var xPathFunction = "count(ds_main_h_limi_limi)";
- while (nodecnt == 0)
- {
- nodecnt = temp.model.getXPathValue(xPathFunction);
- if (nodecnt >= 500){
- temp.sysf_messageBox("해당코드 인정기준을 확인합니다.","I002");
- temp.ds_main_right_h_limt_limt.setColumn( 0, "limt_calcscorcd" ,grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colRef("snglcalcscorcd")));
- temp.ipt_calcscorcd.dispatch("onkeypress");
- //temp.model.refresh();
- break;
- }
- }
- }
- // 약품편람 호출 - 20080930 박창원
- function fOpenDrugDic() {
- frmf_open("SMADB01900", "bbb", ""-"", "", "", "", "", "", "", "", "", "", "M");
- var temp = getChildWindow("bbb");
- // 필터링 할 경우 row값을 제대로 못 가져와서 valueMatrix로 변경함. 2012.02.16 LEJ
- temp.ds_hidden_receivedata.setColumn( 0, "srchdrugcd", grd_ordlist.valueMatrix(grd_ordlist.row,grd_ordlist.colRef("snglcalcscorcd")));
- }
- // 의약품정보 호출 - 20080930 박창원
- function fOpenDruginfo() {
- frmf_open("SMADB00100", "ccc", ""-"", "", "", "", "", "", "", "", "", "", "M");
- var temp = getChildWindow("ccc");
- temp.ds_send_srchinfo.setColumn( 0, "srchcd", grd_ordlist.valueMatrix(grd_ordlist.row,grd_ordlist.colRef("snglcalcscorcd")));
- }
- // 환자단위 메시지 전송
- function fSendMsgPat() {
- dsf_makeValue( ds_temp, "opentab", "string", "pmsg");
- zmifOpenMessagePopup("ds_temp"); // root_temp_opentab 에 receivemsg (받은메세지함) 값을 주고 오픈한다.
- }
- // 처방단위 메시지 전송
- function fSendMsgOrder() {
- dsf_makeValue( ds_temp, "opentab", "string", "pmsg");
- zmifOpenMessagePopup("ds_temp"); // root_temp_opentab 에 pmsg (환자메세지작성창) 값을 주고 오픈한다.
- }
- // 특정 환자에 대한 청구상병을 조회한다.
- function fGetClamDiagHistList() {
- if(ds_main_item1_iteminfo.getColumn(0, "patnm")){
- // 심사대상자의 등록번호를 조건으로 하여 전체 청구 상병이력을 조회한다.
- ds_hidden_smpiz00100_cond.setColumn( 0, "pid", ds_main_item1_iteminfo.getColumn(0, "pid"));
- ds_hidden_smpiz00100_cond.setColumn( 0, "ordfromdd", ds_main_item1_iteminfo.getColumn(0, "indd"));
- ds_hidden_smpiz00100_cond.setColumn( 0, "ordtodd", ds_main_item1_iteminfo.getColumn(0, "dschdd"));
- ds_hidden_smpiz00100_cond.setColumn( 0, "srchflag", "pam"); // 검색구분 Radio : 청구
- frmf_modal("SMPIZ00100", "SMPIZ00100", "ds_hidden_smpiz00100_cond""-"ds_init"", "", "", "10", "10", "", "", "", "", "", "M"); // SMPIZ00100_외래입원상병이력조회.xrw
- //
- //model.refresh();
- 최적화 문제로 20080731 박창원
- var rsltNode = instance1.selectSingleNode("ds_hidden_smpiz00100_rslt");
- var originpid = ds_main_item1_iteminfo.getColumn(0, "pid");
- if (rsltNode != null) {
- for (var i = 1; i <= rsltNode.childNodes.length; i++) {
- var diagcd = ds_hidden_smpiz00100_rslt_diag.getColumn(i, "diagcd");
- var isSame = false;
- for (var j = grd_diaglist.fixedRows; j < grd_diaglist.rows; j++) {
- if (diagcd == ds_main_list3_diaglist.getColumn(j, "diagcd")) {
- // 동일한 상병이 존재하는 경우
- isSame = true;
- j = grd_diaglist.rows;
- }
- }
- // 동일한 상병이 없는 경우
- if (isSame == false) {
- grd_diaglist.addRow(false,true);
- var pid = ds_main_item1_iteminfo.getColumn(0, "pid");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var cretno = ds_main_item1_iteminfo.getColumn(0, "cretno");
- var fromdd = ds_main_item1_iteminfo.getColumn(0, "fromdd");
- var mskind = ds_main_item1_iteminfo.getColumn(0, "mskind");
- var ruleoutyn = ds_hidden_smpiz00100_rslt_diag.getColumn(i, "diagkindcd");
- if(ruleoutyn == "C"){
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_ruleoutyn", "false");
- }else{
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_ruleoutyn", "true");
- }
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_pid", pid);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_indd", indd);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_cretno", cretno);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_fromdd", fromdd);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_mskind", mskind);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_addflag", "Y");
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_drinptyn", "N");
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_seqno", grd_diaglist.row);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_diagcd", ds_hidden_smpiz00100_rslt_diag.getColumn(i, "diagcd"));
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_diagnm", ds_hidden_smpiz00100_rslt_diag.getColumn(i, "diaghngnm"));
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_diagengnm", ds_hidden_smpiz00100_rslt_diag.getColumn(i, "diagengnm"));
- // 청구과, 진료개시일은 주상병을 기준으로 부여한다.
- var clamdeptcd = ds_main_list3_diaglist.getColumn(0, "orddeptcd");
- if (clamdeptcd == "") { // 주상병의 진료과가 입력되지 않은 경우 인적사항의 진료과를 입력한다.
- clamdeptcd = ds_main_item1_iteminfo.getColumn(0, "orddeptcd");
- }
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_orddeptcd", clamdeptcd);
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_ordfromdd", ds_main_list3_diaglist.getColumn(0, "ordfromdd"));
- ds_main_list3.setColumn( 0, "diaglist["+ grd_diaglist.row +"]_toot", "-");
- }
- }
- fSortDiagNo(true);
- }
- }
- }
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //상병처리 관련 코딩 끝 //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // 처방조회부, 처방 Grid용 Group의 컨트롤 크기를 설정한다.
- function fSetOrderControlSize() {
- if(grp_calc.attribute("top") == "305"){
- //기존위치에 +200한 위치, 처방그리드는 사이즈 +200
- grp_calc.attribute("top") = "105";
- grp_calc.attribute("height") = "640";
- grd_ordlist.attribute("height") = "518";
- cap_paylimamt.attribute("top") = "595";
- opt_paylimamt.attribute("top") = "620";
- swt_spclmemo.visible = "false";
- grd_diaglist.visible = "false";
- }else{
- grp_calc.attribute("top") = "305";
- grp_calc.attribute("height") = "440";
- grd_ordlist.attribute("height") = "318";
- cap_paylimamt.attribute("top") = "395";
- opt_paylimamt.attribute("top") = "420";
- swt_spclmemo.visible = "true";
- grd_diaglist.visible = "true";
- }
- }
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //처장 Filter 관련 코딩 끝 //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //특정내역 관련 코딩 //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////
- // 특정 환자에 대해 그동안 작성된 심사자메모, 청구메모 내역을 조회한다.
- function fGetMemoHistList() {
- if(ds_main_item1_iteminfo.getColumn(0, "patnm")){
- ds_hidden_sppiz00300_rslt.clearData();
- dsf_makeValue( ds_hidden_sppiz00300_cond, "pid", "string", ds_main_item1_iteminfo.getColumn(0, "pid"));
- dsf_makeValue( ds_hidden_sppiz00300_cond, "orddeptcd", "string", ds_main_item1_iteminfo.getColumn(0, "orddeptcd"));
- dsf_makeValue( ds_hidden_sppiz00300_cond, "ioflag", "string", "I");
- dsf_makeValue( ds_hidden_sppiz00300_cond, "refterm", "string", "2");
- dsf_makeValue( ds_hidden_sppiz00300_cond, "anofildinclyn", "string", "Y");
- dsf_makeValue( ds_hidden_sppiz00300_cond, "fromdd", "string", "");
- dsf_makeValue( ds_hidden_sppiz00300_cond, "todd", "string", "");
- frmf_modal("SPPIZ00300", "SPPIZ00300", "ds_hidden_sppiz00300_cond""-"ds_init"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ00300_메모이력조회.xrw
- var SelectMemo = instance1.selectSingleNode("ds_hidden_sppiz00300_rslt");
- if (SelectMemo != null) {
- var choimemo = ds_hidden_sppiz00300_rslt.getColumn(0, "choimemo").getTrim(); // (stringHelper.js) 문자열 앞뒤에 있는 공백 제거
- var choiedicd = ds_hidden_sppiz00300_rslt.getColumn(0, "edicd");
- if (choimemo) {
- ds_hidden_sppiz00300_rslt.setColumn( 0, "choimemo", choimemo);
- var destRef = ds_hidden_sppiz00300_rslt.getColumn(0, "destRef");
- if (destRef == "judgmemo") { // 심사메모로 전달
- var judgmemo = ds_main_item1_iteminfo.getColumn(0, "judgrmk");
- if (judgmemo) { // 기존 심사메모가 공백이 아닌 경우 선택된 메모를 심사화면 메모 뒤에 덧붙인다.
- ds_main_item1_iteminfo.setColumn( 0, "judgrmk", judgmemo +" \n"+ choimemo);
- } else {
- if (choiedicd) { // 처방별 메모를 전달하는 경우임
- // 동일한 EDI 코드가 있을 경우만 추가
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- for (var j = 1; j < rowcnt; j++) {
- var clodedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (choiedicd == clodedicd) {
- ds_main_item1_iteminfo.setColumn( 0, "judgrmk", choimemo);
- j = grd_ordlist.rows;
- }
- }
- } else {
- ds_main_item1_iteminfo.setColumn( 0, "judgrmk", choimemo);
- }
- }
- model.toggle("case_judgrmemo"); // 해당 tab 으로 토글시킨다.
- }
- else if (destRef == "edimemo") { // 청구메모로 전달
- var edimemo = ds_main_item1_iteminfo.getColumn(0, "edirmk");
- if (edimemo) { // 기존 청구메모가 공백이 아닌 경우 선택된 메모를 심사화면 메모 뒤에 덧붙인다.
- ds_main_item1_iteminfo.setColumn( 0, "edirmk", edimemo +" \n"+ choimemo);
- } else {
- if (choiedicd) { // 처방별 메모를 전달하는 경우임
- // 동일한 EDI 코드가 있을 경우 * 표시
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- for (var j = 1; j < rowcnt; j++) {
- var clodedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (choiedicd == clodedicd) {
- ds_main_item1_iteminfo.setColumn( 0, "edirmk", choimemo);
- //j = grd_ordlist.rows;
- j = rowcnt;
- }
- }
- } else {
- ds_main_item1_iteminfo.setColumn( 0, "edirmk", choimemo);
- }
- }
- model.toggle("case_ediclammemo"); // 해당 tab 으로 토글시킨다.
- }
- else if (destRef == "prcpmemo") { // 처방별 주석로 전달
- // 동일한 EDI 코드가 있을 경우 * 표시
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var iscledicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (choiedicd == iscledicd) {
- ds_main_list2.setColumn( j , "text", "*");
- }
- }
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var edicd = ds_main_list4_clcjlist.getColumn(i, "edicd");
- var spclspec = ds_main_list4_clcjlist.getColumn(i, "spclspec");
- if (choiedicd == edicd) {
- var ans = sysf_messageBox("등록된 메모가 있습니다. 기존 내역에 추가할 경우 예(Yes)\n 새로운 내역으로 변경하시려면 아니오(No) 선택하여 주십시요", "S003"); ///수정사항이 있습니다. 저장하시려면 예(Yes)\n변경하시려면 아니오(No)
- if (ans == 6) { // 6: yes
- // 'JX999' 코드를 추가한다.
- fSpclGridInsertRow(); // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
- var clsprow = grd_ordlist.row;
- ds_main_list4.setColumn( clsprow , "unitflag", "J");
- ds_main_list4.setColumn( clsprow , "edicd", choiedicd);
- ds_main_list4.setColumn( clsprow , "spclcd", "JX999");
- ds_main_list4.setColumn( clsprow , "spclcdnm", "JX999 기타내역");
- ds_main_list4.setColumn( clsprow , "spclspec", spclspec + "\n"+ choimemo);
- ds_main_list4.setColumn( clsprow , "remfact", "X(700)");
- return;
- }
- else if (ans == 7) { // 7:no
- ds_main_list4.setColumn( i , "spclspec", choimemo);
- return ;
- }
- else if (ans == 2) { // 2:cancel
- return ;
- }
- }
- }
- // 신규로 특정 내역을 추가하는 경우
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var iscledicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (choiedicd == iscledicd) {
- // 'JX999' 코드를 추가한다.
- fSpclGridInsertRow(); // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
- var clsprow = grd_clsphist.row;
- ds_main_list4.setColumn( clsprow , "unitflag", "J");
- ds_main_list4.setColumn( clsprow , "edicd", choiedicd);
- ds_main_list4.setColumn( clsprow , "spclcd", "JX999");
- ds_main_list4.setColumn( clsprow , "spclcdnm", "JX999 기타내역");
- ds_main_list4.setColumn( clsprow , "spclspec", spclspec + "\n"+ choimemo);
- ds_main_list4.setColumn( clsprow , "remfact", "X(700)");
- return;
- }
- }
- }
- //model.refresh();
- }
- }
- }
- }
- // 특정내역 중 MT015, MT016 내역을 조회하여 "소명자료" Btn (첨부물 자료관리) Popup 화면에 표시한다.
- function fGetAttachedDataList() {
- if(ds_main_item1_iteminfo.getColumn(0, "patnm")){
- //ds_hidden_sppiz00200_cond_clsp.clearData();
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "rowstat","");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "unitflag","");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclcd","");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclspec", "");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "initedilnno", "");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "calcscorcd", "");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "seqno", "");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclformat","");
- // 특정내역 Grid에서 "행 삭제"한 경우 MT015 / MT016 자료를 표시하지 않도록 하는 기능 필요함
- // (작성할 것!!!!!!!!!!!!!!!!!!!!!!!)
- for (var i = 1; i < grd_clcjlist.rows; i++) {
- var tmp = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- if(tmp == "MT015" || tmp == "MT016"){
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "rowstat","-");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "unitflag","M");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclcd", ds_main_list4_clcjlist.getColumn(i, "spclcd"));
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclspec", ds_main_list4_clcjlist.getColumn(i, "spclspec"));
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "initedilnno", grd_clcjlist.row);
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "calcscorcd", ds_main_list4_clcjlist.getColumn(i, "edicd"));
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "seqno", "1");
- ds_hidden_sppiz00200_cond_clsp.setColumn( 0, "spclformat", ds_main_list4_clcjlist.getColumn(i, "remfact"));
- }
- }
- frmf_modal("SPPIZ00200", "SPPIZ00200", ""-"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ00200_첨부물자료관리.xrw
- fDisplayAttachedDataList()
- fCheckSpclSpecData();
- }
- }
- // "소명자료" Btn (첨부물 자료관리) Popup 화면에서 특정내역 중 MT015, MT016 정보가 입력된 환자인지를 확인한다.
- // 특정내역 MT004가 입력된 환자인지 체크한다.
- function fDisplayAttachedDataList() {
- var isAttachedDataList = false;
- var cSrcNode = instance1.selectSingleNode("ds_hidden_sppiz00200_rslt_clsp");
- if (cSrcNode == null) { // 특정내역이 없는 경우임
- return;
- }
- if (ds_hidden_sppiz00200_rslt_clsp.getColumn(0, "unitflag") == "") { // "취소" 선택시에 버튼 색이 변경되지 않도록
- return;
- }
- var cSrcChildNodeList = cSrcNode.childNodes;
- for (var i = 1; i <= cSrcChildNodeList.length; i++) {
- var spclcd = ds_hidden_sppiz00200_rslt_clsp.getColumn(i, "spclcd");
- if (spclcd == "MT015" || spclcd == "MT016") {
- var rowstat = ds_hidden_sppiz00200_rslt_clsp.getColumn(i, "rowstat")
- if (rowstat != 'D') {
- var spclspec = ds_hidden_sppiz00200_rslt_clsp.getColumn(i, "spclspec");
- if (spclspec) {
- isAttachedDataList = true;
- }
- // 특정내역 Grid 에서 해당 내용을 삽입 또는 수정한다.
- if (rowstat == "I") { // 삽입
- fSpclGridInsertRow();
- ds_main_list4.setColumn( 0, "clcjlist[" + grd_clcjlist.row + "]_spclcd", spclcd);
- ds_main_list4.setColumn( 0, "clcjlist[" + grd_clcjlist.row + "]_spclspec", spclspec);
- if (spclcd == "MT015") {
- ds_main_list4.setColumn( 0, "clcjlist[" + grd_clcjlist.row + "]_remfact", "X(2)");
- } else {
- ds_main_list4.setColumn( 0, "clcjlist[" + grd_clcjlist.row + "]_remfact", "X(200)");
- }
- } else if (rowstat == "U") { // 수정
- for (var j = 1; j < grd_clcjlist.rows; j++) {
- var gridspclcd = ds_main_list4_clcjlist.getColumn(j, "spclcd");
- var gridspclspec = ds_main_list4_clcjlist.getColumn(j, "spclspec");
- var gridrowstatus = grd_clcjlist.rowstatus(j);
- if (gridspclcd == spclcd) {
- ds_main_list4.setColumn( j , "spclspec", spclspec);
- if (gridrowstatus == 1 || gridrowstatus == 3) { // 1 : insert, 3 : insert & new
- } else {
- grd_clcjlist.rowstatus(j) = 2; // 2 : update 상태로 stat를 변경한다.
- }
- }
- }
- }
- } else { // 삭제
- // 특정내역 Grid 에서 해당 내용을 삭제한다.
- for (var j = 1; j < grd_clcjlist.rows; j++) {
- var gridspclcd = ds_main_list4_clcjlist.getColumn(j, "spclcd");
- var gridspclspec = ds_main_list4_clcjlist.getColumn(j, "spclspec");
- var gridrowstatus = grd_clcjlist.rowstatus(j);
- if (gridspclcd == spclcd) {
- if (gridrowstatus == 1 || gridrowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(j, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(j) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- }
- }
- }
- }
- }
- if (isAttachedDataList) {
- btn_attData.attribute("class") = "btn5_letter4";
- btn_attData.attribute("color") = "#cc3333";
- } else {
- btn_attData.attribute("class") = "btn2_letter4";
- }
- }
- //줄단위 추가
- function fSpclGridInsertRow() {
- // 특정내역 Grid 상에서 직접 행을 추가하는 경우 : 명세서단위 특정내역만을 추가할 수 있다.
- // 줄단위 특정내역의 경우, 처방 Grid에서 'T' 컬럼을 더블클릭하여 특정내역 상세관리 Popup을 통해 입력한다.
- var clcjrow = 0;
- if(grd_clcjlist.rows > 1){
- clcjrow = grd_clcjlist.rows - 1; // 특정내역 Grid 가장 마지막 줄에 추가한다.
- var chkdata = ds_main_list4_clcjlist.getColumn(clcjrow, "spclcd"));
- if(chkdata == ""){
- return;
- }
- }
- grd_clcjlist.insertRow(clcjrow++, true,false,false);
- grd_clcjlist.cellComboNodeset(clcjrow,3) = "ds_init_P0117list_P0117[minval = 'M' and cdid != 'MX999']";
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_pid", ds_send.getColumn(0, "pid"));
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_indd", ds_send.getColumn(0, "indd"));
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_cretno", ds_send.getColumn(0, "cretno") );
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_fromdd", ds_send.getColumn(0, "fromdd"));
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_mskind", ds_send.getColumn(0, "mskind"));
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_unitflag", "M");
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_spclmemoflag","E" );
- ds_main_list4.setColumn( 0, "clcjlist[" + (grd_clcjlist.rows - 1) + "]_status", "3");
- grd_clcjlist.row = grd_clcjlist.rows;
- grd_clcjlist.rowstatus(grd_clcjlist.row) = 1;
- // grd_clcjlist.gridToInstance(); 최적화문제로 주석처리 - 20081015 박창원
- }
- // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 삭제"
- function fSpclGridDeleteRow() {
- var rowstatus = grd_clcjlist.rowstatus(grd_clcjlist.row);
- for( var i = grd_clcjlist.selectedRows; i >= 0 ; i-- ){
- var cRrow = grd_clcjlist.selectedRow(i);
- if (rowstatus == 4) { // 4 : delete
- return;
- }
- else if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(cRrow, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- ds_main_list4.setColumn( 0, "clcjlist[" + grd_clcjlist.row + "]_status", 4);
- grd_clcjlist.rowstatus(cRrow) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- }
- fCheckSpclSpecData();
- //특정내역이 있는 처방에 'T'필드에 *표를 해준다.
- //fSetOrdSpclTxt();
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist");
- model.refreshpart("ds_main_list4_clcjlist");
- }
- // 특정내역 Grid 에서 선택한 줄단위 특정내역을 조회하고, 명세서단위 특정내역을 수정_입력한다.
- function fSetDocRefLnSpclSpec(){
- ds_hidden_sppij00500_rslt.clearData(); // SPPIJ00500_특정내역상세관리 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_sppij00500_cond_list.clearData();
- ds_hidden_sppij00500_cond.clearData(); ds_hidden_sppij00500_cond.addRow();
- var row = grd_clcjlist.row;
- var rows = grd_clcjlist.rows;
- var edicd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("edicd"));
- var oldspclcd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("spclcd"));
- var oldspclcdnm = "";
- var oldspclspec = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("spclspec"));
- var oldremfact = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("remfact"));
- var olddetldesc = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("detldesc"));
- //줄단위 명단위 특정내역 구분.
- var unitflag = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("unitflag"));
- var calcscorcd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("calcscorcd"));
- // pid,indd추가 결과조회 팝업호출을 위하여 - 20080922 박창원
- var pid = ds_main_item1_iteminfo.getColumn(0, "pid");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var rowcnt = 1;
- var setrow =0 ;
- if(unitflag == "J"){
- if (edicd ) {
- for (var i=1; i<rows; i++) {
- var grdedicd = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("edicd"));
- if ( edicd == grdedicd) {
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "pid", pid);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "indd", indd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "flag", "U");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "edicd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("edicd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcdnm", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclspec", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "detldesc", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("detldesc")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "remfact", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("remfact")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "unitflag", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "rownum", i);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclcd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclspec", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("calcscorcd")));
- if (row == i) {
- setrow = i;
- }
- rowcnt = rowcnt+1;
- }
- }
- ds_hidden_sppij00500_cond.setColumn( 0, "pid", pid);
- ds_hidden_sppij00500_cond.setColumn( 0, "indd", indd);
- ds_hidden_sppij00500_cond.setColumn( 0, "flag", "U");
- ds_hidden_sppij00500_cond.setColumn( 0, "edicd", edicd);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclcd", oldspclcd);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclcdnm", oldspclcdnm);
- ds_hidden_sppij00500_cond.setColumn( 0, "detldesc", olddetldesc);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclspec", oldspclspec);
- ds_hidden_sppij00500_cond.setColumn( 0, "remfact", oldremfact);
- ds_hidden_sppij00500_cond.setColumn( 0, "rownum", setrow);
- ds_hidden_sppij00500_cond.setColumn( 0, "unitflag", "J");
- ds_hidden_sppij00500_cond.setColumn( 0, "calcscorcd", calcscorcd);
- //var unitflag = ds_main_list4_clcjlist.getColumn(row, "unitflag"));
- var unitflag = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("unitflag"))
- // 삭제상태인 경우 처방Grid에서 입력,수정은 가능하지만 특정내역Grid에서는 편집할 수 없다.
- var rowstatus = grd_clcjlist.rowstatus(row);
- if (rowstatus == 4) { // 4 : delete
- sysf_messageBox("삭제된 특정내역은 수정할 수", "I004"); ///삭제된 특정내역은 수정할 수 없습니다.
- return;
- }
- frmf_modal("SPPIJ00500", "SPPIJ00500", "ds_hidden_sppij00500""-"ds_hidden_clcj"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIJ00500_특정내역상세관리.xrw
- var rsltcnt = ds_hidden_sppij00500_rslt_list.rowcount;
- // 처리 건수
- if (rsltcnt > 0) {
- for(var i=rsltcnt; i>0; i--) {
- var flag = ds_hidden_sppij00500_rslt_list.getColumn(i, "flag");
- var rownum = ds_hidden_sppij00500_rslt_list.getColumn(i, "rownum");
- var edicd = ds_hidden_sppij00500_rslt_list.getColumn(i, "edicd");
- var newspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcd");
- var newspclcdnm = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcdnm");
- var newspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclspec");
- var newremfact = ds_hidden_sppij00500_rslt_list.getColumn(i, "remfact");
- var newdetldesc = ds_hidden_sppij00500_rslt_list.getColumn(i, "detldesc");
- oldspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclcd");
- oldspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclspec");
- // 특정코드 추가인 경우
- if (flag == "I") {
- var clsprow = grd_clcjlist.rows - 1; // 특정내역 Grid 가장 마지막 줄에 추가한다.
- grd_clcjlist.insertRow(clsprow++, true,false,false);
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("unitflag")) = unitflag;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("edicd")) = edicd;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("status")) = "3";
- // 특정코드 변경인 경우
- } else if (flag == "U") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("unitflag")) = unitflag;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("edicd")) = edicd;
- if ( grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) != "3") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "0";
- }
- //model.refresh();
- // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
- if (oldspclcd != newspclcd || oldspclspec != newspclspec || grd_clcjlist.rowstatus(row) == 4) {
- var rowstatus = grd_clcjlist.rowstatus(rownum);
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- } else {
- grd_clcjlist.rowstatus(rownum) = 2; // 2 : update 상태로 stat를 변경한다.
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "2";
- }
- }
- // 처방Grid에서도 해당 줄단위 특정내역의 'T' 컬럼의 "*" 를 표시한다.
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- if(newspclcd == "JX999"){
- ds_main_list2.setColumn( j , "text", "#");
- }else{
- ds_main_list2.setColumn( j , "text", "*");
- }
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist");
- }
- }
- ds_hidden_item1.setColumn( 0, "message", "특정코드 - "+ newspclcd +" / 특정내역 : "+ newspclspec +" / 기재형식 : "+ newremfact);
- // 특정코드 삭제인 경우
- } else if (flag == "D" && rownum != "" ) {
- // 특정내역 Grid에서 삭제
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(rownum, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(rownum) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- // 처방Grid에서도 해당 줄단위 특정내역의 삭제 처리를 한다.
- // 줄번호가 부여된 줄단위 특정내역이 삭제된 경우, 처방Grid의 'T' 컬럼의 "*" 를 삭제한다.
- //var clcjedicd = ds_main_list4_clcjlist.getColumn(rownum, "edicd")); //root_main_list4_clcjlist_edicd
- var clcjedicd = grd_clcjlist.valueMatrix( rownum,grd_clcjlist.colRef("edicd"));
- if (clcjedicd) {
- var isSameLn = false;
- for (var j = 1; j < grd_clcjlist.rows; j++) {
- if (grd_clcjlist.rowstatus(j) != 4) {
- isSameLn = true; // 같은 줄번호에 여러개의 특정내역이 있는 경우임
- }
- }
- }
- if (isSameLn == false) { // 동일한 줄번호의 특정내역이 없는 경우
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var iscldicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (clcjedicd == iscldicd) {
- model.resetInstanceNode("ds_main_list2_iscllist["+ j +"]_text");
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist");
- }
- }
- }
- } // 특정코드 비교 if
- } // end for
- var rdounitflag = ds_send.getColumn(0, "unitflag");
- if (rdounitflag == "-") {
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var delstatus = grd_clcjlist.rowStatus(i);
- var delspclspec = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec"));
- if (delstatus == 1 || delstatus == 3) { // 0 : new, 3 : insert & new
- if (delspclspec == "") {
- grd_clcjlist.deleteItem(i);
- }
- }
- }
- // 입력행 추가
- fSpclGridInsertRow();
- } else if (rdounitflag == "M") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'M']";
- grd_clcjlist.rebuild();
- } else if (rdounitflag == "J") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'J']";
- grd_clcjlist.rebuild();
- }
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var status = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("status"));
- if (status != "") {
- grd_clcjlist.rowStatus(i) = status;
- }
- if (unitflag == "M") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M'and cdid != 'MX999']";
- } else if (unitflag == "J") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J' ]";
- }
- }
- } // 처리 건수
- } else {
- sysf_messageBox("EDI코드가 없는 경우 해당 줄단위 특정내역이", "I004"); ///EDI코드가 없는 경우 해당 줄단위 특정내역이 없습니다.
- }
- //명단위 특정내역으르 클릭한경우(unitflag =="M") 또는 빈칸을 클릭한경우는 명단위 특정내역으로 구분한다. 2007.09.23 박도형
- }else{
- ds_hidden_sppij00500_rslt.clearData(); // SPPIZ00500_특정내역상세관리 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_sppij00500_cond.clearData(); ds_hidden_sppij00500_cond.addRow();
- var edicd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("edicd"));
- var spclcd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("spclcd"));
- var spclcdnm = "";
- var spclspec = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("spclspec"));
- var remfact = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("remfact"));
- var detldesc = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("detldesc"));
- //줄단위 명단위 특정내역 구분.
- var unitflag = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("unitflag"));
- var calcscorcd = grd_clcjlist.valueMatrix(row, grd_clcjlist.colRef("calcscorcd"));
- ds_hidden_sppij00500_cond.setColumn( 0, "pid", pid);
- ds_hidden_sppij00500_cond.setColumn( 0, "indd", indd);
- ds_hidden_sppij00500_cond.setColumn( 0, "edicd", edicd);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclcd", spclcd);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclcdnm", spclcdnm);
- ds_hidden_sppij00500_cond.setColumn( 0, "remfact", remfact);
- ds_hidden_sppij00500_cond.setColumn( 0, "spclspec", spclspec);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "M");
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd);
- // 명단위도 기존 입력된 내역까지 다 보낸다. 2008.01.04 박지욱
- var rowcnt = 1;
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var spclcd = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd"));
- if (unitflag == "M" && grd_clcjlist.rowstatus(i) != 4 && spclcd != "") {
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "pid", pid);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "indd", indd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "flag", "U");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "edicd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("edicd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcdnm", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcdnm")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclspec", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "detldesc", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("detldesc")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "remfact", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("remfact")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "unitflag", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "rownum", i);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclcd", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclspec", grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", calcscorcd);
- if (row == i) {
- setrow = i;
- }
- rowcnt = rowcnt+1;
- }
- }
- frmf_modal("SPPIJ00500", "SPPIJ00500", "ds_hidden_sppij00500""-"ds_hidden_clcj"", "", "", "10", "10", "", "", "", "", "", "M");
- var rsltcnt = ds_hidden_sppij00500_rslt_list.rowcount;
- // 처리 건수
- if (rsltcnt > 0) {
- for(var i=rsltcnt; i>0; i--) {
- var flag = ds_hidden_sppij00500_rslt_list.getColumn(i, "flag");
- var rownum = ds_hidden_sppij00500_rslt_list.getColumn(i, "rownum");
- var edicd = ds_hidden_sppij00500_rslt_list.getColumn(i, "edicd");
- var newspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcd");
- var newspclcdnm = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcdnm");
- var newspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclspec");
- var newremfact = ds_hidden_sppij00500_rslt_list.getColumn(i, "remfact");
- var newdetldesc = ds_hidden_sppij00500_rslt_list.getColumn(i, "detldesc");
- // 특정코드 추가인 경우
- if (flag == "I") {
- var clsprow = grd_clcjlist.rows - 1; // 특정내역 Grid 가장 마지막 줄에 추가한다.
- grd_clcjlist.insertRow(clsprow++, true,false,false);
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("unitflag")) = unitflag;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("edicd")) = edicd;
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("status")) = "3";
- // pid, indd, cretno, fromdd, mskind, spclmemoflag, seqno 세팅
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("pid")) = ds_send.getColumn(0, "pid");
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("indd")) = ds_send.getColumn(0, "indd");
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("cretno")) = ds_send.getColumn(0, "cretno");
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("fromdd")) = ds_send.getColumn(0, "fromdd");
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("mskind")) = ds_send.getColumn(0, "mskind");
- grd_clcjlist.valueMatrix(clsprow, grd_clcjlist.colRef("spclmemoflag")) = "E";
- // 특정코드 변경인 경우
- } else if (flag == "U") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("unitflag")) = unitflag;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("edicd")) = edicd;
- if ( grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) != "3") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "0";
- }
- ds_hidden_item1.setColumn( 0, "message", "특정코드 - "+ newspclcd +" / 특정내역 : "+ newspclspec +" / 기재형식 : "+ newremfact);
- // 특정코드 삭제인 경우
- } else if (flag == "D" && rownum != "" ) {
- // 특정내역 Grid에서 삭제
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(rownum, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(rownum) = 4; // 4 : delete 상태로 stat를 변경한다.
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "4";
- }
- }
- }
- // 그리드 정렬 & 한줄추가
- //fSortSpclNo();
- //fSaveClcjList();
- } // 처리건수
- }
- }
- // 처방 행 삭제 or 삭제취소 후에 특정내역 sorting 작업
- function fSortSpclNo() {
- // 빈 줄을 삭제한다.
- for (var i = 1; i < grd_clcjlist.rows; i++) {
- var rowstatus = grd_clcjlist.rowstatus(i);
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- if (spclcd == "") {
- // 줄을 삭제한다.
- grd_clcjlist.deleteRow(i, false);
- i--;
- }
- }
- }
- // JS010(특정코드:야간가산)의 hhmm이 야간(18~09시)가 아니면 특정내역 Grid에 빨간색으로 표시
- for(var i = 1; i < grd_clcjlist.rows; i++) {
- grd_clcjlist.rowStyle(i, "data", "color") = "#000000";
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- var spclspec = ds_main_list4_clcjlist.getColumn(i, "spclspec");
- if (spclcd == "JS010") {
- var js010chk = false;
- if (spclspec.length >= 12) {
- var ccyymmddhhmm = spclspec.substr(0, 12);
- if (utlf_isValidDateTime(ccyymmddhhmm, "YYYYMMDDhhmm")) { // (dateHelper.js) 유효한 날짜, 시간 인지 점검
- var hhmm = parseInt(spclspec.substr(8, 4), 10); // '09' 와 같은 형식으로 입력한 경우 -> 9로 처리
- if (hhmm >= 1800 || hhmm < 900) {
- js010chk = true;
- }
- }
- }
- if (js010chk == false) {
- grd_clcjlist.rowStyle(i, "data", "color") = "#ff3333"; // ff3333=붉은색
- }
- }
- }
- grd_clcjlist.colsort(grd_clcjlist.colRef("unitflag")) = "desc";
- grd_clcjlist.colsort(grd_clcjlist.colRef("edicd")) = "asc";
- grd_clcjlist.colsort(grd_clcjlist.colRef("spclcd")) = "asc";
- grd_clcjlist.colsort(grd_clcjlist.colRef("status")) = "desc";
- var maxRow = parseInt(grd_clcjlist.rows) - 1; // rows는 타이틀부분 부터 개수를 센다.
- var maxCol = parseInt(grd_clcjlist.cols) - 1;
- grd_clcjlist.sort(grd_clcjlist.fixedRows, grd_clcjlist.fixedCols, maxRow, maxCol) = "usersort";
- // Sort 된 Grid 상의 Data 순서와 Instance Node 상의 Data 순서를 동일하게 맞춰준다.
- grd_clcjlist.gridToInstance();
- // 빈줄 추가
- fSpclGridInsertRow();
- }
- function fSetLnUnitSpclcjec() { // 'T' 필드 더블클릭시 호출한다.
- var rdounitflag = ds_send.getColumn(0, "unitflag");
- // pid,indd추가 결과조회 팝업호출을 위하여 - 20080922 박창원
- var pid = ds_main_item1_iteminfo.getColumn(0, "pid");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- if (rdounitflag == "M") {
- // 줄단위로 셋팅하고 처리
- rdo_unitflag.value = "J";
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'J']";
- grd_clcjlist.rebuild();
- // 단위에 필터에 따라 해당 행있는 특정코드 콤보 재설정
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var status = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("status"));
- if (status != "") {
- grd_clcjlist.rowStatus(i) = status;
- }
- if (unitflag == "M") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M'' and cdid != 'MX999']";
- } else if (unitflag == "J") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J']";
- }
- }
- }
- var row = grd_ordlist.row;
- var rows = grd_clcjlist.rows;
- ds_hidden_sppij00500_rslt.clearData(); // SPPIJ00500_특정내역상세관리 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_sppij00500_cond.clearData();
- // 처방 Grid에서 줄번호가 부여된 경우
- //var edicd = ds_main_list2_iscllist.getColumn(row, "edicd"));
- var edicd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("edicd"));
- var calcscorcd = grd_ordlist.valueMatrix(row, grd_ordlist.colref("snglcalcscorcd")); // 수정추가 JHP 특정내역에 수가코드 추가하기. 20090423
- var rowcnt = 1;
- var setrow = 0;
- if (edicd) {
- if (rows == 1) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd); // 수정추가 JHP 특정내역에 수가코드 추가하기. 20090423
- dsf_makeValue( ds_hidden_sppij00500_cond, "edicd", "string", edicd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "J");
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "I");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", "JX999");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", "");
- } else {
- for (var i=1; i<rows; i++) {
- var clcjcalcscorcd = grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("calcscorcd"));
- var clcjedicd = grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("edicd"));
- var spclcd = grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd"));
- if ( edicd == clcjedicd) {
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "flag", "U");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("calcscorcd"))); // 수정추가 JHP 특정내역에 수가코드 추가하기. 20090423
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "edicd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("edicd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "detldesc", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("detldesc")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclcdnm", "");
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "spclspec", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "remfact", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("remfact")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "rownum", i);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "unitflag", "J")
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclcd", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclcd")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "oldspclspec", grd_clcjlist.valueMatrix( i,grd_clcjlist.colRef("spclspec")));
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "pid", pid);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "indd", indd);
- ds_hidden_sppij00500_cond_list.setColumn( rowcnt, "calcscorcd", "");
- rowcnt = rowcnt+1;
- // 특정내역 상세 화면에 보여줄 특정내역 선택
- setrow = i;
- }
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", calcscorcd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "edicd", "string", edicd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "unitflag", "string", "J");
- if ( setrow != 0 ) {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "U");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("spclcd")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("detldesc")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("spclspec")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", grd_clcjlist.valueMatrix(setrow,grd_clcjlist.colRef("remfact")));
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", setrow);
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", "");
- } else {
- dsf_makeValue( ds_hidden_sppij00500_cond, "pid", "string", pid);
- dsf_makeValue( ds_hidden_sppij00500_cond, "indd", "string", indd);
- dsf_makeValue( ds_hidden_sppij00500_cond, "flag", "string", "I");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcd", "string", "JX999");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclcdnm", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "detldesc", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "spclspec", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "remfact", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "rownum", "string", "");
- dsf_makeValue( ds_hidden_sppij00500_cond, "calcscorcd", "string", "");
- }
- }
- }
- ds_hidden_sppij00500_rslt.clearData();
- frmf_modal("SPPIJ00500", "SPPIJ00500", "ds_hidden_sppij00500""-"ds_hidden_clcj"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIJ00500_특정내역상세관리.xrw
- var rsltcnt = ds_hidden_sppij00500_rslt_list.rowcount;
- // 처리 건수
- if (rsltcnt > 0) {
- for(var i=rsltcnt; i>0; i--) {
- var flag = ds_hidden_sppij00500_rslt_list.getColumn(i, "flag");
- var rownum = ds_hidden_sppij00500_rslt_list.getColumn(i, "rownum");
- var calcscorcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "calcscorcd");
- var edicd = ds_hidden_sppij00500_rslt_list.getColumn(i, "edicd");
- var newspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcd");
- var newspclcdnm = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclcdnm");
- var newspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "spclspec");
- var newremfact = model.getValue("ds_hidden_sppij00500_rslt_list["+ i +"]_remfact ");
- var newdetldesc = ds_hidden_sppij00500_rslt_list.getColumn(i, "detldesc");
- var oldspclcd = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclcd");
- var oldspclspec = ds_hidden_sppij00500_rslt_list.getColumn(i, "oldspclspec");
- // 특정코드 추가인 경우
- if (flag == "I") {
- var clcjrow = grd_clcjlist.rows - 1; // 특정내역 Grid 가장 마지막 줄에 추가한다.
- grd_clcjlist.insertRow(clcjrow++, true,false,false);
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("pid")) = ds_send.getColumn(0, "pid");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("indd")) = ds_send.getColumn(0, "indd");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("cretno")) = ds_send.getColumn(0, "cretno");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("fromdd")) = ds_send.getColumn(0, "fromdd");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("mskind")) = ds_send.getColumn(0, "mskind");
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("unitflag")) = "J";
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("calcscorcd")) = calcscorcd;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("edicd")) = edicd;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("spclmemoflag")) = "E";
- grd_clcjlist.valueMatrix(clcjrow, grd_clcjlist.colRef("status")) = "3";
- // 처방Grid에서도 해당 줄단위 특정내역의 'T' 컬럼의 "*" 를 표시한다.
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "*");
- //
- //model.refresh();
- 최적화 문제로 20080731 박창원
- }
- }
- // 특정코드 변경인 경우
- } else if (flag == "U") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcd")) = newspclcd;
- //grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclcdnm")) = newspclcdnm;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("spclspec")) = newspclspec;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("remfact")) = newremfact;
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("detldesc")) = newdetldesc;
- if ( grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) != "3") {
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "0";
- }
- //model.refresh();
- // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
- if (oldspclcd != newspclcd || oldspclspec != newspclspec || grd_clcjlist.rowstatus(row) == 4) {
- var rowstatus = grd_clcjlist.rowstatus(rownum);
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- } else {
- grd_clcjlist.rowstatus(rownum) = 2; // 2 : update 상태로 stat를 변경한다.
- grd_clcjlist.valueMatrix(rownum, grd_clcjlist.colRef("status")) = "2";
- }
- }
- // 처방Grid에서도 해당 줄단위 특정내역의 'T' 컬럼의 "*" 를 표시한다.
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "*");
- //
- //model.refresh();
- 최적화 문제로 20080731 박창원
- }
- }
- ds_hidden_item1.setColumn( 0, "message", "특정코드 - "+ newspclcd +" / 특정내역 : "+ newspclspec +" / 기재형식 : "+ newremfact);
- // 특정코드 삭제인 경우
- } else if (flag == "D" && rownum != "" ) {
- var cnt = 0;
- for (var j = 1; j < grd_clcjlist.rows; j++) {
- var clcjedicd = ds_main_list4_clcjlist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- if (grd_clcjlist.rowstatus(j) != 4) {
- cnt++;
- }
- }
- }
- if (cnt > 0) {
- } else {
- grd_ordlist.valueMatrix(row, grd_ordlist.colref("text")) = "";
- //model.resetInstanceNode("ds_main_list2_iscllist["+ row +"]_text");
- }
- // 특정내역 Grid에서 삭제
- var rowstatus = grd_clcjlist.rowstatus(rownum);
- if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(rownum, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(rownum) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- grd_clcjlist.row = rownum;
- var rowcnt = ds_main_list2_iscllist.rowcount; // 필터
- rowcnt = eval(rowcnt) + 1;
- for (var j = 1; j < rowcnt; j++) {
- //for (var j = 1; j < grd_ordlist.rows; j++) {
- var clcjedicd = ds_main_list2_iscllist.getColumn(j, "edicd");
- if (edicd == clcjedicd) {
- ds_main_list2.setColumn( j , "text", "");
- //
- //model.refresh();
- 최적화 문제로 20080731 박창원
- }
- }
- } // 특정 코드 상태 따른 if end
- } // for end
- var rdounitflag = ds_send.getColumn(0, "unitflag");
- if (rdounitflag == "-") {
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var delstatus = grd_clcjlist.rowStatus(i);
- var delspclspec = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec"));
- if (delstatus == 1 || delstatus == 3) { // 0 : new, 3 : insert & new
- if (delspclspec == "") {
- grd_clcjlist.deleteItem(i);
- }
- }
- }
- // 입력행 추가
- fSpclGridInsertRow();
- } else if (rdounitflag == "M") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'M']";
- grd_clcjlist.rebuild();
- } else if (rdounitflag == "J") {
- grd_clcjlist.attribute("nodeset") = "ds_main_list4_clcjlist[unitflag = 'J']";
- grd_clcjlist.rebuild();
- }
- for (var i=1; i<grd_clcjlist.rows; i++) {
- var unitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- var status = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("status"));
- if (status != "") {
- grd_clcjlist.rowStatus(i) = status;
- }
- if (unitflag == "M") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'M' and cdid != 'MX999']";
- } else if (unitflag == "J") {
- grd_clcjlist.cellComboNodeset(i,3) = "ds_init_P0117list_P0117[minval = 'J']";
- }
- }
- } // 처리 건수 if end
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list2_iscllist");
- model.refreshpart("ds_main_list4_clcjlist");
- } else {
- sysf_messageBox("EDI코드가 없는 경우 해당 줄단위 특정내역이", "I004"); ///EDI코드가 없는 경우 해당 줄단위 특정내역이 없습니다.
- }
- }
- function fGetStageTNM(){
- ds_hidden_smpij02000_rslt.clearData(); // SMPIZ02000_환자별암병기분류조회 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_smpij02000_cond.clearData(); ds_hidden_smpij02000_cond.addRow();
- ds_hidden_smpij02000_cond.setColumn( 0, "pid", ds_main_item1_iteminfo.getColumn(0, "pid"));
- ds_hidden_smpij02000_cond.setColumn( 0, "insuflag", "");
- frmf_modal("SMPIJ02000", "SMPIJ02000", "ds_hidden_smpij02000_cond""-"ds_send_list01"", "", "", "10", "10", "", "", "", "", "", "M");
- }
- //심사자 메모 팝업 갱신
- function fSetJudgMemoRefresh(){
- //model.refresh();
- var memo = ds_hidden_sppiz00700_rslt.getColumn(0, "memo");
- var tmp = ds_main_item1_iteminfo.getColumn(0, "judgrmk");
- if(tmp){
- tmp = tmp + " ";
- }
- ds_main_item1_iteminfo.setColumn( 0, "judgrmk",tmp + memo);
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- //model.refresh();
- }
- //EDI 메모 팝업 갱신
- function fSetEdiMemoRefresh(){
- var memo = ds_hidden_sppiz00700_rslt.getColumn(0, "memo");
- var tmp = ds_main_item1_iteminfo.getColumn(0, "edirmk");
- if(tmp){
- tmp = tmp + " ";
- }
- ds_main_item1_iteminfo.setColumn( 0, "edirmk",tmp + memo);
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- //model.refresh();
- }
- //확인코드(JT001) 줄단위 특정내역 입력
- function fCnfmCdInsert(){
- var trgtManWindow = getChildWindow("SPPIJ00500");
- //var edicd = ds_main_list2_iscllist.getColumn(grd_ordlist.row, "edicd"));
- var edicd = grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colref("edicd"));
- var selectededicd = "";
- var row = 0;
- ds_hidden_sppij00500_rslt.clearData(); // SPPIZ00500_특정내역상세관리 에서 선택된 결과가 copyNode되는 경로임
- ds_hidden_sppij00500_cond.clearData(); ds_hidden_sppij00500_cond.addRow();
- if(edicd){
- for (var i = 1; i < grd_clcjlist.rows; i++) {
- if(edicd == ds_main_list4_clcjlist.getColumn(i, "edicd")){
- ds_hidden_sppij00500_cond.setColumn( 0, "edicd", ds_main_list4_clcjlist.getColumn(i, "edicd"));
- ds_hidden_sppij00500_cond.setColumn( 0, "spclcd", ds_main_list4_clcjlist.getColumn(i, "spclcd"));
- ds_hidden_sppij00500_cond.setColumn( 0, "remfact", ds_main_list4_clcjlist.getColumn(i, "remfact"));
- ds_hidden_sppij00500_cond.setColumn( 0, "spclspec", ds_main_list4_clcjlist.getColumn(i, "spclspec"));
- ds_hidden_sppij00500_cond.setColumn( 0, "row", i);
- selectededicd = edicd;
- row = i;
- }
- }
- //이미 등록된 확인코드가 있는경우
- if(selectededicd){
- ds_hidden_sppij00500_cond.setColumn( 0, "unitflag", "J");
- var chk = ds_hidden_sppij00500_cond.getColumn(0, "spclcd");
- if(chk == "JT001"){
- ds_hidden_sppiz01100_rslt.clearData();
- dsf_makeValue( ds_hidden_sppiz01100_cond, "code", "string", ds_hidden_sppij00500_cond.getColumn(0, "spclspec"));
- dsf_makeValue( ds_hidden_sppiz01100, "edicd", "string", edicd);
- frmf_modal("SPPIZ01100", "SPPIZ01100", "ds_hidden_sppiz01100""-"ds_init_sppiz01100"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ01100_확인코드조회
- if (instance1.selectSingleNode("ds_hidden_sppiz01100_rslt")) {
- ds_main_list4.setColumn( row , "spclspec", ds_hidden_sppiz01100_rslt.getColumn(0, "code"));
- //Combo 줄단위 코드로 셋팅
- grd_clcjlist.cellComboNodeset(row,3) = "ds_init_P0117list_P0117[minval = 'J']";
- grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colref("cnfmcd")) = ds_hidden_sppiz01100_rslt.getColumn(0, "code");
- //model.refresh();
- fSpclGridInsertRow() ;
- }
- }
- //등록된 확인코드가 없으면 신규로 발생시켜준다.
- }else{
- ds_hidden_sppiz01100_rslt.clearData();
- dsf_makeValue( ds_hidden_sppiz01100_cond, "code", "string", "");
- frmf_modal("SPPIZ01100", "SPPIZ01100", "ds_hidden_sppiz01100""-"ds_init_sppiz01100"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ01100_확인코드조회
- if (instance1.selectSingleNode("ds_hidden_sppiz01100_rslt")) {
- fSpclGridInsertRow() ;
- var row = grd_clcjlist.rows - 1;
- //Combo 줄단위 코드로 셋팅
- grd_clcjlist.cellComboNodeset(row,3) = "ds_init_P0117list_P0117[minval = 'J']";
- ds_main_list4.setColumn( row , "edicd", edicd);
- ds_main_list4.setColumn( row , "spclcd", "JT001");
- ds_main_list4.setColumn( row , "unitflag","J");
- ds_main_list4.setColumn( row , "spclmemoflag","E" );
- ds_main_list4.setColumn( row , "remfact", "X(5)");
- ds_main_list4.setColumn( row , "spclspec", ds_hidden_sppiz01100_rslt.getColumn(0, "code"));
- grd_ordlist.valueMatrix(grd_ordlist.row, grd_ordlist.colref("cnfmcd")) = ds_hidden_sppiz01100_rslt.getColumn(0, "code");
- //ds_main_list2.setColumn( 0, "iscllist[" + grd_ordlist.row + "]_cnfmcd",ds_hidden_sppiz01100_rslt.getColumn(0, "code"));
- fSpclGridInsertRow() ;
- }
- }
- //특정내역이 있는 처방에 'T'필드에 *표를 해준다.
- //fSetOrdSpclTxt();
- }
- }
- ///////////////////////////////////////////////////////////////////////////
- //특정내역 관련 코딩 종료 //
- ///////////////////////////////////////////////////////////////////////////
- ///////////////////////////////////////////////////////////////////////////
- // 조합기호(ipt_cmpyno)를 입력하면 해당 조합명칭을 조회한다.
- function fGetCmpyNm() {
- /*var rrgstno = ds_main_item1_iteminfo.getColumn(0, "rrgstno");
- rrgstno = rrgstno.replace("-","");
- //보험증번호 조회(보험자격조회)
- var parm = rrgstno + "▦" + //주민번호
- ds_main_item1_iteminfo.getColumn(0, "patnm") + "▦" + //이름
- ds_main_item1_iteminfo.getColumn(0, "indd") + "▦";//진료일자
- frmf_setParameter("SPPMC03700_PARM",parm);
- frmf_setParameter("SPPMC03700_RTN","");
- frmf_modal("SPPMC03700", "SPPMC03700", ""-"", "", "1", "400", "400", "", "", "", "", "", "M"); */
- }
- //보조유형이 바뀌는경우
- function fSetPatSuppRate() {
- // 보조유형ID과 요율%로 combo 의 value
- // 보조유형NM과 요율%로 combo 의 label
- //cmb_suppkind.choices.itemset.attribute("nodeset") = "ds_main_item4_insu[suppkind = '"+ cmb_suppkind.value +"']";
- var suppkindcd = ds_main_item4_insu.getColumn(0, "suppkind");
- var payownbrate = ds_main_item4_insu.getColumn(0, "ownbrate");
- ds_main_item1_iteminfo.setColumn( 0, "suppkindcd", suppkindcd);
- ds_main_item1_iteminfo.setColumn( 0, "ownrate", payownbrate);
- if(payownbrate == "20"){
- opt_suppkind.attribute("class") = "output_fix";
- }else{
- opt_suppkind.attribute("color") = "#ff0066";
- }
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_item1_iteminfo");
- }
- ///////////////////////////////////////////////////////////////////////////
- //처방 관련 코딩 시작 //
- ///////////////////////////////////////////////////////////////////////////
- //처방조회 옵션에 항목구분에 처방이 있는 것만 Bold로 보여준다.
- //이건 처음에 로드했을때 한번만 도는것이라서 따로 분리하여 만듬. 2007.09.09 박도형
- // 최적화 문제로 else if를 사용하여 수정 - 20081017 박창원
- function fSetItemBold(){
- rdo_ordfilflag.item(0).attribute("font-weight") = "bold"; // "전체" 항목은 default 로 굵게 표시한다.
- //우선 초기화를 한다.
- rdo_ordfilflag.item(1).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(2).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(3).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(4).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(5).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(6).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(7).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(8).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(9).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(10).attribute("font-weight") = "normal";
- rdo_ordfilflag.item(11).attribute("font-weight") = "normal";
- // 처방 조회부 항목구분 Radio에서 해당 처방이 있는 item을 굵게 표시한다.
- var item1 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 01 + "'", "item1"); //항목구분 에 Bold처리하기 위한 체크
- var item2 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 02 + "'", "item1");
- var item3 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 03 + "'", "item1");
- var item4 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 04 + "'", "item1");
- var item5 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 05 + "'", "item1");
- var item6 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 06 + "'", "item1");
- var item7 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 07 + "'", "item1");
- var item8 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 08 + "'", "item1");
- var item9 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 09 + "'", "item1");
- var item10 = ds_main_list2_iscllist.lookupExpr("item1 == '" + 10 + "'", "item1");
- var itemSS = ds_main_list2_iscllist.lookupExpr("item1 == '" + SS + "'", "item1");
- if (item1 == "01") {
- rdo_ordfilflag.item(1).attribute("font-weight") = "bold";
- }
- if (item2 == "02") {
- rdo_ordfilflag.item(2).attribute("font-weight") = "bold";
- }
- if (item3 == "03") {
- rdo_ordfilflag.item(3).attribute("font-weight") = "bold";
- }
- if (item4 == "04") {
- rdo_ordfilflag.item(4).attribute("font-weight") = "bold";
- }
- if (item5 == "05") {
- rdo_ordfilflag.item(5).attribute("font-weight") = "bold";
- }
- if (item6 == "06") {
- rdo_ordfilflag.item(6).attribute("font-weight") = "bold";
- }
- if (item7 == "07") {
- rdo_ordfilflag.item(7).attribute("font-weight") = "bold";
- }
- if (item8 == "08") {
- rdo_ordfilflag.item(8).attribute("font-weight") = "bold";
- }
- if (item9 == "09") {
- rdo_ordfilflag.item(9).attribute("font-weight") = "bold";
- }
- if (item10 == "10") {
- rdo_ordfilflag.item(10).attribute("font-weight") = "bold";
- }
- if (itemSS == "SS") {
- rdo_ordfilflag.item(11).attribute("font-weight") = "bold";
- }
- }
- // 항목별소계
- function fSetItemSubTotal() {
- grd_ordlist.rebuildStyle();
- grd_ordlist.rebuild();
- // ****************************************************************************************************************
- // 항목별 소계 subtotal 김상진 20101122
- // ****************************************************************************************************************
- // #ffff0| 밝은노랑
- // #d9e3fe 옅은파랑
- // #eeddff 옅은보라
- // #b9fcf8 밝은하늘
- // #cefcfa 옅은하늘
- var grdobj = document.controls.item("grd_ordlist");
- if (model.getValue(chk_showsubtotal.attribute("ref")) == "Y") {
- var col_hngnm = grdobj.colRef("hngnm");
- var col_item1 = grdobj.colRef("item1");
- var subtot_style = "background-color:#cefcfa; color:#0000ff;font-weight:bold;"
- var subtot_fromat = "format:(-)#,###; roundmode:round; roundposition:0"
- grdobj.subtotalposition= "below";
- grdobj.subtotal("sum", col_item1, grdobj.colRef("hospaddamt"),subtot_fromat, subtot_style, col_hngnm, col_hngnm, true);
- grdobj.subtotal("sum", col_item1, grdobj.colRef("specamt"),subtot_fromat, subtot_style, col_hngnm, col_hngnm, true);
- grdobj.subtotal("sum", col_item1, grdobj.colRef("totordamt"),subtot_fromat, subtot_style, col_hngnm, col_hngnm, true);
- grdobj.subtotal("sum", col_item1, grdobj.colRef("calcamt"),subtot_fromat, subtot_style, col_hngnm, col_hngnm, true);
- var srchnm = "";
- var fild1 = "0";
- var rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_item1, true, true);
- while( rowno > 0){
- var fild1 = "0";
- fild1 = grd_ordlist.valueMatrix(rowno, col_hngnm);
- if(fild1 == "01"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "진찰료 소계";
- }else if(fild1== "02"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "입원료 소계";
- }else if(fild1 == "03"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "투약료 소계";
- }else if(fild1 == "04"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "주사료 소계";
- }else if(fild1 == "05"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "마취료 소계";
- }else if(fild1 == "06"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "이학료 소계";
- }else if(fild1 == "07"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "정신료 소계";
- }else if(fild1 == "08"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "수술료 소계";
- }else if(fild1 == "09"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "검사료 소계";
- }else if(fild1 == "10"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "방사선 소계";
- }else if(fild1 == "SS"){
- grd_ordlist.valueMatrix(rowno, col_hngnm) = "특수 소계";
- }
- rowno = grdobj.findRow(srchnm, rowno + 1,col_item1,true,true);
- }
- }
- }
- //범례 색깔을 표시한다.
- function fSetColorSpclJudgOrder() {
- //일단 수정변경 : 20090915 : JHP 필터기능으로 숨김기능이 제어가 되어서 for문을 돌릴때 i의 제어가 어렵다 하여 datagrid의 rows로 for문을 돌리는걸로 변경한다.
- if (model.getValue(chk_showitemcoloryn.attribute("ref")) == "Y") {
- fSetOrderColorByEdiitem();
- }
- //Color 표시 범례
- //1. 문제처방 : #fcd2c1
- //2. 선별심사 : #ffe79d
- //3. 선별심사 + 문제처방 : #7BE6B7
- //4. 야간, 공휴가산 : #ffff00(밝은노랑)
- //선별심사, 문제처방 체크 (기왕증, CP보다 우선시 한다. -심사자가 기왕증 ,CP여부를 확인하고 문제처방을 한경우 임으로)
- var grdobj = document.controls.item("grd_ordlist");
- var col_hngnm = grdobj.colRef("hngnm");
- var col_probordyn = grdobj.colRef("probordyn");
- var srchnm = "Y";
- var spcljudgyn = "";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_probordyn, true, true);
- while( rowno > 0){
- grd_ordlist.setCellProprty("body", rowno, "background", "#fcd2c1"); grd_ordlist.setCellProperty("body", rowno, "background2", "#fcd2c1");
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_probordyn, true, true);
- }
- var col_spcljudgyn = grdobj.colRef("spcljudgyn");
- var probordyn = "";
- var rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_spcljudgyn, true, true);
- while( rowno > 0){
- grd_ordlist.setCellProprty("body", rowno, "background", "#ffe79d"); grd_ordlist.setCellProperty("body", rowno, "background2", "#ffe79d");
- probordyn = grdobj.valueMatrix(rowno, col_probordyn);
- if (probordyn == "Y"){ //둘다 체크된경우
- grd_ordlist.setCellProprty("body", rowno, "background", "#7BE6B7"); grd_ordlist.setCellProperty("body", rowno, "background2", "#7BE6B7");
- }
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_spcljudgyn, true, true);
- }
- // 야간가산(산정의미 두번째 "1'), 공휴가산(산정의미 두번째자리 "5")
- var col_estmmeancd = grdobj.colRef("estmmeancd");
- var col_pay100 = grdobj.colRef("pay100");
- srchnm = "1";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_estmmeancd, false, false);
- while( rowno > 0){
- if ( grdobj.valueMatrix(rowno,col_estmmeancd).substr(1, 1) == "1" ){
- grdobj.cellStyle("background-color", rowno, col_estmmeancd, rowno, col_pay100) = "#ffff00";
- }
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_estmmeancd, false, false);
- }
- // 야간가산(산정의미 두번째 "1'), 공휴가산(산정의미 두번째자리 "5")
- srchnm = "5";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_estmmeancd, false, false);
- while( rowno > 0){
- if ( grdobj.valueMatrix(rowno,col_estmmeancd).substr(1, 1) == "5" ){
- grdobj.cellStyle("background-color", rowno, col_estmmeancd, rowno, col_pay100) = "#ffff00";
- }
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_estmmeancd, false, false);
- }
- //DRG 수술구분
- var col_drgopyn = grdobj.colRef("drgopyn");
- srchnm = "Y";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_drgopyn, true, true);
- while( rowno > 0){
- grdobj.cellStyle("background-color", rowno, col_pay100, rowno, col_pay100) = "#fec34d";
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_drgopyn, true, true);
- }
- // 급여구분 본인부담, 일반 색깔구분
- var col_calcpayflag = grdobj.colRef("calcpayflag");
- srchnm = "1";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_calcpayflag, true, true);
- while( rowno > 0){
- grdobj.cellStyle("background-color", rowno, col_calcpayflag, rowno, col_calcpayflag) = "#00ff00";
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_calcpayflag, true, true);
- }
- srchnm = "2";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_calcpayflag, true, true);
- while( rowno > 0){
- var pynpy = grdobj.valueMatrix(rowno,grdobj.colRef("pynpy"));
- if (pynpy != 0) {
- grdobj.cellStyle("background-color", rowno, col_calcpayflag, rowno, col_calcpayflag) = "#ccccff";
- } else {
- grdobj.cellStyle("background-color", rowno, col_calcpayflag, rowno, col_calcpayflag) = "#ff99cc";
- }
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_calcpayflag, true, true);
- }
- // 외래 필수심사 품목 표기
- var col_bfjudgyn = grdobj.colRef("bfjudgyn");
- srchnm = "Y";
- rowno = grdobj.findRow(srchnm,grdobj.fixedrows ,col_bfjudgyn, true, true);
- while( rowno > 0){
- grdobj.cellStyle("background-color", rowno, col_hngnm, rowno, col_hngnm) = "#f7a08b";
- rowno = grdobj.findRow(srchnm,rowno + 1 ,col_bfjudgyn, true, true);
- }
- var spclcnt = grd_clcjlist.rows;
- var col_edicd = grdobj.colRef("edicd");
- var spclcd = "";
- var spclspec = "";
- var spcledicd = "";
- var spclunitflag = "";
- for (var i = 0; i < spclcnt; i++) {
- spclcd = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclcd"));
- spclspec = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("spclspec"));
- spcledicd = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("edicd"));
- spclunitflag = grd_clcjlist.valueMatrix(i, grd_clcjlist.colRef("unitflag"));
- if (spclunitflag == 'J') { // 줄단위 특정내역인 경우만 적용한다. (2015.03.30 LEJ)
- rowno = grdobj.findRow(spcledicd,grdobj.fixedrows ,col_edicd, true, true);
- while( rowno > 0){
- if(spclcd == "JT001"){
- grdobj.valueMatrix(rowno,grdobj.colRef("cnfmcd")) = spclspec;
- }else{
- grdobj.valueMatrix(rowno,grdobj.colRef("text")) = "*";
- }
- rowno = grdobj.findRow(spcledicd,rowno + 1 ,col_edicd, true, true);
- }
- }
- }
- }
- //특정내역이 있는 처방에 'T'필드에 *표를 해준다.
- function fSetOrdSpclTxt(){
- var cSrcNode = instance1.selectSingleNode("ds_main_list2_iscllist");
- if (cSrcNode == null) { // 특정내역이 없는 경우임
- return;
- }
- var rowcnt = ds_main_list2_iscllist.rowcount;
- rowcnt = eval(rowcnt) + 1;
- // grd_clcjlist.findRow 로 변경(최적화문제) - 20081017 박창원
- for (var i = 1; i < rowcnt ; i++) { // Grid 필터링 이후 Grid 상에 표시된 처방 개수만큼 돌면서
- var edicd = ds_main_list2_iscllist.getColumn(i, "edicd");
- var spcl = grd_clcjlist.rows;
- ds_main_list2.setColumn( i , "text", "");
- if(spcl > 0){
- if (edicd != "") {
- var row = grd_clcjlist.findRow(edicd, 0, grd_clcjlist.colRef("edicd"), false, true);
- if ( row > 0 ) {
- var spclcd = ds_main_list4_clcjlist.getColumn(row, "spclcd"));
- var spclspec = ds_main_list4_clcjlist.getColumn(row, "spclspec"));
- var spcledicd = ds_main_list4_clcjlist.getColumn(row, "spcledicd"));
- if(edicd == spcledicd){
- if(spclcd == "JT001"){
- ds_main_list2.setColumn( i , "cnfmcd", spclspec);
- }else{
- ds_main_list2.setColumn( i , "text", "*");
- }
- }
- }
- }
- }
- }
- //grd_ordlist.refresh();
- }
- // 처방 치식 입력
- function fOrderToothInput() {
- var row = grd_ordlist.mouseRow;
- ds_hidden_sppiz00600_cond.setColumn( 0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
- ds_hidden_sppiz00600_cond.setColumn( 0, "toot", ds_main_list2_clod.getColumn(row, "toot")));
- ds_hidden_sppiz00600_rslt.clearData(); // SPPIZ00600_상병및처방별치식 에서 선택된 결과가 copyNode되는 경로임
- frmf_modal("SPPIZ00600", "SPPIZ00600", "ds_hidden_sppiz00600_cond""-"ds_hidden_cond"", "", "", "10", "10", "", "", "", "", "", "M"); // SPPIZ00600_상병및처방별치식.xrw
- var tootSelect = instance1.selectSingleNode("ds_hidden_sppiz00600_rslt");
- if (tootSelect != null) { // 취소를 누른 경우를 제외시킴
- var toot = ds_hidden_sppiz00600_rslt.getColumn(0, "toot");
- ds_main_list3.setColumn( row , "toothYN", ds_hidden_sppiz00600_rslt.getColumn(0, "toothYN"));
- ds_main_list3.setColumn( row , "toot", toot);
- //model.refresh();
- if (ds_hidden_sppiz00600_cond.getColumn(0, "toot") != toot) { // 치식번호가 변경된 경우
- var diagstatus = grd_diaglist.rowstatus(row);
- if (diagstatus == 0 || diagstatus == 2) { // 0 : new, 2 : update
- grd_diaglist.rowstatus(row) = 2; // 2 : update
- }
- }
- }
- }
- ///////////////////////////////////////////////////////////////////////////
- //처방 관련 코딩 끝 //
- ///////////////////////////////////////////////////////////////////////////
- function fSaveAll(){
- ds_send_item1.setColumn( 0, "iteminfo",getNodeListCSV(instance1.selectNodes("ds_main_item1_iteminfo")));
- //상병은 전체 삭제 날리고 다시 insert시킨다.
- //빈데이터를 삭제한다.
- var rowcnt = grd_diaglist.rows;
- for (var i = rowcnt; i > 0; i--) { // Grid 필터링 이후 Grid 상에 표시된 처방 개수만큼 돌면서
- var diagcd = ds_main_list3_diaglist.getColumn(i, "diagcd");
- if(diagcd == ""){
- grd_diaglist.deleteRow(i, false);
- }else{
- grd_diaglist.rowstatus(i) = 3;
- }
- }
- var updtdiag = getGridUpdateData(grd_diaglist);
- if(updtdiag) {
- ds_send.setColumn( 0, "diaglist",grd_diaglist.getUpdateData());
- }
- if (btn_save.disabled == false) {
- //빈데이터를 삭제한다.
- for (var i = 1; i < grd_clcjlist.rows; i++) { // Grid 필터링 이후 Grid 상에 표시된 특정내역 개수만큼 돌면서
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- if(spclcd == ""){
- var rowstatus = grd_clcjlist.rowstatus(i);
- if (rowstatus == 4) { // 4 : delete
- return;
- }
- else if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(i, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(i) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- }
- }
- var updtclcj = getGridUpdateData(grd_clcjlist);
- if(updtclcj) {
- ds_send.setColumn( 0, "clcjlist",grd_clcjlist.getUpdateData());
- //if ( submit("TXPIJ00303") ) {
- //삭제였던 특정내역은 그리드에서 지워 버린다.
- for (var d = grd_clcjlist.rows; d > 0 ; d--) {
- var delstatus = grd_clcjlist.rowstatus(d);
- if(delstatus == 4){
- grd_clcjlist.deleteRow(d, false); // 해당 라인을 Grid에서 삭제한다.
- }
- }
- grd_clcjlist.clearStatus();
- // }
- }
- //저장후 빈행을 추가해 준다.
- fSpclGridInsertRow() ;
- }
- //특정내역 처리
- var judgrmk = ds_main_item1_iteminfo.getColumn(0, "judgrmk");
- var edirmk = ds_main_item1_iteminfo.getColumn(0, "edirmk");
- var tstrmk = ds_main_item1_iteminfo.getColumn(0, "tstrmk");
- var dumprmk = ds_main_item1_iteminfo.getColumn(0, "dumprmk");
- // var tmpedirmk = strTrim(edirmk);
- ds_main_list5.clearData();
- if(judgrmk){
- fSetJudgEDIMemo(judgrmk, "Y");
- }
- if(edirmk){
- fSetJudgEDIMemo(edirmk, "N");
- }
- if(tstrmk){
- fSetJudgEDIMemo(tstrmk, "T");
- }
- if(dumprmk){
- fSetJudgEDIMemo(dumprmk, "D");
- }
- ds_send.setColumn( 0, "spclspec",getNodeListCSV(instance1.selectNodes("ds_main_list5_judgrmk")));
- // submit("TXPIJ00309",false);
- var oParam = {};
- oParam.id = "TXPIJ00309";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveAll";
- oParam.inds = "req=ds_ diagreq=ds_ clcjreq=ds_ spclreq=ds_";
- oParam.outds = "ds_=vcode ds_=rareessc ds_=chkesscedi ds_=getdschcalccheck ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00309";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00309(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00309(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00309") > -1
- arErrorCode.pop("TXPIJ00309") < 0
- */
- }
- //상병리스트를 저장한다.
- function fSaveDiagList(){
- //상병은 전체 삭제 날리고 다시 insert시킨다.
- //빈데이터를 삭제한다.
- var rowcnt = grd_diaglist.rows;
- for (var i = rowcnt; i > 0; i--) { // Grid 필터링 이후 Grid 상에 표시된 처방 개수만큼 돌면서
- var diagcd = ds_main_list3_diaglist.getColumn(i, "diagcd");
- if(diagcd == ""){
- grd_diaglist.deleteRow(i, false);
- }else{
- grd_diaglist.rowstatus(i) = 3;
- }
- }
- var updtdiag = getGridUpdateData(grd_diaglist);
- if(updtdiag) {
- ds_send.setColumn( 0, "diaglist",grd_diaglist.getUpdateData());
- // if ( submit("TXPIJ00302",false) ) {
- var oParam = {};
- oParam.id = "TXPIJ00302";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveDiag";
- oParam.inds = "req=ds_ iteminfo=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00302";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00302(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00302(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00302") > -1
- arErrorCode.pop("TXPIJ00302") < 0
- */
- }
- }
- model.refreshpart("ds_main_list3_diaglist");
- }
- //특정내역을 저장 한다.
- function fSaveClcjList(){
- if (btn_save.disabled == false) {
- //빈데이터를 삭제한다.
- for (var i = 1; i < grd_clcjlist.rows; i++) { // Grid 필터링 이후 Grid 상에 표시된 특정내역 개수만큼 돌면서
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- if(spclcd == ""){
- var rowstatus = grd_clcjlist.rowstatus(i);
- if (rowstatus == 4) { // 4 : delete
- return;
- }
- else if (rowstatus == 1 || rowstatus == 3) { // 1 : insert, 3 : insert & new
- grd_clcjlist.deleteRow(i, false); // 해당 라인을 Grid에서 삭제한다.
- } else { // 0 : new, 2 : update
- grd_clcjlist.rowstatus(i) = 4; // 4 : delete 상태로 stat를 변경한다.
- }
- }
- }
- var updtclcj = getGridUpdateData(grd_clcjlist);
- if(updtclcj) {
- ds_send.setColumn( 0, "clcjlist",grd_clcjlist.getUpdateData());
- // if ( submit("TXPIJ00303",false) ) {
- var oParam = {};
- oParam.id = "TXPIJ00303";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveClcj";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00303";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00303(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00303(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00303") > -1
- arErrorCode.pop("TXPIJ00303") < 0
- */
- //삭제였던 특정내역은 그리드에서 지워 버린다.
- for (var d = grd_clcjlist.rows; d > 0 ; d--) {
- var delstatus = grd_clcjlist.rowstatus(d);
- if(delstatus == 4){
- grd_clcjlist.deleteRow(d, false); // 해당 라인을 Grid에서 삭제한다.
- }
- }
- grd_clcjlist.clearStatus();
- }
- }
- //저장후 빈행을 추가해 준다.
- fSpclGridInsertRow() ;
- }
- }
- //퇴원마감 취소 처리
- function fJudgEndCancel(){
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","A");
- // if (submit("TXPIJ00301",false)) {
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- // submit("TXPIJ03203",false);
- var oParam = {};
- oParam.id = "TXPIJ03203";
- oParam.service = "bfjudgapp.DRGJudgList";
- oParam.method = "reqExeDelDrgCreateMasterInfo";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ03203";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ03203(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ03203(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ03203") > -1
- arErrorCode.pop("TXPIJ03203") < 0
- */
- fSetItemInfoSetting();
- return 1;
- } else {
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","B");
- fSetItemInfoSetting();
- return 0;
- }
- }
- //Link 연결 팝업
- function fLinkPopMenu(trgtWindow, cond, send){
- var trgtManWindow = getChildWindow(trgtWindow);
- if (trgtManWindow == null) {
- frmf_open("trgtWindow ", "trgtWindow", "cond"-"send", "", "", "10", "10", "", "", "", "", "", "M");
- } else {
- activateChild(trgtWindow);
- //model.refresh();
- }
- }
- // 치식 팝업용 데이타 생성
- function fSetToothPop(row, flag) {
- ds_hidden_sppiz00600_cond_list.clearData();
- dsf_makeValue( ds_hidden_sppiz00600_cond, "list", "string", "" );
- // 상병
- var cntdiag = ds_main_list3_diaglist.rowcount;
- // 처방
- var cntiscl = ds_main_list2_iscllist.rowcount;
- var cd = "";
- var cdnm = "";
- var orddd = "";
- var toot = "";
- var rowcnt = 1;
- for (i=1; i<=cntdiag; i++) {
- cd = ds_main_list3_diaglist.getColumn(i, "diagcd");
- cdnm = ds_main_list3_diaglist.getColumn(i, "diagnm");
- orddd = ds_main_list3_diaglist.getColumn(i, "ordfromdd");
- toot = ds_main_list3_diaglist.getColumn(i, "toot");
- estmcls = ds_main_list2_iscllist.getColumn(i, "estmcls"); //20100318 정승우 의정부 오류로 추가
- if (cd != "") {
- if ((toot != "-" && toot != "") || estmcls == "U") {
- var milktoothstr = "ABCDE000";
- var subTootStr = "";
- for (var inx = 0; inx < 32; inx++) {
- var tootnum = toot.substr(inx,1);
- if (tootnum == "*") { // 선택된 영구치의 경우 1~8 사이 숫자로 표시한다.
- if (inx < 8) {
- subTootStr += (8 - inx);
- }
- else if (inx > 7 && inx < 16) {
- subTootStr += (inx - 7);
- }
- else if (inx > 15 && inx < 24) {
- subTootStr += (24 - inx);
- } else {
- subTootStr += (inx - 23);
- }
- } else if (tootnum == "#") { // 선택된 유치의 경우 A~E 사이 알파벳으로 표시한다.
- if (inx < 8) {
- subTootStr += milktoothstr.charAt(7 - inx);
- }
- else if (inx > 7 && inx < 16) {
- subTootStr += milktoothstr.charAt(inx - 8);
- }
- else if (inx > 15 && inx < 24) {
- subTootStr += milktoothstr.charAt(23 - inx);
- } else {
- subTootStr += milktoothstr.charAt(inx - 24);
- }
- } else { // if (tootnum == "0") 선택되지 않은 경우 공백으로 처리한다.
- subTootStr += " ";
- }
- }
- //치식 표기를 설정한다.
- if (row == i && flag == "1" ) {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "true");
- } else {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "false");
- }
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "flag", "상병");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cd", cd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cdnm", cdnm);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightupper", subTootStr.substr(0, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftupper", subTootStr.substr(8, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightlower", subTootStr.substr(16, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftlower", subTootStr.substr(24, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "orddd", orddd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "toot", toot);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "row", i);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "pid", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "indd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cretno", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "instcd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "execdd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "calcseqno", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "calcscorseqno", "");
- rowcnt = rowcnt+1;
- } else {
- if (row == i && flag == "1" ) {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "true");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "flag", "상병");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cd", cd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cdnm", cdnm);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightupper", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftupper", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightlower", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftlower", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "orddd", orddd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "toot", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "row", i);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "pid", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "indd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cretno", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "instcd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "execdd", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "calcseqno", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "calcscorseqno", "");
- rowcnt = rowcnt+1;
- }
- }
- } // if cd != ""
- } // for end
- for (i=1; i<=cntiscl; i++) {
- cd = ds_main_list2_iscllist.getColumn(i, "snglcalcscorcd");
- cdnm = ds_main_list2_iscllist.getColumn(i, "hngnm");
- orddd = ds_main_list2_iscllist.getColumn(i, "ordfromdd");
- toot = ds_main_list2_iscllist.getColumn(i, "tootfact");
- estmcls = ds_main_list2_iscllist.getColumn(i, "estmcls");
- if ((toot != "-" && toot != "") || estmcls == "U") {
- var milktoothstr = "ABCDE000";
- var subTootStr = "";
- var tmpStr = "";
- for (var inx = 0; inx < 32; inx++) {
- var tootnum = toot.substr(inx,1);
- if (tootnum == "*") { // 선택된 영구치의 경우 1~8 사이 숫자로 표시한다.
- if (inx < 8) {
- subTootStr += (8 - inx);
- }
- else if (inx > 7 && inx < 16) {
- subTootStr += (inx - 7);
- }
- else if (inx > 15 && inx < 24) {
- subTootStr += (24 - inx);
- } else {
- subTootStr += (inx - 23);
- }
- } else if (tootnum == "#") { // 선택된 유치의 경우 A~E 사이 알파벳으로 표시한다.
- if (inx < 8) {
- subTootStr += milktoothstr.charAt(7 - inx);
- }
- else if (inx > 7 && inx < 16) {
- subTootStr += milktoothstr.charAt(inx - 8);
- }
- else if (inx > 15 && inx < 24) {
- subTootStr += milktoothstr.charAt(23 - inx);
- } else {
- subTootStr += milktoothstr.charAt(inx - 24);
- }
- } else { // if (tootnum == "0") 선택되지 않은 경우 공백으로 처리한다.
- subTootStr += " ";
- }
- }
- //치식 표기를 설정한다.
- if (row == i && flag == "2" ) {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "true");
- } else {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "false");
- }
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "flag", "처방");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cd", cd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cdnm", cdnm);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightupper", subTootStr.substr(0, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftupper", subTootStr.substr(8, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightlower", subTootStr.substr(16, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftlower", subTootStr.substr(24, 8));
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "orddd", orddd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "toot", toot);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "row", i);
- rowcnt = rowcnt+1;
- } else {
- if (row == i && flag == "2" ) {
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "chos", "true");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "flag", "처방");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cd", cd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "cdnm", cdnm);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightupper", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftupper", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "rightlower", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "leftlower", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "orddd", orddd);
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "toot", "");
- ds_hidden_sppiz00600_cond_list_toothapplist.setColumn( rowcnt, "row", i);
- rowcnt = rowcnt+1;
- }
- }
- }
- }
- // 치식 팝어에 받은 데이타
- function fGetToothPop() {
- var tootSelectcnt = ds_hidden_sppiz00600_rslt_list.rowcount;
- var flag = "";
- var row = "";
- var toot = "";
- tootSelectcnt = eval(tootSelectcnt) + 1;
- for (var i=1; i<tootSelectcnt; i++) {
- flag = ds_hidden_sppiz00600_rslt_list.getColumn(i, "flag");
- row = ds_hidden_sppiz00600_rslt_list.getColumn(i, "row");
- var rlsttoot = ds_hidden_sppiz00600_rslt_list.getColumn(i, "toot");
- var rlsttoot1 = ds_hidden_sppiz00600_rslt_list.getColumn(i, "toot1");
- if (rlsttoot == "") {
- rlsttoot = "-";
- }
- if (rlsttoot1 == "") {
- rlsttoot1 = "-";
- }
- if (flag == "1") {
- toot = ds_main_list3_diaglist.getColumn(row, "toot"));
- ds_main_list3.setColumn( row , "toot", rlsttoot);
- ds_main_list3.setColumn( row , "toot1", rlsttoot1);
- if (rlsttoot != toot) { // 치식번호가 변경된 경우
- var diagstatus = grd_diaglist.rowstatus(row);
- if (diagstatus == 0 || diagstatus == 2) { // 0 : new, 2 : update
- grd_diaglist.rowstatus(row) = 2; // 2 : update
- }
- }
- }
- }
- }
- // 변경된 퇴원확정여부, 심사상태 flag를 대상자조회화면에 보여준다. (2008.01.28 박지욱 추가)
- function fSetChildStat() {
- //model.refresh();
- // 대상자조회화면에 심사상태를 업데이트 보여주도록 한다. (2008. 01. 28 박지욱 추가, 심사상태와 퇴원확정여부, 최종심사자, 심사일자 변경)
- var trgtManWindow = getChildWindow("SMPIJ00200"); // SMPIJ00600_입원재원심사대상자조회.xrw
- if (trgtManWindow != null) {
- var dschjudgprcsstat = ds_main_item1_iteminfo.getColumn(0, "dschjudgprcsstat"); // 심사상태
- var dschnotiyn = ds_main_item1_iteminfo.getColumn(0, "dschnotiyn"); // 퇴원확정여부
- var selectedRow = trgtManWindow.ds_hidden.getColumn(0, "selectedRow");
- var row = parseInt(selectedRow);
- if (row > 0) {
- trgtManWindow.ds_main_list1.setColumn( row , "dschjudgprcsstat", dschjudgprcsstat);
- trgtManWindow.ds_main_list1.setColumn( row , "dschnotiyn", dschnotiyn);
- trgtManWindow.ds_main_list1.setColumn( row , "lastjudgendid", VAL_usernm);
- trgtManWindow.ds_main_list1.setColumn( row , "lastjudgdt", VAL_today);
- }
- }
- // 끝
- }
- // grid 타이틀 컬럼 정보
- function getOrderInfoOfCol(grdid){
- var refdata = ""; // ref
- var sizedata = ""; // size
- var grdobj = document.controls.item(grdid);
- var totcol = grdobj.cols;
- for(var i = 0; i < totcol; i++){
- var refval = grdobj.colAttribute(i, "ref");
- refdata += refval + "^";
- var sizeval = grdobj.colWidth(i);
- sizedata += sizeval + "^";
- }
- refdata = refdata.substring(0 , refdata.length-1);
- sizedata = sizedata.substring(0, sizedata.length-1);
- var scrnid = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + grdid + "'", "scrnid");
- var compscnts = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + grdid + "'", "compscnts");
- if (scrnid == "") {
- ds_send_listval_uuee.setColumn( 0, "flag","I");
- } else {
- ds_send_listval_uuee.setColumn( 0, "flag","U");
- }
- ds_send_listval_uuee.setColumn( 0, "scrnid","SMPIJ00300");
- ds_send_listval_uuee.setColumn( 0, "compsnm",grdid.toString());
- ds_send_listval_uuee.setColumn( 0, "compscnts",refdata);
- ds_send_listval_uuee.setColumn( 0, "compsrefcnts","-");
- ds_send_listval_uuee.setColumn( 0, "compssizecnts",sizedata);
- // if ( submit("TXPIJ00402") ) {
- var oParam = {};
- oParam.id = "TXPIJ00402";
- oParam.service = "bfjudgapp.InHospJudgDetl";
- oParam.method = "reqExeSaveUuee";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=uuee";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00402";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00402") > -1
- arErrorCode.pop("TXPIJ00402") < 0
- */
- sysf_messageBox("사용자 환경 저장이","I002");
- }
- }
- // grid 타이틀 컬럼 정보
- function getOrderInfoOfRdo(rdoid){
- var refdata = ""; // ref
- var sizedata = ""; // size
- var scrnid = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + rdoid + "'", "scrnid");
- var compscnts = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + rdoid + "'", "compscnts");
- var calcamtflag = ds_hidden_list1_isclcond.getColumn(0, "calcamtflag")
- if (scrnid == "") {
- ds_send_listval_uuee.setColumn( 0, "flag","I");
- } else {
- ds_send_listval_uuee.setColumn( 0, "flag","U");
- }
- ds_send_listval_uuee.setColumn( 0, "scrnid","SMPIJ00300");
- ds_send_listval_uuee.setColumn( 0, "compsnm",rdoid);
- ds_send_listval_uuee.setColumn( 0, "compscnts",(calcamtflag.length == 0 ? "-" : calcamtflag));
- ds_send_listval_uuee.setColumn( 0, "compsrefcnts", "-");
- ds_send_listval_uuee.setColumn( 0, "compssizecnts","-");
- // if ( submit("TXPIJ00402") ) {
- var oParam = {};
- oParam.id = "TXPIJ00402";
- oParam.service = "bfjudgapp.InHospJudgDetl";
- oParam.method = "reqExeSaveUuee";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=uuee";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00402";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00402") > -1
- arErrorCode.pop("TXPIJ00402") < 0
- */
- //sysf_messageBox("사용자 환경 저장이","I002");
- }
- }
- function getOrderInfoOfChk(chkid){
- var scrnid = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + chkid + "'", "scrnid");
- var compscnts = ds_hidden_listval_uuee.lookupExpr("compsnm == '" + chkid + "'", "compscnts");
- var chkval = model.getValue("ds_hidden_list1_isclcond/" + chkid.replace("chk_",""));
- if (scrnid == "") {
- ds_send_listval_uuee.setColumn( 0, "flag","I");
- } else {
- ds_send_listval_uuee.setColumn( 0, "flag","U");
- }
- ds_send_listval_uuee.setColumn( 0, "scrnid","SMPIJ00300");
- ds_send_listval_uuee.setColumn( 0, "compsnm",chkid);
- ds_send_listval_uuee.setColumn( 0, "compscnts",(chkval.length == 0 ? "N" : chkval));
- ds_send_listval_uuee.setColumn( 0, "compsrefcnts", "-");
- ds_send_listval_uuee.setColumn( 0, "compssizecnts","-");
- // if ( submit("TXPIJ00402") ) {
- var oParam = {};
- oParam.id = "TXPIJ00402";
- oParam.service = "bfjudgapp.InHospJudgDetl";
- oParam.method = "reqExeSaveUuee";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=uuee";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00402";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00402(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00402") > -1
- arErrorCode.pop("TXPIJ00402") < 0
- */
- //sysf_messageBox("사용자 환경 저장이","I002");
- }
- }
- // 중간청구등록 화면에서 조회된 환자가 중간 청구 등록이 된 경우.
- function fSetMidregist(midcflag) {
- btn_midregist.enable = true;
- if(midcflag == "Y"){
- btn_midregist.attribute("class") = "btn2_letter6";
- btn_midregist.attribute("color") = "#ff0066";
- btn_midregistyn.enable = false;
- btn_midcomplete.enable = true;
- btn_midcancel.enable = true;
- } else {
- btn_midregist.attribute("class") = "btn2_letter6";
- btn_midregistyn.attribute("class") = "btn2_letter6";
- btn_midregistyn.enable = true;
- btn_midcomplete.enable = false;
- btn_midcancel.enable = false;
- }
- }
- // SPPIZ00700_심사Comment조회.xrw 호출(심사자메모,EDI메모)
- function fGetJudgEdiComment(memoflag, memocls) {
- ds_hidden_sppiz00700_rslt.clearData(); ds_hidden_sppiz00700_rslt.addRow();
- ds_hidden_sppiz00700_cond.clearData(); ds_hidden_sppiz00700_cond.addRow();
- ds_hidden_sppiz00700_cond.setColumn( 0, "memoflag", memoflag);
- ds_hidden_sppiz00700_cond.setColumn( 0, "memocls", memocls);
- frmf_modal("SPPIZ00700", "SPPIZ00700", "ds_hidden_sppiz00700""-"ds_send_sppiz00700"", "", "", "10", "10", "", "", "", "", "", "M");
- }
- //평가메모 관련 팝업창세팅
- function fSetTstMemoRefresh(){
- var memo = ds_hidden_sppiz00700_rslt.getColumn(0, "memo");
- var tmp = ds_main_item1_iteminfo.getColumn(0, "edirmk");
- if(tmp){
- tmp = tmp + " ";
- }
- ds_main_item1_iteminfo.setColumn( 0, "tstrmk",tmp + memo);
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- //model.refresh();
- }
- //중간청구등록
- function fmidregist() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd");
- if(chk){
- if(ipt_pid.text.length >1){
- if(indd.length>1){
- //var trgtManWindow = getChildWindow("SMPIJ01100");
- var trgtManWindow = getChildWindow("SMPIJ02300");
- var patunitsrch1 = ds_main_item1_iteminfo.getColumn(0, "pid").getTrim(); // (stringHelper.js) 문자열 앞뒤에 있는 공백 제거
- // 2008.01.23 박지욱 수정 (중간청구등록화면에 넘겨주는 데이터 추가 - pid, indd)
- ds_hidden_midclam.clearData();
- dsf_makeValue( ds_hidden_midclam, "pid", "string", patunitsrch1);
- dsf_makeValue( ds_hidden_midclam, "indd", "string", ds_main_item1_iteminfo.getColumn(0, "indd"));
- if (trgtManWindow == null) {
- frmf_open("SMPIJ02300", "SMPIJ02300", "ds_hidden_midclam""-"ds_hidden_midclam"", "", "", "10", "10", "", "", "", "", "", "M");
- } else {
- activateChild("SMPIJ02300");
- trgtManWindow.javascript.fGetMidClamList();
- }
- //model.refresh();
- }
- }
- }
- }
- //분할제외등록
- function fmidregistyn() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- if(chk){
- var midregistyn = ds_main_item1_iteminfo.getColumn(0, "midregistyn");
- if (midregistyn == "Y") {
- // if (submit("TXPIJ00307", false)) {
- var oParam = {};
- oParam.id = "TXPIJ00307";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqSetDivClamExpt";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=result";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00307";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00307(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00307(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00307") > -1
- arErrorCode.pop("TXPIJ00307") < 0
- */
- btn_midregist.attribute("class") = "btn2_letter6";
- btn_midregist.enable = true;
- btn_midregistyn.attribute("class") = "btn2_letter6";
- //btn_midregistyn.attribute("color") = "#ff0066";
- ds_main_item1_iteminfo.setColumn( 0, "midregistyn", "N");
- sysf_messageBox("분할제외 등록 취소가","I002");
- }
- } else {
- // if (submit("TXPIJ00307"), false) {
- var oParam = {};
- oParam.id = "TXPIJ00307";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqSetDivClamExpt";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=result";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00307";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00307(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00307(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00307") > -1
- arErrorCode.pop("TXPIJ00307") < 0
- */
- btn_midregist.attribute("class") = "btn2_letter6";
- btn_midregist.enable = false;
- btn_midregistyn.attribute("class") = "btn2_letter6";
- btn_midregistyn.attribute("color") = "#ff0066";
- ds_main_item1_iteminfo.setColumn( 0, "midregistyn", "Y");
- sysf_messageBox("분할제외 등록이","I002");
- }
- }
- }
- }
- //애기_엄마
- function fbabymother() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- if(chk){
- var readonly = ds_send.getColumn(0, "readonly");
- // 6시간 미만 환자일 경우 Block - 20081005 박창원
- var sixtimyn = ds_main_item1_iteminfo.getColumn(0, "sixtimyn");
- // open일관련 적용 - 20090302 - 하드코딩 제거,확산병원 데이터 미등록 때문에 예외처리함
- var opendd = ds_main_item1_iteminfo.getColumn(0, "opendd");
- // 이력 그리드내에서 보조유형이 09(자연분만) 있는 경우 이미 면제기간이 적용된 경우
- // 분만신생아관리 화면에서 면제기간적용 버튼 비활성화 (2008.01.29 박지욱 추가)
- var fromdd = "";
- var todd = "";
- var seqno = ds_main_item1_iteminfo.getColumn(0, "seqno");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- var dschnotidt = ds_main_item1_iteminfo.getColumn(0, "dschnotidt");
- var dschnotiyn = ds_main_item1_iteminfo.getColumn(0, "dschnotiyn");
- var cfe = ds_main_item1_iteminfo.getColumn(0, "cfe");
- for (var i = 1; i < grd_insuhistory.rows; i++) {
- var suppkind = ds_main_list1_insulist.getColumn(i, "suppkind");
- if (suppkind == "09" || suppkind == "42") {
- fromdd = ds_main_list1_insulist.getColumn(i, "fromdd");
- todd = ds_main_list1_insulist.getColumn(i, "dschnotidt");
- seqno = ds_main_list1_insulist.getColumn(i, "seqno");
- }
- }
- ds_hidden_sppiz01200_cond.setColumn( 0, "pid",ds_main_item1_iteminfo.getColumn(0, "pid"));
- ds_hidden_sppiz01200_cond.setColumn( 0, "indd",indd);
- ds_hidden_sppiz01200_cond.setColumn( 0, "cretno",ds_main_item1_iteminfo.getColumn(0, "cretno"));
- ds_hidden_sppiz01200_cond.setColumn( 0, "mskind",ds_main_item1_iteminfo.getColumn(0, "mskind"));
- ds_hidden_sppiz01200_cond.setColumn( 0, "brateflag",ds_main_item1_iteminfo.getColumn(0, "brateflag"));
- ds_hidden_sppiz01200_cond.setColumn( 0, "brthdd",ds_main_item1_iteminfo.getColumn(0, "brthdd"));
- ds_hidden_sppiz01200_cond.setColumn( 0, "dschnotidt",dschnotidt);
- ds_hidden_sppiz01200_cond.setColumn( 0, "dschnotiyn",dschnotiyn);
- ds_hidden_sppiz01200_cond.setColumn( 0, "calcbasedd", '-');
- ds_hidden_sppiz01200_cond.setColumn( 0, "seqno", seqno);
- ds_hidden_sppiz01200_cond.setColumn( 0, "cfe", cfe);
- // 심사마감이나 퇴원한 환자는 면제일자적용이나 해제를 시킬 수 없다. - 20080924 박창원
- // 기존에는 심사마감이나 퇴원여부를 인스턴스에서 가져오던 것을 실시간 체크로 변경 - 20080927 박창원
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- var indschacptstat = ds_main_item1_iteminfo.getColumn(0, "indschacptstat");
- var dschjudgprcsstat = ds_main_item1_iteminfo.getColumn(0, "dschjudgprcsstat");
- // 중간청구 여부를 판단해서 블로킹 - 20081017 박창원
- var lastmdlclamdd = ds_main_item1_iteminfo.getColumn(0, "lastmdlclamdd");
- var fromdd = ds_main_item1_iteminfo.getColumn(0, "fromdd");
- if (lastmdlclamdd > fromdd && lastmdlclamdd > opendd && lastmdlclamdd != "" ) {
- ds_hidden_sppiz01200_cond.setColumn( 0, "saveyn","Y");
- }
- if (dschjudgprcsstat == "C" || dschjudgprcsstat == "E" || indschacptstat == "D" || readonly == "Y") {
- ds_hidden_sppiz01200_cond.setColumn( 0, "saveyn","Y");
- } else {
- ds_hidden_sppiz01200_cond.setColumn( 0, "saveyn","N");
- }
- // fromdd 와 todd 에 값이 있으면 면제기간 적용된 환자임을 알려주는 flag 세팅
- if (fromdd != "" && todd != "") {
- ds_hidden_sppiz01200_cond.setColumn( 0, "disyn","Y");
- } else {
- ds_hidden_sppiz01200_cond.setColumn( 0, "disyn","N");
- }
- if (sixtimyn == "Y") {
- sysf_messageBox("6시간 미만 상태 입니다. 자연분만 요율을 설정(저장) ","E001");
- }
- ds_hidden_sppiz01200_cond.setColumn( 0, "fromdd",fromdd);
- ds_hidden_sppiz01200_cond.setColumn( 0, "todd",todd);
- var trgtManWindow = getChildWindow("SPPIZ01200");
- if (trgtManWindow == null) {
- frmf_open("SPPIZ01200", "SPPIZ01200", "ds_hidden_sppiz01200_cond""-"ds_hidden_sppiz01200_cond"", "", "", "10", "10", "", "", "", "", "", "M");
- } else {
- activateChild("SPPIZ01200");
- //model.refresh();
- }
- }
- }
- //수술(유)
- function foperdiag() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- if(chk){
- var trgtManWindow = getChildWindow("SPPIZ01300");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd1");
- ds_hidden_sppiz01300_cond.setColumn( 0, "pid",ds_main_item1_iteminfo.getColumn(0, "pid"));
- ds_hidden_sppiz01300_cond.setColumn( 0, "indd",indd);
- ds_hidden_sppiz01300_cond.setColumn( 0, "cretno",ds_main_item1_iteminfo.getColumn(0, "cretno"));
- if (trgtManWindow == null) {
- frmf_open("SPPIZ01300", "SPPIZ01300", "ds_hidden_sppiz01300_cond""-"ds_send_data1"", "", "", "10", "10", "", "", "", "", "", "M");
- } else {
- activateChild("SPPIZ01300");
- //model.refresh();
- }
- }
- }
- //중간마감취소
- function fmidcancel() {
- //20091126 JHP 수정추가
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd");
- var ans = 0;
- if(chk){
- if(ipt_pid.text.length >1){
- if(indd.length>1){
- var trgtManWindow = getChildWindow("SMPID10100");
- var patunitsrch1 = ds_main_item1_iteminfo.getColumn(0, "pid").getTrim(); // (stringHelper.js) 문자열 앞뒤에 있는 공백 제거
- // 2008.01.23 박지욱 수정 (중간청구등록화면에 넘겨주는 데이터 추가 - pid, indd)
- ds_hidden_midclam.clearData();
- dsf_makeValue( ds_hidden_midclam, "pid", "string", patunitsrch1);
- dsf_makeValue( ds_hidden_midclam, "indd", "string", ds_main_item1_iteminfo.getColumn(0, "indd"));
- if (trgtManWindow == null) {
- ans = sysf_messageBox("심사 취소 할 경우", "S001");
- if (ans == 6) {
- dsf_makeValue( ds_send, "checkyn", "string", "Y");
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- if (fGetDrgOpenPopup("O") == false) {
- return false;
- }
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","A");
- // if (submit("TXPIJ00301", false)) {
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- }
- }
- } else {
- ans = sysf_messageBox("심사 취소 할 경우", "S001");
- if (ans == 6) {
- dsf_makeValue( ds_send, "checkyn", "string", "Y");
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- if (fGetDrgOpenPopup("O") == false) {
- return false;
- }
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","A");
- // submit("TXPIJ00301",false);
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- }
- }
- //model.refresh();
- }
- }
- }
- }
- //특정내역
- function fspclData() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- if(chk){
- var rrgstno = ds_main_item1_iteminfo.getColumn(0, "rrgstno");
- rrgstno = rrgstno.replace("-","");
- ds_send.setColumn( 0, "rrgstno",rrgstno);
- ds_send.setColumn( 0, "dschdd",ds_main_item1_iteminfo.getColumn(0, "dschdd"));
- var fromdd = ds_send.getColumn(0, "fromdd");
- // v191, v192, v193 값을 넣기 위한 vcode
- ds_send.setColumn( 0, "vcode", ds_hidden_item1.getColumn(0, "vcode"));
- // if (submit("TRPIJ00310")) {
- var oParam = {};
- oParam.id = "TRPIJ00310";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqGetSpclCdList";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=clcjlist";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00310";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00310(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00310(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00310") > -1
- arErrorCode.pop("TRPIJ00310") < 0
- */
- ds_main_list4.copyData(ds_hidden_list4);
- //grd_clcjlist.dispatch("xforms-value-changed");
- //
- //model.refresh();
- 최적화 문제로 대체 20080731 박창원
- model.refreshpart("ds_main_list4");
- for(var i = 1; i < grd_clcjlist.rows; i++) {
- var spclcd = ds_main_list4_clcjlist.getColumn(i, "spclcd");
- ds_main_list4.setColumn( i , "fromdd", fromdd);
- if (spclcd == "" ) {
- grd_clcjlist.deleteRow(i, false);
- }
- }
- for(var i = 1; i < grd_clcjlist.rows; i++) {
- var status = ds_main_list4_clcjlist.getColumn(i, "status");
- if(status == "3"){
- grd_clcjlist.rowstatus(i) = 1;
- }
- }
- // 그리드 정렬 + 빈줄 추가
- fSortSpclNo();
- // 행추가
- // fSpclGridInsertRow();
- }
- }
- }
- //퇴원마감취소
- function fdschclosecancel() {
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- var tmpnotiyn;
- var notichngflag = "N";
- // 퇴원 마감 취소시 퇴원수납이 되었는지 실시한 확인 후 진행한다.
- // 마감에서부터 취소사이에 수납에서 퇴원수납이 되었는데 마감취소가 되는 상황이 발생되지 않기 위함
- // 퇴원수납이 된경우에는 대상자 조회 호면을 refresh 하고
- // 메인화면의 심사상태를 'A' 미심상태로 하고 메인화면을 다시 로드- 20080927 박창원
- dsf_makeValue( ds_send, "checkyn", "string", "Y");
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- var indschacptstat = ds_main_item11_endcnclstat.getColumn(0, "indschacptstat");
- if (indschacptstat == 'D') {
- sysf_messageBox("이미 퇴원처리가 된 환자입니다. 마감취소 ", "E001");
- // 무조건 대상자 조회 화면을 refresh
- var trgtManWindow = getChildWindow("SMPIJ00200");
- trgtManWindow.javascript.fGetInBfJudgTrgtManList();
- trgtManWindow.javascript.fCountPat();
- //trgtManWindow.model.refresh();
- fGetItemInfo();
- return;
- }
- if(chk){
- var receiptyn = ds_main_item1_iteminfo.getColumn(0, "receiptyn");
- var dschnotiyn = ds_main_item1_iteminfo.getColumn(0, "dschnotiyn");
- var dschdclrtyn = ds_main_item11_endcnclstat.getColumn(0, "dschdclrtyn");
- var dschjudgprcsstat = ds_main_item11_endcnclstat.getColumn(0, "dschjudgprcsstat");
- if (receiptyn != "" && dschnotiyn == "Y") {
- sysf_messageBox("퇴원(가퇴원) 수납이 되었으므로 마감취소를","E001");
- } else if (receiptyn == "" && (dschnotiyn == "Y" || ( dschjudgprcsstat == 'G' && dschdclrtyn == 'Y' ))) {
- //DRG 상세 마감 취소 팝업
- if (fGetDrgOpenPopup("O") == false) {
- return false;
- }
- if ( dschnotiyn == "Y" ) {
- // var msg = sysf_messageBox("간호의 퇴원확정여부도 함께 취소","S001");
- // if(msg == 6){
- // if (indschacptstat == "T") { // 가퇴원 블로킹 추가 - 20081005 박창원
- // var msg1 = sysf_messageBox("가퇴원 상태에서는 간호확정 취소가 불가합니다. 계속진행","S001");
- // if (msg1 != 6) {
- // return;
- // }
- // } else {
- // ds_main_item1_iteminfo.setColumn( 0, "dschnotiyn","Z");
- // }
- // }else if(msg == 2){
- // return;
- // }
- }
- if (fJudgEndCancel()) {
- if(fSaveCalcAmt("D")) {
- } else {
- sysf_messageBox("마감취소 처리가 되지","E007");
- return 0;
- }
- } else {
- sysf_messageBox("마감취소 처리가 되지","E007");
- return 0;
- }
- if(ds_main_item1_iteminfo.getColumn(0, "dschnotiyn") == "Z"){
- ds_main_item1_iteminfo.setColumn( 0, "dschnotiyn","N");
- notichngflag = "Y";
- }
- fJudgEndClear();
- }
- }
- }
- //종료
- function fClear() {
- // 심사상태를 미심상태로 바꾸고 대상자 조회를 리프레쉬 - 20081004 박창원
- // 심사상태를 실시간 체크하여 심사상태가 심사중일때만 업데이트 되게 함 - 20081008 박창원
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다.기본데이터 이상이나 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- // 혹시모르는 종료버튼 클릭시 간호퇴원확정 취소를 막기위해 적용 - 20081008 박창원
- var realnotiyn = ds_main_item11_endcnclstat.getColumn(0, "dschnotiyn");
- var notiyn = ds_main_item1_iteminfo.getColumn(0, "dschnotiyn");
- var readonly = ds_send.getColumn(0, "readonly");
- if (notiyn == "Z") {
- ds_main_item1_iteminfo.setColumn( 0, "dschnotiyn", realnotiyn);
- }
- var dschjudgprcsstat = ds_main_item11_endcnclstat.getColumn(0, "dschjudgprcsstat");
- if (dschjudgprcsstat == "B" && readonly != "Y") {
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","Z");
- // submit("TXPIJ00301");
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- }
- // 2. 화면 클리어 (공통)
- fJudgEndClear();
- }
- //중간청구마감
- function fMidcomplete() {
- // 20091126 JHP 수정추가
- var chk = ds_main_item1_iteminfo.getColumn(0, "patnm");
- var indd = ds_main_item1_iteminfo.getColumn(0, "indd");
- var ans = 0;
- if(chk){
- if(ipt_pid.text.length >1){
- if(indd.length>1){
- // if (!submit("TRPIJ00319", false )) {
- var oParam = {};
- oParam.id = "TRPIJ00319";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNoActYn";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=noactyn";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00319";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00319(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00319(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00319") > -1
- arErrorCode.pop("TRPIJ00319") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- var noactyn = ds_main_item16_noactyn.getColumn(0, "noactyn");
- if (noactyn == 'Y') {
- frmf_modal("SPPIJ00900", "SPPIJ00900", "ds_main_item1_iteminfo_pid""-"ds_send_send_pid_pid"", "", "", "10", "10", "", "", "", "", "", "M");
- }
- var trgtManWindow = getChildWindow("SMPID10100");
- var patunitsrch1 = ds_main_item1_iteminfo.getColumn(0, "pid").getTrim(); // (stringHelper.js) 문자열 앞뒤에 있는 공백 제거
- // 2008.01.23 박지욱 수정 (중간청구등록화면에 넘겨주는 데이터 추가 - pid, indd)
- ds_hidden_midclam.clearData();
- dsf_makeValue( ds_hidden_midclam, "pid", "string", patunitsrch1);
- dsf_makeValue( ds_hidden_midclam, "indd", "string", ds_main_item1_iteminfo.getColumn(0, "indd"));
- if (trgtManWindow == null) {
- ans = sysf_messageBox("심사 마감 할 경우", "S001");
- if (ans == 6) {
- dsf_makeValue( ds_send, "checkyn", "string", "Y");
- // if (!submit("TRPIJ00315", false )) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- if (fGetDrgOpenPopup("O") == false) {
- return false;
- }
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","C");
- // if (submit("TXPIJ00301")) {
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- frmf_open("SMPID10100", "SMPID10100", "ds_hidden_midclam""-"ds_hidden_midclam"", "", "", "10", "10", "", "", "", "", "", "M");
- }
- } else {
- }
- } else {
- ans = sysf_messageBox("심사 마감 할 경우", "S001");
- if (ans == 6) {
- dsf_makeValue( ds_send, "checkyn", "string", "Y");
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- if (fGetDrgOpenPopup("O") == false) {
- return false;
- }
- ds_main_item1_iteminfo.setColumn( 0, "dschjudgprcsstat","C");
- // if (submit("TXPIJ00301")) {
- var oParam = {};
- oParam.id = "TXPIJ00301";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqExeSaveInpt";
- oParam.inds = "req=ds_";
- oParam.outds = "";
- oParam.async = false;
- oParam.callback = "cf_TXPIJ00301";
- tranf_submit(oParam);
- /*
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TXPIJ00301(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TXPIJ00301") > -1
- arErrorCode.pop("TXPIJ00301") < 0
- */
- activateChild("SMPID10100");
- trgtManWindow.javascript.fGetMidClamList();
- }
- } else {
- activateChild("SMPID10100");
- trgtManWindow.javascript.fGetMidClamList();
- }
- }
- //model.refresh();
- }
- }
- }
- }
- //중간청구마감
- function fAccept() {
- // 심사마감이나 퇴원한 환자는 요율변경을 할 수 없다. - 20080924 박창원
- // 기존에는 심사마감이나 퇴원여부를 인스턴스에서 가져오던 것을 실시간 체크로 변경 - 20080927 박창원
- // if (!submit("TRPIJ00315", false)) {
- var oParam = {};
- oParam.id = "TRPIJ00315";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqNotiDschStat";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=endcnclstat ds_=recal ds_=drginfo";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00315";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00315(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00315") > -1
- arErrorCode.pop("TRPIJ00315") < 0
- */
- sysf_messageBox("실시간 환자상태 체크에 실패 했습니다. 시스템 오류입니다.관리자 문의 후", "C003");
- return;
- }
- // 오픈일 적용 - 20090302 박창원 - 하드코딩 제거 - 확산병원은 자료가 구축되어 있지 않기 때문에 오픈전까지 예외처리
- var opendd = ds_main_item1_iteminfo.getColumn(0, "opendd");
- var indschacptstat = ds_main_item1_iteminfo.getColumn(0, "indschacptstat");
- var dschjudgprcsstat = ds_main_item1_iteminfo.getColumn(0, "dschjudgprcsstat");
- // 중간청구, 읽기전옹 여부를 판단해서 블로킹 - 20081017 박창원
- var lastmdlclamdd = ds_main_item1_iteminfo.getColumn(0, "lastmdlclamdd");
- var fromdd = ds_main_item1_iteminfo.getColumn(0, "fromdd");
- var readonly = ds_send.getColumn(0, "readonly");
- if (lastmdlclamdd > fromdd && lastmdlclamdd > "20081003" && lastmdlclamdd != "" ) {
- sysf_messageBox("중간청구 등록이 되어있습니다. 요율을 변경","E001");
- grp_changeownbrate.visible = false;
- return;
- } else if (readonly == "Y") {
- sysf_messageBox("읽기전용 모드에서는 요율을 변경","E001");
- grp_changeownbrate.visible = false;
- return;
- } else if (indschacptstat == "D") {
- sysf_messageBox("이미 퇴원한 환자입니다. 요율을 변경","E001");
- grp_changeownbrate.visible = false;
- return;
- } else if (dschjudgprcsstat == "C" || dschjudgprcsstat == "E") {
- sysf_messageBox("이미 마감된 환자입니다. 요율을 변경","E001");
- grp_changeownbrate.visible = false;
- return;
- }
- fChangeRate1();
- }
- //병용금기확인
- function fUseincombinationtaboo() {
- // 20091126 수정추가 JHP 병용금기내역 확인
- var prcsyn = sysf_messageBox("병용금기확인시 계산내역에 따라 일부 시간이 지연될수 있습니다.\n\n","Q003");
- if(prcsyn == "6"){
- var pid = ds_main_item1_iteminfo.getColumn(0, "pid");
- if(pid == "" || pid == null || pid == " "){
- }else{
- // submit("TRPIJ00318");
- var oParam = {};
- oParam.id = "TRPIJ00318";
- oParam.service = "bfjudgapp.InHospJudg";
- oParam.method = "reqGetUseInCombinationTaboo";
- oParam.inds = "req=ds_";
- oParam.outds = "ds_=list";
- oParam.async = false;
- oParam.callback = "cf_TRPIJ00318";
- tranf_submit(oParam);
- /*
- function cf_TRPIJ00318(sSvcId, nErrorCode, sErrorMsg) {
- if(nErrorCode < 0) return;
- }
- function cf_TRPIJ00318(sSvcId, nErrorCode, sErrorMsg) {
- arErrorCode.push(sSvcId, nErrorCode);
- }
- arErrorCode.pop("TRPIJ00318") > -1
- arErrorCode.pop("TRPIJ00318") < 0
- */
- var nodecnt = ds_hidden_useincombinationtaboo_list.rowcount;
- if(nodecnt > 1){
- var seeyn = sysf_messageBox("병용금기내역이 존재합니다. 확인","Q005");
- if(seeyn == "6"){
- grp_taboo.attribute("left") = "420px";
- grp_taboo.attribute("top") = "525px";
- grp_taboo.attribute("width") = "508px";
- grp_taboo.attribute("height") = "199px";
- grp_taboo.visible = true;
- }else{
- }
- }else{
- sysf_messageBox("병용금기내역이 존재하지 ","I011");
- }
- }
- }
- }
- function fOpenSPPIJ03800(){
- var cond = "ds_hidden_SPPIJ03800_cond";
- var ref = "ds_main_item1_iteminfo";
- var send = "ds_send";
- model.makevalue(cond+"_pid", model.getValue(ref+"_pid"));
- model.makevalue(cond+"_cretno", model.getValue(ref+"_cretno"));
- model.makevalue(cond+"_orddd", model.getValue(ref+"_fromdd"));
- model.makevalue(cond+"_ordtodd", model.getValue(ref+"_todd"));
- fLinkPopMenu("SPPIJ03800", cond, send, "modal");
- }
- ]]></Script>
|