SSLBR80100_혈액은행검사항목상세.xfdl 197 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <FDL version="1.5">
  3. <TypeDefinition url="..\..\..\default_typedef.xml"/>
  4. <Form id="SSLBR80100" position="absolute 0 0 870 720" titletext="Untitle" style="color:#184d8bff;" onload="SSLBR80100_onload">
  5. <Layouts>
  6. <Layout>
  7. <Div position="absolute 1 0 871 721" id="group2" visible="true">
  8. <Layouts>
  9. <Layout>
  10. <Static text="바코드번호" position="absolute 0 26 90 49" id="caption7" class="cell_1"/>
  11. <Static text="검체정보" position="absolute 0 3 111 24" id="caption3" class="tit_2"/>
  12. <Shape position="absolute 0 23 870 29" linetype="horizontal" id="line2" class="line_1"/>
  13. <Static text="작업번호" position="absolute 632 25 722 48" id="caption1" class="cell_1"/>
  14. <Static text="채취일시" position="absolute 199 25 289 48" id="caption4" class="cell_1"/>
  15. <Shape position="absolute 0 45 870 51" linetype="horizontal" id="line1" class="line_3"/>
  16. <Edit position="absolute 93 27 195 46" id="output1"/>
  17. <Edit readonly="true" position="absolute 725 27 867 46" id="output2"/>
  18. <MaskEdit readonly="true" position="absolute 293 27 412 46" id="output4" mask="####-##-## ##:##:##" type="string"/>
  19. <Static text="결과상세내역" position="absolute 1 58 112 79" id="caption5" class="tit_2"/>
  20. <Button position="absolute 235 55 304 74" id="btn_rsltsize1" class="btn2" text="결과상세" onclick="group2_btn_rsltsize1_onclick"/>
  21. <Button position="absolute 180 55 233 74" id="btn_sizeinit" class="btn2" text="초기화"/>
  22. <Shape position="absolute -1 76 673 82" linetype="horizontal" id="line3" class="line_1" style="strokepen:3 solid #33bbbbff;"/>
  23. <Shape position="absolute 0 569 870 575" linetype="horizontal" id="line4" class="line_1" style="strokepen:3 solid #33bbbbff;"/>
  24. <Static text="의뢰의사 Remark" position="absolute 0 573 210 596" align="align:center middle;" id="caption10" class="cell_1"/>
  25. <Static text=" 시행부서별 소견입력" position="absolute 504 573 868 596" align="align:center middle;" id="caption11" class="cell_1"/>
  26. <TextArea position="absolute 0 598 210 715" id="textarea1"/>
  27. <TextArea position="absolute 505 622 870 715" id="textarea2" ontextchanged="group2_textarea2_ontextchanged" wordwrap="char"/>
  28. <Shape position="absolute 0 715 870 721" linetype="horizontal" id="line6" class="line_3"/>
  29. <Shape position="absolute 505 617 865 623" linetype="horizontal" id="line7" class="line_2"/>
  30. <Grid id="grd_TestInfoCnts" taborder="0" useinputpanel="false" position="absolute 0 80 675 520" onclick="grd_TestInfoCnts_onclick" binddataset="ds_grid_testlist" oncellclick="group2_grd_TestInfoCnts_oncellclick" onrbuttondown="group2_grd_TestInfoCnts_onrbuttondown" oncelldblclick="group2_grd_TestInfoCnts_oncelldblclick" autoenter="select" class="bg_white" cellmovingtype="col" cellsizebandtype="allband" cellsizingtype="col" selecttype="cell" onmousemove="group2_grd_TestInfoCnts_onmousemove" onheadclick="group2_grd_TestInfoCnts_onheadclick" onkeydown="group2_grd_TestInfoCnts_onkeydown">
  31. <Formats>
  32. <Format id="default">
  33. <Columns>
  34. <Column size="25"/>
  35. <Column size="23"/>
  36. <Column size="136"/>
  37. <Column size="80"/>
  38. <Column size="80"/>
  39. <Column size="18"/>
  40. <Column size="120"/>
  41. <Column size="65"/>
  42. <Column size="65"/>
  43. <Column size="20"/>
  44. <Column size="64"/>
  45. <Column size="127"/>
  46. <Column size="80"/>
  47. <Column size="80"/>
  48. <Column size="127"/>
  49. <Column size="80"/>
  50. <Column size="130"/>
  51. <Column size="100"/>
  52. </Columns>
  53. <Rows>
  54. <Row size="22" band="head"/>
  55. <Row size="20"/>
  56. </Rows>
  57. <Band id="head">
  58. <Cell text="상태"/>
  59. <Cell col="1" displaytype="image" edittype="checkbox" style="align:center middle;background:center middle;background2:center middle;backgroundimage:URL('IMG::/lis/chkRPT0.png');" expandimage="expr:&quot;URL('IMG::lis/chkRPT0.png') center middle&quot;"/>
  60. <Cell col="2" text="검사항목명"/>
  61. <Cell col="3" colspan="2" text="결과"/>
  62. <Cell col="5" text="-"/>
  63. <Cell col="6" text="결과일시"/>
  64. <Cell col="7" text="공여자"/>
  65. <Cell col="8" text="검사자"/>
  66. <Cell col="9" text="S"/>
  67. <Cell col="10" text="이전결과"/>
  68. <Cell col="11" text="이전결과일시"/>
  69. <Cell col="12" text="이전검사자"/>
  70. <Cell col="13" text="전문의"/>
  71. <Cell col="14" text="확인일시"/>
  72. <Cell col="15" text="예비결과자"/>
  73. <Cell col="16" text="예비결과일시"/>
  74. <Cell col="17" text="Comment"/>
  75. </Band>
  76. <Band id="body">
  77. <Cell celltype="head" displaytype="image" expr="expr:getRowType(currow) == 2 ?'theme://images/ico_i.png' : (getRowType(currow) == 4 ? 'theme://images/ico_u.png' : (getRowType(currow) == 8 ? 'theme://images/ico_d.png' : 'theme://images/ico_e.png'))"/>
  78. <Cell col="1" displaytype="expr:getColumn(currow, 'chkImage')" edittype="expr:getColumn(currow, 'chkImage')" style="align:center middle;backgroundimage:EXPR((selchk == '0' ? &quot;URL('IMG::lis/chkRPT1.png') center middle&quot; : &quot;URL('IMG::lis/chkRPT0.png') center middle&quot;)) : ');" text="bind:selchk" expr="expr:getColumn(currow, 'chkImage') == 'checkbox' ? getColumn(currow, 'selchk') : ''"/>
  79. <Cell col="2" style="align:left middle;" text="bind:tclsscrnm"/>
  80. <Cell col="3" displaytype="text" edittype="expr:getColumn(currow, 'readonly')=='true'?'none':'text'" text="bind:bufinptrslt" editautoselect="true"/>
  81. <Cell col="4" style="background:EXPR(getColumn(currow, 'readonly') == 'true' ? '#c0c0c0' : '#FFFFFA');background2:EXPR(getColumn(currow, 'readonly') == 'true' ? '#c0c0c0' : '#FFFFFA');color:EXPR(getColumn(currow, 'color'));color2:EXPR(getColumn(currow, 'color'));" text="bind:reptrslt"/>
  82. <Cell col="5" style="backgroundimage:EXPR(getColumn(currow, 'rstImage'));" text="bind:multi"/>
  83. <Cell col="6" text="bind:lastreptdt" mask="####-##-## ##:##:##"/>
  84. <Cell col="7" style="align:center middle;" text="bind:refvals"/>
  85. <Cell col="8" style="align:center middle;" text="bind:rstnm"/>
  86. <Cell col="9" style="align:center middle;color:#339966ff;color2:#339966ff;" text="bind:rsltmark"/>
  87. <Cell col="10" style="background:EXPR(getColumn(currow, 'panicmark') == 'P' ? '#7BE6B7' : '');background2:EXPR(getColumn(currow, 'panicmark') == 'P' ? '#7BE6B7' : '');" text="bind:bfreptrslt"/>
  88. <Cell col="11" style="background:EXPR(getColumn(currow, 'deltamark') == 'D' ? '#dec6a4' : '');background2:EXPR(getColumn(currow, 'deltamark') == 'D' ? '#dec6a4' : '');" text="bind:bflastreptdt" mask="####-##-## ##:##:##"/>
  89. <Cell col="12" style="background:EXPR(getColumn(currow, 'criticalmark') == 'C' ? '#ffe79d' : '');background2:EXPR(getColumn(currow, 'criticalmark') == 'C' ? '#ffe79d' : '');" text="bind:bfrstnm"/>
  90. <Cell col="13" style="background2:EXPR(getColumn(currow, 'alertmark') == 'A' ? '#fec34d' : '');backgroundimage:EXPR(getColumn(currow, 'alertmark') == 'A' ? '#fec34d' : '');" text="bind:medispclnm"/>
  91. <Cell col="14" text="bind:medispcldt" mask="####-##-## ##:##:##"/>
  92. <Cell col="15" text="bind:mdlreptnm"/>
  93. <Cell col="16" text="bind:mdlreptdt" mask="####-##-## ##:##:##"/>
  94. <Cell col="17" displaytype="text" edittype="text" text="bind:testcmt"/>
  95. </Band>
  96. </Format>
  97. </Formats>
  98. </Grid>
  99. <Button position="absolute 156 56 171 68" id="btn_check" text=""/>
  100. <Static text="접수일시" position="absolute 416 25 506 48" id="caption2" class="cell_1"/>
  101. <MaskEdit readonly="true" position="absolute 509 27 630 46" id="output3" mask="####-##-## ##:##:##" type="string"/>
  102. <Combo position="absolute 505 599 640 618" id="cmb_sect" class="combo_default" innerdataset="ds_init_testconttsectcd" datacolumn="nm" codecolumn="cd"/>
  103. <Combo position="absolute 641 599 846 618" id="cmb_cmt" class="combo_default" innerdataset="ds_init_lb0210" datacolumn="nm" codecolumn="cd" onitemchanged="group2_cmb_cmt_onitemchanged"/>
  104. <Grid position="absolute 211 599 504 715" id="grd_TestCmts" class="datagrid_noborder" binddataset="ds_grid_grd_TestCmts">
  105. <Formats>
  106. <Format id="default">
  107. <Columns>
  108. <Column size="0"/>
  109. <Column size="0"/>
  110. <Column size="0"/>
  111. <Column size="0"/>
  112. <Column size="0"/>
  113. <Column size="0"/>
  114. <Column size="0"/>
  115. <Column size="290"/>
  116. </Columns>
  117. <Rows>
  118. <Row size="1" band="head"/>
  119. <Row size="24"/>
  120. </Rows>
  121. <Band id="head">
  122. <Cell text="1^2^3^4^5^6^7^소견"/>
  123. <Cell col="1"/>
  124. <Cell col="2"/>
  125. <Cell col="3"/>
  126. <Cell col="4"/>
  127. <Cell col="5"/>
  128. <Cell col="6"/>
  129. <Cell col="7"/>
  130. </Band>
  131. <Band id="body">
  132. <Cell text="bind:bcno"/>
  133. <Cell col="1" text="bind:tclscd"/>
  134. <Cell col="2" text="bind:spccd"/>
  135. <Cell col="3" text="bind:testcd"/>
  136. <Cell col="4" text="bind:rsltseq"/>
  137. <Cell col="5" text="bind:testcontcd"/>
  138. <Cell col="6" text="bind:flag"/>
  139. <Cell col="7" displaytype="text" edittype="text" text="bind:testcont" wordwrap="char" autosizerow="default" autosizecol="limitmax"/>
  140. </Band>
  141. </Format>
  142. </Formats>
  143. </Grid>
  144. <Edit position="absolute 710 0 786 19" id="ipt_testpsn" class="input_essential" onkeydown="group2_ipt_testpsn_onkeydown"/>
  145. <Edit readonly="true" position="absolute 788 0 870 19" id="opt_testpsn"/>
  146. <Static text="검사자" position="absolute 638 4 698 25" id="caption16" class="tit_2"/>
  147. <Static text="검체명" position="absolute 452 527 512 543" id="caption17" class="tit_2" visible="false"/>
  148. <Edit readonly="true" position="absolute 520 525 866 544" id="output8" visible="false"/>
  149. <Div position="absolute 670 77 870 507" id="group1">
  150. <Layouts>
  151. <Layout>
  152. <Shape position="absolute 5 0 195 425" id="roundrect3" class="roundrect_btnset" type="roundrectangle"/>
  153. <Button position="absolute 13 35 55 60" align="align:center middle;" id="btn_typeA" text="A" onclick="group2_group1_btn_typeA_onclick"/>
  154. <Button position="absolute 57 35 99 60" align="align:center middle;" id="btn_typeB" text="B" onclick="group2_group1_btn_typeB_onclick"/>
  155. <Button position="absolute 101 35 143 60" align="align:center middle;" id="btn_typeO" text="O" onclick="group2_group1_btn_typeO_onclick"/>
  156. <Button position="absolute 145 35 187 60" align="align:center middle;" id="btn_typeAB" text="AB" onclick="group2_group1_btn_typeAB_onclick"/>
  157. <Button position="absolute 13 65 99 90" align="align:center middle;" id="btn_antiA" text="Anti - A" onclick="group2_group1_btn_antiA_onclick"/>
  158. <Button position="absolute 101 65 187 90" align="align:center middle;" id="btn_antiB" text="Anti - B" onclick="group2_group1_btn_antiB_onclick"/>
  159. <Button position="absolute 13 95 55 120" align="align:center middle;" id="btn_plusM" text="-" onclick="group2_group1_btn_plusM_onclick"/>
  160. <Button position="absolute 57 95 99 120" align="align:center middle;" id="btn_plusPM" text="±" onclick="group2_group1_btn_plusPM_onclick"/>
  161. <Button position="absolute 145 95 187 120" align="align:center middle;" id="btn_mom" text="Mom" onclick="group2_group1_btn_mom_onclick"/>
  162. <Button position="absolute 57 125 99 150" align="align:center middle;" id="btn_plus2P" text="++" onclick="group2_group1_btn_plus2P_onclick"/>
  163. <Button position="absolute 13 125 55 150" align="align:center middle;" id="btn_plus1P" text="+" onclick="group2_group1_btn_plus1P_onclick"/>
  164. <Button position="absolute 101 125 143 150" align="align:center middle;" id="btn_plus3P" text="+++" onclick="group2_group1_btn_plus3P_onclick"/>
  165. <Button position="absolute 145 125 187 150" align="align:center middle;" id="btn_plus4P" text="++++" onclick="group2_group1_btn_plus4P_onclick"/>
  166. <Button position="absolute 13 155 99 180" align="align:center middle;" id="btn_ACell" text="A - Cell" onclick="group2_group1_btn_ACell_onclick"/>
  167. <Button position="absolute 101 155 187 180" align="align:center middle;" id="btn_BCell" text="B - Cell" onclick="group2_group1_btn_BCell_onclick"/>
  168. <Button position="absolute 13 185 99 210" align="align:center middle;" id="btn_Positive" text="Positive" style="background:lightpink;border:1 solid hotpink ;color:#184d8bff;" onclick="group2_group1_btn_Positive_onclick"/>
  169. <Button position="absolute 101 185 187 210" align="align:center middle;" id="btn_Negative" text="Negative" onclick="group2_group1_btn_Negative_onclick"/>
  170. <Button position="absolute 13 5 99 30" align="align:center middle;" id="btn_blodWeakD" text="Weak D" onclick="group2_group1_btn_blodWeakD_onclick"/>
  171. <Button position="absolute 145 5 187 30" align="align:center middle;" id="btn_negative" text="-" onclick="group2_group1_btn_negative_onclick"/>
  172. <Button position="absolute 55 240 97 265" align="align:center middle;" id="button43" text="B" onclick="group2_group1_button43_onclick"/>
  173. <Button position="absolute 11 240 53 265" align="align:center middle;" id="button44" text="A" onclick="group2_group1_button44_onclick"/>
  174. <Button position="absolute 99 240 141 265" align="align:center middle;" id="button45" text="O" onclick="group2_group1_button45_onclick"/>
  175. <Button position="absolute 143 240 185 265" align="align:center middle;" id="button46" text="AB" onclick="group2_group1_button46_onclick"/>
  176. <Static text="신검" position="absolute 15 220 58 240" id="caption9" style="color:red;font:arial,9,bold;"/>
  177. </Layout>
  178. </Layouts>
  179. </Div>
  180. <Button position="absolute 850 599 866 615" id="button18" class="icon_search" text="" onclick="group2_button18_onclick"/>
  181. <Button position="absolute 805 548 869 567" id="button20" class="btn2" text="소견저장" onclick="group2_button20_onclick"/>
  182. <Edit readonly="true" position="absolute 722 430 847 449" id="output11" oneditclick="group2_output11_oneditclick" transparenthittest="false" autoselect="false" maxlength="10" style="font:arial,9;"/>
  183. <Edit readonly="true" position="absolute 722 380 847 399" id="output13" oneditclick="group2_output13_oneditclick"/>
  184. <Static text="일시" position="absolute 685 428 720 451" align="align:center middle;" id="caption6" class="cell_1"/>
  185. <Static text="Do" position="absolute 685 403 720 426" align="align:center middle;" id="caption8" class="cell_1"/>
  186. <Button position="absolute 685 355 738 374" id="button41" class="btn2" text="BMT" onclick="group2_button41_onclick"/>
  187. <Edit readonly="true" position="absolute 722 405 847 424" id="output5" oneditclick="group2_output5_oneditclick" style="font:arial,8;"/>
  188. <Static text="Pt" position="absolute 685 378 720 401" align="align:center middle;" id="caption18" class="cell_1"/>
  189. <Button position="absolute 580 452 666 471" id="button15" class="btn2" visible="false" text="B - Cell"/>
  190. <Button position="absolute 580 475 666 494" id="button16" class="btn2" visible="false" text="Negative"/>
  191. <Button position="absolute 536 355 578 374" id="button1" class="btn2_letter2" visible="false" text="B"/>
  192. <Button position="absolute 492 475 578 494" id="button17" class="btn2" visible="false" text="Positive" onclick="group2_button17_onclick"/>
  193. <Button position="absolute 580 355 622 374" id="button2" class="btn2_letter2" visible="false" text="O"/>
  194. <Button position="absolute 624 355 666 374" id="button3" class="btn2_letter2" visible="false" text="AB"/>
  195. <Button position="absolute 624 403 666 422" id="button19" class="btn2_letter2" visible="false" text="Mom"/>
  196. <Button position="absolute 624 334 666 353" id="button4" class="btn2_letter2" visible="false" text="-"/>
  197. <Button position="absolute 492 379 578 398" id="button5" class="btn2" visible="false" text="Anti - A"/>
  198. <Button position="absolute 580 379 666 398" id="button6" class="btn2" visible="false" text="Anti - B"/>
  199. <Button position="absolute 536 403 578 422" id="button7" class="btn2_letter2" visible="false" text="±"/>
  200. <Button position="absolute 492 403 534 422" id="button8" class="btn2_letter2" visible="false" text="-"/>
  201. <Button position="absolute 536 427 578 446" id="button9" class="btn2_letter2" visible="false" text="++"/>
  202. <Button position="absolute 580 427 622 446" id="button10" class="btn2_letter2" visible="false" text="+++"/>
  203. <Button position="absolute 492 334 578 353" id="button21" class="btn2" visible="false" text="Weak D"/>
  204. <Button position="absolute 492 355 534 374" id="button11" class="btn2_letter2" visible="false" text="A"/>
  205. <Button position="absolute 624 427 666 446" id="button12" class="btn2_letter2" visible="false" text="++++"/>
  206. <Button position="absolute 492 427 534 446" id="button13" class="btn2_letter2" visible="false" text="+"/>
  207. <Button position="absolute 492 452 578 471" id="button14" class="btn2" visible="false" text="A - Cell"/>
  208. <CheckBox position="absolute 565 59 670 75" id="chkChlidBtype" text="소아혈액형입력"/>
  209. <Edit readonly="true" position="absolute 549 58 564 77" id="output6" visible="false"/>
  210. <CheckBox position="absolute 380 525 440 545" id="checkbox1" onclick="group2_checkbox1_onclick"/>
  211. <Static id="caption111" text=" 검사항목별 소견입력" class="cell_1" position="absolute 211 573 499 596"/>
  212. <Radio position="absolute 212 575 802 593" id="rdo_cntsflag" columncount="2" codecolumn="codecolumn" datacolumn="datacolumn" onitemclick="group2_rdo_cntsflag_onitemclick" onitemchanged="group2_rdo_cntsflag_onitemchanged">
  213. <Dataset id="innerdataset">
  214. <ColumnInfo>
  215. <Column id="codecolumn"/>
  216. <Column id="datacolumn"/>
  217. </ColumnInfo>
  218. <Rows>
  219. <Row>
  220. <Col id="codecolumn">2</Col>
  221. <Col id="datacolumn"/>
  222. </Row>
  223. <Row>
  224. <Col id="codecolumn">1</Col>
  225. <Col id="datacolumn"/>
  226. </Row>
  227. </Rows>
  228. </Dataset>
  229. </Radio>
  230. <Button position="absolute 440 575 493 594" id="btn_cmtdel" class="btn2" text="행삭제" onclick="group2_btn_cmtdel_onclick"/>
  231. </Layout>
  232. </Layouts>
  233. </Div>
  234. <Shape position="absolute 1 523 371 553" id="roundrect2" class="roundrect_example" type="roundrectangle"/>
  235. <Static text="범 례" position="absolute 6 528 76 548" align="align:center middle;" id="caption14" class="cell_2"/>
  236. <Static text="△ 결과저장" position="absolute 86 528 156 548" align="align:center middle;" id="caption12"/>
  237. <Static text="○ 중간(예비)보고" position="absolute 171 528 271 548" align="align:center middle;" id="caption13"/>
  238. <Static text="◆ 최종보고" position="absolute 286 528 352 548" align="align:center middle;" id="caption15" style="color:#339966ff;"/>
  239. <Div position="absolute 291 105 292 320" id="grp_bmtinfo" visible="false">
  240. <Layouts>
  241. <Layout>
  242. <Grid position="absolute 0 0 324 190" id="grd_bmtinfo" binddataset="ds_grd_bmtinfo" anchor="default">
  243. <Formats>
  244. <Format id="default">
  245. <Columns>
  246. <Column size="100"/>
  247. <Column size="80"/>
  248. <Column size="80"/>
  249. <Column size="40"/>
  250. </Columns>
  251. <Rows>
  252. <Row size="24" band="head"/>
  253. <Row size="24"/>
  254. </Rows>
  255. <Band id="head">
  256. <Cell text="이식전 btype"/>
  257. <Cell col="1" text="공여자 btype"/>
  258. <Cell col="2" text="이식일자"/>
  259. <Cell col="3" text="차수"/>
  260. </Band>
  261. <Band id="body">
  262. <Cell text="bind:btype"/>
  263. <Cell col="1" text="bind:dnorbtype"/>
  264. <Cell col="2" text="bind:trnptdd" mask="yyyy-mm-dd"/>
  265. <Cell col="3" text="bind:trnptdg"/>
  266. </Band>
  267. </Format>
  268. </Formats>
  269. </Grid>
  270. <Button position="absolute 280 191 322 210" id="button42" class="btn2_letter2" text="닫기" anchor="default"/>
  271. </Layout>
  272. </Layouts>
  273. </Div>
  274. <TextArea id="cmt_extext" taborder="1" wordwrap="both" oneditclick="group2_cmt_extext_oneditclick" ontextchanged="group2_cmt_extext_ontextchanged" visible="false" position="absolute 5 315 850 619"/>
  275. <Button id="btn_excmt" taborder="4" text="확장" onclick="btn_excmt_onclick" class="btn2" position="absolute 773 548 815 567"/>
  276. <Shape id="cmt_exline" class="line_10" visible="false" position="absolute 5 288 848 292" style="strokepen:3 solid #33bbbbff;"/>
  277. <Button id="cmt_exbtn" taborder="3" text="축소" onclick="cmt_exbtn_onclick" class="btn2" visible="false" position="absolute 808 295 850 314"/>
  278. <Button id="cmt_exbtn6" taborder="2" text="최종저장" onclick="cmt_exbtn6_onclick" class="btn2" visible="false" position="absolute 290 295 360 314"/>
  279. <Static id="cmt_excap2" text="소견상세내역" class="tit_2" visible="false" position="absolute 7 297 105 314"/>
  280. </Layout>
  281. </Layouts>
  282. <Objects>
  283. <Dataset id="ds_cond_patinfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  284. <ColumnInfo>
  285. <Column id="bcno" type="STRING" size="256"/>
  286. <Column id="pid" type="STRING" size="256"/>
  287. <Column id="hngnm" type="STRING" size="256"/>
  288. <Column id="patsexage" type="STRING" size="256"/>
  289. <Column id="regno" type="STRING" size="256"/>
  290. <Column id="reqdoctnm" type="STRING" size="256"/>
  291. <Column id="orddeptnm" type="STRING" size="256"/>
  292. <Column id="orddrnm" type="STRING" size="256"/>
  293. <Column id="workno" type="STRING" size="256"/>
  294. <Column id="orddeptcd" type="STRING" size="256"/>
  295. <Column id="reqdoctcd" type="STRING" size="256"/>
  296. <Column id="prcpdd" type="STRING" size="256"/>
  297. <Column id="spcacptid" type="STRING" size="256"/>
  298. <Column id="spcacptdt" type="STRING" size="256"/>
  299. <Column id="mdlreptdt" type="STRING" size="256"/>
  300. <Column id="lstreptdt" type="STRING" size="256"/>
  301. <Column id="rsltrgsgid" type="STRING" size="256"/>
  302. <Column id="rsltrgstdt" type="STRING" size="256"/>
  303. <Column id="mdlreptid" type="STRING" size="256"/>
  304. <Column id="lastreptid" type="STRING" size="256"/>
  305. <Column id="lastreptdt" type="STRING" size="256"/>
  306. <Column id="spcscrnnm" type="STRING" size="256"/>
  307. <Column id="barcdprntid" type="STRING" size="256"/>
  308. <Column id="barcdprntdt" type="STRING" size="256"/>
  309. <Column id="bcolldt" type="STRING" size="256"/>
  310. <Column id="bcollid" type="STRING" size="256"/>
  311. <Column id="tsectcdlist" type="STRING" size="256"/>
  312. <Column id="testcontcd" type="STRING" size="256"/>
  313. <Column id="testcont" type="STRING" size="256"/>
  314. <Column id="bak_testcont" type="STRING" size="256"/>
  315. <Column id="sectcd" type="STRING" size="256"/>
  316. <Column id="tsectcd" type="STRING" size="256"/>
  317. <Column id="prcprempact" type="STRING" size="256"/>
  318. <Column id="obcno" type="STRING" size="256"/>
  319. </ColumnInfo>
  320. </Dataset>
  321. <Dataset id="ds_temp_abnormallist" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  322. <Dataset id="ds_temp_testcont" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  323. <ColumnInfo>
  324. <Column id="bcno" type="STRING" size="256"/>
  325. <Column id="testcontcd" type="STRING" size="256"/>
  326. <Column id="testcont" type="STRING" size="256"/>
  327. <Column id="testcontkind" type="STRING" size="256"/>
  328. <Column id="execdeptcd" type="STRING" size="256"/>
  329. <Column id="iud" type="STRING" size="256"/>
  330. <Column id="prcprempact" type="STRING" size="256"/>
  331. </ColumnInfo>
  332. </Dataset>
  333. <Dataset id="ds_grid_testcmts" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  334. <ColumnInfo>
  335. <Column id="testcont" type="STRING" size="256"/>
  336. </ColumnInfo>
  337. </Dataset>
  338. <Dataset id="ds_RelationParm" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  339. <ColumnInfo>
  340. <Column id="pid" type="STRING"/>
  341. <Column id="tclsscrnnm" type="STRING"/>
  342. <Column id="testcd" type="STRING"/>
  343. <Column id="spccd" type="STRING"/>
  344. </ColumnInfo>
  345. </Dataset>
  346. <Dataset id="ds_temp_relationrslt" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  347. <Dataset id="ds_temp_chkstr" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  348. <Dataset id="ds_temp_prcpinfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  349. <Dataset id="ds_temp_getaboinfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  350. <Dataset id="ds_hidden_DJGGParrm" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  351. <ColumnInfo>
  352. <Column id="bcno" type="STRING"/>
  353. <Column id="testlrgkind" type="STRING"/>
  354. <Column id="microtestkind" type="STRING"/>
  355. <Column id="bufDJGG" type="STRING"/>
  356. <Column id="testcdlist" type="STRING"/>
  357. <Column id="uprsltYN" type="STRING"/>
  358. <Column id="userid" type="STRING"/>
  359. <Column id="rsltsaveYN" type="STRING"/>
  360. <Column id="orgBufDJGG" type="STRING" size="0"/>
  361. </ColumnInfo>
  362. </Dataset>
  363. <Dataset id="ds_baseinfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  364. <ColumnInfo>
  365. <Column id="pid" type="STRING"/>
  366. <Column id="testcd" type="STRING"/>
  367. <Column id="hngnm" type="STRING"/>
  368. <Column id="sex" type="STRING"/>
  369. <Column id="age" type="STRING"/>
  370. <Column id="startdd" type="STRING"/>
  371. <Column id="enddd" type="STRING"/>
  372. <Column id="flag" type="STRING"/>
  373. </ColumnInfo>
  374. </Dataset>
  375. <Dataset id="ds_copy_grd_TestInfoCnts" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false"/>
  376. <Dataset id="ds_autocmt" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  377. <ColumnInfo>
  378. <Column id="cmttext" type="STRING"/>
  379. <Column id="flag" type="STRING"/>
  380. </ColumnInfo>
  381. </Dataset>
  382. <Dataset id="ds_grd_TestInfoCnts" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false"/>
  383. <Dataset id="ds_grid_testlist" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false" oncolumnchanged="ds_grid_testlist_oncolumnchanged">
  384. <ColumnInfo>
  385. <Column id="exp_value" type="STRING" size="256"/>
  386. <Column id="selch" type="STRING" size="256"/>
  387. <Column id="sel_value" type="STRING" size="256"/>
  388. <Column id="medispcreadyn" type="STRING" size="256"/>
  389. <Column id="nmeddilute" type="STRING" size="256"/>
  390. <Column id="bcno" type="STRING" size="256"/>
  391. <Column id="pid" type="STRING" size="256"/>
  392. <Column id="worknoflag" type="STRING" size="256"/>
  393. <Column id="patsex" type="STRING" size="256"/>
  394. <Column id="patage" type="STRING" size="256"/>
  395. <Column id="regno" type="STRING" size="256"/>
  396. <Column id="prcpgenrflag" type="STRING" size="256"/>
  397. <Column id="orddeptcd" type="STRING" size="256"/>
  398. <Column id="execprcpuniqno" type="STRING" size="256"/>
  399. <Column id="prcpdd" type="STRING" size="256"/>
  400. <Column id="testflag" type="STRING" size="256"/>
  401. <Column id="barcdprntid" type="STRING" size="256"/>
  402. <Column id="prcprgstdd" type="STRING" size="256"/>
  403. <Column id="testcd" type="STRING" size="256"/>
  404. <Column id="spccd" type="STRING" size="256"/>
  405. <Column id="readonly" type="STRING" size="256"/>
  406. <Column id="inptrslt" type="STRING" size="256"/>
  407. <Column id="bufinptrslt" type="STRING" size="256"/>
  408. <Column id="reptrslt" type="STRING" size="256"/>
  409. <Column id="judgmark" type="STRING" size="256"/>
  410. <Column id="nmeddivgrupcd" type="STRING" size="256"/>
  411. <Column id="panicmark" type="STRING" size="256"/>
  412. <Column id="criticalmark" type="STRING" size="256"/>
  413. <Column id="orddrid" type="STRING" size="256"/>
  414. <Column id="relatingmark" type="STRING" size="256"/>
  415. <Column id="amrmark" type="STRING" size="256"/>
  416. <Column id="rsltstat" type="STRING" size="256"/>
  417. <Column id="bfbcno" type="STRING" size="256"/>
  418. <Column id="deltamark" type="STRING" size="256"/>
  419. <Column id="bfinptrslt" type="STRING" size="256"/>
  420. <Column id="bfreptrslt" type="STRING" size="256"/>
  421. <Column id="prereptrslt" type="STRING" size="256"/>
  422. <Column id="sectcd" type="STRING" size="256"/>
  423. <Column id="testcmt" type="STRING" size="256"/>
  424. <Column id="retestyn" type="STRING" size="256"/>
  425. <Column id="imagrsltyn" type="STRING" size="256"/>
  426. <Column id="workseq" type="STRING" size="256"/>
  427. <Column id="bcollid" type="STRING" size="256"/>
  428. <Column id="settestyn" type="STRING" size="256"/>
  429. <Column id="workno" type="STRING" size="256"/>
  430. <Column id="spcacptid" type="STRING" size="256"/>
  431. <Column id="rgstdd" type="STRING" size="256"/>
  432. <Column id="rsltrgsgid" type="STRING" size="256"/>
  433. <Column id="nmedworkdt" type="STRING" size="256"/>
  434. <Column id="mdlreptid" type="STRING" size="256"/>
  435. <Column id="mdlreptnm" type="STRING" size="256"/>
  436. <Column id="rsltrgstdt" type="STRING" size="256"/>
  437. <Column id="lastreptid" type="STRING" size="256"/>
  438. <Column id="lastreptnm" type="STRING" size="256"/>
  439. <Column id="lastreptdt" type="STRING" size="256"/>
  440. <Column id="tclsscrnm" type="STRING" size="256"/>
  441. <Column id="tclsscrnnm" type="STRING" size="256"/>
  442. <Column id="rsltdispseq" type="STRING" size="256"/>
  443. <Column id="tclskind" type="STRING" size="256"/>
  444. <Column id="testrsltkind" type="STRING" size="256"/>
  445. <Column id="spclrsltkind" type="STRING" size="256"/>
  446. <Column id="mdlreptdt" type="STRING" size="256"/>
  447. <Column id="childessnrsltyn" type="STRING" size="256"/>
  448. <Column id="diffcntyn" type="STRING" size="256"/>
  449. <Column id="rsltkind" type="STRING" size="256"/>
  450. <Column id="rsltintsize" type="STRING" size="256"/>
  451. <Column id="rsltdcmlsize" type="STRING" size="256"/>
  452. <Column id="rundkind" type="STRING" size="256"/>
  453. <Column id="rsltunit" type="STRING" size="256"/>
  454. <Column id="medispclyn" type="STRING" size="256"/>
  455. <Column id="fiximedispclid" type="STRING" size="256"/>
  456. <Column id="tclscdfromdd" type="STRING" size="256"/>
  457. <Column id="spcscrnnm" type="STRING" size="256"/>
  458. <Column id="nmedworkseq" type="STRING" size="256"/>
  459. <Column id="descrval" type="STRING" size="256"/>
  460. <Column id="rsltstat2" type="STRING" size="256"/>
  461. <Column id="userjudgchar1" type="STRING" size="256"/>
  462. <Column id="workdd" type="STRING" size="256"/>
  463. <Column id="medispcdt" type="STRING" size="256"/>
  464. <Column id="panicflag" type="STRING" size="256"/>
  465. <Column id="panicminval" type="STRING" size="256"/>
  466. <Column id="panicmaxval" type="STRING" size="256"/>
  467. <Column id="panicminvalsinq" type="STRING" size="256"/>
  468. <Column id="panicmaxvalsinq" type="STRING" size="256"/>
  469. <Column id="parentidx" type="STRING" size="256"/>
  470. <Column id="deltaminval" type="STRING" size="256"/>
  471. <Column id="microtestkind" type="STRING" size="256"/>
  472. <Column id="prcpdelivefact" type="STRING" size="256"/>
  473. <Column id="deltaminvalsinq" type="STRING" size="256"/>
  474. <Column id="deltamaxvalsinq" type="STRING" size="256"/>
  475. <Column id="criticalflag" type="STRING" size="256"/>
  476. <Column id="criticalminval" type="STRING" size="256"/>
  477. <Column id="signno" type="STRING" size="256"/>
  478. <Column id="bcolldt" type="STRING" size="256"/>
  479. <Column id="criticalmaxvalsinq" type="STRING" size="256"/>
  480. <Column id="patnm" type="STRING" size="256"/>
  481. <Column id="descrsltyn" type="STRING" size="256"/>
  482. <Column id="alertmaxval" type="STRING" size="256"/>
  483. <Column id="alertminvalsinq" type="STRING" size="256"/>
  484. <Column id="workno2" type="STRING" size="256"/>
  485. <Column id="barcdprntdt" type="STRING" size="256"/>
  486. <Column id="prcpremfact" type="STRING" size="256"/>
  487. <Column id="spcstat" type="STRING" size="256"/>
  488. <Column id="alimitmaxval" type="STRING" size="256"/>
  489. <Column id="orddrnm" type="STRING" size="256"/>
  490. <Column id="initflag" type="STRING" size="256"/>
  491. <Column id="alimitmaxdispkind" type="STRING" size="256"/>
  492. <Column id="alimitmindispkind" type="STRING" size="256"/>
  493. <Column id="amrflag" type="STRING" size="256"/>
  494. <Column id="amrminval" type="STRING" size="256"/>
  495. <Column id="amrmaxval" type="STRING" size="256"/>
  496. <Column id="amrminvalsinq" type="STRING" size="256"/>
  497. <Column id="spcltestseqno" type="STRING" size="256"/>
  498. <Column id="rsltdt" type="STRING" size="256"/>
  499. <Column id="erprcpflag" type="STRING" size="256"/>
  500. <Column id="execdeptcd" type="STRING" size="256"/>
  501. <Column id="spcltestyy" type="STRING" size="256"/>
  502. <Column id="refl" type="STRING" size="256"/>
  503. <Column id="rsltseq" type="STRING" size="256"/>
  504. <Column id="alertflag" type="STRING" size="256"/>
  505. <Column id="refhs" type="STRING" size="256"/>
  506. <Column id="rsltmark" type="STRING" size="256"/>
  507. <Column id="rstinterval" type="STRING" size="256"/>
  508. <Column id="testlrgkind" type="STRING" size="256"/>
  509. <Column id="relation" type="STRING" size="256"/>
  510. <Column id="dnorgbn" type="STRING" size="256"/>
  511. <Column id="instcd" type="STRING" size="256"/>
  512. <Column id="alertmaxvalsinq" type="STRING" size="256"/>
  513. <Column id="rstdt" type="STRING" size="256"/>
  514. <Column id="rstnm" type="STRING" size="256"/>
  515. <Column id="eqmtnm" type="STRING" size="256"/>
  516. <Column id="bfrstnm" type="STRING" size="256"/>
  517. <Column id="alertmark" type="STRING" size="256"/>
  518. <Column id="medispcldt" type="STRING" size="256"/>
  519. <Column id="bflastreptdt" type="STRING" size="256"/>
  520. <Column id="orddeptnm" type="STRING" size="256"/>
  521. <Column id="acptcnt" type="STRING" size="256"/>
  522. <Column id="acpt01" type="STRING" size="256"/>
  523. <Column id="acpt02" type="STRING" size="256"/>
  524. <Column id="acpt03" type="STRING" size="256"/>
  525. <Column id="acpt04" type="STRING" size="256"/>
  526. <Column id="acpt05" type="STRING" size="256"/>
  527. <Column id="acpt06" type="STRING" size="256"/>
  528. <Column id="acpt07" type="STRING" size="256"/>
  529. <Column id="acpt08" type="STRING" size="256"/>
  530. <Column id="acpt09" type="STRING" size="256"/>
  531. <Column id="acpt10" type="STRING" size="256"/>
  532. <Column id="reflt" type="STRING" size="256"/>
  533. <Column id="userjudgchar2" type="STRING" size="256"/>
  534. <Column id="calformkind" type="STRING" size="256"/>
  535. <Column id="refls" type="STRING" size="256"/>
  536. <Column id="spcacptdt" type="STRING" size="256"/>
  537. <Column id="conttestyn" type="STRING" size="256"/>
  538. <Column id="alimitmaxvalsinq" type="STRING" size="256"/>
  539. <Column id="parentrsltinptyn" type="STRING" size="256"/>
  540. <Column id="rackposition" type="STRING" size="256"/>
  541. <Column id="chkstring" type="STRING" size="256"/>
  542. <Column id="testcnt" type="STRING" size="256"/>
  543. <Column id="alertminval" type="STRING" size="256"/>
  544. <Column id="userjudgchar3" type="STRING" size="256"/>
  545. <Column id="Column1" type="STRING" size="256"/>
  546. <Column id="abnrtestuseyn" type="STRING" size="256"/>
  547. <Column id="testeqmtcd" type="STRING" size="256"/>
  548. <Column id="Column4" type="STRING" size="256"/>
  549. <Column id="Column5" type="STRING" size="256"/>
  550. <Column id="Column6" type="STRING" size="256"/>
  551. <Column id="Column7" type="STRING" size="256"/>
  552. <Column id="Column8" type="STRING" size="256"/>
  553. <Column id="rvalflag" type="STRING" size="256"/>
  554. <Column id="Column10" type="STRING" size="256"/>
  555. <Column id="tsectcd" type="STRING" size="256"/>
  556. <Column id="Column12" type="STRING" size="256"/>
  557. <Column id="Column13" type="STRING" size="256"/>
  558. <Column id="Column14" type="STRING" size="256"/>
  559. <Column id="deltaterm" type="STRING" size="256"/>
  560. <Column id="Column16" type="STRING" size="256"/>
  561. <Column id="Column17" type="STRING" size="256"/>
  562. <Column id="Column18" type="STRING" size="256"/>
  563. <Column id="alimitminvalsinq" type="STRING" size="256"/>
  564. <Column id="Column20" type="STRING" size="256"/>
  565. <Column id="dnorno" type="STRING" size="256"/>
  566. <Column id="spcltestkind" type="STRING" size="256"/>
  567. <Column id="selchk" type="STRING" size="256"/>
  568. <Column id="color" type="STRING" size="256"/>
  569. <Column id="chkImage" type="STRING" size="256"/>
  570. <Column id="relImage" type="STRING" size="256"/>
  571. <Column id="exisImage" type="STRING" size="256"/>
  572. <Column id="rstImage" type="STRING" size="256"/>
  573. <Column id="rstcdexists" type="STRING" size="256"/>
  574. <Column id="nvalrsltlimyn" type="STRING" size="256"/>
  575. <Column id="judgkind" type="STRING" size="256"/>
  576. <Column id="refh" type="STRING" size="256"/>
  577. <Column id="deltaflag" type="STRING" size="256"/>
  578. <Column id="deltamaxval" type="STRING" size="256"/>
  579. <Column id="criticalmaxval" type="STRING" size="256"/>
  580. <Column id="alimitflag" type="STRING" size="256"/>
  581. <Column id="alimitminval" type="STRING" size="256"/>
  582. <Column id="rsltstat01" type="STRING" size="256"/>
  583. <Column id="inptrslt01" type="STRING" size="256"/>
  584. <Column id="reptrslt01" type="STRING" size="256"/>
  585. <Column id="rsltrgsgid01" type="STRING" size="256"/>
  586. <Column id="rsltrgstdt01" type="STRING" size="256"/>
  587. <Column id="rsltstat02" type="STRING" size="256"/>
  588. <Column id="inptrslt02" type="STRING" size="256"/>
  589. <Column id="reptrslt02" type="STRING" size="256"/>
  590. <Column id="rsltrgsgid02" type="STRING" size="256"/>
  591. <Column id="rsltrgstdt02" type="STRING" size="256"/>
  592. <Column id="tclscd" type="STRING" size="256"/>
  593. <Column id="bfspcacptdd" type="STRING" size="256"/>
  594. <Column id="Column0" type="STRING" size="256"/>
  595. </ColumnInfo>
  596. </Dataset>
  597. <Dataset id="ds_BmtExecInfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  598. <ColumnInfo>
  599. <Column id="btype" type="STRING" size="256"/>
  600. <Column id="dnorbtype" type="STRING" size="256"/>
  601. <Column id="trnptdd" type="STRING" size="256"/>
  602. </ColumnInfo>
  603. </Dataset>
  604. <Dataset id="ds_BmtExecInfoList" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false"/>
  605. <Dataset id="ds_vSndSG" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  606. <ColumnInfo>
  607. <Column id="testcontcd" type="STRING"/>
  608. <Column id="execdeptcd" type="STRING"/>
  609. <Column id="testcont" type="STRING"/>
  610. <Column id="testcontkind" type="STRING"/>
  611. </ColumnInfo>
  612. </Dataset>
  613. <Dataset id="ds_grid_grd_TestInfoCnts" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false" onrowposchanged="ds_grid_grd_TestInfoCnts_onrowposchanged">
  614. <ColumnInfo>
  615. <column id="exp_value" type="STRING"/>
  616. <column id="selchk" type="STRING"/>
  617. <column id="sel_value" type="STRING"/>
  618. <column id="parentidx" type="STRING"/>
  619. <column id="bcno" type="STRING"/>
  620. <column id="pid" type="STRING"/>
  621. <column id="patnm" type="STRING"/>
  622. <column id="patsex" type="STRING"/>
  623. <column id="patage" type="STRING"/>
  624. <column id="regno" type="STRING"/>
  625. <column id="orddeptnm" type="STRING"/>
  626. <column id="orddeptcd" type="STRING"/>
  627. <column id="execprcpuniqno" type="STRING"/>
  628. <column id="prcpdd" type="STRING"/>
  629. <column id="reqdoctrem" type="STRING"/>
  630. <column id="reqdoctid" type="STRING"/>
  631. <column id="prcprgstdd" type="STRING"/>
  632. <column id="testcd" type="STRING"/>
  633. <column id="spccd" type="STRING"/>
  634. <column id="readonly" type="STRING"/>
  635. <column id="inptrslt" type="STRING"/>
  636. <column id="bufinptrslt" type="STRING"/>
  637. <column id="reptrslt" type="STRING"/>
  638. <column id="judgmark" type="STRING"/>
  639. <column id="deltamark" type="STRING"/>
  640. <column id="panicmark" type="STRING"/>
  641. <column id="criticalmark" type="STRING"/>
  642. <column id="alertmark" type="STRING"/>
  643. <column id="relatingmark" type="STRING"/>
  644. <column id="amrmark" type="STRING"/>
  645. <column id="rsltstat" type="STRING"/>
  646. <column id="bfbcno" type="STRING"/>
  647. <column id="bflastreptdt" type="STRING"/>
  648. <column id="bfinptrslt" type="STRING"/>
  649. <column id="bfreptrslt" type="STRING"/>
  650. <column id="prereptrslt" type="STRING"/>
  651. <column id="testeqmtcd" type="STRING"/>
  652. <column id="testcmt" type="STRING"/>
  653. <column id="retestyn" type="STRING"/>
  654. <column id="imagrsltyn" type="STRING"/>
  655. <column id="workseq" type="STRING"/>
  656. <column id="tclscd" type="STRING"/>
  657. <column id="rsltseq" type="STRING"/>
  658. <column id="workno" type="STRING"/>
  659. <column id="spcacptid" type="STRING"/>
  660. <column id="spcacptdt" type="STRING"/>
  661. <column id="rsltrgsgid" type="STRING"/>
  662. <column id="rsltrgstdt" type="STRING"/>
  663. <column id="mdlreptid" type="STRING"/>
  664. <column id="mdlreptnm" type="STRING"/>
  665. <column id="mdlreptdt" type="STRING"/>
  666. <column id="lastreptid" type="STRING"/>
  667. <column id="lastreptnm" type="STRING"/>
  668. <column id="lastreptdt" type="STRING"/>
  669. <column id="tclsscrnm" type="STRING"/>
  670. <column id="tclsscrnnm" type="STRING"/>
  671. <column id="rsltdispseq" type="STRING"/>
  672. <column id="tclskind" type="STRING"/>
  673. <column id="testrsltkind" type="STRING"/>
  674. <column id="spclrsltkind" type="STRING"/>
  675. <column id="parentrsltinptyn" type="STRING"/>
  676. <column id="childessnrsltyn" type="STRING"/>
  677. <column id="diffcntyn" type="STRING"/>
  678. <column id="rsltkind" type="STRING"/>
  679. <column id="rsltintsize" type="STRING"/>
  680. <column id="rsltdcmlsize" type="STRING"/>
  681. <column id="rundkind" type="STRING"/>
  682. <column id="rsltunit" type="STRING"/>
  683. <column id="medispclyn" type="STRING"/>
  684. <column id="fiximedispclid" type="STRING"/>
  685. <column id="tclscdfromdd" type="STRING"/>
  686. <column id="spcscrnnm" type="STRING"/>
  687. <column id="rvalflag" type="STRING"/>
  688. <column id="descrval" type="STRING"/>
  689. <column id="judgkind" type="STRING"/>
  690. <column id="userjudgchar1" type="STRING"/>
  691. <column id="userjudgchar2" type="STRING"/>
  692. <column id="userjudgchar3" type="STRING"/>
  693. <column id="panicflag" type="STRING"/>
  694. <column id="panicminval" type="STRING"/>
  695. <column id="panicmaxval" type="STRING"/>
  696. <column id="panicminvalsinq" type="STRING"/>
  697. <column id="panicmaxvalsinq" type="STRING"/>
  698. <column id="deltaflag" type="STRING"/>
  699. <column id="deltaminval" type="STRING"/>
  700. <column id="deltamaxval" type="STRING"/>
  701. <column id="deltaterm" type="STRING"/>
  702. <column id="deltaminvalsinq" type="STRING"/>
  703. <column id="deltamaxvalsinq" type="STRING"/>
  704. <column id="criticalflag" type="STRING"/>
  705. <column id="criticalminval" type="STRING"/>
  706. <column id="criticalmaxval" type="STRING"/>
  707. <column id="criticalminvalsinq" type="STRING"/>
  708. <column id="criticalmaxvalsinq" type="STRING"/>
  709. <column id="alertflag" type="STRING"/>
  710. <column id="alertminval" type="STRING"/>
  711. <column id="alertmaxval" type="STRING"/>
  712. <column id="alertminvalsinq" type="STRING"/>
  713. <column id="alertmaxvalsinq" type="STRING"/>
  714. <column id="alimitls" type="STRING"/>
  715. <column id="alimitflag" type="STRING"/>
  716. <column id="alimitminval" type="STRING"/>
  717. <column id="alimitmaxval" type="STRING"/>
  718. <column id="alimitmaxvalsinq" type="STRING"/>
  719. <column id="alimitminvalsinq" type="STRING"/>
  720. <column id="alimitmaxdispkind" type="STRING"/>
  721. <column id="alimitmindispkind" type="STRING"/>
  722. <column id="amrflag" type="STRING"/>
  723. <column id="amrminval" type="STRING"/>
  724. <column id="amrmaxval" type="STRING"/>
  725. <column id="amrminvalsinq" type="STRING"/>
  726. <column id="amrmaxvalsinq" type="STRING"/>
  727. <column id="rsltdt" type="STRING"/>
  728. <column id="erprcpflag" type="STRING"/>
  729. <column id="refval" type="STRING"/>
  730. <column id="rsltmark" type="STRING"/>
  731. <column id="refl" type="STRING"/>
  732. <column id="refls" type="STRING"/>
  733. <column id="refh" type="STRING"/>
  734. <column id="refhs" type="STRING"/>
  735. <column id="reflt" type="STRING"/>
  736. <column id="rstinterval" type="STRING"/>
  737. <column id="testlrgkind" type="STRING"/>
  738. <column id="relation" type="STRING"/>
  739. <column id="rstcdexists" type="STRING"/>
  740. <column id="instcd" type="STRING"/>
  741. <column id="testcd2" type="STRING"/>
  742. <column id="rstdt" type="STRING"/>
  743. <column id="rstnm" type="STRING"/>
  744. <column id="eqmtnm" type="STRING"/>
  745. <column id="bfrstnm" type="STRING"/>
  746. <column id="medispclnm" type="STRING"/>
  747. <column id="medispcldt" type="STRING"/>
  748. <column id="medispclid" type="STRING"/>
  749. <column id="nvalrsltlimyn" type="STRING"/>
  750. <column id="acptcnt" type="STRING"/>
  751. <column id="acpt01" type="STRING"/>
  752. <column id="acpt02" type="STRING"/>
  753. <column id="acpt03" type="STRING"/>
  754. <column id="acpt04" type="STRING"/>
  755. <column id="acpt05" type="STRING"/>
  756. <column id="acpt06" type="STRING"/>
  757. <column id="acpt07" type="STRING"/>
  758. <column id="acpt08" type="STRING"/>
  759. <column id="acpt09" type="STRING"/>
  760. <column id="acpt10" type="STRING"/>
  761. <column id="apptclscd" type="STRING"/>
  762. <column id="apptestcnt" type="STRING"/>
  763. <column id="calformkind" type="STRING"/>
  764. <column id="calformcnts" type="STRING"/>
  765. <column id="testunit" type="STRING"/>
  766. <column id="conttestyn" type="STRING"/>
  767. <column id="conttest" type="STRING"/>
  768. <column id="refvals" type="STRING"/>
  769. <column id="rackposition" type="STRING"/>
  770. <column id="chkstring" type="STRING"/>
  771. <column id="testcnt" type="STRING"/>
  772. <column id="urinspcyn" type="STRING"/>
  773. <column id="erkind" type="STRING"/>
  774. <Column id="tooltip" type="STRING" size="256"/>
  775. <Column id="acptspc01" type="STRING" size="256"/>
  776. <Column id="acptspc02" type="STRING" size="256"/>
  777. <Column id="acptspc03" type="STRING" size="256"/>
  778. <Column id="acptspc04" type="STRING" size="256"/>
  779. <Column id="acptspc05" type="STRING" size="256"/>
  780. <Column id="acptspc06" type="STRING" size="256"/>
  781. <Column id="acptspc07" type="STRING" size="256"/>
  782. <Column id="acptspc08" type="STRING" size="256"/>
  783. <Column id="acptspc09" type="STRING" size="256"/>
  784. <Column id="acptspc10" type="STRING" size="256"/>
  785. <Column id="fromdd" type="STRING" size="256"/>
  786. <Column id="visible" type="STRING" size="256"/>
  787. <Column id="orgreptrslt" type="STRING" size="256"/>
  788. <Column id="calrsltrgstdt" type="STRING" size="256"/>
  789. <Column id="calmdlreptdt" type="STRING" size="256"/>
  790. <Column id="callastreptdt" type="STRING" size="256"/>
  791. <Column id="blank1" type="STRING" size="256"/>
  792. <Column id="blank2" type="STRING" size="256"/>
  793. <Column id="testeqmtgbn" type="STRING" size="256"/>
  794. <Column id="orginptrslt" type="STRING" size="256"/>
  795. <Column id="bfspcacptdd" type="STRING" size="256"/>
  796. </ColumnInfo>
  797. </Dataset>
  798. <Dataset id="ds_getSpcInfo" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  799. <ColumnInfo>
  800. <column id="bcno" type="STRING"/>
  801. <column id="pid" type="STRING"/>
  802. <column id="hngnm" type="STRING"/>
  803. <column id="patsexage" type="STRING"/>
  804. <column id="regno" type="STRING"/>
  805. <column id="reqdoctnm" type="STRING"/>
  806. <column id="orddeptnm" type="STRING"/>
  807. <column id="orddrnm" type="STRING"/>
  808. <column id="workno" type="STRING"/>
  809. <column id="orddeptcd" type="STRING"/>
  810. <column id="reqdoctcd" type="STRING"/>
  811. <column id="prcpdd" type="STRING"/>
  812. <column id="spcacptid" type="STRING"/>
  813. <column id="spcacptdt" type="STRING"/>
  814. <column id="lstreptdt" type="STRING"/>
  815. <column id="rsltrgsgid" type="STRING"/>
  816. <column id="rsltrgstdt" type="STRING"/>
  817. <column id="mdlreptid" type="STRING"/>
  818. <column id="mdlreptdt" type="STRING"/>
  819. <column id="lastreptid" type="STRING"/>
  820. <column id="lastreptdt" type="STRING"/>
  821. <column id="spcscrnnm" type="STRING"/>
  822. <column id="barcdprntid" type="STRING"/>
  823. <column id="barcdprntdt" type="STRING"/>
  824. <column id="bcolldt" type="STRING"/>
  825. <column id="bcollid" type="STRING"/>
  826. <column id="tsectcdlist" type="STRING"/>
  827. <column id="testcontcd" type="STRING"/>
  828. <column id="testcont" type="STRING"/>
  829. <column id="bak_testcont" type="STRING"/>
  830. <column id="sectcd" type="STRING"/>
  831. <column id="tsectcd" type="STRING"/>
  832. <column id="prcprempact" type="STRING"/>
  833. <column id="obcno" type="STRING"/>
  834. <column id="pritnInfo" type="STRING"/>
  835. <column id="lisInfo" type="STRING"/>
  836. <column id="lisadd" type="STRING"/>
  837. <Column id="spcfcnts" type="STRING" size="256"/>
  838. </ColumnInfo>
  839. <Rows>
  840. <Row/>
  841. </Rows>
  842. </Dataset>
  843. <Dataset id="ds_grid_grd_TestCmts" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  844. <ColumnInfo>
  845. <Column id="bcno" type="STRING"/>
  846. <Column id="tclscd" type="STRING"/>
  847. <Column id="spccd" type="STRING"/>
  848. <Column id="testcd" type="STRING"/>
  849. <Column id="rsltseq" type="STRING"/>
  850. <Column id="testcontcd" type="STRING"/>
  851. <Column id="flag" type="STRING"/>
  852. <Column id="testcont" type="STRING"/>
  853. </ColumnInfo>
  854. </Dataset>
  855. <Dataset id="ds_testcont" firefirstcount="0" firenextcount="0" useclientlayout="true" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  856. <ColumnInfo>
  857. <column id="bcno" type="STRING"/>
  858. <column id="testcontcd" type="STRING"/>
  859. <column id="testcont" type="STRING"/>
  860. <column id="testcontkind" type="STRING"/>
  861. <column id="execdeptcd" type="STRING"/>
  862. <column id="iud" type="STRING"/>
  863. </ColumnInfo>
  864. </Dataset>
  865. </Objects>
  866. <Bind>
  867. <BindItem id="item0" compid="group2.output1" propid="value" datasetid="ds_cond_patinfo" columnid="bcno"/>
  868. <BindItem id="item1" compid="group2.output4" propid="value" datasetid="ds_cond_patinfo" columnid="bcolldt"/>
  869. <BindItem id="item2" compid="group2.output3" propid="value" datasetid="ds_cond_patinfo" columnid="spcacptdt"/>
  870. <BindItem id="item3" compid="group2.output2" propid="value" datasetid="ds_cond_patinfo" columnid="workno"/>
  871. <BindItem id="item4" compid="group2.textarea2" propid="value" datasetid="ds_temp_testcont" columnid="testcont"/>
  872. <BindItem id="item5" compid="group2.output13" propid="value" datasetid="ds_BmtExecInfo" columnid="btype"/>
  873. <BindItem id="item6" compid="group2.output5" propid="value" datasetid="ds_BmtExecInfo" columnid="dnorbtype"/>
  874. <BindItem id="item7" compid="group2.output11" propid="value" datasetid="ds_BmtExecInfo" columnid="trnptdd"/>
  875. <BindItem id="item8" compid="group2.textarea1" propid="value" datasetid="ds_cond_patinfo" columnid="prcprempact"/>
  876. <BindItem id="item9" compid="cmt_extext" propid="value" datasetid="ds_temp_testcont" columnid="testcont"/>
  877. </Bind>
  878. <Script type="xscript4.0"><![CDATA[/***************************************************************************************
  879. * System Name :
  880. * Job Name :
  881. * Creator :
  882. * Make Date : 2015-05-01
  883. * Description :
  884. *---------------------------------------------------------------------------------------
  885. * Modify Date Modifier Modify Description
  886. *---------------------------------------------------------------------------------------
  887. * 2015-05-01 Live Converter TF->XP
  888. *
  889. *---------------------------------------------------------------------------------------
  890. ****************************************************************************************/
  891. include "com_commonxp::comm_main.xjs";
  892. include "lis_commonxp::LLZ001.xjs";
  893. var p_isedit = false; //소견 수정여부
  894. var gv_isedit = "";
  895. var plgv_SMMMI00100_pid = "";
  896. var cell_focus = "N"; //cell typing 마우스 포커스 여부
  897. var serum_focus = "N"; //serum typing 마우스 포커스 여부
  898. var rh_focus = "N"; //rh typing 마우스 포커스 여부
  899. var gRow = -1; //마우스 클릭 포인트 임시저장
  900. var gCOl = -1;
  901. var gv_preautocmt = "";
  902. var gv_preautocmtarr = new Array();
  903. var gv_check = "0";
  904. //콜백함수
  905. function cbf_SSLLR80100(strSvcID, nErrorCode, strErrorMag){
  906. if(nErrorCode != 0 && strSvcID != "TXLLR80101") {
  907. if(strSvcID == "TRLLR00301" || strSvcID = "TRLLR80102") { //환자조회 or 결과상세내역
  908. ds_grd_patlist.clearData();
  909. ds_grid_testlist.clearData();
  910. } else {
  911. sysf_messageBox("ID: " + strSvcID + " Error: " + strErrorMag, "E009", "");
  912. }
  913. return;
  914. }
  915. }
  916. function SSLBR80100_onload(obj:Form, e:LoadEventInfo)
  917. {
  918. //마우스 우측 메뉴 항목 세팅
  919. frmf_createPopupMenu("pm_SubMenu", "pm_SubMenu_onmenuclick");
  920. // grdf_setAllCheck(group2.grd_TestInfoCnts);
  921. ds_baseinfo.addRow(); //누적결과조회 DS
  922. }
  923. //검사자 조회
  924. function lf_UserNMRef(){
  925. var sInDsName = dsf_createDsRow("ds_temp_search"
  926. , [{col: "userid", val: group2.ipt_testpsn.value}]);
  927. var sOutDsName = dsf_createDsRow("ds_temp_acceptnm"
  928. , [{col: "usernm"}, {col: "userflag"}]);
  929. var oParam = {};
  930. oParam.id = "TRLZZ00104";
  931. oParam.service = "diagtestapplib.LisCommon";
  932. oParam.method = "reqGetUserNM";
  933. oParam.inds = "cond="+sInDsName;
  934. oParam.outds = sOutDsName+"=usernm";
  935. oParam.async = false;
  936. oParam.callback = "cbf_TRLZZ00104";
  937. tranf_submit(oParam);
  938. }
  939. function lf_hiddenrow(){
  940. for(var i=0; i<ds_grid_testlist.rowcount; i++){
  941. var testcd = ds_grid_testlist.getColumn(i, "testcd");
  942. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  943. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");
  944. var etc01_105 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "105"), "cd");
  945. if(testcd == etc01_102 || testcd == etc01_105 || testcd == etc01_112 || testcd == "B2061000"){
  946. group2.grd_TestInfoCnts.setRealRowSize(i, 0);
  947. }
  948. }
  949. }
  950. //리스트조회후 그리드 변경사항
  951. function lf_RemakeList(){
  952. //조회시 자동소견 초기화
  953. gv_preautocmt = "";
  954. gv_preautocmtarr = new Array();
  955. var check = 0;
  956. var vCurRow = 1;
  957. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");//cell typing
  958. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");//cell typing
  959. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");//cell type,donor
  960. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");//serum typing
  961. var etc01_111 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "111"), "cd");//serum type,donor
  962. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");//Rh(D)
  963. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");//Rh(D),donor
  964. //신생아추가
  965. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");//cell typing(신생아)
  966. var etc01_201 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "201"), "cd");//serum typing(신생아)
  967. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");//Rh(D)(신생아)
  968. var abocnt = 0;
  969. if(ds_grid_testlist.rowcount > 0){
  970. var vSectcd = ds_grid_testlist.getColumn(0, "sectcd");
  971. var vTsectcd = ds_grid_testlist.getColumn(0, "tsectcd");
  972. lf_CMTPCD_ChangeNodeset(vSectcd, vTsectcd);
  973. lf_InitializeSoGyeon(); //소견 초기화
  974. ds_grid_testlist.addColumn("color","string");
  975. ds_grid_testlist.addColumn("background-color","string");
  976. ds_grid_testlist.addColumn( "chkImage","string");
  977. ds_grid_testlist.addColumn( "relImage","string");
  978. ds_grid_testlist.addColumn( "exisImage","string");
  979. ds_grid_testlist.addColumn( "rstImage","string");
  980. ds_grid_testlist.updatecontrol = false;
  981. for(var i=0; i<ds_grid_testlist.rowcount; i++){
  982. var vTclsKind = ds_grid_testlist.getColumn(i, "tclskind");
  983. var bufinptrslt = ds_grid_testlist.getColumn(i, "bufinptrslt");
  984. var reptrslt = ds_grid_testlist.getColumn(i, "reptrslt");
  985. var bufpositiveYN = utlf_isSearchString(String(bufinptrslt).toUpperCase(), "POSITIVE");
  986. var reptpositiveYN = utlf_isSearchString(String(reptrslt).toUpperCase(), "POSITIVE");
  987. // Cell Typing, Cell Typing (교차시험용) 일때 Negative 있으면 font 빨간색으로
  988. // 변경요청번호 10555 2010-01-26 박정은
  989. var testcd = ds_grid_testlist.getColumn(i, "testcd");
  990. if(testcd == etc01_100 || testcd == etc01_103 ){
  991. abocnt++;
  992. var bufnegativeYN = utlf_isSearchString(String(bufinptrslt).toUpperCase(), "NEGATIVE");
  993. var reptnegativeYN = utlf_isSearchString(String(reptrslt).toUpperCase(), "NEGATIVE");
  994. //var rhnegativeYN = utlf_isSearchString(String(bufinptrslt).toUpperCase(), "-");
  995. //var rhnegativeYN2 = utlf_isSearchString(String(reptrslt).toUpperCase(), "-");
  996. //rh
  997. if(bufnegativeYN || reptnegativeYN){
  998. ds_grid_testlist.setColumn(i, "color", "#EE0000"); //3,4만 빨간색
  999. }
  1000. //cell, serum 결과 다를때
  1001. var reptrslt = ds_grid_testlist.getColumn(i, "reptrslt");
  1002. var reptrslt_1 = ds_grid_testlist.getColumn((i+3), "reptrslt");
  1003. if(String(reptrslt).replace("+","").replace(" Negative", "").toUpperCase() != String(reptrslt_1).toUpperCase() &&
  1004. reptrslt_1 != ""){
  1005. ds_grid_testlist.setColumn(i, "color", "#EE0000");
  1006. }
  1007. }
  1008. if(vTclsKind == "2" || vTclsKind == "3"){
  1009. ds_grid_testlist.setColumn(i, "relImage", "..\\..\\..\\IMAGES\\lis\\chkRPT0.png");
  1010. ds_grid_testlist.setColumn(i, "chkImage", "checkbox");
  1011. }
  1012. if(ds_grid_testlist.getColumn(i, "relation") == "Y"){
  1013. ds_grid_testlist.setColumn(i, "relImage", "..\\..\\..\\IMAGES\\lis\\icnRelationGeomSa.png");
  1014. }
  1015. if(ds_grid_testlist.getColumn(i, "readonly") == "true"){
  1016. ds_grid_testlist.setColumn(i, "background-color", "#eaeaea");
  1017. if(i == 0) vCurRow += 1;
  1018. else
  1019. ds_grid_testlist.setColumn(i, "background-color", "#EEFFFF");
  1020. //ds_grid_testlist.setColumn(i, "background-color", "#EEFFFA");
  1021. }
  1022. if(ds_grid_testlist.getColumn(i, "rstcdexists") == "Y"){
  1023. ds_grid_testlist.setColumn(i, "exisImage", "..\\..\\..\\IMAGES\\lis\\icnRstCDExists.png");
  1024. }
  1025. if(Number(ds_grid_testlist.getColumn(i, "rsltseq")) > 1){
  1026. ds_grid_testlist.setColumn(i, "rstImage", "..\\..\\..\\IMAGES\\lis\\icnMULTIRST.png");
  1027. }
  1028. var vJudg = ds_grid_testlist.getColumn(i, "judgmark");
  1029. if(vJudg == "H"){
  1030. ds_grid_testlist.setColumn(i, "background-color", "#f7a08b");
  1031. }
  1032. else if(vJudg == "L"){
  1033. ds_grid_testlist.setColumn(i, "background-color", "#b9e5fb");
  1034. }
  1035. else{
  1036. ds_grid_testlist.setColumn(i, "background-color", "#ffffff");
  1037. }
  1038. //panic
  1039. var vPanic = ds_grid_testlist.getColumn(i, "panicmark");
  1040. if(vPanic == "P"){
  1041. ds_grid_testlist.setColumn(i, "background-color", "#7BE6B7");
  1042. }
  1043. else{
  1044. ds_grid_testlist.setColumn(i, "background-color", "#ffffff");
  1045. }
  1046. //delta
  1047. var vDelta = ds_grid_testlist.getColumn(i, "deltamark");
  1048. if(vDelta == "D"){
  1049. ds_grid_testlist.setColumn(i, "background-color", "#dec6a4");
  1050. }
  1051. else{
  1052. ds_grid_testlist.setColumn(i, "background-color", "#ffffff");
  1053. }
  1054. //critical
  1055. var vCritical = ds_grid_testlist.getColumn(i, "criticalmark");
  1056. if(vCritical == "C"){
  1057. ds_grid_testlist.setColumn(i, "background-color", "#ffe79d");
  1058. }
  1059. else{
  1060. ds_grid_testlist.setColumn(i, "background-color", "#ffffff");
  1061. }
  1062. //alert
  1063. var vAlert = ds_grid_testlist.getColumn(i, "alertmark");
  1064. if(vAlert == "A"){
  1065. ds_grid_testlist.setColumn(i, "background-color", "#fec34d");
  1066. }
  1067. else{
  1068. ds_grid_testlist.setColumn(i, "background-color", "#ffffff");
  1069. }
  1070. if(bufpositiveYN || reptpositiveYN){
  1071. ds_grid_testlist.setColumn(i, "color", "#EE0000"); //3,4만 빨간색
  1072. }
  1073. ds_grid_testlist.setRowType(i, Dataset.ROWTYPE_NORMAL);
  1074. } //end for
  1075. ds_grid_testlist.updatecontrol = false;;
  1076. //BIND(color)
  1077. var sExprColor = "EXPR(color)";
  1078. for(var i=0; i<group2.grd_TestInfoCnts.getCellCount("Body"); i++){
  1079. if(i == 3 || i == 4 ){
  1080. // sExprColor = ds_grid_testlist.getColumn(iRow,"color");
  1081. //trace('1 '+iRow+' / '+sExprColor);
  1082. group2.grd_TestInfoCnts.setCellProperty("Body", i, "color", sExprColor);
  1083. group2.grd_TestInfoCnts.setCellProperty("Body", i, "color2", sExprColor);
  1084. group2.grd_TestInfoCnts.setCellProperty("Body", i, "selectcolor", sExprColor);
  1085. }
  1086. }
  1087. lf_UpPatinfo();
  1088. var bNumber = true ;
  1089. var vPatAge = ds_grid_testlist.getColumn(0, "patage");
  1090. if (!vPatAge.isNumber() && !vPatAge.isFloat()) {
  1091. bNumber = false ;
  1092. }
  1093. if(bNumber){
  1094. if(eval(vPatAge) > 0){
  1095. group2.chkChlidBtype.value = 0;
  1096. }else{
  1097. group2.chkChlidBtype.value = 1;
  1098. }
  1099. }
  1100. var findRow = 0;
  1101. if(ds_grid_testlist.rowcount > 0){
  1102. if(ds_grid_testlist.getColumn(0,"readonly") == "1" || ds_grid_testlist.getColumn(0,"readonly") == "true"){
  1103. findRow = ds_grid_testlist.findRowExpr("readonly == '' || readonly == '0' || readonly == 'false'");
  1104. }
  1105. ds_grid_testlist.rowposition = findRow;
  1106. group2.grd_TestInfoCnts.setCellPos(group2.grd_TestInfoCnts.getBindCellIndex("Body","bufinptrslt"));
  1107. group2.grd_TestInfoCnts.setFocus();
  1108. }
  1109. /* if(abocnt == 0){*/
  1110. // grp_aboinfo.visible = false;
  1111. //caption00.visible = false;
  1112. group2.grd_TestInfoCnts.position.height = "440";
  1113. // }else{
  1114. // grp_aboinfo.visible = true;
  1115. // caption00.visible = true;
  1116. // group2.grd_TestInfoCnts.position.height = "134";
  1117. // }
  1118. }
  1119. }
  1120. //소견 초기화
  1121. function lf_InitializeSoGyeon(){
  1122. var cntTsect = ds_init_testconttsectcd.rowcount;
  1123. var cntSG = ds_temp_testcont.rowcount;
  1124. var curTsect = "";
  1125. var strSG = "";
  1126. var plusIdx = 1;
  1127. var currow = 0;
  1128. createColumn(ds_temp_testcont, "iud");
  1129. for(var i=1; i<cntTsect; i++){
  1130. curTsect = ds_init_testconttsectcd.getColumn(i, "cd");
  1131. if(utlf_isNull(ds_temp_testcont.getColumn(ds_temp_testcont.findRow("execdeptcd", curTsect), "execdeptcd"))){
  1132. currow = ds_temp_testcont.addRow();
  1133. ds_temp_testcont.setColumn(currow, "execdeptcd", curTsect);
  1134. ds_temp_testcont.setColumn(currow, "iud", "n");
  1135. plusIdx++;
  1136. }
  1137. }
  1138. if(cntTsect == 2){
  1139. group2.cmb_sect.value = ds_init_testconttsectcd.getColumn(1, "cd");
  1140. group2.cmb_cmt.index = 0;
  1141. }else{
  1142. group2.cmb_sect.index = 0;
  1143. group2.cmb_cmt.index = 0;
  1144. }
  1145. lf_SelectTestContTsect();
  1146. p_isedit = false;
  1147. }
  1148. //선택 시행부서 소견
  1149. function lf_SelectTestContTsect(){
  1150. var selTsectcd = String(group2.cmb_sect.value).getTrim();
  1151. var vSectcd = String(ds_cond_patinfo.getColumn(0, "sectcd")).getTrim();
  1152. var vTsectcd = String(ds_cond_patinfo.getColumn(0, "tsectcd")).getTrim();
  1153. var cntSoGyeon = ds_temp_testcont.rowcount;
  1154. var strSG = "";
  1155. if(selTsectcd == "00"){
  1156. for(var i=0; i<cntSoGyeon; i++){
  1157. if(ds_temp_testcont.getColumn(i, "iud") != "n"){
  1158. strSG += "【" + ds_temp_testcont.getColumn(i, "execdeptcd") + "】";
  1159. strSg += lf_nvl(ds_temp_testcont.getColumn(i, "testcont"),"") + "\n";
  1160. }
  1161. }
  1162. }else{
  1163. for(var i=0; i<cntSoGyeon; i++){
  1164. if(ds_temp_testcont.getColumn(i, "execdeptcd") == vTsectcd){
  1165. strSG += lf_nvl(ds_temp_testcont.getColumn(i, "testcont"),"") + "\n";
  1166. }
  1167. }
  1168. }
  1169. // group2.textarea2.value = strSG;
  1170. }
  1171. function lf_UpPatinfo(){
  1172. var sInDsName = dsf_createDsRow("ds_temp_search"
  1173. , [{col: "pid", val: ds_cond_patinfo.getColumn(0, "pid")}]);
  1174. var oParam = {};
  1175. oParam.id = "TRLZZ00109";
  1176. oParam.service = "diagtestapplib.LisCommon";
  1177. oParam.method = "reqGetPidTopinfo";
  1178. oParam.inds = "cond="+sInDsName;
  1179. oParam.outds = "ds_temp_prcpinfo=getPidTopinfo";
  1180. oParam.async = false;
  1181. oParam.callback = "cbf_TRLZZ00109";
  1182. tranf_submit(oParam);
  1183. }
  1184. //결과예문 결과값과 같은지 체크
  1185. function lf_chkResultCodeEqual(){
  1186. var chkEqualCnt = 0;
  1187. var rowType = "";
  1188. var vInptRslt = "";
  1189. var nm = "";
  1190. var tclskind = "";
  1191. for(var row=0; row<ds_grid_testlist.rowcount; row++){
  1192. rowType = ds_grid_testlist.getRowType(row);
  1193. tclskind = ds_grid_testlist.getColumn(row, "tclskind");
  1194. if(rowType == "4" && tclskind!= "1"){
  1195. //vInptRslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  1196. vInptRslt = ds_grid_testlist.getColumn(row, "reptrslt");
  1197. ds_init_lb0109.filter("etc01 == '"+ds_grid_testlist.getColumn(row, "testcd")+"'");
  1198. chkEqualCnt = 0;
  1199. if( !utlf_isNull(vInptRslt) ) {
  1200. for(var i=0; i<ds_init_lb0109.rowcount; i++){
  1201. nm = ds_init_lb0109.getColumn(i, "nm");
  1202. if(vInptRslt.toUpperCase() == nm.toUpperCase() || vInptRslt.toLowerCase() == nm.toLowerCase()){
  1203. chkEqualCnt++;
  1204. }
  1205. }
  1206. if(chkEqualCnt==0){
  1207. sysf_messageBox("["+ds_grid_testlist.getColumn(row, "tclsscrnnm")+"]결과 예문에 없는 결과입니다.\n","I","");
  1208. //return;
  1209. var mr = sysf_messageBox("계속 진행 ","S001","");
  1210. //예
  1211. if(mr == "6") {
  1212. return false;
  1213. //아니요 / 취소
  1214. }else if(mr == "7" || mr == "2"){
  1215. return true;
  1216. }
  1217. }
  1218. }
  1219. }
  1220. }
  1221. }
  1222. // 결과저장 - 1차저장
  1223. function lf_insRsltSave(){
  1224. if(lf_Validation("1")){
  1225. var bRow = ds_grd_patlist.rowposition;
  1226. var sInDsName = dsf_createDsRow("ds_temp_refflag"
  1227. , [{col: "bcno", val: ds_cond_patinfo.getColumn(0, "bcno")}
  1228. , {col: "userid", val: ds_temp_acceptnm.getColumn(0,"userid")}
  1229. , {col: "isedit" , val: (p_isedit ? "true" : "false")}
  1230. , {col: "rsltstat", val: "1"}
  1231. , {col: "testlrgkind", val: "B"}]);
  1232. ds_temp_testcont.updatecontrol = false;
  1233. for(var i=0; i<ds_temp_testcont.rowcount; i++){
  1234. if(!utlf_isNull(ds_temp_testcont.getColumn(i, "iud"))){
  1235. ds_temp_testcont.setRowType(i, Dataset.ROWTYPE_UPDATE);
  1236. }
  1237. }
  1238. ds_temp_testcont.updatecontrol = true;
  1239. var oParam = {};
  1240. oParam.id = "TXLLR80101";
  1241. oParam.service = "rsltmngtapp.RsltMngt";
  1242. oParam.method = "reqSetResultSave";
  1243. oParam.inds = "TestData=ds_grid_testlist:U "
  1244. +"RefFalg=ds_temp_refflag "
  1245. +"SpcCmtInfo=ds_temp_testcont:U "
  1246. +"TestCmtInfo=ds_grid_testcmts:U";
  1247. oParam.async = false;
  1248. oParam.callback = "cbf_TXLLR80101";
  1249. tranf_submit(oParam);
  1250. if(!utlf_isNull(group3.iptSearch.value)) {
  1251. lf_OnclickBtnRef("Q");
  1252. lf_PatListClick(bRow);
  1253. group3.iptSearch.setFocus();
  1254. group3.iptSearch.setSelect(0,group3.iptSearch.getLength());
  1255. }else{
  1256. lf_OnclickBtnRef();
  1257. var bcnoRow = ds_grd_patlist.findRow("bcno", ds_temp_refflag.getColumn(0, "bcno"));
  1258. if(bcnoRow > -1){
  1259. ds_grd_patlist.rowposition = bcnoRow;
  1260. lf_PatListClick(bcnoRow);
  1261. }
  1262. }
  1263. }
  1264. }
  1265. //중간보고 - 2차저장
  1266. function lf_SetMdlRept(){
  1267. if(lf_Validation("2")){
  1268. var bRow = ds_grd_patlist.rowposition;
  1269. var sInDsName = dsf_createDsRow("ds_temp_refflag"
  1270. , [{col: "bcno", val: ds_cond_patinfo.getColumn(0, "bcno")}
  1271. , {col: "userid", val: ds_temp_acceptnm.getColumn(0,"userid")}
  1272. , {col: "isedit" , val: (p_isedit ? "true" : "false")}
  1273. , {col: "rsltstat", val: "2"}
  1274. , {col: "testlrgkind", val: "B"}]);
  1275. ds_temp_testcont.updatecontrol = false;
  1276. for(var i=0; i<ds_temp_testcont.rowcount; i++){
  1277. if(!utlf_isNull(ds_temp_testcont.getColumn(i, "iud"))){
  1278. ds_temp_testcont.setRowType(i, Dataset.ROWTYPE_UPDATE);
  1279. }
  1280. }
  1281. ds_temp_testcont.updatecontrol = true;
  1282. var oParam = {};
  1283. oParam.id = "TXLLR80101";
  1284. oParam.service = "rsltmngtapp.RsltMngt";
  1285. oParam.method = "reqSetResultSave";
  1286. oParam.inds = "TestData=ds_grid_testlist:U "
  1287. +"RefFalg=ds_temp_refflag "
  1288. +"SpcCmtInfo=ds_temp_testcont:U "
  1289. +"TestCmtInfo=ds_grid_testcmts:U";
  1290. oParam.async = false;
  1291. oParam.callback = "cbf_TXLLR80101";
  1292. tranf_submit(oParam);
  1293. if(!utlf_isNull(group3.iptSearch.value)){
  1294. lf_OnclickBtnRef("Q");
  1295. lf_PatListClick(bRow);
  1296. group3.iptSearch.setFocus();
  1297. group3.iptSearch.setSelect(0,group3.iptSearch.getLength());
  1298. }else{
  1299. lf_OnclickBtnRef();
  1300. var bcnoRow = ds_grd_patlist.findRow("bcno", ds_temp_refflag.getColumn(0, "bcno"));
  1301. if(bcnoRow > -1){
  1302. ds_grd_patlist.rowposition = bcnoRow;
  1303. lf_PatListClick(bcnoRow);
  1304. }
  1305. }
  1306. }
  1307. }
  1308. //최종보고
  1309. function lf_SetLstRept(){
  1310. // 이재오 추가 8월 28일
  1311. ds_hidden_DJGGParrm.clearData(); //수정대장,다중결과DS
  1312. ds_hidden_DJGGParrm.addRow();
  1313. if(lf_Validation("4")){
  1314. //trace("jolee ");
  1315. //return;
  1316. var updtRslt = lf_UpdtRslt();
  1317. trace("updtRslt :"+updtRslt);
  1318. if (updtRslt != 0) {
  1319. return;
  1320. }
  1321. //if(lf_UpdtRslt() != 0) return;
  1322. var Brow = ds_grd_patlist.rowposition;
  1323. //data2
  1324. dsf_createDsRow("ds_temp_refflag"
  1325. , [{col: "bcno" , val: ds_cond_patinfo.getColumn(0, "bcno")}
  1326. , {col: "userid", val: ds_temp_acceptnm.getColumn(0,"userid")}
  1327. , {col: "isedit" , val: (p_isedit ? "true" : "false")}
  1328. , {col: "rsltstat" , val: "4"}
  1329. , {col: "testlrgkind" , val: "B"}]);
  1330. //data3
  1331. ds_temp_testcont.updatecontrol = false;
  1332. for(var i=0; i<ds_temp_testcont.rowcount; i++){
  1333. if(!utlf_isNull(ds_temp_testcont.getColumn(i, "iud"))){
  1334. ds_temp_testcont.setRowType(i, Dataset.ROWTYPE_UPDATE);
  1335. }
  1336. }
  1337. ds_temp_testcont.updatecontrol = true;
  1338. /*
  1339. //data4
  1340. //ds_grid_testcmts
  1341. oParam.id = "TXLLR80101";
  1342. oParam.service = "rsltmngtapp.RsltMngt";
  1343. oParam.method = "reqSetResultSave";
  1344. oParam.inds = "TestData=uploadDS RefFalg=ds_temp_search SpcCmtInfo=ds_vSndSG:A TestCmtInfo=ds_grid_grd_TestCmts:U"
  1345. */
  1346. var oParam = {};
  1347. oParam.id = "TXLLR80101";
  1348. oParam.service = "rsltmngtapp.RsltMngt";
  1349. oParam.method = "reqSetResultSave";
  1350. oParam.inds = "TestData=ds_grid_testlist:U RefFalg=ds_temp_refflag SpcCmtInfo=ds_temp_testcont:U TestCmtInfo=ds_grid_testcmts:U";
  1351. oParam.async = false;
  1352. oParam.callback = "cbf_TXLLR80101";
  1353. tranf_submit(oParam);
  1354. if(!utlf_isNull(group3.iptSearch.value) ){
  1355. lf_OnclickBtnRef("Q");
  1356. lf_PatListClick(Brow);
  1357. group3.iptSearch.setFocus();
  1358. group3.iptSearch.setSelect(0,group3.iptSearch.getLength());
  1359. }else{
  1360. lf_OnclickBtnRef();
  1361. var bcnoRow = ds_grd_patlist.findRow("bcno", ds_temp_refflag.getColumn(0, "bcno"));
  1362. if(bcnoRow > -1){
  1363. ds_grd_patlist.rowposition = bcnoRow;
  1364. lf_PatListClick(bcnoRow);
  1365. }
  1366. }
  1367. }
  1368. }
  1369. //재검
  1370. function lf_InsJeaGeom(){
  1371. if(lf_Validation("10")){
  1372. if(lf_UpdtRslt() != 0) return;
  1373. var bRow = ds_grd_patlist.rowposition;
  1374. //data1
  1375. //ds_grid_testlist
  1376. //data2
  1377. dsf_createDsRow("ds_temp_refflag"
  1378. , [{col: "bcno" , val: ds_cond_patinfo.getColumn(0, "bcno")}
  1379. , {col: "rsltstat" , val: "10"}
  1380. , {col: "testlrgkind" , val: "B"}]);
  1381. //data3
  1382. ds_temp_testcont.updatecontrol = false;
  1383. for(var i=0; i<ds_temp_testcont.rowcount; i++){
  1384. if(!utlf_isNull(ds_temp_testcont.getColumn(i, "iud"))){
  1385. ds_temp_testcont.setRowType(i, Dataset.ROWTYPE_UPDATE);
  1386. }
  1387. }
  1388. ds_temp_testcont.updatecontrol = true;
  1389. //data4
  1390. //ds_grid_testcmts
  1391. var oParam = {};
  1392. oParam.id = "TXLLR80101";
  1393. oParam.service = "rsltmngtapp.RsltMngt";
  1394. oParam.method = "reqSetResultSave";
  1395. oParam.inds = "TestData=ds_grid_testlist:U RefFalg=ds_temp_refflag SpcCmtInfo=ds_temp_testcont:U TestCmtInfo=ds_grid_testcmts:U";
  1396. oParam.async = false;
  1397. oParam.callback = "cbf_TXLLR80101";
  1398. tranf_submit(oParam);
  1399. if(!utlf_isNull(group3.iptSearch.value) ){
  1400. lf_OnclickBtnRef("Q");
  1401. lf_PatListClick(bRow);
  1402. }else{
  1403. lf_OnclickBtnRef();
  1404. var bcnoRow = ds_grd_patlist.findRow("bcno", ds_temp_refflag.getColumn(0, "bcno"));
  1405. if(bcnoRow > -1){
  1406. ds_grd_patlist.rowposition = bcnoRow;
  1407. lf_PatListClick(bcnoRow);
  1408. }
  1409. }
  1410. }
  1411. }
  1412. //특이결과등록
  1413. function lf_SpcfRsltSave(){
  1414. var objArg = new Object();
  1415. objArg.refparam_bcno = ds_cond_patinfo.getColumn(0, "bcno");
  1416. objArg.pRdt = ds_cond_patinfo.getColumn(0, "rsltrgstdt");
  1417. objArg.pMdt = ds_cond_patinfo.getColumn(0, "mdlreptdt");
  1418. objArg.pLdt = ds_cond_patinfo.getColumn(0, "lastreptdt");
  1419. if(utlf_isNull(objArg.pRdt) && utlf_isNull(objArg.pMdt) && utlf_isNull(objArg.pLdt)){
  1420. sysf_messageBox("결과등록이 되지 않은 검체입니다.","I","");
  1421. return;
  1422. }
  1423. if(!utlf_isNull(objArg.refparam_bcno)){
  1424. frmf_modal("SMLLR90200", "SMLLR90200", objArg);
  1425. }
  1426. }
  1427. //부적합검체등록
  1428. function lf_inSpecSave(){
  1429. var objArg = new Object();
  1430. ds_getParam.clearData();
  1431. ds_getParam.addRow();
  1432. if(!utlf_isNull(ds_cond_patinfo.getColumn(0, "bcno"))){
  1433. //objArg.bcno = ds_cond_patinfo.getColumn(0, "bcno");
  1434. ds_getParam.setColumn(0,"bcno",ds_cond_patinfo.getColumn(0, "bcno"));
  1435. }else{
  1436. ds_getParam.setColumn(0,"bcno","");
  1437. }
  1438. objArg.ds_getParam = ds_getParam;
  1439. frmf_modal("SPLLJ90100", "SPLLJ90100", objArg, null, null, null, null, null, null, null, null, null, "M");
  1440. }
  1441. //결과저장시 유효성 체크
  1442. function lf_Validation(pRsltstat){
  1443. //검색구분 등록번호 선택후 엔터 쳤을때
  1444. if(onclickbtnref == "Q" && group3.combo1.value == "2"){
  1445. if(ds_grd_patlist.rowposition < 0){
  1446. sysf_messageBox("등록번호로 조회했을 경우 \n\n환자목록을 선택하여 결과를 입력하셔야 합니다.","E","");
  1447. return;
  1448. }
  1449. }
  1450. var nUsernm = ds_temp_acceptnm.getColumn(0, "usernm");
  1451. var nText = group2.ipt_testpsn.value;
  1452. if((utlf_isNull(nUsernm)) || (utlf_isNull(nText))){
  1453. sysf_messageBox("검사자를","C001","");
  1454. group2.ipt_testpsn.setFocus();
  1455. return;
  1456. }
  1457. var rept = 6;
  1458. var flag = 0;
  1459. var rstnm1 = "1";
  1460. var rstnm2 = "2";
  1461. var rstnm3 = "3";
  1462. var rstnm4 = "4";
  1463. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  1464. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");
  1465. if(ds_grd_patlist.getColumn(ds_grd_patlist.rowposition,"rsltstat") == "-"){
  1466. for(i = 1 ; i < ds_grid_testlist.rowcount; i++) {
  1467. if(ds_grid_testlist.getColumn(i,"selchk") == "true"){
  1468. if(ds_grid_testlist.getColumn(i,"testcd") == etc01_100
  1469. && ds_grid_testlist.getColumn(i,"tclscd") != "LBR002"){
  1470. rstnm1 = ds_temp_acceptnm(0,"usernm");
  1471. rstnm2 = ds_grid_testlist.getColumn(i+1,"rstnm");
  1472. }
  1473. if(ds_grid_testlist.getColumn(i,"testcd") == etc01_100){
  1474. rstnm3 = ds_temp_acceptnm(0,"usernm");
  1475. rstnm4 = ds_grid_testlist.getColumn(i-1,"rstnm");
  1476. }
  1477. }
  1478. }
  1479. if(rstnm1 == rstnm2 || rstnm3 == rstnm4 || rstnm1 == rstnm3){
  1480. //LJO 2011 .5.11일 막다
  1481. //rept = messageBox("Serum Type 검사자와 Cell Type 검사자가 동일 합니다.", "Q002", "");
  1482. }
  1483. }
  1484. else{
  1485. for(i = 1 ; i < ds_grid_testlist.rowcount; i++) {
  1486. if(ds_grid_testlist.getColumn(i,"selchk") == "true"){
  1487. if(ds_grid_testlist.getColumn(i,"testcd") == etc01_100
  1488. && ds_grid_testlist.getColumn(i,"tclscd") != "LBR002"){
  1489. if(ds_grid_testlist.getColumn(i+1,"rstnm") == ds_temp_acceptnm.getColumn(0,"usernm")){
  1490. //LJO 2011 .5.11일 막다
  1491. //rept = messageBox("Serum Type 검사자와 Cell Type 검사자가 동일 합니다.", "Q002", "");
  1492. flag = 1;
  1493. }
  1494. }
  1495. if(flag != 1){
  1496. if(ds_grid_testlist.getColumn(i,"testcd") == etc01_101) {
  1497. if(ds_grid_testlist.getColumn(i-1,"rstnm") == ds_temp_acceptnm.getColumn(0,"usernm")){
  1498. //LJO 2011 .5.11일 막다
  1499. //rept = messageBox("Serum Type 검사자와 Cell Type 검사자가 동일 합니다.", "Q002", "");
  1500. }
  1501. }
  1502. }
  1503. }
  1504. }
  1505. }
  1506. if(rept == 6){
  1507. }
  1508. else{
  1509. return;
  1510. }
  1511. var isChk = false;
  1512. //trace("lee1");
  1513. if(p_isedit){ //소견 수정 되었으면(전역변수)
  1514. var vRetval = lf_COMLIS_ResultValidation(ds_grid_testlist, pRsltstat, false);
  1515. if(vRetval != "1"){
  1516. isChk = true;
  1517. }
  1518. }else{
  1519. trace("lee 2");
  1520. var vRetval = lf_COMLIS_ResultValidation(ds_grid_testlist, pRsltstat, false);
  1521. if ( vRetval == "0") {
  1522. isChk = true;
  1523. }
  1524. trace(vRetval);
  1525. }
  1526. //trace("lee 끝");
  1527. return isChk;
  1528. }
  1529. //수정결과등록 개발중
  1530. function lf_UpdtRslt(){
  1531. var vPid = ds_cond_patinfo.getColumn(0, "pid");
  1532. ds_hidden_DJGGParrm.setColumn(0, "userid", ds_temp_acceptnm.getColumn(0, "userid"));
  1533. ds_hidden_DJGGParrm.setColumn(0, "bcno" , ds_cond_patinfo.getColumn(0, "bcno"));
  1534. //if(!utlf_isNull(vPid) && utlf_transNullToEmpty(ds_hidden_DJGGParrm.getColumn(0,"uprsltYN")) == "Y"){
  1535. if(vPid != "" && utlf_transNullToEmpty(ds_hidden_DJGGParrm.getColumn(0,"uprsltYN")) == "Y"){
  1536. var objArg = new Object();
  1537. ds_hidden_DJGGParrm.setColumn(0,"rsltsaveYN","N");
  1538. objArg.pDJGGParm = ds_hidden_DJGGParrm;
  1539. frmf_modal("SMLLR90600", "SMLLR90600", objArg, null, null, null, null, null, null, null, null, null, "M")
  1540. if (ds_hidden_DJGGParrm.getColumn(0,"rsltsaveYN") == "Y") {
  1541. return 0;
  1542. }else{
  1543. return 1;
  1544. }
  1545. }else{
  1546. return 0;
  1547. }
  1548. // if("Y" == frmf_modal("SMLLR90600","SMLLR90600",objArg)){
  1549. // return 0;
  1550. // }else{
  1551. // return 1;
  1552. // }
  1553. }
  1554. function lf_updtRslt_backup(){
  1555. var vPID = utlf_transNullToEmpty(ds_grid_grd_TestInfoCnts.getColumn(0,"pid"));
  1556. var vBcno = utlf_transNullToEmpty(ds_grid_grd_TestInfoCnts.getColumn(0,"bcno"));
  1557. ds_hidden_DJGGParrm.setColumn(0, "bcno", vBcno);
  1558. ds_hidden_DJGGParrm.setColumn(0, "userid", group2.ipt_testpsn.value);
  1559. ds_getSpcInfo.setColumn(0,"bcno",vBcno);
  1560. //ds_getSpcInfo.setColumn(0,"userid",utlf_transNullToEmpty(group2.ipt_testpsn.value)); //수정자ID 직접입력을 원하셔서 막음..
  1561. if(vPID != "" && utlf_transNullToEmpty(ds_hidden_DJGGParrm.getColumn(0,"uprsltYN")) == "Y"){
  1562. var objArg = new Object();
  1563. ds_hidden_DJGGParrm.setColumn(0,"rsltsaveYN","N");
  1564. objArg.pDJGGParm = ds_hidden_DJGGParrm;
  1565. frmf_modal("SMLLR90600", "SMLLR90600", objArg, null, null, null, null, null, null, null, null, null, "M")
  1566. if (ds_hidden_DJGGParrm.getColumn(0,"rsltsaveYN") == "Y") {
  1567. return 0;
  1568. }else{
  1569. return 1;
  1570. }
  1571. }else{
  1572. return 0;
  1573. }
  1574. }
  1575. function lf_SetClear(){
  1576. ds_grid_testlist.clearData();
  1577. ds_grid_testcmts.clearData();
  1578. ds_temp_abnormallist.clearData();
  1579. // 이재오 추가 2017 8월 29일
  1580. ds_hidden_DJGGParrm.clearData(); //수정대장,다중결과DS
  1581. ds_hidden_DJGGParrm.addRow();
  1582. if(!utlf_isNull(this.objects.get_item("ds_hidden_DJGGParm"))){
  1583. ds_hidden_DJGGParm.clearData();
  1584. }
  1585. ds_cond_patinfo.clearData();
  1586. ds_temp_testcont.clearData();
  1587. ds_init_testconttsectcd.clearData();
  1588. gv_preautocmt = "";
  1589. gv_preautocmtarr = new Array();
  1590. p_isedit = false;
  1591. lf_CMTPCD_ChangeNodeset();
  1592. group2.grd_TestInfoCnts.setCellProperty("head", group2.grd_TestInfoCnts.getBindCellIndex("body", "selchk"), "text", 0);
  1593. }
  1594. function lf_setClear2(){
  1595. ds_grid_testlist.clearData();
  1596. ds_grid_testcmts.clearData();
  1597. ds_temp_abnormallist.clearData();
  1598. // 이재오 추가 2017 8월 29일
  1599. ds_hidden_DJGGParrm.clearData(); //수정대장,다중결과DS
  1600. ds_hidden_DJGGParrm.addRow();
  1601. if(!utlf_isNull(this.objects.get_item("ds_hidden_DJGGParm"))){
  1602. ds_hidden_DJGGParm.clearData();
  1603. }
  1604. ds_cond_patinfo.clearData();
  1605. ds_temp_testcont.clearData();
  1606. ds_init_testconttsectcd.clearData();
  1607. gv_preautocmt = "";
  1608. gv_preautocmtarr = new Array();
  1609. p_isedit = false;
  1610. lf_CMTPCD_ChangeNodeset();
  1611. group2.grd_TestInfoCnts.setCellProperty("head", group2.grd_TestInfoCnts.getBindCellIndex("body", "selchk"), "text", 0);
  1612. gv_isedit = "";
  1613. }
  1614. function lf_CMTPCD_ChangeNodeset(pSectcd, pTsectcd){
  1615. ds_init_testconttsectcd.clearData();
  1616. if(utlf_isNull(pSectcd)){
  1617. ds_init_lb0210.filter("cd == '00'");
  1618. }else{
  1619. ds_init_lb0210.filter("cd == '00' || (etc01 == '"+pSectcd+"' && etc02 == '"+pTsectcd+"')");
  1620. }
  1621. group2.cmb_cmt.index = 0;
  1622. var vCmtTsect = String(ds_cond_patinfo.getColumn(0, "tsectcdlist")).split("▦");
  1623. if(ds_init_testconttsectcd.rowcount < 1){
  1624. ds_init_testconttsectcd.addRow();
  1625. }
  1626. ds_init_testconttsectcd.setColumn(0, "cd", "00");
  1627. ds_init_testconttsectcd.setColumn(0, "nm", "- 시행부서선택 -");
  1628. if(vCmtTsect.length > 0){
  1629. var currow = 0;
  1630. var nm = "";
  1631. for(var i = 0; i<vCmtTsect.length; i++){
  1632. if(!utlf_isNull(vCmtTsect[i])){
  1633. currow = ds_init_testconttsectcd.addRow();
  1634. nm = ds_init_lb0106.getColumn(ds_init_lb0106.findRow("cd", vCmtTsect[i]), "nm");
  1635. ds_init_testconttsectcd.setColumn(currow, "cd", vCmtTsect[i]);
  1636. ds_init_testconttsectcd.setColumn(currow, "nm", nm);
  1637. }
  1638. }
  1639. }else{
  1640. group2.cmb_sect.index = 0;
  1641. }
  1642. }
  1643. function lf_BlodWeakD(){
  1644. var row = ds_grid_testlist.rowposition;
  1645. var returnValue = "Y";
  1646. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  1647. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  1648. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");
  1649. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  1650. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");
  1651. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");
  1652. //신생아혈액 추가
  1653. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd"); //Cell Type(신생아)
  1654. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd"); //Rh(신생아)
  1655. //Rh 검사코드 row 찾기
  1656. var findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  1657. //신생아 혈액 판단 추가
  1658. //if(findRowNum < 1) findRowNum = ds_grid_testlist.findRow("testcd", etc01_202); //Rh(신생아)
  1659. // if(findRowNum < 1){
  1660. // findRowNum = ds_grid_testlist.findRow("testcd", etc01_112);
  1661. // }
  1662. if(testcd == etc01_100 || testcd == etc01_103 ){
  1663. var bufinptrslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  1664. ds_grid_testlist.setColumn(row, "bufinptrslt", String(bufinptrslt).replace("+","")+" Weak D");
  1665. //이전결과 비교
  1666. returnValue = lf_CompareOldData(row);
  1667. if(returnValue == "N") return;
  1668. lf_BlodTypeIns();
  1669. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  1670. ds_grid_testlist.rowposition = findRowNum;
  1671. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "Weak D");
  1672. lf_BlodTypeIns();
  1673. }
  1674. ds_grid_testlist.rowposition = row;
  1675. lf_TestInfoCntsClick(row, 3);
  1676. }
  1677. //rh 버튼 기능 새로 구현
  1678. //기존에는 그리드에서 cell typing 셀 클릭후 버튼 체크해야 결과 들어갔음.
  1679. //변경후 : 그리드에서rh 셀 클릭후 버튼 체크해야 결과 들어가도록 수정.
  1680. function lf_BlodRh(rhtype){
  1681. var returnValue = "Y";
  1682. var rhValue = rhtype;
  1683. var row = ds_grid_testlist.rowposition;
  1684. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  1685. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");//Rh(D)
  1686. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");//Rh(D),donor
  1687. //신생아혈액 추가
  1688. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");//Rh(D)(신생아)
  1689. //rh 코드일때
  1690. if(testcd == etc01_102 || testcd == etc01_112 || testcd == etc01_202 ){
  1691. ds_grid_testlist.setColumn(row, "bufinptrslt", rhtype);
  1692. //이전결과 비교
  1693. returnValue = lf_CompareOldData(row);
  1694. if(returnValue == "N") return;
  1695. lf_BlodTypeIns();
  1696. }
  1697. ds_grid_testlist.rowposition = row;
  1698. lf_TestInfoCntsClick(row, 3);
  1699. }
  1700. function lf_BlodNegative(){
  1701. var row = ds_grid_testlist.rowposition;
  1702. var returnValue = "Y";
  1703. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  1704. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  1705. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");
  1706. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  1707. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");
  1708. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");
  1709. //신생아혈액 추가
  1710. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd"); //Cell Type(신생아)
  1711. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd"); //Rh(신생아)
  1712. //Rh 검사코드 row 찾기
  1713. var findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  1714. // //신생아
  1715. // if(findRowNum < 1) findRowNum = ds_grid_testlist.findRow("testcd", etc01_202);
  1716. //
  1717. //
  1718. // if(findRowNum < 1){
  1719. // findRowNum = ds_grid_testlist.findRow("testcd", etc01_112);
  1720. // }
  1721. ds_grid_testlist.addColumn("color","string");
  1722. ds_grid_testlist.setColumn(row, "color", "#EE0000");
  1723. group2.grd_TestInfoCnts.updateToDataset();
  1724. if(testcd == etc01_100 || testcd == etc01_103 ){
  1725. var bufinptrslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  1726. ds_grid_testlist.setColumn(row, "bufinptrslt", String(bufinptrslt).replace("+","")+" Negative");
  1727. //이전결과 비교
  1728. returnValue = lf_CompareOldData(row);
  1729. if(returnValue == "N") return;
  1730. lf_BlodTypeIns();
  1731. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  1732. ds_grid_testlist.rowposition = findRowNum;
  1733. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "-");
  1734. lf_BlodTypeIns();
  1735. }
  1736. ds_grid_testlist.rowposition = row;
  1737. lf_TestInfoCntsClick(row, 3);
  1738. }
  1739. function lf_BlodTypeClick(blodtype){
  1740. var row = ds_grid_testlist.rowposition;
  1741. var returnValue = "Y";
  1742. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  1743. //Rh 검사코드 row 찾기
  1744. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  1745. //ANTO BODY 검사코드 row 찾기
  1746. var etc01_106 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "106"), "cd");
  1747. var etc01_011 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "011"), "cd");
  1748. var etc01_012 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "012"), "cd");
  1749. var etc01_222 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "222"), "cd");
  1750. var etc01_228 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "228"), "cd");
  1751. var etc01_229 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "229"), "cd");
  1752. var etc01_230 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "230"), "cd");
  1753. var etc01_231 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "231"), "cd");
  1754. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  1755. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");
  1756. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");
  1757. var etc01_104 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "104"), "cd");
  1758. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");
  1759. var etc01_111 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "111"), "cd");
  1760. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");
  1761. //신생아혈액추가
  1762. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");
  1763. var etc01_201 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "201"), "cd");
  1764. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");
  1765. //Rh 검사코드 row 찾기
  1766. var findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  1767. //ANTO BODY 검사코드 row 찾기
  1768. var findRowNumA = ds_grid_testlist.findRow("testcd", etc01_106);
  1769. //이재오 2012 09 19
  1770. //검사코드 row 찾기
  1771. var findRowNumB = ds_grid_testlist.findRow("testcd", etc01_011);
  1772. //이재오 2012 09 19
  1773. //검사코드 row 찾기
  1774. var findRowNumC = ds_grid_testlist.findRow("testcd", etc01_012);
  1775. var findRowNumD = ds_grid_testlist.findRow("testcd", etc01_222);
  1776. var findRowNumE = ds_grid_testlist.findRow("testcd", etc01_228);
  1777. var findRowNumF = ds_grid_testlist.findRow("testcd", etc01_229);
  1778. var findRowNumG = ds_grid_testlist.findRow("testcd", etc01_230);
  1779. var findRowNumH = ds_grid_testlist.findRow("testcd", etc01_231);
  1780. //SERUN 검사코드 row 찾기
  1781. var findRowNumI = ds_grid_testlist.findRow("testcd", etc01_101);
  1782. var findRowNumJ = ds_grid_testlist.findRow("testcd", etc01_104);
  1783. if(findRowNum < 1) findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  1784. if(findRowNumA < 1) findRowNumA = ds_grid_testlist.findRow("testcd", etc01_106);
  1785. if(findRowNumB < 1) findRowNumB = ds_grid_testlist.findRow("testcd", etc01_011);
  1786. if(findRowNumC < 1) findRowNumC = ds_grid_testlist.findRow("testcd", etc01_012);
  1787. if(findRowNumD < 1) findRowNumD = ds_grid_testlist.findRow("testcd", etc01_222);
  1788. if(findRowNumE < 1) findRowNumE = ds_grid_testlist.findRow("testcd", etc01_228);
  1789. if(findRowNumF < 1) findRowNumF = ds_grid_testlist.findRow("testcd", etc01_229);
  1790. if(findRowNumG < 1) findRowNumG = ds_grid_testlist.findRow("testcd", etc01_230);
  1791. if(findRowNumH < 1) findRowNumH = ds_grid_testlist.findRow("testcd", etc01_231);
  1792. if(findRowNumI < 1) findRowNumI = ds_grid_testlist.findRow("testcd", etc01_101);
  1793. if(findRowNumJ < 1) findRowNumJ = ds_grid_testlist.findRow("testcd", etc01_104);
  1794. ds_grid_testlist.addColumn("color","string");
  1795. ds_grid_testlist.setColumn(row, "color", "#000000");
  1796. group2.grd_TestInfoCnts.updateToDataset();
  1797. //Serum Type
  1798. if(testcd == etc01_101 || testcd == etc01_104 ){
  1799. if(blodtype == " "){
  1800. ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype);
  1801. //이전결과 비교
  1802. returnValue = lf_CompareOldData(row);
  1803. if(returnValue == "N") return;
  1804. lf_CompareCellAnti(2, row);
  1805. lf_BlodTypeIns();
  1806. //이재오 추가 2013 6.3 일
  1807. row = row + 1 ;
  1808. trace(row);
  1809. //model.setValue("/root/main/TestInfo/getTestInfoCnts["+row+"]/bufinptrslt" , blodtype);
  1810. ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype);
  1811. // 이전결과 비교
  1812. lf_BlodTypeIns();
  1813. //이재오 추가 2013 6.3 일
  1814. row = row + 1 ;
  1815. //model.setValue("/root/main/TestInfo/getTestInfoCnts["+row+"]/bufinptrslt" , blodtype);
  1816. ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype);
  1817. //이재오 추가 2013 6.3 일
  1818. //fBlodTypeIns();
  1819. lf_BlodTypeIns();
  1820. row = row - 2 ;
  1821. }
  1822. }
  1823. ds_grid_testlist.rowposition = row;
  1824. //Cell Type
  1825. if(testcd == etc01_100 || testcd == etc01_103 ){
  1826. //ksh 수정 - 부천병원 cell typing 에 RH 표시 제외 요청
  1827. ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype + "+");
  1828. //ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype);
  1829. //이전결과 비교
  1830. returnValue = lf_CompareOldData(row);
  1831. if(returnValue == "N") return;
  1832. lf_CompareCellAnti(1, row);
  1833. lf_BlodTypeIns();
  1834. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  1835. ds_grid_testlist.rowposition = findRowNum;
  1836. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "+");
  1837. lf_BlodTypeIns();
  1838. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  1839. //이재오 abo & rh 판정 추가 2012 09 19일 var rr = grd_TestInfoCnts.row+1;
  1840. if(findRowNumB > 0) {
  1841. ds_grid_testlist.rowposition = findRowNumB;
  1842. ds_grid_testlist.setColumn(findRowNumB, "bufinptrslt", blodtype + "+");
  1843. lf_BlodTypeIns();
  1844. }
  1845. if(findRowNumC > 0) {
  1846. ds_grid_testlist.rowposition = findRowNumC;
  1847. ds_grid_testlist.setColumn(findRowNumC, "bufinptrslt", blodtype + "+");
  1848. lf_BlodTypeIns();
  1849. }
  1850. // anti -a
  1851. if(findRowNumD > 0) {
  1852. ds_grid_testlist.rowposition = findRowNumD;
  1853. if ( blodtype == "A" ) {
  1854. ds_grid_testlist.setColumn(findRowNumD, "bufinptrslt", "4+");
  1855. }
  1856. if ( blodtype == "B" ) {
  1857. ds_grid_testlist.setColumn(findRowNumD, "bufinptrslt", "-");
  1858. }
  1859. if ( blodtype == "O" ) {
  1860. ds_grid_testlist.setColumn(findRowNumD, "bufinptrslt", "-");
  1861. }
  1862. if ( blodtype == "AB" ) {
  1863. ds_grid_testlist.setColumn(findRowNumD, "bufinptrslt", "4+");
  1864. }
  1865. lf_BlodTypeIns();
  1866. }
  1867. // anti -b
  1868. if(findRowNumE > 0) {
  1869. ds_grid_testlist.rowposition = findRowNumE;
  1870. if ( blodtype == "A" ) {
  1871. ds_grid_testlist.setColumn(findRowNumE, "bufinptrslt", "-");
  1872. }
  1873. if ( blodtype == "B" ) {
  1874. ds_grid_testlist.setColumn(findRowNumE, "bufinptrslt", "4+");
  1875. }
  1876. if ( blodtype == "O" ) {
  1877. ds_grid_testlist.setColumn(findRowNumE, "bufinptrslt", "-");
  1878. }
  1879. if ( blodtype == "AB" ) {
  1880. ds_grid_testlist.setColumn(findRowNumE, "bufinptrslt", "4+");
  1881. }
  1882. lf_BlodTypeIns();
  1883. }
  1884. // a cell
  1885. if(findRowNumF > 0) {
  1886. ds_grid_testlist.rowposition = findRowNumF;
  1887. if ( blodtype == "A" ) {
  1888. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "-");
  1889. }
  1890. if ( blodtype == "B" ) {
  1891. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "3+");
  1892. }
  1893. if ( blodtype == "O" ) {
  1894. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "3+");
  1895. }
  1896. if ( blodtype == "AB" ) {
  1897. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "-");
  1898. }
  1899. lf_BlodTypeIns();
  1900. }
  1901. // b cell
  1902. if(findRowNumG > 0) {
  1903. ds_grid_testlist.rowposition = findRowNumG;
  1904. if ( blodtype == "A" ) {
  1905. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "3+");
  1906. }
  1907. if ( blodtype == "B" ) {
  1908. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "-");
  1909. }
  1910. if ( blodtype == "O" ) {
  1911. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "3+");
  1912. }
  1913. if ( blodtype == "AB" ) {
  1914. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "-");
  1915. }
  1916. lf_BlodTypeIns();
  1917. }
  1918. // auto
  1919. if(findRowNumH > 0) {
  1920. ds_grid_testlist.rowposition = findRowNumH;
  1921. ds_grid_testlist.setColumn(findRowNumH, "bufinptrslt", "-");
  1922. lf_BlodTypeIns();
  1923. }
  1924. // SERUN TYPE INSERT
  1925. if(findRowNumI > 0) {
  1926. ds_grid_testlist.rowposition = findRowNumI;
  1927. ds_grid_testlist.setColumn(findRowNumI, "bufinptrslt", blodtype);
  1928. lf_BlodTypeIns();
  1929. }
  1930. if(findRowNumJ > 0) {
  1931. ds_grid_testlist.rowposition = findRowNumJ;
  1932. ds_grid_testlist.setColumn(findRowNumJ, "bufinptrslt", blodtype);
  1933. lf_BlodTypeIns();
  1934. }
  1935. if(findRowNumA > 0) {
  1936. ds_grid_testlist.rowposition = findRowNumA;
  1937. ds_grid_testlist.setColumn(findRowNumA, "bufinptrslt", "Negative");
  1938. lf_BlodTypeIns();
  1939. }
  1940. }
  1941. ds_grid_testlist.rowposition = row;
  1942. lf_TestInfoCntsClick(row, 3);
  1943. lf_aboRsltInfoSet("btn");
  1944. row = row -1;
  1945. }
  1946. function lf_Anticlick(Antitype){
  1947. var row = ds_grid_testlist.rowposition;
  1948. var returnValue = "Y";
  1949. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  1950. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  1951. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  1952. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");
  1953. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");
  1954. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");
  1955. //신생아혈액 추가
  1956. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");
  1957. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");
  1958. //Rh 검사코드 row 찾기
  1959. var findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  1960. // //신생아
  1961. // if(findRowNum < 1) findRowNum = ds_grid_testlist.findRow("testcd", etc01_202);
  1962. //
  1963. //
  1964. // if(findRowNum < 1){
  1965. // findRowNum = ds_grid_testlist.findRow("testcd", etc01_112);
  1966. // }
  1967. if(testcd == etc01_100 || testcd == etc01_103 ){
  1968. if(String(ds_grid_testlist.getColumn(row, "bufinptrslt")).indexOf("Anti") != -1){
  1969. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt")+ " " + Antitype);
  1970. returnValue = lf_CompareEtypeOldData(row, "Anti");
  1971. if(returnValue == "N"){
  1972. return;
  1973. }
  1974. lf_BlodTypeIns();
  1975. ds_grid_testlist.rowposition = findRowNum;
  1976. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "+");
  1977. lf_BlodTypeIns();
  1978. }else{
  1979. ds_grid_testlist.setColumn(row, "bufinptrslt", Antitype);
  1980. returnValue = lf_CompareOldData(row, "Anti");
  1981. if(returnValue == "N"){
  1982. return;
  1983. }
  1984. lf_BlodTypeIns();
  1985. ds_grid_testlist.rowposition = findRowNum;
  1986. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "+");
  1987. lf_BlodTypeIns();
  1988. }
  1989. }
  1990. ds_grid_testlist.rowposition = row;
  1991. lf_TestInfoCntsClick(row, 3);
  1992. }
  1993. function lf_puls(mark){
  1994. var row = ds_grid_testlist.rowposition;
  1995. var returnValue = "Y";
  1996. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt")+mark);
  1997. lf_BlodTypeIns();
  1998. ds_grid_testlist.rowposition = row;
  1999. if(String(ds_grid_testlist.getColumn(row, "bufinptrslt")).indexOf("tive") != -1) {
  2000. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt")+mark);
  2001. lf_BlodTypeIns();
  2002. }
  2003. ds_grid_testlist.rowposition = row;
  2004. if(String(ds_grid_testlist.getColumn(row, "bufinptrslt")).indexOf("tive") != -1){
  2005. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt")+mark);
  2006. returnValue = lf_CompareOldData(row);
  2007. if(returnValue == "N") return;
  2008. lf_BlodTypeIns();
  2009. }
  2010. ds_grid_testlist.rowposition = row;
  2011. lf_TestInfoCntsClick(row, 3);
  2012. }
  2013. function lf_mom(mom){
  2014. var row = ds_grid_testlist.rowposition;
  2015. var returnValue = "Y";
  2016. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt")+mom);
  2017. returnValue = lf_CompareOldData(row);
  2018. if(returnValue == "N"){
  2019. return;
  2020. }
  2021. lf_BlodTypeIns();
  2022. ds_grid_testlist.rowposition = row;
  2023. }
  2024. function lf_cellclick(celltype){
  2025. var row = ds_grid_testlist.rowposition;
  2026. var returnValue = "Y";
  2027. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  2028. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");
  2029. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  2030. var etc01_104 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "104"), "cd");
  2031. var findRowNum = ds_grid_testlist.findRow("testcd", etc01_102);
  2032. if(testcd == etc01_101 || testcd == etc01_104){
  2033. if(String(ds_grid_testlist.getColumn(row, "bufinptrslt")).indexOf("Cell") != -1){
  2034. ds_grid_testlist.setColumn(row, "bufinptrslt", ds_grid_testlist.getColumn(row, "bufinptrslt") + " " + celltype);
  2035. returnValue = lf_CompareEtypeOldData(row, "Cell");
  2036. if(returnValue == "N") return;
  2037. lf_BlodTypeIns();
  2038. ds_grid_testlist.rowposition = findRowNum;
  2039. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "+");
  2040. lf_BlodTypeIns();
  2041. }else{
  2042. ds_grid_testlist.setColumn(row, "bufinptrslt", celltype);
  2043. returnValue = lf_CompareEtypeOldData(row, "Cell");
  2044. if(returnValue == "N") return;
  2045. lf_BlodTypeIns();
  2046. ds_grid_testlist.rowposition = findRowNum;
  2047. ds_grid_testlist.setColumn(findRowNum, "bufinptrslt", "+");
  2048. lf_BlodTypeIns();
  2049. }
  2050. }
  2051. ds_grid_testlist.rowposition = row;
  2052. lf_TestInfoCntsClick(row, 3);
  2053. }
  2054. function lf_posneg(blodtype){
  2055. var row = ds_grid_testlist.rowposition;
  2056. var returnValue = "Y";
  2057. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  2058. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  2059. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");
  2060. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  2061. if(testcd != etc01_100 || testcd != etc01_101 || testcd != etc01_102 ){
  2062. ds_grid_testlist.setColumn(row, "bufinptrslt", blodtype);
  2063. returnValue = lf_CompareOldData(row);
  2064. if(returnValue == "N") return;
  2065. lf_BlodTypeIns();
  2066. }
  2067. ds_grid_testlist.rowposition = row+1;
  2068. }
  2069. function lf_CompareOldData(row){
  2070. if(!utlf_isNull(ds_grid_testlist.getColumn(row,"bfreptrslt"))){
  2071. if(String(ds_grid_testlist.getColumn(row,"bfreptrslt")).toUpperCase() != String(ds_grid_testlist.getColumn(row,"bufinptrslt")).toUpperCase()){
  2072. var msgRsltValue = sysf_messageBox("["+ds_grid_testlist.getColumn(row,"tclsscrnm")+" ] 입력한 결과는 이전결과와 다름니다.","Q002","");
  2073. if(msgRsltValue == "6"){
  2074. return "Y";
  2075. }else if(msgRsltValue == "7"){
  2076. ds_grid_testlist.setColumn(row, "inptrslt", "");
  2077. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  2078. ds_grid_testlist.setColumn(row, "reptrslt", "");
  2079. return "N";
  2080. }
  2081. }else{
  2082. return "Y";
  2083. }
  2084. }
  2085. return "Y";
  2086. }
  2087. function lf_CompareEtypeOldData(row, Etype){
  2088. if(!utlf_isNull(ds_grid_testlist.getColumn(row, "bfreptrslt"))){
  2089. if(String(ds_grid_testlist.getColumn(row, "bfreptrslt")).indexOf(Etype) != -1){
  2090. }else{
  2091. if(String(ds_grid_testlist.getColumn(row, "bfreptrslt")).toUpperCase() !=
  2092. String(ds_grid_testlist.getColumn(row, "bfreptrslt")).toUpperCase()){
  2093. var msgRsltValue = sysf_messageBox("["+ds_grid_testlist.getColumn(row,"tclsscrnm")+" ] 입력한 결과는 이전결과와 다름니다.","Q002","");
  2094. if(msgRsltValue == "6"){
  2095. return "Y";
  2096. }else if(msgRsltValue == "7"){
  2097. ds_grid_testlist.setColumn(row, "inptrslt", "");
  2098. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  2099. ds_grid_testlist.setColumn(row, "reptrslt", "");
  2100. return "N";
  2101. }
  2102. }
  2103. }
  2104. }
  2105. }
  2106. function lf_BlodTypeIns(){
  2107. var row = ds_grid_testlist.rowposition;
  2108. var vBufInptRslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  2109. var InptRslt = ds_grid_testlist.getColumn(row, "inptrslt");
  2110. if(utlf_isNull(vBufInptRslt) && utlf_isNull(InptRslt)){
  2111. ds_grid_testlist.setColumn(row, "inptrslt", vBufInptRslt);
  2112. return;
  2113. }else{
  2114. //이전결과와 현재 입력한 결과가 같은경우
  2115. if(vBufInptRslt == InptRslt){
  2116. //결과판정
  2117. lf_CvtViewResult(true);
  2118. return;
  2119. }
  2120. }
  2121. //결과코드
  2122. lf_CvtResultCode(row);
  2123. lf_CvtViewResult();
  2124. }
  2125. //결과판정
  2126. function lf_CvtViewResult(pMatch, pMulty, pRow){
  2127. var vRow = ds_grid_testlist.rowposition;
  2128. var vCol = ds_grid_testlist.rowposition;
  2129. //var vMaxRow = ds_grid_testlist.rowcount -1;
  2130. var vMaxRow = ds_grid_testlist.rowcount ;
  2131. if (utlf_isNull(pMatch)) pMatch = false;
  2132. if (utlf_isNull(pMulty)) pMulty = false;
  2133. if (!utlf_isNull(pRow)) vRow = pRow;
  2134. /*
  2135. if (typeof(pMatch) == "undefined") pMatch = false;
  2136. if (typeof(pMulty) == "undefined") pMulty = false;
  2137. if (typeof(pRow) != "undefined") vRow = pRow;
  2138. */
  2139. var vBufinptrslt = ds_grid_testlist.getColumn(vRow, "bufinptrslt");
  2140. if(!pMatch){
  2141. var colorTF = false;
  2142. var vRsltkind = ds_grid_testlist.getColumn(vRow, "testrsltkind");
  2143. var vRsltintsize = ds_grid_testlist.getColumn(vRow, "rsltintsize");
  2144. var vRsltdcmlsize = ds_grid_testlist.getColumn(vRow, "rsltdcmlsize");
  2145. var vRundkind = ds_grid_testlist.getColumn(vRow, "rundkind");
  2146. var vNvalrsltlimyn = ds_grid_testlist.getColumn(vRow, "nvalrsltlimyn");
  2147. var vReptrslt = fCOMLIS_CvtReptrslt(vBufinptrslt, vRsltkind, vRsltintsize, vRsltdcmlsize, vRundkind,vNvalrsltlimyn);
  2148. if(vReptrslt == "err"){
  2149. ds_grid_testlist.setColumn(vRow, "bufinptrslt", "");
  2150. return;
  2151. }
  2152. ds_grid_testlist.setColumn(vRow, "inptrslt", vBufinptrslt);
  2153. //LH 판정
  2154. var vJudgkind = ds_grid_testlist.getColumn(vRow, "judgkind");
  2155. var vRefL = ds_grid_testlist.getColumn(vRow, "refl");
  2156. var vRefLS = ds_grid_testlist.getColumn(vRow, "refls");
  2157. var vRefH = ds_grid_testlist.getColumn(vRow, "refh");
  2158. var vRefHS = ds_grid_testlist.getColumn(vRow, "refhs");
  2159. var vRefLT = ds_grid_testlist.getColumn(vRow, "reflt");
  2160. var vRvalflag = ds_grid_testlist.getColumn(vRow, "rvalflag");
  2161. var vJudgLH = fCOMLIS_JudgLH(vReptrslt, vJudgkind, vRefL, vRefLS, vRefH, vRefHS, vRefLT,vRvalflag);
  2162. ds_grid_testlist.setColumn(vRow, "judgmark", vJudgLH);
  2163. //panic 판정
  2164. var vJudgGbn = String(ds_grid_testlist.getColumn(vRow, "panicflag")).getTrim();
  2165. var vRefL = String(ds_grid_testlist.getColumn(vRow, "panicminval")).getTrim();
  2166. var vRefH = String(ds_grid_testlist.getColumn(vRow, "panicmaxval")).getTrim();
  2167. var vJudgPanic = fCOMLIS_JudgPCA(vReptrslt, vJudgGbn, vRefL, vRefH, "P");
  2168. if(vJudgPanic == "P"){
  2169. colorTF = true;
  2170. }
  2171. ds_grid_testlist.setColumn(vRow, "panicmark", vJudgPanic);
  2172. // Delta판정
  2173. var vBfResult = String(ds_grid_testlist.getColumn(vRow, "bfreptrslt")).getTrim();
  2174. var vJudgGbn = String(ds_grid_testlist.getColumn(vRow, "deltaflag")).getTrim();
  2175. var vRefH = String(ds_grid_testlist.getColumn(vRow, "deltamaxval")).getTrim();
  2176. var vDeltaday = String(ds_grid_testlist.getColumn(vRow, "deltaterm")).getTrim();
  2177. var vRstinterval = String(ds_grid_testlist.getColumn(vRow, "rstinterval")).getTrim();
  2178. var vJudgDelta = fCOMLIS_JudgDelta(vReptrslt, vBfResult, vJudgGbn, vRefH, vDeltaday, vRstinterval);
  2179. ds_grid_testlist.setColumn(vRow, "deltamark", vJudgDelta);
  2180. if(vJudgDelta == "D"){
  2181. colorTF = true;
  2182. }
  2183. // Critical판정
  2184. var vJudgGbn = String(ds_grid_testlist.getColumn(vRow, "criticalflag")).getTrim();
  2185. var vRefL = String(ds_grid_testlist.getColumn(vRow, "criticalminval")).getTrim();
  2186. var vRefH = String(ds_grid_testlist.getColumn(vRow, "criticalmaxval")).getTrim();
  2187. var vJudgCritical = fCOMLIS_JudgPCA(vReptrslt, vJudgGbn, vRefL, vRefH, "C");
  2188. ds_grid_testlist.setColumn(vRow, "criticalmark", vJudgCritical);
  2189. if(vJudgCritical == "C"){
  2190. colorTF = true;
  2191. }
  2192. // Alert판정
  2193. var vJudgGbn = String(ds_grid_testlist.getColumn(vRow, "alertflag")).getTrim();
  2194. var vRefL = String(ds_grid_testlist.getColumn(vRow, "alertminval")).getTrim();
  2195. var vRefH = String(ds_grid_testlist.getColumn(vRow, "alertmaxval")).getTrim();
  2196. var vJudgAlert = fCOMLIS_JudgPCA(vReptrslt, vJudgGbn, vRefL, vRefH, "A");
  2197. ds_grid_testlist.setColumn(vRow, "alertmark", vJudgAlert);
  2198. if(vJudgAlert == "A"){
  2199. colorTF = true;
  2200. }
  2201. //if(!colorTF) group2.grd_TestInfoCnts.cellstyle("background-color" , vRow,4) = "#FFFFFA"; 개발중
  2202. // 허용참고치 판정
  2203. var vJudgGbn = String(ds_grid_testlist.getColumn(vRow, "alimitflag")).getTrim();
  2204. var vRefL = String(ds_grid_testlist.getColumn(vRow, "alimitminval")).getTrim();
  2205. var vRefLS = String(ds_grid_testlist.getColumn(vRow, "alimitmaxval")).getTrim();
  2206. var vRefH = String(ds_grid_testlist.getColumn(vRow, "alimitmaxvalsinq")).getTrim();
  2207. var vRefHS = String(ds_grid_testlist.getColumn(vRow, "alimitminvalsinq")).getTrim();
  2208. vReptrslt = fCOMLIS_JudgLimit(vReptrslt, vJudgGbn, vRefL, vRefLS, vRefH, vRefHS);
  2209. // 사용자정의판정 결과변경
  2210. var vUjudglt = new Array(3);
  2211. vUjudglt[0] = vJudgkind;
  2212. for (var i = 1; i <= 3; i++) {
  2213. vUjudglt[i] = ds_grid_testlist.getColumn(vRow, "userjudgchar"+i.toString());
  2214. }
  2215. vReptrslt = fCOMLIS_CvtUjudgRst(vBufinptrslt, vReptrslt, vJudgLH, vUjudglt);
  2216. ds_grid_testlist.setColumn(vRow, "reptrslt", vReptrslt);
  2217. var tclskind = ds_grid_testlist.getColumn(vRow, "tclskind");
  2218. if(tclskind == "2"){
  2219. if(ds_grid_testlist.getColumn(vRow, "sel_value") == 0 || ds_grid_testlist.getColumn(vRow, "sel_value") == "false"){
  2220. if(!utlf_isNull(ds_grid_testlist.getColumn(vRow, "reptrslt"))){
  2221. ds_grid_testlist.setColumn(vRow, "sel_value", "true");
  2222. ds_grid_testlist.setColumn(vRow, "selchk", 1);
  2223. ds_grid_testlist.updatecontrol = false;
  2224. ds_grid_testlist.setRowType(vRow, Dataset.ROWTYPE_UPDATE);
  2225. ds_grid_testlist.updatecontrol = true;
  2226. }
  2227. }
  2228. }else if(tclskind=="3" || tclskind=="4" || tclskind=="5"){
  2229. var parentidx = ds_grid_testlist.getColumn(vRow, "parentidx");
  2230. if(!utlf_isNull(ds_grid_testlist.getColumn(vRow, "reptrslt"))){
  2231. ds_grid_testlist.setColumn(vRow, "sel_value", "true");
  2232. ds_grid_testlist.setColumn(vRow, "selchk", 1);
  2233. ds_grid_testlist.updatecontrol = false;
  2234. ds_grid_testlist.setRowType(vRow, Dataset.ROWTYPE_UPDATE);
  2235. ds_grid_testlist.updatecontrol = true;
  2236. }
  2237. }
  2238. }
  2239. if(pMulty){
  2240. ds_grid_testlist.setColumn(vRow, "bufinptrslt", "");
  2241. }else{
  2242. var vMoveRow = "";
  2243. if(vMaxRow == Number(vRow)){
  2244. vMoveRow = -1;
  2245. }else{
  2246. vMoveRow = Number(vRow) +1;
  2247. }
  2248. if(vMaxRow >= vMoveRow){
  2249. if(ds_grid_testlist.getColumn(vMoveRow, "readonly") == "true"){
  2250. vMoveRow++;
  2251. }
  2252. }else{
  2253. vMoveRow--;
  2254. }
  2255. ds_grid_testlist.setColumn(vRow, "bufinptrslt", "");
  2256. if(vMoveRow > ds_grid_testlist.rowcount-1) vMoveRow = ds_grid_testlist.rowcount -1;
  2257. ds_grid_testlist.rowposition = vMoveRow;
  2258. if(!utlf_isNull(ds_grid_testlist.getColumn(vMoveRow, "inptrslt"))){
  2259. ds_grid_testlist.setColumn(vMoveRow, "bufinptrslt", ds_grid_testlist.getColumn(vMoveRow, "inptrslt"));
  2260. }
  2261. }
  2262. group2.grd_TestInfoCnts.updateToDataset();
  2263. }
  2264. //결과코드
  2265. function lf_CvtResultCode(row){
  2266. var vTestcd = ds_grid_testlist.getColumn(row, "testcd");
  2267. var vInptRslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  2268. var returnValue = "Y";
  2269. ds_init_lb0109.filter("etc01 == '"+vTestcd+"'");
  2270. var vRstcontLower ="";
  2271. var vRstcontUpper = "";
  2272. for(var i=0; i<ds_init_lb0109.rowcount; i++){
  2273. var cd = ds_init_lb0109.getColumn(i, "cd");
  2274. var nm = ds_init_lb0109.getColumn(i, "nm");
  2275. if(vInptRslt.toLowerCase() == cd) vRstcontLower = nm;
  2276. if(vInptRslt.toUpperCase() == cd) vRstcontUpper = nm;
  2277. }
  2278. if(!utlf_isNull(vRstcontLower) || !utlf_isNull(vRstcontUpper)){
  2279. var vRstcont = (String(vRstcontLower).getTrim() != "") ? String(vRstcontLower).getTrim() : String(vRstcontUpper).getTrim();
  2280. ds_grid_testlist.setColumn(row, "bufinptrslt", vRstcont);
  2281. ds_grid_testlist.setColumn(row, "inptrslt", vRstcont);
  2282. //이전결과 체크하도록 수정
  2283. returnValue = lf_CompareOldData(row);
  2284. if(returnValue == "N") return;
  2285. }
  2286. }
  2287. function lf_CompareCellAnti(type, row){
  2288. //alert("이상@@");
  2289. var tclscd = ds_grid_testlist.getColumn(row, "tclscd");
  2290. var bufinptrslt = String(ds_grid_testlist.getColumn(row, "bufinptrslt")).replace("+","").replace(" Negative","").toUpperCase();
  2291. var reptrslt = String(utlf_transNullToEmpty(ds_grid_testlist.getColumn(row+ 3, "reptrslt"))).toUpperCase();
  2292. trace("tclscd : " + tclscd + "bufinptrslt : "+ bufinptrslt + "reptrslt : "+ reptrslt);
  2293. if(tclscd != "LBR002" && type == 1 && bufinptrslt != reptrslt && (!utlf_isNull(reptrslt)) ){
  2294. ds_grid_testlist.addColumn("color","string");
  2295. ds_grid_testlist.setColumn(row, "color", "#EE0000");
  2296. ds_grid_testlist.setColumn(row+1, "color", "#EE0000");
  2297. if(group2.chkChlidBtype.value == 1 && String(ds_grid_testlist.getColumn(row+1, reptrslt)).toUpperCase() == " "){
  2298. return "Y";
  2299. }
  2300. //alert("이상ㅃㅃㅃㅃㅃㅃㅃㅃㅃㅃㅃㅃ");
  2301. var msgRsltValue = sysf_messageBox("Serum Type 과 Cell Type 이 다름니다. ","Q002","");
  2302. if(msgRsltValue == "6"){
  2303. return "Y";
  2304. }else if(msgRsltValue == "7"){
  2305. ds_grid_testlist.setColumn(row, "inptrslt", "");
  2306. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  2307. ds_grid_testlist.setColumn(row, "reptrslt", "");
  2308. return "N";
  2309. }
  2310. }else{
  2311. ds_grid_testlist.addColumn("color","string");
  2312. ds_grid_testlist.setColumn(row, "color", "#000000");
  2313. ds_grid_testlist.setColumn(row+1, "color", "#000000");
  2314. }
  2315. //serum typing 입력시
  2316. reptrslt = String(ds_grid_testlist.getColumn(row, "reptrslt")).replace("+","").replace(" Negative","").toUpperCase();
  2317. bufinptrslt = String(ds_grid_testlist.getColumn(row-1, "bufinptrslt")).toUpperCase();
  2318. if(type == 2 && reptrslt != bufinptrslt && (!utlf_isNull(reptrslt))){
  2319. //alert("이상ㅆㅆㅆㅆㅆㅆㅆㅆㅆㅆㅆ");
  2320. ds_grid_testlist.addColumn("color","string");
  2321. ds_grid_testlist.setColumn(row, "color", "#EE0000");
  2322. ds_grid_testlist.setColumn(row-1, "color", "#EE0000");
  2323. if(group2.chkChlidBtype.value == 1 && String(ds_grid_testlist.getColumn(row, "bufinptrslt")).toUpperCase() == " "){
  2324. return "Y";
  2325. }
  2326. var msgRsltValue = sysf_messageBox("Serum Type 과 Cell Type 이 다름니다.","Q002","");
  2327. if(msgRsltValue == "6"){
  2328. return "Y";
  2329. }else if(msgRsltValue == "7"){
  2330. ds_grid_testlist.setColumn(row, "inptrslt", "");
  2331. ds_grid_testlist.setColumn(row, "bufinptrslt", "");
  2332. ds_grid_testlist.setColumn(row, "reptrslt", "");
  2333. return "N";
  2334. }
  2335. }else{
  2336. ds_grid_testlist.addColumn("color","string");
  2337. ds_grid_testlist.setColumn(row, "color", "#EE0000");
  2338. ds_grid_testlist.setColumn(row-1, "color", "#EE0000");
  2339. }
  2340. }
  2341. //소견저장
  2342. function lf_SetContCmt(){
  2343. if(utlf_isNull(ds_temp_acceptnm.getColumn(0, "usernm")) || utlf_isNull(group2.ipt_testpsn.value)){
  2344. sysf_messageBox("검사자를","C001","");
  2345. group2.ipt_testpsn.setFocus();
  2346. return;
  2347. }
  2348. if(ds_grd_patlist.getColumn(ds_grd_patlist.rowposition, "rsltstat") == "-"){
  2349. sysf_messageBox("소견등록은 결과저장 이후에 가능합니다.","C","");
  2350. return;
  2351. }
  2352. /* 17년 11월 14일 이재오 막다
  2353. if(!p_isedit && ds_grid_testcmts.rowcount < 1){
  2354. sysf_messageBox("소견입력을 하세요!","C","");
  2355. return;
  2356. }
  2357. */
  2358. var rtn = 0;
  2359. var nRowType; //row type
  2360. for(i=0;i<ds_temp_testcont.getRowCount();i++){
  2361. nRowType = ds_temp_testcont.getRowType(i);
  2362. if( nRowType == 2|| nRowType == 4 || nRowType == 8 ){
  2363. rtn++;
  2364. gv_isedit = "true";
  2365. }
  2366. }
  2367. //trace(gv_isedit);
  2368. if (gv_isedit != "true" && rtn < 1) {
  2369. sysf_messageBox("소견을 입력 하세요" , "C" ,"");
  2370. return;
  2371. }
  2372. if (utlf_trim(group2.textarea2.value)==""){
  2373. sysf_messageBox("소견을 입력 하세요" , "C" ,"");
  2374. return;
  2375. }
  2376. if (gv_isedit == "true") {
  2377. //trace("2222222222");
  2378. lf_makeSendSoGyeon();
  2379. }
  2380. createColumn(ds_grid_testcmts, "flag");
  2381. for(var i=0; i<ds_grid_testcmts.rowcount; i++){
  2382. ds_grid_testcmts.setColumn(i, "flag", "2"); //소견만저장시
  2383. }
  2384. var sInDsName = dsf_createDsRow("ds_temp_refflag"
  2385. , [{col: "bcno", val: ds_cond_patinfo.getColumn(0,"bcno")}
  2386. , {col: "rsltstat" , val: "1"}
  2387. , {col: "testlrgkind" , val: "B"}
  2388. , {col: "isedit" , val: gv_isedit}
  2389. , {col: "rsltscrflag" , val: "spc"}
  2390. , {col: "conf" , val: null}
  2391. , {col: "XFMGbn" , val: null}
  2392. , {col: "userid" , val: ds_temp_acceptnm.getColumn(0, "userid")}]);
  2393. // 서브밋호출
  2394. tranf_submit({
  2395. id: "TXLLR80101"
  2396. , service: "rsltmngtapp.RsltMngt"
  2397. , method: "reqSetResultSave"
  2398. , inds : "TestData=ds_grid_testlist:U RefFalg="+sInDsName+" SpcCmtInfo=ds_vSndSG:A TestCmtInfo=ds_grid_testcmts:U"
  2399. , callback: "cbf_SSLLR80100"
  2400. , async: false
  2401. });
  2402. //ds_vSndSG.clearData();
  2403. /* 이재오 막다
  2404. //data2
  2405. dsf_createDsRow("ds_temp_refflag"
  2406. , [{col: "bcno" , val: ds_cond_patinfo.getColumn(0, "bcno")}
  2407. , {col: "rsltstat" , val: "1"}
  2408. , {col: "testlrgkind" , val: "B"}
  2409. , {col: "isedit" , val: (p_isedit ? "true" : "false")}
  2410. , {col: "rsltscrflag" , val: "spc"}
  2411. , {col: "conf" , val: null}
  2412. , {col: "XFMGbn" , val: null}
  2413. , {col: "userid" , val: ds_temp_acceptnm.getColumn(0, "userid")}]);
  2414. //data3
  2415. if(p_isedit){
  2416. ds_temp_testcont.updatecontrol = false;
  2417. for(var i=0; i<ds_temp_testcont.rowcount; i++){
  2418. if(!utlf_isNull(ds_temp_testcont.getColumn(i, "iud"))){
  2419. ds_temp_testcont.setRowType(i, Dataset.ROWTYPE_UPDATE);
  2420. }
  2421. }
  2422. ds_temp_testcont.updatecontrol = true;
  2423. }
  2424. //data4
  2425. createColumn(ds_grid_testcmts, "flag");
  2426. for(var i=0; i<ds_grid_testcmts.rowcount; i++){
  2427. ds_grid_testcmts.setColumn(i, "flag", "2"); //소견만저장시
  2428. }
  2429. var oParam = {};
  2430. oParam.id = "TXLLR80101";
  2431. oParam.service = "rsltmngtapp.RsltMngt";
  2432. oParam.method = "reqSetResultSave";
  2433. oParam.inds = "TestData=ds_grid_testlist:U RefFalg=ds_temp_refflag SpcCmtInfo=ds_temp_testcont:U TestCmtInfo=ds_grid_testcmts:U";
  2434. oParam.async = false;
  2435. oParam.callback = "cbf_TXLLR80101";
  2436. tranf_submit(oParam);
  2437. */
  2438. }
  2439. function lf_setContCmt_backup(){
  2440. if(group2.ipt_testpsn.value == "" || group2.opt_testpsn.value == ""){
  2441. sysf_messageBox("검사자를 " , "C001" ,"");
  2442. group2.ipt_testpsn.setFocus();
  2443. return;
  2444. }
  2445. var rtn = 0;
  2446. var nRowType; //row type
  2447. for(i=0;i<ds_getSpcInfo.getRowCount();i++){
  2448. nRowType = ds_getSpcInfo.getRowType(i);
  2449. if( nRowType == 2|| nRowType == 4 || nRowType == 8 ){
  2450. rtn++;
  2451. gv_isedit = "true";
  2452. }
  2453. }
  2454. if (gv_isedit != "true" && rtn < 1) {
  2455. sysf_messageBox("소견을 입력 하세요" , "C" ,"");
  2456. return;
  2457. }
  2458. if (utlf_trim(group2.textarea2.value)==""){
  2459. sysf_messageBox("소견을 입력 하세요" , "C" ,"");
  2460. return;
  2461. }
  2462. if (gv_isedit == "true") {
  2463. lf_makeSendSoGyeon();
  2464. }
  2465. for(i = 0; i < ds_grid_grd_TestCmts.rowcount; i++){
  2466. if(ds_grid_grd_TestCmts.getRowType(i) == "2" || ds_grid_grd_TestCmts.getRowType(i) == "4"){ //추가되거나 수정된 행만 값변경
  2467. ds_grid_grd_TestCmts.setColumn(i,"flag","2"); //소견만저장시
  2468. }
  2469. if(ds_getSpcInfo.getRowType(i) == "2" || ds_getSpcInfo.getRowType(i) == "4"){ //추가되거나 수정된 행만 값변경
  2470. ds_grid_grd_TestCmts.setColumn(i,"flag","2"); //소견만저장시
  2471. }
  2472. }
  2473. var sInDsName = dsf_createDsRow("ds_temp_search"
  2474. , [{col: "bcno", val: ds_getSpcInfo.getColumn(0,"bcno")}
  2475. , {col: "rsltstat", val: "1"}
  2476. , {col: "testlrgkind", val: "-"}
  2477. , {col: "isedit", val: gv_isedit}
  2478. , {col: "XFMGbn", val: "result"}
  2479. , {col: "userid", val: group2.ipt_testpsn.value}
  2480. , {col: "rsltscrflag", val: "spc"}]);
  2481. //, {col: "conf", val: ""}]); 결과확인버튼에만 "Y"
  2482. // 서브밋호출
  2483. tranf_submit({
  2484. id: "TXLLR80101"
  2485. , service: "rsltmngtapp.RsltMngt"
  2486. , method: "reqSetResultSave"
  2487. , inds : "TestData= RefFalg="+sInDsName+" SpcCmtInfo=ds_vSndSG:A TestCmtInfo=ds_grid_grd_TestCmts:U"
  2488. , callback: "cbf_SSLLR80100"
  2489. , async: false
  2490. });
  2491. ds_vSndSG.clearData();
  2492. lf_setClear2();
  2493. lf_beforeForcus();
  2494. lf_patListClick(ds_grid_grd_patList.rowposition); //재조회처리
  2495. }
  2496. //소견선택
  2497. function lf_SetCmt(){
  2498. var curSlip = group2.cmb_sect.value;
  2499. var curCmptcd = group2.cmb_cmt.value;
  2500. if(curSlip == "00"){
  2501. group2.cmb_cmt.value = "00";
  2502. }
  2503. if(curCmptcd != "00"){
  2504. var vSectcd = ds_cond_patinfo.getColumn(0, "sectcd");
  2505. var vTsectcd = ds_cond_patinfo.getColumn(0, "tsectcd");
  2506. var curCmt = lf_nvl(ds_temp_testcont.getColumn(0, "testcont"),"");
  2507. ds_init_lb0210.filter("cd == '"+curCmptcd+"' && etc01 == '"+vSectcd+"' && etc02 == '"+vTsectcd+"'");
  2508. var newCmt = ds_init_lb0210.getColumn(0, "etc03");
  2509. //ds_init_lb0210.filter("cd == '00' || (cd == '"+curCmptcd+"' && etc01 == '"+vSectcd+"' && etc02 == '"+vTsectcd+"')");
  2510. //시행부서별소견
  2511. if(group2.rdo_cntsflag.value == 1){
  2512. if(curCmt == "\n" || curCmt==""){
  2513. var rstCmt = newCmt;
  2514. }else{
  2515. var rstCmt = curCmt + "\n" + newCmt;
  2516. }
  2517. group2.textarea2.value = rstCmt;
  2518. lf_SoGyeonJeoJang();
  2519. }else{
  2520. if(ds_grid_testcmts.rowposition == -1){
  2521. sysf_messageBox("소견을 지정 할 항목을 선택 하세요.","I","");
  2522. group2.cmb_cmt.index = 0;
  2523. return;
  2524. }
  2525. var sCmts = ds_grid_testcmts.getColumn(ds_grid_testcmts.rowposition, "testcont");
  2526. ds_grid_testcmts.setColumn(ds_grid_testcmts.rowposition, "testcont", sCmts + " " + newCmt);
  2527. ds_grid_testcmts.setColumn(ds_grid_testcmts.rowposition, "testcontcd", curCmptcd);
  2528. if(ds_grid_testcmts.getRowType(ds_grid_testcmts.rowposition) == Dataset.ROWTYPE_NORMAL){
  2529. ds_grid_testcmts.updatecontrol = false;
  2530. ds_grid_testcmts.setRowType(ds_grid_testcmts.rowposition, Dataset.ROWTYPE_UPDATE);
  2531. ds_grid_testcmts.updatecontrol = true;
  2532. }
  2533. }
  2534. }
  2535. ds_init_lb0210.filter("");
  2536. }
  2537. //소견저장
  2538. function lf_SoGyeonJeoJang(){
  2539. var curSlip = ds_cond_patinfo.getColumn(0, "tsectcd");
  2540. var curCmptcd = group2.cmb_cmt.value;
  2541. var vCmtp = group2.textarea2.value;
  2542. if(curSlip == "-") return;
  2543. var findRow = ds_temp_testcont.findRow("execdeptcd", curSlip);
  2544. ds_temp_testcont.setColumn(findRow, "testcontcd" , curCmptcd);
  2545. //ds_temp_testcont.setColumn(findRow, "testcont" , String(vCmtp).getTrim());
  2546. ds_temp_testcont.setColumn(findRow, "testcontkind" , "3");
  2547. ds_temp_testcont.setColumn(findRow, "iud" , "i");
  2548. if( !utlf_isNull(vCmtp.getTrim())) {
  2549. p_isedit = true;
  2550. }else{
  2551. p_isedit = false;
  2552. }
  2553. }
  2554. //결과상세내역 클릭
  2555. function lf_TestInfoCntsClick(row, col){
  2556. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");
  2557. var etc01_106 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "106"), "cd");
  2558. //Rh 검사코드 row 찾기
  2559. var findRowRH = ds_grid_testlist.findRow("testcd", etc01_102);
  2560. //ANTO BODY 검사코드 row 찾기
  2561. var findRowNum2 = ds_grid_testlist.findRow("testcd", etc01_106);
  2562. if(row < 0) return;
  2563. for(var i=1; i< ds_grid_testlist.rowcount; i++){
  2564. if(i == row){
  2565. if(col == 3){
  2566. var vInptRslt = ds_grid_testlist.getColumn(row, "inptrslt");
  2567. if(!utlf_isNull(vInptRslt)){
  2568. ds_grid_testlist.setColumn(i, "bufinptrslt", vInptRslt);
  2569. }
  2570. }else{
  2571. ds_grid_testlist.setColumn(i, "bufinptrslt", "");
  2572. }
  2573. }else{
  2574. ds_grid_testlist.setColumn(i, "bufinptrslt", "");
  2575. }
  2576. }
  2577. if(col == 1){
  2578. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  2579. var vSelValue = ds_grid_testlist.getColumn(row, "sel_value");
  2580. if(utlf_isNull(vSelValue)) return;
  2581. vSelValue = (vSelValue == "true") ? "false" : "true";
  2582. //RH 체크
  2583. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");
  2584. var etc01_103 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "103"), "cd");
  2585. if(testcd == etc01_100 || testcd == etc01_103 ){
  2586. vSelValue = ds_grid_testlist.getColumn(row, "sel_value");
  2587. ds_grid_testlist.setColumn(findRowRH, "sel_value", vSelValue);
  2588. if(findRowNum2 > 0){
  2589. ds_grid_testlist.rowposition = findRowNum2;
  2590. ds_grid_testlist.setColumn(findRowNum2, "sel_value", "vSelValue");
  2591. //sysf_messageBox("알림1 : "+findRowNum2,"I","");
  2592. }
  2593. }
  2594. }else if(col == 5){
  2595. if(eval(ds_grid_testlist.getColumn(row, "rsltseq")) > 1){
  2596. var vBCNO = ds_grid_testlist.getColumn(row, "bcno");
  2597. var objArg = new Object();
  2598. objArg.pBcno = vBCNO;
  2599. objArg.pTestlrgkind = "-";
  2600. objArg.pMicrotestkind = "-";
  2601. frmf_modal("SPLLR90100", "SPLLR90100", objArg);
  2602. var vBufDJGG = ds_DJGGParm.getColumn(0,"bufDJGG");
  2603. if (!utlf_isNull(vBufDJGG.getTrim())) {
  2604. var vRowA = vBufDJGG.split("▩");
  2605. for (n = 0; n < vRowA.length - 1; n++) {
  2606. vColA = vRowA[n].split("▦");
  2607. var findrow = ds_grid_testlist.findRow(vColA[0], vColA[0].toString().getTrim());
  2608. if (findrow > 0) {
  2609. grd_TestInfoCnts.row= findrow;
  2610. grd_TestInfoCnts.col = 3;
  2611. //model.setValue("/root/main/TestInfo/getTestInfoCnts["+findrow+"]/bufinptrslt", vColA[1].toString());
  2612. ds_grid_testlist.setColumn(findrow,vColA[0],vColA[1].toString());
  2613. lf_CvtViewResult(false, true);
  2614. }
  2615. }
  2616. }
  2617. }
  2618. }
  2619. }
  2620. function lf_gridKeyEvent_backup(row, col){
  2621. if(col == group2.grd_TestInfoCnts.getBindCellIndex("body", "bufinptrslt")
  2622. && (ds_grid_testlist.getColumn(row, "readonly") == "0" || utlf_isNull(ds_grid_testlist.getColumn(row, "readonly"))) ){
  2623. var vBufInptRslt = ds_grid_testlist.getColumn(row, "bufinptrslt");
  2624. var InptRslt = ds_grid_testlist.getColumn(row, "inptrslt");
  2625. if(utlf_isNull(vBufInptRslt) && utlf_isNull(InptRslt)){
  2626. ds_grid_testlist.setColumn(row, "inptrslt", vBufInptRslt);
  2627. return;
  2628. }else{
  2629. if(vBufInptRslt == InptRslt){
  2630. lf_CvtViewResult(true);
  2631. return;
  2632. }
  2633. }
  2634. lf_CvtResultCode(row);
  2635. lf_CvtViewResult();
  2636. /* 2012-01-30 LHT add 자동소견 추가*/
  2637. var iAutoCnt;
  2638. ds_temp_chkstr.filter("");
  2639. iAutoCnt = ds_temp_chkstr.rowcount;
  2640. //로컬자동소견 오류임시주석
  2641. if (iAutoCnt > 0) lf_setAutoCmt(row);
  2642. }
  2643. lf_aboRsltInfoSet("btn");
  2644. }
  2645. function lf_GetMouseDown(screenX, screenY, row, col){
  2646. if(row > -1){
  2647. var menu = new Array();
  2648. var n = 0;
  2649. if(col == 3){
  2650. //결과예문
  2651. var testcd = String(ds_grid_testlist.getColumn(row, "testcd")).getTrim();
  2652. ds_init_lb0109.filter("etc01 == '"+testcd+"'");
  2653. n = ds_init_lb0109.rowcount;
  2654. if(n > 0){
  2655. for(var i=0; i<ds_init_lb0109.rowcount; i++){
  2656. var cd = ds_init_lb0109.getColumn(i, "cd");
  2657. var nm = ds_init_lb0109.getColumn(i, "nm");
  2658. var yn = ds_init_lb0109.getColumn(i, "etc03");
  2659. if(yn == "Y"){
  2660. var obj = new Object();
  2661. obj.id = nm + "▦" + row;
  2662. obj.level = "1";
  2663. obj.title = "["+cd+"] "+nm;
  2664. menu.push(obj);
  2665. }
  2666. }
  2667. }
  2668. var diffcountyn = ds_grid_testlist.getColumn(row, "diffcntyn");
  2669. if(diffcountyn == "Y"){
  2670. n = frmfds_pm_SubMenu.rowcount;
  2671. if(n > 0){
  2672. var obj = new Object();
  2673. obj.id = "";
  2674. obj.level = "1";
  2675. obj.title = "-";
  2676. menu.push(obj);
  2677. n++;
  2678. }
  2679. var obj = new Object();
  2680. obj.id = "fDiffInput";
  2681. obj.level = "1";
  2682. obj.title = "▶ Diff Count 입력";
  2683. menu.push(obj);
  2684. }
  2685. }else if(col == 2){
  2686. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  2687. var spccd = ds_grid_testlist.getColumn(row, "spccd");
  2688. var vRelation = ds_init_lb0108.getColumn(ds_init_lb0108.findRow("cd", testcd), "cd");
  2689. if(!utlf_isNull(vRelation)){
  2690. var obj = new Object();
  2691. obj.id = "fRelationTest";
  2692. obj.level = "1";
  2693. obj.title = "▶ 연관검사조회";
  2694. menu.push(obj);
  2695. }
  2696. ds_temp_abnormallist.filter("testcd2 == '"+testcd+"'");
  2697. if(ds_temp_abnormallist.rowcount > 0){
  2698. n = menu.length;
  2699. if(n > 0){
  2700. var obj = new Object();
  2701. obj.id = "";
  2702. obj.level = "1";
  2703. obj.title = "-";
  2704. menu.push(obj);
  2705. n++;
  2706. }
  2707. var obj = new Object();
  2708. obj.id = "fAbResult" + testcd;
  2709. obj.level = "1";
  2710. obj.title = "▶ AbNormal Result";
  2711. menu.push(obj);
  2712. }
  2713. if(ds_grid_testlist.getColumn(row, "tclskind") == "5"){
  2714. if(utlf_isNull(ds_grid_testlist.getColumn(row, "reptrslt"))){
  2715. n = menu.length;
  2716. if(n > 0){
  2717. var obj = new Object();
  2718. obj.id = "";
  2719. obj.level = "1";
  2720. obj.title = "-";
  2721. menu.push(obj);
  2722. n++;
  2723. }
  2724. var obj = new Object();
  2725. obj.id = "fAbDel" + row;
  2726. obj.level = "1";
  2727. obj.title = "▶ AbNormal Result 삭제";
  2728. menu.push(obj);
  2729. }
  2730. }
  2731. }
  2732. n = menu.length;
  2733. if(n > 0){
  2734. var obj = new Object();
  2735. obj.id = "";
  2736. obj.level = "1";
  2737. obj.title = "-";
  2738. menu.push(obj);
  2739. n++;
  2740. }
  2741. var obj = new Object();
  2742. obj.id = "fTGyeolGwa";
  2743. obj.level = "1";
  2744. obj.title = "▶ 통합결과조회";
  2745. menu.push(obj);
  2746. var obj = new Object();
  2747. obj.id = "fAcmlRsltRef";
  2748. obj.level = "1";
  2749. obj.title = "▶ 누적결과조회";
  2750. menu.push(obj);
  2751. frmf_setPopupMenuDs("pm_SubMenu", menu);
  2752. pm_SubMenu.trackPopup(screenX+5,screenY+5,"right bottom");
  2753. }
  2754. }
  2755. function lf_Onmenu(id){
  2756. if(id == "fDiffInput"){
  2757. lf_DiffInput();
  2758. }else if(id == "fTGyeolGwa"){
  2759. lf_TGyeolGwa();
  2760. }else if(id == "fRelationTest"){
  2761. lf_RelationTest();
  2762. }else if(id == "fAcmlRsltRef"){
  2763. lf_acmlRsltRef();
  2764. }else if(String(id).substring(0,9) == "fAbResult"){
  2765. lf_AbResult(String(id).substring(9));
  2766. }else if(String(id).substring(0,6) == "fAbDel"){
  2767. lf_AbResultDel(String(id).substring(6));
  2768. }else{
  2769. if(!utlf_isNull(id)){
  2770. var aL = String(id).split("▦");
  2771. ds_grid_testlist.setColumn(Number(aL[1]), "bufinptrslt", aL[0]);
  2772. lf_CvtViewResult();
  2773. //마우스 선택시, 하단에 값 매핑 처리 되도록 수정 - 2014-10-21 김남규 추가
  2774. lf_gridKeyEvent(gRow, gCol);
  2775. }
  2776. }
  2777. }
  2778. //누적결과조회
  2779. function lf_acmlRsltRef(){
  2780. var aData = new Array();
  2781. aData = div_cond.cp_periodCal.getData();
  2782. ds_baseinfo.setColumn(0,"pid",utlf_transNullToEmpty(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition,"pid")));
  2783. ds_baseinfo.setColumn(0,"testcd",utlf_transNullToEmpty(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition,"testcd")));
  2784. ds_baseinfo.setColumn(0,"hngnm",utlf_transNullToEmpty(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition,"patnm")));
  2785. ds_baseinfo.setColumn(0,"sex",utlf_transNullToEmpty(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition,"patsex")));
  2786. ds_baseinfo.setColumn(0,"age",utlf_transNullToEmpty(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition,"patage")));
  2787. ds_baseinfo.setColumn(0,"flag","");
  2788. ds_baseinfo.setColumn(0,"startdd",aData[0]);
  2789. ds_baseinfo.setColumn(0,"enddd",aData[1]);
  2790. var objArg = new Object();
  2791. objArg.ds_baseinfo = ds_baseinfo;
  2792. frmf_modal("SPLLP90100","SPLLP90100",objArg);
  2793. }
  2794. function lf_DiffInput(){
  2795. var objArg = new Object();
  2796. objArg.bcno = ds_cond_patinfo.getColumn(0, "bcno");
  2797. objArg.pid = ds_cond_patinfo.getColumn(0, "pid");
  2798. objArg.patnm = ds_cond_patinfo.getColumn(0, "hngnm");
  2799. objArg.sexage = ds_cond_patinfo.getColumn(0, "patsexage");
  2800. objArg.testcd = String(ds_grid_testlist.getColumn(ds_grid_testlist.rowposition, "testcd")).substr(0,6);
  2801. var vBufDiffGG = frmf_modal("SMLLR90700", "SMLLR90700", objArg);
  2802. if(String(vBufDiffGG).getTrim() != ""){
  2803. var vRowA = String(vBufDiffGG).split("▩");
  2804. for(var i=0; i<vRowA.length-1; i++){
  2805. var vColA = String(vRowA[i]).split("▦");
  2806. var findRow = ds_grid_testlist.findRow("", vColA[0]);
  2807. //var findrow = group2.grd_TestInfoCnts.FindRow(vColA[0].getTrim(), 1, 24, false, false); row24가 어딘지 모르겠음 개발중
  2808. if(findRow > -1){
  2809. ds_grid_testlist.rowposition = findRow;
  2810. ds_grid_testlist.setColumn(findRow, "bufinptrslt", String(vColA[1]));
  2811. lf_CvtViewResult(false, true);
  2812. }
  2813. }
  2814. }
  2815. }
  2816. function lf_TGyeolGwa(){
  2817. plgv_SMMMI00100_pid = ds_cond_patinfo.getColumn(0, "pid");
  2818. frmf_modal("SMMMI00100", "SMMMI00100", null, null, null, null, null, null, null, null, null, null, "M");
  2819. }
  2820. function lf_RelationTest(){
  2821. ds_RelationParm.clearData();
  2822. nRow = ds_RelationParm.addRow();
  2823. var vRow = ds_grid_testlist.rowposition;
  2824. ds_RelationParm.setColumn(nRow,"pid",utlf_transNullToEmpty(ds_cond_patinfo.getColumn(0,"pid")));
  2825. ds_RelationParm.setColumn(nRow,"tclsscrnnm",utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"tclsscrnm")));
  2826. ds_RelationParm.setColumn(nRow,"testcd",utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"testcd")));
  2827. ds_RelationParm.setColumn(nRow,"spccd",utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"spccd")));
  2828. var objArg = new Object();
  2829. objArg.ds_RelationParm = ds_RelationParm;
  2830. frmf_modal("SMLLR90400","SMLLR90400",objArg);
  2831. }
  2832. function lf_AbResult(testcd){
  2833. var objArg = new Object();
  2834. objArg.abnormallist = ds_temp_abnormallist;
  2835. frmf_modal("SMLLR90500", "SMLLR90500", objArg);
  2836. /* 개발중
  2837. var abCnt = ds_temp_abnormallist.rowcount;
  2838. if(abCnt > 0){
  2839. var row = ds_grid_testlist.rowposition;
  2840. for(var i=row ; ; i++){
  2841. if(ds_grid_testlist.getColumn(i, "testcd2") != testcd) break;
  2842. if(i == ds_grid_testlist.rowcount) break;
  2843. }
  2844. i = i-1;
  2845. for(var j=0; j<abCnt; j++){
  2846. var row = i + j - 1;
  2847. }
  2848. }
  2849. */
  2850. }
  2851. function lf_AbResultDel(pRow){
  2852. sysf_messageBox("개발중");
  2853. }
  2854. function lf_TestInfoCntsDBlclick(row, col){
  2855. if(col == group2.grd_TestInfoCnts.getBindCellIndex("body", "tclsscrnm")){
  2856. var tclsnm = ds_grid_testlist.getColumn(row, "tclsscrnm");
  2857. var sTestcd = ds_grid_testlist.getColumn(row, "testcd");
  2858. var sBcno = ds_grid_testlist.getColumn(row, "bcno");
  2859. if(group2.rdo_cntsflag.value == 1){
  2860. var bfcont = lf_nvl(ds_temp_testcont.getColumn(0, "testcont"), "");
  2861. ds_temp_testcont.setColumn(0, "testcont", bfcont + tclsnm + ",");
  2862. }else if(group2.rdo_cntsflag.value == 2){
  2863. var findRow = -1;
  2864. for(var i=0; i<ds_grid_testcmts.rowcount; i++){
  2865. if(ds_grid_testcmts.getColumn(i, "testcd") == sTestcd &&
  2866. ds_grid_testcmts.getColumn(i, "bcno") == sBcno){
  2867. findRow = i;
  2868. }
  2869. }
  2870. if(findRow > -1){
  2871. sysf_messageBox(tclsnm + "항목에 대하여 소견이 존재합니다.","I","");
  2872. ds_grid_testcmts.rowposition = findRow;
  2873. return;
  2874. }
  2875. var addRow = ds_grid_testcmts.addRow();
  2876. ds_grid_testcmts.setColumn(addRow, "bcno" , ds_grid_testlist.getColumn(row, "bcno"));
  2877. ds_grid_testcmts.setColumn(addRow, "tclscd" , ds_grid_testlist.getColumn(row, "tclscd"));
  2878. ds_grid_testcmts.setColumn(addRow, "testcd" , ds_grid_testlist.getColumn(row, "testcd"));
  2879. ds_grid_testcmts.setColumn(addRow, "spccd" , ds_grid_testlist.getColumn(row, "spccd"));
  2880. ds_grid_testcmts.setColumn(addRow, "rsltseq" , ds_grid_testlist.getColumn(row, "rsltseq"));
  2881. ds_grid_testcmts.setColumn(addRow, "testcontcd" , "-");
  2882. ds_grid_testcmts.setColumn(addRow, "testcont" , tclsnm + " : ");
  2883. }
  2884. group2.grd_TestCmts.updateToDataset();
  2885. }
  2886. }
  2887. //혈액형 검사결과 셋팅
  2888. function lf_aboRsltInfoSet(param){
  2889. var pid = "";
  2890. var hngnm = "";
  2891. var aboCellTyping = "";
  2892. var aboRh = "";
  2893. var aboSermTyping = "";
  2894. var aboLastRslt = "";
  2895. var testcd = "";
  2896. var reptrslt = "";
  2897. var bfreptrslt = "";
  2898. var abrnblodyn = "N"; //이형 여부
  2899. var bfaboCellTyping = "";
  2900. var bfaboSermTyping = "";
  2901. var bfaboRh = "";
  2902. var bfaboLastRslt = "";
  2903. var mdlreptInfo = "";
  2904. var mdlreptdt = "";
  2905. var lastreptdtInfo = "";
  2906. var lastreptdt = "";
  2907. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");//cell typing
  2908. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");//cell type,donor
  2909. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");//serum typing
  2910. var etc01_111 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "111"), "cd");//serum type,donor
  2911. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");//Rh(D)
  2912. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");//Rh(D),donor
  2913. //신생아추가
  2914. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");//cell typing(신생아)
  2915. var etc01_201 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "201"), "cd");//serum typing(신생아)
  2916. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");//cRh(D)(신생아)
  2917. // grp_aboinfo. .value = "";
  2918. // grp_aboinfo.opt_serumtyping.value = "";
  2919. // grp_aboinfo.opt_rh.value = "";
  2920. // grp_aboinfo.opt_lastabo.value = "";
  2921. // grp_aboinfo.sta_pid.text = "";
  2922. for(var i=0; i < ds_grid_testlist.rowcount; i++){
  2923. pid = ds_grid_testlist.getColumn(0, "pid");
  2924. hngnm = ds_grid_testlist.getColumn(0, "patnm");
  2925. testcd = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "testcd"));
  2926. reptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "reptrslt"));
  2927. bfreptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "bfreptrslt"));
  2928. mdlreptdt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "mdlreptdt"));
  2929. lastreptdt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "lastreptdt"));
  2930. mdlreptInfo = (mdlreptdt==""?"":urlf_getStrDate(mdlreptdt)) + " " + utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "mdlreptnm"));
  2931. //cell
  2932. if(testcd == etc01_100 || testcd == etc01_110 || testcd == etc01_200){
  2933. // grp_aboinfo.opt_celltyping.value = reptrslt;
  2934. aboCellTyping = reptrslt;
  2935. bfaboCellTyping = bfreptrslt;
  2936. //grp_aboinfo.opt_celltypingM.value = mdlreptInfo;
  2937. lastreptdtInfo = (lastreptdt==""?"":urlf_getStrDate(lastreptdt)) + " " + utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "rstnm"));
  2938. //serum
  2939. }else if(testcd == etc01_101 || testcd == etc01_111 || testcd == etc01_201 ){
  2940. //grp_aboinfo.opt_serumtyping.value = reptrslt;
  2941. aboSermTyping = reptrslt;
  2942. bfaboSermTyping = bfreptrslt;
  2943. //grp_aboinfo.opt_serumtypingM.value = mdlreptInfo;
  2944. lastreptdtInfo = (lastreptdt==""?"":urlf_getStrDate(lastreptdt)) + " " + utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "rstnm"));
  2945. //rh
  2946. }else if(testcd == etc01_102 || testcd == etc01_112 || testcd == etc01_202 ){
  2947. //grp_aboinfo.opt_rh.value= reptrslt;
  2948. aboRh = reptrslt;
  2949. bfaboRh = bfreptrslt;
  2950. //grp_aboinfo.opt_rhM.value = mdlreptInfo;
  2951. lastreptdtInfo = (lastreptdt==""?"":urlf_getStrDate(lastreptdt)) + " " + utlf_transNullToEmpty(ds_grid_testlist.getColumn(i, "rstnm"));
  2952. }
  2953. }
  2954. // grp_aboinfo.sta_pid.text = hngnm + "\n" + pid;
  2955. //확정 혈액형
  2956. if(aboCellTyping == aboSermTyping){
  2957. aboLastRslt = aboCellTyping +""+(aboRh.substring(0,1)=="W"?" "+aboRh:aboRh);
  2958. }else{
  2959. aboLastRslt = aboCellTyping +"/"+aboSermTyping +""+(aboRh.substring(0,1)=="W"?" "+aboRh:aboRh);
  2960. abrnblodyn = "Y";
  2961. }
  2962. //과거 혈액형
  2963. if(bfaboCellTyping == bfaboSermTyping){
  2964. bfaboLastRslt = bfaboCellTyping +""+(bfaboRh.substring(0,1)=="W"?" "+bfaboRh:bfaboRh);
  2965. }else{
  2966. bfaboLastRslt = bfaboCellTyping +"/"+bfaboSermTyping +""+(bfaboRh.substring(0,1)=="W"?" "+bfaboRh:bfaboRh);
  2967. }
  2968. // grp_aboinfo.opt_lastabo.value = aboLastRslt;
  2969. // grp_aboinfo.opt_lastrept.value = lastreptdtInfo;
  2970. // grp_aboinfo.sta_bflastabo.text = bfaboLastRslt;
  2971. //혈액형별 색상 지정
  2972. var colorA = "darkorange";
  2973. var colorB = "red";
  2974. var colorO = "blue";
  2975. var colorAB = "#000000";
  2976. var font = "Arial,50,bold";
  2977. var aborh = String(aboLastRslt).substring(0,1);
  2978. // grp_aboinfo.opt_lastabo.style.font = font;
  2979. // grp_aboinfo.opt_celltyping.style.font = font;
  2980. // grp_aboinfo.opt_serumtyping.style.font = font;
  2981. // grp_aboinfo.opt_rh.style.font = font;
  2982. // if(aborh=="A"){
  2983. // if(String(aboLastRslt).substring(0,2) == "AB"){
  2984. // grp_aboinfo.opt_lastabo.style.color = colorAB;
  2985. // grp_aboinfo.opt_celltyping.style.color = colorAB;
  2986. // grp_aboinfo.opt_serumtyping.style.color = colorAB;
  2987. // grp_aboinfo.opt_rh.style.color = colorAB;
  2988. //
  2989. // grp_aboinfo.opt_lastabo.style.selectcolor = colorAB;
  2990. // grp_aboinfo.opt_celltyping.style.selectcolor = colorAB;
  2991. // grp_aboinfo.opt_serumtyping.style.selectcolor = colorAB;
  2992. // grp_aboinfo.opt_rh.style.selectcolor = colorAB;
  2993. //
  2994. // }else{
  2995. // grp_aboinfo.opt_lastabo.style.color = colorA;
  2996. // grp_aboinfo.opt_celltyping.style.color = colorA;
  2997. // grp_aboinfo.opt_serumtyping.style.color = colorA;
  2998. // grp_aboinfo.opt_rh.style.color = colorA;
  2999. //
  3000. // grp_aboinfo.opt_lastabo.style.selectcolor = colorA;
  3001. // grp_aboinfo.opt_celltyping.style.selectcolor = colorA;
  3002. // grp_aboinfo.opt_serumtyping.style.selectcolor = colorA;
  3003. // grp_aboinfo.opt_rh.style.selectcolor = colorA;
  3004. // }
  3005. // }else if(aborh=="B"){
  3006. // grp_aboinfo.opt_lastabo.style.color = colorB;
  3007. // grp_aboinfo.opt_celltyping.style.color = colorB;
  3008. // grp_aboinfo.opt_serumtyping.style.color = colorB;
  3009. // grp_aboinfo.opt_rh.style.color = colorB;
  3010. //
  3011. // grp_aboinfo.opt_lastabo.style.selectcolor = colorB;
  3012. // grp_aboinfo.opt_celltyping.style.selectcolor = colorB;
  3013. // grp_aboinfo.opt_serumtyping.style.selectcolor = colorB;
  3014. // grp_aboinfo.opt_rh.style.selectcolor = colorB;
  3015. // }else if(aborh=="O"){
  3016. // grp_aboinfo.opt_lastabo.style.color = colorO;
  3017. // grp_aboinfo.opt_celltyping.style.color = colorO;
  3018. // grp_aboinfo.opt_serumtyping.style.color = colorO;
  3019. // grp_aboinfo.opt_rh.style.color = colorO;
  3020. //
  3021. // grp_aboinfo.opt_lastabo.style.selectcolor = colorO;
  3022. // grp_aboinfo.opt_celltyping.style.selectcolor = colorO;
  3023. // grp_aboinfo.opt_serumtyping.style.selectcolor = colorO;
  3024. // grp_aboinfo.opt_rh.style.selectcolor = colorO;
  3025. // }
  3026. // if(aboRh.substring(0,1) == "W"){
  3027. // grp_aboinfo.opt_rh.style.font = "Arial,30,bold";
  3028. // }
  3029. // if(aboLastRslt.length > 5){
  3030. // grp_aboinfo.opt_lastabo.style.font = "Arial,25,bold";
  3031. // }
  3032. //
  3033. // //과거혈액형 bfaboRh.substring(0,1)=="W"
  3034. // if(bfaboRh.substring(0,1)=="W" || bfaboLastRslt.length > 5){
  3035. // grp_aboinfo.sta_bflastabo.style.font = "Arial,20,bold";
  3036. // }else{
  3037. // grp_aboinfo.sta_bflastabo.style.font = "Arial,40,bold";
  3038. // }
  3039. //
  3040. // if(String(bfaboLastRslt).substring(0,1)=="A"){
  3041. // if(String(bfaboLastRslt).substring(0,2) == "AB"){
  3042. // grp_aboinfo.sta_bflastabo.style.color = colorAB;
  3043. //
  3044. // }else{
  3045. // grp_aboinfo.sta_bflastabo.style.color = colorA;
  3046. // }
  3047. // }else if(String(bfaboLastRslt).substring(0,1)=="B"){
  3048. // grp_aboinfo.sta_bflastabo.style.color = colorB;
  3049. // }else if(String(bfaboLastRslt).substring(0,1)=="O"){
  3050. // grp_aboinfo.sta_bflastabo.style.color = colorO;
  3051. // }
  3052. //
  3053. // if(param != "btn"){
  3054. // var bdbtype = utlf_transNullToEmpty(ds_temp_getaboinfo.getColumn(0, "bdbtype"));
  3055. // //인지혈액형
  3056. // grp_aboinfo.sta_bdbtype.text = bdbtype;
  3057. // grp_aboinfo.sta_bdbtype.style.font = "Arial,40,bold";
  3058. //
  3059. // if(String(bdbtype).substring(0,1)=="A"){
  3060. // if(String(bdbtype).substring(0,2) == "AB"){
  3061. // grp_aboinfo.sta_bdbtype.style.color = colorAB;
  3062. //
  3063. // }else{
  3064. // grp_aboinfo.sta_bdbtype.style.color = colorA;
  3065. // }
  3066. // }else if(String(bdbtype).substring(0,1)=="B"){
  3067. // grp_aboinfo.sta_bdbtype.style.color = colorB;
  3068. // }else if(String(bdbtype).substring(0,1)=="O"){
  3069. // grp_aboinfo.sta_bdbtype.style.color = colorO;
  3070. // }
  3071. // }
  3072. }
  3073. //큰 버튼 클릭시
  3074. function lf_BlodTypeClickBigBtn(type, param){
  3075. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");//cell typing
  3076. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");//cell type,donor
  3077. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");//serum typing
  3078. var etc01_111 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "111"), "cd");//serum type,donor
  3079. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");//Rh(D)
  3080. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");//Rh(D),donor
  3081. //신생아혈액 추가
  3082. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");//cell typing(신생아)
  3083. var etc01_201 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "201"), "cd");//serum typing(신생아)
  3084. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");//Rh(D)(신생아)
  3085. var cellFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_100+"' || testcd == '"+etc01_110+"' || testcd == '"+etc01_200+"'"); //cell typing
  3086. var serumFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_101+"' || testcd == '"+etc01_101+"' || testcd == '"+etc01_201+"'"); //serum typing
  3087. var rhFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_102+"' || testcd == '"+etc01_112+"' || testcd == '"+etc01_202+"'"); //Rh(D)
  3088. //큰버튼 클릭시
  3089. if(type == "B"){
  3090. //1.포커스가 cell 이면
  3091. if(cell_focus == "Y" && (param=="A" || param=="B" || param=="O" || param=="AB")){
  3092. //1.1 cell 결과 입력
  3093. ds_grid_testlist.rowposition = cellFindRow;
  3094. lf_BlodTypeClick(param);
  3095. ds_grid_testlist.rowposition = serumFindRow;
  3096. lf_BlodTypeClick(param);
  3097. //2.포커스가 serum 이면
  3098. }else if(serum_focus == "Y" && (param=="A" || param=="B" || param=="O" || param=="AB")){
  3099. //2.1 serum 만 결과 입력
  3100. ds_grid_testlist.rowposition = serumFindRow;
  3101. lf_BlodTypeClick(param);
  3102. //grp_aboinfo.opt_serumtyping.value = param;
  3103. //3.포커스가 rh 이면
  3104. }else if(rh_focus == "Y" && (param=="N" || param=="P" || param=="W")){
  3105. //3.1 rh만 결과 입력
  3106. ds_grid_testlist.rowposition = rhFindRow;
  3107. if(param == "N"){
  3108. //lf_BlodNegative();
  3109. lf_BlodRh("-");
  3110. }else if(param == "P"){
  3111. //lf_BlodTypeClick(grp_aboinfo.opt_celltyping.value);
  3112. lf_BlodRh("+");
  3113. }else if(param == "W"){
  3114. //lf_BlodWeakD();
  3115. lf_BlodRh("Weak D");
  3116. }
  3117. }else{
  3118. sysf_messageBox("검사항목을 선택해주세요.", "I");
  3119. return;
  3120. }
  3121. //텍스트로 입력시
  3122. }else{
  3123. //1.포커스가 cell 이면
  3124. if(cell_focus == "Y"){
  3125. //1.1 cell 결과 입력
  3126. ds_grid_testlist.rowposition = cellFindRow;
  3127. lf_BlodTypeClick(param);
  3128. //2.포커스가 serum 이면
  3129. }else if(serum_focus == "Y"){
  3130. //2.1 serum 만 결과 입력
  3131. ds_grid_testlist.rowposition = serumFindRow;
  3132. lf_BlodTypeClick(param);
  3133. //grp_aboinfo.opt_serumtyping.value = param;
  3134. //3.포커스가 rh 이면
  3135. }else if(rh_focus == "Y"){
  3136. //3.1 rh만 결과 입력
  3137. ds_grid_testlist.rowposition = rhFindRow;
  3138. lf_BlodRh(param);
  3139. }else{
  3140. sysf_messageBox("검사항목을 선택해주세요2.", "I");
  3141. return;
  3142. }
  3143. }
  3144. //혈액형 검사결과 셋팅
  3145. lf_aboRsltInfoSet("btn");
  3146. cell_focus = "N";
  3147. serum_focus = "N";
  3148. rh_focus = "N";
  3149. }
  3150. //큰버튼 결과 텍스트 입력시 - 사용안함 (오류)
  3151. function lf_BlodTextInpt(){
  3152. // // var cellValue = grp_aboinfo.opt_celltyping.value;
  3153. // var serumValue = grp_aboinfo.opt_serumtyping.value;
  3154. // var rhValue = grp_aboinfo.opt_rh.value;
  3155. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");//cell typing
  3156. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");//cell type,donor
  3157. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");//serum typing
  3158. var etc01_111 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "111"), "cd");//serum type,donor
  3159. var etc01_102 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "102"), "cd");//Rh(D)
  3160. var etc01_112 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "112"), "cd");//Rh(D),donor
  3161. //신생아혈액 추가
  3162. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");//cell typing
  3163. var etc01_201 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "201"), "cd");//serum typing
  3164. var etc01_202 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "202"), "cd");//Rh(D)
  3165. var cellFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_100+"' || testcd == '"+etc01_110+"' || testcd == '"+etc01_200+"'"); //cell typing
  3166. var serumFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_101+"' || testcd == '"+etc01_101+"' || testcd == '"+etc01_201+"'"); //serum typing
  3167. var rhFindRow = ds_grid_testlist.findRowExpr("testcd == '"+etc01_102+"' || testcd == '"+etc01_112+"' || testcd == '"+etc01_202+"'"); //Rh(D)
  3168. if(cell_focus == "Y"){
  3169. ds_grid_testlist.setColumn(cellFindRow, "bufinptrslt", cellValue);
  3170. lf_gridKeyEvent(cellFindRow, "3");
  3171. }else if(serum_focus == "Y"){
  3172. ds_grid_testlist.setColumn(serumFindRow, "bufinptrslt", serumValue);
  3173. lf_gridKeyEvent(serumFindRow, "3");
  3174. }else if(rh_focus == "Y"){
  3175. ds_grid_testlist.setColumn(rhFindRow, "bufinptrslt", rhValue);
  3176. lf_gridKeyEvent(rhFindRow, "3");
  3177. }
  3178. }
  3179. //=======================================================================================
  3180. // 콜백
  3181. //---------------------------------------------------------------------------------------
  3182. //콜백_검사자 조회
  3183. function cbf_TRLZZ00104(strSvcID, nErrorCode, strErrorMag){
  3184. if(nErrorCode != 0){
  3185. sysf_messageBox("ID: " + strSvcID + " Error: " + strErrorMag, "E009", "");
  3186. }else{
  3187. group2.opt_testpsn.value = ds_temp_acceptnm.getColumn(0, "usernm");
  3188. if(ds_temp_acceptnm.getColumn(0, "usernm") != ""){
  3189. lf_bodyControl(true,parent,"");
  3190. //lf_bodyControl(true,div_cond,"");
  3191. //lf_bodyControl(true,this,"");
  3192. //lf_bodyControl(true,grp_btns,"");
  3193. //div_cond.cp_periodCal.enable = true;
  3194. // 검사자 입력하고 엔터후 바코드입력란에 포커스 가도록 요청
  3195. // ksh 20150226 손기현과장 요청
  3196. //parent.parent.group3.ipt_searchtext.setFocus();
  3197. }else{
  3198. sysf_messageBox("검사자 ID가 정확히 입력되지","E007","");
  3199. group2.ipt_testpsn.setFocus();
  3200. return;
  3201. }
  3202. }
  3203. }
  3204. //콜백_재검
  3205. function cbf_TXLLR80101(strSvcID, nErrorCode, strErrorMag){
  3206. if(nErrorCode != 0){
  3207. sysf_messageBox("ID: " + strSvcID + " Error: " + strErrorMag, "E009", "");
  3208. }
  3209. /*else{
  3210. lf_OnclickBtnRef();
  3211. lf_SetClear();
  3212. }*/
  3213. }
  3214. function group2_ipt_testpsn_onkeydown(obj:Edit, e:KeyEventInfo)
  3215. {
  3216. //lf_KeyEvent(obj.name, e.keycode);
  3217. if(e.keycode == "13"){
  3218. lf_UserNMRef();
  3219. }
  3220. }
  3221. function btn_rsltsize1_onclick(obj:Button, e:ClickEventInfo)
  3222. {
  3223. group2.grd_TestInfoCnts.setFormatColProperty(3, "size", 160);
  3224. group2.grd_TestInfoCnts.setFormatColProperty(4, "size", 160);
  3225. }
  3226. function btn_sizeinit_onclick(obj:Button, e:ClickEventInfo)
  3227. {
  3228. group2.grd_TestInfoCnts.setFormatColProperty(3, "size", 80);
  3229. group2.grd_TestInfoCnts.setFormatColProperty(4, "size", 80);
  3230. }
  3231. function btn_setCmt_onclick(obj:Button, e:ClickEventInfo)
  3232. {
  3233. lf_SetContCmt();
  3234. }
  3235. function group2_cmb_cmt_onitemchanged(obj:Combo, e:ItemChangeEventInfo)
  3236. {
  3237. lf_SetCmt();
  3238. }
  3239. function group2_grd_TestInfoCnts_oncellclick(obj:Grid, e:GridClickEventInfo)
  3240. {
  3241. lf_TestInfoCntsClick(e.row, e.col);
  3242. }
  3243. function group2_grd_TestInfoCnts_onenterdown(obj:Grid, e:GridEditEventInfo)
  3244. {
  3245. obj.updateToDataset();
  3246. var etc01_100 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "100"), "cd");//cell typing
  3247. var etc01_110 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "110"), "cd");//cell type,donor
  3248. //신생아혈액추가
  3249. var etc01_200 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "200"), "cd");//cell typing(신생아)
  3250. //ABO Cell Typing 입력시 ABO Serum Typing, Rh[D] typing 자동으로 입력시킨다. 2014.10.13 김남규
  3251. if( ds_grid_testlist.getColumn(e.row, "testcd") == etc01_100 || ds_grid_testlist.getColumn(e.row, "testcd") == etc01_110 || ds_grid_testlist.getColumn(e.row, "testcd") == etc01_200 ) { //ABO Cell Typing
  3252. ds_grid_testlist.setColumn(e.row + 1, "bufinptrslt", ds_grid_testlist.getColumn(e.row, "bufinptrslt") );
  3253. ds_grid_testlist.setColumn(e.row + 2, "bufinptrslt", "+" );
  3254. lf_gridKeyEvent(e.row, e.col);
  3255. lf_gridKeyEvent(e.row+1, e.col);
  3256. lf_gridKeyEvent(e.row+2, e.col);
  3257. }
  3258. else {
  3259. lf_gridKeyEvent(e.row, e.col);
  3260. }
  3261. }
  3262. function group2_grd_TestInfoCnts_onrbuttondown(obj:Grid, e:GridMouseEventInfo)
  3263. {
  3264. grdf_setSelectedCell(obj, e);
  3265. gRow = e.row;
  3266. gCol = e.col;
  3267. lf_GetMouseDown(e.screenX, e.screenY, e.row, e.col);
  3268. }
  3269. function pm_SubMenu_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo){
  3270. lf_Onmenu(e.id);
  3271. }
  3272. function group2_grd_TestInfoCnts_oncelldblclick(obj:Grid, e:GridClickEventInfo)
  3273. {
  3274. lf_TestInfoCntsDBlclick(e.row, e.col);
  3275. }
  3276. function tea_testcont_canchange(obj:TextArea, e:ChangeEventInfo)
  3277. {
  3278. lf_SoGyeonJeoJang();
  3279. }
  3280. function btn_cmtdel_onclick(obj:Button, e:ClickEventInfo)
  3281. {
  3282. var row = ds_grid_testcmts.rowposition;
  3283. if(row > -1){
  3284. if(ds_grid_testcmts.getRowType(row) == Dataset.ROWTYPE_INSERT){
  3285. ds_grid_testcmts.deleteRow(row);
  3286. }else{
  3287. ds_grid_testcmts.updatecontrol = false;
  3288. ds_grid_testcmts.setRowType(row, Dataset.ROWTYPE_DELETE);
  3289. ds_grid_testcmts.updatecontrol = true;
  3290. }
  3291. }else{
  3292. sysf_messageBox("삭제할 행을 선택하세요.","I","");
  3293. return;
  3294. }
  3295. }
  3296. function btn_testcmtlist_onclick(obj:Button, e:ClickEventInfo)
  3297. {
  3298. frmf_modal("SMLLF00800", "SMLLF00800", null, false,"","","","","","","","","M");
  3299. }
  3300. function ds_grid_testlist_oncolumnchanged(obj:Dataset, e:DSColChangeEventInfo)
  3301. {
  3302. obj.updatecontrol = false;
  3303. if(obj.getColumn(e.row, "selchk") == 1){
  3304. obj.setColumn(e.row, "sel_value", "true");
  3305. obj.setRowType(e.row, Dataset.ROWTYPE_UPDATE);
  3306. }else{
  3307. obj.setColumn(e.row, "sel_value", "false");
  3308. obj.setRowType(e.row, Dataset.ROWTYPE_NORMAL);
  3309. }
  3310. obj.updatecontrol = true;
  3311. }
  3312. function group2_group1_btn_blodWeakD_onclick(obj:Button, e:ClickEventInfo)
  3313. {
  3314. lf_BlodWeakD();
  3315. //lf_BlodRh("Weak D");
  3316. //lf_aboRsltInfoSet("btn");
  3317. }
  3318. function group2_group1_btn_negative_onclick(obj:Button, e:ClickEventInfo)
  3319. {
  3320. lf_BlodNegative();
  3321. //lf_BlodRh("-");
  3322. //lf_aboRsltInfoSet("btn");
  3323. }
  3324. function group2_group1_btn_positive_onclick(obj:Button, e:ClickEventInfo)
  3325. {
  3326. //lf_BlodNegative();
  3327. lf_BlodRh("+");
  3328. lf_aboRsltInfoSet("btn");
  3329. }
  3330. function group2_group1_btn_typeA_onclick(obj:Button, e:ClickEventInfo)
  3331. {
  3332. lf_BlodTypeClick("A");
  3333. ds_grid_testlist.rowposition = ds_grid_testlist.rowposition + 3;
  3334. if (group2.chkChlidBtype.value == "1") {
  3335. lf_BlodTypeClick(" ");
  3336. }else{
  3337. lf_BlodTypeClick("A");
  3338. }
  3339. }
  3340. function group2_group1_btn_typeB_onclick(obj:Button, e:ClickEventInfo)
  3341. {
  3342. lf_BlodTypeClick("B");
  3343. ds_grid_testlist.rowposition = ds_grid_testlist.rowposition + 3;
  3344. if (group2.chkChlidBtype.value == "1") {
  3345. lf_BlodTypeClick(" ");
  3346. }else{
  3347. lf_BlodTypeClick("B");
  3348. }
  3349. }
  3350. function group2_group1_btn_typeO_onclick(obj:Button, e:ClickEventInfo)
  3351. {
  3352. lf_BlodTypeClick("O");
  3353. ds_grid_testlist.rowposition = ds_grid_testlist.rowposition + 3;
  3354. if (group2.chkChlidBtype.value == "1") {
  3355. lf_BlodTypeClick(" ");
  3356. }else{
  3357. lf_BlodTypeClick("O");
  3358. }
  3359. }
  3360. function group2_group1_btn_typeAB_onclick(obj:Button, e:ClickEventInfo)
  3361. {
  3362. lf_BlodTypeClick("AB");
  3363. ds_grid_testlist.rowposition = ds_grid_testlist.rowposition + 3;
  3364. if (group2.chkChlidBtype.value == "1") {
  3365. lf_BlodTypeClick(" ");
  3366. }else{
  3367. lf_BlodTypeClick("AB");
  3368. }
  3369. }
  3370. function group2_group1_btn_antiA_onclick(obj:Button, e:ClickEventInfo)
  3371. {
  3372. lf_Anticlick("Anti-A");
  3373. }
  3374. function group2_group1_btn_antiB_onclick(obj:Button, e:ClickEventInfo)
  3375. {
  3376. lf_Anticlick("Anti-B");
  3377. }
  3378. function group2_group1_btn_plusM_onclick(obj:Button, e:ClickEventInfo)
  3379. {
  3380. lf_puls(" (-)");
  3381. }
  3382. function group2_group1_btn_plusPM_onclick(obj:Button, e:ClickEventInfo)
  3383. {
  3384. lf_puls(" (±)");
  3385. }
  3386. function group2_group1_btn_mom_onclick(obj:Button, e:ClickEventInfo)
  3387. {
  3388. lf_mom(" (Mom)");
  3389. }
  3390. function group2_group1_btn_plus1P_onclick(obj:Button, e:ClickEventInfo)
  3391. {
  3392. lf_puls(" (1+)");
  3393. }
  3394. function group2_group1_btn_plus2P_onclick(obj:Button, e:ClickEventInfo)
  3395. {
  3396. lf_puls(" (2+)");
  3397. }
  3398. function group2_group1_btn_plus3P_onclick(obj:Button, e:ClickEventInfo)
  3399. {
  3400. lf_puls(" (3+)");
  3401. }
  3402. function group2_group1_btn_plus4P_onclick(obj:Button, e:ClickEventInfo)
  3403. {
  3404. lf_puls(" (4+)");
  3405. }
  3406. function group2_group1_btn_ACell_onclick(obj:Button, e:ClickEventInfo)
  3407. {
  3408. lf_cellclick("A-Cell");
  3409. }
  3410. function group2_group1_btn_BCell_onclick(obj:Button, e:ClickEventInfo)
  3411. {
  3412. lf_cellclick("B-Cell");
  3413. }
  3414. function group2_group1_btn_Positive_onclick(obj:Button, e:ClickEventInfo)
  3415. {
  3416. lf_posneg("Positive");
  3417. }
  3418. function group2_group1_btn_Negative_onclick(obj:Button, e:ClickEventInfo)
  3419. {
  3420. lf_posneg("Negative");
  3421. }
  3422. function grp_aboinfo_btn_typeA_Big_onclick(obj:Button, e:ClickEventInfo)
  3423. {
  3424. lf_BlodTypeClickBigBtn("B","A");
  3425. }
  3426. function grp_aboinfo_btn_typeB_Big_onclick(obj:Button, e:ClickEventInfo)
  3427. {
  3428. lf_BlodTypeClickBigBtn("B","B");
  3429. }
  3430. function grp_aboinfo_btn_typeO_Big_onclick(obj:Button, e:ClickEventInfo)
  3431. {
  3432. lf_BlodTypeClickBigBtn("B","O");
  3433. }
  3434. function grp_aboinfo_btn_typeAB_Big_onclick(obj:Button, e:ClickEventInfo)
  3435. {
  3436. lf_BlodTypeClickBigBtn("B","AB");
  3437. }
  3438. function grp_aboinfo_btn_negative_Big_onclick(obj:Button, e:ClickEventInfo)
  3439. {
  3440. lf_BlodTypeClickBigBtn("B","N");
  3441. }
  3442. function grp_aboinfo_btn_blodWeakD_Big_onclick(obj:Button, e:ClickEventInfo)
  3443. {
  3444. lf_BlodTypeClickBigBtn("B","W");
  3445. }
  3446. function grp_aboinfo_btn_positive_Big_onclick(obj:Button, e:ClickEventInfo)
  3447. {
  3448. lf_BlodTypeClickBigBtn("B","P");
  3449. }
  3450. function opt_celltyping_oneditclick(obj:Edit, e:EditClickEventInfo)
  3451. {
  3452. cell_focus = "Y";
  3453. serum_focus = "N";
  3454. rh_focus = "N";
  3455. }
  3456. function opt_serumtyping_oneditclick(obj:Edit, e:EditClickEventInfo)
  3457. {
  3458. cell_focus = "N";
  3459. serum_focus = "Y";
  3460. rh_focus = "N";
  3461. }
  3462. function opt_rh_oneditclick(obj:Edit, e:EditClickEventInfo)
  3463. {
  3464. cell_focus = "N";
  3465. serum_focus = "N";
  3466. rh_focus = "Y";
  3467. }
  3468. function opt_serumtyping_onkeydown(obj:Edit, e:KeyEventInfo)
  3469. {
  3470. if(e.keycode == "13"){
  3471. //lf_BlodTextInpt();
  3472. // lf_BlodTypeClickBigBtn("T", grp_aboinfo.opt_serumtyping.value);
  3473. }
  3474. }
  3475. function opt_rh_onkeydown(obj:Edit, e:KeyEventInfo)
  3476. {
  3477. if(e.keycode == "13"){
  3478. //lf_BlodTextInpt();
  3479. // lf_BlodTypeClickBigBtn("T", grp_aboinfo.opt_rh.value);
  3480. }
  3481. }
  3482. function opt_celltyping_onkeydown(obj:Edit, e:KeyEventInfo)
  3483. {
  3484. if(e.keycode == "13"){
  3485. //lf_BlodTextInpt();
  3486. // lf_BlodTypeClickBigBtn("T", grp_aboinfo.opt_celltyping.value);
  3487. }
  3488. }
  3489. function opt_celltyping_canchange(obj:Edit, e:ChangeEventInfo)
  3490. {
  3491. //lf_BlodTextInpt();
  3492. }
  3493. function opt_rh_canchange(obj:Edit, e:ChangeEventInfo)
  3494. {
  3495. //lf_BlodTextInpt();
  3496. }
  3497. function opt_serumtyping_canchange(obj:Edit, e:ChangeEventInfo)
  3498. {
  3499. //lf_BlodTextInpt();
  3500. }
  3501. function btn_reset_onclick(obj:Button, e:ClickEventInfo)
  3502. {
  3503. if(ds_grd_patlist.rowposition > -1){
  3504. lf_PatListClick(ds_grd_patlist.rowposition);
  3505. }
  3506. /*ds_grid_testlist.clearData();
  3507. ds_grid_testcmts.clearData();
  3508. ds_temp_abnormallist.clearData();
  3509. if(!utlf_isNull(objects.get_item("ds_hidden_DJGGParm"))){
  3510. ds_hidden_DJGGParm.clearData();
  3511. }
  3512. ds_cond_patinfo.clearData();
  3513. ds_temp_testcont.clearData();
  3514. ds_init_testconttsectcd.clearData();
  3515. //ds_temp_acceptnm.clearData();
  3516. //group2.ipt_testpsn.value = "";
  3517. //group2.opt_testpsn.value = "";
  3518. p_isedit = false;
  3519. lf_CMTPCD_ChangeNodeset();
  3520. grp_aboinfo.sta_pid.text = "";
  3521. grp_aboinfo.sta_bdbtype.text = "";
  3522. grp_aboinfo.sta_bflastabo.text = "";
  3523. grp_aboinfo.opt_celltyping.value = "";
  3524. grp_aboinfo.opt_rh.value = "";
  3525. grp_aboinfo.opt_serumtyping.value = "";
  3526. grp_aboinfo.opt_lastabo.value = "";
  3527. grp_aboinfo.opt_celltypingM.value = "";
  3528. grp_aboinfo.opt_serumtypingM.value = "";
  3529. grp_aboinfo.opt_rhM.value = "";
  3530. grp_aboinfo.opt_lastrept.value = "";*/
  3531. }
  3532. function opt_rh_onkeyup(obj:Edit, e:KeyEventInfo)
  3533. {
  3534. cell_focus = "N";
  3535. serum_focus = "N";
  3536. rh_focus = "Y";
  3537. }
  3538. function opt_celltyping_onkeyup(obj:Edit, e:KeyEventInfo)
  3539. {
  3540. cell_focus = "Y";
  3541. serum_focus = "N";
  3542. rh_focus = "N";
  3543. }
  3544. function opt_serumtyping_onkeyup(obj:Edit, e:KeyEventInfo)
  3545. {
  3546. cell_focus = "N";
  3547. serum_focus = "Y";
  3548. rh_focus = "N";
  3549. }
  3550. function lf_makeSendSoGyeon_backup(){
  3551. var cntSG = ds_temp_testcont.rowcount; //소견 저장 개수
  3552. var vSndSG = "m▦testcontcd▦execdeptcd▦testcont▦testcontkind▩";
  3553. for(var i = 1; i <= cntSG; i++){
  3554. if(!utlf_isNull(ds_temp_testcont.getColumn(i,"iud"))){
  3555. vSndSG += "u" + "▦"
  3556. + ds_temp_testcont.getColumn(i,"testcontcd") + "▦"
  3557. + ds_temp_testcont.getColumn(i,"execdeptcd") + "▦"
  3558. + ds_temp_testcont.getColumn(i,"testcont") + "▦"
  3559. + ds_temp_testcont.getColumn(i,"testcontkind") + "▩";
  3560. }
  3561. }
  3562. // var sInDsName = dsf_createDsRow("ds_temp_testcont"
  3563. // , [{col: "", val: group2.ipt_testpsn.value}]);
  3564. }
  3565. function lf_makeSendSoGyeon(){
  3566. //trace('소견222');
  3567. var cntSG = ds_temp_testcont.rowcount; //소견 저장 개수
  3568. for(var i = 0; i < cntSG; i++){
  3569. if(utlf_transNullToEmpty(ds_temp_testcont.getColumn(i,"iud")) != ""){
  3570. nRow = ds_vSndSG.addRow();
  3571. // ds_vSndSG.setColumn(nRow,"testcontcd",utlf_transNullToEmpty(ds_temp_testcont.getColumn(i,"testcontcd")));
  3572. ds_vSndSG.setColumn(nRow,"testcontcd",'-');
  3573. ds_vSndSG.setColumn(nRow,"execdeptcd",utlf_transNullToEmpty(ds_temp_testcont.getColumn(i,"execdeptcd")));
  3574. ds_vSndSG.setColumn(nRow,"testcont",utlf_transNullToEmpty(ds_temp_testcont.getColumn(i,"testcont")));
  3575. ds_vSndSG.setColumn(nRow,"testcontkind",utlf_transNullToEmpty(ds_temp_testcont.getColumn(i,"testcontkind")));
  3576. }
  3577. }
  3578. }
  3579. function lf_autoCmtJudg(sJudgmthd, sJudgVal, sSingQ, sBaseVal, sRefminvalsinq, sRefminval, sRefmaxvalsinq, sRefmaxval, judgmark, criticalmark)
  3580. {
  3581. var bRtnFlag = false;
  3582. if (sJudgmthd == "-") bRtnFlag = true; //판정방법이 없음이면 true
  3583. else if(sJudgmthd == "1"){ //Low
  3584. if (judgmark == "L") bRtnFlag = true;
  3585. }
  3586. else if(sJudgmthd == "2"){ //High
  3587. if (judgmark == "H") bRtnFlag = true;
  3588. }
  3589. else if(sJudgmthd == "3"){ //Crit
  3590. if (criticalmark == "C") bRtnFlag = true;
  3591. }
  3592. else if(sJudgmthd == "4"){ //범위
  3593. var pSingQ = "-";
  3594. if (sRefminvalsinq == "1") pSingQ = "<=";
  3595. if (sRefminvalsinq == "2") pSingQ = "<";
  3596. bRtnFlag = lf_singqJudg(sJudgVal, pSingQ, sRefminval);
  3597. if (bRtnFlag){ //하한 조건이 만족하면 상한도 체크
  3598. pSingQ = "-";
  3599. if (sRefmaxvalsinq == "1") pSingQ = ">=";
  3600. if (sRefmaxvalsinq == "2") pSingQ = ">";
  3601. bRtnFlag = lf_singqJudg(sJudgVal, pSingQ, sRefmaxval);
  3602. }
  3603. }
  3604. else if(sJudgmthd == "5"){ //패턴
  3605. var pSingQ = "-";
  3606. if (sSingQ == "1") pSingQ = "=";
  3607. if (sSingQ == "2") pSingQ = "like";
  3608. bRtnFlag = lf_singqJudg(sJudgVal, pSingQ, sBaseVal);
  3609. } else {
  3610. bRtnFlag = false;
  3611. }
  3612. return bRtnFlag;
  3613. }
  3614. function lf_singqJudg(lVal, sSingQ, rVal)
  3615. {
  3616. var bRtnFlag = false;
  3617. if (sSingQ == "-") // 없음
  3618. {
  3619. bRtnFlag = true;
  3620. }
  3621. else if (sSingQ == ">=") // >=
  3622. {
  3623. if (parseFloat(lVal) >= parseFloat(rVal)) {
  3624. bRtnFlag = true;
  3625. }
  3626. } else if (sSingQ == ">") // >
  3627. {
  3628. if (parseFloat(lVal) > parseFloat(rVal)) {
  3629. bRtnFlag = true;
  3630. }
  3631. } else if (sSingQ == "<=") // <=
  3632. {
  3633. if (parseFloat(lVal) <= parseFloat(rVal)) {
  3634. bRtnFlag = true;
  3635. }
  3636. } else if (sSingQ == "<") // <
  3637. {
  3638. if (parseFloat(lVal) < parseFloat(rVal)) {
  3639. bRtnFlag = true;
  3640. }
  3641. } else if (sSingQ == "=") // =
  3642. {
  3643. //if (StringHelper.strEquals(lVal, rVal)) {
  3644. if (lVal == rVal) {
  3645. bRtnFlag = true;
  3646. }
  3647. } else if (sSingQ == "like") // like
  3648. {
  3649. if (lVal.indexOf(rVal) > -1) {
  3650. bRtnFlag = true;
  3651. }
  3652. } else {
  3653. bRtnFlag = false;
  3654. }
  3655. return bRtnFlag;
  3656. }
  3657. /* 자동소견 추가 */
  3658. // 1. 검사코드가 사용하는 소견 목록 조회
  3659. // 2. 검사항목별 판정 (judg 컬럼)
  3660. // 3. 소견순번 DS 생성
  3661. // for (검사항목)
  3662. // {
  3663. // 1. 소견순번에 maxcnt(소견에 딸린 인수갯수), chkcnt(판정이 true인 갯수)
  3664. // 2. 계산식이면 검사코드순번에 해당하는 검사코드순번(A1, A2등) 을 판정값으로 replace
  3665. // }
  3666. // 4. 판정
  3667. // for(소견순번DS)
  3668. // {
  3669. // 계산식유형이
  3670. // 1. OR 면 chkcnt > 0 then true
  3671. // 2. AND 면 chkcnt == maxcnt then true
  3672. // 3. 계산식이면 eval 처리
  3673. // }
  3674. function lf_setAutoCmt(iRow)
  3675. {
  3676. ds_temp_chkstr.addColumn( "judg", "string" );
  3677. //결과 입력시 해당 검사코드를 포함하는 자동소견을 필터링 한다.
  3678. ds_temp_chkstr.filter("(spccd=='000' && tclscd=='"+ds_grid_testlist.getColumn(iRow, "testcd") + "') || (spccd!='000' && chkstring=='"+ds_grid_testlist.getColumn(iRow, "chkstring")+"')");
  3679. var dsCopy_chkstr = new Dataset;
  3680. dsCopy_chkstr.Name = "dsCopy_chkstr";
  3681. this.addChild("dsCopy_chkstr", dsCopy_chkstr);
  3682. dsCopy_chkstr.loadXML(ds_temp_chkstr.saveXML());
  3683. dsCopy_chkstr.filter("(spccd=='000' && tclscd=='"+ds_grid_testlist.getColumn(iRow, "testcd") + "') || (spccd!='000' && chkstring=='"+ds_grid_testlist.getColumn(iRow, "chkstring")+"')");
  3684. //필터링된 목록의 시행부서^소견코드로 다시 필터링을 한다.
  3685. var strfilter = "";
  3686. for (var z = 0 ; z < dsCopy_chkstr.rowcount; z++)
  3687. {
  3688. var tsectcd = dsCopy_chkstr.getColumn(z, "tsectcd");
  3689. var cmtcdseqno = dsCopy_chkstr.getColumn(z, "cmtcdseqno");
  3690. // if (i==0) strfilter = "(tsectcd=='"+tsectcd+"' && cmtcdseqno=='" + cmtcdseqno + "')";
  3691. // else strfilter += " || (tsectcd=='"+tsectcd+"' && cmtcdseqno=='" + cmtcdseqno + "')";
  3692. strfilter = "(tsectcd=='"+tsectcd+"' && cmtcdseqno=='" + cmtcdseqno + "')";
  3693. // }
  3694. if (strfilter != "") ds_temp_chkstr.filter(strfilter);
  3695. for (var i = 0 ; i < ds_temp_chkstr.rowcount; i++)
  3696. {
  3697. var sJudgKind = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "judgrsltkind"));
  3698. var sSinq = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "basevalsinq"));
  3699. var sBaseVal = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "baseval"));
  3700. var judgcond = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "judgcond"));
  3701. var sJudgmthd = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "judgmthd"));
  3702. var sRefminvalsinq = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "refminvalsinq"));
  3703. var sRefminval = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "refminval"));
  3704. var sRefmaxvalsinq = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "refmaxvalsinq"));
  3705. var sRefmaxval = utlf_transNullToEmpty(ds_temp_chkstr.getColumn(i, "refmaxval"));
  3706. //검사코드별 결과를 가져와서 판정을 한다.
  3707. var iFindRow = -1;
  3708. var spccd = ds_temp_chkstr.getColumn(i, "spccd");
  3709. if (spccd == "000"){
  3710. iFindRow = ds_grid_testlist.findRowExpr( "testcd=='" + ds_temp_chkstr.getColumn(i, "tclscd") + "'");
  3711. }else{
  3712. iFindRow = ds_grid_testlist.findRowExpr( "chkstring=='" + ds_temp_chkstr.getColumn(i, "chkstring") + "'");
  3713. }
  3714. if (iFindRow > -1)
  3715. {
  3716. var orgrst = utlf_transNullToEmpty(ds_grid_testlist.getColumn(iFindRow,"inptrslt"));
  3717. var viewrst = utlf_transNullToEmpty(ds_grid_testlist.getColumn(iFindRow,"reptrslt"));
  3718. var judgmark = utlf_transNullToEmpty(ds_grid_testlist.getColumn(iFindRow,"judgmark"));
  3719. var criticalmark = utlf_transNullToEmpty(ds_grid_testlist.getColumn(iFindRow,"criticalmark"));
  3720. var bJudg = false;
  3721. if (sJudgKind == "1")// 실제값 orgrst 비교
  3722. {
  3723. bJudg = lf_autoCmtJudg(sJudgmthd, orgrst, sSinq, sBaseVal, sRefminvalsinq, sRefminval, sRefmaxvalsinq, sRefmaxval, judgmark, criticalmark);
  3724. }
  3725. else
  3726. {
  3727. bJudg = lf_autoCmtJudg(sJudgmthd, viewrst, sSinq, sBaseVal, sRefminvalsinq, sRefminval, sRefmaxvalsinq, sRefmaxval, judgmark, criticalmark);
  3728. }
  3729. ds_temp_chkstr.setColumn(i, "judg", bJudg);
  3730. }else{
  3731. ds_temp_chkstr.setColumn(i, "judg", false);
  3732. }
  3733. }
  3734. if(this.objects["dsTmp_chkstr"] == null){
  3735. var dsTmp_chkstr = new Dataset;
  3736. dsTmp_chkstr.Name = "dsTmp_chkstr";
  3737. this.addChild("dsTmp_chkstr", dsTmp_chkstr);
  3738. }
  3739. var dsTmp_chkstr = this.objects["dsTmp_chkstr"];
  3740. dsTmp_chkstr.clear();
  3741. dsTmp_chkstr.addColumn( "cmtcdseqno", "string" );
  3742. dsTmp_chkstr.addColumn( "iMaxCnt", "int" );
  3743. dsTmp_chkstr.addColumn( "iChkCnt", "int" );
  3744. dsTmp_chkstr.addColumn( "judgcond", "string" );
  3745. dsTmp_chkstr.addColumn( "cmtcnts", "string" );
  3746. dsTmp_chkstr.addColumn( "cmtdetlcnts", "string" );
  3747. dsTmp_chkstr.addColumn( "calform", "string" );
  3748. for (var i = 0 ; i < ds_temp_chkstr.rowcount; i++)
  3749. {
  3750. var cmtcdseqno = ds_temp_chkstr.getColumn(i, "cmtcdseqno");
  3751. var judgcond = ds_temp_chkstr.getColumn(i, "judgcond");
  3752. var judg = ds_temp_chkstr.getColumn(i, "judg");
  3753. var ijudg = (judg=="true"?1:0);
  3754. var sFindRow = dsTmp_chkstr.findRowExpr("cmtcdseqno=='" + cmtcdseqno + "'");
  3755. if (sFindRow == -1)
  3756. {
  3757. var nRow = dsTmp_chkstr.addRow();
  3758. dsTmp_chkstr.setColumn(nRow, "cmtcdseqno", cmtcdseqno);
  3759. dsTmp_chkstr.setColumn(nRow, "iMaxCnt", 1);
  3760. dsTmp_chkstr.setColumn(nRow, "iChkCnt", ijudg);
  3761. dsTmp_chkstr.setColumn(nRow, "judgcond", ds_temp_chkstr.getColumn(i, "judgcond"));
  3762. dsTmp_chkstr.setColumn(nRow, "cmtcnts", ds_temp_chkstr.getColumn(i, "cmtcnts"));
  3763. dsTmp_chkstr.setColumn(nRow, "cmtdetlcnts", ds_temp_chkstr.getColumn(i, "cmtdetlcnts"));
  3764. dsTmp_chkstr.setColumn(nRow, "calform", ds_temp_chkstr.getColumn(i, "calform"));
  3765. if (judgcond == "3")//계산식
  3766. {
  3767. var calform = dsTmp_chkstr.getColumn(nRow, "calform");
  3768. var tclscdseqno = ds_temp_chkstr.getColumn(i, "tclscdseqno");
  3769. dsTmp_chkstr.setColumn(nRow, "calform", calform.replace(tclscdseqno, ijudg));
  3770. }
  3771. }else{
  3772. dsTmp_chkstr.setColumn(sFindRow, "iMaxCnt", (dsTmp_chkstr.getColumn(sFindRow,"iMaxCnt") + 1));
  3773. dsTmp_chkstr.setColumn(sFindRow, "iChkCnt", (dsTmp_chkstr.getColumn(sFindRow,"iChkCnt") + ijudg));
  3774. if (judgcond == "3")//계산식
  3775. {
  3776. var calform = dsTmp_chkstr.getColumn(sFindRow, "calform");
  3777. var tclscdseqno = ds_temp_chkstr.getColumn(i, "tclscdseqno");
  3778. dsTmp_chkstr.setColumn(sFindRow, "calform", calform.replace(tclscdseqno, ijudg));
  3779. }
  3780. }
  3781. }
  3782. var bAutoCmtJudg = false;
  3783. ds_autocmt.clearData();
  3784. ds_autocmt.addRow()
  3785. ds_autocmt.setColumn(0, "flag", "F");
  3786. ds_autocmt.setColumn(0, "cmttext", "");
  3787. // 판정조건 (-:없음, 1:OR, 2:AND, 3:계산식)
  3788. for (var i = 0 ; i < dsTmp_chkstr.rowcount; i++)
  3789. {
  3790. var judgcond = dsTmp_chkstr.getColumn(i, "judgcond");
  3791. var iMaxCnt = dsTmp_chkstr.getColumn(i, "iMaxCnt");
  3792. var iChkCnt = dsTmp_chkstr.getColumn(i, "iChkCnt");
  3793. if (judgcond == "-" || judgcond == "1")
  3794. {
  3795. if (iChkCnt > 0) bAutoCmtJudg = true;
  3796. }
  3797. else if (judgcond == "2")
  3798. {
  3799. if (iMaxCnt == iChkCnt) bAutoCmtJudg = true;
  3800. }
  3801. else if (judgcond == "3")
  3802. {
  3803. var calform = dsTmp_chkstr.getColumn(i, "calform");
  3804. calform = calform.replace("AND", "&&");
  3805. calform = calform.replace("and", "&&");
  3806. calform = calform.replace("OR", "||");
  3807. calform = calform.replace("or", "||");
  3808. //환자기본정보 파라미터 replace
  3809. // if (ds_patBaseCalcInfo.rowcount > 0)
  3810. // {
  3811. // for (var k = 0; k < ds_patBaseCalcInfo.rowcount; k++) {
  3812. // var sTag = "";
  3813. // if(utlf_transNullToEmpty(ds_patBaseCalcInfo.getColumn(k,"vsrecord")) == ""){
  3814. //
  3815. // }
  3816. // else{
  3817. // if ( !utlf_transNullToEmpty(ds_patBaseCalcInfo.getColumn(k,"vsrecord")).isNumber()
  3818. // && !utlf_transNullToEmpty(ds_patBaseCalcInfo.getColumn(k,"vsrecord")).isFloat() ) {
  3819. // sTag = "'";
  3820. // }
  3821. // }
  3822. // calform = calform.replace(ds_patBaseCalcInfo.getColumn(k, "vsname"), sTag + utlf_transNullToEmpty(ds_patBaseCalcInfo.getColumn(k, "vsrecord")) + sTag);
  3823. //
  3824. // }
  3825. //
  3826. // }
  3827. var bAutoCmtJudg = false;
  3828. try{
  3829. bAutoCmtJudg = eval(calform); //eval("if (" + calform + ") { 1; } else { 0; } ");
  3830. }catch(e){}
  3831. }
  3832. if (bAutoCmtJudg)
  3833. {
  3834. ds_autocmt.setColumn(0, "flag", "T");
  3835. ds_autocmt.setColumn(0, "cmttext", dsTmp_chkstr.getColumn(i, "cmtdetlcnts"));
  3836. break;
  3837. }
  3838. }
  3839. //
  3840. // // 서브밋호출
  3841. // tranf_submit({
  3842. // id: "TRLLR80105"
  3843. // , service: "rsltmngtapp.RsltMngt"
  3844. // , method: "reqGetAutoCmt"
  3845. // , inds : "args="+sInDsName+" values=ds_searchcmt"
  3846. // , outds: "ds_autocmt=autocmt"
  3847. // , callback: "cbf_SSLLR80100"
  3848. // , async: false
  3849. // });
  3850. var sAutoCmt, sAddText, sSetText, sPreText;
  3851. if (utlf_transNullToEmpty(ds_autocmt.getColumn(0,"flag")) == "T"){
  3852. sAutoCmt = utlf_transNullToEmpty(ds_temp_testcont.getColumn(0,"testcont"));
  3853. sAddText = utlf_transNullToEmpty(ds_autocmt.getColumn(0,"cmttext"));
  3854. for (var i = 0; i < gv_preautocmtarr.length; i++) {
  3855. if (gv_preautocmtarr[i] == sAddText) {
  3856. // 조회 해온 소견과 이전 조회 소견이 같다면 중단
  3857. // if(grp2.cmt_extext.visible){
  3858. // lf_hiddentext();
  3859. // }
  3860. continue;//return;
  3861. }
  3862. }
  3863. gv_preautocmtarr[gv_preautocmtarr.length] = sAddText;
  3864. // sPreText = gv_preautocmt;
  3865. //
  3866. // if(sPreText.length == 0)
  3867. // {
  3868. // gv_preautocmt = sAddText;
  3869. // } else
  3870. // {
  3871. // if (sAddText == sPreText)
  3872. // {
  3873. // // 조회 해온 소견과 이전 조회 소견이 같다면 중단
  3874. // if(grp2.cmt_extext.visible){
  3875. // lf_hiddentext();
  3876. // }
  3877. // return;
  3878. // }
  3879. // }
  3880. if (sAutoCmt.length == 1){
  3881. ds_temp_testcont.setColumn(0,"testcont","");
  3882. sSetText = sAddText;
  3883. } else
  3884. {
  3885. sSetText = sAutoCmt + "\n" + "\n" + sAddText;
  3886. }
  3887. ds_temp_testcont.setColumn(0,"testcont",sSetText);
  3888. // ds_temp_testcont.setColumn(0,"testcont",sSetText);
  3889. // ds_temp_testcont.setColumn(0,"iud","i");
  3890. //20150116 testcontcd 오류 관련 수정
  3891. var curCmptcd = utlf_transNullToEmpty(group2.cmb_cmt.value);
  3892. ds_temp_testcont.setColumn(0,"testcontcd",curCmptcd);
  3893. p_isedit = true;
  3894. //gv_isedit = "true";
  3895. // if(!grp2.cmt_extext.visible){
  3896. // //lf_hiddentext(); //값입력할때 불편해서 주석.2014-10-21 김정권선생님
  3897. // }
  3898. } else{
  3899. if(utlf_transNullToEmpty(ds_autocmt.getColumn(0,"cmttext")).length >0){
  3900. sysf_messageBox(utlf_transNullToEmpty(ds_autocmt.getColumn(0,"cmttext")) , "I007" ,"");
  3901. }
  3902. // if(grp2.cmt_extext.visible){
  3903. // lf_hiddentext();
  3904. // }
  3905. continue;//return;
  3906. }
  3907. }//for
  3908. }
  3909. function SSLBR80100_onkeydown(obj:Form, e:KeyEventInfo)
  3910. {
  3911. if(e.keycode == 115){
  3912. lf_onclickBtnRef();
  3913. }
  3914. var num = grd_patList.currentrow;
  3915. if(e.keycode == 33){ //PAGEUP
  3916. if(num == 0){
  3917. //첫번째행
  3918. }else{
  3919. ds_grd_patlist.rowposition = num-1;
  3920. //grp3.grd_patList.currentrow(num-1);
  3921. lf_PatListClick(num-1);
  3922. }
  3923. }else if(e.keycode == 34){ //PAGEDN
  3924. if((num+1) == ds_grd_patlist.rowcount){
  3925. //맨아래행
  3926. } else{
  3927. ds_grd_patlist.rowposition = num+1;
  3928. lf_PatListClick(num+1);
  3929. }
  3930. }
  3931. }
  3932. function btn_excmt_onclick(obj:Button, e:ClickEventInfo)
  3933. {
  3934. lf_hiddentext();
  3935. }
  3936. //소견상세 보이기/숨기기
  3937. function lf_hiddentext(){
  3938. if(cmt_extext.visible){ //상세내역textarea
  3939. cmt_extext.visible = false;
  3940. //cmt_excap.visible = false;
  3941. //stc_cmtline.visible = false;
  3942. cmt_excap2.visible =false ;
  3943. cmt_exbtn.visible = false;
  3944. cmt_exbtn6.visible = false;
  3945. }else{
  3946. cmt_extext.visible = true;
  3947. //cmt_excap.visible = true;
  3948. //stc_cmtline.visible = true;
  3949. cmt_excap2.visible =true ;
  3950. cmt_exbtn.visible =true ;
  3951. cmt_exbtn6.visible = true;
  3952. }
  3953. }
  3954. function grp2_cmt_exbtn_onclick(obj:Button, e:ClickEventInfo)
  3955. {
  3956. lf_hiddentext();
  3957. }
  3958. function group2_group1_button44_onclick(obj:Button, e:ClickEventInfo)
  3959. {
  3960. lf_BlodTypeNewClick("A");
  3961. if (group2.chkChlidBtype.value == "1") {
  3962. lf_BlodTypeNewClick(" ");
  3963. }else{
  3964. lf_BlodTypeNewClick("A");
  3965. }
  3966. }
  3967. function group2_group1_button43_onclick(obj:Button, e:ClickEventInfo)
  3968. {
  3969. lf_BlodTypeNewClick("B");
  3970. if (group2.chkChlidBtype.value == "1") {
  3971. lf_BlodTypeNewClick(" ");
  3972. }else{
  3973. lf_BlodTypeNewClick("B");
  3974. }
  3975. }
  3976. function group2_group1_button45_onclick(obj:Button, e:ClickEventInfo)
  3977. {
  3978. lf_BlodTypeNewClick("O");
  3979. if (group2.chkChlidBtype.value == "1") {
  3980. lf_BlodTypeNewClick(" ");
  3981. }else{
  3982. lf_BlodTypeNewClick("O");
  3983. }
  3984. }
  3985. function group2_group1_button46_onclick(obj:Button, e:ClickEventInfo)
  3986. {
  3987. lf_BlodTypeNewClick("AB");
  3988. if (group2.chkChlidBtype.value == "1") {
  3989. lf_BlodTypeNewClick(" ");
  3990. }else{
  3991. lf_BlodTypeNewClick("AB");
  3992. }
  3993. }
  3994. function lf_BlodTypeNewClick(blodtype){
  3995. var row = ds_grid_testlist.rowposition;
  3996. var returnValue = "Y";
  3997. var testcd = ds_grid_testlist.getColumn(row, "testcd");
  3998. var etc01_229 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "229"), "cd");
  3999. var etc01_230 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "230"), "cd");
  4000. var etc01_101 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "101"), "cd");
  4001. var etc01_104 = ds_init_lb1301.getColumn(ds_init_lb1301.findRow("etc01", "104"), "cd");
  4002. //이재오 2012 09 19
  4003. //검사코드 row 찾기
  4004. var findRowNumF = ds_grid_testlist.findRow("testcd", etc01_229);
  4005. var findRowNumG = ds_grid_testlist.findRow("testcd", etc01_230);
  4006. //SERUN 검사코드 row 찾기
  4007. var findRowNumI = ds_grid_testlist.findRow("testcd", etc01_101);
  4008. var findRowNumJ = ds_grid_testlist.findRow("testcd", etc01_104);
  4009. //이재오 추가 2013 06 01 종합판정
  4010. if(findRowNumF < 1) findRowNumF = ds_grid_testlist.findRow("testcd", etc01_229);
  4011. //이재오 추가 2013 06 01 종합판정
  4012. if(findRowNumG < 1) findRowNumG = ds_grid_testlist.findRow("testcd", etc01_230);
  4013. //이재오 추가 2013 06 01 종합판정
  4014. if(findRowNumI < 1) findRowNumI = ds_grid_testlist.findRow("testcd", etc01_101);
  4015. //이재오 추가 2013 06 01 종합판정
  4016. if(findRowNumJ < 1) findRowNumJ = ds_grid_testlist.findRow("testcd", etc01_104);
  4017. ds_grid_testlist.addColumn("color","string");
  4018. ds_grid_testlist.setColumn(row, "color", "#000000");
  4019. group2.grd_TestInfoCnts.updateToDataset();
  4020. // a cell
  4021. if(findRowNumF > 0) {
  4022. ds_grid_testlist.rowposition = findRowNumF;
  4023. if ( blodtype == "A" ) {
  4024. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "-");
  4025. }
  4026. if ( blodtype == "B" ) {
  4027. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "3+");
  4028. }
  4029. if ( blodtype == "O" ) {
  4030. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "3+");
  4031. }
  4032. if ( blodtype == "AB" ) {
  4033. ds_grid_testlist.setColumn(findRowNumF, "bufinptrslt", "-");
  4034. }
  4035. lf_BlodTypeIns();
  4036. }
  4037. // b cell
  4038. if(findRowNumG > 0) {
  4039. ds_grid_testlist.rowposition = findRowNumG;
  4040. if ( blodtype == "A" ) {
  4041. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "3+");
  4042. }
  4043. if ( blodtype == "B" ) {
  4044. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "-");
  4045. }
  4046. if ( blodtype == "O" ) {
  4047. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "3+");
  4048. }
  4049. if ( blodtype == "AB" ) {
  4050. ds_grid_testlist.setColumn(findRowNumG, "bufinptrslt", "-");
  4051. }
  4052. lf_BlodTypeIns();
  4053. }
  4054. // SERUN TYPE INSERT
  4055. if(findRowNumI > 0) {
  4056. ds_grid_testlist.rowposition = findRowNumI;
  4057. ds_grid_testlist.setColumn(findRowNumI, "bufinptrslt", blodtype);
  4058. lf_BlodTypeIns();
  4059. }
  4060. if(findRowNumJ > 0) {
  4061. ds_grid_testlist.rowposition = findRowNumJ;
  4062. ds_grid_testlist.setColumn(findRowNumJ, "bufinptrslt", blodtype);
  4063. lf_BlodTypeIns();
  4064. }
  4065. ds_grid_testlist.rowposition = row;
  4066. lf_TestInfoCntsClick(row, 3);
  4067. }
  4068. function group2_button41_onclick(obj:Button, e:ClickEventInfo)
  4069. {
  4070. lf_GetBMTInfo("list")
  4071. }
  4072. function lf_GetBMTInfo(gbn){
  4073. //--------------------------------------------------------------------
  4074. // BMT 실시 정보
  4075. dsf_createDsRow("ds_send"
  4076. , [{col: "bmtsearchgbn", val: gbn}
  4077. , {col: "pid", val: ds_cond_patinfo.getColumn(0, "pid")}]);
  4078. if(gbn == "info"){
  4079. var oParam = {};
  4080. oParam.id = "TRLBT10209";
  4081. oParam.service = "transfusionmngtapp.PseuDeliveryRgst";
  4082. oParam.method = "reqGetBmtExecInfo";
  4083. oParam.inds = "cond=ds_send";
  4084. oParam.outds = "ds_BmtExecInfo=getBmtExecInfo";
  4085. oParam.async = false;
  4086. //oParam.callback = "cf_TRLBT10209";
  4087. tranf_submit(oParam);
  4088. }else if(gbn == "list"){
  4089. var oParam = {};
  4090. oParam.id = "TRLBT10210";
  4091. oParam.service = "transfusionmngtapp.PseuDeliveryRgst";
  4092. oParam.method = "reqGetBmtExecInfo";
  4093. oParam.inds = "cond=ds_send";
  4094. oParam.outds = "ds_BmtExecInfoList=getBmtExecInfoList";
  4095. oParam.async = false;
  4096. //oParam.callback = "cf_TRLBT10210";
  4097. tranf_submit(oParam);
  4098. grp_bmtinfo.visible = true;
  4099. }
  4100. }
  4101. function group2_output5_oneditclick(obj:Edit, e:EditClickEventInfo)
  4102. {
  4103. lf_cellclick("B-Cell");
  4104. }
  4105. function group2_output13_oneditclick(obj:Edit, e:EditClickEventInfo)
  4106. {
  4107. lf_GetBMTInfo("list")
  4108. lf_GetBMTInfo("list")
  4109. lf_GetBMTInfo("list")
  4110. }
  4111. function group2_output11_oneditclick(obj:Edit, e:EditClickEventInfo)
  4112. {
  4113. lf_GetBMTInfo("list")
  4114. lf_GetBMTInfo("list")
  4115. lf_GetBMTInfo("list")
  4116. }
  4117. function group2_button20_onclick(obj:Button, e:ClickEventInfo)
  4118. {
  4119. lf_SetContCmt();
  4120. }
  4121. function group2_button18_onclick(obj:Button, e:ClickEventInfo)
  4122. {
  4123. frmf_modal("SMLLF00800", "SMLLF00800", null, false,"","","","","","","","","M");
  4124. }
  4125. function group2_btn_cmtdel_onclick(obj:Button, e:ClickEventInfo)
  4126. {
  4127. var row = ds_grid_testcmts.rowposition;
  4128. if(row > -1){
  4129. if(ds_grid_testcmts.getRowType(row) == Dataset.ROWTYPE_INSERT){
  4130. ds_grid_testcmts.deleteRow(row);
  4131. }else{
  4132. ds_grid_testcmts.updatecontrol = false;
  4133. ds_grid_testcmts.setRowType(row, Dataset.ROWTYPE_DELETE);
  4134. ds_grid_testcmts.updatecontrol = true;
  4135. }
  4136. }else{
  4137. sysf_messageBox("삭제할 행을 선택하세요.","I","");
  4138. return;
  4139. }
  4140. }
  4141. function group2_checkbox1_onclick(obj:CheckBox, e:ClickEventInfo)
  4142. {
  4143. lf_SetCmt();
  4144. }
  4145. function group2_grd_TestInfoCnts_onmousemove(obj:Grid, e:GridMouseEventInfo)
  4146. {
  4147. if (e.row < 0) return;
  4148. if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "reptrslt")){
  4149. var sReptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"reptrslt"));
  4150. if(sReptrslt !=""){
  4151. obj.tooltiptext = sReptrslt;
  4152. }
  4153. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "bfreptrslt")){
  4154. var sBfreptrsltv = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"bfreptrslt"));
  4155. if(sBfreptrsltv !=""){
  4156. obj.tooltiptext = sBfreptrsltv;
  4157. }
  4158. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "prereptrslt")){
  4159. var sPrereptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"prereptrslt"));
  4160. if(sPrereptrslt !=""){
  4161. obj.tooltiptext = sPrereptrslt;
  4162. }
  4163. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "tclsscrnm")){
  4164. var tClsscrnm = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"tclsscrnm"));
  4165. if(tClsscrnm !=""){
  4166. obj.tooltiptext = tClsscrnm;
  4167. }
  4168. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "lastreptdt")){
  4169. var tClsscrnm = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"lastreptdt"));
  4170. if(tClsscrnm !=""){
  4171. obj.tooltiptext = tClsscrnm;
  4172. }
  4173. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "rstnm")){
  4174. var tClsscrnm = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"rstnm"));
  4175. if(tClsscrnm !=""){
  4176. obj.tooltiptext = tClsscrnm;
  4177. }
  4178. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "rsltmark")){
  4179. var tClsscrnm = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"rsltmark"));
  4180. if(tClsscrnm !=""){
  4181. obj.tooltiptext = tClsscrnm;
  4182. }
  4183. }else if(e.cell == group2.grd_TestInfoCnts.getBindCellIndex("body", "bfreptrslt")){
  4184. var tClsscrnm = utlf_transNullToEmpty(ds_grid_testlist.getColumn(e.row,"bfreptrslt"));
  4185. if(tClsscrnm !=""){
  4186. obj.tooltiptext = tClsscrnm;
  4187. }
  4188. }else{
  4189. obj.tooltiptext = ""; //tooltiptext 초기화
  4190. }
  4191. }
  4192. function group2_btn_rsltsize1_onclick(obj:Button, e:ClickEventInfo)
  4193. {
  4194. }
  4195. //전체선택버튼 체크 해제
  4196. function lf_btnAllCheck(obj:Grid, e:GridClickEventInfo){
  4197. gv_check = (gv_check == "0" ? 1 : 0);
  4198. if (gv_check == "1"){
  4199. obj.setCellProperty( "Head", 1, "backgroundimage", "IMG::lis/chkRPT1.png");
  4200. }else{
  4201. obj.setCellProperty( "Head", 1, "backgroundimage", "IMG::lis/chkRPT0.png");
  4202. }
  4203. for(i=0;i<ds_grid_testlist.rowcount;i++){
  4204. var sReptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"reptrslt"));
  4205. var vTclskind = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"tclskind"));
  4206. var vRsltstat = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"rsltstat"));
  4207. var iRetestYN = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"retestyn"));
  4208. //var sOrgReptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"orgreptrslt"))
  4209. var sOrgReptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"inptrslt"))
  4210. var iSelValue = utlf_transNullToEmpty(ds_grid_testlist.getColumn(i,"sel_value"));
  4211. if (iSelValue == 0) iSelValue = "false";
  4212. if (iSelValue == 1) iSelValue = "true";
  4213. // 1. 최종보고 아니면서 결과값이 있으면 체크
  4214. // 2. 저장, 중간보고시 결과값 안변하게 처리
  4215. // 3. 최종보고시 보고
  4216. var bRsltChange = false;
  4217. if (sReptrslt != sOrgReptrslt) bRsltChange = true;
  4218. trace(i+" iSelValue :"+iSelValue+" sReptrslt :"+sReptrslt+" vTclskind :"+vTclskind+" vRsltstat :"+vRsltstat+" iRetestYN :"+iRetestYN);
  4219. if(!utlf_isNull(iSelValue)){
  4220. if(!utlf_isNull(sReptrslt) || vTclskind == "3"){
  4221. //if (gv_check=="1" && bRsltChange) ds_grid_testlist.setColumn(i,"sel_value","true");//변경한거는 체크
  4222. if(gv_check=="1" && vRsltstat != '-' )
  4223. {
  4224. //ds_grid_testlist.setColumn(i,"sel_value","true");
  4225. //ds_grid_testlist.setColumn(i,"selchk","true");
  4226. ds_grid_testlist.setColumn(i,"selchk","1");
  4227. } else{
  4228. ds_grid_testlist.setColumn(i,"selchk","false");
  4229. //ds_grid_testlist.setColumn(i,"selchk","false");
  4230. }
  4231. }
  4232. else{
  4233. if(gv_check=="0"){
  4234. ds_grid_testlist.setColumn(i,"selchk","false");
  4235. }
  4236. }
  4237. //if(vRsltstat == "4" || vRsltstat == "5"){
  4238. // ds_grid_testlist.setColumn(i,"sel_value","false");
  4239. //}
  4240. }
  4241. }
  4242. //gv_check = checked;
  4243. //trace('lf_btnAllCheck end :'+gv_check);
  4244. }
  4245. function group2_grd_TestInfoCnts_onheadclick(obj:Grid, e:GridClickEventInfo)
  4246. {
  4247. //trace('test');
  4248. if(e.cell ==1){
  4249. lf_btnAllCheck(obj,e);
  4250. }
  4251. }
  4252. function group2_grd_TestInfoCnts_onkeydown(obj:Grid, e:KeyEventInfo)
  4253. {
  4254. lf_gridKeyEvent(obj,e.keycode);
  4255. }
  4256. function lf_gridKeyEvent(obj,keycd)
  4257. {
  4258. var row = ds_grid_testlist.rowposition;
  4259. var col = group2.grd_TestInfoCnts.currentcol;
  4260. /*
  4261. if(keycd == 37 || keycd == 39){
  4262. if (group2.grd_TestInfoCnts.getCellPos() != group2.grd_TestInfoCnts.getBindCellIndex("body", "bufinptrslt"))
  4263. {
  4264. ds_grid_testlist.setColumn(row,"bufinptrslt","");
  4265. }
  4266. }
  4267. */
  4268. if(col == group2.grd_TestInfoCnts.getBindCellIndex("body", "bufinptrslt") && utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"readonly")) != "1" ){
  4269. if(keycd == "13"){
  4270. obj.updateToDataset();
  4271. var vBufInptRslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"bufinptrslt"));
  4272. //저장된 값에서 엔터누를시 null값입력방지위해
  4273. //alert("test");
  4274. if(vBufInptRslt == ""){
  4275. vBufInptRslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"inptrslt"));
  4276. }
  4277. var InptRslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"inptrslt"));
  4278. /*------------------------------------------------------------------시작
  4279. DPD 검사일 경우 Urine Creatinine(LCU102) 검사의 결과와 계산하여 결과 보고 하여야 한다고 함
  4280. DPD / (Creatinine × 0.088)
  4281. Creatinine 조회 기준은 같은 처방일 임 */
  4282. var vTestcd = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"testcd"));
  4283. var vPrcpdd = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"prcpdd"));
  4284. var vPid = utlf_transNullToEmpty(ds_grid_testlist.getColumn(row,"pid"));
  4285. if(vBufInptRslt == "" && InptRslt==""){
  4286. ds_grid_testlist.setColumn(row,"inptrslt",vBufInptRslt);
  4287. //빈값 엔터시 아래줄로 이동
  4288. if (ds_grid_grd_TestInfoCnts.rowcount > row +1)
  4289. {
  4290. ds_grid_testlist.rowposition = row+1;
  4291. group2.grd_TestInfoCnts.setCellPos(group2.grd_TestInfoCnts.getBindCellIndex("Body","bufinptrslt"));
  4292. group2.grd_TestInfoCnts.setFocus();
  4293. }
  4294. return;
  4295. } else {
  4296. if(vBufInptRslt == InptRslt){
  4297. //lf_cvtViewResult(true);
  4298. lf_CvtViewResult();
  4299. // alert("이상");
  4300. return;
  4301. }
  4302. }
  4303. // alert("test12");
  4304. lf_CvtViewResult();
  4305. }
  4306. }
  4307. }
  4308. // 결과판정
  4309. function lf_cvtViewResult_backup(pMatch, pMulty, pRow){
  4310. var vRow = ds_grid_testlist.rowposition;
  4311. var vCol = group2.grd_TestInfoCnts.currentcell;
  4312. var vMaxRow = ds_grid_testlist.rowcount;
  4313. if (typeof(pMatch) == "undefined") pMatch = false;
  4314. if (typeof(pMulty) == "undefined") pMulty = false;
  4315. if (typeof(pRow) != "undefined") vRow = pRow;
  4316. var vBufinptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"bufinptrslt"));
  4317. if(!pMatch){
  4318. //입력값이 기존값과 같으면 return
  4319. var vOrginptrslt = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"inptrslt"));
  4320. if (vBufinptrslt == vOrginptrslt) return;
  4321. var colorTF = false;
  4322. var vRsltkind = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"testrsltkind"));
  4323. var vRsltintsize = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"rsltintsize"));
  4324. var vRsltdcmlsize = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"rsltdcmlsize"));
  4325. var vRundkind = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"rundkind"));
  4326. var vNvalrsltlimyn = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"nvalrsltlimyn"));
  4327. var testcd = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"testcd"));
  4328. trace("vRsltkind : " + vRsltkind + "\nvRsltintsize : "+ vRsltintsize + "\nvRsltdcmlsize : "+ vRsltdcmlsize + "\nvRundkind : "+ vRundkind + "\nvNvalrsltlimyn : "+ vNvalrsltlimyn + "\ntestcd : "+ testcd);
  4329. var vReptrslt = fCOMLIS_CvtReptrslt(vBufinptrslt, vRsltkind, vRsltintsize, vRsltdcmlsize, vRundkind ,vNvalrsltlimyn );
  4330. if(vReptrslt == "err") {
  4331. ds_grid_testlist.setColumn(vRow,"bufinptrslt","");
  4332. return;
  4333. }
  4334. ds_grid_testlist.setColumn(vRow,"inptrslt",vBufinptrslt);
  4335. // 이재오 막다. 2017 10월 12일 풀다.
  4336. ds_grid_testlist.setColumn(vRow,"reptrslt",vReptrslt);
  4337. var tclskind = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"tclskind"));
  4338. // 그룹항목도 처리
  4339. if(tclskind == "0" ){
  4340. if(utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"sel_value")) != "" ){
  4341. if(utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"reptrslt")) != ""){
  4342. alert("lee");
  4343. ds_grid_testlist.setColumn(vRow,"sel_value","true");
  4344. ds_grid_testlist.setColumn(vRow, "selchk", 1);
  4345. }
  4346. }
  4347. }
  4348. else if(tclskind == "2" ){
  4349. // if(utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"sel_value")) != "" ||
  4350. // utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"sel_value")) == "" ){
  4351. alert("2");
  4352. if( utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"sel_value")) == "false" ||
  4353. utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"sel_value")) == "true" ){
  4354. alert("3");
  4355. if(utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"reptrslt")) != ""){
  4356. alert("4");
  4357. ds_grid_testlist.setColumn(vRow,"sel_value","true");
  4358. }
  4359. }
  4360. }
  4361. else if(tclskind=="3" || tclskind=="4"){
  4362. var parentidx = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"parentidx"));
  4363. if(utlf_transNullToEmpty(ds_grid_grd_TestInfoCnts.getColumn(vRow,"reptrslt")) != ""){
  4364. ds_grid_testlist.setColumn(parentidx-1,"sel_value","true");
  4365. }
  4366. }else if(tclskind=="5"){ //abnormal인 경우
  4367. var parentidx = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"parentidx")); //parent있는 row
  4368. var vTestcd = utlf_transNullToEmpty(ds_grid_testlist.getColumn(vRow,"testcd")); //검사코드
  4369. var sFind = ds_grid_testlist.findRow("testcd",vTestcd);
  4370. if(vReptrslt != "") { //보고결과가 null이 아닐때
  4371. ds_grid_testlist.setColumn(parentidx-1,"sel_value","true");
  4372. } else if((utlf_transNullToEmpty(ds_grid_testlist.getColumn(sFind,"inptrslt")) != "")
  4373. && (vReptrslt == "")){ //이전에 입력된 결과는 있는데 현 보고결과가 null일때
  4374. ds_grid_testlist.setColumn(parentidx-1,"sel_value","true");
  4375. } else { //나머지..
  4376. ds_grid_testlist.setColumn(parentidx-1,"sel_value","false");
  4377. }
  4378. }
  4379. }
  4380. if (pMulty) {
  4381. ds_grid_testlist.setColumn(vRow,"bufinptrslt","");
  4382. } else {
  4383. var vMoveRow = "";
  4384. ds_grid_testlist.setColumn(vRow,"bufinptrslt","");
  4385. if(vMaxRow == parseInt(vRow))
  4386. //vMoveRow = 1;
  4387. //2013.06 부천 위종빈선생님요청,하단값입력시 상단이동하면 입력된값 확인못하니 이동하지말것
  4388. vMoveRow = parseInt(vRow);
  4389. else
  4390. vMoveRow = parseInt(vRow) + 1;
  4391. if( vMaxRow >= vMoveRow ) {
  4392. if(utlf_transNullToEmpty(ds_grid_testlist.getColumn(vMoveRow,"readonly")) == "1" ) {
  4393. vMoveRow += 1;
  4394. }
  4395. } else {
  4396. vMoveRow -= 1;
  4397. }
  4398. if(vMoveRow > ds_grid_testlist.rowcount-1) vMoveRow = ds_grid_testlist.rowcount-1;
  4399. ds_grid_testlist.rowposition = vMoveRow;
  4400. group2.grd_TestInfoCnts.setCellPos(group2.grd_TestInfoCnts.getBindCellIndex("Body","bufinptrslt"));
  4401. group2.grd_TestInfoCnts.setFocus();
  4402. group2.grd_TestInfoCnts.showEditor(true); //추가 2015.03.20 엔터이동시 에디터창 auto select 안되는 문제 처리
  4403. ds_grid_testlist.setColumn(vMoveRow,"bufinptrslt",utlf_transNullToEmpty(ds_grid_testlist.getColumn(vMoveRow,"inptrslt")));
  4404. }
  4405. }
  4406. function group2_textarea2_ontextchanged(obj:TextArea, e:TextChangedEventInfo)
  4407. {
  4408. obj.updateToDataset();
  4409. //lf_soGyeonJeoJang();
  4410. lf_SoGyeonJeoJang();
  4411. }
  4412. function cmt_exbtn6_onclick(obj:Button, e:ClickEventInfo)
  4413. {
  4414. lf_SetContCmt();
  4415. lf_hiddentext();
  4416. }
  4417. function cmt_exbtn_onclick(obj:Button, e:ClickEventInfo)
  4418. {
  4419. lf_hiddentext();
  4420. }
  4421. function group2_cmt_extext_ontextchanged(obj:TextArea, e:TextChangedEventInfo)
  4422. {
  4423. obj.updateToDataset();
  4424. lf_SoGyeonJeoJang();
  4425. }
  4426. ]]></Script>
  4427. </Form>
  4428. </FDL>