SMPID20000.xjs 571 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <Script type="xscript4.0"><![CDATA[function pidfCalMonth(idc, av_ym)
  3. {
  4. var lv_date = av_ym.toDate("YYYYMM" + "01");
  5. lv_date = lv_date.getAddDate(idc, "M");
  6. return lv_date.getDateFormat("YYYYMM");
  7. }
  8. /****************************************************************************************
  9. * Argument : 상병 그리드
  10. * Description : 그리드 마우스 우클릭
  11. ****************************************************************************************/
  12. function grp_biz_grd_cldihist_onrbuttondown(obj:Grid, e:GridMouseEventInfo)
  13. {
  14. if(!grdf_setSelectedCell(obj, e)) return;
  15. lf_gridcldi_item.trackPopup(e.screenX,e.screenY);
  16. }
  17. /****************************************************************************************
  18. * Argument : 상병 그리드
  19. * Description : 그리드 마우스 우클릭 메뉴 이벤트 함수
  20. ****************************************************************************************/
  21. function lf_grd_cldihist_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  22. {
  23. if(e.id == "lf_fDiagSeqUp")
  24. {
  25. lf_fDiagSeqUp(); // 상병순서 위로
  26. }
  27. else if (e.id == "lf_fDiagSeqDown")
  28. {
  29. lf_fDiagSeqDown(); // 상병순서 아래로
  30. }
  31. else if (e.id == "lf_fDiagGridInsertRow")
  32. {
  33. lf_fDiagGridInsertRow(); // 행 삽입
  34. }
  35. else if (e.id == "lf_fDiagGridInsertRowMulti")
  36. {
  37. lf_fDiagGridInsertRowMulti(); // 행 추가(5줄)
  38. }
  39. else if (e.id == "lf_fDiagGridDeleteRow")
  40. {
  41. lf_fDiagGridDeleteRow(); //행 삭제
  42. }
  43. }
  44. /****************************************************************************************
  45. * Argument : 상병 그리드
  46. * Description : 그리드 마우스 우클릭 메뉴 이벤트 함수
  47. ****************************************************************************************/
  48. function lf_gridcldi_item_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  49. {
  50. if(e.id == "lf_fDiagSeqUp")
  51. {
  52. lf_fDiagSeqUp(); // 상병순서 위로
  53. }
  54. else if (e.id == "lf_fDiagSeqDown")
  55. {
  56. lf_fDiagSeqDown(); // 상병순서 아래로
  57. }
  58. else if (e.id == "lf_fDiagGridInsertRow")
  59. {
  60. lf_fDiagGridInsertRow(); // 행 삽입
  61. }
  62. else if (e.id == "lf_fDiagGridAddRow")
  63. {
  64. lf_fDiagGridAddRow(); // 행 추가
  65. }
  66. else if (e.id == "lf_fDiagGridInsertRowMulti")
  67. {
  68. lf_fDiagGridInsertRowMulti(); // 행 추가(5줄)
  69. }
  70. else if (e.id == "lf_fDiagGridDeleteRow")
  71. {
  72. lf_fDiagGridDeleteRow(); //행 삭제
  73. }
  74. }
  75. /****************************************************************************************
  76. * Argument : 원외 처방 그리드
  77. * Description : 그리드 마우스 우클릭 메뉴 이벤트 함수
  78. ****************************************************************************************/
  79. function lf_gridclop_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  80. {
  81. if(e.id == "lf_fOutOrderGridCopyRow")
  82. {
  83. lf_fOutOrderGridCopyRow();
  84. }
  85. else if(e.id == "lf_fCallClsoSpclSpec")
  86. {
  87. lf_fCallClsoSpclSpec();
  88. }
  89. else if(e.id == "lf_fCallClsoSpclAllSpec")
  90. {
  91. lf_fCallClsoSpclAllSpec();
  92. }
  93. else if (e.id == "lf_fClopGridAllDeleteRow")
  94. {
  95. lf_fClopGridAllDeleteRow();
  96. }
  97. else if (e.id == "lf_fOrderCalcScorSrch_clop")
  98. {
  99. lf_fOrderCalcScorSrch_clop();
  100. }
  101. else if (e.id == "lf_fOrderDrugHBook_clop")
  102. {
  103. lf_fOrderDrugHBook_clop();
  104. }
  105. else if (e.id == "lf_fOutOrderGridInsertRow")
  106. {
  107. lf_fOutOrderGridInsertRow(); //행 추가
  108. }
  109. else if (e.id == "lf_fClopGridDeleteRow")
  110. {
  111. lf_fClopGridDeleteRow();
  112. }
  113. }
  114. /****************************************************************************************
  115. * Argument : 처방 그리드
  116. * Description : 그리드 마우스 우클릭 메뉴 이벤트 함수
  117. ****************************************************************************************/
  118. function grp_biz_grd_clodhist_onrbuttondown(obj:Grid, e:GridMouseEventInfo)
  119. {
  120. if(!grdf_setSelectedCell(obj, e)) return;
  121. if (ds_main_item1_clbs.getColumn(0, "clamym"))
  122. {
  123. if (ds_list2_clod.rowcount <= 0)
  124. {
  125. lf_inititem.trackPopup(e.screenX,e.screenY);
  126. }
  127. else
  128. {
  129. lf_grd_clodhist.trackPopup(e.screenX,e.screenY);
  130. }
  131. }
  132. }
  133. /****************************************************************************************
  134. * Argument : 원외 처방 그리드
  135. * Description : 데이터 없는 경우
  136. ****************************************************************************************/
  137. function lf_clopinititem_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  138. {
  139. if(e.id == "lf_fOutOrderGridInsertRow")
  140. {
  141. lf_fOutOrderGridInsertRow(); // 원외처방 추가
  142. }
  143. }
  144. /****************************************************************************************
  145. * Argument : 원외 처방 그리드
  146. * Description : 데이터 없는 경우
  147. ****************************************************************************************/
  148. function lf_inititem_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  149. {
  150. if(e.id == "lf_fOrderGridInsertRow")
  151. {
  152. lf_fOrderGridInsertRow(); // 처방 추가
  153. }
  154. }
  155. /****************************************************************************************
  156. * Argument : 원외 처방 그리드
  157. * Description : 행복사
  158. ****************************************************************************************/
  159. function lf_fOutOrderGridCopyRow()
  160. {
  161. var cloprow = ds_list7_clop.rowposition;
  162. var adjtresncd = ds_list7_clop.getColumn(cloprow, "adjtresncd");
  163. if (utlf_isNull(adjtresncd)|| adjtresncd == "-")
  164. {
  165. var cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  166. if (utlf_isNull(cmbAdjtresncd) || cmbAdjtresncd == "-" )
  167. {
  168. var sppiz01000 = new Object();
  169. sppiz01000.sCdCls = "aftout";
  170. sppiz01000.sCdid = adjtresncd;
  171. sppiz01000.sAdjtresndesc = "";
  172. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  173. adjtresncd = objArg.sCdid;
  174. }
  175. else
  176. {
  177. adjtresncd = cmbAdjtresncd;
  178. }
  179. }
  180. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  181. {
  182. return;
  183. }
  184. var iRow = ds_list7_clop.insertRow(++cloprow);
  185. ds_list7_clop.copyRow(iRow, ds_list7_clop, iRow-1);
  186. ds_list7_clop.setColumn(iRow, "spclspecyn", "");
  187. ds_list7_clop.setColumn(iRow, "clopseqno", "");
  188. ds_list7_clop.setColumn(iRow, "adjtresncd", adjtresncd);
  189. var cur_seqno = ds_rslt_clopmaxseqno.getColumn(0, "seqno");
  190. ds_list7_clop.setColumn(iRow, "seqno", cur_seqno);
  191. ds_rslt_clopmaxseqno.setColumn(0, "seqno", parseInt(cur_seqno) + 1);
  192. ds_list7_clop.setColumn(iRow, "edilnno", "0");
  193. }
  194. /****************************************************************************************
  195. * Argument : 마우스 우 클릭
  196. * Description : 상병순서 위로
  197. ****************************************************************************************/
  198. function lf_fDiagSeqUp()
  199. {
  200. var rowstatus = ds_list1_cldi.getRowType(ds_list1_cldi.rowposition);
  201. if (rowstatus == 8)
  202. {
  203. return;
  204. }
  205. var diagseq = parseInt(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "diagseq"));
  206. if (diagseq > 1)
  207. {
  208. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "diagseq", --diagseq);
  209. if (rowstatus == 1 || rowstatus == 4)
  210. {
  211. var arrRow = new Array();
  212. arrRow[0] = ds_list1_cldi.rowposition;
  213. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  214. }
  215. var nextrow = ds_list1_cldi.rowposition - 1;
  216. var nextdiagseq = ds_list1_cldi.getColumn(nextrow, "diagseq");
  217. if (diagseq == nextdiagseq)
  218. {
  219. ds_list1_cldi.setColumn(nextrow, "diagseq", ++diagseq);
  220. rowstatus = ds_list1_cldi.getRowType(nextrow);
  221. if (rowstatus == 1 || rowstatus == 4)
  222. {
  223. var arrRow = new Array();
  224. arrRow[0] = nextrow;
  225. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  226. }
  227. }
  228. lf_fSortDiagNo(false);
  229. if (ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "diagseq") == "1" && !utlf_isNull(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "vcode")))
  230. {
  231. lf_fSetDiagMT002(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "vcode"));
  232. }
  233. }
  234. }
  235. /****************************************************************************************
  236. * Argument : 마우스 우 클릭
  237. * Description : 상병순서 아래로
  238. ****************************************************************************************/
  239. function lf_fDiagSeqDown()
  240. {
  241. var rowstatus = ds_list1_cldi.getRowType(ds_list1_cldi.rowposition);
  242. if (rowstatus == 8)
  243. {
  244. return;
  245. }
  246. var lastRow = ds_list1_cldi.rowcount;
  247. for ( var i = 0; i < ds_list1_cldi.rowcount; i++ )
  248. {
  249. if (ds_list1_cldi.getRowType(i) == 8)
  250. {
  251. lastRow = i - 1;
  252. i = ds_list1_cldi.rowcount;
  253. }
  254. }
  255. var diagseq = parseInt(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "diagseq"));
  256. if (diagseq < lastRow)
  257. {
  258. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "diagseq", ++diagseq);
  259. if (rowstatus == 1 || rowstatus == 4)
  260. {
  261. var arrRow = new Array();
  262. arrRow[0] = ds_list1_cldi.rowposition;
  263. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  264. }
  265. var nextrow = ds_list1_cldi.rowposition + 1;
  266. var nextdiagseq = ds_list1_cldi.getColumn(nextrow, "diagseq");
  267. if (diagseq == nextdiagseq)
  268. {
  269. ds_list1_cldi.setColumn(nextrow, "diagseq", --diagseq);
  270. rowstatus = ds_list1_cldi.getRowType(nextrow);
  271. if (rowstatus == 1 || rowstatus == 4)
  272. {
  273. var arrRow = new Array();
  274. arrRow[0] = nextrow;
  275. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  276. }
  277. }
  278. if (ds_list1_cldi.getColumn(nextrow, "diagseq") == "1" && !utlf_isNull(ds_list1_cldi.getColumn(nextrow, "vcode")))
  279. {
  280. lf_fSetDiagMT002(ds_list1_cldi.getColumn(nextrow, "vcode"));
  281. }
  282. lf_fSortDiagNo(false);
  283. }
  284. }
  285. /****************************************************************************************
  286. * Argument : 마우스 우 클릭
  287. * Description : 행삽입
  288. ****************************************************************************************/
  289. function lf_fDiagGridInsertRow(addyn, selectyn, fstrow)
  290. {
  291. var iInsertRow = 0;
  292. if (ds_list1_cldi.rowcount == 1 || addyn == "Y")
  293. {
  294. iInsertRow = ds_list1_cldi.addRow();
  295. }
  296. else
  297. {
  298. iInsertRow = ds_list1_cldi.insertRow(ds_list1_cldi.rowposition+1);
  299. }
  300. var nowRow = 0;
  301. nowRow = ds_list1_cldi.rowposition;
  302. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "diagkindcd", "C");
  303. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "diagseq", ds_list1_cldi.rowposition+1);
  304. var clamdeptcd = ds_list1_cldi.getColumn(0, "clamdeptcd");
  305. if (utlf_isNull(clamdeptcd))
  306. {
  307. clamdeptcd = ds_main_item1_clbs.getColumn(0, "clamdeptcd");
  308. }
  309. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "clamdeptcd", clamdeptcd);
  310. var ordfromdd = ds_list1_cldi.getColumn(0, "ordfromdd");
  311. if (ordfromdd)
  312. {
  313. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "ordfromdd", ordfromdd);
  314. }
  315. else
  316. {
  317. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  318. }
  319. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "toot", "-");
  320. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "vcode", "");
  321. if (selectyn != "Y")
  322. {
  323. lf_fSortDiagNo(true);
  324. }
  325. if (addyn != "Y")
  326. {
  327. grp_biz.grd_cldihist.setCellProperty("Body", grp_biz.grd_cldihist.getBindCellIndex("body", "diagcd"), "edittype", "normal");
  328. }
  329. if (utlf_isNull(fstrow)){
  330. ds_list1_cldi.clearSelect();
  331. ds_list1_cldi.rowposition = nowRow;
  332. ds_list1_cldi.selectRow(nowRow);
  333. }
  334. grp_biz.grd_cldihist.setCellPos(grp_biz.grd_cldihist.getBindCellIndex("body", "diagcd"));
  335. grp_biz.grd_cldihist.showEditor(true);
  336. return iInsertRow;
  337. }
  338. /****************************************************************************************
  339. * Argument : 마우스 우 클릭
  340. * Description : 상병순서 행추가 5줄
  341. ****************************************************************************************/
  342. function lf_fDiagGridInsertRowMulti()
  343. {
  344. for ( var i = 0; i < 5; i++)
  345. {
  346. var iRow = ds_list1_cldi.insertRow(ds_list1_cldi.rowcount + 1);
  347. ds_list1_cldi.setColumn(iRow, "diagkindcd", "C");
  348. ds_list1_cldi.setColumn(iRow, "diagseq", iRow);
  349. var clamdeptcd = ds_list1_cldi.getColumn(0, "clamdeptcd");
  350. if (utlf_isNull(clamdeptcd))
  351. {
  352. clamdeptcd = ds_main_item1_clbs.getColumn(0, "clamdeptcd");
  353. }
  354. ds_list1_cldi.setColumn(iRow, "clamdeptcd", clamdeptcd);
  355. var ordfromdd = ds_list1_cldi.getColumn(0, "ordfromdd");
  356. if (ordfromdd)
  357. {
  358. ds_list1_cldi.setColumn(iRow, "ordfromdd", ordfromdd);
  359. }
  360. else
  361. {
  362. ds_list1_cldi.setColumn(iRow, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  363. }
  364. ds_list1_cldi.setColumn(iRow, "toot", "-");
  365. ds_list1_cldi.setColumn(iRow, "vcode", "");
  366. }
  367. lf_fSortDiagNo(true);
  368. }
  369. /****************************************************************************************
  370. * Argument : 마우스 우 클릭
  371. * Description : 행삭제
  372. ****************************************************************************************/
  373. function lf_fDiagGridDeleteRow()
  374. {
  375. var SelectedRows = grdf_getSelectedRows(grp_biz.grd_cldihist)
  376. for(var i = SelectedRows.length-1; i >= 0; i--)
  377. {
  378. var rowstatus = ds_list1_cldi.getRowType(SelectedRows[i]);
  379. var diagcd = ds_list1_cldi.getColumn(SelectedRows[i],"diagcd");
  380. var frow = ds_lglydisinfo.findRowExpr("fromdiag<='" + diagcd + "' && todiag>='" + diagcd + "'");
  381. if (frow > -1){
  382. lf_setAlramMessage("상병코드: " + diagcd + " 법정전염병 상병입니다. 확인하십시오.");
  383. }
  384. if (rowstatus == 8)
  385. {
  386. }
  387. else if ( rowstatus == 2 )
  388. {
  389. ds_list1_cldi.deleteRow(SelectedRows[i]);
  390. }
  391. else
  392. {
  393. var dRow = "D"+ds_list1_cldi.getColumn(SelectedRows[i], "diagseq");
  394. ds_list1_cldi.setColumn(SelectedRows[i], "diagseq", dRow);
  395. grdf_setStatus(grp_biz.grd_cldihist, "D", SelectedRows[i]);
  396. ds_list1_cldi.deleteRow(SelectedRows[i]);
  397. }
  398. }
  399. lf_fSortDiagNo(true);
  400. }
  401. /****************************************************************************************
  402. * Argument : 마우스 우 클릭
  403. * Description : 정렬
  404. ****************************************************************************************/
  405. function lf_fSortDiagNo(isNumbering)
  406. {
  407. var objds = ds_list1_cldi;
  408. var objgrd = grp_biz.grd_cldihist;
  409. var seqnm = "diagseq";
  410. var delcnt = 0;
  411. if (isNumbering == false)
  412. {
  413. var maxRow = objds.rowcount - 1; // rows는 타이틀부분 부터 개수를 센다
  414. objds.keystring = "";
  415. objds.keystring = "S:+diagseq";
  416. objgrd.updateToDataset();
  417. return;
  418. }
  419. var cldino = 1;
  420. for ( var i = 0; i < objds.rowcount; i++)
  421. {
  422. if (objds.getRowType(i) != 8)
  423. {
  424. var diagseq = objds.getColumn(i, seqnm);
  425. if (objds.getRowType(i) == 1 && diagseq != cldino)
  426. {
  427. objds.enableevent = false;
  428. objds.setRowType(i, 'u'); //update
  429. objds.enableevent = true;
  430. }
  431. objds.setColumn(i, seqnm, cldino++);
  432. } else {
  433. delcnt++;
  434. }
  435. }
  436. objds.keystring = "";
  437. objds.keystring = "S:+"+seqnm;
  438. if (delcnt > 0)
  439. {
  440. objds.keystring = "";
  441. objds.keystring = "S:+"+seqnm;
  442. }
  443. // Sort 된 Grid 상의 Data 순서와 Instance Node 상의 Data 순서를 동일하게 맞춰준다.
  444. objgrd.updateToDataset();
  445. }
  446. /****************************************************************************************
  447. * Argument :
  448. * Description : 원외처방 행 추가
  449. ****************************************************************************************/
  450. function lf_fOutOrderGridInsertRow()
  451. {
  452. var iRow = ds_list7_clop.addRow();
  453. var ordfromdd = utlf_transNullToEmpty(ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  454. var clopno = utlf_transNullToEmpty(ds_list7_clop.getColumn(0, "clopno"));
  455. ds_list7_clop.rowposition = iRow;
  456. // 기본값 입력
  457. ds_list7_clop.setColumn(iRow, "clopdd" , ordfromdd);
  458. ds_list7_clop.setColumn(iRow, "clopno" , clopno);
  459. ds_list7_clop.setColumn(iRow, "oldclopdd" , ordfromdd);
  460. ds_list7_clop.setColumn(iRow, "oldclopno" , clopno);
  461. ds_list7_clop.setColumn(iRow, "mpsno" , ordfromdd+clopno);
  462. ds_list7_clop.setColumn(iRow, "newmpsno" , ordfromdd+clopno);
  463. ds_list7_clop.setColumn(iRow, "edilnno" , "0");
  464. ds_list7_clop.setColumn(iRow, "payflag" , "0");
  465. ds_list7_clop.setColumn(iRow, "drugqty" , "1");
  466. ds_list7_clop.setColumn(iRow, "edidrugqty" , "1");
  467. ds_list7_clop.setColumn(iRow, "drugtims" , "1");
  468. ds_list7_clop.setColumn(iRow, "drugdayno" , "1");
  469. ds_list7_clop.setColumn(iRow, "edidrugdayno" , "1");
  470. ds_list7_clop.setColumn(iRow, "edidrugdaynomax" , "1");
  471. ds_list7_clop.setColumn(iRow, "workflag" , "12");
  472. ds_list7_clop.setColumn(iRow, "spclspecyn" , "");
  473. var adjtresncd = ds_list7_clop.getColumn(iRow, "adjtresncd");
  474. if (utlf_isNull(adjtresncd)|| adjtresncd == "-")
  475. {
  476. var cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  477. if (utlf_isNull(cmbAdjtresncd) || cmbAdjtresncd == "-" )
  478. {
  479. var sppiz01000 = new Object();
  480. sppiz01000.sCdCls = "aftout";
  481. sppiz01000.sCdid = adjtresncd;
  482. sppiz01000.sAdjtresndesc = "";
  483. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  484. adjtresncd = objArg.sCdid;
  485. }
  486. else
  487. {
  488. adjtresncd = cmbAdjtresncd;
  489. }
  490. }
  491. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  492. {
  493. ds_list7_clop.deleteRow(iRow);
  494. }
  495. else
  496. {
  497. ds_list7_clop.setColumn(iRow, "adjtresncd", adjtresncd);
  498. }
  499. }
  500. /****************************************************************************************
  501. * Argument : enter
  502. * Description : 청구년월 enter 키 이벤트
  503. ****************************************************************************************/
  504. function grp_biz_grp_sea00_ipt_clamym_onkeydown(obj:cp_monthCal, e:KeyEventInfo)
  505. {
  506. if(e.keycode == 13)
  507. {
  508. fn_Cal();
  509. }
  510. }
  511. /****************************************************************************************
  512. * Argument : combo
  513. * Description : 진료과 콤보 변경 시 이벤트
  514. ****************************************************************************************/
  515. function grp_biz_grp_sea00_cmb_ordfildcd_onitemchanged(obj:Combo, e:ItemChangeEventInfo)
  516. {
  517. var ordfildcd = ds_main_item1_clbs.getColumn(0, "ordfildcd");
  518. var clamtypecd = ds_main_item1_clbs.getColumn(0, "clamtypecd");
  519. if (clamtypecd == "8")
  520. {
  521. if (ordfildcd == "6")
  522. {
  523. ds_main_item1_clbs.setColumn(0,"sumtypecd", "6")// 집계형태 : 치과분야
  524. }
  525. else if (ordfildcd == "8")
  526. {
  527. ds_main_item1_clbs.setColumn(0,"sumtypecd", "8")// 집계형태 : 한방분야
  528. }
  529. else
  530. {
  531. ds_main_item1_clbs.setColumn(0,"sumtypecd", "0")// 집계형태 : 의과분야
  532. }
  533. }
  534. }
  535. /****************************************************************************************
  536. * Argument : combo
  537. * Description : 진료과 콤보 선택 시 의사 filter
  538. ****************************************************************************************/
  539. function grp_biz_grp_sea00_cmb_orddeptcd_onitemchanged(obj:Combo, e:ItemChangeEventInfo)
  540. {
  541. var orddeptcd = obj.value;
  542. if (orddeptcd == "-")
  543. {
  544. ds_init_orddrid2.filterstr = "";
  545. }
  546. else
  547. {
  548. ds_init_orddrid2.filterstr = "dp == '"+ obj.value +"' || dp == '-'";
  549. }
  550. ds_main_item1_clbs.setColumn(0,"clamdeptcd", ds_init_orddeptcd2.lookupExpr("cd=='"+ obj.value +"'","reqdeptno"));
  551. }
  552. /****************************************************************************************
  553. * Argument : column
  554. * Description : 컬럼 검사
  555. ****************************************************************************************/
  556. function lf_fEdiCheck()
  557. {
  558. var sEdiCheck = "";
  559. sEdiCheck = ds_hidden.getColumn(0, "edicheck");
  560. // edi 관련 컬럼 조회기준으로 변경 (재원비교로 변경)
  561. if ( sEdiCheck == "Y" )
  562. {
  563. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "edicd"), "size", 70); // EDI코드
  564. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "unitcost"), "size", 45); // 단가
  565. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "drugqty"), "size", 45); // 1회량
  566. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "dayno"), "size", 45); // 일수
  567. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "amt"), "size", 45); // 금액
  568. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "druglimitamt"), "size", 45); // 약제상한가
  569. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "limitdiffamt"), "size", 45); // 약제상한차액
  570. if(ds_main_item1_clbs.getColumn(0, "ioflag") == "O")
  571. {
  572. grp_biz.grd_oprcphist.setFormatColProperty(grp_biz.grd_oprcphist.getBindCellIndex("body", "drugqty"), "size", 45); // 원외 1회량
  573. grp_biz.grd_oprcphist.setFormatColProperty(grp_biz.grd_oprcphist.getBindCellIndex("body", "drugdayno"), "size", 45); // 원외 일수
  574. }
  575. }
  576. else
  577. {
  578. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "edicd"), "size", 0); // EDI코드
  579. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "unitcost"), "size", 0); // 단가
  580. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "drugqty"), "size", 0); // 1회량
  581. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "dayno"), "size", 0); // 일수
  582. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "amt"), "size", 0); // 금액
  583. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "druglimitamt"), "size", 0); // 약제상한가
  584. grp_biz.grd_clodhist.setFormatColProperty(grp_biz.grd_clodhist.getBindCellIndex("body", "limitdiffamt"), "size", 0); // 약제상한차액
  585. if(ds_main_item1_clbs.getColumn(0, "ioflag") == "O")
  586. {
  587. grp_biz.grd_oprcphist.setFormatColProperty(grp_biz.grd_oprcphist.getBindCellIndex("body", "drugqty"), "size", 0); // 원외 1회량
  588. grp_biz.grd_oprcphist.setFormatColProperty(grp_biz.grd_oprcphist.getBindCellIndex("body", "drugdayno"), "size", 0); // 원외 일수
  589. }
  590. }
  591. }
  592. /****************************************************************************************
  593. * Argument : row
  594. * Description : 그리드 row 추가
  595. ****************************************************************************************/
  596. function lf_fOrderGridAddRow()
  597. {
  598. var clodrow = ds_list2_clod.rowposition;
  599. var preediitem1 = ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoItem");
  600. var prematractflag = ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoMatrAct");
  601. var prepayflag = ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoPay");
  602. var clodrow = ds_list2_clod.addRow();
  603. ds_list2_clod.setColumn(clodrow, "ediitem1" , preediitem1);
  604. ds_list2_clod.setColumn(clodrow, "matractflag" , prematractflag);
  605. ds_list2_clod.setColumn(clodrow, "payflag" , prepayflag);
  606. ds_list2_clod.setColumn(clodrow, "snglcalcscorcd", ds_hidden_list2_clodsrch.getColumn(0, "inpCalcScorCd"));
  607. ds_list2_clod.setColumn(clodrow, "basecd", ds_hidden_list2_clodsrch.getColumn(0, "inpEDICd"));
  608. var indd = ds_main_item1_clbs.getColumn(0, "indd");
  609. ds_list2_clod.setColumn(clodrow, "ordfromdd", indd);
  610. ds_list2_clod.clearSelect();
  611. ds_list2_clod.rowposition = clodrow;
  612. ds_list2_clod.selectRow(clodrow);
  613. var newcd = ds_hidden_list2_clodsrch.getColumn(0, "cmbAdjtresncd");
  614. if (newcd)
  615. {
  616. ds_list2_clod.setColumn(iRow, "adjtresncd", newcd);
  617. lf_fOrderBkColorNew();
  618. }
  619. else
  620. {
  621. newcd = lf_fSetAdjtResnCd();
  622. if (utlf_isNull(newcd) || newcd == "-")
  623. {
  624. ds_list2_clod.deleteRow(clodrow); // 처방 Grid에서 해당 라인을 삭제한다.
  625. }
  626. }
  627. }
  628. /****************************************************************************************
  629. * Argument : 처방 Grid
  630. * Description : 그리드에서 추가/수정된 row 배경색 설정
  631. ****************************************************************************************/
  632. function lf_fOrderBkColorNew(clodrow)
  633. {
  634. // 신규처방 노란배경 // ffff9c=연한노랑
  635. // bgcExpr = "EXPR(curcol == grp_biz.grd_clodhist.getBindCellIndex('body','rowstat') && (getRowType("+clodrow+") == 2 || getRowType("+clodrow+") == 4) ? '#ffff9c' : 'default')";
  636. // grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body','rowstat'), "background", bgcExpr); // rowstat
  637. // grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body','rowstat'), "background2", bgcExpr); // rowstat
  638. }
  639. /****************************************************************************************
  640. * Argument : modal
  641. * Description : 심사수정사유관리 화면 modal 호출
  642. ****************************************************************************************/
  643. function lf_fSetAdjtResnCd()
  644. {
  645. var oldcd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "adjtresncd");
  646. var olddesc = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "adjtresndesc");
  647. var sppiz01000 = new Object();
  648. sppiz01000.sCdCls = "aftin";
  649. sppiz01000.sCdid = oldcd;
  650. sppiz01000.sAdjtresndesc = olddesc;
  651. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  652. if (!utlf_isNull(objArg))
  653. {
  654. var newcd = objArg.sCdid;
  655. var newdesc = objArg.sAdjtresndesc;
  656. if (!utlf_isNull(newcd))
  657. {
  658. for ( var i = 0; i < ds_list2_clod.rowcount; i++)
  659. {
  660. var sRow = ds_list2_clod.getSelect(i);
  661. if ( sRow == true )
  662. {
  663. if (newcd != oldcd && oldcd != "G")
  664. {
  665. ds_list2_clod.setColumn(i, "adjtresncd", newcd);
  666. ds_list2_clod.setColumn(i, "adjtresndesc", newdesc);
  667. if ( ds_list2_clod.getRowType(i) == 1 )
  668. {
  669. var arrRow = new Array();
  670. arrRow[0] = i;
  671. grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  672. }
  673. lf_fOrderBkColorNew(i);
  674. }
  675. }
  676. }
  677. }
  678. return newcd;
  679. }
  680. }
  681. /****************************************************************************************
  682. * Argument : modal
  683. * Description : 결과조회화면 modal 호출
  684. ****************************************************************************************/
  685. function lf_fOrderRsltSrch()
  686. {
  687. trace("tf랑 다름")
  688. if (grp_dropdownmenu.visible == true)
  689. {
  690. grp_dropdownmenu.visible = false;
  691. }
  692. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  693. if (!utlf_isNull(clamym))
  694. {
  695. var smmmi00100 = new Object();
  696. smmmi00100.plgv_SMMMI00100_pid = ds_main_item1_clbs.getColumn(0, "pid");
  697. frmf_modal("SMMMI00100", "SMMMI00100", smmmi00100, "", "", "", "", "", "", "", "", "", "M");
  698. }
  699. }
  700. /****************************************************************************************
  701. * Argument : modal
  702. * Description : 상세계산내역화면 modal 호출
  703. ****************************************************************************************/
  704. function lf_fGetOsclClamData(chkAll, grid)
  705. {
  706. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  707. var ctrlObj;
  708. var row;
  709. var col;
  710. var seqno;
  711. var hngnm;
  712. var grupcd;
  713. var calcscorcd;
  714. var edicd;
  715. var clopyn;
  716. if (chkAll != "ALL" && chkAll != "N")
  717. {
  718. chkAll = "N";
  719. }
  720. if (grid != "grd_clodhist" && grid != "grd_oprcphist")
  721. {
  722. grid = "grd_clodhist";
  723. }
  724. if (clamkey)
  725. {
  726. var objArg = new Object();
  727. objArg.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  728. objArg.sPatnm = ds_main_item1_clbs.getColumn(0, "patnm");
  729. objArg.sGender = ds_main_item1_clbs.getColumn(0, "gender");
  730. objArg.sScrhdate = "execdd";
  731. objArg.sFromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  732. objArg.sTodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  733. objArg.sClamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  734. objArg.sIoflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  735. objArg.sStsioflag = ds_main_item1_clbs.getColumn(0, "stsioflag");
  736. objArg.sInstcd = ds_main_item1_clbs.getColumn(0, "instcd");
  737. if (grid == "grd_clodhist")
  738. {
  739. ctrlObj = grp_biz.grd_clodhist;
  740. col = grp_biz.grd_clodhist.currentcol;
  741. seqno = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "seqno");
  742. hngnm = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "hngnm");
  743. grupcd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "grupcalcscorcd");
  744. calcscorcd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd");
  745. edicd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "edicd");
  746. clopyn = "N"; //원외처방여부
  747. }
  748. else if (grid == "grd_oprcphist")
  749. {
  750. ctrlObj = grp_biz.grd_oprcphist;
  751. col = grp_biz.grd_oprcphist.currentcol;
  752. seqno = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "clopseqno");
  753. hngnm = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "hngnm");
  754. grupcd = "";
  755. calcscorcd = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "snglcalcscorcd");
  756. edicd = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "edicd");
  757. clopyn = "Y"; //원외처방여부
  758. }
  759. objArg.sClopyn = clopyn;
  760. if (chkAll == "ALL")
  761. {
  762. objArg.sClamcretdd = "0";
  763. objArg.sHhngnm = "";
  764. objArg.sChoicdsrch = "calcscorcd";
  765. objArg.sCalcscorcd = "";
  766. }
  767. else
  768. {
  769. objArg.sClamcretdd = seqno;
  770. objArg.sHhngnm = hngnm;
  771. if (col == ctrlObj.getBindCellIndex("body", "grupcalcscorcd"))
  772. {
  773. objArg.sChoicdsrch = "grupcd";
  774. objArg.sCalcscorcd = grupcd;
  775. }
  776. else if (col == ctrlObj.getBindCellIndex("body", "snglcalcscorcd"))
  777. {
  778. objArg.sChoicdsrch = "calcscorcd";
  779. objArg.sCalcscorcd = calcscorcd;
  780. }
  781. else if (col == ctrlObj.getBindCellIndex("body", "basecd") || col == ctrlObj.getBindCellIndex("body", "edicd"))
  782. {
  783. objArg.sChoicdsrch = "edicd";
  784. objArg.sCalcscorcd = edicd;
  785. }
  786. else
  787. {
  788. objArg.sChoicdsrch = "calcscorcd";
  789. objArg.sCalcscorcd = calcscorcd;
  790. }
  791. }
  792. frmf_modal("SPPID22100", "SPPID22100", objArg, "", "", "", "", "", "", "", "", "", "M");
  793. }
  794. }
  795. /****************************************************************************************
  796. * Argument : modal
  797. * Description : 환자 전체메세지 간편보기화면 modal 호출
  798. ****************************************************************************************/
  799. function lf_fOrderInsuRcogBase(isAll, grdFlag)
  800. {
  801. var calcscorcd = "";
  802. var hngnm = "";
  803. if(grdFlag == "clod")
  804. {
  805. calcscorcd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd");
  806. hngnm = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "hngnm");
  807. }
  808. else if(grdFlag == "clop")
  809. {
  810. calcscorcd = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "snglcalcscorcd");
  811. hngnm = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "hngnm");
  812. }
  813. var objArg = new Object();
  814. objArg.sBhviewyn = "Y";
  815. objArg.sCalcscorcd = calcscorcd;
  816. objArg.sCalcscorcdnm = hngnm;
  817. objArg.sPreveiwyn = "Y";
  818. objArg.sLimtcd = "";
  819. objArg.sAppdd = "";
  820. frmf_open("SPPIZ01600", "SPPIZ01600", "", "", "", "", "", "", "", "", "", "", "M");
  821. }
  822. /****************************************************************************************
  823. * Argument : modal
  824. * Description : 중복 처방 사유 조회 화면 modal 호출
  825. ****************************************************************************************/
  826. function lf_fPrcpResnRef()
  827. {
  828. var sUserInfosS = sysf_getUserInfo();
  829. sUserInfosS = sUserInfosS + "|";
  830. var UserInfosS_Array = sUserInfosS.split("|");
  831. var userid = UserInfosS_Array[0]; // 사용자번호
  832. var usernm = UserInfosS_Array[1]; // 사용자이름
  833. var posinstcd = UserInfosS_Array[6]; // 근무지기관코드
  834. var posinstnm = UserInfosS_Array[7]; // 근무지기관명
  835. var posdeptcd = UserInfosS_Array[4]; // 소속부서코드
  836. var posdeptnm = UserInfosS_Array[5]; // 소속부서명
  837. ds_tmp_prcpresnref.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  838. ds_tmp_prcpresnref.setColumn(0, "fromdd" , ds_main_item1_clbs.getColumn(0, "indd"));
  839. ds_tmp_prcpresnref.setColumn(0, "todd" , ds_main_item1_clbs.getColumn(0, "dschdd"));
  840. ds_tmp_prcpresnref.setColumn(0, "orddeptcd" , "-");
  841. ds_tmp_prcpresnref.setColumn(0, "orddrid" , "-");
  842. ds_tmp_prcpresnref.setColumn(0, "mainjudgid" , "-");
  843. ds_tmp_prcpresnref.setColumn(0, "prcpcd" , ds_list2_clod.getColumn(ds_list2_clod.rowposition, "grupcalcscorcd"));
  844. ds_tmp_prcpresnref.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  845. ds_tmp_prcpresnref.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  846. ds_tmp_prcpresnref.setColumn(0, "resncd" , "FF");
  847. ds_tmp_prcpresnref.setColumn(0, "popup" , "judg");
  848. var objArg = new Object();
  849. objArg.prv_ds = ds_tmp_prcpresnref;
  850. frmf_open("SPMMO19000", "SPMMO19000", objArg, "", "", "", "", "", "", "", "", "", "M");
  851. }
  852. /****************************************************************************************
  853. * Argument : modal
  854. * Description : 급비변경관리 화면 modal 호출
  855. ****************************************************************************************/
  856. function lf_fSetPayflag()
  857. {
  858. var oldpayflag = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "payflag");
  859. var objArg = new Object();
  860. objArg.sCdid = oldpayflag;
  861. objArg.sCdCls = "";
  862. var objRtnVal = frmf_modal("SPPID23100", "SPPID23100", objArg, "", "", "", "", "", "", "", "", "", "M");
  863. if (!utlf_isNull(objRtnVal))
  864. {
  865. var newpayflag = objRtnVal.sCdid;
  866. if ( newpayflag != oldpayflag )
  867. {
  868. var adjtresncd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "adjtresncd");
  869. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  870. {
  871. var newcd = lf_fSetAdjtResnCd();
  872. if (utlf_isNull(newcd) || newcd == "-")
  873. {
  874. return;
  875. }
  876. }
  877. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "payflag", newpayflag);
  878. if ( newpayflag == "0" || newpayflag == "9" )
  879. {
  880. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "calcappyn", "Y");
  881. }
  882. else
  883. {
  884. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "calcappyn", "N");
  885. }
  886. var matractflag = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "matractflag");
  887. if ( newpayflag == "9" && matractflag == "2" )
  888. {
  889. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "matractflag", "3");
  890. }
  891. if (ds_list2_clod.getRowType(ds_list2_clod.rowposition) == 1)
  892. {
  893. var arrRow = new Array();
  894. arrRow[0] = ds_list2_clod.rowposition;
  895. grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  896. }
  897. lf_fOrderBkColorNew(ds_list2_clod.rowposition);
  898. var insukind = ds_main_item1_clbs.getColumn(0, "insukind");
  899. if (newpayflag == "8" && (insukind == "31" || insukind == "41"))
  900. {
  901. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "payflag" , "9");
  902. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "item" , "YY01");
  903. ds_list2_clod.setColumn(ds_list2_clod.rowposition, "calcappyn", "Y");
  904. }
  905. lf_fSetTotDrugQtyAmt();
  906. }
  907. }
  908. }
  909. /****************************************************************************************
  910. * Argument : modal
  911. * Description : 확인코드 조회 화면 modal 호출
  912. ****************************************************************************************/
  913. function lf_fOrderGridInsertCnfmCd()
  914. {
  915. var row = ds_list2_clod.rowposition;
  916. var seqno = ds_list2_clod.getColumn(row, "seqno");
  917. if (seqno != "0")
  918. {
  919. ds_rslt_sppiz01100.clearData();
  920. ds_rslt_sppiz01100.addRow();
  921. var sppiz01100 = new Object();
  922. sppiz01100.sCode = ds_list2_clod.getColumn(row, "cnfmcd");
  923. var rtnObj = frmf_modal("SPPIZ01100", "SPPIZ01100", sppiz01100, "", "", "", "", "", "", "", "", "", "M");
  924. if (!utlf_isNull(rtnObj))
  925. {
  926. var cnfmcd = rtnObj.sCode;
  927. ds_list2_clod.setColumn(row, "cnfmcd", cnfmcd);
  928. ds_list3_clsp.filter("");
  929. if (!utlf_isNull(cnfmcd))
  930. {
  931. var isFind = false;
  932. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  933. {
  934. var spcClodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  935. var spcClsoyn = ds_list3_clsp.getColumn(j, "clsoyn"); //원외특정여부
  936. if (spcClodseqno == seqno && spcClsoyn == "N")
  937. {
  938. var spclcd = ds_list3_clsp.getColumn(j, "spclcd");
  939. if (spclcd == "JT001")
  940. {
  941. ds_list3_clsp.setColumn(j, "snglcalcscorcd" , ds_list2_clod.getColumn(row, "snglcalcscorcd"));
  942. ds_list3_clsp.setColumn(j, "edilnno" , ds_list2_clod.getColumn(row, "edilnno"));
  943. ds_list3_clsp.setColumn(j, "edicd" , ds_list2_clod.getColumn(row, "edicd"));
  944. ds_list3_clsp.setColumn(j, "edicdflag" , ds_list2_clod.getColumn(row, "edicdflag"));
  945. ds_list3_clsp.setColumn(j, "spclcd" , "JT001");
  946. ds_list3_clsp.setColumn(j, "cdnm" , "확인코드");
  947. ds_list3_clsp.setColumn(j, "spclspec" , cnfmcd);
  948. ds_list3_clsp.setColumn(j, "spclformat" , "X(5)");
  949. ds_list3_clsp.setColumn(j, "detldesc" , "진료행위에 대한 추가기술 사항을 구분하는 코드로서 확인코드가 여러개 발생할 경우 '/'로 구분하여 기재");
  950. var rowstatus = ds_list3_clsp.getRowType(j);
  951. if ( rowstatus == 2 )
  952. { // 2 : insert
  953. }
  954. else
  955. {
  956. var arrRow = new Array();
  957. arrRow[0] = j;
  958. grdf_setStatus(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, "U", arrRow);
  959. }
  960. isFind = true;
  961. }
  962. }
  963. }
  964. if (isFind == false)
  965. {
  966. var clsprow = ds_list3_clsp.addRow();
  967. ds_list3_clsp.setColumn(clsprow, "unitflag" , "J");
  968. ds_list3_clsp.setColumn(clsprow, "edilnno" , ds_list2_clod.getColumn(row, "edilnno"));
  969. ds_list3_clsp.setColumn(clsprow, "clodseqno" , seqno);
  970. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd" , ds_list2_clod.getColumn(row, "snglcalcscorcd"));
  971. ds_list3_clsp.setColumn(clsprow, "edicd" , ds_list2_clod.getColumn(row, "edicd"));
  972. ds_list3_clsp.setColumn(clsprow, "edicdflag" , ds_list2_clod.getColumn(row, "edicdflag"));
  973. ds_list3_clsp.setColumn(clsprow, "spclcd" , "JT001");
  974. ds_list3_clsp.setColumn(clsprow, "cdnm" , "확인코드");
  975. ds_list3_clsp.setColumn(clsprow, "spclspec" , cnfmcd);
  976. ds_list3_clsp.setColumn(clsprow, "spclformat" , "X(5)");
  977. ds_list3_clsp.setColumn(clsprow, "detldesc" , "진료행위에 대한 추가기술 사항을 구분하는 코드로서 확인코드가 여러개 발생할 경우 '/'로 구분하여 기재");
  978. ds_list3_clsp.setColumn(clsprow, "oldedilnno" , "0");
  979. ds_list3_clsp.setColumn(clsprow, "clsoyn" , "N");
  980. ds_list3_clsp.rowposition = clsprow;
  981. }
  982. ds_hidden_list3.setColumn(0, "msgspclformat", "확인코드 - JT001 / 입력코드내역 : "+ cnfmcd +" / 기재형식 : X(5)");
  983. } else {
  984. var frow = ds_list3_clsp.findRowExpr("spclcd == 'JT001' && clsoyn == 'N' && clodseqno=='"+seqno+"'");
  985. var rowstatus = ds_list3_clsp.getRowType(frow);
  986. if (rowstatus == 2)
  987. {
  988. ds_list3_clsp.setColumn(frow, "spclcd", "");
  989. ds_list3_clsp.setColumn(frow, "spclspec", "");
  990. }
  991. else
  992. {
  993. ds_list3_clsp.updatecontrol = false;
  994. ds_list3_clsp.setRowType(frow, "d");
  995. ds_list3_clsp.updatecontrol = true;
  996. }
  997. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 확인코드 내역이 없습니다.");
  998. }
  999. }
  1000. }
  1001. }
  1002. /****************************************************************************************
  1003. * Argument : modal
  1004. * Description : 보험인정기준 조회 화면 modal 호출
  1005. ****************************************************************************************/
  1006. function lf_fOrderInsuRcogBase(isAll)
  1007. {
  1008. var calcscorcd = ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd");
  1009. dsf_createDsRow("ds_cond_sppiz01600", [{col:"calcscorcd", type:"STRING", size:256 , val : calcscorcd}]);
  1010. var objArg = new Object();
  1011. objArg.arg_ds_send_item3 = ds_cond_sppiz01600;
  1012. frmf_modal("SPPIZ01600", "SPPIZ01600", objArg, "", "", "", "", "", "", "", "", "", "M");
  1013. }
  1014. /****************************************************************************************
  1015. * Argument : modal
  1016. * Description : 약품편람 조회 화면 modal 호출
  1017. ****************************************************************************************/
  1018. function lf_fOrderDrugHBook()
  1019. {
  1020. dsf_createDsRow("ds_cond_smadb01900", [{col:"calcscorcd", type:"STRING", size:256 , val : ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd")}]);
  1021. var objArg = new Object();
  1022. objArg.arg_ds_hidden_receivedata = ds_cond_smadb01900;
  1023. frmf_modal("SMADB01900", "SMADB01900", objArg, "", "", "", "", "", "", "", "", "", "M");
  1024. }
  1025. /****************************************************************************************
  1026. * Argument : grid
  1027. * Description : 그리드 행추가
  1028. ****************************************************************************************/
  1029. function lf_fOrderGridInsertRow()
  1030. {
  1031. var clodrow = ds_list2_clod.rowposition;
  1032. var preediitem1 = ds_list2_clod.getColumn(clodrow, "ediitem1");
  1033. var prematractflag = ds_list2_clod.getColumn(clodrow, "matractflag");
  1034. var prepayflag = ds_list2_clod.getColumn(clodrow, "payflag");
  1035. var ordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  1036. var clodrow = ds_list2_clod.insertRow(clodrow == -1 ? 0 : clodrow+1);
  1037. ds_list2_clod.enableevent = false;
  1038. ds_list2_clod.setColumn(clodrow, "ediitem1" , preediitem1);
  1039. ds_list2_clod.setColumn(clodrow, "matractflag" , prematractflag);
  1040. ds_list2_clod.setColumn(clodrow, "payflag" , prepayflag);
  1041. ds_list2_clod.setColumn(clodrow, "orddd" , ordfromdd);
  1042. ds_list2_clod.setColumn(clodrow, "ordfromdd" , ordfromdd);
  1043. ds_list2_clod.setColumn(clodrow, "ordtodd" , ordfromdd);
  1044. ds_list2_clod.setColumn(clodrow, "dayno" , "1");
  1045. ds_list2_clod.setColumn(clodrow, "orddd", ordfromdd);
  1046. ds_list2_clod.setColumn(clodrow, "ordfromdd", ordfromdd);
  1047. ds_list2_clod.setColumn(clodrow, "ordtodd", ordfromdd);
  1048. ds_list2_clod.setColumn(clodrow, "dayno", "1");
  1049. ds_list2_clod.enableevent = true;
  1050. ds_list2_clod.clearSelect();
  1051. ds_list2_clod.rowposition = clodrow;
  1052. ds_list2_clod.selectRow(clodrow);
  1053. var newcd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  1054. if (newcd)
  1055. {
  1056. ds_list2_clod.setColumn(clodrow, "adjtresncd", newcd);
  1057. lf_fOrderBkColorNew(clodrow);
  1058. }
  1059. else
  1060. {
  1061. newcd = lf_fSetAdjtResnCd();
  1062. if (utlf_isNull(newcd) || newcd == "-")
  1063. {
  1064. ds_list2_clod.deleteRow(clodrow);
  1065. }
  1066. }
  1067. }
  1068. /****************************************************************************************
  1069. * Argument : grid
  1070. * Description : 그리드행삭제
  1071. ****************************************************************************************/
  1072. function lf_fOrderGridDeleteRow()
  1073. {
  1074. var newcd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  1075. var newdesc = "";
  1076. var selectgrupcd = "";
  1077. if (utlf_isNull(newcd))
  1078. {
  1079. var oldcd = ds_list2_clod.getColumn(i, "adjtresncd");
  1080. var sppiz01000 = new Object();
  1081. sppiz01000.sCdCls = "aftout";
  1082. sppiz01000.sCdid = oldcd;
  1083. sppiz01000.sAdjtresndesc = "";
  1084. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  1085. newcd = objArg.sCdid;
  1086. newdesc = objArg.sAdjtresndesc;
  1087. if (utlf_isNull(newcd) || newcd == "-")
  1088. {
  1089. return;
  1090. }
  1091. }
  1092. var SelectedRows = grdf_getSelectedRows(grp_biz.grd_clodhist)
  1093. for(var i = SelectedRows.length-1; i >= 0; i--)
  1094. {
  1095. if ( ds_list2_clod.getRowType(SelectedRows[i]) == 2 )
  1096. {
  1097. ds_list2_clod.deleteRow(SelectedRows[i]);
  1098. }
  1099. else
  1100. {
  1101. var selectgrupcd = ds_list2_clod.getColumn(SelectedRows[i], "grupcalcscorcd");
  1102. var seqno = ds_list2_clod.getColumn(SelectedRows[i], "seqno");
  1103. var selectgrupflag = ds_list2_clod.getColumn(SelectedRows[i], "grupsnglflag");
  1104. if ( newcd != ds_list2_clod.getColumn(SelectedRows[i], "adjtresncd"))
  1105. {
  1106. if ( ds_list2_clod.getRowType(SelectedRows[i]) == 1 )
  1107. {
  1108. grdf_setStatus(grp_biz.grd_clodhist, "U", SelectedRows[i]);
  1109. }
  1110. }
  1111. ds_list2_clod.setColumn(SelectedRows[i], "adjtresncd" , newcd);
  1112. ds_list2_clod.setColumn(SelectedRows[i], "adjtresndesc", newdesc);
  1113. ds_list2_clod.deleteRow(SelectedRows[i]);
  1114. // 해당 특정내역을 삭제한다.
  1115. var cur_filter = ds_list3_clsp.filterstr.current;
  1116. ds_list3_clsp.filter("");
  1117. var frow = ds_list3_clsp.findRowExpr("clodseqno=='"+seqno+"'");
  1118. while(frow > -1){
  1119. ds_list3_clsp.setColumn(frow, "rowstat","D");
  1120. ds_list3_clsp.updatecontrol = false;
  1121. ds_list3_clsp.setRowType(frow, 'd');
  1122. ds_list3_clsp.updatecontrol = true;
  1123. lf_fSetSpclSpecJX999()
  1124. ds_list3_clsp.deleteRow(frow);
  1125. frow = ds_list3_clsp.findRowExpr("clodseqno=='"+seqno+"'");
  1126. }
  1127. ds_list3_clsp.filter(cur_filter);
  1128. }
  1129. }
  1130. }
  1131. /****************************************************************************************
  1132. * Argument :
  1133. * Description :
  1134. ****************************************************************************************/
  1135. function lf_fSetPatPamInfo(objDs)
  1136. {
  1137. var pid = objDs.getColumn(0,"pid");
  1138. var indd = objDs.getColumn(0,"indd");
  1139. var cretno = objDs.getColumn(0,"cretno");
  1140. var instcd = objDs.getColumn(0,"instcd");
  1141. var stsioflag = objDs.getColumn(0,"stsioflag");
  1142. var ordtodd = objDs.getColumn(0,"ordtodd");
  1143. var ioflag = objDs.getColumn(0,"ioflag");
  1144. // 20100201 응급실 주과구분(C) 추가
  1145. if (stsioflag == "E" || stsioflag == "C" )
  1146. {
  1147. ioflag = "E";
  1148. srchdd = indd;
  1149. }
  1150. else
  1151. {
  1152. srchdd = ordtodd;
  1153. }
  1154. if (!utlf_isNull(cretno))
  1155. {
  1156. var param = ioflag + "▦" + pid + "▦" + indd + "▦" + cretno + "▦" + instcd + "▦" + srchdd; ;
  1157. frmf_setParameter("condparam", param);
  1158. frmf_setParameter("errflag", "Y");
  1159. var useyn = appf_initPatientInfo(param);
  1160. if(useyn == true)
  1161. {
  1162. frmf_setParameter("SPMMO08900_rtn_useyn", "");
  1163. }
  1164. else
  1165. {
  1166. appf_delPatientInfos();
  1167. }
  1168. }
  1169. else
  1170. {
  1171. appf_delPatientInfos();
  1172. }
  1173. }
  1174. /****************************************************************************************
  1175. * Argument :
  1176. * Description :
  1177. ****************************************************************************************/
  1178. function lf_getCheckMsg()
  1179. {
  1180. // "저장" Btn 클릭시에 인적사항이 변경되었는지 여부를 알기 위해 조회한 항목을 임시로 저장해두고 추후에 비교한다.
  1181. ds_hidden_item1_initclbs.copyData(ds_main_item1_clbs);
  1182. ds_hidden_item1_initmemo.copyData(ds_main_item1_memo);
  1183. ds_hidden_list2_clod.copyData(ds_list2_clod);
  1184. var realrgstno = ds_main_item1_clbs.getColumn(0, "realrgstno");
  1185. if(!utlf_isNull(realrgstno))
  1186. {
  1187. realrgstno = realrgstno.length;
  1188. }
  1189. else
  1190. {
  1191. realrgstno = 0;
  1192. }
  1193. if ( ds_main_item1_clbs.getColumn(0, "lockyn") != "Y"&& realrgstno == 13 && ds_main_item1_clbs.getColumn(0, "realrgstno") != ds_main_item1_clbs.getColumn(0, "patrrgstno")
  1194. && ds_main_item1_clbs.getColumn(0, "preresncd").substr(0, 2) == "91")
  1195. {
  1196. var ans = sysf_messageBox("명세서상의 주민번호와 온라인 상의 주민번호가 상이합니다. "+ "\n\n"
  1197. + "온라인 상의 주민번호는 ( "+ ds_main_item1_clbs.getColumn(0, "realrgstno").substr(0,6)
  1198. + "-"+ ds_main_item1_clbs.getColumn(0, "realrgstno").substr(6,7) + " ) 입니다." + "\n\n" + "주민번호를 변경 ", "S001");
  1199. if ( ans == 6 )
  1200. {
  1201. ds_main_item1_clbs.setColumn(0, "patrrgstno", ds_main_item1_clbs.getColumn(0, "realrgstno"));
  1202. }
  1203. }
  1204. }
  1205. /****************************************************************************************
  1206. * Argument :
  1207. * Description : 심사완료여부 상태따라 버튼권한 설정(현재환자 심사중 설정)
  1208. ****************************************************************************************/
  1209. function lf_fSetJudgStatBtnAuth()
  1210. {
  1211. var xAuth = frmf_checkAuth("X");
  1212. if(ds_tmp_clbs.rowcount > 0)
  1213. {
  1214. xAuth = false;
  1215. }
  1216. // if ( xAuth == true )
  1217. // {
  1218. var clamendyn = ds_main_item1_clbs.getColumn(0, "clamendyn");
  1219. var lockyn = ds_main_item1_clbs.getColumn(0, "lockyn");
  1220. if (lockyn == "N")
  1221. {
  1222. var userid = sysf_getUserId();
  1223. if (utlf_isNull(userid))
  1224. {
  1225. userid = "12345678";
  1226. }
  1227. var judgendyn = ds_main_item1_clbs.getColumn(0, "judgendyn");
  1228. if ( judgendyn == "B" )
  1229. {
  1230. if ( ds_hidden.getColumn(0, "reselect") == "N" )
  1231. {
  1232. var lastupdtrid = ds_main_item1_clbs.getColumn(0, "lastupdtrid");
  1233. if (lastupdtrid == userid)
  1234. {
  1235. grp_biz.btn_save.enable = true; //저장버튼
  1236. grp_biz.btn_save.class = "btn5";
  1237. grp_biz.btn_save.style.font = "dotum,9,bold";
  1238. grp_biz.btn_end.enable = true; //완료버튼
  1239. grp_biz.btn_end.class = "btn5";
  1240. grp_biz.btn_end.style.font = "dotum,9,bold";
  1241. grp_biz.btn_end.style.color = "#cc3333";
  1242. grp_biz.btn_unjudg.enable = true; //미심버튼
  1243. grp_biz.btn_unjudg.class = "btn5";
  1244. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1245. grp_biz.btn_unjudg.style.color = "#cc3333";
  1246. grp_biz.btn_rete.enable = true; //보류버튼
  1247. grp_biz.btn_rete.class = "btn5";
  1248. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1249. grp_biz.btn_rete.style.color = "#cc3333";
  1250. grp_biz.btn_del.enable = true; //삭제버튼
  1251. grp_biz.btn_del.class = "btn5";
  1252. grp_biz.btn_del.style.font = "dotum,9,bold";
  1253. grp_biz.btn_del.style.color = "#cc3333";
  1254. //lf_setAlramMessage("기존에 심사중이었던 환자입니다.");
  1255. trace("기존에 심사중이었던 환자입니다.")
  1256. }
  1257. else
  1258. {
  1259. grp_biz.btn_save.enable = false; //저장버튼
  1260. grp_biz.btn_save.class = "btn2";
  1261. grp_biz.btn_save.style.font = "dotum,9";
  1262. grp_biz.btn_end.enable = false; //완료버튼
  1263. grp_biz.btn_end.class = "btn2";
  1264. grp_biz.btn_end.style.color = "";
  1265. grp_biz.btn_end.style.font = "dotum,9";
  1266. grp_biz.btn_unjudg.enable = false; //미심버튼
  1267. grp_biz.btn_unjudg.class = "btn2";
  1268. grp_biz.btn_unjudg.style.color = "";
  1269. grp_biz.btn_unjudg.style.font = "dotum,9";
  1270. grp_biz.btn_rete.enable = false; //보류버튼
  1271. grp_biz.btn_rete.class = "btn2";
  1272. grp_biz.btn_rete.style.color = "";
  1273. grp_biz.btn_rete.style.font = "dotum,9";
  1274. grp_biz.btn_del.enable = false; //삭제버튼
  1275. grp_biz.btn_del.class = "btn2";
  1276. grp_biz.btn_del.style.color = "";
  1277. grp_biz.btn_del.style.font = "dotum,9";
  1278. lf_setAlramMessage("다른 심사자가 심사중인 환자입니다.");
  1279. }
  1280. }
  1281. else
  1282. {
  1283. grp_biz.btn_save.enable = true; //저장버튼
  1284. grp_biz.btn_save.class = "btn5";
  1285. grp_biz.btn_save.style.font = "dotum,9,bold";
  1286. grp_biz.btn_end.enable = true; //완료버튼
  1287. grp_biz.btn_end.class = "btn5";
  1288. grp_biz.btn_end.style.font = "dotum,9,bold";
  1289. grp_biz.btn_end.style.color = "#cc3333";
  1290. grp_biz.btn_unjudg.enable = true; //미심버튼
  1291. grp_biz.btn_unjudg.class = "btn5";
  1292. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1293. grp_biz.btn_unjudg.style.color = "#cc3333";
  1294. grp_biz.btn_rete.enable = true; //보류버튼
  1295. grp_biz.btn_rete.class = "btn5";
  1296. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1297. grp_biz.btn_rete.style.color = "#cc3333";
  1298. grp_biz.btn_del.enable = true; //삭제버튼
  1299. grp_biz.btn_del.class = "btn5";
  1300. grp_biz.btn_del.style.font = "dotum,9,bold";
  1301. grp_biz.btn_del.style.color = "#cc3333";
  1302. ds_hidden.setColumn(0, "reselect", "N");
  1303. }
  1304. }
  1305. else if (judgendyn != "B")
  1306. {
  1307. if ( ds_init_item3.getColumn(0, "judgidyn") == "Y" && judgendyn == "A")
  1308. {
  1309. var judgendyn = ds_main_item1_clbs.getColumn(0, "judgendyn");
  1310. ds_send_item4_endclbs.clearData();
  1311. ds_send_item4_endclbs.addRow();
  1312. ds_send_item4_endclbs.setColumn(0, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  1313. ds_send_item4_endclbs.setColumn(0, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  1314. ds_send_item4_endclbs.setColumn(0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  1315. ds_send_item4_endclbs.setColumn(0, "pidsn", ds_main_item1_clbs.getColumn(0, "pidsn"));
  1316. ds_send_item4_endclbs.setColumn(0, "judgendyn", "B");
  1317. var oParam = {};
  1318. oParam.id = "TXPID20302";
  1319. oParam.service = "aftjudgapp.InAftJudg";
  1320. oParam.method = "reqSetPidmclbsJudgEndYNAll";
  1321. oParam.inds = "endclbs=ds_send_item4_endclbs";
  1322. oParam.outds = "";
  1323. oParam.async = false;
  1324. //oParam.callback = "cf_TXPID20302";
  1325. tranf_submit(oParam);
  1326. ds_main_item1_clbs.setColumn(0, "judgendyn", "B");
  1327. ds_main_item1_clbs.setColumn(0, "lastupdtrid", userid);
  1328. lf_fSetJudgSaveState("B");
  1329. }
  1330. ds_hidden.setColumn(0, "orgjudgendyn", judgendyn);
  1331. if (judgendyn == "D")
  1332. {
  1333. grp_biz.btn_save.enable = false; //저장버튼
  1334. //2012.5.23 이경민 심사완료일자가 15일 이후면 완료버튼 비활성화 추가.
  1335. var judgenddd = ds_main_item1_clbs.getColumn(0, "judgenddd");
  1336. judgenddd = judgenddd.toDate();
  1337. var bfday15 = utlf_getCurrentDate().toDate().getAddDate(-15,'D');
  1338. if (judgenddd < bfday15)
  1339. {
  1340. grp_biz.btn_del.enable = false; //삭제버튼
  1341. grp_biz.btn_del.class = "btn2";
  1342. grp_biz.btn_del.style.color = "";
  1343. grp_biz.btn_del.style.font = "dotum,9";
  1344. }
  1345. else
  1346. {
  1347. grp_biz.btn_end.enable = true; //완료버튼
  1348. grp_biz.btn_end.class = "btn5";
  1349. grp_biz.btn_end.style.font = "dotum,9,bold";
  1350. grp_biz.btn_end.style.color = "#cc3333";
  1351. }
  1352. grp_biz.btn_unjudg.enable = true; //미심버튼
  1353. grp_biz.btn_unjudg.class = "btn5";
  1354. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1355. grp_biz.btn_unjudg.style.color = "#cc3333";
  1356. grp_biz.btn_rete.enable = true; //보류버튼
  1357. grp_biz.btn_rete.class = "btn5";
  1358. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1359. grp_biz.btn_rete.style.color = "#cc3333";
  1360. grp_biz.btn_unjudg.enable = true; //미심버튼
  1361. grp_biz.btn_rete.enable = true; //보류버튼
  1362. grp_biz.btn_del.enable = false; //삭제버튼
  1363. grp_biz.btn_del.class = "btn2";
  1364. grp_biz.btn_del.style.color = "";
  1365. grp_biz.btn_del.style.font = "dotum,9";
  1366. }
  1367. else if (judgendyn == "C" || judgendyn == "E" || judgendyn == "Z")
  1368. {
  1369. grp_biz.btn_save.enable = true; //저장버튼
  1370. grp_biz.btn_save.class = "btn5";
  1371. grp_biz.btn_save.style.font = "dotum,9,bold";
  1372. grp_biz.btn_end.enable = true; //완료버튼
  1373. grp_biz.btn_end.class = "btn5";
  1374. grp_biz.btn_end.style.font = "dotum,9,bold";
  1375. grp_biz.btn_end.style.color = "#cc3333";
  1376. grp_biz.btn_unjudg.enable = true; //미심버튼
  1377. grp_biz.btn_unjudg.class = "btn5";
  1378. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1379. grp_biz.btn_unjudg.style.color = "#cc3333";
  1380. grp_biz.btn_rete.enable = true; //보류버튼
  1381. grp_biz.btn_rete.class = "btn5";
  1382. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1383. grp_biz.btn_rete.style.color = "#cc3333";
  1384. grp_biz.btn_del.enable = true; //삭제버튼
  1385. grp_biz.btn_del.class = "btn5";
  1386. grp_biz.btn_del.style.font = "dotum,9,bold";
  1387. grp_biz.btn_del.style.color = "#cc3333";
  1388. }
  1389. else if (judgendyn == "A")
  1390. {
  1391. grp_biz.btn_save.enable = true; //저장버튼
  1392. grp_biz.btn_save.class = "btn5";
  1393. grp_biz.btn_save.style.font = "dotum,9,bold";
  1394. grp_biz.btn_end.enable = true; //완료버튼
  1395. grp_biz.btn_end.class = "btn5";
  1396. grp_biz.btn_end.style.font = "dotum,9,bold";
  1397. grp_biz.btn_end.style.color = "#cc3333";
  1398. grp_biz.btn_rete.enable = true; //보류버튼
  1399. grp_biz.btn_rete.class = "btn5";
  1400. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1401. grp_biz.btn_rete.style.color = "#cc3333";
  1402. grp_biz.btn_del.enable = true; //삭제버튼
  1403. grp_biz.btn_del.class = "btn5";
  1404. grp_biz.btn_del.style.font = "dotum,9,bold";
  1405. grp_biz.btn_del.style.color = "#cc3333";
  1406. grp_biz.btn_unjudg.enable = false;
  1407. grp_biz.btn_unjudg.class = "btn2";
  1408. grp_biz.btn_unjudg.style.color = "";
  1409. grp_biz.btn_unjudg.style.font = "dotum,9";
  1410. }
  1411. else if (judgendyn == "N")
  1412. {
  1413. grp_biz.btn_save.enable = true; //저장버튼
  1414. grp_biz.btn_save.class = "btn5";
  1415. grp_biz.btn_save.style.font = "dotum,9,bold";
  1416. grp_biz.btn_end.enable = true; //완료버튼
  1417. grp_biz.btn_end.class = "btn5";
  1418. grp_biz.btn_end.style.font = "dotum,9,bold";
  1419. grp_biz.btn_end.style.color = "#cc3333";
  1420. grp_biz.btn_unjudg.enable = true; //미심버튼
  1421. grp_biz.btn_unjudg.class = "btn5";
  1422. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1423. grp_biz.btn_unjudg.style.color = "#cc3333";
  1424. grp_biz.btn_del.enable = true; //삭제버튼
  1425. grp_biz.btn_del.class = "btn5";
  1426. grp_biz.btn_del.style.font = "dotum,9,bold";
  1427. grp_biz.btn_del.style.color = "#cc3333";
  1428. grp_biz.btn_rete.enable = false;
  1429. grp_biz.btn_rete.class = "btn2";
  1430. grp_biz.btn_rete.style.color = "";
  1431. grp_biz.btn_rete.style.font = "dotum,9";
  1432. }
  1433. else
  1434. {
  1435. grp_biz.btn_save.enable = true; //저장버튼
  1436. grp_biz.btn_save.class = "btn5";
  1437. grp_biz.btn_save.style.font = "dotum,9,bold";
  1438. grp_biz.btn_end.enable = true; //완료버튼
  1439. grp_biz.btn_end.class = "btn5";
  1440. grp_biz.btn_end.style.font = "dotum,9,bold";
  1441. grp_biz.btn_end.style.color = "#cc3333";
  1442. grp_biz.btn_unjudg.enable = true; //미심버튼
  1443. grp_biz.btn_unjudg.class = "btn5";
  1444. grp_biz.btn_unjudg.style.font = "dotum,9,bold";
  1445. grp_biz.btn_unjudg.style.color = "#cc3333";
  1446. grp_biz.btn_rete.enable = true; //보류버튼
  1447. grp_biz.btn_rete.class = "btn5";
  1448. grp_biz.btn_rete.style.font = "dotum,9,bold";
  1449. grp_biz.btn_rete.style.color = "#cc3333";
  1450. grp_biz.btn_del.enable = true; //삭제버튼
  1451. grp_biz.btn_del.class = "btn5";
  1452. grp_biz.btn_del.style.font = "dotum,9,bold";
  1453. grp_biz.btn_del.style.color = "#cc3333";
  1454. }
  1455. }
  1456. }
  1457. else
  1458. {
  1459. grp_biz.btn_save.enable = false; //저장버튼
  1460. grp_biz.btn_save.class = "btn2";
  1461. grp_biz.btn_save.style.font = "dotum,9";
  1462. grp_biz.btn_end.enable = false; //완료버튼
  1463. grp_biz.btn_end.class = "btn2";
  1464. grp_biz.btn_end.style.color = "";
  1465. grp_biz.btn_end.style.font = "dotum,9";
  1466. grp_biz.btn_unjudg.enable = false; //미심버튼
  1467. grp_biz.btn_unjudg.class = "btn2";
  1468. grp_biz.btn_unjudg.style.color = "";
  1469. grp_biz.btn_unjudg.style.font = "dotum,9";
  1470. grp_biz.btn_rete.enable = false; //보류버튼
  1471. grp_biz.btn_rete.class = "btn2";
  1472. grp_biz.btn_rete.style.color = "";
  1473. grp_biz.btn_rete.style.font = "dotum,9";
  1474. grp_biz.btn_del.enable = false; //삭제버튼
  1475. grp_biz.btn_del.class = "btn2";
  1476. grp_biz.btn_del.style.color = "";
  1477. grp_biz.btn_del.style.font = "dotum,9";
  1478. }
  1479. // }
  1480. var suppkindcd = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  1481. if (!utlf_isNull(suppkindcd) && suppkindcd != "00")
  1482. {
  1483. grp_sea00.opt_suppkind.style.backgroundColor = "#f7a08b"; // class="color_6" 다홍색"#cece9c";
  1484. grp_sea00.opt_payownbrate.style.backgroundColor = "#f7a08b"; // class="color_6" 다홍색"#cece9c";
  1485. }
  1486. else
  1487. {
  1488. grp_sea00.opt_suppkind.style.backgroundColor = "#f2f2f2"; // output_fix클래스의background-color
  1489. grp_sea00.opt_payownbrate.style.backgroundColor = "#f2f2f2"; // output_fix클래스의background-color
  1490. }
  1491. if (ds_main_item1_clbs.getColumn(0,"ioflag") == "I" || frmf_getScreenID() == "SMPID20300")
  1492. {
  1493. if(ds_main_item1_clbs.getColumn(0, "opyn") == "Y")
  1494. {
  1495. grp_biz.btn_opyn.visible = true;
  1496. grp_biz.btn_opyn.class = "btn5";
  1497. grp_biz.btn_opyn.style.color = "#ff0066";
  1498. }
  1499. else
  1500. {
  1501. grp_biz.btn_opyn.visible = false;
  1502. grp_biz.btn_opyn.class = "btn2";
  1503. grp_biz.btn_opyn.style.color = "";
  1504. }
  1505. lf_fCheckSpclSpecData();
  1506. var clbs_licnsno = ds_main_item1_clbs.getColumn(0, "licnsno");
  1507. var cldi_licnsno = ds_main_item1_clbs.lookup("diagseq", "1", "licnsno");
  1508. var clod_snglcalcscorcd = ds_list8_clod2.lookupExpr("item == '0101' || item == '0102'", "snglcalcscorcd");
  1509. if (ds_main_item1_clbs.getColumn(0, "patmsgyn") == "Y")
  1510. {
  1511. img_msg.visible = true;
  1512. }
  1513. else
  1514. {
  1515. img_msg.visible = false;
  1516. }
  1517. var fixrateyn = ds_main_item1_clbs.getColumn(0, "fixrateyn");
  1518. if (fixrateyn == "7" || fixrateyn == "8")
  1519. {
  1520. grp_biz.pm_flag.visible = true;
  1521. }
  1522. }
  1523. else
  1524. {
  1525. if (ds_main_item1_clbs.getColumn(0, "opyn") == "Y")
  1526. {
  1527. grp_biz.btn_opyn.visible = true;
  1528. grp_biz.btn_opyn.class = "btn5";
  1529. grp_biz.btn_opyn.style.color = "#cc3333"; // 해당 정보가 있는 경우 버튼 색 변경 // cc3333=붉은색
  1530. // 중증질환 Btn
  1531. grp_biz.btn_esscdiag.position.left = "215";
  1532. }
  1533. else
  1534. {
  1535. grp_biz.btn_opyn.visible = false;
  1536. grp_biz.btn_opyn.class = "btn2";
  1537. grp_biz.btn_opyn.style.color = "";
  1538. }
  1539. }
  1540. var dispclsp = ds_main_item1_clbs.getColumn(0, "dispclsp");
  1541. if(dispclsp == "S")
  1542. {
  1543. grp_biz.swt_spclmemo.tabindex = 0;
  1544. }
  1545. else if(dispclsp == "E")
  1546. {
  1547. grp_biz.swt_spclmemo.tabindex = 2;
  1548. }
  1549. else if(dispclsp == "U")
  1550. {
  1551. grp_biz.swt_spclmemo.tabindex = 1;
  1552. }
  1553. if ( lgv_ds_rslt.getColumn(0, "judgendyn") == "A" // 대상자조회창
  1554. && ( ds_main_item1_clbs.getColumn(0, "judgendyn") == "C" // 심사화면 심사완료
  1555. || ds_main_item1_clbs.getColumn(0, "judgendyn") == "Z" // 심사화면 일괄완료
  1556. )
  1557. ) {
  1558. lf_setAlramMessage("심사 완료되어 있는 명세서 입니다.", "I005"); //심사 완료되어 있는 명세서입니다.
  1559. }
  1560. else if ( lgv_ds_rslt.getColumn(0, "judgendyn") == "A" // 대상자조회창
  1561. && ds_main_item1_clbs.getColumn(0, "judgendyn") == "N" // 심사화면 보류
  1562. ) {
  1563. lf_setAlramMessage("심사 보류되어 있는 명세서 입니다.", "I005"); //심사 보류되어 있는 명세서입니다.
  1564. }
  1565. if ( ds_main_item1_clbs.getColumn(0, "insukindcd") == "31" )
  1566. {
  1567. grp_sea00.cap_insdnm.text = "사고일자";
  1568. grp_sea00.cap_certno.text = "접수번호";
  1569. }
  1570. else if (ds_main_item1_clbs.getColumn(0, "insukindcd") == "41")
  1571. {
  1572. grp_sea00.cap_insdnm.text = "사고일자";
  1573. grp_sea00.cap_certno.text = "관리번호";
  1574. }
  1575. else
  1576. {
  1577. grp_sea00.cap_insdnm.text = "가입자";
  1578. grp_sea00.cap_certno.text = "증번호";
  1579. }
  1580. if ( ds_main_item1_clbs.getColumn(0, "patmsgyn") == "Y")
  1581. {
  1582. img_msg.visible = true;
  1583. }
  1584. else
  1585. {
  1586. img_msg.visible = false;
  1587. }
  1588. if ( ds_main_item1_clbs.getColumn(0, "sumtypecd") == "T")
  1589. {
  1590. if (lgv_ioflag == "O") {
  1591. grp_biz.opt_etcordflag.visible = true;
  1592. } else {
  1593. grp_sea00.opt_etcordflag.visible = true;
  1594. }
  1595. }
  1596. else
  1597. {
  1598. if (lgv_ioflag == "O") {
  1599. grp_biz.opt_etcordflag.visible = false;
  1600. } else {
  1601. grp_sea00.opt_etcordflag.visible = false;
  1602. }
  1603. }
  1604. var supprate = ds_main_item1_clbs.getColumn(0, "suppkindcd")+"/"+ds_main_item1_clbs.getColumn(0, "payownbrate"); // 보조유형ID과 요율%로 combo 의 value
  1605. ds_main_item1_clbs.addColumn("patsupprate", "STRING");
  1606. ds_main_item1_clbs.setColumn(0, "patsupprate", supprate);
  1607. if (ds_main_item1_clbs.getColumn(0, "insukindcd") == "41")
  1608. {
  1609. // cmb_ordrsltcd의 INIT Dataset - 진료결과
  1610. grp_sea00.cmb_ordrsltcd.innerdataset = "ds_init_P0297";
  1611. }
  1612. else
  1613. {
  1614. grp_sea00.cmb_ordrsltcd.innerdataset = "ds_init_P0110";
  1615. }
  1616. }
  1617. /****************************************************************************************
  1618. * Argument :
  1619. * Description :
  1620. ****************************************************************************************/
  1621. function lf_fSetJudgSaveState(judgendyn)
  1622. {
  1623. var userid = sysf_getUserId(); // (common.js) 현재 로그인한 사용자 번호(ID)
  1624. if (userid) {
  1625. } else {
  1626. userid = "12345678";
  1627. }
  1628. var trgtManWindow = frmf_getChildWindow(lgv_trgtManWindow); //SMPID20400,SMPID20200
  1629. if (!utlf_isNull(trgtManWindow))
  1630. {
  1631. var selectedRow = trgtManWindow.ds_grid_grd_clbsmast.rowposition;
  1632. if (selectedRow > -1)
  1633. {
  1634. var trgtmanlist = lgv_ds_rslt.rowcount;
  1635. if (trgtmanlist < 0)
  1636. {
  1637. }
  1638. else
  1639. {
  1640. var userid = sysf_getUserInfo();
  1641. if (utlf_isNull(userid))
  1642. {
  1643. userid = "12345678";
  1644. }
  1645. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  1646. var srchmode = trgtManWindow.ds_hidden_clbs.getColumn(0, "srchmode");
  1647. if (srchmode == "specclbs")
  1648. {
  1649. var fclamkey = trgtManWindow.ds_grid_grd_clbsmast.findRow("clamkey", clamkey);
  1650. var fjudgendyn = trgtManWindow.ds_grid_grd_clbsmast.getColumn(fclamkey, "judgendyn")
  1651. if (fclamkey > -1 && fjudgendyn != "Z")
  1652. {
  1653. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "judgendyn", judgendyn);
  1654. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "lastupdtrid", userid);
  1655. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "prepdata", (grp_biz.btn_attData.class == "btn5" ? "Y" : ""));
  1656. }
  1657. }
  1658. else
  1659. {
  1660. var fclamkey = trgtManWindow.ds_grid_grd_clbsmast.findRow("clamkey", clamkey);
  1661. var fjudgendyn = trgtManWindow.ds_grid_grd_clbsmast.getColumn(fclamkey, "judgendyn")
  1662. if (fclamkey > -1)
  1663. {
  1664. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "judgendyn", judgendyn);
  1665. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "lastupdtrid", userid);
  1666. trgtManWindow.ds_grid_grd_clbsmast.setColumn(fclamkey, "prepdata", (grp_biz.btn_attData.class == "btn5" ? "Y" : ""));
  1667. }
  1668. }
  1669. trgtManWindow.lf_fSetWorkStatCnt();
  1670. }
  1671. }
  1672. }
  1673. }
  1674. /****************************************************************************************
  1675. * Argument :
  1676. * Description : TRPID20308 submit callback
  1677. ****************************************************************************************/
  1678. function cf_TRPID20308(sSvcId, nErrorCode, sErrorMsg)
  1679. {
  1680. if(nErrorCode < 0)
  1681. {
  1682. alert("["+sSvcId+"]"+sErrorMsg);
  1683. return;
  1684. }
  1685. if (ds_rslt_aftjudgbtn.getColumn(0,"patspcfyn") == "Y")
  1686. {
  1687. btn_patspcfyn.style.backgroundImage = "URL('theme://images/icon_btn_s.gif')";
  1688. }
  1689. else
  1690. {
  1691. btn_patspcfyn.style.backgroundImage = "URL('theme://images/icon_btn.png')"; // 파란색
  1692. }
  1693. // 이전명세서 버튼 설정
  1694. if (ds_rslt_aftjudgbtn.getColumn(0, "predocuyn") == "Y")
  1695. {
  1696. grp_biz.btn_predocu.class = "btn5";
  1697. grp_biz.btn_predocu.style.color = "#cc3333";
  1698. }
  1699. else
  1700. {
  1701. grp_biz.btn_predocu.class = "btn2";
  1702. grp_biz.btn_predocu.style.color = "";
  1703. }
  1704. if ( ds_rslt_aftjudgbtn.getColumn(0, "cutprcpyn") == "Y" )
  1705. {
  1706. if (ds_send_item1_clbs.getColumn(0, "cutprcpyn") == "2"){
  1707. lf_pidfOpenSMPIS00600(ds_main_item1_clbs.getColumn(0, "ioflag"), "D", "O");
  1708. } else {
  1709. btn_redu.class = "btn5";
  1710. btn_redu.style.color = "#cc3333";
  1711. }
  1712. }
  1713. else
  1714. {
  1715. btn_redu.class = "btn2";
  1716. btn_redu.style.color = "";
  1717. }
  1718. // 상병이력 버튼 설정
  1719. if ( ds_rslt_aftjudgbtn.getColumn(0, "diaghist") == "Y")
  1720. {
  1721. grp_biz.btn_diagHist.class = "btn5";
  1722. grp_biz.btn_diagHist.style.color = "#cc3333"; // 해당 정보가 있는 경우 버튼 색 변경 cc3333=붉은색
  1723. }
  1724. else
  1725. {
  1726. grp_biz.btn_diagHist.class = "btn2"; // 표준에서 정한 기본 버튼으로 설정
  1727. }
  1728. if (ds_main_item1_clbs.getColumn(0,"ioflag") == "O")
  1729. {
  1730. // 미시행처방 버튼 설정
  1731. if ( ds_rslt_aftjudgbtn.getColumn(0, "unexecord") == "Y")
  1732. {
  1733. grp_biz.btn_unexecord.class = "btn5";
  1734. grp_biz.btn_unexecord.style.color = "#cc3333";
  1735. }
  1736. else
  1737. {
  1738. grp_biz.btn_unexecord.class = "btn2";
  1739. }
  1740. }
  1741. else
  1742. {
  1743. if ( ds_rslt_aftjudgbtn.getColumn(0, "bornbaby") == "Y")
  1744. {
  1745. grp_biz.btn_babymom.visible = true;
  1746. grp_biz.btn_babymom.style.color = "#cc3333"; // "#ff0066"; 해당 정보가 있는 경우 버튼 색 변경 cc3333=붉은색
  1747. }
  1748. else
  1749. {
  1750. grp_biz.btn_babymom.visible = false;
  1751. grp_biz.btn_babymom.class = "btn2"; // 표준에서 정한 기본 버튼으로 설정
  1752. grp_biz.btn_babymom.style.color = "";
  1753. }
  1754. if ( ds_rslt_aftjudgbtn.getColumn(0, "oprcp") == "Y")
  1755. {
  1756. grp_biz.btn_oprcp.class = "btn5";
  1757. grp_biz.btn_oprcp.style.color = "#cc3333"; // "#ff0066"; 해당 정보가 있는 경우 버튼 색 변경 cc3333=붉은색
  1758. }
  1759. else
  1760. {
  1761. grp_biz.btn_oprcp.class = "btn2"; // 표준에서 정한 기본 버튼으로 설정
  1762. grp_biz.btn_oprcp.style.color = "";
  1763. }
  1764. if (ds_rslt_aftjudgbtn.getColumn(0, "diaghist") == "Y")
  1765. {
  1766. grp_biz.btn_diagHist.class = "btn5";
  1767. grp_biz.btn_diagHist.style.color = "#cc3333";
  1768. }
  1769. else
  1770. {
  1771. grp_biz.btn_diagHist.class = "btn2";
  1772. grp_biz.btn_diagHist.style.color = "";
  1773. }
  1774. }
  1775. if ( ds_rslt_aftjudgbtn.getColumn(0, "samedocuyn") == "Y")
  1776. {
  1777. lf_setAlramMessage("동일진료일자 동일진료과 명세서가 존재합니다. 확인하십시오 !");
  1778. }
  1779. if ( ds_rslt_aftjudgbtn.getColumn(0, "samedocuioyn") == "Y")
  1780. {
  1781. lf_setAlramMessage("동일진료일자 동일진료과 입원 명세서가 존재합니다. 확인하십시오 !");
  1782. }
  1783. }
  1784. /****************************************************************************************
  1785. * Argument :
  1786. * Description : TRPID20321 submit callback
  1787. ****************************************************************************************/
  1788. function cf_TRPID20321(sSvcId, nErrorCode, sErrorMsg)
  1789. {
  1790. if(nErrorCode < 0)
  1791. {
  1792. alert("["+sSvcId+"]"+sErrorMsg);
  1793. return;
  1794. }
  1795. ds_hidden_item1_initmemo.copyData(ds_main_item1_memo);
  1796. //메모여부에 따른 색깔분류 - 박창원 20091102
  1797. var edimemo = ds_main_item1_memo.getColumn(0,"edimemo");
  1798. var usermemo = ds_main_item1_memo.getColumn(0,"judgmemo");
  1799. var edilength = edimemo.length;
  1800. var userlength = usermemo.length;
  1801. if (userlength > 0)
  1802. {
  1803. grp_biz.swt_spclmemo.case_judgrmemo.text = "심사자메모●";
  1804. }
  1805. else
  1806. {
  1807. grp_biz.swt_spclmemo.case_judgrmemo.text = "심사자메모";
  1808. }
  1809. if (edilength > 0)
  1810. {
  1811. grp_biz.swt_spclmemo.case_ediclammemo.text = "EDI 메모●";
  1812. }
  1813. else
  1814. {
  1815. grp_biz.swt_spclmemo.case_ediclammemo.text = "EDI 메모";
  1816. }
  1817. }
  1818. /****************************************************************************************
  1819. * Argument : TRPIJ00340
  1820. * Description : TRPIJ00340 submit callback
  1821. ****************************************************************************************/
  1822. function cf_TRPIJ00340(sSvcId, nErrorCode, sErrorMsg)
  1823. {
  1824. if(nErrorCode < 0)
  1825. {
  1826. sysf_messageBox("데이터 가","I004");
  1827. return;
  1828. }
  1829. var serdiagfromdd = ds_init_cmb_rarecancermsg.getCaseMax("rgstkindcd == '00'","rareobstfromdd");
  1830. var serdiagtodd = ds_init_cmb_rarecancermsg.getCaseMax("rgstkindcd == '00'","rareobsttodd");
  1831. var itemmsg = ds_init_cmb_rarecancermsg.lookupExpr("rgstkindcd=='00' && rareobsttodd=='"+serdiagtodd+"'","msg");
  1832. var rareobstfromdd = ds_init_cmb_rarecancermsg.getCaseMax("rgstkindcd != '00'","rareobstfromdd");
  1833. var rareobsttodd = ds_init_cmb_rarecancermsg.getCaseMax("rgstkindcd != '00'","rareobsttodd");
  1834. var raremsg = ds_init_cmb_rarecancermsg.lookupExpr("rgstkindcd!='00' && rareobsttodd=='"+serdiagtodd+"'","msg");
  1835. cmb_rarecancermsg.index = 0;
  1836. //lf_fGetPersonalData();
  1837. }
  1838. /****************************************************************************************
  1839. * Argument :
  1840. * Description : TRPID20324 submit callback
  1841. ****************************************************************************************/
  1842. function cf_TRPID20324(sSvcId, nErrorCode, sErrorMsg)
  1843. {
  1844. if(nErrorCode < 0)
  1845. {
  1846. alert("["+sSvcId+"]"+sErrorMsg);
  1847. return;
  1848. }
  1849. for (var i = 0; i < ds_list1_cldi.rowcount; i++)
  1850. {
  1851. var srchnm = utlf_transNullToEmpty(ds_list1_cldi.getColumn(i, "diagcd")).substr(0, 2);
  1852. var t_vcode = ds_list1_cldi.getColumn(i, "vcode");
  1853. var rowno, rn = 0;
  1854. rowno = ds_list1_cldi.findRowAs("diagcd",srchnm);
  1855. if (t_vcode != "V252" && t_vcode != "V193")
  1856. {
  1857. while( rowno > -1)
  1858. {
  1859. var s_vcode = ds_list1_cldi.getColumn(rowno, "vcode");
  1860. var t_diagcd = utlf_transNullToEmpty(ds_list1_cldi.getColumn(rowno, "diagcd")).substr(0, 2);
  1861. if (rowno != i && !utlf_isNull(t_diagcd) && !utlf_isNull(t_vcode) && srchnm == t_diagcd && t_vcode == s_vcode )
  1862. {
  1863. ds_list1_cldi.updatecontrol = false;
  1864. ds_list1_cldi.setColumn(rowno, "bgcolor", "#ffff9c"); //#ffff9c=연한노랑
  1865. ds_list1_cldi.updatecontrol = true;
  1866. }
  1867. rowno = ds_list1_cldi.findRowAs("diagcd",srchnm, rowno + 1);
  1868. }
  1869. }
  1870. var srchnm2 = utlf_transNullToEmpty(ds_list1_cldi.getColumn(i, "diagcd")).substr(0, 3);
  1871. rn = ds_list1_cldi.findRowAs("diagcd",srchnm2);
  1872. while( rn > -1)
  1873. {
  1874. var t_diagcd = utlf_transNullToEmpty(ds_list1_cldi.getColumn(rn, "diagcd")).substr(0, 3);
  1875. if (rn != i && srchnm2 == t_diagcd && !utlf_isNull(t_diagcd))
  1876. {
  1877. ds_list1_cldi.updatecontrol = false;
  1878. ds_list1_cldi.setColumn(rn, "bgcolor", "#ffff9c"); //#ffff9c=연한노랑
  1879. ds_list1_cldi.updatecontrol = true;
  1880. }
  1881. rn = ds_list1_cldi.findRowAs("diagcd",srchnm2, rn + 1);
  1882. }
  1883. }
  1884. rn = ds_list1_cldi.findRow("kcd6chk","Y");
  1885. while( rn > -1)
  1886. {
  1887. ds_list1_cldi.updatecontrol = false;
  1888. ds_list1_cldi.setColumn(rn, "bgcolor", "#6699ff");
  1889. ds_list1_cldi.updatecontrol = true;
  1890. rn = ds_list1_cldi.findRow("kcd6chk","Y", rn + 1);
  1891. }
  1892. rn = ds_list1_cldi.findRow("endyn","Y");
  1893. while( rn > -1)
  1894. {
  1895. ds_list1_cldi.updatecontrol = false;
  1896. ds_list1_cldi.setColumn(rn, "bgcolor", "#ff0000");
  1897. ds_list1_cldi.setRowType(rn, 8);
  1898. ds_list1_cldi.setColumn(rn, "diagseq", ds_list1_cldi.rowcount + 1 );
  1899. ds_list1_cldi.updatecontrol = true;
  1900. rn = ds_list1_cldi.findRow("endyn","Y", rn + 1);
  1901. }
  1902. lf_fDiagGridInsertRow("Y", "N", "1"); // 상병마지막 그리드에 한줄추가
  1903. //ds_list1_cldi.rowposition = 0;
  1904. }
  1905. /****************************************************************************************
  1906. * Argument :
  1907. * Description : TRPID20326 submit callback
  1908. ****************************************************************************************/
  1909. function cf_TRPID20326(sSvcId, nErrorCode, sErrorMsg)
  1910. {
  1911. if(nErrorCode < 0)
  1912. {
  1913. alert("["+sSvcId+"]"+sErrorMsg);
  1914. return;
  1915. }
  1916. for ( var i = 1 ; i < grp_biz.grd_oprcphist.getCellCount('Body'); i++ )
  1917. {
  1918. colorExpr = "EXPR( spcljudgyn == 'Y' ? '#ff3333' : surecdyn == 'Y' ? '#0000ff' : 'default'";
  1919. grp_biz.grd_oprcphist.setCellProperty('Body', i, "color", colorExpr);
  1920. }
  1921. // 원외처방 그리드 상태를 급여구분 기본값인 "급여"로 필터링한다.
  1922. grp_biz_rdo_cloppayflag_onitemchanged(grp_biz.rdo_cloppayflag);
  1923. }
  1924. /****************************************************************************************
  1925. * Argument :
  1926. * Description : TRPID20330 submit callback
  1927. ****************************************************************************************/
  1928. function cf_TRPID20330(sSvcId, nErrorCode, sErrorMsg)
  1929. {
  1930. if(nErrorCode < 0)
  1931. {
  1932. alert("["+sSvcId+"]"+sErrorMsg);
  1933. return;
  1934. }
  1935. if (ds_rslt_dupid.rowcount > 0 )
  1936. {
  1937. if (ds_main_item1_clbs.getColumn(0,"pid") == ds_rslt_dupid.getColumn(0,"newpid"))
  1938. {
  1939. duppid = ds_rslt_dupid.getColumn(0,"oldpid")
  1940. }
  1941. lf_setAlramMessage("★★★ 합번정보 : 해당 환자는 "+duppid+" 챠트번호와 합번정보가 있으며, " +
  1942. "진료개시일이 동일한 "+duppid+"의 명세서가 존재하니 반드시 청구여부 확인하시기 바랍니다. ★★★");
  1943. }
  1944. }
  1945. /****************************************************************************************
  1946. * Argument : submit
  1947. * Description : TRPID20328 submit callback
  1948. ****************************************************************************************/
  1949. function cf_TRPID20328(sSvcId, nErrorCode, sErrorMsg)
  1950. {
  1951. if(nErrorCode < 0) { alert("["+sSvcId+"]"+sErrorMsg); return; }
  1952. var orddiag = "";
  1953. if ((ds_rslt_mmohdiag1.rowcount > 0 && ds_rslt_mmohdiag2.rowcount == 0) || (ds_rslt_mmohdiag1.rowcount > 0 && ds_rslt_mmohdiag2.rowcount > 0))
  1954. {
  1955. orddiag = ds_rslt_mmohdiag1.getColumn(0,"diagcd");
  1956. grp_biz.cbo_diag.innerdataset = "ds_rslt_mmohdiag1";
  1957. }
  1958. else if (ds_rslt_mmohdiag1.rowcount == 0 && ds_rslt_mmohdiag2.rowcount > 0)
  1959. {
  1960. orddiag = ds_rslt_mmohdiag2.getColumn(0,"diagcd");
  1961. grp_biz.cbo_diag.innerdataset = "ds_rslt_mmohdiag2";
  1962. }
  1963. ds_main_item1_clbs.addColumn("orddiag", "string");
  1964. ds_main_item1_clbs.setColumn(0, "orddiag", orddiag);
  1965. lf_showDsValue(ds_rslt_mmohdiag1, "diagcd", "diaghngnm");
  1966. lf_showDsValue(ds_rslt_mmohdiag2, "diagcd", "diaghngnm");
  1967. }
  1968. /****************************************************************************************
  1969. * Argument : messagebox
  1970. * Description : messagebox
  1971. ****************************************************************************************/
  1972. function lf_setAlramMessage(msg)
  1973. {
  1974. var nrow = ds_grd_msg.addRow();
  1975. ds_grd_msg.setColumn(nrow,"msg", msg);
  1976. grp_msg.position.x = 343;
  1977. grp_msg.position.y = 241;
  1978. grp_msg.visible = true;
  1979. grp_msg.button25.setFocus();
  1980. grp_msg.bringToFront();
  1981. }
  1982. /****************************************************************************************
  1983. * Argument :
  1984. * Description : 처방별환자조회(계산)_수가코드
  1985. ****************************************************************************************/
  1986. function lf_fOpenSMPIS00500DetailSnglCD()
  1987. {
  1988. lf_pidfOpenSMPIS00500(ds_main_item1_clbs.getColumn(0, "ioflag"), "D", "SnglCD");
  1989. }
  1990. /****************************************************************************************
  1991. * Argument :
  1992. * Description : 처방별환자조회(계산)_EDI코드
  1993. ****************************************************************************************/
  1994. function lf_fOpenSMPIS00500DetailEdicd()
  1995. {
  1996. lf_pidfOpenSMPIS00500(ds_main_item1_clbs.getColumn(0, "ioflag"), "D", "Edicd");
  1997. }
  1998. /****************************************************************************************
  1999. * Argument :
  2000. * Description : 처방별환자조회(청구/삭감)
  2001. ****************************************************************************************/
  2002. function lf_fOpenSMPIS00600Detail()
  2003. {
  2004. lf_pidfOpenSMPIS00600(ds_main_item1_clbs.getColumn(0, "ioflag"), "D");
  2005. }
  2006. /****************************************************************************************
  2007. * Argument : modal
  2008. * Description : 청구삭감조회화면 호출
  2009. ****************************************************************************************/
  2010. function lf_pidfOpenSMPIS00600(ioflag, calltype, opentype)
  2011. {
  2012. ds_cond_smpis00600.clearData();
  2013. ds_cond_smpis00600.addRow();
  2014. if (calltype == "M")
  2015. {
  2016. if (ioflag == "I")
  2017. {
  2018. var irow = ds_grid_grd_clbsmast.rowposition;
  2019. }
  2020. var pid = ds_grid_grd_clbsmast.getColumn(irow, "pid");
  2021. if (!utlf_isNull(pid))
  2022. {
  2023. ds_cond_smpis00600.setColumn(0, "patunitsrch" , ds_grid_grd_clbsmast.getColumn(irow, "pid"));
  2024. ds_cond_smpis00600.setColumn(0, "clamym" , "");
  2025. ds_cond_smpis00600.setColumn(0, "clamymfrom" , ds_grid_grd_clbsmast.getColumn(irow, "clamym"));
  2026. ds_cond_smpis00600.setColumn(0, "clamymto" , ds_grid_grd_clbsmast.getColumn(irow, "clamym"));
  2027. ds_cond_smpis00600.setColumn(0, "clamflag" , ds_grid_grd_clbsmast.getColumn(irow, "clamflagcd"));
  2028. ds_cond_smpis00600.setColumn(0, "ioflag" , ioflag);
  2029. ds_cond_smpis00600.setColumn(0, "insukind" , ds_grid_grd_clbsmast.getColumn(irow, "insukindcd"));
  2030. ds_cond_smpis00600.setColumn(0, "cutonly" , "false");
  2031. ds_cond_smpis00600.setColumn(0, "code" , "");
  2032. ds_cond_smpis00600.setColumn(0, "codecond" , "calc");
  2033. ds_cond_smpis00600.setColumn(0, "trustinstcd" , "N");
  2034. ds_cond_smpis00600.setColumn(0, "clamdgfrom" , "");
  2035. ds_cond_smpis00600.setColumn(0, "clamdgto" , "");
  2036. ds_cond_smpis00600.setColumn(0, "orddeptcd" , "-");
  2037. ds_cond_smpis00600.setColumn(0, "orddrid" , "-");
  2038. }
  2039. }
  2040. else
  2041. {
  2042. var irow = ds_list2_clod.rowposition;
  2043. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  2044. if (!utlf_isNull(pid))
  2045. {
  2046. ds_cond_smpis00600.setColumn(0, "openflag" , ioflag);
  2047. ds_cond_smpis00600.setColumn(0, "patunitsrch" , ds_main_item1_clbs.getColumn(0, "pid"));
  2048. ds_cond_smpis00600.setColumn(0, "clamym" , "");
  2049. ds_cond_smpis00600.setColumn(0, "clamymfrom" , ds_main_item1_clbs.getColumn(0, "clamym"));
  2050. ds_cond_smpis00600.setColumn(0, "clamymto" , ds_main_item1_clbs.getColumn(0, "clamym"));
  2051. ds_cond_smpis00600.setColumn(0, "clamflag" , ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  2052. ds_cond_smpis00600.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  2053. ds_cond_smpis00600.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  2054. ds_cond_smpis00600.setColumn(0, "cutonly" , "false"); // 삭감처방만조회:true, 청구처방조회:false
  2055. ds_cond_smpis00600.setColumn(0, "code" , ds_list2_clod.getColumn(irow, "snglcalcscorcd"));
  2056. ds_cond_smpis00600.setColumn(0, "codecond" , "N");
  2057. ds_cond_smpis00600.setColumn(0, "trustinstcd" , "");
  2058. ds_cond_smpis00600.setColumn(0, "clamdgfrom" , "");
  2059. ds_cond_smpis00600.setColumn(0, "clamdgto" , "");
  2060. ds_cond_smpis00600.setColumn(0, "orddeptcd" , "-");
  2061. ds_cond_smpis00600.setColumn(0, "orddrid" , "-");
  2062. }
  2063. }
  2064. if (opentype == "O"){
  2065. frmf_open("SMPIS00600", "SMPIS00600", {args_ds_send:ds_cond_smpis00600}, "", "", "", "", "", "", "", "", "", "M");
  2066. } else {
  2067. frmf_modal("SMPIS00600", "SMPIS00600", {args_ds_send:ds_cond_smpis00600}, "", "", "", "", "", "", "", "", "", "M");
  2068. }
  2069. }
  2070. /****************************************************************************************
  2071. * Argument : modal
  2072. * Description : 계산처방시행조회
  2073. ****************************************************************************************/
  2074. function lf_pidfOpenSMPIS00500(ioflag, calltype, codetype)
  2075. {
  2076. ds_cond_smpis00500.clearData();
  2077. ds_cond_smpis00500.addRow();
  2078. if (calltype == "M")
  2079. {
  2080. if (ioflag == "I")
  2081. {
  2082. var irow = ds_grid_grd_clbsmast.rowposition;
  2083. }
  2084. else
  2085. {
  2086. var srchmode = ds_hidden_clbs.getColumn(0, "srchmode");
  2087. if (srchmode == "specclbs")
  2088. {
  2089. var irow = ds_grid_grd_specclbs.rowposition;
  2090. }
  2091. else
  2092. {
  2093. var irow = ds_grid_grd_clbsmast.rowposition;
  2094. }
  2095. }
  2096. var pid = ds_grid_grd_clbsmast.getColumn(irow, "pid");
  2097. if (!utlf_isNull(pid))
  2098. {
  2099. ds_cond_smpis00500.setColumn(0, "patunitsrch" , ds_grid_grd_clbsmast.getColumn(irow, "pid"));
  2100. ds_cond_smpis00500.setColumn(0, "fromdd" , ds_grid_grd_clbsmast.getColumn(irow, "ordfromdd"));
  2101. ds_cond_smpis00500.setColumn(0, "todd" , ds_grid_grd_clbsmast.getColumn(irow, "ordtodd"));
  2102. if (ioflag == "O")
  2103. {
  2104. ds_cond_smpis00500.setColumn(0, "ioflag", "A");
  2105. ds_cond_smpis00500.setColumn(0, "orddrid", "");
  2106. }
  2107. else
  2108. {
  2109. ds_cond_smpis00500.setColumn(0, "ioflag", ds_send.getColumn(0, "ioflag"));
  2110. ds_cond_smpis00500.setColumn(0, "orddrid", ds_grid_grd_clbsmast.getColumn(irow, "orddrid"));
  2111. }
  2112. ds_cond_smpis00500.setColumn(0, "orddeptcd", ds_grid_grd_clbsmast.getColumn(irow, "orddeptcd"));
  2113. ds_cond_smpis00500.setColumn(0, "codecond", "calc"); // calc:코드별, cancer:항암제, kind:분류별
  2114. ds_cond_smpis00500.setColumn(0, "code", ""); // 검색할 수가코드
  2115. }
  2116. }
  2117. else
  2118. {
  2119. var irow = ds_list2_clod.rowposition;
  2120. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  2121. if (!utlf_isNull(pid))
  2122. {
  2123. ds_cond_smpis00500.setColumn(0, "patunitsrch", ds_main_item1_clbs.getColumn(0, "pid"));
  2124. if (ioflag == "O")
  2125. {
  2126. ds_cond_smpis00500.setColumn(0, "fromdd" , ds_main_item1_clbs.getColumn(0, "indd"));
  2127. ds_cond_smpis00500.setColumn(0, "todd" , ds_main_item1_clbs.getColumn(0, "dschdd"));
  2128. ds_cond_smpis00500.setColumn(0, "orddrid" , "");
  2129. if (ds_main_item1_clbs.getColumn(0, "stsioflag") == "-")
  2130. {
  2131. ds_cond_smpis00500.setColumn(0, "ioflag", "O");
  2132. }
  2133. else
  2134. {
  2135. ds_cond_smpis00500.setColumn(0, "ioflag", "I");
  2136. }
  2137. }
  2138. else
  2139. {
  2140. ds_cond_smpis00500.setColumn(0, "fromdd" , ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  2141. ds_cond_smpis00500.setColumn(0, "todd" , ds_main_item1_clbs.getColumn(0, "ordtodd"));
  2142. ds_cond_smpis00500.setColumn(0, "orddrid" , ds_main_item1_clbs.getColumn(0, "orddrid"));
  2143. ds_cond_smpis00500.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  2144. }
  2145. ds_cond_smpis00500.setColumn(0, "orddeptcd" , "-");
  2146. ds_cond_smpis00500.setColumn(0, "orddrid" , "-");
  2147. ds_cond_smpis00500.setColumn(0, "codecond" , "calc"); // calc:코드별, cancer:항암제, kind:분류별
  2148. if (codetype == "SnglCD")
  2149. {
  2150. ds_cond_smpis00500.setColumn(0, "code" , ds_list2_clod.getColumn(irow, "snglcalcscorcd"));
  2151. }
  2152. else
  2153. {
  2154. ds_cond_smpis00500.setColumn(0, "edicd" , ds_list2_clod.getColumn(irow, "edicd")); // 검색할 EDI코드
  2155. }
  2156. }
  2157. }
  2158. var objArg = new Object();
  2159. objArg.arg_ds_send = ds_cond_smpis00500;
  2160. frmf_modal("SMPIS00500", "SMPIS00500", objArg, "", "", "", "", "", "", "", "", "", "M");
  2161. }
  2162. /****************************************************************************************
  2163. * Argument :
  2164. * Description : 처방 항목 구분 및 선별심사 처방 색깔 구분
  2165. ****************************************************************************************/
  2166. function lf_fSetOrderData()
  2167. {
  2168. var colorExpr = "";
  2169. var bgExpr1 = "";
  2170. var bgExpr2 = "";
  2171. for ( var i = 1 ; i < grp_biz.grd_clodhist.getCellCount('Body'); i++ )
  2172. {
  2173. // 3-1. 필수심사
  2174. colorExpr = "EXPR( surecdyn == 'Y' ? '#0000ff' : (spcljudgyn == 'Y' ? '#ff3333' : 'default'))";
  2175. grp_biz.grd_clodhist.setCellProperty('Body', i, "color", colorExpr);
  2176. var backExpr = "EXPR( erroramtyn == 'Y' ? '#ffff9c' : 'default')";
  2177. grp_biz.grd_clodhist.setCellProperty('Body', i, "background" , "");
  2178. grp_biz.grd_clodhist.setCellProperty('Body', i, "background2" , "");
  2179. grp_biz.grd_clodhist.setCellProperty('Body', i, "background" , backExpr);
  2180. grp_biz.grd_clodhist.setCellProperty('Body', i, "background2", backExpr);
  2181. }
  2182. var backExpr3 = "EXPR( !utlf_isNull(adjtresncd) && adjtresncd != '-' ? '#cece9c' : (erroramtyn == 'Y' ? '#ffff9c' : 'default'))"
  2183. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"adjtresncd"), "background" , "");
  2184. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"adjtresncd"), "background2" , "");
  2185. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"adjtresncd"), "background" , backExpr3); // 사유
  2186. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"adjtresncd"), "background2", backExpr3); // 사유
  2187. var backExpr4 = "EXPR( payflag == '1' ? '#00FF00' : payflag == '2' ? '#ff00ff' : 'default')"
  2188. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"payflag"), "background" , "");
  2189. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"payflag"), "background2" , "");
  2190. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"payflag"), "background" , backExpr4); // 급비
  2191. grp_biz.grd_clodhist.setCellProperty('Body', grp_biz.grd_clodhist.getBindCellIndex('body',"payflag"), "background2", backExpr4); // 급비
  2192. lf_fSetItemBold();
  2193. }
  2194. /****************************************************************************************
  2195. * Argument :
  2196. * Description : 항목구분 색표시
  2197. ****************************************************************************************/
  2198. function lf_fSetItemBold()
  2199. {
  2200. // 초기화
  2201. for (var i = 0; i < ds_init_ordfilflag.rowcount; i++)
  2202. {
  2203. ds_init_ordfilflag.setColumn(i, "color", "");
  2204. ds_init_ordfilflag.setColumn(i, "font", "");
  2205. }
  2206. // 전체 굵게
  2207. ds_init_ordfilflag.setColumn(0, "color", "red");
  2208. ds_init_ordfilflag.setColumn(0, "font", "Dotum,9,bold");
  2209. ds_list2_clod.filter("");
  2210. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  2211. {
  2212. var curitem1 = ds_list2_clod.getColumn(i, "ediitem1");
  2213. var fItem = "-";
  2214. switch (curitem1)
  2215. {
  2216. // 진찰료
  2217. case "01":
  2218. fItem = "01";
  2219. break;
  2220. // 입원
  2221. case "02":
  2222. fItem = "02";
  2223. break;
  2224. // 투약
  2225. case "03":
  2226. fItem = "03";
  2227. break;
  2228. // 주사
  2229. case "04":
  2230. fItem = "04";
  2231. break;
  2232. // 마취
  2233. case "05":
  2234. fItem = "05";
  2235. break;
  2236. // 이학
  2237. case "06":
  2238. fItem = "06";
  2239. break;
  2240. // 정신
  2241. case "07":
  2242. fItem = "07";
  2243. break;
  2244. // 수술
  2245. case "08":
  2246. fItem = "08";
  2247. break;
  2248. // 검사
  2249. case "09":
  2250. fItem = "09";
  2251. break;
  2252. // 방사
  2253. case "10":
  2254. fItem = "10";
  2255. break;
  2256. // 특수 장비
  2257. case "SS":
  2258. fItem = "SS";
  2259. break;
  2260. // A항
  2261. case "AA":
  2262. fItem = "AA";
  2263. break;
  2264. // B항
  2265. case "BB":
  2266. fItem = "BB";
  2267. break;
  2268. // D항
  2269. case "DD":
  2270. fItem = "DD";
  2271. break;
  2272. // E항
  2273. case "EE":
  2274. fItem = "EE";
  2275. break;
  2276. // 혈액투석정액
  2277. case "ZZ":
  2278. fItem = "ZZ";
  2279. break;
  2280. }
  2281. var fRow = ds_init_ordfilflag.findRow("codecolumn", fItem);
  2282. if ( fRow > -1 )
  2283. {
  2284. ds_init_ordfilflag.setColumn(fRow, "color", "red");
  2285. ds_init_ordfilflag.setColumn(fRow, "font", "Dotum,9,bold");
  2286. }
  2287. else
  2288. {
  2289. ds_init_ordfilflag.setColumn(fRow, "color", "");
  2290. ds_init_ordfilflag.setColumn(fRow, "font", "");
  2291. }
  2292. }
  2293. // ds_hidden_list2_clodsrch.setColumn(0, "selectedRdoPay" , "0");
  2294. // ds_hidden_list2_clodsrch.setColumn(0, "selectedRdoItem", "-");
  2295. }
  2296. /****************************************************************************************
  2297. * Argument :
  2298. * Description : TRPID20325 submit callback
  2299. ****************************************************************************************/
  2300. function cf_TRPID20325(sSvcId, nErrorCode, sErrorMsg)
  2301. {
  2302. if(nErrorCode < 0)
  2303. {
  2304. alert("["+sSvcId+"]"+sErrorMsg);
  2305. return;
  2306. }
  2307. ds_hidden_initclodlist_list2.copyData(ds_list2_clod);
  2308. var chk_R = ds_list2_clod.lookupExpr("snglcalcscorcd=='R4351' || snglcalcscorcd=='R3131' || snglcalcscorcd=='R3141' || snglcalcscorcd=='R4361' || snglcalcscorcd=='R4519' " , "snglcalcscorcd"); // 초산 상병체크
  2309. var patage = parseInt(ds_main_item1_clbs.getColumn(0,"patage"));
  2310. var licnscnt = ds_list2_clod.lookupExpr("(item=='0101' && tims>=2) || (item=='0102' && tims>=2)","licnsno");
  2311. var stsioflag = ds_main_item1_clbs.getColumn(0,"stsioflag");
  2312. licnscnt = utlf_transNullToEmpty(licnscnt).split('/');
  2313. if (utlf_transNullToEmpty(chk_R).length > 0 && (patage >= 35 || patage < 16))
  2314. {
  2315. lf_setAlramMessage("어린 초임부 또는 고령초임부 입니다.");
  2316. }
  2317. var holigbn = ds_rslt_aftjudgbtn.getColumn(0,"holigbn");
  2318. var holifromdd = ds_rslt_aftjudgbtn.getColumn(0,"holifromdd");
  2319. var holitodd = ds_rslt_aftjudgbtn.getColumn(0,"holitodd");
  2320. var clod_snglcalcscorcd = ds_list2_clod.lookupExpr("item=='0101' || item=='0102'","snglcalcscorcd");
  2321. if(holigbn == "Y" && utlf_transNullToEmpty(clod_snglcalcscorcd).length > 0)
  2322. {
  2323. lf_setAlramMessage("진료의가 "+holifromdd+" ~ "+holitodd+" 기간동안 해외 출장입니다. 진료의사를 변경하세요.");
  2324. }
  2325. if (lgv_ioflag == "O" ) {
  2326. var chk_tims = ds_list2_clod.lookupExpr("(item=='0101' && tims>=2) || (item=='0102' && tims>=2)","tims");
  2327. if(chk_tims>=2)
  2328. {
  2329. if (stsioflag != "E")
  2330. {
  2331. // 응급실 외퇴 환자가 아닌 경우에만 진찰료 횟수 체크한다. (20160828 LEJ)
  2332. lf_setAlramMessage("진찰료 횟수가 1회 이상 입니다.");
  2333. }
  2334. if (chk_tims != licnscnt.length)
  2335. {
  2336. lf_setAlramMessage("진찰료 횟수와 면허번호 갯수가 일치하지 않습니다.");
  2337. }
  2338. }
  2339. lf_fSetOrderData();
  2340. }
  2341. //20191021 산재 기간 타보험유형 있는지 체크
  2342. if ( ds_main_item1_clbs.getColumn(0, "insukind") == "41" && lgv_ioflag == "O") {
  2343. dsf_createDs("ds_send_item1_clbs_tmp");
  2344. dsf_createDs("ds_inacdayinsukindchk");
  2345. ds_send_item1_clbs_tmp.copyData(ds_send_item1_clbs);
  2346. var ordfromddtmp = "";
  2347. var value = "";
  2348. for(var i = 0 ; i < ds_list2_clod.rowcount ; i++) {
  2349. if(value == ds_list2_clod.getColumn(i, "ordfromdd")) continue;
  2350. value = ds_list2_clod.getColumn(i, "ordfromdd");
  2351. if(utlf_isNull(ordfromddtmp)) ordfromddtmp = value;
  2352. else ordfromddtmp = ordfromddtmp + "','" + value;
  2353. }
  2354. ds_send_item1_clbs_tmp.setColumn(0, "ordfromdd", ordfromddtmp);
  2355. oParam = {};
  2356. oParam.id = "TRPID20325_1";
  2357. oParam.service = "aftjudgapp.InAftJudg";
  2358. // oParam.method = "reqGetPamDiffInsukindList";
  2359. oParam.method = "reqGetInacDayInsukindChk";
  2360. oParam.inds = "req=ds_send_item1_clbs_tmp";
  2361. oParam.outds = "ds_inacdayinsukindchk=rslt";
  2362. oParam.async = true;
  2363. oParam.progress = false;
  2364. oParam.callback = "cf_TRPID20325_1";
  2365. tranf_submit(oParam);
  2366. }
  2367. if (lgv_ioflag == "I" ) {
  2368. lf_fSetItemBold();
  2369. }
  2370. }
  2371. function cf_TRPID20325_1(sSvcId, nErrorCode, sErrorMsg)
  2372. {
  2373. if(nErrorCode < 0) return;
  2374. if(ds_inacdayinsukindchk.getColumn(0, "chkyn") == "Y") lf_setAlramMessage("동일진료일자에 다른 보험유형이 있습니다.확인하세요.");
  2375. }
  2376. /****************************************************************************************
  2377. * Argument :
  2378. * Description : 이력조회 버튼 이벤트
  2379. ****************************************************************************************/
  2380. function btn_histref_onlbuttondown(obj:Button, e:MouseEventInfo)
  2381. {
  2382. ds_popup.filterstr = "case1=='0'";
  2383. ds_popup.rowposition = -1;
  2384. grp_dropdownmenu.caption00.text = obj.text;
  2385. // grp_dropdownmenu.position = "absolute 455 47 711 460";
  2386. grp_dropdownmenu.position.left = obj.position.left;
  2387. grp_dropdownmenu.position.top = 47;
  2388. grp_dropdownmenu.position.bottom = 460;
  2389. grp_dropdownmenu.position.right = obj.position.left+256;
  2390. grp_dropdownmenu.visible = true;
  2391. }
  2392. /****************************************************************************************
  2393. * Argument :
  2394. * Description : 환자정보 버튼 이벤트
  2395. ****************************************************************************************/
  2396. function btn_patinfo_onlbuttondown(obj:Button, e:MouseEventInfo)
  2397. {
  2398. ds_popup.filterstr = "case1=='1'";
  2399. ds_popup.rowposition = -1;
  2400. grp_dropdownmenu.caption00.text = obj.text;
  2401. grp_dropdownmenu.position.left = obj.position.left;
  2402. grp_dropdownmenu.position.top = 47;
  2403. grp_dropdownmenu.position.bottom = 460;
  2404. grp_dropdownmenu.position.right = obj.position.left+256;
  2405. grp_dropdownmenu.visible = true;
  2406. }
  2407. /****************************************************************************************
  2408. * Argument :
  2409. * Description : 자격정보 버튼 이벤트
  2410. ****************************************************************************************/
  2411. function btn_qualinfo_onlbuttondown(obj:Button, e:MouseEventInfo)
  2412. {
  2413. if(sysf_getUserInfo("dutplceinstcd") == "055")
  2414. {
  2415. ds_popup.filterstr = "case1=='2'" + '||' + "popupid == 'SMPMC08000'" ;
  2416. }
  2417. else
  2418. {
  2419. ds_popup.filterstr = "case1=='2'" + '&&' + "popupid != 'SMPMC08000'";
  2420. }
  2421. ds_popup.rowposition = -1;
  2422. grp_dropdownmenu.caption00.text = obj.text;
  2423. grp_dropdownmenu.position.left = obj.position.left;
  2424. grp_dropdownmenu.position.top = 47;
  2425. grp_dropdownmenu.position.bottom = 460;
  2426. grp_dropdownmenu.position.right = obj.position.left+256;
  2427. grp_dropdownmenu.visible = true;
  2428. }
  2429. /****************************************************************************************
  2430. * Argument :
  2431. * Description : 처방조회 버튼 이벤트
  2432. ****************************************************************************************/
  2433. function btn_prcpref_onlbuttondown(obj:Button, e:MouseEventInfo)
  2434. {
  2435. ds_popup.filterstr = "case1=='3'";
  2436. ds_popup.rowposition = -1;
  2437. grp_dropdownmenu.caption00.text = obj.text;
  2438. grp_dropdownmenu.position.left = obj.position.left;
  2439. grp_dropdownmenu.position.top = 47;
  2440. grp_dropdownmenu.position.bottom = 460;
  2441. grp_dropdownmenu.position.right = obj.position.left+256;
  2442. grp_dropdownmenu.visible = true;
  2443. }
  2444. /****************************************************************************************
  2445. * Argument :
  2446. * Description : 투약정보 버튼 이벤트
  2447. ****************************************************************************************/
  2448. function btn_mediinfo_onlbuttondown(obj:Button, e:MouseEventInfo)
  2449. {
  2450. ds_popup.filterstr = "case1=='4'";
  2451. ds_popup.rowposition = -1;
  2452. grp_dropdownmenu.caption00.text = obj.text;
  2453. grp_dropdownmenu.position.left = obj.position.left;
  2454. grp_dropdownmenu.position.top = 47;
  2455. grp_dropdownmenu.position.bottom = 460;
  2456. grp_dropdownmenu.position.right = obj.position.left+256;
  2457. grp_dropdownmenu.visible = true;
  2458. }
  2459. /****************************************************************************************
  2460. * Argument :
  2461. * Description : 결과조회 버튼 이벤트
  2462. ****************************************************************************************/
  2463. function btn_rsltsrch_onclick(obj:Button, e:ClickEventInfo)
  2464. {
  2465. var cretno = ds_main_item1_clbs.getColumn(0, "cretno");
  2466. if (!utlf_isNull(cretno))
  2467. {
  2468. var strPid = ds_main_item1_clbs.getColumn(0, "pid");
  2469. var wndobj = frmf_findPopup("SMMMI00100");
  2470. if(utlf_isNull(wndobj) == false)
  2471. {
  2472. wndobj.ds_reopenpop.setColumn(0, "reopenpop", "Y");
  2473. wndobj.ds_singdata.setColumn(0, "srchpid", pid);
  2474. wndobj.fInitialize_SMMMI00100(); // 초기화함수 호출
  2475. frmf_setFocusPop("SMMMI00100");
  2476. }
  2477. else
  2478. {
  2479. ds_cond_smaer00800.setColumn(0, "srchpid", ds_main_item1_clbs.getColumn(0, "pid"));
  2480. var objArg = new Object();
  2481. objArg.arg_ds_send_singdata = ds_cond_smaer00800;
  2482. frmf_open("SMMMI00100", "SMMMI00100", objArg, null, null, null, null, null, null, null, null, null, "M");
  2483. }
  2484. }
  2485. }
  2486. /****************************************************************************************
  2487. * Argument : onmouseenter
  2488. * Description : 결과조회 버튼 이벤트
  2489. ****************************************************************************************/
  2490. function btn_rsltsrch_onmouseenter(obj:Button, e:MouseEventInfo)
  2491. {
  2492. if (grp_dropdownmenu.visible == true)
  2493. {
  2494. grp_dropdownmenu.visible = false;
  2495. }
  2496. }
  2497. /****************************************************************************************
  2498. * Argument : onmouseenter
  2499. * Description : 삭감처방 버튼 마우스 over
  2500. ****************************************************************************************/
  2501. function grp_biz_btn_redu_onmouseenter(obj:Button, e:MouseEventInfo)
  2502. {
  2503. if (grp_dropdownmenu.visible == true)
  2504. {
  2505. grp_dropdownmenu.visible = false;
  2506. }
  2507. }
  2508. /****************************************************************************************
  2509. * Argument :
  2510. * Description : 진료비 버튼 이벤트
  2511. ****************************************************************************************/
  2512. function btn_ordamt_onlbuttondown(obj:Button, e:MouseEventInfo)
  2513. {
  2514. ds_popup.filterstr = "case1=='5'";
  2515. ds_popup.rowposition = -1;
  2516. grp_dropdownmenu.caption00.text = obj.text;
  2517. grp_dropdownmenu.position.left = obj.position.left;
  2518. grp_dropdownmenu.position.top = 47;
  2519. grp_dropdownmenu.position.bottom = 460;
  2520. grp_dropdownmenu.position.right = obj.position.left+256;
  2521. grp_dropdownmenu.visible = true;
  2522. }
  2523. /****************************************************************************************
  2524. * Argument :
  2525. * Description : 각종조회 버튼 이벤트
  2526. ****************************************************************************************/
  2527. function btn_etcref_onlbuttondown(obj:Button, e:MouseEventInfo)
  2528. {
  2529. ds_popup.filterstr = "case1=='6'";
  2530. ds_popup.rowposition = -1;
  2531. grp_dropdownmenu.caption00.text = obj.text;
  2532. grp_dropdownmenu.position.left = obj.position.left;
  2533. grp_dropdownmenu.position.top = 47;
  2534. grp_dropdownmenu.position.bottom = 460;
  2535. grp_dropdownmenu.position.right = obj.position.left+256;
  2536. grp_dropdownmenu.visible = true;
  2537. }
  2538. /****************************************************************************************
  2539. * Argument :
  2540. * Description : emr 버튼 이벤트
  2541. ****************************************************************************************/
  2542. function btn_emr_onlbuttondown(obj:Button, e:MouseEventInfo)
  2543. {
  2544. ds_popup.filterstr = "case1=='7'";
  2545. ds_popup.rowposition = -1;
  2546. grp_dropdownmenu.caption00.text = obj.text;
  2547. grp_dropdownmenu.position.left = obj.position.left;
  2548. grp_dropdownmenu.position.top = 47;
  2549. grp_dropdownmenu.position.bottom = 460;
  2550. grp_dropdownmenu.position.right = obj.position.left+256;
  2551. grp_dropdownmenu.visible = true;
  2552. }
  2553. /****************************************************************************************
  2554. * Argument :
  2555. * Description : 응급실정보 버튼 이벤트
  2556. ****************************************************************************************/
  2557. function btn_erroomref_onlbuttondown(obj:Button, e:MouseEventInfo)
  2558. {
  2559. ds_popup.filterstr = "case1=='8'";
  2560. ds_popup.rowposition = -1;
  2561. grp_dropdownmenu.caption00.text = obj.text;
  2562. grp_dropdownmenu.position.left = obj.position.left;
  2563. grp_dropdownmenu.position.top = 47;
  2564. grp_dropdownmenu.position.bottom = 460;
  2565. grp_dropdownmenu.position.right = obj.position.left+256;
  2566. grp_dropdownmenu.visible = true;
  2567. }
  2568. /****************************************************************************************
  2569. * Argument :
  2570. * Description : 이식정보 버튼 이벤트
  2571. ****************************************************************************************/
  2572. function btn_trnptinforef_onlbuttondown(obj:Button, e:MouseEventInfo)
  2573. {
  2574. ds_popup.filterstr = "case1=='9'";
  2575. ds_popup.rowposition = -1;
  2576. grp_dropdownmenu.caption00.text = obj.text;
  2577. grp_dropdownmenu.position.left = obj.position.left;
  2578. grp_dropdownmenu.position.top = 47;
  2579. grp_dropdownmenu.position.bottom = 460;
  2580. grp_dropdownmenu.position.right = obj.position.left+256;
  2581. grp_dropdownmenu.visible = true;
  2582. }
  2583. /****************************************************************************************
  2584. * Argument :
  2585. * Description : 버튼 이벤트
  2586. ****************************************************************************************/
  2587. function grp_biz_img_msg_onclick(obj:Button, e:ClickEventInfo)
  2588. {
  2589. if (ds_main_item1_clbs.getColumn(0, "pid") != " " && ds_main_item1_clbs.getColumn(0, "pid") != "-" &&!utlf_isNull(ds_main_item1_clbs.getColumn(0, "pid")))
  2590. {
  2591. lf_fJudgPatMsgTrsmRef();
  2592. }
  2593. }
  2594. /****************************************************************************************
  2595. * Argument :
  2596. * Description : 메세지 현황 modal 호출
  2597. ****************************************************************************************/
  2598. function lf_fJudgPatMsgTrsmRef()
  2599. {
  2600. var pid = ds_main_item1_clbs.getColumn(0, "pid"); // 메세지 현황에 등록번호반환
  2601. var objArg = new Object();
  2602. objArg.sPid = pid;
  2603. frmf_open("SMPIJ02600","SMPIJ02600",objArg,"","","","","","","","","","M");
  2604. }
  2605. /****************************************************************************************
  2606. * Argument :
  2607. * Description : 등록번호 조회 editbox keydown 이벤트
  2608. ****************************************************************************************/
  2609. function grp_biz_grp_sea00_ipt_pid_onkeydown(obj:Edit, e:KeyEventInfo)
  2610. {
  2611. if (e.keycode == 13)
  2612. {
  2613. var clamym = ds_main_item1_clbs.getColumn(0, "clamym"); // 청구일자
  2614. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg"); // 청구일자
  2615. var oldpid = ds_main_item1_clbs.getColumn(0, "pid");
  2616. var ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  2617. if(!utlf_isNull(obj.value) && !utlf_isNull(obj.text))
  2618. {
  2619. obj.updateToDataset();
  2620. }
  2621. var newpid = obj.value;
  2622. if ( newpid == oldpid)
  2623. {
  2624. return;
  2625. }
  2626. else
  2627. {
  2628. if(ioflag == "I")
  2629. {
  2630. fGetInAftJudgTrgtManPidSrch();
  2631. }
  2632. else
  2633. {
  2634. lf_fGetOutAftJudgTrgtManPidSrch();
  2635. }
  2636. }
  2637. }
  2638. }
  2639. /****************************************************************************************
  2640. * Argument : button
  2641. * Description : 상병이력 버튼 이벤트
  2642. ****************************************************************************************/
  2643. function grp_biz_btn_diagHist_onclick(obj:Button, e:ClickEventInfo)
  2644. {
  2645. lf_fGetDiagHistList();
  2646. }
  2647. /****************************************************************************************
  2648. * Argument :
  2649. * Description : 특정 환자에 대한 상병이력을 조회한다.
  2650. ****************************************************************************************/
  2651. function lf_fGetDiagHistList()
  2652. {
  2653. ds_hidden_smpiz00100_rslt.clearData();
  2654. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  2655. if (!utlf_isNull(clamym))
  2656. {
  2657. // 조회된 심사대상자가 있으면
  2658. // 심사대상자의 등록번호를 조건으로 하여 전체 청구 상병이력을 조회한다.
  2659. var smpiz00100 = new Object();
  2660. smpiz00100.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  2661. smpiz00100.sIoflag = "-";
  2662. var rtnDs = frmf_modal("SMPIZ00100", "SMPIZ00100", smpiz00100, "", "", "", "", "", "", "", "", "", "M");
  2663. for ( var i = 0; i < ds_hidden_smpiz00100_rslt.rowcount; i++)
  2664. {
  2665. var diagcd = ds_hidden_smpiz00100_rslt.getColumn(i, "diagcd");
  2666. var isSame = false;
  2667. for (var j = 0; j < ds_list1_cldi.rowcount; j++)
  2668. {
  2669. if(diagcd == ds_list1_cldi.getColumn(j, "diagcd"))
  2670. {
  2671. // 동일한 상병이 존재하는 경우
  2672. isSame = true;
  2673. j = ds_list1_cldi.rowcount;
  2674. }
  2675. }
  2676. if (isSame == false)
  2677. {
  2678. // 상병 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
  2679. var rRow = lf_fDiagGridAddRow();
  2680. ds_list1_cldi.setColumn(rRow, "diagkindcd", ds_hidden_smpiz00100_rslt.getColumn(i, "diagkindcd"));
  2681. ds_list1_cldi.setColumn(rRow, "diagseq" , rRow + 1);
  2682. ds_list1_cldi.setColumn(rRow, "diagcd" , diagcd);
  2683. ds_list1_cldi.setColumn(rRow, "diagnm" , ds_hidden_smpiz00100_rslt.getColumn(i, "diaghngnm"));
  2684. ds_list1_cldi.setColumn(rRow, "diagengnm" , ds_hidden_smpiz00100_rslt.getColumn(i, "diagengnm"));
  2685. // 20100308 특정내역 조회 추가
  2686. ds_list1_cldi.setColumn(ds_list1_cldi.rowposition, "vcode", lf_fGetDiagVcode(diagcd));
  2687. // 20100329 MT002 입력체크
  2688. if (ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "diagseq") == "1" && !utlf_isNull(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "vcode")))
  2689. {
  2690. lf_fSetDiagMT002(ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "vcode"));
  2691. }
  2692. var frow = ds_lglydisinfo.findRowExpr("fromdiag<='" + diagcd + "' && todiag>='" + diagcd + "'");
  2693. if (frow > -1){
  2694. lf_setAlramMessage("상병코드: " + diagcd + " 법정전염병 상병입니다. 확인하십시오.");
  2695. }
  2696. }
  2697. }
  2698. lf_fSortDiagNo(true);
  2699. lf_fDiagGridAddRow();
  2700. }
  2701. }
  2702. /****************************************************************************************
  2703. * Argument :
  2704. * Description : 상병row MT002 입력
  2705. ****************************************************************************************/
  2706. function lf_fSetDiagMT002(incode)
  2707. {
  2708. var gridrowstatus = "";
  2709. var existsyn = "N";
  2710. var vcode = "";
  2711. if (utlf_isNull(incode))
  2712. {
  2713. vcode = ds_list1_cldi.lookupExpr("diagseq=='1' && !utlf_isNull(vcode) && diagkindcd != 'R'", "vcode");
  2714. }
  2715. else
  2716. {
  2717. vcode = incode;
  2718. }
  2719. if (!utlf_isNull(vcode))
  2720. {
  2721. var spclcdMT002 = ds_list3_clsp.lookupExpr("spclcd=='MT002' && spclspec=='"+vcode+"' && ds_list1_cldi.getRowType(currow) != 8", "spclcd");
  2722. var spclcdCT002 = ds_list3_clsp.lookupExpr("spclcd=='CT002' && spclspec=='"+vcode+"' && ds_list1_cldi.getRowType(currow) != 8", "spclcd");
  2723. if (utlf_transNullToEmpty(spclcdMT002).length > 0 || utlf_transNullToEmpty(spclcdCT002).length > 0)
  2724. {
  2725. existsyn = "Y";
  2726. }
  2727. if ( existsyn != "Y" )
  2728. {
  2729. var ans;
  2730. var tmpspclcd;
  2731. var snglcalcscorcdcnt = ds_list7_clop.rowcount; //원외청방수
  2732. if (vcode == "V252"||vcode == "V352")
  2733. {
  2734. tmpspclcd = "CT002";
  2735. if (snglcalcscorcdcnt > 0)
  2736. {
  2737. ans = sysf_messageBox( vcode + " 상병입니다.\n\n"+ tmpspclcd + "특정내역을 \n\n"+ "입력", "S001");
  2738. }
  2739. }
  2740. else
  2741. {
  2742. tmpspclcd = "MT002";
  2743. ans = sysf_messageBox( vcode + " 상병입니다.\n\n"+ tmpspclcd + "특정내역을 \n\n"+ "입력", "S001");
  2744. }
  2745. if ( ans == 6 )
  2746. {
  2747. var clsprow = lf_fSpclGridInsertRow();
  2748. if (vcode == "V252"||vcode == "V352")
  2749. {
  2750. var clopdd = ds_list7_clop.getColumn(0, "clopdd");
  2751. var clopno = ds_list7_clop.getColumn(0, "clopno");
  2752. if (snglcalcscorcdcnt > 0)
  2753. {
  2754. ds_list3_clsp.setColumn(clsprow, "mpsno", clopdd + "" + clopno);
  2755. }
  2756. ds_list3_clsp.setColumn(clsprow, "unitflag", "C");
  2757. }
  2758. else
  2759. {
  2760. ds_list3_clsp.setColumn(clsprow, "unitflag", "M");
  2761. }
  2762. ds_list3_clsp.setColumn(clsprow, "spclcd", tmpspclcd);
  2763. ds_list3_clsp.setColumn(clsprow, "edilnno", 0);
  2764. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", "-");
  2765. ds_list3_clsp.setColumn(clsprow, "cdnm" , "특정기호");
  2766. ds_list3_clsp.setColumn(clsprow, "spclspec" , vcode);
  2767. ds_list3_clsp.setColumn(clsprow, "spclformat" , "X(4)");
  2768. ds_list3_clsp.setColumn(clsprow, "detldesc" , "");
  2769. ds_list3_clsp.setColumn(clsprow, "oldedilnno" , "");
  2770. ds_list3_clsp.setColumn(clsprow, "clodseqno" , "");
  2771. lf_fSortSpclNo();
  2772. }
  2773. }
  2774. }
  2775. }
  2776. /****************************************************************************************
  2777. * Argument :
  2778. * Description : 특정그리드 sort
  2779. ****************************************************************************************/
  2780. function lf_fSortSpclNo()
  2781. {
  2782. if ( ds_list3_clsp.rowcount > 0)
  2783. {
  2784. for(var j = 0; j < ds_list3_clsp.rowcount; j++)
  2785. {
  2786. var rowstatus = ds_list3_clsp.getRowType(j);
  2787. var spclcd = ds_list3_clsp.getColumn(j, "spclcd");
  2788. var spclspec = ds_list3_clsp.getColumn(j, "spclspec");
  2789. if ( rowstatus != 8 && utlf_isNull(spclcd) && utlf_isNull(spclspec))
  2790. {
  2791. ds_list3_clsp.deleteRow(j);
  2792. }
  2793. else
  2794. {
  2795. for ( var i = 0 ; i < grp_biz.swt_spclmemo.case_spclspec.grd_clsphist.getCellCount("Body"); i++ )
  2796. {
  2797. colorExpr = "EXPR( spclcd == 'JS010' && lf_js010chk(spclspec) ? '#ff3333' : '#ff3333'";
  2798. grp_biz.swt_spclmemo.case_spclspec.grd_clsphist.setCellProperty('Body', i, "color", colorExpr);
  2799. }
  2800. }
  2801. }
  2802. ds_list3_clsp.keystring = "S:+clsoyn-unitflag+spclcd+edilnno";
  2803. grp_biz.swt_spclmemo.case_spclspec.grd_clsphist.updateToDataset();
  2804. }
  2805. else
  2806. {
  2807. }
  2808. }
  2809. /****************************************************************************************
  2810. * Argument : button
  2811. * Description : 상병조회 버튼 이벤트
  2812. ****************************************************************************************/
  2813. function grp_biz_btn_diagSrch_onclick(obj:Button, e:ClickEventInfo)
  2814. {
  2815. // 상병코드 조회를 위해 SPPIZ00400_상병코드조회.xrw 를 호출
  2816. lf_fSearchSPPIZ00400();
  2817. // [SPPIZ00400_상병코드조회.xrw 에서 호출] 상병코드조회 팝업에서 선택한 상병을 상병 그리드에 반영
  2818. lf_fSortDiagNo(true);
  2819. }
  2820. /****************************************************************************************
  2821. * Argument : function
  2822. * Description : 상병조회 버튼 실행 함수
  2823. ****************************************************************************************/
  2824. function lf_fSearchSPPIZ00400()
  2825. {
  2826. var sppiz00400 = new Object();
  2827. sppiz00400.sSelectedrdodiagkind = "1";
  2828. sppiz00400.sSingleFlag = "";
  2829. sppiz00400.sDiagcd = ds_list1_cldi.getColumn(ds_list1_cldi.rowposition, "diagcd");
  2830. sppiz00400.sDiagnm = "";
  2831. var objArg = frmf_modal("SPPIZ00400", "SPPIZ00400", sppiz00400, "", "", "", "", "", "", "", "", "", "M");
  2832. if (!utlf_isNull(objArg))
  2833. {
  2834. ds_rslt_sppiz00400.clearData();
  2835. ds_rslt_sppiz00400.addRow();
  2836. ds_rslt_sppiz00400.setColumn(0, "diagcd" , objArg.sDiagcd);
  2837. ds_rslt_sppiz00400.setColumn(0, "diaghngnm" , objArg.sDiagnm);
  2838. ds_rslt_sppiz00400.setColumn(0, "diagengnm" , objArg.sDiagengnm);
  2839. lf_fSetDiagCdNm();
  2840. }
  2841. }
  2842. /****************************************************************************************
  2843. * Argument : function
  2844. * Description : 상병코드 PopUp 반영
  2845. ****************************************************************************************/
  2846. function lf_fSetDiagCdNm()
  2847. {
  2848. var row = ds_list1_cldi.rowposition;
  2849. var diagcd = ds_rslt_sppiz00400.getColumn(0, "diagcd");
  2850. var diaghngnm = ds_rslt_sppiz00400.getColumn(0, "diaghngnm");
  2851. var diagengnm = ds_rslt_sppiz00400.getColumn(0, "diagengnm");
  2852. if (row > -1)
  2853. {
  2854. ds_list1_cldi.setColumn(row, "diagcd" , diagcd);
  2855. ds_list1_cldi.setColumn(row, "diagnm" , diaghngnm);
  2856. ds_list1_cldi.setColumn(row, "diagengnm" , diagengnm);
  2857. }
  2858. else
  2859. {
  2860. var iRow = ds_list1_cldi.insertRow(0);
  2861. ds_list1_cldi.setColumn(iRow, "diagcd" , diagcd);
  2862. ds_list1_cldi.setColumn(iRow, "diagnm" , diaghngnm);
  2863. ds_list1_cldi.setColumn(iRow, "diagengnm" , diagengnm);
  2864. row = iRow;
  2865. }
  2866. ds_hidden_list3.setColumn(0, "msgspclformat", "상병코드 - " + diagcd + " / " + diaghngnm + " / " + diagengnm);
  2867. ds_list1_cldi.setColumn(row, "vcode", lf_fGetDiagVcode(diagcd));
  2868. if ( ds_list1_cldi.getColumn(row, "diagseq") == "1" && !utlf_isNull(ds_list1_cldi.getColumn(row, "vcode")))
  2869. {
  2870. lf_fSetDiagMT002(ds_list1_cldi.getColumn(row, "vcode"));
  2871. }
  2872. var addval1 = ds_list1_cldi.getColumn(row, "rowstat");
  2873. var addval2 = ds_list1_cldi.getRowType(row);
  2874. var rowstatus = ds_list1_cldi.getRowType(row);
  2875. if (rowstatus != 2 )
  2876. {
  2877. ds_list1_cldi.updatecontrol = false;
  2878. ds_list1_cldi.setRowType(row, 'u');
  2879. ds_list1_cldi.updatecontrol = true;
  2880. }
  2881. var frow = ds_lglydisinfo.findRowExpr("fromdiag<='" + diagcd + "' && todiag>='" + diagcd + "'");
  2882. if (frow > -1){
  2883. lf_setAlramMessage("상병코드: " + diagcd + " 법정전염병 상병입니다. 확인하십시오.");
  2884. }
  2885. if (utlf_isNull(addval1) && addval2 == 2 )
  2886. {
  2887. lf_fDiagGridInsertRow("Y", "N");
  2888. }
  2889. }
  2890. /****************************************************************************************
  2891. * Argument : function
  2892. * Description : 상병코드로 특정기호 조회
  2893. ****************************************************************************************/
  2894. function lf_fGetDiagVcode(diagcd)
  2895. {
  2896. var vcode = "";
  2897. var spclcd = "";
  2898. var spclspec = "";
  2899. var gridrowstatus = "";
  2900. var existsyn = "N";
  2901. ds_cond_getvcode.clearData();
  2902. ds_cond_getvcode.addRow();
  2903. ds_cond_getvcode.setColumn(0, "diagcd" , diagcd);
  2904. ds_cond_getvcode.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  2905. ds_cond_getvcode.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  2906. ds_cond_getvcode.setColumn(0, "suppkind" , ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  2907. ds_cond_getvcode.setColumn(0, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  2908. var oParam = {};
  2909. oParam.id = "TRPID20313";
  2910. oParam.service = "aftjudgapp.InAftJudg";
  2911. oParam.method = "reqGetDiagcdVcode";
  2912. oParam.inds = "req=ds_cond_getvcode";
  2913. oParam.outds = "ds_cond_getvcode=cond ds_rslt_getvcode=rslt";
  2914. oParam.async = false;
  2915. //oParam.callback = "cf_TRPID20313";
  2916. tranf_submit(oParam);
  2917. vcode = ds_rslt_getvcode.getColumn(0, "vcode");
  2918. return vcode;
  2919. }
  2920. /****************************************************************************************
  2921. * Argument : oncelldbclick
  2922. * Description : 상병 grid 더블 클릭 이벤트
  2923. ****************************************************************************************/
  2924. function grp_biz_grd_cldihist_oncelldblclick(obj:Grid, e:GridClickEventInfo)
  2925. {
  2926. var col = e.col;
  2927. if ( col == obj.getBindCellIndex("body", "diagnm"))
  2928. {
  2929. lf_fSearchSPPIZ00400();
  2930. lf_fSortDiagNo(true);
  2931. }
  2932. else if ( col == obj.getBindCellIndex("body", "toot1") )
  2933. {
  2934. lf_fDiagOrderToothInput("Diag");
  2935. }
  2936. }
  2937. /****************************************************************************************
  2938. * Argument : modal
  2939. * Description : SPPIZ00600_상병및처방별치식 modal 호출
  2940. ****************************************************************************************/
  2941. function lf_fDiagOrderToothInput(flag)
  2942. {
  2943. if (flag == "Diag")
  2944. {
  2945. var row = ds_list1_cldi.rowposition;
  2946. var diagcd = ds_list1_cldi.getColumn(row, "diagcd");
  2947. if (!utlf_isNull(diagcd))
  2948. {
  2949. ds_cond_sppiz00600.clearData();
  2950. ds_cond_sppiz00600.addRow();
  2951. ds_cond_sppiz00600.setColumn(0, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  2952. ds_cond_sppiz00600.setColumn(0, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  2953. ds_cond_sppiz00600.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  2954. ds_cond_sppiz00600.setColumn(0, "pidsn" , ds_main_item1_clbs.getColumn(0, "pidsn"));
  2955. ds_cond_sppiz00600.setColumn(0, "indd" , ds_main_item1_clbs.getColumn(0, "indd"));
  2956. ds_cond_sppiz00600.setColumn(0, "cretno", ds_main_item1_clbs.getColumn(0, "cretno"));
  2957. ds_cond_sppiz00600.setColumn(0, "toot" , ds_list1_cldi.getColumn(row, "toot"));
  2958. ds_cond_sppiz00600_toothapplist.clearData();
  2959. lf_fSetToothPop(row, "1");
  2960. ds_rslt_sppiz00600.clearData();
  2961. ds_rslt_sppiz00600.addRow();
  2962. var rtn = frmf_modal("SPPIZ00600","SPPIZ00600", {objDs:ds_cond_sppiz00600, objDs2:ds_cond_sppiz00600_toothapplist},"", "", "", "", "", "", "", "", "", "M");
  2963. lf_fGetToothPop();
  2964. }
  2965. }
  2966. else if (flag == "Order")
  2967. {
  2968. var row = ds_list2_clod.rowposition;
  2969. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  2970. if (!utlf_isNull(edilnno))
  2971. {
  2972. ds_cond_sppiz00600.clearData();
  2973. ds_cond_sppiz00600.addRow();
  2974. ds_cond_sppiz00600.setColumn(0, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  2975. ds_cond_sppiz00600.setColumn(0, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  2976. ds_cond_sppiz00600.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  2977. ds_cond_sppiz00600.setColumn(0, "pidsn" , ds_main_item1_clbs.getColumn(0, "pidsn"));
  2978. ds_cond_sppiz00600.setColumn(0, "indd" , ds_main_item1_clbs.getColumn(0, "indd"));
  2979. ds_cond_sppiz00600.setColumn(0, "cretno", ds_main_item1_clbs.getColumn(0, "cretno"));
  2980. ds_cond_sppiz00600.setColumn(0, "toot" , ds_list1_cldi.getColumn(row, "toot"));
  2981. ds_cond_sppiz00600_toothapplist.clearData();
  2982. lf_fSetToothPop(row, "2");
  2983. var rtn = frmf_modal("SPPIZ00600","SPPIZ00600", {objDs:ds_cond_sppiz00600, objDs2:ds_cond_sppiz00600_toothapplist}, "", "", "", "", "", "", "", "", "", "M");
  2984. lf_fGetToothPop();
  2985. }
  2986. }
  2987. }
  2988. /****************************************************************************************
  2989. * Argument : function
  2990. * Description : 현재 상병, 처방 Grid 상에서 입력상태의 치식을 팝업 화면에 전달하기 위해 리스트 형태로 만든다.
  2991. ****************************************************************************************/
  2992. function lf_fSetToothPop(row, flag)
  2993. {
  2994. var cntcldi = ds_list1_cldi.rowcount; //노드셋의 갯수 반환
  2995. var cntclod = ds_list2_clod.rowcount; //노드셋의 갯수 반환
  2996. var cd = "";
  2997. var cdnm = "";
  2998. var orddd = "";
  2999. var toot = "";
  3000. var rowcnt = 0;
  3001. for ( var i = 0; i < cntcldi; i++)
  3002. {
  3003. cd = ds_list1_cldi.getColumn(i, "diagcd");
  3004. cdnm = ds_list1_cldi.getColumn(i, "diagnm");
  3005. orddd = ds_list1_cldi.getColumn(i, "ordfromdd");
  3006. toot = ds_list1_cldi.getColumn(i, "toot");
  3007. if (toot != "-" && !utlf_isNull(toot))
  3008. {
  3009. var milktoothstr = "ABCDE000";
  3010. var subTootStr = "";
  3011. for ( var inx = 0; inx < 32; inx++)
  3012. {
  3013. var tootnum = toot.substr(inx, 1);
  3014. if (tootnum == "*"||tootnum == "!")
  3015. {
  3016. if (inx < 8)
  3017. {
  3018. subTootStr += (8 - inx);
  3019. }
  3020. else if (inx > 7 && inx < 16)
  3021. {
  3022. subTootStr += (inx - 7);
  3023. }
  3024. else if (inx > 15 && inx < 24)
  3025. {
  3026. subTootStr += (24 - inx);
  3027. }
  3028. else
  3029. {
  3030. subTootStr += (inx - 23);
  3031. }
  3032. }
  3033. else if (tootnum == "#")
  3034. {
  3035. if (inx < 8)
  3036. {
  3037. subTootStr += milktoothstr.charAt(7 - inx);
  3038. }
  3039. else if (inx > 7 && inx < 16)
  3040. {
  3041. subTootStr += milktoothstr.charAt(inx - 8);
  3042. }
  3043. else if (inx > 15 && inx < 24)
  3044. {
  3045. subTootStr += milktoothstr.charAt(23 - inx);
  3046. }
  3047. else
  3048. {
  3049. subTootStr += milktoothstr.charAt(inx - 24);
  3050. }
  3051. }
  3052. else
  3053. {
  3054. subTootStr += " ";
  3055. }
  3056. }
  3057. rowcnt = ds_cond_sppiz00600_toothapplist.addRow();
  3058. if (row == i && flag == "1")
  3059. {
  3060. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos", "true");
  3061. }
  3062. else
  3063. {
  3064. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos", "false");
  3065. }
  3066. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "flag", "상병");
  3067. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cd", cd);
  3068. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cdnm", cdnm);
  3069. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightupper", subTootStr.substr(0, 8));
  3070. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftupper", subTootStr.substr(8, 8));
  3071. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightlower", subTootStr.substr(16, 8));
  3072. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftlower", subTootStr.substr(24, 8));
  3073. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "orddd", orddd);
  3074. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "toot", toot);
  3075. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "row", i);
  3076. }
  3077. else
  3078. {
  3079. if (row == i && flag == "1")
  3080. {
  3081. rowcnt = ds_cond_sppiz00600_toothapplist.addRow();
  3082. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos", "true");
  3083. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "flag", "상병");
  3084. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cd", cd);
  3085. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cdnm", cdnm);
  3086. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightupper", "");
  3087. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftupper", "");
  3088. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightlower", "");
  3089. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftlower", "");
  3090. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "orddd", orddd);
  3091. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "toot", "");
  3092. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "row", i);
  3093. }
  3094. }
  3095. }
  3096. for ( var i = 0; i < cntclod; i++)
  3097. {
  3098. cd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  3099. cdnm = ds_list2_clod.getColumn(i, "hngnm");
  3100. orddd = ds_list2_clod.getColumn(i, "orddd");
  3101. toot = ds_list2_clod.getColumn(i, "toot");
  3102. estmcls = ds_list2_clod.getColumn(i, "estmcls");
  3103. if (toot != "-" && !utlf_isNull(toot)|| estmcls == "U")
  3104. {
  3105. var milktoothstr = "ABCDE000";
  3106. var subTootStr = "";
  3107. var tmpStr = "";
  3108. for ( var inx = 0; inx < 32; inx++)
  3109. {
  3110. var tootnum = toot.substr(inx, 1);
  3111. if (tootnum == "*"||tootnum == "!")
  3112. {
  3113. if (inx < 8)
  3114. {
  3115. subTootStr += (8 - inx);
  3116. }
  3117. else if (inx > 7 && inx < 16)
  3118. {
  3119. subTootStr += (inx - 7);
  3120. }
  3121. else if (inx > 15 && inx < 24)
  3122. {
  3123. subTootStr += (24 - inx);
  3124. }
  3125. else
  3126. {
  3127. subTootStr += (inx - 23);
  3128. }
  3129. }
  3130. else if (tootnum == "#")
  3131. {
  3132. if (inx < 8)
  3133. {
  3134. subTootStr += milktoothstr.charAt(7 - inx);
  3135. }
  3136. else if (inx > 7 && inx < 16)
  3137. {
  3138. subTootStr += milktoothstr.charAt(inx - 8);
  3139. }
  3140. else if (inx > 15 && inx < 24)
  3141. {
  3142. subTootStr += milktoothstr.charAt(23 - inx);
  3143. }
  3144. else
  3145. {
  3146. subTootStr += milktoothstr.charAt(inx - 24);
  3147. }
  3148. }
  3149. else
  3150. {
  3151. subTootStr += " ";
  3152. }
  3153. }
  3154. rowcnt = ds_cond_sppiz00600_toothapplist.addRow();
  3155. if (row == i && flag == "2")
  3156. {
  3157. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos", "true");
  3158. }
  3159. else
  3160. {
  3161. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos", "false");
  3162. }
  3163. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "flag" , "처방");
  3164. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cd" , cd);
  3165. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cdnm" , cdnm);
  3166. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightupper", subTootStr.substr(0, 8));
  3167. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftupper" , subTootStr.substr(8, 8));
  3168. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightlower", subTootStr.substr(16, 8));
  3169. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftlower" , subTootStr.substr(24, 8));
  3170. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "orddd" , orddd);
  3171. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "toot" , toot);
  3172. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "row" , i);
  3173. }
  3174. else
  3175. {
  3176. if (row == i && flag == "2")
  3177. {
  3178. rowcnt = ds_cond_sppiz00600_toothapplist.addRow();
  3179. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "chos" , "true");
  3180. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "flag" , "처방");
  3181. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cd" , cd);
  3182. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "cdnm" , cdnm);
  3183. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightupper" , "");
  3184. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftupper" , "");
  3185. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "rightlower" , "");
  3186. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "leftlower" , "");
  3187. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "orddd" , orddd);
  3188. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "toot" , "");
  3189. ds_cond_sppiz00600_toothapplist.setColumn(rowcnt, "row" , i);
  3190. }
  3191. }
  3192. }
  3193. }
  3194. /****************************************************************************************
  3195. * Argument : oncellclick
  3196. * Description : 상병 grid 셀 클릭 이벤트
  3197. ****************************************************************************************/
  3198. function grp_biz_grd_cldihist_oncellclick(obj:Grid, e:GridClickEventInfo)
  3199. {
  3200. var row = e.row;
  3201. if (row > -1)
  3202. {
  3203. var diagcd = utlf_transNullToEmpty(ds_list1_cldi.getColumn(row, "diagcd"));
  3204. var diagnm = utlf_transNullToEmpty(ds_list1_cldi.getColumn(row, "diagnm"));
  3205. var diagengnm = utlf_transNullToEmpty(ds_list1_cldi.getColumn(row, "diagengnm"));
  3206. ds_hidden_list3.setColumn(0, "msgspclformat", "상병코드 - "+ diagcd +" / "+ diagnm +" / "+ diagengnm);
  3207. }
  3208. if (obj.currentcol == obj.getBindCellIndex("body", "diagcd")) {
  3209. obj.showEditor(true);
  3210. }
  3211. }
  3212. /****************************************************************************************
  3213. * Argument : onenterdown
  3214. * Description : 상병 grid enter 클릭 이벤트
  3215. ****************************************************************************************/
  3216. function grp_biz_grd_cldihist_onenterdown(obj:Grid, e:GridEditEventInfo)
  3217. {
  3218. var col = obj.currentcol;
  3219. var row = obj.currentrow;
  3220. if (col == obj.getBindCellIndex("body", "ordfromdd"))
  3221. {
  3222. var ordfromdd = ds_list1_cldi.getColumn(row, "ordfromdd");
  3223. if (!utlf_isValidDateTime(ordfromdd))
  3224. {
  3225. ds_list1_cldi.setColumn(row, "ordfromdd", ds_hidden_list1_cldi.getColumn(0, "oldordfromdd"));
  3226. ds_list1_cldi.updatecontrol = false;
  3227. ds_list1_cldi.setRowType(row, ds_hidden_list1_cldi.getColumn(0, "oldrowstat"));
  3228. ds_list1_cldi.updatecontrol = true;
  3229. }
  3230. }
  3231. else if (col == obj.getBindCellIndex("body", "diagcd"))
  3232. {
  3233. if (ds_hidden_list1_cldi.getColumn(0, "olddiagcd") != ds_list1_cldi.getColumn(row, "diagcd"))
  3234. {
  3235. ds_list1_cldi.setColumn(row, "diagnm", "");
  3236. ds_list1_cldi.setColumn(row, "diagengnm", "");
  3237. obj.updateToDataset();
  3238. lf_fSearchDiageCode();
  3239. obj.showEditor(true);
  3240. }
  3241. }
  3242. else if (col == obj.getBindCellIndex("body", "diagseq"))
  3243. {
  3244. lf_fChangeDiagNo();
  3245. }
  3246. }
  3247. /****************************************************************************************
  3248. * Argument : funtion
  3249. * Description : 상병코드를 조회하여 해당 정보를 표시하거나 상병코드 조회용 Popup을 호출
  3250. ****************************************************************************************/
  3251. function lf_fSearchDiageCode()
  3252. {
  3253. var row = ds_list1_cldi.rowposition;
  3254. var diagcd = ds_list1_cldi.getColumn(row, "diagcd");
  3255. if (!utlf_isNull(diagcd))
  3256. {
  3257. var objArg = new Object();
  3258. objArg.sSelectedrdodiagkind = "1";
  3259. objArg.sDiagcd = diagcd;
  3260. objArg.sDiagnm = "";
  3261. ds_rslt_sppiz00400.clearData();
  3262. ds_cond_sppiz00400.clearData();
  3263. ds_cond_sppiz00400.addRow();
  3264. ds_cond_sppiz00400.setColumn(0, "basedd", utlf_getCurrentDate());
  3265. ds_cond_sppiz00400.setColumn(0, "diagcd", diagcd);
  3266. ds_cond_sppiz00400.setColumn(0, "diagnm", "");
  3267. ds_cond_sppiz00400.setColumn(0, "selectedrdodiagkind", "1");
  3268. // 입력된 상병코드로 emr.mrtmicd10 테이블을 조회한다.
  3269. var oParam = {};
  3270. oParam.id = "TRPID20306";
  3271. oParam.service = "aftjudgapp.InAftJudg";
  3272. oParam.method = "reqGetSickAndWounded";
  3273. oParam.inds = "req=ds_cond_sppiz00400";
  3274. oParam.outds = "ds_cond_sppiz00400=cond ds_rslt_sppiz00400=rslt";
  3275. oParam.async = false;
  3276. tranf_submit(oParam);
  3277. var rsltList = ds_rslt_sppiz00400.rowcount;
  3278. if ( rsltList == 1 )
  3279. {
  3280. // 조회된 결과가 1건이면
  3281. lf_fSetDiagCdNm();
  3282. // 다음칸에 자동 포커스 2008-11-26
  3283. row++;
  3284. ds_list1_cldi.rowposition = row;
  3285. grp_biz.grd_cldihist.vscrollbar.pos = row;
  3286. grp_biz.grd_cldihist.setCellPos(grp_biz.grd_cldihist.getBindCellIndex("body", "diagcd"));
  3287. grp_biz.grd_cldihist.showEditor(true);
  3288. }
  3289. else
  3290. {
  3291. // 조회된 결과가 없거나 여러 건이면
  3292. // 상병코드 조회를 위해 SPPIZ00400_상병코드조회.xrw 를 호출한다.
  3293. lf_fSearchSPPIZ00400();
  3294. if ( utlf_isNull(ds_list1_cldi.getColumn(row, "diagnm")) && utlf_isNull(ds_list1_cldi.getColumn(row, "diagengnm")))
  3295. {
  3296. ds_list1_cldi.setColumn(row, "diagcd", ds_hidden_list1_cldi.getColumn(0, "olddiagcd"));
  3297. ds_list1_cldi.setColumn(row, "diagnm", ds_hidden_list1_cldi.getColumn(0, "olddiagnm"));
  3298. ds_list1_cldi.setColumn(row, "diagengnm", ds_hidden_list1_cldi.getColumn(0, "oldengnm"));
  3299. ds_list1_cldi.setColumn(row, "kcd6chk", "N");
  3300. ds_list1_cldi.setRowType(row, ds_hidden_list1_cldi.getColumn(0, "oldrowstat"));
  3301. return;
  3302. }
  3303. else
  3304. {
  3305. row = ds_list1_cldi.rowposition;
  3306. if ( utlf_isNull(ds_list1_cldi.getColumn(row, "diagcd")))
  3307. {
  3308. ds_list1_cldi.setColumn(row, "diagcd" , ds_hidden_list1_cldi.getColumn(0, "olddiagcd"));
  3309. ds_list1_cldi.setColumn(row, "diagnm" , ds_hidden_list1_cldi.getColumn(0, "olddiagnm"));
  3310. ds_list1_cldi.setColumn(row, "diagengnm" , ds_hidden_list1_cldi.getColumn(0, "oldengnm"));
  3311. ds_list1_cldi.setColumn(row, "kcd6chk", "N");
  3312. ds_list1_cldi.setRowType(row, ds_hidden_list1_cldi.getColumn(0, "oldrowstat"));
  3313. return;
  3314. }
  3315. }
  3316. }
  3317. }
  3318. else
  3319. {
  3320. // 상병 Grid에 상병코드를 입력하지 않고 Enter 친 경우
  3321. // 상병코드 조회를 위해 SPPIZ00400_상병코드조회.xrw 를 호출한다.
  3322. lf_fSearchSPPIZ00400();
  3323. row = ds_list1_cldi.rowposition;
  3324. if ( utlf_isNull(ds_list1_cldi.getColumn(row, "diagcd")))
  3325. {
  3326. ds_list1_cldi.setColumn(row, "diagcd", ds_hidden_list1_cldi.getColumn(0, "olddiagcd"));
  3327. ds_list1_cldi.setColumn(row, "diagnm", ds_hidden_list1_cldi.getColumn(0, "olddiagnm"));
  3328. ds_list1_cldi.setColumn(row, "diagengnm", ds_hidden_list1_cldi.getColumn(0, "oldengnm"));
  3329. ds_list1_cldi.setColumn(row, "kcd6chk", "N");
  3330. ds_list1_cldi.setRowType(row, ds_hidden_list1_cldi.getColumn(0, "oldrowstat"));
  3331. return;
  3332. }
  3333. }
  3334. }
  3335. /****************************************************************************************
  3336. * Argument : funtion
  3337. * Description : 사용자가 입력한 숫자를 기준으로 상병순서 부여
  3338. ****************************************************************************************/
  3339. function lf_fChangeDiagNo() {
  3340. var objds = ds_list1_cldi;
  3341. var objgrd = grp_biz.grd_cldihist;
  3342. var seqnm = "diagseq";
  3343. var row = objds.rowposition;
  3344. var iptseqno = objds.getColumn(row, seqnm)
  3345. var destrow = objds.findRow(seqnm,iptseqno);
  3346. if ( objds.getRowType(row) != 2 ) { // insert
  3347. objds.updatecontrol = false;
  3348. objds.setRowType(row, "u"); // update
  3349. objds.updatecontrol = true;
  3350. }
  3351. var newseq = objds.getColumn(row, seqnm);
  3352. var oldseq = ds_hidden_list1_cldi.getColumn(0, "oldseq");
  3353. if (!utlf_isNull(newseq)) {
  3354. // '09' 와 같은 형식으로 입력한 경우 -> 9로 처리
  3355. newseq = parseInt(objds.getColumn(row, seqnm), 10);
  3356. // 삭제상태가 아닌 중복된 번호가 있는지 체크한다.
  3357. var sameRow = -1;
  3358. for (var i = 0; i < objds.rowcount; i++) {
  3359. var diagseq = objds.getColumn(i, seqnm);
  3360. if (row != i && diagseq == newseq) {
  3361. sameRow = i;
  3362. i = objds.rowcount;
  3363. }
  3364. }
  3365. if (sameRow > -1) {
  3366. // 중복된 상병순서의 row가 있음
  3367. if (newseq < oldseq) {
  3368. // 이전보다 앞번호를 입력한 경우
  3369. for (var j = sameRow; j < row; j++) {
  3370. var rowstatus = objds.getRowType(j);
  3371. if ( rowstatus != 8 ) {
  3372. var curseq = parseInt(objds.getColumn(j, seqnm), 10);
  3373. if ( rowstatus != 2 ) {
  3374. if ( objds.getColumn(j, seqnm) != (curseq+1)) {
  3375. objds.updatecontrol = false;
  3376. objds.setRowType(j, "u");
  3377. objds.updatecontrol = true;
  3378. }
  3379. }
  3380. objds.setColumn(j, seqnm, curseq+1);
  3381. }
  3382. }
  3383. } else {
  3384. // 이전보다 뒷번호를 입력한 경우
  3385. for (var j = row+1; j <= sameRow; j++) {
  3386. var rowstatus = objds.getRowType(j);
  3387. if (rowstatus != 8) {
  3388. var curseq = parseInt(objds.getColumn(j, seqnm), 10);
  3389. if (rowstatus != 2) {
  3390. if (objds.getColumn(j, seqnm) != (curseq-1)) {
  3391. objds.updatecontrol = false;
  3392. objds.setRowType(j, "u");
  3393. objds.updatecontrol = true;
  3394. }
  3395. }
  3396. objds.setColumn(j, seqnm, curseq-1);
  3397. }
  3398. }
  3399. }
  3400. lf_fSortDiagNo(false);
  3401. } else {
  3402. // 중복된 상병순서의 row가 없는 경우
  3403. lf_fSortDiagNo(false);
  3404. }
  3405. } else {
  3406. // 순번을 삭제한 경우
  3407. objds.setColumn(row, seqnm, oldseq);
  3408. objds.updatecontrol = false;
  3409. objds.setRowType(row, ds_hidden_list1_cldi.getColumn(0, "oldrowstat"));
  3410. objds.updatecontrol = true;
  3411. }
  3412. }
  3413. /****************************************************************************************
  3414. * Argument : funtion
  3415. * Description : 상병 그리드 row 추가
  3416. ****************************************************************************************/
  3417. function lf_fDiagGridAddRow()
  3418. {
  3419. var frow = ds_list1_cldi.findRowExpr("ds_list1_cldi.getRowType(currow) != 8 && utlf_isNull(diagcd)")
  3420. if (frow > -1){
  3421. var irow = frow;
  3422. }else {
  3423. var irow = ds_list1_cldi.insertRow(ds_list1_cldi.rowcount);
  3424. }
  3425. ds_list1_cldi.setColumn(irow, "diagkindcd", "C");
  3426. ds_list1_cldi.setColumn(irow, "diagseq", irow+1);
  3427. var clamdeptcd = ds_list1_cldi.getColumn(0, "clamdeptcd");
  3428. if (utlf_isNull(clamdeptcd))
  3429. {
  3430. clamdeptcd = ds_main_item1_clbs.getColumn(0, "clamdeptcd");
  3431. }
  3432. ds_list1_cldi.setColumn(irow, "clamdeptcd", clamdeptcd);
  3433. var ordfromdd = ds_list1_cldi.getColumn(0, "ordfromdd");
  3434. if (utlf_isNull(ordfromdd))
  3435. {
  3436. ds_list1_cldi.setColumn(irow, "ordfromdd", ordfromdd);
  3437. }
  3438. else
  3439. {
  3440. ds_list1_cldi.setColumn(irow, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  3441. }
  3442. ds_list1_cldi.setColumn(irow, "toot", "-");
  3443. ds_list1_cldi.setColumn(irow, "vcode", "");
  3444. ds_list1_cldi.clearSelect();
  3445. ds_list1_cldi.rowposition = irow;
  3446. ds_list1_cldi.selectRow(irow);
  3447. grp_biz.grd_cldihist.setCellPos(grp_biz.grd_cldihist.getBindCellIndex("body", "diagcd"));
  3448. grp_biz.grd_cldihist.showEditor(true);
  3449. lf_fSortDiagNo(true);
  3450. return irow;
  3451. }
  3452. /****************************************************************************************
  3453. * Argument : radio box onitemchanged
  3454. * Description : 특정내역 라디오 박스 이벤트
  3455. ****************************************************************************************/
  3456. function grp_biz_swt_spclmemo_case_spclspec_rdo_unitflag_onitemchanged(obj:Radio, e:ItemChangeEventInfo)
  3457. {
  3458. // 특정내역 Radio button
  3459. lf_fSelectSpclRadio();
  3460. }
  3461. /****************************************************************************************
  3462. * Argument : funtion
  3463. * Description : 특정내역 라디오 박스 이벤트 함수
  3464. ****************************************************************************************/
  3465. function lf_fSelectSpclRadio()
  3466. {
  3467. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  3468. if ( !utlf_isNull(clamym))
  3469. {
  3470. // 조회된 심사대상자가 있으면
  3471. var visibleRow = 0;
  3472. var rdounitflag = ds_hidden_list3.getColumn(0, "selectedUnitFlag");
  3473. var chk_JT001 = grp_biz.swt_spclmemo.case_spclspec.chk_JT001.value;
  3474. switch(rdounitflag)
  3475. {
  3476. case "-" : // 전체
  3477. if (chk_JT001 == 'Y')
  3478. {
  3479. ds_list3_clsp.filter("spclcd != 'JT001' && spclcd != 'JX998'");
  3480. }
  3481. else
  3482. {
  3483. ds_list3_clsp.filter("");
  3484. }
  3485. break;
  3486. case "M" : // 명세서
  3487. ds_list3_clsp.filter("unitflag == 'M'");
  3488. break;
  3489. case "J" : // 줄
  3490. ds_list3_clsp.filter("unitflag == 'J' && spclcd != 'JT001'");
  3491. break;
  3492. case "C" : // 처방
  3493. ds_list3_clsp.filter("unitflag == 'C'");
  3494. break;
  3495. }
  3496. visibleRow = ds_list3_clsp.getRowCount();
  3497. }
  3498. if (visibleRow == 0)
  3499. {
  3500. lf_fSpclGridInsertRow(); // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
  3501. }
  3502. else
  3503. {
  3504. //ds_list3_clsp.rowposition = 0;
  3505. }
  3506. }
  3507. /****************************************************************************************
  3508. * Argument : funtion
  3509. * Description : 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
  3510. ****************************************************************************************/
  3511. function lf_fSpclGridInsertRow(spclcd)
  3512. {
  3513. var clsprow = ds_list3_clsp.addRow();
  3514. ds_list3_clsp.setColumn(clsprow, "unitflag", "M");
  3515. ds_list3_clsp.setColumn(clsprow, "edilnno", "0");
  3516. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  3517. ds_list3_clsp.clearSelect();
  3518. ds_list3_clsp.rowposition = clsprow;
  3519. ds_list3_clsp.selectRow(clsprow);
  3520. return clsprow;
  3521. }
  3522. /****************************************************************************************
  3523. * Argument : oncellclick
  3524. * Description : 특정내역 Grid cell 클릭 이벤트
  3525. ****************************************************************************************/
  3526. function grp_biz_swt_spclmemo_case_spclspec_grd_clsphist_oncellclick(obj:Grid, e:GridClickEventInfo)
  3527. {
  3528. var row = e.row;
  3529. var rowstatus = ds_list3_clsp.getRowType(row);
  3530. if (rowstatus == 1 || rowstatus == 4 || rowstatus == 8)
  3531. {
  3532. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "displaytype", "combo");
  3533. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "edittype", "none");
  3534. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclspec"), "edittype", "normal");
  3535. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclspec"), "edittype", "textarea");
  3536. }
  3537. else
  3538. {
  3539. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "displaytype", "combo");
  3540. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "edittype", "combo");
  3541. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclspec"), "edittype", "normal");
  3542. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclspec"), "edittype", "textarea");
  3543. var unitflag = ds_list3_clsp.getColumn(row,"unitflag");
  3544. if (unitflag == "J")
  3545. {
  3546. if (ds_list3_clsp.getColumn(row,"spclcd") == "JT001")
  3547. {
  3548. // 확인코드의 경우 전용 팝업창을 사용하므로 특정내역 Grid에서 수정하지 않는다.
  3549. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "displaytype", "combo");
  3550. obj.setCellProperty("body", obj.getBindCellIndex("body", "spclcd"), "edittype", "none");
  3551. fds_init_P0117.filterstr = "cdid=='JT001'";
  3552. }
  3553. else
  3554. {
  3555. fds_init_P0117.filterstr = "minval == 'J' && cdid != 'JT001'";
  3556. }
  3557. }
  3558. else
  3559. {
  3560. fds_init_P0117.filterstr = "minval == 'M' && cdid != 'MX999'";
  3561. }
  3562. }
  3563. var row = e.row;
  3564. if(row > -1)
  3565. {
  3566. var spclcd = ds_list3_clsp.getColumn(row, "spclcd");
  3567. if (spclcd == "JT001")
  3568. {
  3569. var spclspec = ds_list3_clsp.getColumn(row, "spclspec");
  3570. var spclformat = ds_list3_clsp.getColumn(row, "spclformat");
  3571. ds_hidden_list3.setColumn(0, "msgspclformat", "확인코드 - "+ spclcd +" / 입력코드내역 : "+ spclspec +" / 기재형식 : "+ spclformat);
  3572. }
  3573. else if (spclcd)
  3574. {
  3575. var cdnm = ds_list3_clsp.getColumn(row, "cdnm");
  3576. var spclspec = ds_list3_clsp.getColumn(row, "spclspec");
  3577. var spclformat = ds_list3_clsp.getColumn(row, "spclformat");
  3578. ds_hidden_list3.setColumn(0, "msgspclformat", "특정내역코드: "+ spclcd +" / 특정내역명칭: "+ cdnm +" / 기재내역: "+ spclspec +" / 기재형식: "+ spclformat);
  3579. }
  3580. }
  3581. }
  3582. /****************************************************************************************
  3583. * Argument : oncellclick
  3584. * Description : 특정내역 Grid enter down 이벤트
  3585. ****************************************************************************************/
  3586. function grp_biz_swt_spclmemo_case_spclspec_grd_clsphist_onenterdown(obj:Grid, e:GridEditEventInfo)
  3587. {
  3588. var row = e.row;
  3589. var newspclcd = ds_list3_clsp.getColumn(row, "spclcd");
  3590. var newspclspec = ds_list3_clsp.getColumn(row, "spclspec");
  3591. if (e.col == obj.getBindCellIndex("body", "spclcd"))
  3592. {
  3593. if( newspclcd == "CT001")
  3594. {
  3595. ds_list3_clsp.setColumn(row, "unitflag", "C");
  3596. }
  3597. var unitflag = ds_list3_clsp.getColumn(row, "unitflag");
  3598. if (unitflag == "M" && !utlf_isNull(newspclcd))
  3599. {
  3600. if (newspclcd == "MT004" || newspclcd == "MT015" || newspclcd == "MT016")
  3601. {
  3602. // 중복된 특정코드가 있는지를 확인한다.
  3603. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  3604. {
  3605. var oth_spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  3606. if (row != i && newspclcd == oth_spclcd)
  3607. {
  3608. if (ds_list3_clsp.getRowType(i) != 8)
  3609. {
  3610. ds_list3_clsp.setColumn(row, "spclcd" , "");
  3611. ds_list3_clsp.setColumn(row, "spclspec" , "");
  3612. ds_list3_clsp.setColumn(row, "spclformat" , "");
  3613. ds_list3_clsp.setColumn(row, "cdnm" , "");
  3614. ds_list3_clsp.setColumn(row, "detldesc" , "");
  3615. ds_hidden_list3.setColumn(0, "msgspclformat", "명세서 단위 특정코드 '"+ newspclcd +"'가 중복되었습니다.");
  3616. return;
  3617. }
  3618. }
  3619. }
  3620. }
  3621. // MT018:본인부담코드 변경시 clbs-ownbflag도 변경해줌
  3622. if (newspclcd == "MT018" && !utlf_isNull(newspclspec))
  3623. {
  3624. ds_main_item1_clbs.setColumn(0, "ownbflag", newspclspec);
  3625. }
  3626. // 특정코드 MT015, MT016, MT004 정보가 입력된 환자인지를 확인한다.
  3627. lf_fCheckSpclSpecData();
  3628. }
  3629. else
  3630. { // 줄단위
  3631. if (newspclcd == "JX999" || newspclcd == "JT001")
  3632. {
  3633. // 중복된 특정코드가 있는지를 확인한다.
  3634. var spclLnNo = ds_list3_clsp.getColumn(row, "edilnno");
  3635. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  3636. {
  3637. var oth_spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  3638. var oth_spclLnNo = ds_list3_clsp.getColumn(i, "edilnno");
  3639. if (spclLnNo == oth_spclLnNo && row != i && newspclcd == oth_spclcd)
  3640. {
  3641. if (ds_list3_clsp.getRowType(i) != 8)
  3642. {
  3643. ds_list3_clsp.setColumn(row, "spclcd" , "");
  3644. ds_list3_clsp.setColumn(row, "spclspec" , "");
  3645. ds_list3_clsp.setColumn(row, "spclformat" , "");
  3646. ds_list3_clsp.setColumn(row, "cdnm" , "");
  3647. ds_list3_clsp.setColumn(row, "detldesc" , "");
  3648. ds_hidden_list3.setColumn(0, "msgspclformat", "줄번호 "+ spclLnNo +"의 줄단위 특정코드 '"+ newspclcd +"'가 중복되었습니다.");
  3649. return;
  3650. }
  3651. }
  3652. }
  3653. }
  3654. if (newspclcd == "JS010")
  3655. { // JS010 야간가산
  3656. for ( var i = 0 ; i < obj.getCellCount('Body'); i++ )
  3657. {
  3658. // ff3333=붉은색
  3659. colorExpr = "EXPR( spclcd == 'JS010' && lf_js010chk(spclspec) ? '#ff3333' : ''";
  3660. grp_biz.swt_spclmemo.case_spclspec.grd_clsphist.setCellProperty('Body', i, "color", colorExpr);
  3661. }
  3662. } // if (newspclcd == "JS010")
  3663. } // if (unitflag == "M" && newspclcd != "") 가 아닌 경우
  3664. if(!utlf_isNull(newspclcd))
  3665. {
  3666. var nRow = ds_init_P0117.findRow("cdid", newspclcd);
  3667. var format = ds_init_P0117.getColumn(nRow, "cdval");
  3668. var detldesc = ds_init_P0117.getColumn(nRow, "detldesc");
  3669. ds_list3_clsp.setColumn(row, "spclspec", "");
  3670. ds_list3_clsp.setColumn(row, "spclformat", format);
  3671. ds_list3_clsp.setColumn(row, "detldesc", detldesc);
  3672. }
  3673. var rowstatus = ds_list3_clsp.getRowType(row);
  3674. // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
  3675. if (rowstatus == 2)
  3676. { // 1 : insert, 3 : insert & new
  3677. }
  3678. else
  3679. {
  3680. ds_list3_clsp.updatecontrol = false;
  3681. ds_list3_clsp.setRowType(row, "u");
  3682. ds_list3_clsp.updatecontrol = true;
  3683. }
  3684. var cdnm = ds_list3_clsp.getColumn(row, "cdnm");
  3685. var spclformat = ds_list3_clsp.getColumn(row, "spclformat");
  3686. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ cdnm +" / 내역: "+ newspclspec +" / 형식: "+ spclformat);
  3687. }
  3688. else
  3689. {
  3690. var unitflag = ds_list3_clsp.getColumn(row, "unitflag");
  3691. if (unitflag == "J")
  3692. {
  3693. if (newspclcd == "JT001")
  3694. {
  3695. // JT001 확인코드
  3696. var clsplnno = ds_list3_clsp.getColumn(row, "edilnno");
  3697. for (var j = 0; j < ds_list2_clod.rowcount; j++)
  3698. {
  3699. var clodlnno = ds_list2_clod.getColumn(j, "edilnno");
  3700. if (clsplnno == clodlnno)
  3701. {
  3702. ds_list2_clod.setColumn(j, "cnfmcd", newspclspec);
  3703. }
  3704. }
  3705. if (utlf_isNull(newspclspec))
  3706. { // 확인코드의 특정내역이 삭제된 경우임
  3707. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  3708. {
  3709. var unitflag = ds_list3_clsp.getColumn(j, "unitflag");
  3710. if (unitflag == "J")
  3711. {
  3712. var spclLnno = ds_list3_clsp.getColumn(j, "edilnno");
  3713. var spclSpclcd = ds_list3_clsp.getColumn(j, "spclcd");
  3714. if (spclLnno == clsplnno && spclSpclcd == "JT001")
  3715. {
  3716. var rowstatus = ds_list3_clsp.getRowType(j);
  3717. if (rowstatus == 2)
  3718. {
  3719. ds_list3_clsp.setColumn(j, "spclcd", "");
  3720. ds_list3_clsp.setColumn(j, "spclspec", "");
  3721. }
  3722. else
  3723. {
  3724. ds_list3_clsp.updatecontrol = false;
  3725. ds_list3_clsp.setRowType(j, "d");
  3726. ds_list3_clsp.updatecontrol = true;
  3727. }
  3728. }
  3729. }
  3730. }
  3731. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 확인코드 내역이 없습니다.");
  3732. lf_fSortSpclNo();
  3733. return;
  3734. } // if (newspclspec == "")
  3735. } // if (newspclcd == "JT001")
  3736. } // if (unitflag == "J")
  3737. else if (unitflag == "M")
  3738. {
  3739. // MT018:본인부담코드 변경시 clbs-ownbflag도 변경해줌
  3740. if (newspclcd == "MT018" && !utlf_isNull(newspclspec))
  3741. {
  3742. ds_main_item1_clbs.setColumn(0, "ownbflag", newspclspec);
  3743. }
  3744. }
  3745. var rowstatus = ds_list3_clsp.getRowType(row);
  3746. // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
  3747. if (rowstatus == 2)
  3748. {
  3749. }
  3750. else
  3751. {
  3752. ds_list3_clsp.updatecontrol = false;
  3753. ds_list3_clsp.setRowType(row, "u");
  3754. ds_list3_clsp.updatecontrol = true;
  3755. }
  3756. var cdnm = ds_list3_clsp.getColumn(row, "cdnm");
  3757. var spclformat = ds_list3_clsp.getColumn(row, "spclformat");
  3758. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ cdnm +" / 내역: "+ newspclspec +" / 형식: "+ spclformat);
  3759. lf_fSortSpclNo();
  3760. } // grd_clsphist.colRef("spclcd") 가 아닌 경우
  3761. }
  3762. /****************************************************************************************
  3763. * Argument : funtion
  3764. * Description : 특정코드 MT015, MT016, MT004 정보가 입력된 환자인지를 확인한다.
  3765. ****************************************************************************************/
  3766. function lf_fCheckSpclSpecData()
  3767. {
  3768. // 삭제된 상태가 아닌 소명자료 내역이 있는지 파악하여 "소명자료" Btn 색을 설정한다.
  3769. // 특정코드 MT004 가 있는지를 파악하여 "MT004" Btn 색을 설정한다.
  3770. var isAttachedDataList = false;
  3771. var isMT004DataList = false;
  3772. var fmt015 = ds_list3_clsp.findRowExpr("(spclcd=='MT015' || spclcd=='MT016') && ds_list3_clsp.getRowType(currow) != 8");
  3773. var fmt004 = ds_list3_clsp.findRowExpr("spclcd=='MT004' && ds_list3_clsp.getRowType(currow) != 8");
  3774. if (fmt015 > -1){isAttachedDataList = true;}
  3775. if (fmt004 > -1){isMT004DataList = true;}
  3776. // 소명자료 Btn
  3777. if (isAttachedDataList)
  3778. {
  3779. grp_biz.btn_attData.class = "btn5";
  3780. grp_biz.btn_attData.style.color = "#cc3333"; // cc3333=붉은색
  3781. }
  3782. else
  3783. {
  3784. grp_biz.btn_attData.class = "btn2";
  3785. grp_biz.btn_attData.style.color = "";
  3786. }
  3787. // MT004 Btn
  3788. if (isMT004DataList)
  3789. {
  3790. grp_biz.btn_mt0004.class = "btn5";
  3791. grp_biz.btn_mt0004.style.color = "#cc3333"; // cc3333=붉은색
  3792. }
  3793. else
  3794. {
  3795. grp_biz.btn_mt0004.class = "btn2";
  3796. grp_biz.btn_mt0004.style.color = "";
  3797. }
  3798. if (lgv_ioflag == "O") {
  3799. var clopfrow = ds_list7_clop.findRowExpr("!utlf_isNull(snglcalcscorcd)");
  3800. var clspfrow = ds_list3_clsp.findRowExpr("(spclcd=='CT002' && (spclspec=='V252' || spclspec=='V352' || spclspec=='V100'))");
  3801. var clsp_spec = ds_list3_clsp.getColumn(clspfrow, "spclspec");
  3802. if (clopfrow > -1 && clspfrow > -1) {
  3803. grp_biz.stc_v252.text = clsp_spec;
  3804. grp_biz.stc_v252.visible = true;
  3805. } else {
  3806. grp_biz.stc_v252.visible = false;
  3807. }
  3808. }
  3809. if (lgv_ioflag == "O") {
  3810. grp_biz.opt_fromddtm.value = String(ds_list3_clsp.lookupExpr("spclcd=='MS005' && ds_list3_clsp.getRowType(currow) != 8","spclspec")).split("/")[0];
  3811. grp_biz.opt_toddtm.value = String(ds_list3_clsp.lookupExpr("spclcd=='MS005' && ds_list3_clsp.getRowType(currow) != 8","spclspec")).split("/")[1];
  3812. } else {
  3813. grp_sea00.opt_fromddtm.value = String(ds_list3_clsp.lookupExpr("spclcd=='MS005' && ds_list3_clsp.getRowType(currow) != 8","spclspec")).split("/")[0];
  3814. grp_sea00.opt_toddtm.value = String(ds_list3_clsp.lookupExpr("spclcd=='MS005' && ds_list3_clsp.getRowType(currow) != 8","spclspec")).split("/")[1];
  3815. }
  3816. }
  3817. /****************************************************************************************
  3818. * Argument : onrbuttondown
  3819. * Description : 특정내역 그리드 마우스 오른쪽 버튼 이벤트
  3820. ****************************************************************************************/
  3821. function grp_biz_swt_spclmemo_case_spclspec_grd_clsphist_onrbuttondown(obj:Grid, e:GridMouseEventInfo)
  3822. {
  3823. if (e.col != obj.getBindCellIndex("body","spclspec")) {
  3824. if(!grdf_setSelectedCell(obj, e)) return;
  3825. lf_grd_clsphist.trackPopup(e.screenX,e.screenY);
  3826. }
  3827. }
  3828. /****************************************************************************************
  3829. * Argument : funtion
  3830. * Description : 특정내역 그리드 마우스 오른쪽 버튼 함수 선언
  3831. ****************************************************************************************/
  3832. function lf_grd_clsphist_onmenuclick(obj:PopupMenu, e:MenuClickEventInfo)
  3833. {
  3834. if (e.id == "lf_fSpclGridInsertRow")
  3835. {
  3836. lf_fSpclGridInsertRow(); // 행 삽입
  3837. }
  3838. else if (e.id == "lf_fSpclGridDeleteRow")
  3839. {
  3840. lf_fSpclGridDeleteRow(); //행 삭제
  3841. }
  3842. }
  3843. /****************************************************************************************
  3844. * Argument : funtion
  3845. * Description : 특정내역 그리드 마우스 오른쪽 버튼 행 삭제
  3846. ****************************************************************************************/
  3847. function lf_fSpclGridDeleteRow()
  3848. {
  3849. var SelectedRows = grdf_getSelectedRows(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist)
  3850. for(var i = SelectedRows.length-1; i >= 0; i--) {
  3851. var unitflag = ds_list3_clsp.getColumn(SelectedRows[i], "unitflag");
  3852. var clsoyn = ds_list3_clsp.getColumn(SelectedRows[i], "clsoyn");
  3853. var clodseqno = ds_list3_clsp.getColumn(SelectedRows[i], "clodseqno");
  3854. //줄메모 삭제할 경우 처방내역의 색표시, "*" 표시도 같이 제거
  3855. if(unitflag == "J") {
  3856. if(clsoyn == "Y") {
  3857. //원외
  3858. // var cur_filter = ds_list7_clop.filterstr.current;
  3859. // ds_list7_clop.filter("");
  3860. // var frow = ds_list7_clop.findRowExpr("seqno=='"+clodseqno+"'");
  3861. // while(frow > -1){
  3862. // ds_list7_clop.setColumn(frow, "cnfmcd", "");
  3863. // frow = ds_list7_clop.findRowExpr("seqno=='"+clodseqno+"'", frow+1);
  3864. // }
  3865. // ds_list7_clop.filter(cur_filter);
  3866. } else {
  3867. var cur_filter = ds_list2_clod.filterstr.current;
  3868. ds_list2_clod.filter("");
  3869. var frow = ds_list2_clod.findRowExpr("seqno=='"+clodseqno+"'");
  3870. while(frow > -1){
  3871. ds_list2_clod.setColumn(frow, "cnfmcd", "");
  3872. frow = ds_list2_clod.findRowExpr("seqno=='"+clodseqno+"'", frow+1);
  3873. }
  3874. ds_list2_clod.filter(cur_filter);
  3875. }
  3876. ds_list3_clsp.setColumn(SelectedRows[i], "rowstat","D");
  3877. ds_list3_clsp.updatecontrol = false;
  3878. ds_list3_clsp.setRowType(SelectedRows[i], 'd');
  3879. ds_list3_clsp.updatecontrol = true;
  3880. lf_fSetSpclSpecJX999()
  3881. ds_list3_clsp.deleteRow(SelectedRows[i]);
  3882. } else {
  3883. //명세서메모
  3884. ds_list3_clsp.setColumn(SelectedRows[i], "rowstat","D");
  3885. ds_list3_clsp.updatecontrol = false;
  3886. ds_list3_clsp.setRowType(SelectedRows[i], 'd');
  3887. ds_list3_clsp.updatecontrol = true;
  3888. lf_fSetSpclSpecJX999()
  3889. ds_list3_clsp.deleteRow(SelectedRows[i]);
  3890. lf_fCheckSpclSpecData();
  3891. }
  3892. }
  3893. }
  3894. /****************************************************************************************
  3895. * Argument : funtion
  3896. * Description : 특정내역 그리드 마우스 오른쪽 버튼 행 삭제
  3897. ****************************************************************************************/
  3898. function grp_biz_swt_spclmemo_case_spclspec_btn_spcldetl_onclick(obj:Button, e:ClickEventInfo)
  3899. {
  3900. var row = ds_list3_clsp.rowposition;
  3901. var spclcd = ds_list3_clsp.getColumn(row, "spclcd");
  3902. var sppiz01400 = new Object();
  3903. sppiz01400.sSpclcd = spclcd;
  3904. ds_rslt_sppiz01400.clearData();
  3905. var rtnDs = frmf_modal("SPPIZ01400", "SPPIZ01400", sppiz01400, "", "", "", "", "", "", "", "", "", "M");
  3906. if (!utlf_isNull(rtnDs))
  3907. {
  3908. ds_rslt_sppiz01400.copyData(rtnDs);
  3909. // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
  3910. lf_fSpclGridInsertRow();
  3911. var clsprow = ds_list3_clsp.rowposition;
  3912. ds_list3_clsp.setColumn(clsprow, "spclcd", ds_rslt_sppiz01400.getColumn(0, "spclcd"));
  3913. ds_list3_clsp.setColumn(clsprow, "cdnm", ds_rslt_sppiz01400.getColumn(0, "cdnm"));
  3914. ds_list3_clsp.setColumn(clsprow, "spclspec", ds_rslt_sppiz01400.getColumn(0, "spclspec"));
  3915. ds_list3_clsp.setColumn(clsprow, "spclformat", ds_rslt_sppiz01400.getColumn(0, "spclformat"));
  3916. ds_list3_clsp.setColumn(clsprow, "detldesc", ds_rslt_sppiz01400.getColumn(0, "detldesc"));
  3917. // 특정내역 줄번호/특정코드에 따라 sorting 작업
  3918. lf_fSortSpclNo();
  3919. }
  3920. }
  3921. /****************************************************************************************
  3922. * Argument : button
  3923. * Description : 특정내역 내역추가
  3924. ****************************************************************************************/
  3925. function grp_biz_swt_spclmemo_case_spclspec_btn_addspec_onclick(obj:Button, e:ClickEventInfo)
  3926. {
  3927. var row = ds_list3_clsp.rowposition;
  3928. if (row > 0)
  3929. {
  3930. if (ds_list3_clsp.getColumn(row, "spclcd") == "JT001")
  3931. {
  3932. lf_fSetCnfmCdSpclSpec();
  3933. }
  3934. else
  3935. {
  3936. lf_fSetDocRefLnSpclSpec();
  3937. }
  3938. }
  3939. else
  3940. {
  3941. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  3942. if (clamkey)
  3943. {
  3944. var rdounitflag = ds_hidden_list3.getColumn(0, "selectedUnitFlag");
  3945. if (rdounitflag == "-" || rdounitflag == "M")
  3946. {
  3947. lf_fSpclGridInsertRow();
  3948. lf_fSetDocRefLnSpclSpec();
  3949. }
  3950. else
  3951. {
  3952. if(ds_list2_clod.rowposition > 0)
  3953. {
  3954. lf_fSetLnUnitSpclSpec(); // 'T' 필드 더블클릭시 호출한다.
  3955. }
  3956. else
  3957. {
  3958. sysf_messageBox("특정내역을 추가할 줄번호를 먼저", "C002"); ///특정내역을 추가할 줄번호를 먼저 선택하십시오.
  3959. }
  3960. }
  3961. }
  3962. }
  3963. }
  3964. /****************************************************************************************
  3965. * Argument : function
  3966. * Description : 특정내역 더블클릭 : 확인코드 줄단위 특정내역 수정/입력 ==> SPPIZ01100_확인코드조회
  3967. ****************************************************************************************/
  3968. function lf_fSetCnfmCdSpclSpec()
  3969. {
  3970. var row = ds_list3_clsp.rowposition;
  3971. var sppiz01100 = new Object();
  3972. sppiz01100.sCode = ds_list3_clsp.getColumn(row, "spclspec");
  3973. // SPPIZ01100_확인코드조회
  3974. var rtnObj = frmf_modal("SPPIZ01100", "SPPIZ01100", sppiz01100, "", "", "", "", "", "", "", "", "", "M");
  3975. //if ( !utlf_isNull(rtnObj))
  3976. //{
  3977. var cnfmcd = rtnObj.sCode;
  3978. var clodseqno = ds_list3_clsp.getColumn(row, "clodseqno");
  3979. for (var j = 0; j < ds_list2_clod.rowcount; j++)
  3980. {
  3981. var seqno = ds_list2_clod.getColumn(j, "seqno");
  3982. if (seqno == clodseqno)
  3983. {
  3984. ds_list2_clod.setColumn(j, "cnfmcd", cnfmcd);
  3985. j = ds_list2_clod.rowcount;
  3986. }
  3987. }
  3988. var rowstatus = ds_list3_clsp.getRowType(row);
  3989. if (!utlf_isNull(cnfmcd))
  3990. {
  3991. ds_list3_clsp.setColumn(row, "spclspec", cnfmcd);
  3992. ds_hidden_list3.setColumn(0, "msgspclformat", "확인코드 - JT001 / 입력코드내역 : "+ cnfmcd +" / 기재형식 : X(5)");
  3993. if (rowstatus == 2)
  3994. {
  3995. }
  3996. else
  3997. {
  3998. ds_list3_clsp.updatecontrol = false;
  3999. ds_list3_clsp.setRowType(row, 'u');
  4000. ds_list3_clsp.updatecontrol = true;
  4001. }
  4002. }
  4003. else
  4004. {
  4005. if (rowstatus == 2)
  4006. {
  4007. ds_list3_clsp.setColumn(row, "spclcd", "");
  4008. ds_list3_clsp.setColumn(row, "spclspec", "");
  4009. }
  4010. else
  4011. {
  4012. ds_list3_clsp.updatecontrol = false;
  4013. ds_list3_clsp.setRowType(row, "d");
  4014. ds_list3_clsp.updatecontrol = true;
  4015. }
  4016. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 확인코드 내역이 없습니다.");
  4017. }
  4018. // 특정내역 줄번호/특정코드에 따라 sorting 작업
  4019. lf_fSortSpclNo();
  4020. //}
  4021. }
  4022. /****************************************************************************************
  4023. * Argument : function
  4024. * Description : 특정내역 명세서단위 특정내역을 수정/입력
  4025. ****************************************************************************************/
  4026. function lf_fSetDocRefLnSpclSpec()
  4027. {
  4028. ds_rslt_sppiz00500.clearData();
  4029. ds_cond_sppiz00500.clearData();
  4030. ds_cond_sppiz00500_list.clearData();
  4031. var row = ds_list3_clsp.rowposition;
  4032. var clodseqno = ds_list3_clsp.getColumn(row, "clodseqno");
  4033. var edilnno = ds_list3_clsp.getColumn(row, "edilnno");
  4034. var snglcalcscorcd = ds_list3_clsp.getColumn(row, "snglcalcscorcd");
  4035. var unitflag = ds_list3_clsp.getColumn(row, "unitflag");
  4036. if (unitflag == "J")
  4037. {
  4038. var rowstatus = ds_list3_clsp.getRowType(row);
  4039. if (rowstatus == 8)
  4040. {
  4041. sysf_messageBox("삭제된 특정내역은 수정할 수", "I004"); ///삭제된 특정내역은 수정할 수 없습니다.
  4042. return;
  4043. }
  4044. }
  4045. var rowcnt = 0;
  4046. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  4047. {
  4048. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  4049. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  4050. if (spcClodseqno == clodseqno && spcClsoyn == "N")
  4051. {
  4052. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  4053. if (!utlf_isNull(spclcd) && spclcd != "JT001" && ds_list3_clsp.getRowType(i)!= 8)
  4054. {
  4055. dsf_makeValue(ds_cond_sppiz00500_list, "flag", "string", "", rowcnt);
  4056. dsf_makeValue(ds_cond_sppiz00500_list, "rownum", "string", i, rowcnt);
  4057. dsf_makeValue(ds_cond_sppiz00500_list, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  4058. dsf_makeValue(ds_cond_sppiz00500_list, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  4059. dsf_makeValue(ds_cond_sppiz00500_list, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  4060. dsf_makeValue(ds_cond_sppiz00500_list, "spclcd", "string", spclcd, rowcnt);
  4061. dsf_makeValue(ds_cond_sppiz00500_list, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  4062. dsf_makeValue(ds_cond_sppiz00500_list, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), rowcnt);
  4063. dsf_makeValue(ds_cond_sppiz00500_list, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  4064. dsf_makeValue(ds_cond_sppiz00500_list, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), rowcnt);
  4065. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclcd", "string", oldspclcd, rowcnt);
  4066. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  4067. dsf_makeValue(ds_cond_sppiz00500_list, "seqno", "string", ds_list3_clsp.getColumn(i, "seqno"), rowcnt);
  4068. rowcnt = rowcnt+1;
  4069. }
  4070. }
  4071. }
  4072. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "", 0);
  4073. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  4074. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", clodseqno, 0);
  4075. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  4076. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", ds_list3_clsp.getColumn(row, "spclcd"), 0);
  4077. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", ds_list3_clsp.getColumn(row, "detldesc"), 0);
  4078. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", ds_list3_clsp.getColumn(row, "spclspec"), 0);
  4079. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", ds_list3_clsp.getColumn(row, "spclformat"), 0);
  4080. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", row, 0);
  4081. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", ds_list3_clsp.getColumn(row, "cdnm"), 0);
  4082. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", unitflag, 0);
  4083. dsf_makeValue(ds_cond_sppiz00500, "seqno", "string", ds_list3_clsp.getColumn(row, "seqno"), 0);
  4084. var objArg = new Object();
  4085. objArg.arg_ds_hidden_clsp = ds_cond_sppiz00500;
  4086. objArg.arg_ds_hidden_clsp_list = ds_cond_sppiz00500_list;
  4087. var rtn = frmf_modal("SPPIZ00500", "SPPIZ00500", objArg, "", "", "", "", "", "", "", "", "", "M");
  4088. var rsltcnt = ds_rslt_sppiz00500.rowcount;
  4089. if (rsltcnt > 0)
  4090. {
  4091. for (var i = 0; i < rsltcnt; i++)
  4092. {
  4093. var flag = ds_rslt_sppiz00500.getColumn(i, "flag");
  4094. var rownum = ds_rslt_sppiz00500.getColumn(i, "rownum");
  4095. var newspclcd = ds_rslt_sppiz00500.getColumn(i, "spclcd");
  4096. var newcdnm = ds_rslt_sppiz00500.getColumn(i, "cdnm");
  4097. var newspclspec = ds_rslt_sppiz00500.getColumn(i, "spclspec");
  4098. var newspclformat = ds_rslt_sppiz00500.getColumn(i, "spclformat");
  4099. var newdetldesc = ds_rslt_sppiz00500.getColumn(i, "detldesc");
  4100. if (flag == "I")
  4101. {
  4102. var clsprow = ds_list3_clsp.addRow();
  4103. if( newspclcd == "CT001")
  4104. {
  4105. ds_list3_clsp.setColumn(clsprow, "unitflag", "C");
  4106. }
  4107. else if( newspclcd == "CT002")
  4108. {
  4109. ds_list3_clsp.setColumn(clsprow, "unitflag", "C");
  4110. var snglcalcscorcdcnt = ds_list7_clop.rowcount;
  4111. var clopdd = ds_list7_clop.getColumn(0, "clopdd"); //model.getValue("/root/main/list7/clop[1]/clopdd");
  4112. var clopno = ds_list7_clop.getColumn(0, "clopno"); //model.getValue("/root/main/list7/clop[1]/clopno");
  4113. if (snglcalcscorcdcnt > 0)
  4114. {
  4115. ds_list3_clsp.setColumn(clsprow, "mpsno", clopdd + "" + clopno);
  4116. }
  4117. }
  4118. else
  4119. {
  4120. ds_list3_clsp.setColumn(clsprow, "unitflag", unitflag);
  4121. }
  4122. ds_list3_clsp.setColumn(clsprow, "clodseqno", clodseqno);
  4123. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  4124. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  4125. ds_list3_clsp.setColumn(clsprow, "spclcd", newspclcd);
  4126. ds_list3_clsp.setColumn(clsprow, "cdnm", newcdnm);
  4127. ds_list3_clsp.setColumn(clsprow, "spclspec", newspclspec);
  4128. ds_list3_clsp.setColumn(clsprow, "spclformat", newspclformat);
  4129. ds_list3_clsp.setColumn(clsprow, "detldesc", newdetldesc);
  4130. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  4131. ds_list3_clsp.setColumn(clsprow, "oldspclcd", "");
  4132. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  4133. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  4134. }
  4135. else if (flag == "U")
  4136. {
  4137. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd", snglcalcscorcd);
  4138. ds_list3_clsp.setColumn(rownum, "spclcd", newspclcd);
  4139. ds_list3_clsp.setColumn(rownum, "cdnm", newcdnm);
  4140. ds_list3_clsp.setColumn(rownum, "spclspec", newspclspec);
  4141. ds_list3_clsp.setColumn(rownum, "spclformat", newspclformat);
  4142. ds_list3_clsp.setColumn(rownum, "detldesc", newdetldesc);
  4143. var oldspclcd = ds_rslt_sppiz00500.getColumn(i, "oldspclcd");
  4144. var oldspclspec = ds_rslt_sppiz00500.getColumn(i, "oldspclspec");
  4145. var rowstatus = ds_list3_clsp.getRowType(rownum);
  4146. if (rowstatus == 2)
  4147. {
  4148. }
  4149. else
  4150. {
  4151. var arrRow = new Array();
  4152. arrRow[0] = rownum;
  4153. grdf_setStatus(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, "U", arrRow);
  4154. }
  4155. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  4156. }
  4157. else if (flag == "D" && !utlf_isNull(rownum))
  4158. {
  4159. var rowstatus = ds_list3_clsp.getRowType(rownum);
  4160. if (rowstatus == 2)
  4161. {
  4162. ds_list3_clsp.deleteRow(rownum);
  4163. }
  4164. else
  4165. {
  4166. ds_list3_clsp.setColumn(rownum, "rowstat","D");
  4167. ds_list3_clsp.updatecontrol = false;
  4168. ds_list3_clsp.setRowType(rownum, 'd');
  4169. ds_list3_clsp.updatecontrol = true;
  4170. lf_fSetSpclSpecJX999();
  4171. ds_list3_clsp.deleteRow(rownum);
  4172. }
  4173. ds_list3_clsp.rowposition = rownum;
  4174. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  4175. }
  4176. }
  4177. if (unitflag == "M")
  4178. {
  4179. lf_fCheckSpclSpecData();
  4180. if (flag == "I" || flag == "U")
  4181. {
  4182. if (newspclcd == "MT018" && !utlf_isNull(newspclspec))
  4183. {
  4184. ds_main_item1_clbs.setColumn(0, "ownbflag", newspclspec);
  4185. }
  4186. }
  4187. }
  4188. lf_fSortSpclNo();
  4189. lf_fSaveClspList();
  4190. }
  4191. }
  4192. /****************************************************************************************
  4193. * Argument : function
  4194. * Description : 특정내역 줄단위 특정내역을 수정/입력한다
  4195. ****************************************************************************************/
  4196. function lf_fSetLnUnitSpclSpec()
  4197. {
  4198. ds_cond_sppiz00500.clearData();
  4199. ds_rslt_sppiz00500.clearData();
  4200. ds_list_sppiz00500.clearData();
  4201. ds_cond_sppiz00500.addRow();
  4202. var row = ds_list2_clod.rowposition;
  4203. // 처방 Grid에서 줄번호가 부여된 경우
  4204. var seqno = ds_list2_clod.getColumn(row, "seqno");
  4205. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  4206. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  4207. if (seqno != "0")
  4208. {
  4209. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(row, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  4210. if (utlf_isNull(lnunitspclspecyn))
  4211. {
  4212. ds_cond_sppiz00500.setColumn(0, "flag" , "I");
  4213. ds_cond_sppiz00500.setColumn(0, "snglcalcscorcd" , snglcalcscorcd);
  4214. ds_cond_sppiz00500.setColumn(0, "edilnno" , edilnno);
  4215. ds_cond_sppiz00500.setColumn(0, "clodseqno" , seqno);
  4216. ds_cond_sppiz00500.setColumn(0, "spclcd" , "JX999");
  4217. ds_cond_sppiz00500.setColumn(0, "detldesc" , "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  4218. ds_cond_sppiz00500.setColumn(0, "spclspec" , "");
  4219. ds_cond_sppiz00500.setColumn(0, "spclformat" , "X(700)");
  4220. ds_cond_sppiz00500.setColumn(0, "rownum" , "");
  4221. ds_cond_sppiz00500.setColumn(0, "cdnm" , "기타내역");
  4222. ds_cond_sppiz00500.setColumn(0, "unitflag" , "J");
  4223. }
  4224. else
  4225. {
  4226. //기존에 입력된 줄단위 특정내역이 있는 경우
  4227. var rowcnt = 1;
  4228. var setrow = 0;
  4229. for ( var i = 0; i < ds_list3_clsp.rowcount; i++)
  4230. {
  4231. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  4232. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn"); //원외특정여부
  4233. if ( spcClodseqno == seqno && spcClsoyn == "N" )
  4234. {
  4235. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  4236. if (!utlf_isNull(spclcd) && spclcd != "JT001" && ds_list3_clsp.getRowType(i) != 8)
  4237. {
  4238. // 확인코드가 아닌 경우
  4239. rowcnt = ds_list_sppiz00500.addRow();
  4240. ds_list_sppiz00500.setColumn(rowcnt, "flag" , "");
  4241. ds_list_sppiz00500.setColumn(rowcnt, "rownum" , i);
  4242. ds_list_sppiz00500.setColumn(rowcnt, "snglcalcscorcd", ds_list3_clsp.getColumn(i, "snglcalcscorcd"));
  4243. ds_list_sppiz00500.setColumn(rowcnt, "clodseqno" , ds_list3_clsp.getColumn(i, "clodseqno"));
  4244. ds_list_sppiz00500.setColumn(rowcnt, "edilnno" , ds_list3_clsp.getColumn(i, "edilnno"));
  4245. ds_list_sppiz00500.setColumn(rowcnt, "spclcd" , spclcd);
  4246. ds_list_sppiz00500.setColumn(rowcnt, "spclspec" , ds_list3_clsp.getColumn(i, "spclspec"));
  4247. ds_list_sppiz00500.setColumn(rowcnt, "spclformat" , ds_list3_clsp.getColumn(i, "spclformat"));
  4248. ds_list_sppiz00500.setColumn(rowcnt, "cdnm" , ds_list3_clsp.getColumn(i, "cdnm"));
  4249. ds_list_sppiz00500.setColumn(rowcnt, "detldesc" , ds_list3_clsp.getColumn(i, "detldesc"));
  4250. ds_list_sppiz00500.setColumn(rowcnt, "oldspclcd" , spclcd);
  4251. ds_list_sppiz00500.setColumn(rowcnt, "oldspclspec" , ds_list3_clsp.getColumn(i, "spclspec"));
  4252. // 특정내역 상세 화면에 보여줄 특정내역 선택
  4253. if ( spclcd == "JX999")
  4254. {
  4255. setrow = i; // 줄단위의 경우 가장 마지막 row로 설정한다.
  4256. }
  4257. rowcnt = rowcnt + 1;
  4258. }
  4259. }
  4260. }
  4261. if (setrow > 0)
  4262. {
  4263. ds_cond_sppiz00500.setColumn(0, "flag" , "");
  4264. ds_cond_sppiz00500.setColumn(0, "snglcalcscorcd" , snglcalcscorcd);
  4265. ds_cond_sppiz00500.setColumn(0, "clodseqno" , seqno);
  4266. ds_cond_sppiz00500.setColumn(0, "edilnno" , edilnno);
  4267. ds_cond_sppiz00500.setColumn(0, "spclcd" , ds_list3_clsp.getColumn(setrow, "spclcd"));
  4268. ds_cond_sppiz00500.setColumn(0, "detldesc" , ds_list3_clsp.getColumn(setrow, "detldesc"));
  4269. ds_cond_sppiz00500.setColumn(0, "spclspec" , ds_list3_clsp.getColumn(setrow, "spclspec"));
  4270. ds_cond_sppiz00500.setColumn(0, "spclformat" , ds_list3_clsp.getColumn(setrow, "spclformat"));
  4271. ds_cond_sppiz00500.setColumn(0, "rownum" , setrow);
  4272. ds_cond_sppiz00500.setColumn(0, "cdnm" , ds_list3_clsp.getColumn(setrow, "cdnm"));
  4273. ds_cond_sppiz00500.setColumn(0, "unitflag" , "J");
  4274. }
  4275. else
  4276. {
  4277. // 기존에 입력된 JX999가 없는 경우
  4278. ds_cond_sppiz00500.setColumn(0, "flag" , "I");
  4279. ds_cond_sppiz00500.setColumn(0, "snglcalcscorcd" , snglcalcscorcd);
  4280. ds_cond_sppiz00500.setColumn(0, "clodseqno" , seqno);
  4281. ds_cond_sppiz00500.setColumn(0, "edilnno" , edilnno);
  4282. ds_cond_sppiz00500.setColumn(0, "spclcd" , "JX999");
  4283. ds_cond_sppiz00500.setColumn(0, "detldesc" , "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  4284. ds_cond_sppiz00500.setColumn(0, "spclspec" , "");
  4285. ds_cond_sppiz00500.setColumn(0, "spclformat" , "X(700)");
  4286. ds_cond_sppiz00500.setColumn(0, "rownum" , "");
  4287. ds_cond_sppiz00500.setColumn(0, "cdnm" , "기타내역");
  4288. ds_cond_sppiz00500.setColumn(0, "unitflag" , "J");
  4289. }
  4290. }
  4291. var objArg = new Object();
  4292. objArg.arg_ds_hidden_clsp = ds_cond_sppiz00500;
  4293. objArg.arg_ds_hidden_clsp_list = ds_list_sppiz00500;
  4294. var rtn = frmf_modal("SPPIZ00500", "SPPIZ00500", objArg, "", "", "", "", "", "", "", "", "", "M");
  4295. if (!utlf_isNull(rtn))
  4296. {
  4297. ds_rslt_sppiz00500.copyData(rtn);
  4298. }
  4299. var rsltcnt = ds_rslt_sppiz00500.rowcount;
  4300. // 처리 건수
  4301. if (rsltcnt > 0)
  4302. {
  4303. for ( var i = rsltcnt-1; i >= 0; i--)
  4304. {
  4305. var flag = ds_rslt_sppiz00500.getColumn(i, "flag");
  4306. var rownum = ds_rslt_sppiz00500.getColumn(i, "rownum");
  4307. var newspclcd = ds_rslt_sppiz00500.getColumn(i, "spclcd");
  4308. var newcdnm = ds_rslt_sppiz00500.getColumn(i, "cdnm");
  4309. var newspclspec = ds_rslt_sppiz00500.getColumn(i, "spclspec");
  4310. var newspclformat = ds_rslt_sppiz00500.getColumn(i, "spclformat");
  4311. var newdetldesc = ds_rslt_sppiz00500.getColumn(i, "detldesc");
  4312. // 특정코드 추가인 경우
  4313. if (flag == "I")
  4314. {
  4315. var clsprow = ds_list3_clsp.addRow();
  4316. ds_list3_clsp.setColumn(clsprow, "unitflag" , "J");
  4317. ds_list3_clsp.setColumn(clsprow, "clodseqno" , seqno);
  4318. ds_list3_clsp.setColumn(clsprow, "edilnno" , edilnno);
  4319. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  4320. ds_list3_clsp.setColumn(clsprow, "spclcd" , newspclcd);
  4321. ds_list3_clsp.setColumn(clsprow, "cdnm" , newcdnm);
  4322. ds_list3_clsp.setColumn(clsprow, "spclspec" , newspclspec);
  4323. ds_list3_clsp.setColumn(clsprow, "spclformat" , newspclformat);
  4324. ds_list3_clsp.setColumn(clsprow, "detldesc" , newdetldesc);
  4325. ds_list3_clsp.setColumn(clsprow, "oldedilnno" , edilnno);
  4326. ds_list3_clsp.setColumn(clsprow, "oldspclcd" , "");
  4327. ds_list3_clsp.setColumn(clsprow, "clsoyn" , "N");
  4328. ds_hidden_list3.setColumn(0, "msgspclformat" , "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  4329. }
  4330. else if (flag == "U")
  4331. {
  4332. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd", snglcalcscorcd);
  4333. ds_list3_clsp.setColumn(rownum, "spclcd" , newspclcd);
  4334. ds_list3_clsp.setColumn(rownum, "cdnm" , newcdnm);
  4335. ds_list3_clsp.setColumn(rownum, "spclspec" , newspclspec);
  4336. ds_list3_clsp.setColumn(rownum, "spclformat" , newspclformat);
  4337. ds_list3_clsp.setColumn(rownum, "detldesc" , newdetldesc);
  4338. // 특정코드, 특정내역이 변경되었거나 삭제된 특정코드를 조회하여 "확인"을 선택한 경우
  4339. var oldspclcd = ds_rslt_sppiz00500.getColumn(i, "oldspclcd");
  4340. var oldspclspec = ds_rslt_sppiz00500.getColumn(i, "oldspclspec");
  4341. var rowstatus = ds_list3_clsp.getRowType(rownum);
  4342. if (rowstatus == 2)
  4343. {
  4344. }
  4345. else
  4346. {
  4347. ds_list3_clsp.updatecontrol = false;
  4348. ds_list3_clsp.setRowType(rownum, "u");
  4349. ds_list3_clsp.updatecontrol = true;
  4350. }
  4351. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  4352. // 특정코드 삭제인 경우
  4353. }
  4354. else if (flag == "D" && !utlf_isNull(rownum))
  4355. {
  4356. // 특정내역 Grid에서 삭제
  4357. var rowstatus = ds_list3_clsp.getRowType(rownum);
  4358. if (rowstatus == 2)
  4359. {
  4360. ds_list3_clsp.deleteRow(rownum);
  4361. }
  4362. else
  4363. {
  4364. ds_list3_clsp.setColumn(rownum, "rowstat","D");
  4365. ds_list3_clsp.updatecontrol = false;
  4366. ds_list3_clsp.setRowType(rownum, 'd');
  4367. ds_list3_clsp.updatecontrol = true;
  4368. lf_fSetSpclSpecJX999()
  4369. ds_list3_clsp.deleteRow(rownum);
  4370. }
  4371. ds_list3_clsp.clearSelect();
  4372. ds_list3_clsp.rowposition = rownum;
  4373. ds_list3_clsp.selectRow(rownum);
  4374. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  4375. } // 특정 코드 상태 따른 if end
  4376. } // for end
  4377. } // 처리 건수 if end
  4378. }
  4379. else
  4380. {
  4381. sysf_messageBox("처방번호가 부여되지 않았으며 해당 줄단위 특정내역이", "I004");
  4382. }
  4383. }
  4384. /****************************************************************************************
  4385. * Argument : button
  4386. * Description : 특정내역 반송사유 버튼 이벤트
  4387. ****************************************************************************************/
  4388. function btn_preresncd_onclick(obj:Button, e:ClickEventInfo)
  4389. {
  4390. lf_setAlramMessage( "반송_접수번호 : " + ds_main_item1_clbs.getColumn(0, "preacptno") + "\n"
  4391. + "반송_명일련 : " + ds_main_item1_clbs.getColumn(0, "predocuno") + "\n"
  4392. + "반송_접수일자 : " + ds_main_item1_clbs.getColumn(0, "preacptdd") + "\n"
  4393. + "반송_사유 : " + ds_main_item1_clbs.getColumn(0, "preresncdnm") + "\n\n"
  4394. + "수신비고 : " + ds_main_item1_clbs.getColumn(0, "preresntext") + " 입니다.");
  4395. }
  4396. /****************************************************************************************
  4397. * Argument : button
  4398. * Description : 상단 버튼 마우스 이벤트
  4399. ****************************************************************************************/
  4400. function btn_onmouseenter(obj:Button, e:MouseEventInfo)
  4401. {
  4402. if(grp_dropdownmenu.visible == true)
  4403. {
  4404. obj.click();
  4405. }
  4406. }
  4407. /****************************************************************************************
  4408. * Argument : button
  4409. * Description : 삭감처방 버튼 이벤트
  4410. ****************************************************************************************/
  4411. function grp_biz_button3_onclick(obj:Button, e:ClickEventInfo)
  4412. {
  4413. if (!utlf_isNull(ds_main_item1_clbs.getColumn(0, "pid")))
  4414. {
  4415. ds_cond_smpis00600.setColumn(0, "openflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  4416. ds_cond_smpis00600.setColumn(0, "patunitsrch" , ds_main_item1_clbs.getColumn(0, "pid"));
  4417. ds_cond_smpis00600.setColumn(0, "clamym" , "");
  4418. ds_cond_smpis00600.setColumn(0, "clamymfrom" , ds_main_item1_clbs.getColumn(0, "clamym"));
  4419. ds_cond_smpis00600.setColumn(0, "clamymto" , ds_main_item1_clbs.getColumn(0, "clamym"));
  4420. ds_cond_smpis00600.setColumn(0, "clamflag" , ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  4421. ds_cond_smpis00600.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  4422. ds_cond_smpis00600.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  4423. ds_cond_smpis00600.setColumn(0, "cutonly" , "false"); // 삭감처방만조회:true, 청구처방조회:false
  4424. ds_cond_smpis00600.setColumn(0, "code" , "");//ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd"));
  4425. ds_cond_smpis00600.setColumn(0, "codecond" , "N");
  4426. ds_cond_smpis00600.setColumn(0, "trustinstcd" , "");
  4427. ds_cond_smpis00600.setColumn(0, "clamdgfrom" , "");
  4428. ds_cond_smpis00600.setColumn(0, "clamdgto" , "");
  4429. ds_cond_smpis00600.setColumn(0, "orddeptcd" , "-");
  4430. ds_cond_smpis00600.setColumn(0, "orddrid" , "-");
  4431. }
  4432. frmf_open("SMPIS00600", "SMPIS00600", {args_ds_send:ds_cond_smpis00600}, "", "", "", "", "", "", "", "", "", "M");
  4433. }
  4434. /****************************************************************************************
  4435. * Argument : button
  4436. * Description : 특정내역 MT004 버튼 이벤트
  4437. ****************************************************************************************/
  4438. function grp_biz_btn_mt0004_onclick(obj:Button, e:ClickEventInfo)
  4439. {
  4440. lf_fSetSpclMT004(); // 특정내역 중 MT004 내역을 설정한다.
  4441. }
  4442. /****************************************************************************************
  4443. * Argument : function
  4444. * Description : 특정내역 중 MT004 내역을 설정한다.
  4445. ****************************************************************************************/
  4446. function lf_fSetSpclMT004()
  4447. {
  4448. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  4449. if (clamkey)
  4450. {
  4451. if (grp_biz.btn_mt0004.class == "btn5")
  4452. {
  4453. // 특정내역에 'MT004' 코드가 있는 경우 'MT004' 코드를 삭제한다.
  4454. for ( var i = 0; i < ds_list3_clsp.rowcount; i++ )
  4455. {
  4456. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  4457. var gridrowstatus = ds_list3_clsp.getRowType(i);
  4458. if (spclcd == "MT004" && gridrowstatus != 8)
  4459. {
  4460. if ( gridrowstatus == 2 )
  4461. {
  4462. ds_list3_clsp.setColumn(i, "spclcd", "");
  4463. ds_list3_clsp.setColumn(i, "cdnm", "");
  4464. ds_list3_clsp.setColumn(i, "spclspec", "");
  4465. ds_list3_clsp.setColumn(i, "spclformat", "");
  4466. ds_list3_clsp.setColumn(i, "detldesc", "");
  4467. }
  4468. else
  4469. {
  4470. }
  4471. }
  4472. }
  4473. grp_biz.btn_mt0004.class = "btn2";
  4474. grp_biz.btn_mt0004.style.color = "#057777ff";
  4475. }
  4476. else
  4477. {
  4478. // 특정내역에 'MT004' 코드가 없는 경우 'MT004' 코드를 추가한다.
  4479. // 특정내역 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 추가"
  4480. var clsprow = lf_fSpclGridInsertRow();
  4481. ds_list3_clsp.setColumn(clsprow, "spclcd", "MT004");
  4482. ds_list3_clsp.setColumn(clsprow, "cdnm", "소명자료 구분");
  4483. ds_list3_clsp.setColumn(clsprow, "spclspec", "Y");
  4484. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(1)");
  4485. ds_list3_clsp.setColumn(clsprow, "detldesc", "소명자료를 첨부하는 경우 'Y'를 기재");
  4486. grp_biz.btn_mt0004.class = "btn5";
  4487. grp_biz.btn_mt0004.style.color = "#cc3333"; // cc3333=붉은색
  4488. }
  4489. lf_fSortSpclNo();
  4490. }
  4491. }
  4492. /****************************************************************************************
  4493. * Argument : button
  4494. * Description : 특정내역 소명자료 버튼 이벤트
  4495. ****************************************************************************************/
  4496. function grp_biz_btn_attData_onclick(obj:Button, e:ClickEventInfo)
  4497. {
  4498. // 특정내역 중 MT015, MT016 내역을 조회하여 "소명자료" Btn (첨부물 자료관리) Popup 화면에 표시한다.
  4499. lf_fGetAttachedDataList();
  4500. //lf_fSetSpclMT004();
  4501. }
  4502. /****************************************************************************************
  4503. * Argument : function
  4504. * Description : 특정내역 중 MT015, MT016 내역을 조회하여 "소명자료" Btn (첨부물 자료관리) Popup 화면에 표시한다.
  4505. ****************************************************************************************/
  4506. function lf_fGetAttachedDataList()
  4507. {
  4508. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  4509. if (!utlf_isNull(clamkey))
  4510. {
  4511. ds_cond_sppiz00200.clearData();
  4512. for(var i=0; i < ds_list3_clsp.rowcount; i++)
  4513. {
  4514. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  4515. var gridrowstatus = ds_list3_clsp.getRowType(i);
  4516. if (spclcd == "MT015" || spclcd == "MT016")
  4517. {
  4518. var index = ds_cond_sppiz00200.addRow();
  4519. ds_cond_sppiz00200.setColumn(index, "spclcd" , ds_list3_clsp.getColumn(i, "spclcd"));
  4520. ds_cond_sppiz00200.setColumn(index, "seqno" , ds_list3_clsp.getColumn(i, "seqno"));
  4521. ds_cond_sppiz00200.setColumn(index, "spclspec", ds_list3_clsp.getColumn(i, "spclspec"));
  4522. ds_cond_sppiz00200.setColumn(index, "rowstat" , gridrowstatus);
  4523. }
  4524. }
  4525. var objArg = new Object();
  4526. objArg.sOpenflag = "";
  4527. ds_rslt_sppiz00200.clearData();
  4528. var rtn = frmf_modal("SPPIZ00200", "SPPIZ00200", objArg, "", "", "", "", "", "", "", "", "", "M");
  4529. if (!utlf_isNull(rtn))
  4530. {
  4531. ds_rslt_sppiz00200.copyData(rtn);
  4532. }
  4533. lf_fDisplayAttachedDataList();
  4534. }
  4535. }
  4536. /****************************************************************************************
  4537. * Argument : function
  4538. * Description : "소명자료" Btn (첨부물 자료관리) Popup 화면에서 특정내역 중 MT015, MT016 정보가 입력된 환자인지를 확인한다.
  4539. ****************************************************************************************/
  4540. function lf_fDisplayAttachedDataList()
  4541. {
  4542. var isAttachedDataList = false;
  4543. var cSrcNode = ds_rslt_sppiz00200.rowcount;
  4544. if (cSrcNode < 0)
  4545. {
  4546. // 특정내역이 없는 경우임
  4547. return;
  4548. }
  4549. var cSrcChildNodeList = ds_rslt_sppiz00200.rowcount;
  4550. var chkstr = "";
  4551. for ( var i = 0; i < cSrcChildNodeList; i++)
  4552. {
  4553. var spclcd = ds_rslt_sppiz00200.getColumn(i, "spclcd");
  4554. if (spclcd == "MT015" || spclcd == "MT016")
  4555. {
  4556. var rowstat = ds_rslt_sppiz00200.getColumn(i, "rowstat");
  4557. if (rowstat != "D")
  4558. {
  4559. var spclspec = ds_rslt_sppiz00200.getColumn(i, "spclspec");
  4560. if (!utlf_isNull(spclspec))
  4561. {
  4562. isAttachedDataList = true;
  4563. }
  4564. // 특정내역 Grid 에서 해당 내용을 삽입 또는 수정한다.
  4565. if (rowstat == "I")
  4566. { // 삽입
  4567. lf_fSpclGridInsertRow();
  4568. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "spclcd" , spclcd);
  4569. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "spclspec", spclspec);
  4570. if (spclcd == "MT015")
  4571. {
  4572. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "cdnm" , "제출자료 목록표");
  4573. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "spclformat", "X(2)");
  4574. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "detldesc" , "제출자료코드/제출자료코드/... 형태로 입력");
  4575. }
  4576. else
  4577. {
  4578. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "cdnm" , "제출자료 목록표(기타)");
  4579. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "spclformat", "X(200)");
  4580. ds_list3_clsp.setColumn(ds_list3_clsp.rowposition, "detldesc" , "영문(200자), 한글(100자)");
  4581. }
  4582. }
  4583. else if (rowstat == "U")
  4584. {// 수정
  4585. var fRow = ds_list3_clsp.findRow("spclcd", spclcd);
  4586. var gridrowstatus = ds_list3_clsp.getRowType(fRow);
  4587. if (fRow > -1)
  4588. {
  4589. ds_list3_clsp.setColumn(fRow, "spclspec", spclspec);
  4590. if (gridrowstatus != 2)
  4591. {
  4592. ds_list3_clsp.updatecontrol = false;
  4593. ds_list3_clsp.setRowType(fRow, "u");
  4594. ds_list3_clsp.updatecontrol = true;
  4595. }
  4596. }
  4597. }
  4598. }
  4599. else
  4600. { // 삭제
  4601. // 특정내역 Grid 에서 해당 내용을 삭제한다.
  4602. var fRow = ds_list3_clsp.findRow("spclcd", spclcd);
  4603. var gridspclcd = ds_list3_clsp.getColumn(fRow, "spclcd");
  4604. var gridspclspec = ds_list3_clsp.getColumn(fRow, "spclspec");
  4605. var gridrowstatus = ds_list3_clsp.getRowType(fRow);
  4606. if (fRow > -1)
  4607. {
  4608. if (gridrowstatus == 2)
  4609. {
  4610. ds_list3_clsp.setColumn(fRow, "spclcd" , "");
  4611. ds_list3_clsp.setColumn(fRow, "spclspec", "");
  4612. }
  4613. else
  4614. {
  4615. ds_list3_clsp.updatecontrol = false;
  4616. ds_list3_clsp.setRowType(fRow, "d");
  4617. ds_list3_clsp.updatecontrol = true;
  4618. }
  4619. }
  4620. }
  4621. }
  4622. }
  4623. // 특정내역 줄번호/특정코드에 따라 sorting 작업
  4624. lf_fSortSpclNo();
  4625. lf_fCheckSpclSpecData()
  4626. }
  4627. /****************************************************************************************
  4628. * Argument : function
  4629. * Description : 특정내역 탭 버튼 클릭 시 이벤트 : 특정내역
  4630. ****************************************************************************************/
  4631. var sClsphist;
  4632. // function grp_biz_btn_spclspec_onclick(obj:Button, e:ClickEventInfo)
  4633. // {
  4634. // grp_biz.swt_spclmemo.position.bottom = parseInt(grp_biz.grp_sea01.position.top) - 10 ;
  4635. //
  4636. // var spclspecClass = grp_biz.btn_spclspec.class;
  4637. //
  4638. // if ( spclspecClass == "btn_tab" )
  4639. // {
  4640. // grp_biz.btn_spclspec.class = "btn_tab_S";
  4641. // grp_biz.btn_judgrmemo.class = "btn_tab";
  4642. // grp_biz.btn_ediclammemo.class = "btn_tab";
  4643. // grp_biz.swt_spclmemo.tabindex = 0;
  4644. // }
  4645. // }
  4646. /****************************************************************************************
  4647. * Argument : function
  4648. * Description : 특정내역 탭 버튼 클릭 시 이벤트 : edi메모
  4649. ****************************************************************************************/
  4650. function grp_biz_btn_ediclammemo_onclick(obj:Button, e:ClickEventInfo)
  4651. {
  4652. grp_biz.swt_spclmemo.position.bottom = parseInt(grp_biz.grp_sea01.position.top) - 10 ;
  4653. var ediclammemoClass = grp_biz.btn_ediclammemo.class;
  4654. if ( ediclammemoClass == "btn_tab" )
  4655. {
  4656. grp_biz.btn_spclspec.class = "btn_tab";
  4657. grp_biz.btn_judgrmemo.class = "btn_tab";
  4658. grp_biz.btn_ediclammemo.class = "btn_tab_S";
  4659. grp_biz.swt_spclmemo.tabindex = 1;
  4660. }
  4661. }
  4662. /****************************************************************************************
  4663. * Argument : button
  4664. * Description : 특정내역 메모이력 버튼 이벤트
  4665. ****************************************************************************************/
  4666. function grp_biz_btn_memohist_onclick(obj:Button, e:ClickEventInfo)
  4667. {
  4668. // 특정 환자에 대해 그동안 작성된 심사자메모, 청구메모 내역을 조회한다.
  4669. fGetMemoHistList();
  4670. }
  4671. /****************************************************************************************
  4672. * Argument : button
  4673. * Description : 특정 환자에 대해 그동안 작성된 심사자메모, 청구메모 내역을 조회한다.
  4674. ****************************************************************************************/
  4675. function fGetMemoHistList(flag)
  4676. {
  4677. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  4678. if (clamym)
  4679. {
  4680. var sppiz00300 = new Object();
  4681. sppiz00300.sClamym = clamym;
  4682. sppiz00300.sClamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  4683. sppiz00300.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  4684. sppiz00300.sPidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  4685. sppiz00300.sOrddeptcd = ds_main_item1_clbs.getColumn(0, "orddeptcd");
  4686. sppiz00300.sIoflag = lgv_ioflag;
  4687. sppiz00300.sRefterm = "-";
  4688. sppiz00300.sAnofildinclyn = "";
  4689. sppiz00300.sFromdd = ds_main_item1_clbs.getColumn(0, "indd");
  4690. sppiz00300.sTodd = ds_main_item1_clbs.getColumn(0, "dschdd");
  4691. sppiz00300.sOrdfildcd = ds_main_item1_clbs.getColumn(0, "ordfildcd");
  4692. sppiz00300.sFlag = "Y";
  4693. // SPPIZ00300_메모이력조회.xrw
  4694. if (utlf_isNull(flag)) {
  4695. var rtn = frmf_open("SPPIZ00300","SPPIZ00300",sppiz00300,"","","","","","","","","","M");
  4696. }
  4697. var SelectMemo = ds_rslt_sppiz00300.rowcount;
  4698. if (SelectMemo > 0 ) {
  4699. var choimemo = utlf_trim(ds_rslt_sppiz00300.getColumn(0, "choimemo"));
  4700. var choiedicd = utlf_transNullToEmpty(ds_rslt_sppiz00300.getColumn(0, "edicd"));
  4701. if (!utlf_isNull(choimemo)) {
  4702. ds_rslt_sppiz00300.setColumn(0, "choimemo", choimemo);
  4703. var destRef = utlf_transNullToEmpty(ds_rslt_sppiz00300.getColumn(0, "destRef"));
  4704. if (destRef == "judgmemo") {
  4705. var judgmemo = utlf_transNullToEmpty(ds_main_item1_memo.getColumn(0, "judgmemo"));
  4706. for (var i=0; i < SelectMemo; i++){
  4707. choimemo = utlf_transNullToEmpty(ds_rslt_sppiz00300.getColumn(i, "choimemo"));
  4708. judgmemo = utlf_transNullToEmpty(ds_main_item1_memo.getColumn(0, "judgmemo"));
  4709. ds_main_item1_memo.setColumn(0,"judgmemo", judgmemo + (utlf_isNull(judgmemo) ? "" : " \n") + choimemo)
  4710. }
  4711. grp_biz.swt_spclmemo.tabindex = 1;
  4712. } else if (destRef == "edimemo") {
  4713. var judgmemo = ds_main_item1_memo.getColumn(0, "edimemo");
  4714. for (var i=0; i < SelectMemo; i++){
  4715. choimemo = utlf_transNullToEmpty(ds_rslt_sppiz00300.getColumn(i, "choimemo"));
  4716. judgmemo = utlf_transNullToEmpty(ds_main_item1_memo.getColumn(0, "edimemo"));
  4717. ds_main_item1_memo.setColumn(0,"edimemo", judgmemo + (utlf_isNull(judgmemo) ? "" : " \n") + choimemo)
  4718. }
  4719. grp_biz.swt_spclmemo.tabindex = 2;
  4720. }
  4721. else if (destRef == "prcpmemo")
  4722. {
  4723. // 동일한 EDI 코드가 있을 경우 * 표시
  4724. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  4725. {
  4726. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  4727. var edicd = ds_list2_clod.getColumn(i, "basecd");
  4728. var seqno = ds_list2_clod.getColumn(i, "seqno");
  4729. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  4730. if (choiedicd == edicd)
  4731. {
  4732. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(i, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  4733. var rowNum = "";
  4734. if (lnunitspclspecyn)
  4735. {
  4736. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  4737. {
  4738. if (ds_list3_clsp.getRowType(j) != 8)
  4739. {
  4740. var clodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  4741. if (clodseqno == seqno)
  4742. {
  4743. if (ds_list3_clsp.getColumn(j, "spclcd") == "JX999")
  4744. {
  4745. rowNum = j;
  4746. j = ds_list3_clsp.rowcount;
  4747. }
  4748. }
  4749. }
  4750. }
  4751. if (rowNum)
  4752. {
  4753. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  4754. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  4755. if (ans == 6)
  4756. {
  4757. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  4758. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  4759. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  4760. if (rowstatus == 2)
  4761. {
  4762. }
  4763. else
  4764. {
  4765. ds_list3_clsp.updatecontrol = false;
  4766. ds_list3_clsp.setRowType(rowNum, "u");
  4767. ds_list3_clsp.updatecontrol = true;
  4768. }
  4769. }
  4770. else if (ans == 7)
  4771. {
  4772. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  4773. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  4774. if (rowstatus == 2)
  4775. {
  4776. }
  4777. else
  4778. {
  4779. ds_list3_clsp.updatecontrol = false;
  4780. ds_list3_clsp.setRowType(rowNum, 'u');
  4781. ds_list3_clsp.updatecontrol = true;
  4782. }
  4783. }
  4784. else if (ans == 2)
  4785. {
  4786. }
  4787. }
  4788. else
  4789. { // 기존에 입력된 JX999가 없는 경우
  4790. // 'JX999' 코드를 추가한다.
  4791. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  4792. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  4793. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  4794. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  4795. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  4796. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  4797. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  4798. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  4799. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  4800. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  4801. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  4802. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  4803. lf_fSetOrderChangeRowStat(i);
  4804. }
  4805. }
  4806. else
  4807. { // 기존에 입력된 줄단위 특정내역이 없는 경우
  4808. // 'JX999' 코드를 추가한다.
  4809. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  4810. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  4811. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  4812. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  4813. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  4814. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  4815. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  4816. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  4817. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  4818. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  4819. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  4820. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  4821. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  4822. } // lnunitspclspecyn == ""
  4823. } // if (choiedicd == clodedicd)
  4824. }
  4825. // 특정내역 줄번호/특정코드에 따라 sorting 작업
  4826. lf_fSortSpclNo();
  4827. //grp_biz_btn_spclspec_onclick();
  4828. } // if (destRef == "prcpmemo")
  4829. }
  4830. }
  4831. ds_rslt_sppiz00300.clearData();
  4832. }
  4833. }
  4834. function lf_fGetMemoHistList()
  4835. {
  4836. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  4837. if (clamym)
  4838. {
  4839. // 조회된 심사대상자가 있고
  4840. ds_rslt_sppiz00300.clearData();
  4841. var sppiz00300 = new Object();
  4842. sppiz00300.sClamym = clamym;
  4843. sppiz00300.sClamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  4844. sppiz00300.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  4845. sppiz00300.sPidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  4846. sppiz00300.sOrddeptcd = ds_main_item1_clbs.getColumn(0, "orddeptcd");
  4847. sppiz00300.sIoflag = lgv_ioflag;
  4848. sppiz00300.sRefterm = "-";
  4849. sppiz00300.sAnofildinclyn = "";
  4850. sppiz00300.sFromdd = ds_main_item1_clbs.getColumn(0, "indd");
  4851. sppiz00300.sTodd = ds_main_item1_clbs.getColumn(0, "dschdd");
  4852. sppiz00300.sOrdfildcd = ds_main_item1_clbs.getColumn(0, "ordfildcd");
  4853. // SPPIZ00300_메모이력조회.xrw
  4854. frmf_modal("SPPIZ00300", "SPPIZ00300", sppiz00300, "", "", "", "", "", "", "", "", "", "M");
  4855. var SelectMemo = ds_rslt_sppiz00300.rowcount;
  4856. if (SelectMemo >= 0 )
  4857. {
  4858. for( i = 0 ; i < ds_rslt_sppiz00300.rowcount; i++)
  4859. {
  4860. var choimemo = utlf_trim(ds_rslt_sppiz00300.getColumn(i, "choimemo"));
  4861. var choiedicd = ds_rslt_sppiz00300.getColumn(i, "edicd");
  4862. var choiedilnno = ds_rslt_sppiz00300.getColumn(i, "edilnno");
  4863. var choispclcd = ds_rslt_sppiz00300.getColumn(i, "spclcd");
  4864. if (choimemo)
  4865. {
  4866. ds_rslt_sppiz00300.setColumn(i, "choimemo", choimemo);
  4867. var destRef = ds_rslt_sppiz00300.getColumn(i, "destRef");
  4868. if (destRef == "judgmemo")
  4869. {
  4870. // 심사메모로 전달
  4871. var judgmemo = ds_main_item1_memo.getColumn(0, "judgmemo");
  4872. var userid = sysf_getUserInfo("usernm");
  4873. var objDate = new Date();
  4874. var fstrgstdt;
  4875. fstrgstdt = objDate.toFormatString("%Y%m%d%H%M%S"); // YYYYMMDD HHMMSS
  4876. if (judgmemo)
  4877. {
  4878. // 기존 심사메모가 공백이 아닌 경우 선택된 메모를 심사화면 메모 뒤에 덧붙인다.
  4879. var insrow = ds_list10_judgmemo.rowcount;
  4880. var iRow = ds_list10_judgmemo.insertRow(insrow++);
  4881. ds_list10_judgmemo.setColumn(iRow, "unitflag" , "M");
  4882. ds_list10_judgmemo.setColumn(iRow, "spclcd" , "MX999");
  4883. ds_list10_judgmemo.setColumn(iRow, "usermemoyn" , "Y");
  4884. ds_list10_judgmemo.setColumn(iRow, "spclspec" , choimemo);
  4885. ds_list10_judgmemo.setColumn(iRow, "userid" , userid);
  4886. ds_list10_judgmemo.setColumn(iRow, "fstrgstdt" , fstrgstdt);
  4887. }
  4888. else
  4889. {
  4890. if (choiedicd)
  4891. {
  4892. // 처방별 메모를 전달하는 경우임
  4893. // 동일한 EDI 코드가 있을 경우만 추가
  4894. for (var j = 0; j < ds_list2_clod.rowcount; j++)
  4895. {
  4896. var clodedicd = ds_list2_clod.getColumn(j, "basecd");
  4897. if (choiedicd == clodedicd)
  4898. {
  4899. var insrow = ds_list10_judgmemo.rowcount;
  4900. var iRow = ds_list10_judgmemo.insertRow(insrow++);
  4901. ds_list10_judgmemo.setColumn(iRow, "unitflag" , "M");
  4902. ds_list10_judgmemo.setColumn(iRow, "spclcd" , "MX999");
  4903. ds_list10_judgmemo.setColumn(iRow, "usermemoyn" , "Y");
  4904. ds_list10_judgmemo.setColumn(iRow, "spclspec" , choimemo);
  4905. ds_list10_judgmemo.setColumn(iRow, "userid" , userid);
  4906. ds_list10_judgmemo.setColumn(iRow, "fstrgstdt" , fstrgstdt);
  4907. j = ds_list2_clod.rowcount;
  4908. }
  4909. }
  4910. }
  4911. else
  4912. {
  4913. var iRow = ds_list10_judgmemo.addRow();
  4914. ds_list10_judgmemo.setColumn(iRow, "unitflag" , "M");
  4915. ds_list10_judgmemo.setColumn(iRow, "spclcd" , "MX999");
  4916. ds_list10_judgmemo.setColumn(iRow, "usermemoyn" , "Y");
  4917. ds_list10_judgmemo.setColumn(iRow, "spclspec" , choimemo);
  4918. ds_list10_judgmemo.setColumn(iRow, "userid" , userid);
  4919. ds_list10_judgmemo.setColumn(iRow, "fstrgstdt" , fstrgstdt);
  4920. }
  4921. }
  4922. //grp_biz_btn_judgrmemo_onclick();
  4923. grp_biz.swt_spclmemo.tabindex = 1;
  4924. }
  4925. else if (destRef == "edimemo")
  4926. {
  4927. // 청구메모로 전달
  4928. var edimemo = utlf_trim(ds_main_item1_memo.getColumn(0, "edimemo"));
  4929. if (edimemo)
  4930. {
  4931. // 기존 청구메모가 공백이 아닌 경우 선택된 메모를 심사화면 메모 뒤에 덧붙인다.
  4932. var insrow = ds_list11_edimemo.rowcount;
  4933. var iRow = ds_list11_edimemo.insertRow(insrow++);
  4934. ds_list11_edimemo.setColumn(iRow, "unitflag", "M");
  4935. ds_list11_edimemo.setColumn(iRow, "spclcd", "MX999");
  4936. ds_list11_edimemo.setColumn(iRow, "usermemoyn", "N");
  4937. ds_list11_edimemo.setColumn(iRow, "spclspec", choimemo);
  4938. }
  4939. else
  4940. {
  4941. if (choiedicd)
  4942. {
  4943. // 처방별 메모를 전달하는 경우임
  4944. // 동일한 EDI 코드가 있을 경우 * 표시
  4945. for (var j = 0; j < ds_list2_clod.rowcount; j++)
  4946. {
  4947. var clodedicd = ds_list2_clod.getColumn(j, "basecd");
  4948. if (choiedicd == clodedicd)
  4949. {
  4950. var insrow = ds_list11_edimemo.rowcount;
  4951. var iRow = ds_list11_edimemo.insertRow(insrow++);
  4952. ds_list11_edimemo.setColumn(iRow, "unitflag", "M");
  4953. ds_list11_edimemo.setColumn(iRow, "spclcd", "MX999");
  4954. ds_list11_edimemo.setColumn(iRow, "usermemoyn", "N");
  4955. ds_list11_edimemo.setColumn(iRow, "spclspec", choimemo);
  4956. j = ds_list2_clod.rowcount;
  4957. }
  4958. }
  4959. }
  4960. else
  4961. {
  4962. var insrow = ds_list11_edimemo.rowcount;
  4963. var iRow = ds_list11_edimemo.insertRow(insrow++);
  4964. ds_list11_edimemo.setColumn(iRow, "unitflag", "M");
  4965. ds_list11_edimemo.setColumn(iRow, "spclcd", "MX999");
  4966. ds_list11_edimemo.setColumn(iRow, "usermemoyn", "N");
  4967. ds_list11_edimemo.setColumn(iRow, "spclspec", choimemo);
  4968. }
  4969. }
  4970. grp_biz_btn_ediclammemo_onclick();
  4971. }
  4972. else if (destRef == "prcpmemo")
  4973. {
  4974. // 동일한 EDI 코드가 있을 경우 * 표시
  4975. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  4976. {
  4977. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  4978. var edicd = ds_list2_clod.getColumn(i, "basecd");
  4979. var seqno = ds_list2_clod.getColumn(i, "seqno");
  4980. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  4981. if (choiedicd == edicd)
  4982. {
  4983. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(i, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  4984. var rowNum = "";
  4985. if (lnunitspclspecyn)
  4986. {
  4987. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  4988. {
  4989. if (ds_list3_clsp.getRowType(j) != 8)
  4990. {
  4991. var clodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  4992. if (clodseqno == seqno)
  4993. {
  4994. if (ds_list3_clsp.getColumn(j, "spclcd") == "JX999")
  4995. {
  4996. rowNum = j;
  4997. j = ds_list3_clsp.rowcount;
  4998. }
  4999. }
  5000. }
  5001. }
  5002. if (rowNum)
  5003. {
  5004. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  5005. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  5006. if (ans == 6)
  5007. {
  5008. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  5009. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  5010. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5011. if (rowstatus == 2)
  5012. {
  5013. }
  5014. else
  5015. {
  5016. ds_list3_clsp.updatecontrol = false;
  5017. ds_list3_clsp.setRowType(rowNum, "u");
  5018. ds_list3_clsp.updatecontrol = true;
  5019. }
  5020. }
  5021. else if (ans == 7)
  5022. {
  5023. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  5024. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5025. if (rowstatus == 2)
  5026. {
  5027. }
  5028. else
  5029. {
  5030. ds_list3_clsp.updatecontrol = false;
  5031. ds_list3_clsp.setRowType(rowNum, 'u');
  5032. ds_list3_clsp.updatecontrol = true;
  5033. }
  5034. }
  5035. else if (ans == 2)
  5036. {
  5037. }
  5038. }
  5039. else
  5040. { // 기존에 입력된 JX999가 없는 경우
  5041. // 'JX999' 코드를 추가한다.
  5042. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5043. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5044. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5045. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5046. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5047. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5048. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5049. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5050. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5051. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5052. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5053. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  5054. lf_fSetOrderChangeRowStat(i);
  5055. }
  5056. }
  5057. else
  5058. { // 기존에 입력된 줄단위 특정내역이 없는 경우
  5059. // 'JX999' 코드를 추가한다.
  5060. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5061. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5062. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5063. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5064. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5065. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5066. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5067. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5068. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5069. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5070. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5071. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  5072. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  5073. } // lnunitspclspecyn == ""
  5074. } // if (choiedicd == clodedicd)
  5075. }
  5076. // 특정내역 줄번호/특정코드에 따라 sorting 작업
  5077. lf_fSortSpclNo();
  5078. //grp_biz_btn_spclspec_onclick();
  5079. } // if (destRef == "prcpmemo")
  5080. else if (destRef == "dispmemo")
  5081. {
  5082. // 처방별 주석로 전달
  5083. // 동일한 group 코드가 있을 경우 * 표시
  5084. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  5085. {
  5086. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  5087. var edicd = ds_list2_clod.getColumn(i, "grupcalcscorcd");
  5088. var seqno = ds_list2_clod.getColumn(i, "seqno");
  5089. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  5090. if (choiedilnno == edilnno)
  5091. {
  5092. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(i, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  5093. var rowNum = "";
  5094. if (lnunitspclspecyn)
  5095. {
  5096. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  5097. {
  5098. if (ds_list3_clsp.getRowType(j) != 8)
  5099. {
  5100. var clodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  5101. if (clodseqno == seqno)
  5102. {
  5103. if (ds_list3_clsp.getColumn(j, "spclcd") == "JX999")
  5104. {
  5105. rowNum = j;
  5106. j = ds_list3_clsp.rowcount;
  5107. }
  5108. }
  5109. }
  5110. }
  5111. if (rowNum)
  5112. {
  5113. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  5114. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  5115. if (ans == 6)
  5116. {
  5117. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  5118. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  5119. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5120. if (rowstatus == 2)
  5121. {
  5122. }
  5123. else
  5124. {
  5125. ds_list3_clsp.updatecontrol = false;
  5126. ds_list3_clsp.setRowType(rowNum, "u");
  5127. ds_list3_clsp.updatecontrol = true;
  5128. }
  5129. }
  5130. else if (ans == 7)
  5131. {
  5132. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  5133. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5134. if (rowstatus == 2)
  5135. {
  5136. }
  5137. else
  5138. {
  5139. ds_list3_clsp.updatecontrol = false;
  5140. ds_list3_clsp.setRowType(rowNum, "u");
  5141. ds_list3_clsp.updatecontrol = true;
  5142. }
  5143. }
  5144. else if (ans == 2)
  5145. { // 2:cancel
  5146. }
  5147. }
  5148. else
  5149. {
  5150. // 'JX999' 코드를 추가한다.
  5151. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5152. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5153. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5154. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5155. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5156. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5157. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5158. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5159. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5160. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5161. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5162. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  5163. }
  5164. i = ds_list2_clod.rowcount;
  5165. }
  5166. else
  5167. {
  5168. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5169. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5170. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5171. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5172. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5173. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5174. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5175. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5176. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5177. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5178. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5179. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  5180. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  5181. i = ds_list2_clod.rowcount;
  5182. }
  5183. }
  5184. }
  5185. lf_fSortSpclNo();
  5186. //grp_biz_btn_spclspec_onclick();
  5187. }
  5188. else if (destRef == "oprcmemo")
  5189. {
  5190. // 원외처방 jx999 이동
  5191. // 원외처방 동일 edi 코드가 있을 경우 * 표시
  5192. for (var i = 0; i < ds_list7_clop.rowcount; i++)
  5193. {
  5194. var snglcalcscorcd = ds_list7_clop.getColumn(i, "snglcalcscorcd");
  5195. var edicd = ds_list7_clop.getColumn(i, "edicd");
  5196. var seqno = ds_list7_clop.getColumn(i, "seqno");
  5197. var edilnno = ds_list7_clop.getColumn(i, "edilnno");
  5198. var mpsno = ds_list7_clop.getColumn(i, "mpsno");
  5199. if (choiedicd == edicd)
  5200. {
  5201. var lnunitspclspecyn = grp_biz.grd_oprcphist.getCellText(i, grp_biz.grd_oprcphist.getBindCellIndex("body", "spclspecyn"));
  5202. var rowNum = "";
  5203. if (lnunitspclspecyn)
  5204. {
  5205. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  5206. {
  5207. if (ds_list3_clsp.getRowType(j) != 8)
  5208. {
  5209. var clopseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  5210. if (clopseqno == seqno)
  5211. {
  5212. if (ds_list3_clsp.getColumn(j, "spclcd") == "JX999")
  5213. {
  5214. rowNum = j;
  5215. j = ds_list3_clsp.rowcount;
  5216. }
  5217. }
  5218. }
  5219. }
  5220. if (rowNum)
  5221. {
  5222. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  5223. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  5224. if (ans == 6)
  5225. {
  5226. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  5227. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  5228. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5229. if (rowstatus == 2)
  5230. {
  5231. }
  5232. else
  5233. {
  5234. ds_list3_clsp.updatecontrol = false;
  5235. ds_list3_clsp.setRowType(rowNum, "u");
  5236. ds_list3_clsp.updatecontrol = true;
  5237. }
  5238. }
  5239. else if (ans == 7)
  5240. {
  5241. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  5242. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5243. if (rowstatus == 2)
  5244. {
  5245. }
  5246. else
  5247. {
  5248. ds_list3_clsp.updatecontrol = false;
  5249. ds_list3_clsp.setRowType(rowNum, "u");
  5250. ds_list3_clsp.updatecontrol = true;
  5251. }
  5252. }
  5253. else if (ans == 2)
  5254. {
  5255. }
  5256. }
  5257. else
  5258. {
  5259. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5260. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5261. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5262. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5263. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5264. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5265. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5266. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5267. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5268. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5269. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5270. ds_list3_clsp.setColumn(clsprow, "clsoyn", "Y"); //원외처방여부
  5271. ds_list3_clsp.setColumn(clsprow, "mpsno", mpsno); //교부번호
  5272. // JX999 + 다른 코드도 있는 경우가 된다.
  5273. }
  5274. }
  5275. else
  5276. {
  5277. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5278. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5279. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5280. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5281. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5282. ds_list3_clsp.setColumn(clsprow, "spclcd", "JX999");
  5283. ds_list3_clsp.setColumn(clsprow, "cdnm", "기타내역");
  5284. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5285. ds_list3_clsp.setColumn(clsprow, "spclformat", "X(700)");
  5286. ds_list3_clsp.setColumn(clsprow, "detldesc", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5287. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5288. ds_list3_clsp.setColumn(clsprow, "clsoyn", "Y"); //원외처방여부
  5289. ds_list3_clsp.setColumn(clsprow, "mpsno", mpsno); //교부번호
  5290. // JX999만 있는 경우
  5291. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  5292. }
  5293. }
  5294. }
  5295. lf_fSortSpclNo();
  5296. //grp_biz_btn_spclspec_onclick();
  5297. }
  5298. else if (destRef == "spclmemo1")
  5299. {
  5300. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  5301. {
  5302. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  5303. var edicd = ds_list2_clod.getColumn(i, "basecd");
  5304. var seqno = ds_list2_clod.getColumn(i, "seqno");
  5305. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  5306. if (choiedicd == edicd)
  5307. {
  5308. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(i, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  5309. var rowNum = "";
  5310. if (lnunitspclspecyn)
  5311. {
  5312. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  5313. {
  5314. if (ds_list3_clsp.getRowType(j) != 8)
  5315. {
  5316. var clodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  5317. if (clodseqno == seqno)
  5318. {
  5319. if (ds_list3_clsp.getColumn(j, "spclcd") == choispclcd)
  5320. {
  5321. rowNum = j;
  5322. j = ds_list3_clsp.rowcount;
  5323. }
  5324. }
  5325. }
  5326. }
  5327. if (!utlf_isNull(rowNum))
  5328. {
  5329. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  5330. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  5331. if (ans == 6)
  5332. {
  5333. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  5334. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  5335. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5336. if (rowstatus == 2)
  5337. {
  5338. }
  5339. else
  5340. {
  5341. ds_list3_clsp.updatecontrol = false;
  5342. ds_list3_clsp.setRowType(rowNum, "u");
  5343. ds_list3_clsp.updatecontrol = true;
  5344. }
  5345. }
  5346. else if (ans == 7)
  5347. {
  5348. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  5349. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5350. if (rowstatus == 2)
  5351. {
  5352. }
  5353. else
  5354. {
  5355. ds_list3_clsp.updatecontrol = false;
  5356. ds_list3_clsp.setRowType(rowNum, "u");
  5357. ds_list3_clsp.updatecontrol = true;
  5358. }
  5359. }
  5360. else if (ans == 2)
  5361. {
  5362. }
  5363. }
  5364. else
  5365. { // 기존에 입력된 JX999가 없는 경우
  5366. // 'JX999' 코드를 추가한다.
  5367. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5368. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5369. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5370. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5371. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5372. ds_list3_clsp.setColumn(clsprow, "spclcd", choispclcd);
  5373. ds_list3_clsp.setColumn(clsprow, "cdnm", ds_init_P0117.lookup("cdid", choispclcd, "cdnm") );
  5374. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5375. ds_list3_clsp.setColumn(clsprow, "spclformat", ds_init_P0117.lookup("cdid", choispclcd, "cdval") );
  5376. ds_list3_clsp.setColumn(clsprow, "detldesc", ds_init_P0117.lookup("cdid", choispclcd, "detldesc") );
  5377. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5378. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  5379. lf_fSetOrderChangeRowStat(i);
  5380. // JX999 + 다른 코드도 있는 경우가 된다.
  5381. // grd_clodhist.cellStyle("background-color", i, grd_clodhist.colRef("lnunitspclspecyn")) = "#b5a5d1"; // 연한 보라색
  5382. }
  5383. }
  5384. else
  5385. { // 기존에 입력된 줄단위 특정내역이 없는 경우
  5386. // 'JX999' 코드를 추가한다.
  5387. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5388. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5389. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5390. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5391. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5392. ds_list3_clsp.setColumn(clsprow, "spclcd", choispclcd);
  5393. ds_list3_clsp.setColumn(clsprow, "cdnm", ds_init_P0117.lookup("cdid", choispclcd, "cdnm") );
  5394. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5395. ds_list3_clsp.setColumn(clsprow, "spclformat", ds_init_P0117.lookup("cdid", choispclcd, "cdval") );
  5396. ds_list3_clsp.setColumn(clsprow, "detldesc", ds_init_P0117.lookup("cdid", choispclcd, "detldesc") );
  5397. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5398. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N"); //원외처방여부
  5399. // JX999만 있는 경우
  5400. // grd_clodhist.cellStyle("background-color", i, grd_clodhist.colRef("lnunitspclspecyn")) = "#f7a08b"; // class="color_6" 다홍색
  5401. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  5402. } // lnunitspclspecyn == ""
  5403. } // if (choiedicd == clodedicd)
  5404. }
  5405. lf_fSortSpclNo();
  5406. //grp_biz_btn_spclspec_onclick();
  5407. }
  5408. else if (destRef == "spclmemo2")
  5409. {
  5410. for (var i = 0; i < ds_list7_clop.rowcount; i++)
  5411. {
  5412. var snglcalcscorcd = ds_list7_clop.getColumn(i, "snglcalcscorcd");
  5413. var edicd = ds_list7_clop.getColumn(i, "edicd");
  5414. var seqno = ds_list7_clop.getColumn(i, "seqno");
  5415. var edilnno = ds_list7_clop.getColumn(i, "edilnno");
  5416. var mpsno = ds_list7_clop.getColumn(i, "mpsno");
  5417. if (choiedicd == edicd)
  5418. {
  5419. var lnunitspclspecyn = grp_biz.grd_oprcphist.getCellText(i, grp_biz.grd_oprcphist.getBindCellIndex("body", "spclspecyn"));
  5420. var rowNum = "";
  5421. if (lnunitspclspecyn)
  5422. {
  5423. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  5424. {
  5425. if (ds_list3_clsp.getRowType(j) != 8)
  5426. {
  5427. var clopseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  5428. if (clopseqno == seqno)
  5429. {
  5430. if (ds_list3_clsp.getColumn(j, "spclcd") == choispclcd)
  5431. {
  5432. rowNum = j;
  5433. j = ds_list3_clsp.rowcount;
  5434. }
  5435. }
  5436. }
  5437. }
  5438. if (!utlf_isNull(rowNum))
  5439. {
  5440. var ans = sysf_messageBox(edilnno + "번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가", "S001");
  5441. ///***번 줄에 등록된 메모가 있어 기존 내역에 덧붙이거나 삭제후 추가할 수 있습니다.\n덧붙여 추가 하시려면 예(Yes
  5442. if (ans == 6)
  5443. {
  5444. var spclspec = ds_list3_clsp.getColumn(rowNum, "spclspec");
  5445. ds_list3_clsp.setColumn(rowNum, "spclspec", spclspec + "\n"+ choimemo);
  5446. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5447. if (rowstatus == 2)
  5448. {
  5449. }
  5450. else
  5451. {
  5452. ds_list3_clsp.updatecontrol = false;
  5453. ds_list3_clsp.setRowType(rowNum, "u");
  5454. ds_list3_clsp.updatecontrol = true;
  5455. }
  5456. }
  5457. else if (ans == 7)
  5458. {
  5459. ds_list3_clsp.setColumn(rowNum, "spclspec", choimemo);
  5460. var rowstatus = ds_list3_clsp.getRowType(rowNum);
  5461. if (rowstatus == 2)
  5462. {
  5463. }
  5464. else
  5465. {
  5466. ds_list3_clsp.updatecontrol = false;
  5467. ds_list3_clsp.setRowType(rowNum, 'u');
  5468. ds_list3_clsp.updatecontrol = true;
  5469. }
  5470. }
  5471. else if (ans == 2)
  5472. { // 2:cancel
  5473. }
  5474. }
  5475. else
  5476. { // 기존에 입력된 JX999가 없는 경우
  5477. // 'JX999' 코드를 추가한다.
  5478. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5479. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5480. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5481. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5482. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5483. ds_list3_clsp.setColumn(clsprow, "spclcd", choispclcd);
  5484. ds_list3_clsp.setColumn(clsprow, "cdnm", ds_init_P0117.lookup("cdid", choispclcd, "cdnm") );
  5485. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5486. ds_list3_clsp.setColumn(clsprow, "spclformat", ds_init_P0117.lookup("cdid", choispclcd, "cdval") );
  5487. ds_list3_clsp.setColumn(clsprow, "detldesc", ds_init_P0117.lookup("cdid", choispclcd, "detldesc") );
  5488. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5489. ds_list3_clsp.setColumn(clsprow, "clsoyn", "Y"); //원외처방여부
  5490. ds_list3_clsp.setColumn(clsprow, "mpsno", mpsno); //교부번호
  5491. // JX999 + 다른 코드도 있는 경우가 된다.
  5492. }
  5493. }
  5494. else
  5495. {
  5496. var clsprow = ds_list3_clsp.addRow(); // 특정내역 Grid 가장 마지막 줄에 추가한다.
  5497. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  5498. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  5499. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  5500. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  5501. ds_list3_clsp.setColumn(clsprow, "spclcd", choispclcd);
  5502. ds_list3_clsp.setColumn(clsprow, "cdnm", ds_init_P0117.lookup("cdid", choispclcd, "cdnm") );
  5503. ds_list3_clsp.setColumn(clsprow, "spclspec", choimemo);
  5504. ds_list3_clsp.setColumn(clsprow, "spclformat", ds_init_P0117.lookup("cdid", choispclcd, "cdval") );
  5505. ds_list3_clsp.setColumn(clsprow, "detldesc", ds_init_P0117.lookup("cdid", choispclcd, "detldesc") );
  5506. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  5507. ds_list3_clsp.setColumn(clsprow, "clsoyn", "Y"); //원외처방여부
  5508. ds_list3_clsp.setColumn(clsprow, "mpsno", mpsno); //교부번호
  5509. // JX999만 있는 경우
  5510. lf_fSetOrderChangeRowStat(i); // 처방의 수정된 row 상태를 표시한다.
  5511. }
  5512. }
  5513. }
  5514. lf_fSortSpclNo();
  5515. //grp_biz_btn_spclspec_onclick();
  5516. }
  5517. } //for( i = 0 ; i < ds_rslt_sppiz00300.rowcount; i++) {
  5518. //model.refresh();
  5519. } // if (choimemo)
  5520. } // if (SelectMemo != null)
  5521. } // if (clamym)
  5522. }
  5523. /****************************************************************************************
  5524. * Argument : funtion
  5525. * Description : 처방의 수정된 row 상태를 표시한다.
  5526. ****************************************************************************************/
  5527. function lf_fSetOrderChangeRowStat(clodrow)
  5528. {
  5529. var clodstatus = ds_list2_clod.getRowType(clodrow);
  5530. if ( clodstatus == 2 )
  5531. {
  5532. }
  5533. else
  5534. {
  5535. ds_list2_clod.updatecontrol = false;
  5536. ds_list2_clod.setRowType(clodrow, "u");
  5537. ds_list2_clod.updatecontrol = true;
  5538. // 처방 Grid 배경색을 설정한다. - 추가/수정된 row
  5539. lf_fOrderBkColorNew(clodrow);
  5540. }
  5541. }
  5542. /****************************************************************************************
  5543. * Argument : onclick
  5544. * Description : JT001 제외 체크 박스 이벤트
  5545. ****************************************************************************************/
  5546. function grp_biz_swt_spclmemo_case_spclspec_chk_JT001_onclick(obj:CheckBox, e:ClickEventInfo)
  5547. {
  5548. grp_biz_swt_spclmemo_case_spclspec_rdo_unitflag_onitemchanged();
  5549. }
  5550. /****************************************************************************************
  5551. * Argument : onclick
  5552. * Description : 심사자 메모 탭 : 심사자메모
  5553. ****************************************************************************************/
  5554. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_onclick(obj:Button, e:ClickEventInfo)
  5555. {
  5556. var rtn = lf_fGetJudgEdiComment("1","");
  5557. if( !utlf_isNull(rtn) )
  5558. {
  5559. ds_temp_memolist.copyData(rtn);
  5560. var rowCnt = ds_temp_memolist.rowcount;
  5561. for ( i = 0 ; i < rowCnt ; i++)
  5562. {
  5563. if(utlf_isNull(oldTxt))
  5564. {
  5565. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5566. }
  5567. else
  5568. {
  5569. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5570. }
  5571. }
  5572. }
  5573. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5574. }
  5575. /****************************************************************************************
  5576. * Argument : function
  5577. * Description : SPPIZ00700_심사Comment조회.xrw 호출 modal
  5578. ****************************************************************************************/
  5579. function lf_fGetJudgEdiComment(memoflag, memocls)
  5580. {
  5581. var objArg = new Object();
  5582. objArg.sMemocls = memocls;
  5583. objArg.sMemoflag = memoflag;
  5584. objArg.sEdiitem1 = "";
  5585. var rtnObj = frmf_modal("SPPIZ00700","SPPIZ00700", objArg, "", "", "", "", "", "", "", "", "", "M");
  5586. return rtnObj;
  5587. }
  5588. /****************************************************************************************
  5589. * Argument : button
  5590. * Description : 심사자메모 탭 : 약 버튼
  5591. ****************************************************************************************/
  5592. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_drug_onclick(obj:Button, e:ClickEventInfo)
  5593. {
  5594. var rtn = lf_fGetJudgEdiComment("1","01");
  5595. if( !utlf_isNull(rtn) )
  5596. {
  5597. ds_temp_memolist.copyData(rtn);
  5598. var rowCnt = ds_temp_memolist.rowcount;
  5599. for ( i = 0 ; i < rowCnt ; i++)
  5600. {
  5601. if( utlf_isNull( oldTxt ) )
  5602. {
  5603. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5604. }
  5605. else
  5606. {
  5607. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5608. }
  5609. }
  5610. }
  5611. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5612. }
  5613. /****************************************************************************************
  5614. * Argument : button
  5615. * Description : 심사자메모 탭 : 주사 버튼
  5616. ****************************************************************************************/
  5617. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_injection_onclick(obj:Button, e:ClickEventInfo)
  5618. {
  5619. var rtn = lf_fGetJudgEdiComment("1", "02");
  5620. if( !utlf_isNull(rtn) )
  5621. {
  5622. ds_temp_memolist.copyData(rtn);
  5623. var rowCnt = ds_temp_memolist.rowcount;
  5624. for ( i = 0 ; i < rowCnt ; i++)
  5625. {
  5626. if( utlf_isNull( oldTxt ) )
  5627. {
  5628. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5629. }
  5630. else
  5631. {
  5632. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5633. }
  5634. }
  5635. }
  5636. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5637. }
  5638. /****************************************************************************************
  5639. * Argument : button
  5640. * Description : 심사자메모 탭 : 처치 버튼
  5641. ****************************************************************************************/
  5642. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_treat_onclick(obj:Button, e:ClickEventInfo)
  5643. {
  5644. var rtn = lf_fGetJudgEdiComment("1", "03");
  5645. if( !utlf_isNull(rtn) )
  5646. {
  5647. ds_temp_memolist.copyData(rtn);
  5648. var rowCnt = ds_temp_memolist.rowcount;
  5649. for ( i = 0 ; i < rowCnt ; i++)
  5650. {
  5651. if( utlf_isNull( oldTxt ) )
  5652. {
  5653. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5654. }
  5655. else
  5656. {
  5657. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5658. }
  5659. }
  5660. }
  5661. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5662. }
  5663. /****************************************************************************************
  5664. * Argument : button
  5665. * Description : 심사자메모 탭 : 검사 버튼
  5666. ****************************************************************************************/
  5667. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_exam_onclick(obj:Button, e:ClickEventInfo)
  5668. {
  5669. var rtn = lf_fGetJudgEdiComment("1", "04");
  5670. if(!utlf_isNull(rtn))
  5671. {
  5672. ds_temp_memolist.copyData(rtn);
  5673. var rowCnt = ds_temp_memolist.rowcount;
  5674. for ( i = 0 ; i < rowCnt ; i++)
  5675. {
  5676. if( utlf_isNull( oldTxt ) )
  5677. {
  5678. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5679. }
  5680. else
  5681. {
  5682. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5683. }
  5684. }
  5685. }
  5686. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5687. }
  5688. /****************************************************************************************
  5689. * Argument : button
  5690. * Description : 심사자메모 탭 : 기타 버튼
  5691. ****************************************************************************************/
  5692. function grp_biz_swt_spclmemo_case_judgrmemo_btn_memohistory_etc_onclick(obj:Button, e:ClickEventInfo)
  5693. {
  5694. var rtn = lf_fGetJudgEdiComment("1", "99");
  5695. if( !utlf_isNull(rtn) )
  5696. {
  5697. ds_temp_memolist.copyData(rtn);
  5698. var rowCnt = ds_temp_memolist.rowcount;
  5699. for ( i = 0 ; i < rowCnt ; i++)
  5700. {
  5701. if( utlf_isNull( oldTxt ) )
  5702. {
  5703. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5704. }
  5705. else
  5706. {
  5707. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5708. }
  5709. }
  5710. }
  5711. ds_main_item1_memo.setColumn(0,"judgmemo", oldTxt);
  5712. }
  5713. /****************************************************************************************
  5714. * Argument : button
  5715. * Description : 심사자메모 탭 : 청구 메모로 전달
  5716. ****************************************************************************************/
  5717. function grp_biz_swt_spclmemo_case_judgrmemo_btn_toclammemo_onclick(obj:Button, e:ClickEventInfo)
  5718. {
  5719. var memo = ds_main_item1_memo.getColumn(0,"edimemo");
  5720. var judgmemo = ds_main_item1_memo.getColumn(0, "judgmemo");
  5721. if (!utlf_isNull(memo))
  5722. {
  5723. var seletedMemo = grp_biz.swt_spclmemo.case_judgrmemo.tar_judgrmemo.getSelectedText();
  5724. if (!utlf_isNull(seletedMemo))
  5725. {
  5726. memo += " \n"+ seletedMemo;
  5727. }
  5728. else
  5729. {
  5730. if (!utlf_isNull(judgmemo))
  5731. {
  5732. memo += " \n"+ judgmemo;
  5733. }
  5734. }
  5735. }
  5736. else
  5737. {
  5738. var seletedMemo = grp_biz.swt_spclmemo.case_judgrmemo.tar_judgrmemo.getSelectedText();
  5739. if (!utlf_isNull(seletedMemo))
  5740. {
  5741. memo = seletedMemo;
  5742. }
  5743. else
  5744. {
  5745. memo = judgmemo;
  5746. }
  5747. }
  5748. ds_main_item1_memo.setColumn(0,"edimemo", memo);
  5749. grp_biz.swt_spclmemo.tabindex = 2; // case_edi tab 으로 토글시킨다.
  5750. }
  5751. /****************************************************************************************
  5752. * Argument : button
  5753. * Description : 심사자메모 탭 : 지우기
  5754. ****************************************************************************************/
  5755. function grp_biz_swt_spclmemo_case_judgrmemo_btn_clearjudgrmemo_onclick(obj:Button, e:ClickEventInfo)
  5756. {
  5757. ds_main_item1_memo.setColumn(0, "judgmemo", "");
  5758. }
  5759. /****************************************************************************************
  5760. * Argument : button
  5761. * Description : EDI메모 탭 : EDI메모
  5762. ****************************************************************************************/
  5763. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_onclick(obj:Button, e:ClickEventInfo)
  5764. {
  5765. var rtn = lf_fGetJudgEdiComment("2", "");
  5766. if(!utlf_isNull(rtn))
  5767. {
  5768. ds_temp_memolist.copyData(rtn);
  5769. var rowCnt = ds_temp_memolist.rowcount;
  5770. for ( i = 0 ; i < rowCnt ; i++)
  5771. {
  5772. if( utlf_isNull( oldTxt ) )
  5773. {
  5774. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5775. }
  5776. else
  5777. {
  5778. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5779. }
  5780. }
  5781. }
  5782. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5783. }
  5784. /****************************************************************************************
  5785. * Argument : button
  5786. * Description : EDI메모 탭 : 약
  5787. ****************************************************************************************/
  5788. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_drug_onclick(obj:Button, e:ClickEventInfo)
  5789. {
  5790. var rtn = lf_fGetJudgEdiComment("2", "01");
  5791. if( !utlf_isNull(rtn) )
  5792. {
  5793. ds_temp_memolist.copyData(rtn);
  5794. var rowCnt = ds_temp_memolist.rowcount;
  5795. for ( i = 0 ; i < rowCnt ; i++)
  5796. {
  5797. if(utlf_isNull(oldTxt))
  5798. {
  5799. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5800. }
  5801. else
  5802. {
  5803. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5804. }
  5805. }
  5806. }
  5807. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5808. }
  5809. /****************************************************************************************
  5810. * Argument : button
  5811. * Description : EDI메모 탭 : 주사
  5812. ****************************************************************************************/
  5813. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_injection_onclick(obj:Button, e:ClickEventInfo)
  5814. {
  5815. var rtn = lf_fGetJudgEdiComment("2", "02");
  5816. if( !utlf_isNull(rtn) )
  5817. {
  5818. ds_temp_memolist.copyData(rtn);
  5819. var rowCnt = ds_temp_memolist.rowcount;
  5820. for ( i = 0 ; i < rowCnt ; i++)
  5821. {
  5822. if( utlf_isNull(oldTxt))
  5823. {
  5824. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5825. }
  5826. else
  5827. {
  5828. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5829. }
  5830. }
  5831. }
  5832. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5833. }
  5834. /****************************************************************************************
  5835. * Argument : button
  5836. * Description : EDI메모 탭 : 처치
  5837. ****************************************************************************************/
  5838. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_treat_onclick(obj:Button, e:ClickEventInfo)
  5839. {
  5840. var rtn = lf_fGetJudgEdiComment("2", "03");
  5841. if( !utlf_isNull(rtn) )
  5842. {
  5843. ds_temp_memolist.copyData(rtn);
  5844. var rowCnt = ds_temp_memolist.rowcount;
  5845. for ( i = 0 ; i < rowCnt ; i++)
  5846. {
  5847. if(utlf_isNull(oldTxt ))
  5848. {
  5849. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5850. }
  5851. else
  5852. {
  5853. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5854. }
  5855. }
  5856. }
  5857. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5858. }
  5859. /****************************************************************************************
  5860. * Argument : button
  5861. * Description : EDI메모 탭 : 검사
  5862. ****************************************************************************************/
  5863. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_exam_onclick(obj:Button, e:ClickEventInfo)
  5864. {
  5865. var rtn = lf_fGetJudgEdiComment("2", "04");
  5866. if(!utlf_isNull(rtn))
  5867. {
  5868. ds_temp_memolist.copyData(rtn);
  5869. var rowCnt = ds_temp_memolist.rowcount;
  5870. for ( i = 0 ; i < rowCnt ; i++)
  5871. {
  5872. if( utlf_isNull(oldTxt))
  5873. {
  5874. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5875. }
  5876. else
  5877. {
  5878. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5879. }
  5880. }
  5881. }
  5882. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5883. }
  5884. /****************************************************************************************
  5885. * Argument : button
  5886. * Description : EDI메모 탭 : 기타
  5887. ****************************************************************************************/
  5888. function grp_biz_swt_spclmemo_case_ediclammemo_btn_memoedi_etc_onclick(obj:Button, e:ClickEventInfo)
  5889. {
  5890. var rtn = lf_fGetJudgEdiComment("2", "99");
  5891. if(!utlf_isNull(rtn))
  5892. {
  5893. ds_temp_memolist.copyData(rtn);
  5894. var rowCnt = ds_temp_memolist.rowcount;
  5895. for ( i = 0 ; i < rowCnt ; i++)
  5896. {
  5897. if(utlf_isNull(oldTxt))
  5898. {
  5899. oldTxt = ds_temp_memolist.getColumn(i, "memo");
  5900. }
  5901. else
  5902. {
  5903. oldTxt = oldTxt + "\n" + ds_temp_memolist.getColumn(i, "memo");
  5904. }
  5905. }
  5906. }
  5907. ds_main_item1_memo.setColumn(0,"edimemo", oldTxt);
  5908. }
  5909. /****************************************************************************************
  5910. * Argument : oncelldblclick
  5911. * Description : 특정내역 그리드 더블 클릭 이벤트
  5912. ****************************************************************************************/
  5913. function grp_biz_swt_spclmemo_case_spclspec_grd_clsphist_oncelldblclick(obj:Grid, e:GridClickEventInfo)
  5914. {
  5915. var row = e.row;
  5916. var unitflag = ds_list3_clsp.getColumn(row, "unitflag");
  5917. var clsoyn = ds_list3_clsp.getColumn(row, "clsoyn");
  5918. if ( ds_list3_clsp.getColumn(row, "spclcd") == "JT001")
  5919. {
  5920. lf_fSetCnfmCdSpclSpec();
  5921. }
  5922. else
  5923. {
  5924. if (clsoyn == "N")
  5925. {
  5926. lf_fSetDocRefLnSpclSpec();// 명세서 특정내역
  5927. }
  5928. else if(clsoyn == "Y")
  5929. {
  5930. lf_fSetLnUnitClsoSpclSpec("grd_clsphist"); // 원외처방 특정내역
  5931. }
  5932. }
  5933. }
  5934. /****************************************************************************************
  5935. * Argument : oncelldblclick
  5936. * Description : 줄단위 원외처방특정내역을 수정/입력한다
  5937. ****************************************************************************************/
  5938. function lf_fSetLnUnitClsoSpclSpec(sgrid)
  5939. {
  5940. ds_cond_sppiz01700.clearData();
  5941. ds_cond_sppiz01700.addRow();
  5942. ds_rslt_sppiz01700.clearData();
  5943. ds_list_sppiz01700.clearData();
  5944. var row = "";
  5945. var seqno = "";
  5946. var edilnno = "";
  5947. var snglcalcscorcd = "";
  5948. var clopdd = "";
  5949. var clopno = "";
  5950. var mpsno = "";
  5951. if (sgrid == "grd_oprcphist" )
  5952. {
  5953. row = ds_list7_clop.rowposition;
  5954. seqno = ds_list7_clop.getColumn(row, "seqno");
  5955. edilnno = ds_list7_clop.getColumn(row, "edilnno");
  5956. snglcalcscorcd = ds_list7_clop.getColumn(row, "snglcalcscorcd");
  5957. clopdd = ds_list7_clop.getColumn(row, "clopdd");
  5958. clopno = ds_list7_clop.getColumn(row, "clopno");
  5959. mpsno = ds_list7_clop.getColumn(row, "mpsno");
  5960. }
  5961. else if (sgrid == "grd_clsphist")
  5962. {
  5963. row = ds_list3_clsp.rowposition;
  5964. seqno = ds_list3_clsp.getColumn(row, "clodseqno");
  5965. edilnno = ds_list3_clsp.getColumn(row, "edilnno");
  5966. snglcalcscorcd = ds_list3_clsp.getColumn(row, "snglcalcscorcd");
  5967. mpsno = ds_list3_clsp.getColumn(row, "mpsno");
  5968. clopdd = mpsno.substr(0,8);
  5969. clopno = mpsno.substr(8,5);
  5970. }
  5971. if (seqno != "0")
  5972. {
  5973. if (sgrid == "grd_oprcphist")
  5974. {
  5975. var lnunitspclspecyn = grp_biz.grd_oprcphist.getCellText(row, grp_biz.grd_oprcphist.getBindCellIndex("body", "spclspecyn"));
  5976. }
  5977. else if (sgrid == "grd_clsphist")
  5978. {
  5979. var lnunitspclspecyn = "*";
  5980. }
  5981. if(utlf_isNull(lnunitspclspecyn))
  5982. {
  5983. ds_cond_sppiz01700.setColumn(0, "flag" , "I");
  5984. ds_cond_sppiz01700.setColumn(0, "snglcalcscorcd", snglcalcscorcd);
  5985. ds_cond_sppiz01700.setColumn(0, "clopdd" , clopdd);
  5986. ds_cond_sppiz01700.setColumn(0, "clopno" , clopno);
  5987. ds_cond_sppiz01700.setColumn(0, "edilnno" , edilnno);
  5988. ds_cond_sppiz01700.setColumn(0, "clodseqno" , seqno);
  5989. ds_cond_sppiz01700.setColumn(0, "spclcd" , "JX999");
  5990. ds_cond_sppiz01700.setColumn(0, "detldesc" , "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  5991. ds_cond_sppiz01700.setColumn(0, "spclspec" , "");
  5992. ds_cond_sppiz01700.setColumn(0, "spclformat" , "X(700)");
  5993. ds_cond_sppiz01700.setColumn(0, "rownum" , "");
  5994. ds_cond_sppiz01700.setColumn(0, "cdnm" , "기타내역");
  5995. ds_cond_sppiz01700.setColumn(0, "unitflag" , "J");
  5996. }
  5997. else
  5998. {
  5999. var rowcnt = 0;
  6000. var setrow = -1;
  6001. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  6002. {
  6003. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  6004. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  6005. if ( spcClodseqno == seqno && spcClsoyn == "Y" )
  6006. {
  6007. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  6008. if (!utlf_isNull(spclcd) && spclcd != "JT001" && ds_list3_clsp.getRowType(i) != 8)
  6009. {
  6010. //var rowcnt = ds_list_sppiz01700.addRow();
  6011. dsf_makeValue(ds_list_sppiz01700, "flag", "string", "", rowcnt);
  6012. dsf_makeValue(ds_list_sppiz01700, "rownum", "string", i, rowcnt);
  6013. dsf_makeValue(ds_list_sppiz01700, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  6014. dsf_makeValue(ds_list_sppiz01700, "clopdd", "string", ds_list3_clsp.getColumn(i, "mpsno").substr(0,8), rowcnt);
  6015. dsf_makeValue(ds_list_sppiz01700, "clopno", "string", ds_list3_clsp.getColumn(i, "mpsno").substr(8,5), rowcnt);
  6016. dsf_makeValue(ds_list_sppiz01700, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  6017. dsf_makeValue(ds_list_sppiz01700, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  6018. dsf_makeValue(ds_list_sppiz01700, "spclcd", "string", spclcd, rowcnt);
  6019. dsf_makeValue(ds_list_sppiz01700, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  6020. dsf_makeValue(ds_list_sppiz01700, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), rowcnt);
  6021. dsf_makeValue(ds_list_sppiz01700, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  6022. dsf_makeValue(ds_list_sppiz01700, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), rowcnt);
  6023. dsf_makeValue(ds_list_sppiz01700, "oldspclcd", "string", spclcd, rowcnt);
  6024. dsf_makeValue(ds_list_sppiz01700, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  6025. dsf_makeValue(ds_list_sppiz01700, "mpsno", "string", ds_list3_clsp.getColumn(i, "mpsno"), rowcnt);
  6026. if (spclcd == "JX999")
  6027. {
  6028. setrow = i;
  6029. }
  6030. rowcnt = rowcnt+1;
  6031. }
  6032. }
  6033. }
  6034. if (setrow > -1)
  6035. {
  6036. ds_cond_sppiz01700.setColumn(0, "flag" , "");
  6037. ds_cond_sppiz01700.setColumn(0, "rownum" , setrow);
  6038. ds_cond_sppiz01700.setColumn(0, "snglcalcscorcd" , snglcalcscorcd);
  6039. ds_cond_sppiz01700.setColumn(0, "clopdd" , clopdd);
  6040. ds_cond_sppiz01700.setColumn(0, "clopno" , clopno);
  6041. ds_cond_sppiz01700.setColumn(0, "clodseqno" , seqno);
  6042. ds_cond_sppiz01700.setColumn(0, "edilnno" , edilnno);
  6043. ds_cond_sppiz01700.setColumn(0, "spclcd" , ds_list3_clsp.getColumn(setrow, "spclcd"));
  6044. ds_cond_sppiz01700.setColumn(0, "detldesc" , ds_list3_clsp.getColumn(setrow, "detldesc"));
  6045. ds_cond_sppiz01700.setColumn(0, "spclspec" , ds_list3_clsp.getColumn(setrow, "spclspec"));
  6046. ds_cond_sppiz01700.setColumn(0, "spclformat" , ds_list3_clsp.getColumn(setrow, "spclformat"));
  6047. ds_cond_sppiz01700.setColumn(0, "cdnm" , ds_list3_clsp.getColumn(setrow, "cdnm"));
  6048. ds_cond_sppiz01700.setColumn(0, "unitflag" , "J");
  6049. ds_cond_sppiz01700.setColumn(0, "mpsno" , ds_list3_clsp.getColumn(setrow, "mpsno"));
  6050. }
  6051. else
  6052. {
  6053. ds_cond_sppiz01700.setColumn(0, "flag" , "I");
  6054. ds_cond_sppiz01700.setColumn(0, "snglcalcscorcd" , snglcalcscorcd);
  6055. ds_cond_sppiz01700.setColumn(0, "clopdd" , clopdd);
  6056. ds_cond_sppiz01700.setColumn(0, "clopno" , clopno);
  6057. ds_cond_sppiz01700.setColumn(0, "clodseqno" , seqno);
  6058. ds_cond_sppiz01700.setColumn(0, "edilnno" , edilnno);
  6059. ds_cond_sppiz01700.setColumn(0, "spclcd" , "JX999");
  6060. ds_cond_sppiz01700.setColumn(0, "detldesc" , "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재");
  6061. ds_cond_sppiz01700.setColumn(0, "spclspec" , "");
  6062. ds_cond_sppiz01700.setColumn(0, "spclformat" , "X(700)");
  6063. ds_cond_sppiz01700.setColumn(0, "rownum" , "");
  6064. ds_cond_sppiz01700.setColumn(0, "cdnm" , "기타내역");
  6065. ds_cond_sppiz01700.setColumn(0, "unitflag" , "J");
  6066. ds_cond_sppiz01700.setColumn(0, "mpsno" , "");
  6067. }
  6068. }
  6069. ds_cond_sppiz01700.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukind"));
  6070. ds_cond_sppiz01700.setColumn(0, "ordfildcd" , ds_main_item1_clbs.getColumn(0, "ordfildcd"));
  6071. frmf_setParameter("iParam_mother_view", "SMPID20500_외래사후심사관리");
  6072. var objArg = new Object();
  6073. objArg.arg_ds_hidden_clsp_cond = ds_cond_sppiz01700;
  6074. objArg.arg_ds_hidden_clsp_cond_list = ds_list_sppiz01700;
  6075. frmf_modal("SPPIZ01700", "SPPIZ01700", objArg, "", "", "", "", "", "", "", "", "", "M");
  6076. if (ds_rslt_sppiz01700.rowcount > 0)
  6077. {
  6078. for ( var i = 0; i < ds_rslt_sppiz01700.rowcount; i++)
  6079. {
  6080. var flag = ds_rslt_sppiz01700.getColumn(i, "flag");
  6081. var rownum = ds_rslt_sppiz01700.getColumn(i, "rownum");
  6082. var newspclcd = ds_rslt_sppiz01700.getColumn(i, "spclcd");
  6083. var newcdnm = ds_rslt_sppiz01700.getColumn(i, "cdnm");
  6084. var newspclspec = ds_rslt_sppiz01700.getColumn(i, "spclspec");
  6085. var newspclformat = ds_rslt_sppiz01700.getColumn(i, "spclformat");
  6086. var newdetldesc = ds_rslt_sppiz01700.getColumn(i, "detldesc");
  6087. if (flag == "I")
  6088. {
  6089. var clsprow = ds_list3_clsp.addRow();
  6090. if( newspclcd == "CT001")
  6091. {
  6092. ds_list3_clsp.setColumn(clsprow, "unitflag" , "C");
  6093. ds_list3_clsp.setColumn(clsprow, "clodseqno" , 0);
  6094. ds_list3_clsp.setColumn(clsprow, "edilnno" , 0);
  6095. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd" , "-");
  6096. }
  6097. else if( newspclcd == "CT002")
  6098. {
  6099. ds_list3_clsp.setColumn(clsprow, "unitflag" , "C");
  6100. ds_list3_clsp.setColumn(clsprow, "clodseqno" , 0);
  6101. ds_list3_clsp.setColumn(clsprow, "edilnno" , 0);
  6102. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd" , "-");
  6103. }
  6104. else
  6105. {
  6106. ds_list3_clsp.setColumn(clsprow, "unitflag" , "J");
  6107. ds_list3_clsp.setColumn(clsprow, "clodseqno" , seqno);
  6108. ds_list3_clsp.setColumn(clsprow, "edilnno" , edilnno);
  6109. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd" , snglcalcscorcd);
  6110. }
  6111. ds_list3_clsp.setColumn(clsprow, "spclcd" , newspclcd);
  6112. ds_list3_clsp.setColumn(clsprow, "cdnm" , newcdnm);
  6113. ds_list3_clsp.setColumn(clsprow, "spclspec" , newspclspec);
  6114. ds_list3_clsp.setColumn(clsprow, "spclformat" , newspclformat);
  6115. ds_list3_clsp.setColumn(clsprow, "detldesc" , newdetldesc);
  6116. ds_list3_clsp.setColumn(clsprow, "oldedilnno" , edilnno);
  6117. ds_list3_clsp.setColumn(clsprow, "oldspclcd" , "");
  6118. ds_list3_clsp.setColumn(clsprow, "mpsno" , clopdd + clopno);
  6119. ds_list3_clsp.setColumn(clsprow, "clsoyn" , "Y");
  6120. ds_hidden_list3.setColumn(0, "msgspclformat" , "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  6121. }
  6122. else if (flag == "U")
  6123. {
  6124. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd" , snglcalcscorcd);
  6125. ds_list3_clsp.setColumn(rownum, "spclcd" , newspclcd);
  6126. ds_list3_clsp.setColumn(rownum, "cdnm" , newcdnm);
  6127. ds_list3_clsp.setColumn(rownum, "spclspec" , newspclspec);
  6128. ds_list3_clsp.setColumn(rownum, "spclformat" , newspclformat);
  6129. ds_list3_clsp.setColumn(rownum, "detldesc" , newdetldesc);
  6130. var oldspclcd = ds_rslt_sppiz01700.getColumn(i, "oldspclcd");
  6131. var oldspclspec = ds_rslt_sppiz01700.getColumn(i, "oldspclspec");
  6132. var rowstatus = ds_list3_clsp.getRowType(rownum);
  6133. if (rowstatus == 2)
  6134. {
  6135. }
  6136. else
  6137. {
  6138. ds_list3_clsp.updatecontrol = false;
  6139. ds_list3_clsp.setRowType(rownum, 'u');
  6140. ds_list3_clsp.updatecontrol = true;
  6141. }
  6142. ds_hidden_list3.setColumn(0, "msgspclformat" , "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  6143. }
  6144. else if (flag == "D" && !utlf_isNull(rownum))
  6145. {
  6146. var rowstatus = ds_list3_clsp.getRowType(rownum);
  6147. if (rowstatus == 2)
  6148. {
  6149. ds_list3_clsp.deleteRow(rownum);
  6150. }
  6151. else
  6152. {
  6153. ds_list3_clsp.setColumn(rownum, "rowstat","D");
  6154. ds_list3_clsp.updatecontrol = false;
  6155. ds_list3_clsp.setRowType(rownum, 'd');
  6156. ds_list3_clsp.updatecontrol = true;
  6157. lf_fSetSpclSpecJX999()
  6158. ds_list3_clsp.deleteRow(rownum);
  6159. }
  6160. ds_list3_clsp.rowposition = rownum;
  6161. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  6162. } // 특정 코드 상태 따른 if end
  6163. } // for end
  6164. }
  6165. }
  6166. else
  6167. {
  6168. sysf_messageBox("처방번호가 부여되지 않았으며 해당 줄단위 특정내역이", "I004");
  6169. }
  6170. }
  6171. /****************************************************************************************
  6172. * Argument : function
  6173. * Description : 재료행위/급여/항목구분 Radio 선택
  6174. ****************************************************************************************/
  6175. function lf_fGetSelectedOrderData()
  6176. {
  6177. var selectedRdoPay = "";
  6178. var selectedRdoItem = "";
  6179. var selectedRdoMatrAct = "";
  6180. var snglcalcscorcd = " String(snglcalcscorcd).indexOf('"+utlf_transNullToEmpty(ds_hidden_list2_clodsrch.getColumn(0, "inpCalcScorCd"))+"') >= 0 ";
  6181. var edicd = " String(basecd).indexOf('"+utlf_transNullToEmpty(ds_hidden_list2_clodsrch.getColumn(0, "inpEDICd"))+"') >= 0 ";
  6182. // if (ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoPay") != "-")
  6183. // {
  6184. // selectedRdoPay = grp_biz.grp_sea02.rdo_payflag.value;
  6185. //
  6186. // selectedRdoPay = "payflag == '" + selectedRdoPay + "'";
  6187. // }
  6188. if (ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoItem") != "-")
  6189. {
  6190. selectedRdoItem = "item1 == '" + ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoItem") + "'";
  6191. }
  6192. if (!utlf_isNull(ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoMatrAct")) && ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoMatrAct") != "-")
  6193. {
  6194. if (ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoMatrAct") == "0"){
  6195. selectedRdoMatrAct = "(matractflag == '2' || matractflag == '3')";
  6196. } else {
  6197. selectedRdoMatrAct = "(matractflag != '2' && matractflag != '3')";
  6198. }
  6199. }
  6200. var prematractflag = ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoMatrAct");
  6201. var tmp = "";
  6202. var chk = "0";
  6203. if(!utlf_isNull(selectedRdoPay))
  6204. {
  6205. tmp = tmp + selectedRdoPay;
  6206. chk = "1";
  6207. }
  6208. if(!utlf_isNull(selectedRdoItem))
  6209. {
  6210. if(chk == "1")
  6211. {
  6212. tmp = tmp + " && " + selectedRdoItem;
  6213. }
  6214. else
  6215. {
  6216. tmp = tmp + selectedRdoItem;
  6217. chk = "1";
  6218. }
  6219. }
  6220. if(!utlf_isNull(selectedRdoMatrAct))
  6221. {
  6222. if(chk == "1")
  6223. {
  6224. tmp = tmp + " && " + selectedRdoMatrAct;
  6225. }
  6226. else
  6227. {
  6228. tmp = tmp + selectedRdoMatrAct;
  6229. chk = "1";
  6230. }
  6231. }
  6232. if(!utlf_isNull(ds_hidden_list2_clodsrch.getColumn(0, "inpCalcScorCd")))
  6233. {
  6234. if(chk == "1")
  6235. {
  6236. tmp = tmp + " && " + snglcalcscorcd;
  6237. }
  6238. else
  6239. {
  6240. tmp = tmp + snglcalcscorcd;
  6241. chk = "1";
  6242. }
  6243. }
  6244. if(!utlf_isNull(ds_hidden_list2_clodsrch.getColumn(0, "inpEDICd")))
  6245. {
  6246. if(chk == "1")
  6247. {
  6248. tmp = tmp + " && " + edicd;
  6249. }
  6250. else
  6251. {
  6252. tmp = tmp + edicd;
  6253. chk = "1";
  6254. }
  6255. }
  6256. if(chk == "0")
  6257. {
  6258. tmp = "";
  6259. }
  6260. ds_list2_clod.filter(tmp);
  6261. }
  6262. /****************************************************************************************
  6263. * Argument : function
  6264. * Description : 급여구분별 처방조회
  6265. ****************************************************************************************/
  6266. function lf_fClodSelectByPayflag()
  6267. {
  6268. ds_hidden_list2_clodsrch.setColumn(0, "inpCalcScorCd", "");
  6269. ds_hidden_list2_clodsrch.setColumn(0, "inpEDICd", "");
  6270. var payflag = ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoPay");
  6271. if (payflag == "0")
  6272. {
  6273. ds_list2_clod.copyData(ds_hidden_initclodlist_list2);
  6274. ds_list2_clod.rowposition = -1;
  6275. }
  6276. else
  6277. {
  6278. var datasave = false;
  6279. var clodupdtdata = grdf_getGridUpdateData(grp_biz.grd_clodhist).rowcount;
  6280. if (clodupdtdata != 0)
  6281. {
  6282. var ans = sysf_messageBox("급여처방에 수정사항이 있습니다. 저장", "S001");
  6283. if (ans == 6)
  6284. {
  6285. lf_fSaveAftJudg("B")
  6286. datasave = true;
  6287. }
  6288. else
  6289. {
  6290. datasave = false;
  6291. }
  6292. }
  6293. // 수정사항을 저장하지 않은 경우 OR 수정사항이 없는 경우
  6294. if (datasave == false)
  6295. {
  6296. var nodeList;
  6297. ds_list2_clod.clearData();
  6298. // 급여구분에 따라 해당되는 처방만 보여준다.
  6299. if (payflag == "-")
  6300. {
  6301. ds_list8_clod2.filterstr = "";
  6302. ds_list2_clod.copyData(ds_list8_clod2);
  6303. }
  6304. else
  6305. { // 전액본인부담, 일반, 선택
  6306. ds_list8_clod2.filterstr = "payflag == '" + payflag + "'";
  6307. ds_list2_clod.copyData(ds_list8_clod2, true);
  6308. }
  6309. ds_list2_clod.rowposition = -1;
  6310. }
  6311. }
  6312. }
  6313. /****************************************************************************************
  6314. * Argument : function
  6315. * Description : CLDI 테이블에 저장할 정보가 올바른지 확인한다.
  6316. ****************************************************************************************/
  6317. function lf_fCheckSaveInAftJudgInfoCLDI(judgendyn)
  6318. {
  6319. var delcldiCheck = false;
  6320. for ( var i = ds_list1_cldi.rowcount-1; i >= 0; i-- )
  6321. {
  6322. var rowstatus = ds_list1_cldi.getRowType(i);
  6323. var diagcd = ds_list1_cldi.getColumn(i, "diagcd");
  6324. if (rowstatus == 2)
  6325. {
  6326. if (utlf_isNull(diagcd))
  6327. {
  6328. ds_list1_cldi.deleteRow(i);
  6329. delcldiCheck = true;
  6330. }
  6331. }
  6332. }
  6333. if ( ds_list1_cldi.rowcount == 0 && judgendyn == "C")
  6334. {
  6335. sysf_messageBox("상병이 입력되지", "E007");
  6336. return false;
  6337. }
  6338. else
  6339. {
  6340. var orddeptcd = ds_main_item1_clbs.getColumn(0, "orddeptcd");
  6341. for ( var i = ds_list1_cldi.rowcount-1; i >= 0; i-- )
  6342. {
  6343. var diagcd = ds_list1_cldi.getColumn(i, "diagcd");
  6344. var toot = ds_list1_cldi.getColumn(i, "toot");
  6345. if (utlf_isNull(diagcd))
  6346. {
  6347. ds_list1_cldi.deleteRow(i);
  6348. }
  6349. else
  6350. {
  6351. var diagseq = ds_list1_cldi.getColumn(i, "diagseq");
  6352. var frow = -1;
  6353. for ( var j = 0; j < i; j++)
  6354. {
  6355. var prediagseq = ds_list1_cldi.getColumn(j, "diagseq");
  6356. var prediagcd = ds_list1_cldi.getColumn(j, "diagcd");
  6357. var pretoot = ds_list1_cldi.getColumn(j, "toot");
  6358. if (ds_list1_cldi.getRowType(i) != 8)
  6359. {
  6360. if (diagseq == prediagseq)
  6361. {
  6362. sysf_messageBox("상병순서 '" + diagseq + "'가", "E006");
  6363. return false;
  6364. }
  6365. if (diagcd == prediagcd && toot == pretoot)
  6366. {
  6367. sysf_messageBox("상병코드 '" + diagcd + "'가", "E006");
  6368. return false;
  6369. }
  6370. frow = ds_main_list2_listdiag.findRowExpr("(orddeptcd == '" +orddeptcd+ "' || orddeptcd == '-') && diagcd == '"+ diagcd +"' && chgdiagcd == '-'")
  6371. if (frow > -1) {
  6372. sysf_messageBox("청구불가 상병코드 '" + diagcd + "'가(이)", "I010");
  6373. }
  6374. }
  6375. }
  6376. if (utlf_isNull(ds_list1_cldi.getColumn(i, "toot")))
  6377. {
  6378. ds_list1_cldi.setColumn(i, "toot", "-");
  6379. }
  6380. }
  6381. }
  6382. }
  6383. return true;
  6384. }
  6385. /****************************************************************************************
  6386. * Argument : function
  6387. * Description : CLSP 테이블에 저장할 정보가 올바른지 확인한다.
  6388. ****************************************************************************************/
  6389. function lf_fCheckSaveInAftJudgInfoCLSP()
  6390. {
  6391. for ( var i = ds_list3_clsp.rowcount-1; i >= 0; i-- )
  6392. {
  6393. var rowstatus = ds_list3_clsp.getRowType(i);
  6394. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  6395. var spclspec = ds_list3_clsp.getColumn(i, "spclspec");
  6396. if (rowstatus != 8 && utlf_isNull(spclcd) && utlf_isNull(spclspec))
  6397. {
  6398. ds_list3_clsp.deleteRow(i);
  6399. }
  6400. }
  6401. var clspList = ds_list3_clsp.rowcount;
  6402. if (clspList < 0)
  6403. {
  6404. return false;
  6405. }
  6406. for ( var i = 0; i < ds_list3_clsp.rowcount; i++)
  6407. {
  6408. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  6409. var spclspec = ds_list3_clsp.getColumn(i, "spclspec");
  6410. if(utlf_isNull(spclspec))
  6411. {
  6412. sysf_messageBox("특정코드 '" + spclcd + "'의 내역이", "I004");
  6413. return false;
  6414. }
  6415. else if (spclcd == "MX999" || spclcd == "MT015" || spclcd == "MT016"|| spclcd == "MT004")
  6416. {
  6417. for ( var j = 0; j < i; j++)
  6418. {
  6419. var prespclcd = ds_list3_clsp.getColumn(j, "spclcd");
  6420. if (ds_list3_clsp.getRowType(i) != 8 && spclcd == prespclcd )
  6421. {
  6422. sysf_messageBox("명세서 단위 특정코드 '" + spclcd + "'가", "E006");
  6423. return false;
  6424. }
  6425. }
  6426. }
  6427. }
  6428. return true;
  6429. }
  6430. /****************************************************************************************
  6431. * Argument : function
  6432. * Description : 줄단위 특정내역 중 기타메모(JX999)를 특정내역 형식에 맞춰 설정한다.
  6433. ****************************************************************************************/
  6434. function lf_fSetSpclSpecJX999()
  6435. {
  6436. ds_send_item3_lnunitmemo.clearData();
  6437. var iTotSpclCdCnt = 0;
  6438. for ( var i = 0; i < ds_list3_clsp.rowcount; i++ )
  6439. {
  6440. var rowstatus = ds_list3_clsp.getRowType(i);
  6441. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  6442. var snglcalcscorcd = ds_list3_clsp.getColumn(i, "snglcalcscorcd");
  6443. var edilnno = ds_list3_clsp.getColumn(i, "edilnno");
  6444. var seqno = ds_list3_clsp.getColumn(i, "seqno");
  6445. var clodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  6446. var clsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  6447. var mpsno = ds_list3_clsp.getColumn(i, "mpsno");
  6448. if ( rowstatus != 1 && spclcd == "JX999" )
  6449. {
  6450. var delclspNode = ds_send_item3_delclsp;
  6451. var max = delclspNode.addRow();
  6452. delclspNode.addColumn("delunitflag", "string");
  6453. delclspNode.setColumn(max, "delunitflag", "J");
  6454. var oldspclcd = ds_list3_clsp.getColumn(i, "oldspclcd");
  6455. if (oldspclcd)
  6456. {
  6457. delclspNode.setColumn(max, "delspclcd", oldspclcd);
  6458. }
  6459. else
  6460. {
  6461. delclspNode.setColumn(max, "delspclcd", spclcd);
  6462. }
  6463. delclspNode.setColumn(max, "delusermemoyn", "N");
  6464. delclspNode.setColumn(max, "delcalcscorcd", snglcalcscorcd);
  6465. if (rowstatus == 4)
  6466. {
  6467. var initedilnno = ds_list3_clsp.getColumn(i, "initedilnno");
  6468. delclspNode.setColumn(max, "deledilnno", initedilnno);
  6469. }
  6470. else
  6471. {
  6472. delclspNode.setColumn(max, "deledilnno", edilnno);
  6473. }
  6474. delclspNode.setColumn(max, "delseqno" , seqno);
  6475. delclspNode.setColumn(max, "delclsoyn", clsoyn);
  6476. delclspNode.setColumn(max, "delmpsno" , mpsno);
  6477. }
  6478. if (rowstatus != 1 && rowstatus != 8 && spclcd == "JX999")
  6479. {
  6480. var iSpclCdCnt = 0;
  6481. var spclmemo = ds_list3_clsp.getColumn(i, "spclspec");
  6482. var repeat = ds_list3_clsp.getColumn(i, "rowstat");
  6483. var iSpclCdTotLength = utlf_getStringLength(spclmemo);
  6484. var insCharTotCnt = 0;
  6485. if (iSpclCdTotLength > 350)
  6486. {
  6487. var iLen = 0;
  6488. var iStartInx = 0;
  6489. var iCharCnt = 0;
  6490. for ( var j = 0; j < spclmemo.length; j++ )
  6491. {
  6492. var sBit = spclmemo.charAt(j);
  6493. iCharCnt++;
  6494. if (escape(sBit).length > 4)
  6495. {
  6496. iLen = iLen + 2;
  6497. }
  6498. else
  6499. {
  6500. iLen = iLen + 1;
  6501. }
  6502. if (iLen == 350 || iLen > 350)
  6503. {
  6504. iTotSpclCdCnt = ds_send_item3_lnunitmemo.addRow();
  6505. iSpclCdCnt++;
  6506. if (iLen == 350)
  6507. {
  6508. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclspec", spclmemo.substr(iStartInx, iCharCnt));
  6509. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "calcscorcd", snglcalcscorcd);
  6510. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "edilnno", edilnno);
  6511. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clodseqno", clodseqno);
  6512. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clsoyn", clsoyn);
  6513. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "mpsno", mpsno);
  6514. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "rowstat", repeat);
  6515. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclcd", "JX999");
  6516. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "usermemoyn", "N");
  6517. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "unitflag", "J");
  6518. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "workflag", "12");
  6519. iStartInx += iCharCnt;
  6520. insCharTotCnt += 350;
  6521. }
  6522. else if (iLen > 350)
  6523. {
  6524. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclspec", spclmemo.substr(iStartInx, iCharCnt));
  6525. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "calcscorcd", snglcalcscorcd);
  6526. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "edilnno", edilnno);
  6527. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clodseqno", clodseqno);
  6528. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clsoyn", clsoyn);
  6529. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "mpsno", mpsno);
  6530. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "rowstat", repeat);
  6531. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclcd", "JX999");
  6532. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "usermemoyn", "N");
  6533. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "unitflag", "J");
  6534. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "workflag", "12");
  6535. iStartInx += (iCharCnt - 1);
  6536. j--;
  6537. insCharTotCnt += 349;
  6538. }
  6539. iCharCnt = 0;
  6540. iLen = 0;
  6541. }
  6542. }
  6543. if (iSpclCdTotLength != insCharTotCnt)
  6544. {
  6545. iTotSpclCdCnt = ds_send_item3_lnunitmemo.addRow();
  6546. iSpclCdCnt++;
  6547. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclspec", spclmemo.substr(iStartInx, iCharCnt));
  6548. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "calcscorcd", snglcalcscorcd);
  6549. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "edilnno", edilnno);
  6550. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clodseqno", clodseqno);
  6551. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clsoyn", clsoyn);
  6552. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "mpsno", mpsno);
  6553. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "rowstat", repeat);
  6554. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclcd", "JX999");
  6555. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "usermemoyn", "N");
  6556. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "unitflag", "J");
  6557. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "workflag", "12");
  6558. }
  6559. }
  6560. else if (iSpclCdTotLength > 0)
  6561. {
  6562. iTotSpclCdCnt = ds_send_item3_lnunitmemo.addRow();
  6563. iSpclCdCnt++;
  6564. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclspec", spclmemo);
  6565. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "calcscorcd", snglcalcscorcd);
  6566. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "edilnno", edilnno);
  6567. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clodseqno", clodseqno);
  6568. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "clsoyn", clsoyn);
  6569. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "mpsno", mpsno);
  6570. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "rowstat", repeat);
  6571. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "spclcd", "JX999");
  6572. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "usermemoyn", "N");
  6573. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "unitflag", "J");
  6574. ds_send_item3_lnunitmemo.setColumn(iTotSpclCdCnt, "workflag", "12");
  6575. }
  6576. }
  6577. }
  6578. }
  6579. /****************************************************************************************
  6580. * Argument : function
  6581. * Description : CLOD 테이블에 저장할 정보가 올바른지 확인한다.
  6582. ****************************************************************************************/
  6583. function lf_fCheckSaveInAftJudgInfoCLOD()
  6584. {
  6585. var clodList = ds_list2_clod.rowcount;
  6586. for ( var i = clodList-1; i >= 0; i-- )
  6587. {
  6588. var rowstatus = ds_list2_clod.getRowType(i);
  6589. var seqno = ds_list2_clod.getColumn(i, "seqno");
  6590. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  6591. var basecd = ds_list2_clod.getColumn(i, "basecd");
  6592. var drugqty = ds_list2_clod.getColumn(i, "drugqty");
  6593. var edidrugqty = ds_list2_clod.getColumn(i, "edidrugqty");
  6594. var tims = ds_list2_clod.getColumn(i, "tims");
  6595. var dayno = ds_list2_clod.getColumn(i, "dayno");
  6596. var edidayno = ds_list2_clod.getColumn(i, "edidayno");
  6597. var ordfromdd = ds_list2_clod.getColumn(i, "ordfromdd");
  6598. var ordtodd = ds_list2_clod.getColumn(i, "ordtodd");
  6599. if (rowstatus != 8 && utlf_isNull(seqno) && utlf_isNull(snglcalcscorcd) && utlf_isNull(basecd) && utlf_isNull(drugqty) && utlf_isNull(tims) && utlf_isNull(dayno) && utlf_isNull(edidrugqty) && utlf_isNull(edidayno) && utlf_isNull(ordtodd))
  6600. {
  6601. ds_list2_clod.deleteRow(i);
  6602. }
  6603. }
  6604. clodList = ds_list2_clod.rowcount;
  6605. if (clodList < 0)
  6606. {
  6607. return false;
  6608. }
  6609. for ( var i = 0; i < clodList; i++ )
  6610. {
  6611. var seqno = ds_list2_clod.getColumn(i, "seqno");
  6612. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  6613. var basecd = ds_list2_clod.getColumn(i, "basecd");
  6614. var drugqty = ds_list2_clod.getColumn(i, "drugqty");
  6615. var edidrugqty = ds_list2_clod.getColumn(i, "edidrugqty");
  6616. var tims = ds_list2_clod.getColumn(i, "tims");
  6617. var dayno = ds_list2_clod.getColumn(i, "dayno");
  6618. var edidayno = ds_list2_clod.getColumn(i, "edidayno");
  6619. var ordfromdd = ds_list2_clod.getColumn(i, "ordfromdd");
  6620. var ordtodd = ds_list2_clod.getColumn(i, "ordtodd");
  6621. if (!utlf_isNull(snglcalcscorcd) && utlf_isNull(basecd))
  6622. {
  6623. if (utlf_isNull(ordfromdd)|| utlf_isNull(ordtodd))
  6624. {
  6625. sysf_messageBox("수가코드 '" + snglcalcscorcd + "'의 처방일자 정보가", "I004");
  6626. return false;
  6627. }
  6628. else if (utlf_isNull(drugqty)|| utlf_isNull(tims) || utlf_isNull(dayno) || utlf_isNull(edidrugqty) || utlf_isNull(edidayno))
  6629. {
  6630. sysf_messageBox("수가코드 '" + snglcalcscorcd + "'의 투여량 정보가", "I004");
  6631. return false;
  6632. }
  6633. }
  6634. }
  6635. return true;
  6636. }
  6637. /****************************************************************************************
  6638. * Argument : function
  6639. * Description : PIFHIUNC 재청구 저장시 차액이 발생했는지 체크
  6640. ****************************************************************************************/
  6641. function lf_fCheckSaveReClamChangeAmt()
  6642. {
  6643. if (ds_main_item1_clbs.getColumn(0, "clamflagcd") == "1" && ds_main_item1_clbs.getColumn(0, "recalcyn") == "Y")
  6644. {
  6645. return true;
  6646. }
  6647. else
  6648. {
  6649. return false;
  6650. }
  6651. }
  6652. /****************************************************************************************
  6653. * Argument : function
  6654. * Description : 재청구 차액발생 사유입력
  6655. ****************************************************************************************/
  6656. function lf_fSetReClamChgAmtResncd()
  6657. {
  6658. ds_send_item8_pifhiunc.clearData();
  6659. ds_send_item8_pifhiunc.addRow();
  6660. var rtn = frmf_modal("SPPID22800", "SPPID22800", "", "", "", "", "", "", "", "", "", "", "M");
  6661. if (!utlf_isNull(rtn))
  6662. {
  6663. var resncd = rtn.sCdid;
  6664. if (!utlf_isNull(resncd))
  6665. {
  6666. ds_send_item8_pifhiunc.setColumn(0, "chgamtresncd", resncd);
  6667. }
  6668. return resncd;
  6669. }
  6670. }
  6671. /****************************************************************************************
  6672. * Argument : onclick
  6673. * Description : 저장 버튼
  6674. ****************************************************************************************/
  6675. function grp_biz_btn_save_onclick(obj:Button, e:ClickEventInfo)
  6676. {
  6677. // 심사중 B값 삭제 -> A:미심으로 저장
  6678. // [2015.06.23] 심사상태완료 -> 저장 가능하도록
  6679. if(obj.visible)
  6680. {
  6681. lf_fSaveAftJudg("B")
  6682. }
  6683. else
  6684. {
  6685. sysf_messageBox("비활성 상태입니다. 진행","E001");
  6686. }
  6687. }
  6688. /****************************************************************************************
  6689. * Argument : funtion
  6690. * Description : 입원 저장 버튼 이벤트 함수
  6691. ****************************************************************************************/
  6692. function lf_fSaveAftJudg(judgendyn)
  6693. {
  6694. grp_biz.grd_clodhist.setFocus();
  6695. ds_send_item2_incd.clearData();
  6696. ds_send_item2_incd.addRow();
  6697. //ds_send_item3_delclsp.clearData();
  6698. ds_send_item3_lnunitmemo.clearData();
  6699. ds_send_item4_endclbs.clearData();
  6700. ds_send_item5_mech.clearData();
  6701. var selectedRow = lgv_ds_rslt.getColumn(0, "selectedRow");
  6702. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  6703. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  6704. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  6705. var pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  6706. var workflag = ds_main_item1_clbs.getColumn(0, "workflag");
  6707. var ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  6708. var insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  6709. var clamflagcd = ds_main_item1_clbs.getColumn(0, "clamflagcd");
  6710. var isValidCheck = true;
  6711. var cutprcpyn = "";
  6712. var trgtManWindow = "";
  6713. trgtManWindow = frmf_getChildWindow(lgv_trgtManWindow);
  6714. if (!utlf_isNull(trgtManWindow))
  6715. {
  6716. cutprcpyn = trgtManWindow.ds_send.getColumn(0, "cutprcpsel");
  6717. }
  6718. if (!utlf_isNull(clamym))
  6719. {
  6720. var saveNoMsg = "";
  6721. var saveOkMsg = "[계산]";
  6722. ds_main_item1_clbs.updatecontrol = false;
  6723. ds_main_item1_clbs.setRowType(0,4);
  6724. ds_main_item1_clbs.updatecontrol = true;
  6725. ds_main_item1_clbs.addColumn("clbsupdateyn", "string");
  6726. ds_main_item1_clbs.addColumn("recalcyn", "string");
  6727. if (lf_fCheckSaveInAftJudgCLBS())
  6728. {
  6729. lf_save_grd_ds(ds_main_item1_clbs, ds_send_item1_clbs);
  6730. if (ds_send_item1_clbs.rowcount > 0)
  6731. {
  6732. saveOkMsg = "[인적사항] ";
  6733. ds_send_item1_clbs.setColumn(0, "clbsupdateyn", "Y");
  6734. ds_send_item1_clbs.setColumn(0, "suppkind" , ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  6735. var init_offcharm = ds_hidden_item1_initclbs.getColumn(0, "offcharm");
  6736. var current_offcharm = ds_main_item1_clbs.getColumn(0, "offcharm");
  6737. if (init_offcharm != current_offcharm)
  6738. {
  6739. ds_send_item1_clbs.setColumn(0, "recalcyn", "Y");
  6740. }
  6741. }
  6742. else
  6743. {
  6744. saveNoMsg = "[인적사항] ";
  6745. dsf_copyDs(ds_send_item1_clbs, ds_main_item1_clbs);
  6746. ds_send_item1_clbs.setColumn(0, "clbsupdateyn", "Y");
  6747. }
  6748. ds_send_item1_clbs.addColumn("judgendyn", "string");
  6749. ds_send_item1_clbs.setColumn(0, "judgendyn", judgendyn);
  6750. }
  6751. else
  6752. {
  6753. isValidCheck = false;
  6754. }
  6755. var initmemo = dsf_getDsCSV(ds_hidden_item1_initmemo, 0);
  6756. var currentmemo = dsf_getDsCSV(ds_main_item1_memo, 0);
  6757. if (initmemo != currentmemo)
  6758. {
  6759. var judgmemo = String(ds_main_item1_memo.getColumn(0, "judgmemo")).trim();
  6760. var judgmemorepeat = ds_main_item1_memo.getColumn(0, "judgmemorepeat");
  6761. var edimemo = String(ds_main_item1_memo.getColumn(0, "edimemo")).trim();
  6762. var edimemorepeat = ds_main_item1_memo.getColumn(0, "edimemorepeat");
  6763. var noChange = true;
  6764. if (judgmemo != String(ds_hidden_item1_initmemo.getColumn(0, "judgmemo")).trim())
  6765. {
  6766. lf_fSetJudgEDIMemo(judgmemo, "Y");
  6767. noChange = false; // 심사자메모가 변경된 경우임
  6768. }
  6769. else if (!utlf_isNull(judgmemo) && judgmemorepeat != ds_hidden_item1_initmemo.getColumn(0, "judgmemorepeat"))
  6770. {
  6771. lf_fSetJudgEDIMemo(judgmemo, "Y");
  6772. noChange = false; // 심사자메모 반복 설정이 변경된 경우임
  6773. }
  6774. if (edimemo != String(ds_hidden_item1_initmemo.getColumn(0, "edimemo")).trim())
  6775. {
  6776. lf_fSetJudgEDIMemo(edimemo, "N");
  6777. noChange = false; // EDI청구메모가 변경된 경우임
  6778. }
  6779. else if (!utlf_isNull(edimemo) && edimemorepeat != ds_hidden_item1_initmemo.getColumn(0, "edimemorepeat"))
  6780. {
  6781. lf_fSetJudgEDIMemo(edimemo, "N");
  6782. noChange = false; // EDI청구메모 반복 설정이 변경된 경우임
  6783. }
  6784. if (noChange == false)
  6785. {
  6786. saveOkMsg += "[심사메모] ";
  6787. }
  6788. else
  6789. {
  6790. saveNoMsg += "[심사메모] ";
  6791. }
  6792. }
  6793. else
  6794. {
  6795. saveNoMsg += "[심사메모] ";
  6796. }
  6797. // ds_send_list10_judgmemo.clearData();
  6798. // lf_save_grd_ds(ds_list10_judgmemo, ds_send_list10_judgmemo);
  6799. //
  6800. // if (ds_send_list10_judgmemo.rowcount > 0)
  6801. // {
  6802. // for ( var i = 0; i < ds_send_list10_judgmemo.rowcount; i++ )
  6803. // {
  6804. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "clamym")))
  6805. // {
  6806. // ds_send_list10_judgmemo.setColumn(i, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  6807. // }
  6808. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "clamdg")))
  6809. // {
  6810. // ds_send_list10_judgmemo.setColumn(i, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  6811. // }
  6812. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "pidsn")))
  6813. // {
  6814. // ds_send_list10_judgmemo.setColumn(i, "pidsn", ds_main_item1_clbs.getColumn(0, "pidsn"));
  6815. // }
  6816. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "usermemoyn")))
  6817. // {
  6818. // ds_send_list10_judgmemo.setColumn(i, "usermemoyn", "Y");
  6819. // }
  6820. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "unitflag")))
  6821. // {
  6822. // ds_send_list10_judgmemo.setColumn(i, "unitflag", "M");
  6823. // }
  6824. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "spclcd")))
  6825. // {
  6826. // ds_send_list10_judgmemo.setColumn(i, "spclcd", "MX999");
  6827. // }
  6828. // if (utlf_isNull(ds_send_list10_judgmemo.getColumn(i, "clsoyn")))
  6829. // {
  6830. // ds_send_list10_judgmemo.setColumn(i, "clsoyn", "N");
  6831. // }
  6832. // }
  6833. // }
  6834. // else
  6835. // {
  6836. // saveOkMsg += "[심사메모] ";
  6837. // }
  6838. //
  6839. // ds_send_list11_edimemo.clearData();
  6840. // lf_save_grd_ds(ds_list11_edimemo, ds_send_list11_edimemo);
  6841. //
  6842. // if (ds_send_list11_edimemo.rowcount > 0)
  6843. // {
  6844. // for ( var i = 0; i < ds_send_list11_edimemo.rowcount; i++ )
  6845. // {
  6846. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "clamym")))
  6847. // {
  6848. // ds_send_list11_edimemo.setColumn(i, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  6849. // }
  6850. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "clamdg")))
  6851. // {
  6852. // ds_send_list11_edimemo.setColumn(i, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  6853. // }
  6854. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "pid")))
  6855. // {
  6856. // ds_send_list11_edimemo.setColumn(i, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  6857. // }
  6858. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "pidsn")))
  6859. // {
  6860. // ds_send_list11_edimemo.setColumn(i, "pidsn", ds_main_item1_clbs.getColumn(0, "pidsn"));
  6861. // }
  6862. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "usermemoyn")))
  6863. // {
  6864. // ds_send_list11_edimemo.setColumn(i, "usermemoyn", "N");
  6865. // }
  6866. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "unitflag")))
  6867. // {
  6868. // ds_send_list11_edimemo.setColumn(i, "unitflag", "M");
  6869. // }
  6870. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "spclcd")))
  6871. // {
  6872. // ds_send_list11_edimemo.setColumn(i, "spclcd", "MX999");
  6873. // }
  6874. // if (utlf_isNull(ds_send_list11_edimemo.getColumn(i, "clsoyn")))
  6875. // {
  6876. // ds_send_list11_edimemo.setColumn(i, "clsoyn", "N");
  6877. // }
  6878. // }
  6879. // }
  6880. // else
  6881. // {
  6882. // saveOkMsg += "[MX999] ";
  6883. // }
  6884. if (lf_fCheckSaveInAftJudgInfoCLDI(judgendyn))
  6885. {
  6886. for ( var i = 0; i < ds_list1_cldi.rowcount; i++ )
  6887. {
  6888. var diagseq = ds_list1_cldi.getColumn(i, "diagseq");
  6889. if (ds_list1_cldi.getRowType(i) == 8 && String(diagseq).substr(0, 1) == "D")
  6890. {
  6891. ds_list1_cldi.setColumn(i, "diagseq", String(diagseq).substr(1, diagseq.length));
  6892. }
  6893. ds_list1_cldi.updatecontrol = false;
  6894. if (utlf_isNull(ds_list1_cldi.getColumn(i, "estmspclcd")))
  6895. {
  6896. ds_list1_cldi.setColumn(i, "estmspclcd", "-");
  6897. }
  6898. if (utlf_isNull(ds_list1_cldi.getColumn(i, "wundresncd")))
  6899. {
  6900. ds_list1_cldi.setColumn(i, "wundresncd", "-");
  6901. }
  6902. if (ds_list1_cldi.getColumn(i, "diagkindcd") == "1")
  6903. {
  6904. ds_list1_cldi.setColumn(i, "diagkindcd", "R");
  6905. }
  6906. if (utlf_isNull(ds_list1_cldi.getColumn(i, "clamdeptcd")))
  6907. {
  6908. ds_list1_cldi.setColumn(i, "clamdeptcd", ds_main_item1_clbs.getColumn(0, "clamdeptcd"));
  6909. }
  6910. ds_list1_cldi.updatecontrol = true;
  6911. }
  6912. }
  6913. else
  6914. {
  6915. isValidCheck = false;
  6916. }
  6917. if (lf_fCheckSaveInAftJudgInfoCLSP())
  6918. {
  6919. ds_list3_clsp.updatecontrol = false;
  6920. if(ds_list3_clsp.rowcount > 0)
  6921. {
  6922. lf_fSetSpclSpecJX999();
  6923. ds_list3_clsp.addColumn("usermemoyn", "string");
  6924. ds_list3_clsp.addColumn("calcscorcd", "string");
  6925. for(var i = 0; i < ds_list3_clsp.rowcount; i++)
  6926. {
  6927. ds_list3_clsp.setColumn(i, "calcscorcd", ds_list3_clsp.getColumn(i, "snglcalcscorcd"));
  6928. var spclLnNo = ds_list3_clsp.getColumn(i, "seqno");
  6929. if ( !utlf_isNull(spclLnNo))
  6930. {
  6931. if (spclLnNo.substr(0, 1) == "D")
  6932. {
  6933. ds_list3_clsp.setColumn(i, "seqno", spclLnNo.substr(1, spclLnNo.length));
  6934. }
  6935. }
  6936. }
  6937. }
  6938. else
  6939. {
  6940. saveNoMsg += "[특정내역] ";
  6941. }
  6942. ds_list3_clsp.updatecontrol = true;
  6943. }
  6944. else
  6945. {
  6946. isValidCheck = false;
  6947. }
  6948. var amtchk = 0;
  6949. var chkCount = 0;
  6950. var arrLinno = new Array();
  6951. if (lf_fCheckSaveInAftJudgInfoCLOD())
  6952. {
  6953. if(ds_list2_clod.rowcount > -1)
  6954. {
  6955. ds_list2_clod.updatecontrol = false;
  6956. ds_list2_clod.enableevent = false;
  6957. ds_list2_clod.addColumn("hospaddamt", "BIGDECIMAL");
  6958. for( var i = 0; i < ds_list2_clod.rowcount; i++)
  6959. {
  6960. if(ds_list2_clod.getColumn(i, "payflag") == "-")
  6961. {
  6962. ds_list2_clod.setColumn(i, "payflag", "0");
  6963. }
  6964. ds_list2_clod.setColumn(i, "hospaddamt", ds_list2_clod.getColumn(i, "edihospaddamt"));
  6965. var ediamt = ds_list2_clod.getColumn(i, "ediamt");
  6966. var ediunitcost = ds_list2_clod.getColumn(i, "ediunitcost");
  6967. var edidrugqty = parseFloat(ds_list2_clod.getColumn(i, "edidrugqty"));
  6968. var tims = ds_list2_clod.getColumn(i, "tims");
  6969. var edidayno = ds_list2_clod.getColumn(i, "edidayno");
  6970. if (ediamt != utlf_round(ediunitcost * (edidrugqty * tims * edidayno), -1) ) {
  6971. lf_setAlramMessage("줄번호:" + ds_list2_clod.getColumn(i, "edilnno") + ", 금액오류 발견 " + ediamt + "(" + (ediunitcost * (edidrugqty * tims * edidayno)).toFixed(0) +") ");
  6972. amtchk++;
  6973. }
  6974. //시작일자 단가와 종료일자 단가비교해서 다르면 팝업하는 로직 추가 by 설승민 2019/12/13
  6975. if(ds_main_item1_clbs.getColumn(0,"ioflag") == "I" && ds_list2_clod.getColumn(i,"matractflag") == "4" && (ds_list2_clod.getRowType(i) == '2' || ds_list2_clod.getRowType(i) == '4'
  6976. || ds_list2_clod.getColumn(i,"rowstat") == "U" || ds_list2_clod.getColumn(i,"rowstat") == "I")){
  6977. ds_send_mechchk.clearData();
  6978. ds_send_mechchk.addRow();
  6979. ds_send_mechchk.setColumn(0,"instcd",ds_main_item1_clbs.getColumn(0,"instcd"));
  6980. ds_send_mechchk.setColumn(0,"insukind",ds_main_item1_clbs.getColumn(0,"insukind"));
  6981. ds_send_mechchk.setColumn(0,"snglcalcscorcd",ds_list2_clod.getColumn(i,"snglcalcscorcd"));
  6982. ds_send_mechchk.setColumn(0,"clbsordfromdd",ds_list2_clod.getColumn(i,"ordfromdd"));
  6983. ds_send_mechchk.setColumn(0,"clbsordtodd",ds_list2_clod.getColumn(i,"ordtodd"));
  6984. var oParam = {};
  6985. oParam.service = "aftjudgapp.InAftJudg";
  6986. oParam.method = "reqGetMechDrgChk";
  6987. oParam.inds = "req=ds_send_mechchk";
  6988. oParam.outds = "ds_main_mechfromchk=mechFromChk ds_main_mechtochk=mechToChk";
  6989. oParam.async = false;
  6990. tranf_submit(oParam);
  6991. if(ds_main_mechfromchk.getColumn(0,"insurbpnt") != ds_main_mechtochk.getColumn(0,"insurbpnt")){
  6992. arrLinno[chkCount] = ds_list2_clod.getColumn(i,"edilnno");
  6993. chkCount++;
  6994. }
  6995. }
  6996. }
  6997. if(chkCount > 0){
  6998. var ans = sysf_messageBox("줄번호 " + arrLinno +"번 변경일자와 실시시작일의 단가가 상이합니다. 계속진행" ,"S001");
  6999. if (ans == 6){
  7000. }else{
  7001. isValidCheck = false;
  7002. }
  7003. chkCount = 0;
  7004. }
  7005. ds_list2_clod.enableevent = true;
  7006. ds_list2_clod.updatecontrol = true;
  7007. }
  7008. else
  7009. {
  7010. saveNoMsg += "[처방] ";
  7011. }
  7012. }
  7013. else
  7014. {
  7015. isValidCheck = false;
  7016. }
  7017. if (amtchk != 0) {
  7018. var ans = sysf_messageBox("금액 오류사항이 있습니다. 계속진행", "S001"); ///수정사항이 있습니다. 저장하시려면 예(Yes)\n아니면 아니오(No)
  7019. if (ans == 6)
  7020. {
  7021. } else {
  7022. isValidCheck = false;
  7023. }
  7024. }
  7025. if (lf_fCheckSaveOutAftJudgInfoCLOP())
  7026. {
  7027. // 원외처방
  7028. if (ds_list7_clop.rowcount > 0)
  7029. {
  7030. ds_send_item1_clbs.addColumn("reclopedilnnoyn", "string");
  7031. saveOkMsg += "[원외처방] ";
  7032. ds_send_item1_clbs.setColumn(0,"reclopedilnnoyn","Y")
  7033. }
  7034. else
  7035. {
  7036. saveNoMsg += "[원외처방] ";
  7037. }
  7038. }
  7039. else
  7040. {
  7041. isValidCheck = false;
  7042. }
  7043. if (lf_fCheckSaveReClamChangeAmt())
  7044. {
  7045. var resncd = lf_fSetReClamChgAmtResncd();
  7046. if (!utlf_isNull(resncd))
  7047. {
  7048. saveOkMsg += "[재청구 차액발생사유] ";
  7049. }
  7050. else
  7051. {
  7052. saveNoMsg += "[재청구 차액발생사유] ";
  7053. }
  7054. }
  7055. var drgyn = ds_main_item1_clbs.getColumn(0, "drgyn");
  7056. if (drgyn == 'Y') {
  7057. ds_send_item1_clbs.setColumn(0, "recalcyn", "N");; // 저장 시에 재계산할지 여부를 설정함
  7058. } else {
  7059. ds_send_item1_clbs.setColumn(0, "recalcyn", "Y"); // 저장 시에 재계산할지 여부를 설정함
  7060. }
  7061. if (grp_biz.btn_end.enable == false && ds_main_item1_clbs.getColumn(0, "judgendyn") == "D") {
  7062. sysf_messageBox("버튼이 비활성화 이거나 심사일로 부터 15일이 경과 된 경우 완료 할 수", "I004");
  7063. return false;
  7064. }
  7065. // 중증, 산정특례 여부 체크
  7066. if (lf_fGetDiagSpclcdCheck() == false) {
  7067. isValidCheck = false;
  7068. return false;
  7069. } else {
  7070. }
  7071. if (String(clamdg).substr(0,2) == "10" && clamflagcd != String(clamdg).substr(0,1)) {
  7072. sysf_messageBox("청구차수와 청구구분이 달라 저장", "I004");
  7073. isValidCheck = false;
  7074. }
  7075. //추가청구 반송건은 보완삭제 후 추가청구 해야 합니다.
  7076. if ( isValidCheck )
  7077. {
  7078. if (!utlf_isNull(saveOkMsg) )
  7079. {
  7080. ds_send_item1_clbs.addColumn("insukind", "string");
  7081. ds_send_item1_clbs.setColumn(0, "insukind", ds_main_item1_clbs.getColumn(0, "insukind"));
  7082. if (utlf_isNull(ds_send_item1_clbs.getColumn(0, "clbtworkflag")))
  7083. {
  7084. ds_send_item1_clbs.setColumn(0, "clbtworkflag", ds_main_item1_clbs.getColumn(0, "clbtworkflag"));
  7085. }
  7086. // dsf_setDefaultVal(ds_send_delmemo, "delclsoyn:N");
  7087. dsf_setDefaultVal(ds_send_list10_judgmemo, "usermemoyn:Y,unitflag:M,spclcd:MX999,clsoyn:N");
  7088. dsf_setDefaultVal(ds_send_list11_edimemo, "usermemoyn:N,unitflag:M,spclcd:MX999,clsoyn:N");
  7089. dsf_setDefaultVal(ds_send_item1_clbs, "insuno:-,certno:-,rsvordgubn:N,ownbflag:-,oprcpdayno:0,direcprcptims:0,ordtims:0,prockindflag:-,offcharm:0,reclopedilnnoyn:N,fixrateyn:-,suppkindchgresn:-,rareobstflag:-");
  7090. dsf_setDefaultVal(ds_send_item3_lnunitmemo, "usermemoyn:N,unitflag:J,spclcd:JX999,clsoyn:N,workflag:12");
  7091. ds_list3_clsp.updatecontrol = false;
  7092. dsf_setDefaultVal(ds_list3_clsp, "usermemoyn:N,clsoyn:N,mpsno:-");
  7093. ds_list3_clsp.updatecontrol = true;
  7094. ds_list2_clod.updatecontrol = false;
  7095. ds_list2_clod.enableevent = false;
  7096. dsf_setDefaultVal(ds_list2_clod, "basecd:-,estmmncd:0000,updtdd:-,toot:-,hosinresncd:00,adjtresncd:-,adjtresndesc:-,edicd:-,prcpflag:1,spcljudgyn:N,calcappyn:Y,payflag:0,hospaddamt:0");
  7097. ds_list2_clod.enableevent =true;
  7098. ds_list2_clod.updatecontrol = true;
  7099. ds_list7_clop.updatecontrol = false;
  7100. ds_list7_clop.enableevent = false;
  7101. dsf_setDefaultVal(ds_list7_clop, "adjtresncd:-");
  7102. ds_list7_clop.enableevent =true;
  7103. ds_list7_clop.updatecontrol = true;
  7104. var oParam = {};
  7105. oParam.id = "TXPID20301";
  7106. oParam.service = "aftjudgapp.InAftJudg";
  7107. oParam.method = "reqExeInAftJudg";
  7108. oParam.inds = "clbs=ds_send_item1_clbs judgmemo=ds_send_list10_judgmemo edimemo=ds_send_list11_edimemo lnunitmemo=ds_send_item3_lnunitmemo cldi=ds_list1_cldi:U clsp=ds_list3_clsp:U clod=ds_list2_clod:U pifhiunc=ds_send_item8_pifhiunc clop=ds_list7_clop:U delmemo=ds_send_item3_delclsp";
  7109. oParam.async = false;
  7110. oParam.callback = "cf_TXPID20301";
  7111. tranf_submit(oParam);
  7112. if (arErrorCode.pop("TXPID20301") > -1){
  7113. if (insukindcd == "11" || insukindcd == "21" || insukindcd == "22") {
  7114. ds_main_clod_chk.clearData();
  7115. var oParam = {};
  7116. oParam.id = "TRPID20601";
  7117. oParam.service = "aftjudgapp.InAftJudg";
  7118. oParam.method = "reqGetPidhclodCostChk";
  7119. oParam.inds = "req=ds_send_item1_clbs";
  7120. oParam.outds = "ds_main_clod_chk=getPidhclodCostChk";
  7121. oParam.async = false;
  7122. tranf_submit(oParam);
  7123. if (ds_main_clod_chk.rowcount > 0) {
  7124. for( var i = 0; i < ds_main_clod_chk.rowcount; i++)
  7125. {
  7126. var edilnno = ds_main_clod_chk.getColumn(i, "edilnno");
  7127. var ediunitcost = ds_main_clod_chk.getColumn(i, "ediunitcost");
  7128. var mechunitcost = ds_main_clod_chk.getColumn(i, "mechunitcost");
  7129. var snglcalcscorcd = ds_main_clod_chk.getColumn(i, "snglcalcscorcd");
  7130. lf_setAlramMessage("줄번호:" + edilnno + ", 단가오류 발견 현재: " + ediunitcost + "(수가: " + mechunitcost +") [" + snglcalcscorcd + "]");
  7131. }
  7132. return false;
  7133. }
  7134. }
  7135. if (judgendyn == "B")
  7136. {
  7137. var selectedRow = lgv_ds_rslt.getColumn(0, "selectedRow");
  7138. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  7139. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  7140. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  7141. var pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  7142. var tootpopupyn = "";
  7143. // 저장 후 결과를 다시 조회하기 위해
  7144. lgv_ds_rslt.clearData();
  7145. lgv_ds_rslt.addRow();
  7146. lgv_ds_rslt.setColumn(0, "clamym", clamym);
  7147. lgv_ds_rslt.setColumn(0, "clamdg", clamdg);
  7148. lgv_ds_rslt.setColumn(0, "pid" , pid);
  7149. lgv_ds_rslt.setColumn(0, "pidsn" , pidsn);
  7150. lgv_ds_rslt.setColumn(0, "selectedRow", selectedRow);
  7151. lgv_ds_rslt.setColumn(0, "cutprcpyn", cutprcpyn);
  7152. ds_hidden.setColumn(0, "reselect", "N");
  7153. lf_fGetAftJudgMngt(lgv_ds_rslt);
  7154. lf_fSetJudgSaveState("B"); // 심사완료여부 (P0151) - B: 심사중
  7155. }
  7156. return "true";
  7157. }
  7158. } else if (saveNoMsg) {
  7159. if (judgendyn != "B")
  7160. {
  7161. return "false";
  7162. }
  7163. }
  7164. }
  7165. else
  7166. {
  7167. for ( var j = 0; j < ds_list1_cldi.rowcount; j++ )
  7168. {
  7169. if (ds_list1_cldi.getRowType(j) == 8)
  7170. {
  7171. var diagseq = ds_list1_cldi.getColumn(j, "diagseq");
  7172. ds_list1_cldi.setColumn(j, "diagseq", "D" + diagseq);
  7173. }
  7174. }
  7175. if (ds_list1_cldi.rowcount == 1)
  7176. {
  7177. lf_fSpclGridInsertRow();
  7178. }
  7179. }
  7180. }
  7181. else
  7182. {
  7183. sysf_messageBox("변경된 정보를 저장할 사후심사 대상자가", "I004");
  7184. return null;
  7185. }
  7186. }
  7187. /****************************************************************************************
  7188. * Argument : function
  7189. * Description : 저장시 체크 함수
  7190. ****************************************************************************************/
  7191. function lf_fCheckSaveInAftJudgCLBS()
  7192. {
  7193. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "clamym")))
  7194. {
  7195. sysf_messageBox("청구년월이", "I004");
  7196. return false;
  7197. }
  7198. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "clamdg")))
  7199. {
  7200. sysf_messageBox("청구차수가", "I004");
  7201. return false;
  7202. }
  7203. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "pid")))
  7204. {
  7205. sysf_messageBox("등록번호가", "I004");
  7206. return false;
  7207. }
  7208. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "patnm")))
  7209. {
  7210. sysf_messageBox("환자이름이", "I004");
  7211. return false;
  7212. }
  7213. var patrrgstno = ds_main_item1_clbs.getColumn(0, "patrrgstno");
  7214. if (String(patrrgstno).length != 13)
  7215. {
  7216. sysf_messageBox("주민번호가", "E016");
  7217. return false;
  7218. }
  7219. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "patrrgstno")))
  7220. {
  7221. sysf_messageBox("주민번호가", "I004");
  7222. return false;
  7223. }
  7224. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "insukindcd")))
  7225. {
  7226. sysf_messageBox("보험유형이", "I004");
  7227. return false;
  7228. }
  7229. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "suppkindcd")))
  7230. {
  7231. sysf_messageBox("보조유형이", "I004");
  7232. return false;
  7233. }
  7234. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "payownbrate")))
  7235. {
  7236. sysf_messageBox("올바른 보조유형을", "C002");
  7237. return false;
  7238. }
  7239. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "ordfildcd")))
  7240. {
  7241. sysf_messageBox("진료분야가", "I004");
  7242. return false;
  7243. }
  7244. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "orddeptcd")))
  7245. {
  7246. sysf_messageBox("진료과가", "I004");
  7247. return false;
  7248. }
  7249. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "orddrid")))
  7250. {
  7251. sysf_messageBox("주치의가", "I004");
  7252. return false;
  7253. }
  7254. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "arvpathcd")))
  7255. {
  7256. sysf_messageBox("도착경로가", "I004");
  7257. return false;
  7258. }
  7259. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "inpathcd")))
  7260. {
  7261. sysf_messageBox("입원경로가", "I004");
  7262. return false;
  7263. }
  7264. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "ordrsltcd")))
  7265. {
  7266. sysf_messageBox("진료결과가", "I004");
  7267. return false;
  7268. }
  7269. if (utlf_isNull(ds_main_item1_clbs.getColumn(0, "insuno")))
  7270. {
  7271. sysf_messageBox("조합기호가", "I004");
  7272. return false;
  7273. }
  7274. return true;
  7275. }
  7276. /****************************************************************************************
  7277. * Argument : function
  7278. * Description : 심사자메모, EDI청구메모를 특정내역 형식에 맞춰 설정한다.
  7279. ****************************************************************************************/
  7280. function lf_fSetJudgEDIMemo(spclmemo, usermemoyn)
  7281. {
  7282. var delclspNode = ds_send_item3_delclsp; //instance1.selectSingleNode("/root/send/item3/delclsp");
  7283. var max = delclspNode.addRow();
  7284. dsf_makeValue(ds_send_item3_delclsp, "delunitflag", "string", "M", max);
  7285. dsf_makeValue(ds_send_item3_delclsp, "delspclcd", "string", "MX999", max);
  7286. dsf_makeValue(ds_send_item3_delclsp, "delusermemoyn", "string", usermemoyn, max);
  7287. dsf_makeValue(ds_send_item3_delclsp, "delcalcscorcd", "string", "", max);
  7288. dsf_makeValue(ds_send_item3_delclsp, "deledilnno", "string", "", max);
  7289. dsf_makeValue(ds_send_item3_delclsp, "delseqno", "string", "", max);
  7290. dsf_makeValue(ds_send_item3_delclsp, "delclsoyn", "string", "N", max);
  7291. dsf_makeValue(ds_send_item3_delclsp, "delmpsno", "string", "", max);
  7292. var item3Path = "";
  7293. var item3Node = "";
  7294. var repeat = "";
  7295. if (usermemoyn == "Y")
  7296. {
  7297. item3Path = ds_send_list10_judgmemo; // "/root/send/item3/judgmemo[";
  7298. item3Node = "judg";
  7299. repeat = ds_main_item1_memo.getColumn(0, "judgmemorepeat");
  7300. }
  7301. else
  7302. {
  7303. item3Path = ds_send_list11_edimemo // "/root/send/item3/edimemo[";
  7304. item3Node = "edi";
  7305. repeat = ds_main_item1_memo.getColumn(0, "edimemorepeat");
  7306. }
  7307. var iSpclCdCnt = 0;
  7308. var iSpclCdTotLength = utlf_getStringLength(spclmemo);
  7309. var insCharTotCnt = 0;
  7310. var insusermemoyn = (item3Node == "judg" ? "Y" : "N");
  7311. if (iSpclCdTotLength > 350)
  7312. {
  7313. var iLen = 0;
  7314. var iStartInx = 0;
  7315. var iCharCnt = 0;
  7316. for (var i = 0; i < spclmemo.length; i++)
  7317. {
  7318. var sBit = spclmemo.charAt(i);
  7319. iCharCnt++;
  7320. if (escape(sBit).length > 4)
  7321. {
  7322. iLen = iLen + 2;
  7323. } else {
  7324. iLen = iLen + 1;
  7325. }
  7326. if (iLen == 350 || iLen > 350)
  7327. {
  7328. iSpclCdCnt = item3Path.addRow();
  7329. if (iLen == 350)
  7330. {
  7331. dsf_makeValue(item3Path, "spclspec", "string", spclmemo.substr(iStartInx, iCharCnt), iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"spclspec", spclmemo.substr(iStartInx, iCharCnt));
  7332. dsf_makeValue(item3Path, "rowstat", "string", repeat, iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"rowstat", repeat);
  7333. dsf_makeValue(item3Path, "unitflag", "string", "M", iSpclCdCnt);
  7334. dsf_makeValue(item3Path, "spclcd", "string", "MX999", iSpclCdCnt);
  7335. dsf_makeValue(item3Path, "clsoyn", "string", "N", iSpclCdCnt);
  7336. dsf_makeValue(item3Path, "usermemoyn", "string", insusermemoyn, iSpclCdCnt);
  7337. iStartInx += iCharCnt;
  7338. insCharTotCnt += 350;
  7339. }
  7340. else if (iLen > 350)
  7341. {
  7342. dsf_makeValue(item3Path, "spclspec", "string", spclmemo.substr(iStartInx, iCharCnt - 1), iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"spclspec", spclmemo.substr(iStartInx, iCharCnt - 1));
  7343. dsf_makeValue(item3Path, "rowstat", "string", repeat, iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"rowstat", repeat);
  7344. dsf_makeValue(item3Path, "unitflag", "string", "M", iSpclCdCnt);
  7345. dsf_makeValue(item3Path, "spclcd", "string", "MX999", iSpclCdCnt);
  7346. dsf_makeValue(item3Path, "clsoyn", "string", "N", iSpclCdCnt);
  7347. dsf_makeValue(item3Path, "usermemoyn", "string", insusermemoyn, iSpclCdCnt);
  7348. iStartInx += (iCharCnt - 1);
  7349. i--;
  7350. insCharTotCnt += 349;
  7351. }
  7352. iCharCnt = 0;
  7353. iLen = 0;
  7354. }
  7355. }
  7356. if (iSpclCdTotLength != insCharTotCnt)
  7357. {
  7358. iSpclCdCnt = item3Path.addRow();
  7359. dsf_makeValue(item3Path, "spclspec", "string", spclmemo.substring(iStartInx, spclmemo.length), iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"spclspec", spclmemo.substring(iStartInx, spclmemo.length));
  7360. dsf_makeValue(item3Path, "rowstat", "string", repeat, iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"rowstat", repeat);
  7361. dsf_makeValue(item3Path, "unitflag", "string", "M", iSpclCdCnt);
  7362. dsf_makeValue(item3Path, "spclcd", "string", "MX999", iSpclCdCnt);
  7363. dsf_makeValue(item3Path, "clsoyn", "string", "N", iSpclCdCnt);
  7364. dsf_makeValue(item3Path, "usermemoyn", "string", insusermemoyn, iSpclCdCnt);
  7365. }
  7366. }
  7367. else if (iSpclCdTotLength > 0)
  7368. {
  7369. iSpclCdCnt = item3Path.addRow();
  7370. dsf_makeValue(item3Path, "spclspec", "string", spclmemo, iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"spclspec", spclmemo);
  7371. dsf_makeValue(item3Path, "rowstat", "string", repeat, iSpclCdCnt); //model.makeValue(item3Path + iSpclCdCnt +"]/"+ item3Node +"rowstat", repeat);
  7372. dsf_makeValue(item3Path, "unitflag", "string", "M", iSpclCdCnt);
  7373. dsf_makeValue(item3Path, "spclcd", "string", "MX999", iSpclCdCnt);
  7374. dsf_makeValue(item3Path, "clsoyn", "string", "N", iSpclCdCnt);
  7375. dsf_makeValue(item3Path, "usermemoyn", "string", insusermemoyn, iSpclCdCnt);
  7376. }
  7377. }
  7378. /****************************************************************************************
  7379. * Argument : button
  7380. * Description : 처방 휴지통 버튼 이벤트 -> 미개발
  7381. ****************************************************************************************/
  7382. function grp_biz_btn_delordlist_onclick(obj:Button, e:ClickEventInfo)
  7383. {
  7384. }
  7385. /****************************************************************************************
  7386. * Argument : button
  7387. * Description : 처방 심사변경 버튼 이벤트
  7388. ****************************************************************************************/
  7389. function grp_biz_btn_delordsrch_onclick(obj:Button, e:ClickEventInfo)
  7390. {
  7391. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  7392. if (!utlf_isNull(clamym))
  7393. {
  7394. var sppid21800 = new Object();
  7395. sppid21800.sClamym = ds_main_item1_clbs.getColumn(0, "clamym");
  7396. sppid21800.sClamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  7397. sppid21800.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  7398. sppid21800.sPidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  7399. frmf_open("SPPID21800", "SPPID21800", sppid21800, "", "", "", "", "", "", "", "", "", "M");
  7400. }
  7401. }
  7402. /****************************************************************************************
  7403. * Argument : button
  7404. * Description : 처방 심사전 버튼 이벤트
  7405. ****************************************************************************************/
  7406. function grp_biz_btn_bfjudgdocu_onclick(obj:Button, e:ClickEventInfo)
  7407. {
  7408. if(ds_main_item1_clbs.getColumn(0, "ioflag") == "O")
  7409. {
  7410. lf_fBfjudgdocu();
  7411. }
  7412. else
  7413. {
  7414. fBfjudgdocu();
  7415. }
  7416. }
  7417. /****************************************************************************************
  7418. * Argument : button
  7419. * Description : 처방 심사전 버튼 이벤트
  7420. ****************************************************************************************/
  7421. function lf_fActivatePreDocuWindow(ds)
  7422. {
  7423. var openerClamym = ds.getColumn(0, "clamym");
  7424. var openerClamdg = ds.getColumn(0, "clamdg");
  7425. var openerPid = ds.getColumn(0, "pid");
  7426. var openerPidsn = ds.getColumn(0, "pidsn");
  7427. var openerCutprcpyn = ds.getColumn(0, "cutprcpyn");
  7428. var openerWorkflag = ds.getColumn(0, "workflag");
  7429. if (!utlf_isNull(openerClamym))
  7430. {
  7431. ds_send_item1_clbs.setColumn(0, "clamym" , openerClamym);
  7432. ds_send_item1_clbs.setColumn(0, "clamdg" , openerClamdg);
  7433. ds_send_item1_clbs.setColumn(0, "pid" , openerPid);
  7434. ds_send_item1_clbs.setColumn(0, "pidsn" , openerPidsn);
  7435. ds_send_item1_clbs.setColumn(0, "cutprcpyn" , openerCutprcpyn);
  7436. ds_send_item1_clbs.setColumn(0, "ioflag" , lgv_ioflag);
  7437. ds_send_item1_clbs.setColumn(0, "workflag" , openerWorkflag);
  7438. // 심사대상자조회
  7439. var oParam = {};
  7440. oParam.id = "TRPID20301";
  7441. oParam.service = "aftjudgapp.InAftJudg";
  7442. oParam.method = "reqGetInAftJudgTrgtMan_xp";
  7443. oParam.inds = "req=ds_send_item1_clbs";
  7444. oParam.outds = "ds_main_item1_clbs=clbs";
  7445. oParam.async = false;
  7446. oParam.callback = "lf_fSetAftJudgTrgtManSrchData";
  7447. tranf_submit(oParam);
  7448. }
  7449. else
  7450. {
  7451. // fCheckAuth(); // 화면 권한을 설정한다.
  7452. }
  7453. }
  7454. /****************************************************************************************
  7455. * Argument : button
  7456. * Description : 처방 행추가
  7457. ****************************************************************************************/
  7458. function grp_biz_btn_clodinsert_onclick(obj:Button, e:ClickEventInfo)
  7459. {
  7460. // 행추가
  7461. lf_fOrderGridInsertRow();
  7462. }
  7463. /****************************************************************************************
  7464. * Argument : button
  7465. * Description : 처방 행복사
  7466. ****************************************************************************************/
  7467. function grp_biz_btn_clodcopy_onclick(obj:Button, e:ClickEventInfo)
  7468. {
  7469. lf_fOrderGridCopyRow();
  7470. }
  7471. /****************************************************************************************
  7472. * Argument : function
  7473. * Description : 처방 Grid 마우스 오른쪽 버튼 클릭시 팝업 메뉴 "행 복사"
  7474. ****************************************************************************************/
  7475. function lf_fOrderGridCopyRow()
  7476. {
  7477. var clodrow = ds_list2_clod.rowposition;
  7478. var iRow = ds_list2_clod.insertRow(++clodrow);
  7479. ds_list2_clod.copyRow(iRow, ds_list2_clod, iRow-1);
  7480. ds_list2_clod.setColumn(iRow, "rowstat", "");
  7481. ds_list2_clod.setColumn(iRow, "cnfmcd", "");
  7482. // seqno 셋팅
  7483. var maxseqno = ds_rslt_maxseqno.getColumn(0, "seqno");
  7484. ds_list2_clod.setColumn(iRow, "seqno", maxseqno);
  7485. ds_rslt_maxseqno.setColumn(0, "seqno", parseInt(maxseqno)+1);
  7486. ds_list2_clod.setColumn(iRow, "edilnno", "0");
  7487. var newcd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  7488. if (newcd)
  7489. {
  7490. ds_list2_clod.setColumn(iRow, "adjtresncd", newcd);
  7491. }
  7492. else
  7493. {
  7494. newcd = ds_list2_clod.getColumn(iRow, "adjtresncd");
  7495. if (newcd)
  7496. {
  7497. ds_list2_clod.setColumn(iRow, "adjtresncd", newcd);
  7498. }
  7499. else
  7500. {
  7501. newcd = lf_fSetAdjtResnCd();
  7502. if (utlf_isNull(newcd) || newcd == "-")
  7503. {
  7504. ds_list2_clod.deleteRow(iRow); // 처방 Grid에서 해당 라인을 삭제한다.
  7505. return;
  7506. }
  7507. }
  7508. }
  7509. // 처방 Grid 타이틀을 이용해서 sorting 한 경우 줄번호가 현재 정렬된 순서대로 부여되므로 다시 sort하여 처리한다.
  7510. lf_fSetOrderLnNo();
  7511. }
  7512. /****************************************************************************************
  7513. * Argument : function
  7514. * Description : 심사사유, 조정사유, 수정사유 입력
  7515. ****************************************************************************************/
  7516. function lf_fSetAdjtResnCdClop()
  7517. {
  7518. var oldcd = ds_list7_clop.getColumn(ds_list7_clop.rowposition, "adjtresncd");
  7519. var sppiz01000 = new Object();
  7520. sppiz01000.sCdCls = "aftout";
  7521. sppiz01000.sCdid = oldcd;
  7522. sppiz01000.sAdjtresndesc = "";
  7523. // SPPIZ01000_심사수정사유관리.xrw
  7524. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  7525. if (!utlf_isNull(objArg))
  7526. {
  7527. var newcd = objArg.sCdid;
  7528. var newdesc = objArg.sAdjtresndesc;
  7529. if (newcd)
  7530. {
  7531. for ( var i = 0; i < ds_list7_clop.rowcount; i++)
  7532. {
  7533. var sRow = ds_list7_clop.getSelect(i);
  7534. if ( sRow == true )
  7535. {
  7536. ds_list7_clop.setColumn(i, "adjtresncd", newcd);
  7537. if (newcd != oldcd)
  7538. {
  7539. if ( ds_list7_clop.getRowType(i) == 1 )
  7540. {
  7541. ds_list7_clop.updatecontrol = false;
  7542. ds_list7_clop.setRowType(i, "u");
  7543. ds_list7_clop.updatecontrol = true;
  7544. }
  7545. }
  7546. }
  7547. }
  7548. }
  7549. return newcd;
  7550. }
  7551. }
  7552. /****************************************************************************************
  7553. * Argument : button
  7554. * Description : 처방 행삭제
  7555. ****************************************************************************************/
  7556. function grp_biz_btn_cloddelete_onclick(obj:Button, e:ClickEventInfo)
  7557. {
  7558. // 행삭제
  7559. lf_fOrderGridDeleteRow();
  7560. }
  7561. /****************************************************************************************
  7562. * Argument : button
  7563. * Description : 처방 행삭제
  7564. ****************************************************************************************/
  7565. function grp_biz_btn_initfilter_onclick(obj:Button, e:ClickEventInfo)
  7566. {
  7567. // 처방 Grid 필터용 조회조건을 초기화한다.
  7568. lf_fInitOrderFilter();
  7569. lf_fGetSelectedOrderData();
  7570. // 필터초기화버튼 클릭시 급여구분이 "급여"가 아니면 급여로 처방을 다시 조회한다.
  7571. if ( ds_hidden_list2_clodsrch.getColumn(0, "selectedRdoPay") != 0 )
  7572. {
  7573. lf_fClodSelectByPayflag();
  7574. }
  7575. }
  7576. /****************************************************************************************
  7577. * Argument : function
  7578. * Description : 처방 Grid 필터용 조회조건을 초기화한다.
  7579. ****************************************************************************************/
  7580. function lf_fInitOrderFilter()
  7581. {
  7582. // 처방Grid용 조회부의 Radio 초기값을 "전체"로 설정한다.
  7583. ds_hidden_list2_clodsrch.clearData();
  7584. ds_hidden_list2_clodsrch.addRow();
  7585. ds_hidden_list2_clodsrch.setColumn(0, "selectedRdoPay" , "0");
  7586. ds_hidden_list2_clodsrch.setColumn(0, "selectedRdoItem" , "-");
  7587. }
  7588. /****************************************************************************************
  7589. * Argument : button
  7590. * Description : 하단 우측 화살표 버튼 이벤트 "<<"
  7591. ****************************************************************************************/
  7592. function grp_biz_btn_pretrgtman_onclick(obj:Button, e:ClickEventInfo)
  7593. {
  7594. lf_fClickPrevNext("P");
  7595. }
  7596. function grp_biz_btn_nexttrgtman_onclick(obj:Button, e:ClickEventInfo){
  7597. lf_fClickPrevNext("N");
  7598. }
  7599. /****************************************************************************************
  7600. * Argument : function
  7601. * Description :
  7602. ****************************************************************************************/
  7603. function lf_fGetAftJudgMngt(grd_clbsmast)
  7604. {
  7605. var clamym = grd_clbsmast.getColumn(0, "clamym");
  7606. var clamdg = grd_clbsmast.getColumn(0, "clamdg");
  7607. var pid = grd_clbsmast.getColumn(0, "pid");
  7608. var pidsn = grd_clbsmast.getColumn(0, "pidsn");
  7609. var selectedRow = grd_clbsmast.getColumn(0, "selectedRow");
  7610. var judgenddd = grd_clbsmast.getColumn(0, "judgenddd");
  7611. var cutprcpyn = grd_clbsmast.getColumn(0, "cutprcpyn");
  7612. if (!utlf_isNull(clamym))
  7613. {
  7614. var rslt = lf_fInitSrchData(); // 화면을 초기화한다.
  7615. if (rslt == false)
  7616. {
  7617. // 수정사항 저장이 완료되지 않아 초기화할 수 없는 경우
  7618. return false;
  7619. }
  7620. ds_send_item1_clbs.clearData();
  7621. ds_send_item1_clbs.addRow();
  7622. ds_send_item1_clbs.setColumn(0, "clamym" , clamym);
  7623. ds_send_item1_clbs.setColumn(0, "clamdg" , clamdg);
  7624. ds_send_item1_clbs.setColumn(0, "pid" , pid);
  7625. ds_send_item1_clbs.setColumn(0, "pidsn" , pidsn);
  7626. ds_send_item1_clbs.setColumn(0, "workflag" , "12");
  7627. ds_send_item1_clbs.setColumn(0, "ioflag" , lgv_ioflag);
  7628. ds_send_item1_clbs.setColumn(0, "cutprcpyn" , cutprcpyn);
  7629. // 20100328 치식팝업
  7630. if (lgv_ioflag == "O")
  7631. {
  7632. var judgendyn = grd_clbsmast.getColumn(0, "judgendyn");
  7633. var tootpopupyn = grd_clbsmast.getColumn(0, "tootpopupyn");
  7634. ds_send_item1_clbs.addColumn("tootpopupyn", "STRING");
  7635. ds_send_item1_clbs.setColumn(0, "tootpopupyn", tootpopupyn);
  7636. grd_clbsmast.setColumn(0, "judgendyn", judgendyn);
  7637. }
  7638. else
  7639. {
  7640. var cretno = grd_clbsmast.getColumn(0, "cretno");
  7641. var popupcallyn = grd_clbsmast.getColumn(0, "popupcallyn");
  7642. ds_send_item1_clbs.setColumn(0, "cretno" , cretno);
  7643. ds_send_item1_clbs.setColumn(0, "popupcallyn" , popupcallyn);
  7644. }
  7645. // 20100302 삭감조회 여부
  7646. if (!utlf_isNull(cutprcpyn))
  7647. {
  7648. ds_send_item1_clbs.addColumn("cutviewyn", "STRING");
  7649. ds_send_item1_clbs.setColumn(0, "cutviewyn", "Y");
  7650. }
  7651. else
  7652. {
  7653. ds_send_item1_clbs.addColumn("cutviewyn", "STRING");
  7654. ds_send_item1_clbs.setColumn(0, "cutviewyn", "N");
  7655. }
  7656. // 심사대상자조회
  7657. var oParam = {};
  7658. oParam.id = "TRPID20301";
  7659. oParam.service = "aftjudgapp.InAftJudg";
  7660. oParam.method = "reqGetInAftJudgTrgtMan_xp";
  7661. oParam.inds = "req=ds_send_item1_clbs";
  7662. oParam.outds = "ds_main_item1_clbs=clbs";
  7663. oParam.async = false;
  7664. oParam.callback = "lf_fSetAftJudgTrgtManSrchData";
  7665. tranf_submit(oParam);
  7666. }
  7667. }
  7668. /****************************************************************************************
  7669. * Argument : function
  7670. * Description : 초기화
  7671. ****************************************************************************************/
  7672. function lf_fInitSrchData()
  7673. {
  7674. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  7675. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  7676. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  7677. var pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  7678. if (!utlf_isNull(clamym))
  7679. {
  7680. var judgendyn = ds_main_item1_clbs.getColumn(0, "judgendyn");
  7681. if (judgendyn == "B")
  7682. {
  7683. var clamendyn = ds_main_item1_clbs.getColumn(0, "clamendyn");
  7684. var lockyn = ds_main_item1_clbs.getColumn(0, "lockyn");
  7685. if (lockyn == "N")
  7686. {
  7687. // 청구완료여부 A:샘생성전
  7688. if ( grp_biz.btn_save.enable == true || grp_biz.btn_unjudg.enable == true)
  7689. {
  7690. var rslt = lf_fCheckChangeSave();
  7691. if (rslt == false)
  7692. {
  7693. return false;
  7694. }
  7695. if ( ds_hidden.getColumn(0, "reselect") == "N" || utlf_isNull(ds_hidden.getColumn(0, "reselect")))
  7696. {
  7697. var judgendyn = "";
  7698. if ( utlf_isNull(ds_hidden.getColumn(0, "orgjudgendyn")))
  7699. {
  7700. judgendyn = "A";
  7701. }
  7702. else
  7703. {
  7704. judgendyn = ds_hidden.getColumn(0, "orgjudgendyn");
  7705. }
  7706. ds_send_item4_endclbs.clearData();
  7707. ds_send_item4_endclbs.addRow();
  7708. ds_send_item4_endclbs.setColumn(0, "clamym", clamym);
  7709. ds_send_item4_endclbs.setColumn(0, "clamdg", clamdg);
  7710. ds_send_item4_endclbs.setColumn(0, "pid", pid);
  7711. ds_send_item4_endclbs.setColumn(0, "pidsn", pidsn);
  7712. ds_send_item4_endclbs.setColumn(0, "judgendyn", judgendyn);
  7713. var oParam = {};
  7714. oParam.id = "TXPID20302";
  7715. oParam.service = "aftjudgapp.InAftJudg";
  7716. oParam.method = "reqSetPidmclbsJudgEndYNAll";
  7717. oParam.inds = "endclbs=ds_send_item4_endclbs";
  7718. oParam.async = false;
  7719. tranf_submit(oParam);
  7720. // 대상자조회 심사상태 변경
  7721. lf_fSetJudgSaveState(judgendyn);
  7722. }
  7723. }
  7724. }
  7725. }
  7726. }
  7727. lf_fInitUIControlSize();
  7728. // 대상자 화면과 이전명세서 화면을 제외한 자식창을 닫는다.
  7729. var judgWindow1 = frmf_getChildWindow("SMPID20400");// SMPID20400_외래사후심사대상자조회.xrw
  7730. var judgWindow2 = frmf_getChildWindow("SMPID20500");// SMPID20500_외래사후심사관리.xrw
  7731. var judgWindow3 = frmf_getChildWindow("SMMMI00100");// SMMMI00100_통합검사결과조회.xrw
  7732. var judgWindow4 = frmf_getChildWindow("SMMMO02500");// SMMMO02500_통합처방조회.xrw
  7733. var judgWindow5 = frmf_getChildWindow("SMMRI00400");// SMMRI00400_통합기록조회.xrw
  7734. if ( utlf_isNull(judgWindow1) && utlf_isNull(judgWindow2) && utlf_isNull(judgWindow3) && utlf_isNull(judgWindow4) && utlf_isNull(judgWindow5))
  7735. {
  7736. var childCnt = frmf_getChildPopList(this); //폼에서 열린 팝업 목록을 가져온다.
  7737. }
  7738. else
  7739. {
  7740. }
  7741. ds_send_item1_clbs.clearData();
  7742. ds_main_item1_clbs.clearData();
  7743. ds_grd_msg.clearData();
  7744. ds_main_item1_memo.clearData();
  7745. ds_item2_incd.clearData();
  7746. ds_item3_supp.clearData();
  7747. ds_list1_cldi.clearData();
  7748. ds_list2_clod.clearData();
  7749. ds_list3_clsp.clearData();
  7750. ds_main_item5_mech.clearData();
  7751. ds_list4_clbs.clearData();
  7752. ds_hidden_list4_clbs.clearData();
  7753. ds_list5_clod.clearData();
  7754. ds_list6_delclod.clearData();
  7755. ds_list7_clop.clearData();
  7756. ds_rslt_aftjudgbtn.clearData();
  7757. ds_rslt_maxseqno.clearData();
  7758. ds_rslt_clopmaxseqno.clearData();
  7759. ds_rslt_clbt.clearData();
  7760. ds_rslt_mmohdiag1.clearData();
  7761. ds_rslt_mmohdiag2.clearData();
  7762. ds_rslt_nbwt.clearData();
  7763. ds_rslt_dupid.clearData();
  7764. ds_hidden_rarecancermsg.clearData();
  7765. ds_tmpsrch.clearData();
  7766. ds_send_item3_delclsp.clearData();
  7767. ds_send_list10_judgmemo.clearData();
  7768. ds_send_list11_edimemo.clearData();
  7769. ds_init_cmb_rarecancermsg.clearData();
  7770. ds_list9_trnpt.clearData();
  7771. ds_send_item8_pifhiunc.clearData();
  7772. ds_send_item1_clbs.addRow();
  7773. ds_main_item1_clbs.addRow();
  7774. ds_main_item1_memo.addRow();
  7775. ds_item2_incd.addRow();
  7776. ds_item3_supp.addRow();
  7777. ds_list1_cldi.addRow();
  7778. ds_list2_clod.addRow();
  7779. ds_list3_clsp.addRow();
  7780. ds_main_item5_mech.addRow();
  7781. ds_list4_clbs.addRow();
  7782. ds_list5_clod.addRow();
  7783. ds_list6_delclod.addRow();
  7784. ds_list7_clop.addRow();
  7785. ds_send_item8_pifhiunc.addRow();
  7786. ds_hidden_rarecancermsg.addRow();
  7787. ds_tmpsrch.addRow();
  7788. grp_biz.swt_spclmemo.case_spclspec.chk_JT001.value = "Y";
  7789. grdf_clearSort(grp_biz.grd_cldihist);
  7790. grdf_clearSort(grp_biz.grd_clodhist);
  7791. grdf_clearSort(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist);
  7792. grdf_clearSort(grp_biz.grd_oprcphist);
  7793. cmb_rarecancermsg.visible = true;
  7794. // 심사완료여부 상태에 따라 "저장 / 재계산 / 완료 / 미심 / 보류 / 삭제" Btn 권한을 설정한다.
  7795. lf_fSetJudgStatBtnAuth()
  7796. // 조회 조건의 초기값을 설정한다. 특정내역Grid용 필터링 Radio 초기값
  7797. ds_hidden_list3.setColumn(0, "selectedUnitFlag", "-");
  7798. // 처방 조회부 항목구분 Radio item의 굵은 표시를 취소한다. [2012.10.26] 김경연 주석풀음
  7799. for (var i=0; i < ds_init_ordfilflag.rowcount; i++)
  7800. {
  7801. ds_init_ordfilflag.setColumn(i, "color", "");
  7802. ds_init_ordfilflag.setColumn(i, "font", "");
  7803. }
  7804. // 처방Grid 필터용 조회조건을 초기화한다.
  7805. lf_fInitOrderFilter();
  7806. grp_sea00.cmb_orddeptcd.innerdataset = "ds_init_orddeptcd2";
  7807. grp_sea00.cmb_orddeptcd.codecolumn = "cd";
  7808. grp_sea00.cmb_orddeptcd.datacolumn = "nm";
  7809. grp_sea00.cmb_orddrid.innerdataset = "ds_init_orddrid2";
  7810. grp_sea00.cmb_orddrid.codecolumn = "cd";
  7811. grp_sea00.cmb_orddrid.datacolumn = "nm";
  7812. grp_msg.visible = false;
  7813. grp_desc.visible = false;
  7814. ds_main_item1_clbs.setColumn(0, "adjtresndesc", "");
  7815. ds_hidden_list7_clop.setColumn(0, "selectedRdoPay", "0");
  7816. return true;
  7817. }
  7818. /****************************************************************************************
  7819. * Argument : function
  7820. * Description : 기존 조회 내역 중 수정 사항이 있는 경우 저장할 것인지를 물어본다.
  7821. ****************************************************************************************/
  7822. function lf_fCheckChangeSave()
  7823. {
  7824. var isChange = false;
  7825. var cldiupdtdata = ""; // 상병 Grid 변경
  7826. var clbsupdatadata = false;
  7827. var ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  7828. clbsupdatadata = dsf_datasetUpdateChk(ds_main_item1_clbs);
  7829. var clopupdtdata = 0;
  7830. var clodupdtdata = 0;
  7831. if (clbsupdatadata == false)
  7832. {
  7833. clodupdtdata = grdf_getGridUpdateData(grp_biz.grd_clodhist).rowcount;
  7834. if(ioflag == "O")
  7835. {
  7836. clopupdtdata = grdf_getGridUpdateData(grp_biz.grd_oprcphist).rowcount;
  7837. }
  7838. if (clodupdtdata != 0 || clopupdtdata != 0)
  7839. {
  7840. // 처방, 원외처방이 수정된 경우
  7841. isChange = true;
  7842. }
  7843. else
  7844. {
  7845. // 특정내역
  7846. for ( var i = ds_list3_clsp.rowcount-1; i >= 0; i-- )
  7847. {
  7848. var rowstatus = ds_list3_clsp.getRowType(i);
  7849. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  7850. var spclspec = ds_list3_clsp.getColumn(i, "spclspec");
  7851. if ( rowstatus != 8 && utlf_isNull(spclcd) && utlf_isNull(spclspec))
  7852. {
  7853. // 줄을 삭제한다.
  7854. ds_list3_clsp.deleteRow(i);
  7855. //i--;
  7856. }
  7857. }
  7858. var clspupdtdata = grdf_getGridUpdateData(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist).rowcount;
  7859. if (clspupdtdata != 0)
  7860. {
  7861. isChange = true;
  7862. }
  7863. else
  7864. {
  7865. // 상병
  7866. for (var i = ds_list1_cldi.rowcount; i >= 0; i--)
  7867. {
  7868. var rowstatus = ds_list1_cldi.getRowType(i);
  7869. var diagcd = ds_list1_cldi.getColumn(i, "diagcd");
  7870. if ( rowstatus == 2 )
  7871. {
  7872. if (utlf_isNull(diagcd))
  7873. {
  7874. // 줄을 삭제한다.
  7875. ds_list1_cldi.deleteRow(i);
  7876. //i--;
  7877. }
  7878. }
  7879. }
  7880. cldiupdtdata = grdf_getGridUpdateData(grp_biz.grd_cldihist).rowcount;
  7881. if (cldiupdtdata != 0)
  7882. {
  7883. isChange = true;
  7884. }
  7885. }
  7886. }
  7887. }
  7888. if(isChange)
  7889. {
  7890. var ans = sysf_messageBox("수정사항이 있습니다. 저장", "S001"); ///수정사항이 있습니다. 저장하시려면 예(Yes)\n아니면 아니오(No)
  7891. if (ans == 6)
  7892. {
  7893. var rslt = lf_fSaveAftJudg("B")
  7894. if (rslt != "true" || utlf_isNull(rslt))
  7895. {
  7896. return false;
  7897. }
  7898. }
  7899. else if (ans == 2)
  7900. {
  7901. if (ds_list3_clsp.rowcount == 1)
  7902. {
  7903. lf_fSpclGridInsertRow(); // 특정내역 줄추가
  7904. }
  7905. if (cldiupdtdata)
  7906. {
  7907. }
  7908. return false;
  7909. }
  7910. }
  7911. return true;
  7912. }
  7913. /****************************************************************************************
  7914. * Argument : function
  7915. * Description : 상병, 특정내역, 처방 Group의 컨트롤 크기를 초기화한다.
  7916. ****************************************************************************************/
  7917. function lf_fInitUIControlSize()
  7918. {
  7919. grp_predoculist.cap_grptemp.visible = false;
  7920. grp_predoculist.visible = false; // 이전 명세서 목록용 Group
  7921. grd_delclod.visible = false; // 처방 휴지통 Group
  7922. }
  7923. /****************************************************************************************
  7924. * Argument : button
  7925. * Description : 완료버튼 이벤트
  7926. ****************************************************************************************/
  7927. function grp_biz_btn_end_onclick(obj:Button, e:ClickEventInfo)
  7928. {
  7929. if (obj.enable == true )
  7930. {
  7931. // P0151 (사후심사-심사완료여부) C: 심사완료
  7932. lf_fGetNextAftJudgTrgtMan("C");
  7933. }
  7934. else
  7935. {
  7936. sysf_messageBox("비활성 상태입니다. 진행","E001");
  7937. }
  7938. }
  7939. /****************************************************************************************
  7940. * Argument : function
  7941. * Description : "완료"~"삭제" 처리 후 다음 심사대상자를 조회한다.
  7942. ****************************************************************************************/
  7943. function lf_fGetNextAftJudgTrgtMan(judgendyn)
  7944. {
  7945. // 완료버튼 클릭시
  7946. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  7947. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  7948. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  7949. var pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  7950. var ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  7951. var rslt ;
  7952. if (pid)
  7953. {
  7954. var rslt = lf_fSaveAftJudg(judgendyn);
  7955. if (utlf_isNull(rslt) || rslt == false)
  7956. {
  7957. return false;
  7958. }
  7959. else
  7960. {
  7961. if (rslt == "false")
  7962. {
  7963. // 변경된 데이터가 없는 경우 "심사상태" 설정한다.
  7964. ds_send_item4_endclbs.clearData();
  7965. ds_send_item4_endclbs.addRow();
  7966. if (!utlf_isNull(ds_send_item4_endclbs.getColumn(0, "suppkind")))
  7967. {
  7968. ds_send_item4_endclbs.setColumn(0, "insukind", ds_main_item1_clbs.getColumn(0, "insukindcd"));
  7969. ds_send_item4_endclbs.setColumn(0, "ordtodd", ds_main_item1_clbs.getColumn(0, "ordtodd"));
  7970. }
  7971. ds_send_item4_endclbs.setColumn(0, "clamym", clamym);
  7972. ds_send_item4_endclbs.setColumn(0, "clamdg", clamdg);
  7973. ds_send_item4_endclbs.setColumn(0, "pid", pid);
  7974. ds_send_item4_endclbs.setColumn(0, "pidsn", pidsn);
  7975. ds_send_item4_endclbs.setColumn(0, "judgendyn", judgendyn);
  7976. ds_send_item4_endclbs.setColumn(0, "ioflag", ds_main_item1_clbs.getColumn(0, "ioflag"));
  7977. // 기존에 심사중이었던 경우
  7978. var oParam = {};
  7979. oParam.id = "TXPID20302";
  7980. oParam.service = "aftjudgapp.InAftJudg";
  7981. oParam.method = "reqSetPidmclbsJudgEndYNAll";
  7982. oParam.inds = "endclbs=ds_send_item4_endclbs";
  7983. oParam.async = false;
  7984. oParam.callback = "cf_TXPID20302";
  7985. tranf_submit(oParam);
  7986. // 대상자조회 심사완료여부 (P0151)
  7987. lf_fSetJudgSaveState(judgendyn);
  7988. ds_main_item1_clbs.setColumn(0, "judgendyn", judgendyn);
  7989. }
  7990. // 현재 로그인한 사용자 번호(ID)
  7991. var userid = sysf_getUserId();
  7992. if (utlf_isNull(userid))
  7993. {
  7994. userid = "12345678";
  7995. }
  7996. ds_main_item1_clbs.setColumn(0, "lastupdtrid", userid);
  7997. ds_main_item1_clbs.setColumn(0, "judgendyn", judgendyn);
  7998. }
  7999. lf_fClickPrevNext("N", judgendyn);
  8000. }
  8001. }
  8002. /****************************************************************************************
  8003. * Argument : submit
  8004. * Description : 에러 처리
  8005. ****************************************************************************************/
  8006. function cf_TXPID20302(strSvcID, nErrorCode, strErrorMsg)
  8007. {
  8008. var clodlength;
  8009. //에러 처리
  8010. if(nErrorCode == 0)
  8011. {
  8012. }
  8013. else
  8014. {
  8015. if ( judgendyn == "C")
  8016. {
  8017. ds_tmpmaindetl_tmpmaindetlinfo.setColumn(ds_tmpmaindetl_tmpmaindetlinfo.rowposition, "judgendyn", "0");
  8018. }
  8019. else if ( judgendyn == "A" )
  8020. {
  8021. ds_tmpmaindetl_tmpmaindetlinfo.setColumn(ds_tmpmaindetl_tmpmaindetlinfo.rowposition, "judgendyn", "1");
  8022. }
  8023. }
  8024. }
  8025. /****************************************************************************************
  8026. * Argument : button
  8027. * Description : 미심 버튼 이벤트
  8028. ****************************************************************************************/
  8029. function grp_biz_btn_unjudg_onclick(obj:Button, e:ClickEventInfo)
  8030. {
  8031. if (obj.enable == true )
  8032. {
  8033. lf_fGetNextAftJudgTrgtMan("A"); // P0151 (사후심사-심사완료여부) A: 미심사
  8034. }
  8035. else
  8036. {
  8037. sysf_messageBox("비활성 상태입니다. 진행","E001");
  8038. }
  8039. }
  8040. /****************************************************************************************
  8041. * Argument : button
  8042. * Description : 보류 버튼 이벤트
  8043. ****************************************************************************************/
  8044. function grp_biz_btn_rete_onclick(obj:Button, e:ClickEventInfo)
  8045. {
  8046. if (obj.enable == true )
  8047. {
  8048. // P0151 (사후심사-심사완료여부) N: 심사보류
  8049. lf_fGetNextAftJudgTrgtMan("N");
  8050. }
  8051. else
  8052. {
  8053. sysf_messageBox("비활성 상태입니다. 진행","E001");
  8054. }
  8055. }
  8056. /****************************************************************************************
  8057. * Argument : button
  8058. * Description : 삭제 버튼 이벤트
  8059. ****************************************************************************************/
  8060. function grp_biz_btn_del_onclick(obj:Button, e:ClickEventInfo)
  8061. {
  8062. var judgendyn = ds_main_item1_clbs.getColumn(0, "judgendyn");
  8063. if(judgendyn == "D")
  8064. {// 심사상태:삭제 -> 삭제버튼 클릭 return *I007=확인하십시오.
  8065. sysf_messageBox("심사상태가 삭제인 환자입니다. 심사상태를", "I007");
  8066. return;
  8067. }
  8068. else
  8069. {
  8070. if (sysf_messageBox("","Q001") == 6)
  8071. {
  8072. var clamflagcd = ds_main_item1_clbs.getColumn(0, "clamflagcd");
  8073. if (clamflagcd == "1")
  8074. {
  8075. if (lf_pidfChkAbdResncd() && lf_pidfChkDocuDelResncd())
  8076. {
  8077. // P0151 (사후심사-심사완료여부) D: 삭제
  8078. lf_fGetNextAftJudgTrgtMan("D");
  8079. }
  8080. }
  8081. else
  8082. {
  8083. if (lf_pidfChkDocuDelResncd())
  8084. {
  8085. // P0151 (사후심사-심사완료여부) D: 삭제
  8086. lf_fGetNextAftJudgTrgtMan("D");
  8087. }
  8088. }
  8089. }
  8090. }
  8091. }
  8092. /****************************************************************************************
  8093. * Argument : function
  8094. * Description : 1. 재청구 삭제일 경우 : (1). 반송부제기사유 체크 (2). 반송부제기사유 UPDATE
  8095. ****************************************************************************************/
  8096. function lf_pidfChkAbdResncd()
  8097. {
  8098. var abdresncd = ds_main_item1_clbs.getColumn(0, "abdresncd");
  8099. if (utlf_isNull(abdresncd))
  8100. {
  8101. //I003=필수입력입니다.
  8102. sysf_messageBox("반송부제기사유는","I003");
  8103. //grp_biz.grp_sea02.cmb_abdresncd.setFocus();
  8104. return false;
  8105. }
  8106. else
  8107. {
  8108. return true;
  8109. }
  8110. }
  8111. /****************************************************************************************
  8112. * Argument : function
  8113. * Description : 2. 명세서삭제일 경우 : (1). 명세서삭제사유 체크 (2). 기타일경우 심사자메모에 기타사유 추가
  8114. ****************************************************************************************/
  8115. function lf_pidfChkDocuDelResncd()
  8116. {
  8117. var docudelresncd = ds_main_item1_clbs.getColumn(0, "docudelresncd");
  8118. if (utlf_isNull(docudelresncd) || docudelresncd == '-')
  8119. {
  8120. //I003=필수입력입니다.
  8121. sysf_messageBox("명세서삭제사유는","I003");
  8122. grp_desc.visible = true ;
  8123. return false;
  8124. }
  8125. else
  8126. {
  8127. if (docudelresncd == "Z")
  8128. {
  8129. // 명세서삭제사유가 "기타"인경우 심사자메모에 기타사유 넣는다.
  8130. var judgmemo = ds_main_item1_clbs.getColumn(0, "judgmemo");
  8131. judgmemo = "[명세서 삭제: 기타]" || " " || judgmemo;
  8132. ds_main_item1_clbs.setColumn(0, "judgmemo", judgmemo);
  8133. }
  8134. return true;
  8135. }
  8136. }
  8137. /****************************************************************************************
  8138. * Argument : button
  8139. * Description : 진료비누적 버튼 이벤트
  8140. ****************************************************************************************/
  8141. function grp_biz_btn_amtsum_onclick(obj:Button, e:ClickEventInfo)
  8142. {
  8143. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  8144. if (!utlf_isNull(clamym))
  8145. {
  8146. var objArg = {};
  8147. objArg.sClamym = clamym;
  8148. objArg.sClamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  8149. objArg.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  8150. objArg.sPidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  8151. objArg.sInsukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  8152. objArg.sSuppkind = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  8153. objArg.sOrdfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  8154. // SPPID21300_심사전후차액조회.xrw
  8155. frmf_open("SPPID21300", "SPPID21300", objArg, "", "", "", "", "", "", "", "", "", "M");
  8156. }
  8157. }
  8158. /****************************************************************************************
  8159. * Argument : button
  8160. * Description : 이전 명세서 버튼 이벤트
  8161. ****************************************************************************************/
  8162. function grp_biz_btn_predocu_onclick(obj:Button, e:ClickEventInfo)
  8163. {
  8164. // 이전명세서
  8165. lf_fGetPreClbs();
  8166. }
  8167. /****************************************************************************************
  8168. * Argument : function
  8169. * Description : 이전 명세서
  8170. ****************************************************************************************/
  8171. function lf_fGetPreClbs()
  8172. {
  8173. if ( grp_predoculist.visible == true )
  8174. {
  8175. grp_predoculist.cap_grptemp.visible = false;
  8176. grp_predoculist.visible = false;
  8177. return;
  8178. }
  8179. var clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  8180. var clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  8181. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  8182. var pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  8183. if (clamym)
  8184. {
  8185. // 조회된 심사대상자가 있음
  8186. // pid로 검색한 명세서 목록을 보여주고, 해당 목록에서 고른 건에 대하여 이전명세서 조회 화면을 호출한다.
  8187. var preDocuNode = ds_hidden_list4_clbs.rowcount;
  8188. if (preDocuNode <= 0)
  8189. {
  8190. ds_send_list4.clearData();
  8191. ds_send_list4.addRow();
  8192. ds_send_list4.setColumn(0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  8193. ds_send_list4.setColumn(0, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  8194. ds_send_list4.setColumn(0, "allordfild", "Y");
  8195. ds_send_list4.setColumn(0, "ioflag", "-"); // 기본 옵션 전체로 수정함
  8196. ds_send_list4.setColumn(0, "refterm", "6"); //기본옵션 6개월로 수정 20130114 이재호
  8197. ds_send_list4.setColumn(0, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  8198. ds_send_list4.setColumn(0, "pidsn", ds_main_item1_clbs.getColumn(0, "pidsn"));
  8199. ds_send_list4.setColumn(0, "refterm", "3");
  8200. grp_predoculist.cp_periodCal00.enable = false;
  8201. var oParam = {};
  8202. oParam.id = "TRPID20304";
  8203. oParam.service = "aftjudgapp.InAftJudg";
  8204. oParam.method = "reqGetInAftJudgPreDocuList";
  8205. oParam.inds = "req=ds_send_list4";
  8206. oParam.outds = "ds_list4_clbs=clbs";
  8207. oParam.async = false;
  8208. //oParam.callback = "cf_TRPID20304";
  8209. tranf_submit(oParam);
  8210. ds_hidden_list4_clbs.copyData(ds_list4_clbs);
  8211. }
  8212. else
  8213. {
  8214. ds_list4_clbs.copyData(ds_hidden_list4_clbs);
  8215. }
  8216. }
  8217. grp_predoculist.position.x = 193;
  8218. grp_predoculist.position.y = 413;
  8219. grp_predoculist.bringToFront();
  8220. grp_predoculist.visible = true; // 이전명세서
  8221. grd_delclod.visible = false; // 처방 휴지통
  8222. }
  8223. /****************************************************************************************
  8224. * Argument : button
  8225. * Description : 이전명세서 닫기 버튼
  8226. ****************************************************************************************/
  8227. function grp_predoculist_btn_closepredoculist_onclick(obj:Button, e:ClickEventInfo)
  8228. {
  8229. grp_predoculist.visible = false;
  8230. }
  8231. /****************************************************************************************
  8232. * Argument : button
  8233. * Description : 이전명세서 닫기 버튼
  8234. ****************************************************************************************/
  8235. function grp_biz_btn_oscllist_onclick(obj:Button, e:ClickEventInfo)
  8236. {
  8237. if(ds_main_item1_clbs.getColumn(0, "ioflag") == "O")
  8238. {
  8239. lf_fGetOsclClamData("ALL", "grd_clodhist");
  8240. }
  8241. else
  8242. {
  8243. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  8244. if (clamkey)
  8245. {
  8246. fOrderCalcDetail(true);
  8247. }
  8248. }
  8249. }
  8250. /****************************************************************************************
  8251. * Argument : button
  8252. * Description : 엑셀 버튼 이벤트
  8253. ****************************************************************************************/
  8254. function grp_biz_btn_excelsave_onclick(obj:Button, e:ClickEventInfo)
  8255. {
  8256. lf_fExelPrint();
  8257. }
  8258. /****************************************************************************************
  8259. * Argument : functio
  8260. * Description : 엑셀저장 & 출력
  8261. ****************************************************************************************/
  8262. function lf_fExelPrint()
  8263. {
  8264. //하시려면 예(Yes)\n아니면 아니오(No)
  8265. var ans = sysf_messageBox("1. 엑셀저장", "S006", "2. 프린터출력|3. 취소");
  8266. if ( ans == 6 )
  8267. {
  8268. //원내처방 엑셀저장
  8269. if ( ds_list2_clod.rowcount > 0 )
  8270. {
  8271. grdf_exportExcel(grp_biz.grd_clodhist, "원내처방", "원내처방");
  8272. }
  8273. else
  8274. {
  8275. //엑셀저장할 원내처방이 없습니다.
  8276. sysf_messageBox("엑셀저장할 원내처방이", "I004");
  8277. }
  8278. //원외처방 엑셀저장
  8279. if ( ds_list7_clop.rowcount > 0 )
  8280. {
  8281. grdf_exportExcel(grp_biz.grd_oprcphist, "원외처방", "원외처방");
  8282. }
  8283. }
  8284. else if ( ans == 7 )
  8285. {
  8286. if (ds_list2_clod.rowcount > 0)
  8287. {
  8288. // 선택 : 부분출력(예6), 전체출력(아니오7), 취소(취소7) 보고서에 들어갈 내용 담기
  8289. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  8290. var patnm = ds_main_item1_clbs.getColumn(0, "patnm");
  8291. var ordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  8292. var ordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  8293. var insukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  8294. var insukindnm = ds_main_item1_clbs.getColumn(0, "insukindnm");
  8295. var suppkind = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  8296. var ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  8297. var suppkindnm = grp_sea00.cmb_supprate.text;
  8298. var iphsfromdd = ds_main_item1_clbs.getColumn(0, "iphsfromdd");
  8299. var diagcd = ds_list1_cldi.getColumn(0, "diagcd") + " ("+ ds_list1_cldi.getColumn(0, "diagnm") + ")";
  8300. //데이터를 부분출력 하시려면 예(Yes)\n아니면 아니오(No)
  8301. var ret = sysf_messageBox("데이터를 부분출력", "S001");
  8302. if (ret == 6)
  8303. {
  8304. // 1. 부분출력 (그리드에 선택된 행만 보고서로 전달한다.)
  8305. ds_send_prntlist.clearData();
  8306. for ( var i = 0; i < ds_list2_clod.rowcount; i++ )
  8307. {
  8308. if ( ds_list2_clod.getSelect(i))
  8309. {
  8310. var aRow = ds_send_prntlist.addRow();
  8311. // 상단 정보
  8312. ds_send_prntlist.setColumn(aRow, "pid" , pid); // 환자번호
  8313. ds_send_prntlist.setColumn(aRow, "patnm" , patnm); // 성명
  8314. ds_send_prntlist.setColumn(aRow, "indd" , ordfromdd); // 입원일
  8315. ds_send_prntlist.setColumn(aRow, "insukindcd", insukind); // 환자유형
  8316. ds_send_prntlist.setColumn(aRow, "insukindnm", insukindnm);// 환자유형
  8317. ds_send_prntlist.setColumn(aRow, "suppkindcd", suppkind); // 보조유형
  8318. ds_send_prntlist.setColumn(aRow, "suppkindnm", suppkindnm);// 보조유형
  8319. ds_send_prntlist.setColumn(aRow, "iphsfromdd", ordtodd);// 유형시작일
  8320. ds_send_prntlist.setColumn(aRow, "diagcd" , diagcd);
  8321. // 리스트
  8322. ds_send_prntlist.setColumn(aRow, "edilnno" , ds_list2_clod.getColumn(i, "edilnno"));
  8323. ds_send_prntlist.setColumn(aRow, "item1" , ds_list2_clod.getColumn(i, "ediitem1"));
  8324. ds_send_prntlist.setColumn(aRow, "item2" , ds_list2_clod.getColumn(i, "ediitem2"));
  8325. ds_send_prntlist.setColumn(aRow, "ordfromdd" , ds_list2_clod.getColumn(i, "ordfromdd"));
  8326. ds_send_prntlist.setColumn(aRow, "grupsnglflag" , ds_list2_clod.getColumn(i, "grupsnglflag"));
  8327. ds_send_prntlist.setColumn(aRow, "grupcalcscorcd", ds_list2_clod.getColumn(i, "grupcalcscorcd"));
  8328. ds_send_prntlist.setColumn(aRow, "matractflag" , ds_list2_clod.getColumn(i, "matractflag"));
  8329. ds_send_prntlist.setColumn(aRow, "snglcalcscorcd", ds_list2_clod.getColumn(i, "snglcalcscorcd"));
  8330. ds_send_prntlist.setColumn(aRow, "basecd" , ds_list2_clod.getColumn(i, "basecd"));
  8331. ds_send_prntlist.setColumn(aRow, "estmcd" , ds_list2_clod.getColumn(i, "estmcd"));
  8332. ds_send_prntlist.setColumn(aRow, "hngnm" , ds_list2_clod.getColumn(i, "hngnm"));
  8333. ds_send_prntlist.setColumn(aRow, "payflag" , ds_list2_clod.getColumn(i, "payflag"));
  8334. ds_send_prntlist.setColumn(aRow, "ediunitcost" , ds_list2_clod.getColumn(i, "ediunitcost"));
  8335. ds_send_prntlist.setColumn(aRow, "edidrugqty" , ds_list2_clod.getColumn(i, "edidrugqty"));
  8336. ds_send_prntlist.setColumn(aRow, "tims" , ds_list2_clod.getColumn(i, "tims"));
  8337. ds_send_prntlist.setColumn(aRow, "daydrugqty" , ds_list2_clod.getColumn(i, "daydrugqty"));
  8338. ds_send_prntlist.setColumn(aRow, "dayno" , ds_list2_clod.getColumn(i, "dayno"));
  8339. ds_send_prntlist.setColumn(aRow, "ediamt" , ds_list2_clod.getColumn(i, "ediamt"));
  8340. ds_send_prntlist.setColumn(aRow, "cnfmcd" , ds_list2_clod.getColumn(i, "cnfmcd"));
  8341. ds_send_prntlist.setColumn(aRow, "ordtodd" , ds_list2_clod.getColumn(i, "ordtodd"));
  8342. ds_send_prntlist.setColumn(aRow, "updtdd" , ds_list2_clod.getColumn(i, "updtdd"));
  8343. ds_send_prntlist.setColumn(aRow, "edihospaddamt" , ds_list2_clod.getColumn(i, "edihospaddamt"));
  8344. ds_send_prntlist.setColumn(aRow, "ediaddamt" , ds_list2_clod.getColumn(i, "ediaddamt"));
  8345. ds_send_prntlist.setColumn(aRow, "totordamt" , ds_list2_clod.getColumn(i, "totordamt"));
  8346. }
  8347. }
  8348. var objDOM = rptf_createDOM(); // DOM 객체 설정
  8349. rptf_setNodeListToDOM(objDOM, "root/send/prntlist/prntinfo", ds_send_prntlist); // 데이터셋 1
  8350. var objParam = new Object();
  8351. objParam.xml_data_XML1 = objDOM.documentElement.source; // 최상의노드 XML 스트링 추출
  8352. var option = "open=1;save=1;directprint=0;print=1;zoom=0;callno=;faxno=";
  8353. if(ioflag == "O")
  8354. {
  8355. rptf_exeReportPreview30(["RPPID20500"],[objParam], option);
  8356. }
  8357. else
  8358. {
  8359. rptf_exeReportPreview30(["RPPID20300"],[objParam], option);
  8360. }
  8361. }
  8362. else if (ret == 7)
  8363. {
  8364. // 2. 전체출력 (그리드에 보여지는 내용 전체를 보고서로 전달한다.)
  8365. ds_send_prntlist.clearData();
  8366. for ( var i = 0; i < ds_list2_clod.rowcount; i++ )
  8367. {
  8368. var aRow = ds_send_prntlist.addRow();
  8369. // 상단 정보
  8370. ds_send_prntlist.setColumn(aRow, "pid" , pid); // 환자번호
  8371. ds_send_prntlist.setColumn(aRow, "patnm" , patnm); // 성명
  8372. ds_send_prntlist.setColumn(aRow, "indd" , ordfromdd); // 입원일
  8373. ds_send_prntlist.setColumn(aRow, "insukindcd", insukind); // 환자유형
  8374. ds_send_prntlist.setColumn(aRow, "insukindnm", insukindnm);// 환자유형
  8375. ds_send_prntlist.setColumn(aRow, "suppkindcd", suppkind); // 보조유형
  8376. ds_send_prntlist.setColumn(aRow, "suppkindnm", suppkindnm);// 보조유형
  8377. ds_send_prntlist.setColumn(aRow, "iphsfromdd", iphsfromdd);// 유형시작일
  8378. ds_send_prntlist.setColumn(aRow, "diagcd" , diagcd);
  8379. // 리스트
  8380. ds_send_prntlist.setColumn(aRow, "edilnno" , ds_list2_clod.getColumn(i, "edilnno"));
  8381. ds_send_prntlist.setColumn(aRow, "item1" , ds_list2_clod.getColumn(i, "ediitem1"));
  8382. ds_send_prntlist.setColumn(aRow, "item2" , ds_list2_clod.getColumn(i, "ediitem2"));
  8383. ds_send_prntlist.setColumn(aRow, "ordfromdd" , ds_list2_clod.getColumn(i, "ordfromdd"));
  8384. ds_send_prntlist.setColumn(aRow, "grupsnglflag" , ds_list2_clod.getColumn(i, "grupsnglflag"));
  8385. ds_send_prntlist.setColumn(aRow, "grupcalcscorcd", ds_list2_clod.getColumn(i, "grupcalcscorcd"));
  8386. ds_send_prntlist.setColumn(aRow, "matractflag" , ds_list2_clod.getColumn(i, "matractflag"));
  8387. ds_send_prntlist.setColumn(aRow, "snglcalcscorcd", ds_list2_clod.getColumn(i, "snglcalcscorcd"));
  8388. ds_send_prntlist.setColumn(aRow, "basecd" , ds_list2_clod.getColumn(i, "basecd"));
  8389. ds_send_prntlist.setColumn(aRow, "estmcd" , ds_list2_clod.getColumn(i, "estmcd"));
  8390. ds_send_prntlist.setColumn(aRow, "hngnm" , ds_list2_clod.getColumn(i, "hngnm"));
  8391. ds_send_prntlist.setColumn(aRow, "payflag" , ds_list2_clod.getColumn(i, "payflag"));
  8392. ds_send_prntlist.setColumn(aRow, "ediunitcost" , ds_list2_clod.getColumn(i, "ediunitcost"));
  8393. ds_send_prntlist.setColumn(aRow, "edidrugqty" , ds_list2_clod.getColumn(i, "edidrugqty"));
  8394. ds_send_prntlist.setColumn(aRow, "tims" , ds_list2_clod.getColumn(i, "tims"));
  8395. ds_send_prntlist.setColumn(aRow, "daydrugqty" , ds_list2_clod.getColumn(i, "daydrugqty"));
  8396. ds_send_prntlist.setColumn(aRow, "dayno" , ds_list2_clod.getColumn(i, "dayno"));
  8397. ds_send_prntlist.setColumn(aRow, "ediamt" , ds_list2_clod.getColumn(i, "ediamt"));
  8398. ds_send_prntlist.setColumn(aRow, "cnfmcd" , ds_list2_clod.getColumn(i, "cnfmcd"));
  8399. ds_send_prntlist.setColumn(aRow, "ordtodd" , ds_list2_clod.getColumn(i, "ordtodd"));
  8400. ds_send_prntlist.setColumn(aRow, "updtdd" , ds_list2_clod.getColumn(i, "updtdd"));
  8401. ds_send_prntlist.setColumn(aRow, "edihospaddamt" , ds_list2_clod.getColumn(i, "edihospaddamt"));
  8402. ds_send_prntlist.setColumn(aRow, "ediaddamt" , ds_list2_clod.getColumn(i, "ediaddamt"));
  8403. ds_send_prntlist.setColumn(aRow, "totordamt" , ds_list2_clod.getColumn(i, "totordamt"));
  8404. }
  8405. var objDOM = rptf_createDOM(); // DOM 객체 설정
  8406. rptf_setNodeListToDOM(objDOM, "root/send/prntlist/prntinfo", ds_send_prntlist); // 데이터셋 1
  8407. var objParam = new Object();
  8408. objParam.xml_data_XML1 = objDOM.documentElement.source; // 최상의노드 XML 스트링 추출
  8409. var option = "open=1;save=1;directprint=0;print=1;zoom=0;callno=;faxno=";
  8410. if(ioflag == "O")
  8411. {
  8412. rptf_exeReportPreview30(["RPPID20500"],[objParam], option);
  8413. }
  8414. else
  8415. {
  8416. rptf_exeReportPreview30(["RPPID20300"],[objParam], option);
  8417. }
  8418. }
  8419. else
  8420. {
  8421. // 3. 취소
  8422. return;
  8423. }
  8424. }
  8425. else
  8426. {
  8427. sysf_messageBox("출력할 처방이", "I004"); ///출력할 처방이 없습니다.
  8428. }
  8429. }
  8430. }
  8431. /****************************************************************************************
  8432. * Argument : button
  8433. * Description : 자보한도 버튼 이벤트
  8434. ****************************************************************************************/
  8435. function grp_biz_btn_autolimit_onclick(obj:Button, e:ClickEventInfo)
  8436. {
  8437. var insukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  8438. var suppkind = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  8439. if (insukind != "31" && suppkind != "18")
  8440. {
  8441. sysf_messageBox("자보환자중 자손/책임/무보험만 한도잔액조회","I006");
  8442. return;
  8443. }
  8444. var sppmc04500 = new Object();
  8445. sppmc04500.sPid = ds_main_item1_clbs.getColumn(0, "pid");
  8446. frmf_modal("SPPMC04500", "SPPMC04500", sppmc04500, "", "", "", "", "", "", "", "", "", "M");
  8447. }
  8448. /****************************************************************************************
  8449. * Argument : oncelldblclick
  8450. * Description : 원외처방 더블 클릭 이벤트
  8451. ****************************************************************************************/
  8452. function grp_biz_grd_oprcphist_oncelldblclick(obj:Grid, e:GridClickEventInfo)
  8453. {
  8454. var col = e.col;
  8455. if(col == obj.getBindCellIndex("body", "snglcalcscorcd") || col == obj.getBindCellIndex("body", "edicd") || col == obj.getBindCellIndex("body", "hngnm"))
  8456. {
  8457. var row = e.row;
  8458. var rowstatus = ds_list7_clop.getRowType(row);
  8459. if(!utlf_isNull(ds_list7_clop.getColumn(row, col)) && rowstatus != 2)
  8460. {
  8461. lf_fGetOsclClamData("N", "grd_oprcphist");
  8462. }
  8463. }
  8464. else if(col == obj.getBindCellIndex("body", "spclspecyn"))
  8465. {
  8466. lf_fSetLnUnitClsoSpclSpec("grd_oprcphist");
  8467. }
  8468. }
  8469. /****************************************************************************************
  8470. * Argument : onrbuttondown
  8471. * Description : 원외처방 마우스 우클릭 이벤트
  8472. ****************************************************************************************/
  8473. function grp_biz_grd_oprcphist_onrbuttondown(obj:Grid, e:GridMouseEventInfo)
  8474. {
  8475. // if( ds_list7_clop.rowcount <= 0 )
  8476. // {
  8477. // // 처방이 한줄도 없는 경우에도 "행 추가"를 하기 위해 사용함 - 원외처방 수정기능 X: [2014-12-16]
  8478. // lf_clopinititem.trackPopup(e.screenX,e.screenY);
  8479. // }
  8480. // else
  8481. // {
  8482. if(!grdf_setSelectedCell(obj, e)) return;
  8483. lf_gridclop.trackPopup(e.screenX,e.screenY);
  8484. // }
  8485. }
  8486. /****************************************************************************************
  8487. * Argument : funtion
  8488. * Description : 원외처방
  8489. ****************************************************************************************/
  8490. function lf_fCallClsoSpclSpec()
  8491. {
  8492. lf_fSetLnUnitClsoSpclSpec("grd_oprcphist");
  8493. }
  8494. /****************************************************************************************
  8495. * Argument : funtion
  8496. * Description : 원외처방 행삭제
  8497. ****************************************************************************************/
  8498. function lf_fClopGridDeleteRow()
  8499. {
  8500. var cloprow = ds_list7_clop.rowposition;
  8501. if (cloprow < 0)
  8502. {
  8503. return;
  8504. }
  8505. if (utlf_isNull(ds_list7_clop.getColumn(cloprow, "newmpsno")))
  8506. {
  8507. var mpsno = ds_list7_clop.getColumn(cloprow, "mpsno");
  8508. }
  8509. else
  8510. {
  8511. var mpsno = ds_list7_clop.getColumn(cloprow, "newmpsno");
  8512. }
  8513. var clopdd = ds_list7_clop.getColumn(cloprow, "clopdd");
  8514. var clopno = ds_list7_clop.getColumn(cloprow, "clopno");
  8515. var edilnno = ds_list7_clop.getColumn(cloprow, "edilnno");
  8516. var snglcalcscorcd = ds_list7_clop.getColumn(cloprow, "snglcalcscorcd");
  8517. var seqno = ds_list7_clop.getColumn(cloprow, "seqno");
  8518. var spclspecyn = ds_list7_clop.getColumn(cloprow, "spclspecyn");
  8519. var clspdelcnt = 0;
  8520. var ans = sysf_messageBox("[ 교부일자 : " + clopdd + ", 교부번호 : " + clopno + ", 줄번호 : " + edilnno + ", 수가코드 : " + snglcalcscorcd + " ] 삭제하시려면", "S001");
  8521. if (ans == 6)
  8522. {
  8523. var adjtresncd = ds_list7_clop.getColumn(cloprow, "adjtresncd");
  8524. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  8525. {
  8526. var cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  8527. if (utlf_isNull(cmbAdjtresncd) || cmbAdjtresncd == "-" )
  8528. {
  8529. var sppiz01000 = new Object();
  8530. sppiz01000.sCdCls = "aftout";
  8531. sppiz01000.sCdid = adjtresncd;
  8532. sppiz01000.sAdjtresndesc = "";
  8533. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  8534. adjtresncd = objArg.sCdid;
  8535. }
  8536. else
  8537. {
  8538. adjtresncd = cmbAdjtresncd;
  8539. }
  8540. }
  8541. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  8542. {
  8543. return;
  8544. }
  8545. else
  8546. {
  8547. ds_list7_clop.setColumn(cloprow, "adjtresncd", adjtresncd);
  8548. }
  8549. if (spclspecyn)
  8550. {
  8551. var nodeList = ds_list3_clsp.rowcount;
  8552. for (var j = nodeList-1; j >= 0; j--)
  8553. {
  8554. var spclmpsno = ds_list3_clsp.getColumn(j, "mpsno"); // mpsno
  8555. var spclClodseqno = ds_list3_clsp.getColumn(j, "clodseqno"); // seqno
  8556. var clsoyn = ds_list3_clsp.getColumn(j, "clsoyn"); // 원외처방 특정내역 여부
  8557. if (spclmpsno == mpsno && spclClodseqno == seqno && clsoyn == "Y")
  8558. {
  8559. var clspstatus = ds_list3_clsp.getRowType(j);
  8560. if (clspstatus != 2)
  8561. {
  8562. ds_list3_clsp.setColumn(j, "rowstat","D");
  8563. ds_list3_clsp.updatecontrol = false;
  8564. ds_list3_clsp.setRowType(j, 'd');
  8565. ds_list3_clsp.updatecontrol = true;
  8566. lf_fSetSpclSpecJX999()
  8567. ds_list3_clsp.deleteRow(j);
  8568. clspdelcnt++;
  8569. }
  8570. else
  8571. {
  8572. ds_list3_clsp.deleteRow(j);
  8573. }
  8574. }
  8575. }
  8576. }
  8577. var clopstatus = ds_list7_clop.getRowType(cloprow);
  8578. ds_list7_clop.deleteRow(cloprow);
  8579. if (clspdelcnt > 0)
  8580. {
  8581. lf_fSortSpclNo();
  8582. }
  8583. }
  8584. }
  8585. /****************************************************************************************
  8586. * Argument : funtion
  8587. * Description : 원외처방 "교부번호 전체삭제"
  8588. ****************************************************************************************/
  8589. function lf_fClopGridAllDeleteRow()
  8590. {
  8591. var cloprow = ds_list7_clop.rowposition;
  8592. if (cloprow < 0)
  8593. {
  8594. return;
  8595. }
  8596. if ( utlf_isNull(ds_list7_clop.getColumn(cloprow, "newmpsno")))
  8597. {
  8598. var mpsno = ds_list7_clop.getColumn(cloprow, "mpsno");
  8599. }
  8600. else
  8601. {
  8602. var mpsno = ds_list7_clop.getColumn(cloprow, "newmpsno");
  8603. }
  8604. var oldclopdd = ds_list7_clop.getColumn(cloprow, "oldclopdd");
  8605. var oldclopno = ds_list7_clop.getColumn(cloprow, "oldclopno");
  8606. var clspdelcnt = 0;
  8607. var ans = sysf_messageBox("[ 교부일자 : " + oldclopdd + ", 교부번호 : " + oldclopno + " ] 전체삭제하시려면", "S001"); // 예(Yes)\n아니면 아니오(No)
  8608. if (ans == 6)
  8609. {
  8610. var adjtresncd = ds_list7_clop.getColumn(cloprow, "adjtresncd");
  8611. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  8612. {
  8613. var cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  8614. if (utlf_isNull(cmbAdjtresncd)|| cmbAdjtresncd == "-" )
  8615. {
  8616. var sppiz01000 = new Object();
  8617. sppiz01000.sCdCls = "aftout";
  8618. sppiz01000.sCdid = adjtresncd;
  8619. sppiz01000.sAdjtresndesc = "";
  8620. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  8621. adjtresncd = objArg.sCdid;
  8622. }
  8623. else
  8624. {
  8625. adjtresncd = cmbAdjtresncd;
  8626. }
  8627. }
  8628. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  8629. {
  8630. return;
  8631. }
  8632. var nodeList = ds_list7_clop.rowcount;
  8633. for (var row = 0; row < nodeList; row++)
  8634. {
  8635. var clopseqno = ds_list7_clop.getColumn(row, "clopseqno");
  8636. if (utlf_isNull(ds_list7_clop.getColumn(row, "newmpsno")))
  8637. {
  8638. var nowmpsno = ds_list7_clop.getColumn(row, "mpsno");
  8639. }
  8640. else
  8641. {
  8642. var nowmpsno = ds_list7_clop.getColumn(row, "newmpsno");
  8643. }
  8644. if (mpsno == nowmpsno)
  8645. {
  8646. if (ds_list7_clop.getColumn(row, "spclspecyn"))
  8647. {
  8648. for (var j = ds_list3_clsp.rowcount-1; j >= 0; j--)
  8649. {
  8650. var spclmpsno = ds_list3_clsp.getColumn(j, "mpsno"); // mpsno
  8651. var spclClodseqno = ds_list3_clsp.getColumn(j, "clodseqno"); // seqno
  8652. var clsoyn = ds_list3_clsp.getColumn(j, "clsoyn"); // 원외처방 특정내역 여부
  8653. if (spclmpsno == mpsno && spclClodseqno == clopseqno && clsoyn == "Y")
  8654. {
  8655. var clspstatus = ds_list3_clsp.getRowType(j);
  8656. if (clspstatus != 2)
  8657. {
  8658. ds_list3_clsp.setColumn(j, "rowstat","D");
  8659. ds_list3_clsp.updatecontrol = false;
  8660. ds_list3_clsp.setRowType(j, 'd');
  8661. ds_list3_clsp.updatecontrol = true;
  8662. lf_fSetSpclSpecJX999()
  8663. ds_list3_clsp.deleteRow(j);
  8664. clspdelcnt++;
  8665. }
  8666. else
  8667. {
  8668. ds_list3_clsp.deleteRow(j);
  8669. }
  8670. }
  8671. }
  8672. }
  8673. var clopstatus = ds_list7_clop.getRowType(row);
  8674. if (clopstatus != 2)
  8675. {
  8676. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd); // 삭제사유
  8677. ds_list7_clop.updatecontrol = false;
  8678. ds_list7_clop.setRowType(row, 'd');
  8679. ds_list7_clop.updatecontrol = true;
  8680. }
  8681. else
  8682. {
  8683. ds_list7_clop.deleteRow(row);
  8684. }
  8685. }
  8686. }
  8687. if (clspdelcnt > 0)
  8688. {
  8689. lf_fSortSpclNo();
  8690. }
  8691. }
  8692. }
  8693. /****************************************************************************************
  8694. * Argument : funtion
  8695. * Description : 원외처방 "수가조회"
  8696. ****************************************************************************************/
  8697. function lf_fOrderCalcScorSrch_clop(isAll)
  8698. {
  8699. frmf_setParameter("calcscorcd", ds_list7_clop.getColumn(ds_list7_clop.rowposition, "snglcalcscorcd"));
  8700. frmf_setParameter("judgflag", "Y");
  8701. var trgtManWindow = frmf_getChildWindow("SMPIC00100");
  8702. if (utlf_isNull(trgtManWindow))
  8703. {
  8704. frmf_open("SMPIC00100", "SMPIC00100", "", "", "", "", "", "", "", "", "", "", "M");
  8705. } else {
  8706. trgtManWindow.fPopupMode();
  8707. }
  8708. }
  8709. /****************************************************************************************
  8710. * Argument : funtion
  8711. * Description : 원외처방 "약품편람"
  8712. ****************************************************************************************/
  8713. function lf_fOrderDrugHBook_clop()
  8714. {
  8715. dsf_createDsRow("ds_cond_SMADB01900", [{col:"srchdrugcd", type:"STRING", size:256, val: ds_list7_clop.getColumn(ds_list7_clop.rowposition, "snglcalcscorcd")}]);
  8716. var objArg = new Object();
  8717. objArg.arg_ds_hidden_receivedata = ds_cond_SMADB01900;
  8718. frmf_open("SMADB01900", "SMADB01900", objArg, "", "", "", "", "", "", "", "", "", "M");
  8719. }
  8720. /****************************************************************************************
  8721. * Argument : oncelldblclick
  8722. * Description : 처방 더블 클릭 이벤트
  8723. ****************************************************************************************/
  8724. function grp_biz_grd_clodhist_oncelldblclick(obj:Grid, e:GridClickEventInfo)
  8725. {
  8726. var col = e.col;
  8727. if (col == obj.getBindCellIndex("body", "estmmncd") || col == obj.getBindCellIndex("body", "estmcd"))
  8728. {
  8729. var row = e.row;
  8730. var isEstm = false;
  8731. var matractflag = ds_list2_clod.getColumn(row, "matractflag");
  8732. // (P0137) 1 : 재료, 2 : 가산있는 행위, 3 : 가산없는 행위, 4:약제, - : 해당없음
  8733. if (matractflag == "2")
  8734. {
  8735. isEstm = true;
  8736. }
  8737. else
  8738. {
  8739. // 검체코드 별로 EDI코드가 존재하는 경우 가X행위로 코드길이는 8자리이고 산정붙은 EDI코드와 basecd가 동일함.
  8740. // 산정코드 바꾸려면 처방 삭제후 신규추가해야하므로 코드 길이를 체크함 (picmediu 예:C4722616)
  8741. var basecd = ds_list2_clod.getColumn(row, "basecd");
  8742. if (basecd.length == 5)
  8743. {
  8744. isEstm = true;
  8745. }
  8746. else
  8747. {
  8748. var ediitem = ds_list2_clod.getColumn(row, "ediitem");
  8749. if (ediitem == "0101" || ediitem == "0102" || ediitem == "0103"|| ediitem == "0201" || ediitem == "0202" || ediitem == "0203" || ediitem == "0204" || ediitem == "0299")
  8750. {
  8751. isEstm = true;
  8752. }
  8753. }
  8754. }
  8755. if (isEstm == false)
  8756. {
  8757. return;
  8758. }
  8759. lf_fSrchEstmCd();
  8760. }
  8761. else if (col == obj.getBindCellIndex("body", "lnunitspclspecyn"))
  8762. {
  8763. // 'T' 필드
  8764. // 특정내역 : SPPIZ00500_특정내역상세관리.xrw
  8765. lf_fSetLnUnitSpclSpec();
  8766. }
  8767. else if (col == obj.getBindCellIndex("body", "toot1"))
  8768. {
  8769. // '치식' 필드
  8770. // 상병 및 처방 치식 입력
  8771. lf_fDiagOrderToothInput("Order");
  8772. }
  8773. else if (col == obj.getBindCellIndex("body", "grupcalcscorcd") || col == obj.getBindCellIndex("body", "snglcalcscorcd") || col == obj.getBindCellIndex("body", "basecd") || col == grp_biz.grd_clodhist.getBindCellIndex("body", "ediecd") || col == obj.getBindCellIndex("body", "hngnm"))
  8774. {
  8775. var row = e.row;
  8776. var rowstatus = ds_list2_clod.getRowType(row);
  8777. if (!utlf_isNull(ds_list2_clod.getColumn(e.row, e.col)) && rowstatus != 2)
  8778. {
  8779. if(ds_main_item1_clbs.getColumn(0, "ioflag") == "O")
  8780. {
  8781. lf_fGetOsclClamData("N", "grd_clodhist");
  8782. }
  8783. else
  8784. {
  8785. fOrderCalcDetail();
  8786. }
  8787. }
  8788. }
  8789. }
  8790. /****************************************************************************************
  8791. * Argument : oncellclick
  8792. * Description : 처방 셀 클릭 이벤트
  8793. ****************************************************************************************/
  8794. function grp_biz_grd_clodhist_oncellclick(obj:Grid, e:GridClickEventInfo)
  8795. {
  8796. var row = ds_list2_clod.rowposition;
  8797. ds_hidden_item5_clod.copyRow(0, ds_list2_clod, row);
  8798. if ( e.col == obj.getBindCellIndex("body", "estmmncd") || e.col == obj.getBindCellIndex("body", "estmcd"))
  8799. {
  8800. // Message 표시
  8801. var estmcls = ds_list2_clod.getColumn(e.row, "estmcls");
  8802. var estmmncd = ds_list2_clod.getColumn(e.row, "estmmncd");
  8803. var estmcd = ds_list2_clod.getColumn(e.row, "estmcd");
  8804. var estmcdnm = ds_list2_clod.getColumn(e.row, "estmcdnm");
  8805. if (estmcls)
  8806. {
  8807. var msg = "산정코드 ["+ estmcls +"] ";
  8808. if (!utlf_isNull(estmmncd) && estmmncd != "-")
  8809. {
  8810. msg += "산정의미코드: "+ estmmncd;
  8811. }
  8812. else
  8813. {
  8814. ds_hidden_list3.setColumn(0, "msgspclformat", msg +" 입력된 산정의미코드가 없습니다.");
  8815. return;
  8816. }
  8817. if (estmcd)
  8818. {
  8819. msg += " / 산정코드: "+ estmcd;
  8820. }
  8821. if (estmcdnm)
  8822. {
  8823. msg += " / 명칭: "+ estmcdnm;
  8824. }
  8825. ds_hidden_list3.setColumn(0, "msgspclformat", msg);
  8826. }
  8827. else
  8828. {
  8829. ds_hidden_list3.setColumn(0, "msgspclformat", "조회된 산정코드가 없습니다.");
  8830. }
  8831. }
  8832. else if ( e.col == obj.getBindCellIndex("body", "cnfmcd"))
  8833. {
  8834. // '확인코드' 필드
  8835. // Message 표시
  8836. var seqno = ds_list2_clod.getColumn(e.row, "seqno");
  8837. var clspindex = "";
  8838. for ( var j = 0; j < ds_list3_clsp.rowcount; j++ )
  8839. {
  8840. var spcClodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  8841. var unitflag = ds_list3_clsp.getColumn(j, "unitflag");
  8842. if (unitflag == "J" && seqno == spcClodseqno && ds_list3_clsp.getColumn(j, "spclcd") == "JT001" && ds_list3_clsp.getRowType(j) != 8)
  8843. {
  8844. clspindex = j;
  8845. j = ds_list3_clsp.rowcount-1;
  8846. }
  8847. }
  8848. if (clspindex)
  8849. {
  8850. var spclcd = ds_list3_clsp.getColumn(clspindex, "spclcd");
  8851. var spclspec = ds_list3_clsp.getColumn(clspindex, "spclspec");
  8852. var spclformat = ds_list3_clsp.getColumn(clspindex, "spclformat");
  8853. ds_hidden_list3.setColumn(0, "msgspclformat", "확인코드 - "+ spclcd +" / 입력코드내역 : "+ spclspec +" / 기재형식 : "+ spclformat);
  8854. }
  8855. else
  8856. {
  8857. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 확인코드 내역이 없습니다.");
  8858. }
  8859. }
  8860. else if ( e.col == obj.getBindCellIndex("body", "lnunitspclspecyn"))
  8861. {
  8862. // 'T' 필드
  8863. // Message 표시
  8864. var seqno = ds_list2_clod.getColumn(e.row, "seqno");
  8865. var clspindex = "";
  8866. for ( var j = 0; j < ds_list3_clsp.rowcount; j++ )
  8867. {
  8868. var spcClodseqno = ds_list3_clsp.getColumn(j, "clodseqno");
  8869. var unitflag = ds_list3_clsp.getColumn(j, "unitflag");
  8870. if (unitflag == "J" && seqno == spcClodseqno && ds_list3_clsp.getColumn(j, "spclcd") == "JT001" && ds_list3_clsp.getRowType(j) != 8)
  8871. {
  8872. clspindex = j;
  8873. j = ds_list3_clsp.rowcount-1;
  8874. }
  8875. }
  8876. if (clspindex)
  8877. {
  8878. var spclcd = ds_list3_clsp.getColumn(clspindex, "spclcd");
  8879. var cdnm = ds_list3_clsp.getColumn(clspindex, "cdnm");
  8880. var spclspec = ds_list3_clsp.getColumn(clspindex, "spclspec");
  8881. var spclformat = ds_list3_clsp.getColumn(clspindex, "spclformat");
  8882. ds_hidden_list3.setColumn(0, "msgspclformat", "특정내역코드: "+ spclcd +" / 특정내역명칭: "+ cdnm +" / 기재내역: "+ spclspec +" / 기재형식: "+ spclformat);
  8883. }
  8884. else
  8885. {
  8886. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  8887. }
  8888. }
  8889. else if ( e.col == obj.getBindCellIndex("body", "hosinresncd"))
  8890. {
  8891. // '원내사유코드' 필드
  8892. //lf_fSetHosInResnCd();
  8893. }
  8894. else if ( e.col == obj.getBindCellIndex("body", "adjtresncd"))
  8895. {
  8896. // '심사사유' 필드
  8897. var adjtresncd = ds_list2_clod.getColumn(e.row, "adjtresncd");
  8898. //if (!utlf_isNull(adjtresncd) && adjtresncd != "-" )
  8899. //{
  8900. lf_fSetAdjtResnCd();
  8901. //}
  8902. }
  8903. }
  8904. /****************************************************************************************
  8905. * Argument : function
  8906. * Description : 원내사유코드에 따라 의약분업예외환자 요율로 재계산한다.
  8907. ****************************************************************************************/
  8908. function lf_fSetHosInResnCd()
  8909. {
  8910. var row = ds_list2_clod.rowposition;
  8911. var objArg = new Object();
  8912. objArg.sOldcd = ds_list2_clod.getColumn(row, "hosinresncd");
  8913. frmf_modal("SPPIZ01500", "SPPIZ01500", objArg, "", "", "", "", "", "", "", "", "", "M");
  8914. var hosinresncd = ds_rslt_sppiz01500.getColumn(0, "cdid");
  8915. if (!utlf_isNull(hosinresncd))
  8916. {
  8917. if ( hosinresncd == "00" )
  8918. {
  8919. //ediflagcd 가 3일때 예외가 없으면 팝업 띄울려고 함. 00값 들어가게끔 수정 20130617 이재호
  8920. hosinresncd = "";
  8921. }
  8922. for (var i = 0; i < ds_list2_clod.rowcount; i++)
  8923. {
  8924. if ( ds_list2_clod.getSelect(i))
  8925. {
  8926. var ordfromdd = ds_list2_clod.getColumn(i, "ordfromdd");
  8927. if (utlf_isNull(ordfromdd))
  8928. {
  8929. //처방일시는 필수입력입니다.
  8930. sysf_messageBox("처방일시는", "I003");
  8931. }
  8932. else
  8933. {
  8934. var edicdflag = ds_list2_clod.getColumn(i, "edicdflag");
  8935. var edicd = ds_list2_clod.getColumn(i, "edicd");
  8936. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  8937. var oldcd = ds_list2_clod.getColumn(i, "hosinresncd");
  8938. // 3:보험등재약에 대해서만 원내사유코드를 입력할 수 있다.
  8939. if ( edicdflag == "3" && snglcalcscorcd )
  8940. {
  8941. ds_list2_clod.setColumn(i, "hosinresncd", hosinresncd);
  8942. if (hosinresncd != oldcd && ds_list2_clod.getRowType(i) == 1)
  8943. {
  8944. ds_list2_clod.updatecontrol = false;
  8945. ds_list2_clod.setRowType(i, "u");
  8946. ds_list2_clod.updatecontrol = true;
  8947. // 처방 Grid 배경색을 설정한다. - 추가/수정된 row
  8948. lf_fOrderBkColorNew(i);
  8949. }
  8950. // 변경된 분업예외코드 특정내역에 반영
  8951. var isFind = false;
  8952. var seqno = ds_list2_clod.getColumn(i, "seqno");
  8953. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  8954. var okmsg = "분업예외코드";
  8955. var spclcd = "JS002";
  8956. var cdnm = "분업예외코드";
  8957. var spclspec = hosinresncd;
  8958. var spclformat = "9(2)";
  8959. var detldesc = "의약분업 예외사항 발생으로 의료기관에서 원내 조제/투약이 이루어진 경우 해당 예외구분코드를 기재하고, 원외처방발행기에서 퇴장방지의약품 원외처방시 해당의약품의 사용장려비를 청구할 경우 구분코드 99를 기재";
  8960. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  8961. {
  8962. var spclColdSeqno = ds_list3_clsp.getColumn(j, "clodseqno");
  8963. var unitflag = ds_list3_clsp.getColumn(j, "unitflag");
  8964. if (unitflag == "J" && seqno == spclColdSeqno && ds_list3_clsp.getColumn(j, "spclcd") == "JS002" && ds_list3_clsp.getRowType(j) != 8)
  8965. {
  8966. ds_list3_clsp.setColumn(j, "spclspec", spclspec);
  8967. var rowstatus = ds_list3_clsp.getRowType(j);
  8968. if ( rowstatus == 1 || rowstatus == 2)
  8969. {
  8970. }
  8971. else
  8972. {
  8973. // 2 : update 상태로 stat를 변경한다.
  8974. ds_list3_clsp.updatecontrol = false;
  8975. ds_list3_clsp.setRowType(j, 'u');
  8976. ds_list3_clsp.updatecontrol = true;
  8977. }
  8978. isFind = true;
  8979. }
  8980. }
  8981. if (isFind == false)
  8982. {
  8983. // 기존에 없었던 경우
  8984. var clsprow = ds_list3_clsp.addRow();
  8985. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  8986. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  8987. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  8988. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", ds_list2_clod.getColumn(i, "snglcalcscorcd"));
  8989. ds_list3_clsp.setColumn(clsprow, "spclcd", spclcd);
  8990. ds_list3_clsp.setColumn(clsprow, "cdnm", cdnm);
  8991. ds_list3_clsp.setColumn(clsprow, "spclspec", spclspec);
  8992. ds_list3_clsp.setColumn(clsprow, "spclformat", spclformat);
  8993. ds_list3_clsp.setColumn(clsprow, "detldesc", detldesc);
  8994. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  8995. ds_list3_clsp.setColumn(clsprow, "edicdflag", edicdflag);
  8996. ds_list3_clsp.setColumn(clsprow, "edicd", edicd);
  8997. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  8998. ds_list3_clsp.rowposition = clsprow;
  8999. }
  9000. } // if ((edicdflag == "3" && snglcalcscorcd) || oldcd) 끝
  9001. } // ordfromdd 가 입력된 경우
  9002. }
  9003. } // for (var i = 0; i < grd_clodhist.selectedRows; i++) 끝
  9004. } // if (hosinresncd) 끝
  9005. }
  9006. /****************************************************************************************
  9007. * Argument : onexpanddown
  9008. * Description : 처방 확인코드 expanddown
  9009. ****************************************************************************************/
  9010. function grp_biz_grd_clodhist_onexpanddown(obj:Grid, e:GridMouseEventInfo)
  9011. {
  9012. lf_fOrderGridInsertCnfmCd();
  9013. }
  9014. /****************************************************************************************
  9015. * Argument : function
  9016. * Description : 입력한 산정의미코드에 해당하는 산정코드를 조회한다.
  9017. ****************************************************************************************/
  9018. function lf_fSrchEstmCd()
  9019. {
  9020. ds_rslt_sppiz00800.clearData();
  9021. ds_rslt_sppiz00800.addRow();
  9022. ds_cond_sppiz00800.clearData();
  9023. ds_cond_sppiz00800.addRow();
  9024. var row = grp_biz.grd_clodhist.currentrow;
  9025. var estmcls = ds_list2_clod.getColumn(row, "estmcls");
  9026. var insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  9027. if (utlf_isNull(insukindcd))
  9028. {
  9029. // 심사대상자의 보험유형이 없습니다
  9030. sysf_messageBox("심사대상자의 보험유형이", "I004");
  9031. return false;
  9032. }
  9033. ds_cond_sppiz00800.setColumn(0, "name" , this.name);
  9034. ds_cond_sppiz00800.setColumn(0, "insukind" , insukindcd);
  9035. ds_cond_sppiz00800.setColumn(0, "calcscorcd", ds_list2_clod.getColumn(row, "snglcalcscorcd"));
  9036. ds_cond_sppiz00800.setColumn(0, "estmcls" , estmcls);
  9037. ds_cond_sppiz00800.setColumn(0, "estmmncd" , ds_list2_clod.getColumn(row, "estmcd"));
  9038. ds_cond_sppiz00800.setColumn(0, "todd" , ds_list2_clod.getColumn(row, "ordtodd"));
  9039. var rtn = frmf_modal("SPPIZ00800","SPPIZ00800", {objDs:ds_cond_sppiz00800}, "", "", "", "", "", "", "", "", "", "M");
  9040. if (!utlf_isNull(ds_rslt_sppiz00800.getColumn(0, "estmcd")))
  9041. {
  9042. // 리턴값이 있으면
  9043. var estmmncd = ds_rslt_sppiz00800.getColumn(0, "estmmncd");
  9044. var oldestmmncd = ds_list2_clod.getColumn(row, "estmmncd");
  9045. if (estmmncd == "0000" && utlf_isNull(oldestmmncd))
  9046. {
  9047. }
  9048. else
  9049. {
  9050. if (estmmncd != oldestmmncd)
  9051. {
  9052. var adjtresncd = ds_list2_clod.getColumn(row, "adjtresncd");
  9053. var cmbAdjtresncd = "";
  9054. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  9055. {
  9056. // 심사(조정)사유가 입력되지 않은 경우
  9057. cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  9058. if (!utlf_isNull(cmbAdjtresncd))
  9059. {
  9060. ds_hidden_list2_clodstat.setColumn(row, "adjtresncd", cmbAdjtresncd);
  9061. }
  9062. else
  9063. {
  9064. var newcd = lf_fSetAdjtResnCd();
  9065. if (utlf_isNull(newcd) || newcd == "-")
  9066. {
  9067. return;
  9068. }
  9069. }
  9070. }
  9071. lf_fSetOrderChangeRowStat(row);
  9072. }
  9073. else
  9074. {
  9075. return;
  9076. }
  9077. var oldestmcd = ds_list2_clod.getColumn(row, "estmcd");
  9078. var oldestmcdnm = ds_list2_clod.getColumn(row, "estmcdnm");
  9079. ds_list2_clod.setColumn(row, "estmmncd", estmmncd);
  9080. ds_list2_clod.setColumn(row, "estmcd" , ds_rslt_sppiz00800.getColumn(0, "estmcd"));
  9081. ds_list2_clod.setColumn(row, "estmcdnm", ds_rslt_sppiz00800.getColumn(0, "estmcdnm"));
  9082. var rslt = lf_fSetEstmCd();
  9083. row = grp_biz.grd_clodhist.currentrow;
  9084. if (rslt == false)
  9085. {
  9086. ds_list2_clod.setColumn(row, "estmmncd", oldestmmncd);
  9087. ds_list2_clod.setColumn(row, "estmcd" , oldestmcd);
  9088. ds_list2_clod.setColumn(row, "estmcdnm", oldestmcdnm);
  9089. }
  9090. else
  9091. {
  9092. if (row != -1 && estmmncd == "0000") {
  9093. // sort 이후에 선택된 row가 있고
  9094. estmmncd = "";
  9095. ds_list2_clod.setColumn(row, "estmmncd", estmmncd);
  9096. ds_list2_clod.setColumn(row, "estmcd" , "");
  9097. ds_list2_clod.setColumn(row, "estmcdnm", "");
  9098. }
  9099. }
  9100. }
  9101. }
  9102. if (row == -1)
  9103. {
  9104. // sort 이후에 선택된 row가 없음
  9105. return false;
  9106. }
  9107. var estmmncd = ds_list2_clod.getColumn(row, "estmmncd");
  9108. var msg = "산정분류 [" + estmcls + "] ";
  9109. if (!utlf_isNull(estmmncd))
  9110. {
  9111. msg += "산정의미코드: " + estmmncd;
  9112. }
  9113. else
  9114. {
  9115. ds_hidden_list3.setColumn(0, "msg", msg + " 입력된 산정의미코드가 없습니다.");
  9116. return true;
  9117. }
  9118. var estmcd = ds_rslt_sppiz00800.getColumn(0, "estmcd");
  9119. var estmcdnm = ds_rslt_sppiz00800.getColumn(0, "estmcdnm");
  9120. if (!utlf_isNull(estmcd))
  9121. {
  9122. msg += " / 산정코드: " + estmcd;
  9123. }
  9124. if (!utlf_isNull(estmcdnm))
  9125. {
  9126. msg += " / 명칭: " + estmcdnm;
  9127. }
  9128. var addmthd = ds_rslt_sppiz00800.getColumn(0, "addmthd");
  9129. if (addmthd)
  9130. {
  9131. msg += " // 계산방법: [" + addmthd + "] ";
  9132. msg += ds_rslt_sppiz00800.getColumn(0, "pnt");
  9133. msg += " / " + ds_rslt_sppiz00800.getColumn(0, "amt");
  9134. msg += " / " + ds_rslt_sppiz00800.getColumn(0, "rate");
  9135. }
  9136. else
  9137. {
  9138. msg += " // 조회된 산정코드가 없습니다.";
  9139. }
  9140. ds_hidden_list3.setColumn(0, "msgspclformat", msg);
  9141. return true;
  9142. }
  9143. /****************************************************************************************
  9144. * Argument : function
  9145. * Description : 수가코드의 estmcls(산정분류)에 따라 선택가능한 5자리의 estmmncd(산정의미), 이에 해당하는 3자리의 estmcd(산정코드)를 조회하고 금액을 재계산한다.
  9146. ****************************************************************************************/
  9147. function lf_fSetEstmCd()
  9148. {
  9149. var row = ds_list2_clod.rowposition;
  9150. ds_send_item5_mech.clearData();
  9151. ds_send_item5_mech.addRow();
  9152. var ordfromdd = ds_list2_clod.getColumn(row, "ordfromdd");
  9153. var ordtodd = ds_list2_clod.getColumn(row, "ordtodd");
  9154. if (utlf_isNull(ordfromdd) || utlf_isNull(ordtodd) )
  9155. {
  9156. //실시일자는 필수입력입니다.
  9157. sysf_messageBox("처방시작일 & 종료일은", "I003");
  9158. return false;
  9159. }
  9160. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  9161. if (utlf_isNull(snglcalcscorcd))
  9162. {
  9163. //수가코드가 입력되지 않았습니다.
  9164. sysf_messageBox("수가코드가 입력되지", "E007");
  9165. return false;
  9166. }
  9167. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", snglcalcscorcd);
  9168. ds_send_item5_mech.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  9169. ds_send_item5_mech.setColumn(0, "suppkind" , ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  9170. var orddeptcd = ds_list2_clod.getColumn(row, "orddeptcd");
  9171. if (orddeptcd)
  9172. {
  9173. ds_send_item5_mech.setColumn(0, "orddeptcd", orddeptcd);
  9174. }
  9175. else
  9176. {
  9177. ds_send_item5_mech.setColumn(0, "orddeptcd", ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  9178. }
  9179. var orddrid = ds_list2_clod.getColumn(row, "orddrid");
  9180. if (orddrid)
  9181. {
  9182. ds_send_item5_mech.setColumn(0, "orddrid", orddrid);
  9183. }
  9184. else
  9185. {
  9186. ds_send_item5_mech.setColumn(0, "orddrid", ds_main_item1_clbs.getColumn(0, "orddrid"));
  9187. }
  9188. ds_send_item5_mech.setColumn(0, "orddd", ds_list2_clod.getColumn(row, "orddd"));
  9189. ds_send_item5_mech.setColumn(0, "ordfromdd", ds_list2_clod.getColumn(row, "ordfromdd"));
  9190. ds_send_item5_mech.setColumn(0, "ordtodd", ds_list2_clod.getColumn(row, "ordtodd"));
  9191. var estmmncd = ds_list2_clod.getColumn(row, "estmmncd");
  9192. if (estmmncd != "-")
  9193. {
  9194. ds_send_item5_mech.setColumn(0, "estmmncd", estmmncd);
  9195. }
  9196. else
  9197. {
  9198. //산정의미코드가 입력되지 않았습니다.
  9199. sysf_messageBox("산정의미코드가 입력되지", "E007");
  9200. return false;
  9201. }
  9202. var drugqty = ds_list2_clod.getColumn(row, "drugqty");
  9203. if (utlf_isNull(drugqty))
  9204. {
  9205. drugqty = "1";
  9206. }
  9207. ds_send_item5_mech.setColumn(0, "drugqty", drugqty);
  9208. var tims = ds_list2_clod.getColumn(row, "tims");
  9209. if (utlf_isNull(tims))
  9210. {
  9211. tims = "1";
  9212. }
  9213. ds_send_item5_mech.setColumn(0, "tims", tims);
  9214. var dayno = ds_list2_clod.getColumn(row, "dayno");
  9215. if (utlf_isNull(dayno))
  9216. {
  9217. dayno = "1";
  9218. }
  9219. ds_send_item5_mech.setColumn(0, "dayno", dayno);
  9220. ds_send_item5_mech.setColumn(0, "adjtresncd" , ds_list2_clod.getColumn(row, "adjtresncd"));
  9221. ds_send_item5_mech.setColumn(0, "payflag" , ds_list2_clod.getColumn(row, "payflag"));
  9222. ds_send_item5_mech.setColumn(0, "undersixageyn" , ds_main_item1_clbs.getColumn(0, "undersixageyn"));
  9223. ds_send_item5_mech.setColumn(0, "mechage" , ds_main_item1_clbs.getColumn(0, "mechage"));
  9224. ds_send_item5_mech.setColumn(0, "hosinresncd" , ds_list2_clod.getColumn(row, "hosinresncd"));
  9225. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  9226. ds_send_item5_mech.setColumn(0, "clamflagcd" , ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  9227. ds_send_item5_mech.setColumn(0, "mode", "u");
  9228. var oParam = {};
  9229. oParam.id = "TRPID20303";
  9230. oParam.service = "aftjudgapp.InAftJudg";
  9231. oParam.method = "reqGetCalcScorCd";
  9232. oParam.inds = "req=ds_send_item5_mech";
  9233. oParam.outds = "ds_main_item5_mech=mech";
  9234. oParam.async = false;
  9235. //oParam.callback = "cf_TRPID20303";
  9236. tranf_submit(oParam);
  9237. var clod = ds_main_item5_mech.rowcount;
  9238. if (clod == 1)
  9239. {
  9240. var mechfromdd = ds_main_item5_mech.getColumn(0, "mechfromdd");
  9241. var mechtodd = ds_main_item5_mech.getColumn(0, "mechtodd");
  9242. if (mechfromdd && mechtodd)
  9243. {
  9244. lf_fSetCalcScorAmt(clod, "update");
  9245. }
  9246. else
  9247. {
  9248. //산정코드가 올바르지 않거나 조회된 처방 계산 내역이 없습니다
  9249. sysf_messageBox("산정코드가 올바르지 않거나 조회된 처방 계산 내역이", "I004");
  9250. return false;
  9251. }
  9252. }
  9253. else
  9254. {
  9255. //조회된 처방 계산 내역이 없습니다
  9256. sysf_messageBox("조회된 처방 계산 내역이", "I004");
  9257. return false;
  9258. }
  9259. return true;
  9260. }
  9261. /****************************************************************************************
  9262. * Argument : function
  9263. * Description : 조회한 수가코드의 금액정보를 표시한다.
  9264. ****************************************************************************************/
  9265. function lf_fSetCalcScorAmt(clod, mode)
  9266. {
  9267. ds_list2_clod.enableevent = false;
  9268. for ( var i = 0; i < clod; i++ )
  9269. {
  9270. // 싱글 수가코드 개수 만큼
  9271. var row = ds_list2_clod.rowposition;
  9272. if (mode == "new")
  9273. {
  9274. ds_list2_clod.setColumn(row, "grupsnglflag" , ds_main_item5_mech.getColumn(i, "grupsnglflag")); // 그룹싱글구분
  9275. ds_list2_clod.setColumn(row, "grupseqno" , ds_main_item5_mech.getColumn(i, "grupseqno")); // 그룹 정렬순번
  9276. ds_list2_clod.setColumn(row, "grupcalcscorcd", ds_main_item5_mech.getColumn(i, "grupcalcscorcd"));
  9277. ds_list2_clod.setColumn(row, "snglcalcscorcd", ds_main_item5_mech.getColumn(i, "snglcalcscorcd"));
  9278. ds_list2_clod.setColumn(row, "orddeptcd" , ds_main_item5_mech.getColumn(i, "orddeptcd"));
  9279. ds_list2_clod.setColumn(row, "orddrid" , ds_main_item5_mech.getColumn(i, "orddrid"));
  9280. ds_list2_clod.setColumn(row, "matractflag" , ds_main_item5_mech.getColumn(i, "matractflag"));
  9281. ds_list2_clod.setColumn(row, "item" , ds_main_item5_mech.getColumn(i, "item"));
  9282. ds_list2_clod.setColumn(row, "payflag" , ds_main_item5_mech.getColumn(i, "payflag"));
  9283. ds_list2_clod.setColumn(row, "payownbrate" , ds_main_item5_mech.getColumn(i, "payownbrate"));
  9284. ds_list2_clod.setColumn(row, "pynpy1" , ds_main_item5_mech.getColumn(i, "pynpy1"));
  9285. ds_list2_clod.setColumn(row, "earncls1" , ds_main_item5_mech.getColumn(i, "earncls1"));
  9286. ds_list2_clod.setColumn(row, "earncls2" , ds_main_item5_mech.getColumn(i, "earncls2"));
  9287. ds_list2_clod.setColumn(row, "earncls3" , ds_main_item5_mech.getColumn(i, "earncls3"));
  9288. if (ds_main_item5_mech.getColumn(i, "insupynpy2") == "8" || ds_main_item5_mech.getColumn(i, "insupynpy2") == "9") {
  9289. if (sysf_messageBox("선별급여품목입니다. 적용하","S001") == 6)
  9290. {
  9291. var ls_hang = "";
  9292. var ls_mok = "";
  9293. if(ds_main_item5_mech.getColumn(i, "insupynpy2") == "8"){
  9294. ls_hang = "AA";
  9295. } else if(ds_main_item5_mech.getColumn(i, "insupynpy2") == "9"){
  9296. ls_hang = "BB";
  9297. }
  9298. if(ds_main_item5_mech.getColumn(i, "matrflag") == "1"){
  9299. ls_mok = '01';
  9300. } else if(ds_main_item5_mech.getColumn(i, "matrflag") == "2"){
  9301. ls_mok = '02';
  9302. } else {
  9303. ls_mok = '03';
  9304. }
  9305. ds_list2_clod.setColumn(row, "ediitem1" , ls_hang);
  9306. ds_list2_clod.setColumn(row, "ediitem2" , ls_mok);
  9307. ds_list2_clod.setColumn(row, "ediitem" , ls_hang + ls_mok);
  9308. } else {
  9309. ds_list2_clod.setColumn(row, "ediitem1" , ds_main_item5_mech.getColumn(i, "ediitem1"));
  9310. ds_list2_clod.setColumn(row, "ediitem2" , ds_main_item5_mech.getColumn(i, "ediitem2"));
  9311. ds_list2_clod.setColumn(row, "ediitem" , ds_main_item5_mech.getColumn(i, "ediitem"));
  9312. }
  9313. } else {
  9314. ds_list2_clod.setColumn(row, "ediitem1" , ds_main_item5_mech.getColumn(i, "ediitem1"));
  9315. ds_list2_clod.setColumn(row, "ediitem2" , ds_main_item5_mech.getColumn(i, "ediitem2"));
  9316. ds_list2_clod.setColumn(row, "ediitem" , ds_main_item5_mech.getColumn(i, "ediitem"));
  9317. }
  9318. ds_list2_clod.setColumn(row, "cnfmcd" , ds_main_item5_mech.getColumn(i, "cnfmcd"));
  9319. ds_list2_clod.setColumn(row, "orddd" , ds_main_item5_mech.getColumn(i, "orddd"));
  9320. ds_list2_clod.setColumn(row, "calcappyn" , ds_main_item5_mech.getColumn(i, "calcappyn"));
  9321. var fRow = ds_init_orddrid2.findRow("cd", ds_main_item5_mech.getColumn(i, "orddrid"));
  9322. var orddrnm = ds_init_orddrid2.getColumn(fRow, "nm");
  9323. ds_list2_clod.setColumn(row, "orddrnm" , orddrnm);
  9324. // 신규입력된 처방은 edilnno는 0, seqno는 최종번호를 셋팅하고 maxseqno에 최종값을 +1한다.
  9325. ds_list2_clod.setColumn(row, "edilnno", "0");
  9326. var maxseqno = ds_rslt_maxseqno.getColumn(0, "seqno");
  9327. ds_list2_clod.setColumn(row, "seqno", maxseqno);
  9328. ds_rslt_maxseqno.setColumn(0, "seqno", parseInt(maxseqno)+1);
  9329. }
  9330. ds_list2_clod.setColumn(row, "mechfromdd" , ds_main_item5_mech.getColumn(i, "mechfromdd"));
  9331. ds_list2_clod.setColumn(row, "mechtodd" , ds_main_item5_mech.getColumn(i, "mechtodd"));
  9332. ds_list2_clod.setColumn(row, "unitcost" , ds_main_item5_mech.getColumn(i, "unitcost"));
  9333. ds_list2_clod.setColumn(row, "drugqty" , ds_main_item5_mech.getColumn(i, "drugqty"));
  9334. ds_list2_clod.setColumn(row, "tims" , ds_main_item5_mech.getColumn(i, "tims"));
  9335. ds_list2_clod.setColumn(row, "daydrugqty" , ds_main_item5_mech.getColumn(i, "daydrugqty"));
  9336. ds_list2_clod.setColumn(row, "dayno" , ds_main_item5_mech.getColumn(i, "dayno"));
  9337. ds_list2_clod.setColumn(row, "totdrugqty" , ds_main_item5_mech.getColumn(i, "totdrugqty"));
  9338. ds_list2_clod.setColumn(row, "amt" , ds_main_item5_mech.getColumn(i, "amt"));
  9339. ds_list2_clod.setColumn(row, "basecd" , ds_main_item5_mech.getColumn(i, "basecd"));
  9340. ds_list2_clod.setColumn(row, "baserlapnt" , ds_main_item5_mech.getColumn(i, "baserlapnt"));
  9341. ds_list2_clod.setColumn(row, "baseaddrlapnt" , ds_main_item5_mech.getColumn(i, "baseaddrlapnt"));
  9342. ds_list2_clod.setColumn(row, "estmcls" , ds_main_item5_mech.getColumn(i, "estmcls"));
  9343. ds_list2_clod.setColumn(row, "estmmncd" , ds_main_item5_mech.getColumn(i, "estmmncd"));
  9344. ds_list2_clod.setColumn(row, "pntunitcost" , ds_main_item5_mech.getColumn(i, "pntunitcost"));
  9345. if (utlf_isNull(ds_main_item5_mech.getColumn(i, "hosinresncd")))
  9346. {
  9347. ds_list2_clod.setColumn(row, "hosinresncd" , "00");
  9348. }
  9349. else
  9350. {
  9351. ds_list2_clod.setColumn(row, "hosinresncd" , ds_main_item5_mech.getColumn(i, "hosinresncd"));
  9352. }
  9353. ds_list2_clod.setColumn(row, "ordfromdd" , ds_main_item5_mech.getColumn(i, "ordfromdd"));
  9354. ds_list2_clod.setColumn(row, "ordtodd" , ds_main_item5_mech.getColumn(i, "ordtodd"));
  9355. var l_edicdflag = utlf_transNullToEmpty(ds_init_PK257list.lookupExpr("cdid=='" + ds_main_item5_mech.getColumn(i, "snglcalcscorcd") + "'","detldesc"));
  9356. if (l_edicdflag.length > 0){
  9357. ds_list2_clod.setColumn(row, "edicdflag" , l_edicdflag);
  9358. } else {
  9359. ds_list2_clod.setColumn(row, "edicdflag" , ds_main_item5_mech.getColumn(i, "edicdflag"));
  9360. }
  9361. ds_list2_clod.setColumn(row, "edicd" , ds_main_item5_mech.getColumn(i, "edicd"));
  9362. ds_list2_clod.setColumn(row, "ediunitcost" , ds_main_item5_mech.getColumn(i, "ediunitcost"));
  9363. ds_list2_clod.setColumn(row, "edidrugqty" , ds_main_item5_mech.getColumn(i, "edidrugqty"));
  9364. ds_list2_clod.setColumn(row, "edidayno" , ds_main_item5_mech.getColumn(i, "edidayno"));
  9365. ds_list2_clod.setColumn(row, "rcptunitcost" , ds_main_item5_mech.getColumn(i, "rcptunitcost"));
  9366. ds_list2_clod.setColumn(row, "prcpflag" , ds_main_item5_mech.getColumn(i, "prcpflag"));
  9367. ds_list2_clod.setColumn(row, "ediamt" , ds_main_item5_mech.getColumn(i, "ediamt"));
  9368. ds_list2_clod.setColumn(row, "rcptcalcamt" , ds_main_item5_mech.getColumn(i, "rcptcalcamt"));
  9369. ds_list2_clod.setColumn(row, "estmcd" , ds_main_item5_mech.getColumn(i, "estmcd"));
  9370. ds_list2_clod.setColumn(row, "hngnm" , ds_main_item5_mech.getColumn(i, "hngnm"));
  9371. ds_list2_clod.setColumn(row, "edihospaddamt" , ds_main_item5_mech.getColumn(i, "edihospaddamt"));
  9372. ds_list2_clod.setColumn(row, "ediaddamt" , ds_main_item5_mech.getColumn(i, "ediaddamt"));
  9373. ds_list2_clod.setColumn(row, "paytotamt" , ds_main_item5_mech.getColumn(i, "paytotamt"));
  9374. ds_list2_clod.setColumn(row, "ownbamt" , ds_main_item5_mech.getColumn(i, "ownbamt"));
  9375. ds_list2_clod.setColumn(row, "clamamt" , ds_main_item5_mech.getColumn(i, "clamamt"));
  9376. ds_list2_clod.setColumn(row, "choiordamt" , ds_main_item5_mech.getColumn(i, "choiordamt"));
  9377. ds_list2_clod.setColumn(row, "edihospaddtotamt", ds_main_item5_mech.getColumn(i, "edihospaddtotamt"));
  9378. ds_list2_clod.setColumn(row, "ediaddtotamt" , ds_main_item5_mech.getColumn(i, "ediaddtotamt"));
  9379. ds_list2_clod.setColumn(row, "choiordtotamt" , ds_main_item5_mech.getColumn(i, "choiordtotamt"));
  9380. ds_list2_clod.setColumn(row, "totordamt" , ds_main_item5_mech.getColumn(i, "totordamt"));
  9381. ds_list2_clod.setColumn(row, "ownbtotamt" , ds_main_item5_mech.getColumn(i, "ownbtotamt"));
  9382. ds_list2_clod.setColumn(row, "ordnm" , ds_main_item5_mech.getColumn(i, "ordnm"));
  9383. ds_list2_clod.setColumn(row, "estmcdnm" , ds_main_item5_mech.getColumn(i, "estmcdnm"));
  9384. ds_list2_clod.setColumn(row, "adjtresncd" , ds_main_item5_mech.getColumn(i, "adjtresncd"));
  9385. ds_list2_clod.setColumn(row, "druglimitamt" , ds_main_item5_mech.getColumn(i, "druglimitamt"));
  9386. ds_list2_clod.setColumn(row, "limitdiffamt" , ds_main_item5_mech.getColumn(i, "limitdiffamt"));
  9387. ds_list2_clod.setColumn(row, "edidruglimitamt" , ds_main_item5_mech.getColumn(i, "edidruglimitamt"));
  9388. ds_list2_clod.setColumn(row, "edilimitdiffamt" , ds_main_item5_mech.getColumn(i, "edilimitdiffamt"));
  9389. // 행 추가 후 싱글코드 조회 후에 다음 줄을 자동으로 한줄 추가함.
  9390. if ( i < clod - 1)
  9391. {
  9392. ds_list2_clod.addRow();
  9393. }
  9394. }
  9395. ds_list2_clod.enableevent = true;
  9396. }
  9397. /****************************************************************************************
  9398. * Argument : function
  9399. * Description : 처방 data 및 row status를 변경 이전 상태로 복구한다.
  9400. ****************************************************************************************/
  9401. function lf_fCancelClodStatusChng()
  9402. {
  9403. var row = ds_list2_clod.rowposition;
  9404. if (ds_list2_clod.getRowType(row) == 2)
  9405. {
  9406. ds_list2_clod.deleteRow(row);
  9407. }
  9408. else
  9409. {
  9410. ds_list2_clod.setColumn(row, "adjtresncd" , ds_hidden_item5_clod.getColumn(0, "adjtresncd"));
  9411. ds_list2_clod.setColumn(row, "ordfromdd" , ds_hidden_item5_clod.getColumn(0, "ordfromdd"));
  9412. ds_list2_clod.setColumn(row, "ordtodd" , ds_hidden_item5_clod.getColumn(0, "ordtodd"));
  9413. ds_list2_clod.setColumn(row, "orddd" , ds_hidden_item5_clod.getColumn(0, "orddd"));
  9414. ds_list2_clod.setColumn(row, "updtdd" , ds_hidden_item5_clod.getColumn(0, "updtdd"));
  9415. ds_list2_clod.setColumn(row, "grupcalcscorcd", ds_hidden_item5_clod.getColumn(0, "grupcalcscorcd"));
  9416. ds_list2_clod.setColumn(row, "snglcalcscorcd", ds_hidden_item5_clod.getColumn(0, "snglcalcscorcd"));
  9417. ds_list2_clod.setColumn(row, "basecd" , ds_hidden_item5_clod.getColumn(0, "basecd"));
  9418. ds_list2_clod.setColumn(row, "hngnm" , ds_hidden_item5_clod.getColumn(0, "hngnm"));
  9419. ds_list2_clod.setColumn(row, "drugqty" , ds_hidden_item5_clod.getColumn(0, "drugqty"));
  9420. ds_list2_clod.setColumn(row, "tims" , ds_hidden_item5_clod.getColumn(0, "tims"));
  9421. ds_list2_clod.setColumn(row, "dayno" , ds_hidden_item5_clod.getColumn(0, "dayno"));
  9422. ds_list2_clod.setColumn(row, "edidrugqty" , ds_hidden_item5_clod.getColumn(0, "edidrugqty"));
  9423. ds_list2_clod.setColumn(row, "edidayno" , ds_hidden_item5_clod.getColumn(0, "edidayno"));
  9424. ds_list2_clod.setColumn(row, "unitcost" , ds_hidden_item5_clod.getColumn(0, "unitcost"));
  9425. ds_list2_clod.updatecontrol = false;
  9426. ds_list2_clod.setRowType(row, ds_hidden_item5_clod.getColumn(0, "rowstatus"));
  9427. ds_list2_clod.updatecontrol = true;
  9428. }
  9429. }
  9430. /****************************************************************************************
  9431. * Argument : function
  9432. * Description : 기존코드 수정 1회량/횟수/일수 수정시
  9433. ****************************************************************************************/
  9434. function lf_fSetTotDrugQtyAmt()
  9435. {
  9436. var i = ds_list2_clod.rowposition;
  9437. var col = grp_biz.grd_clodhist.currentcol;
  9438. //기존코드 수정시에 퇴장장려비용이 있었다면 그 전 데이터 저장 작업 by 설승민 2020/04/08
  9439. var leprotflag = ds_send_item5_mech.getColumn(0,"leprotflag");
  9440. var leprotamt = ds_send_item5_mech.getColumn(0,"leprotamt");
  9441. var rbpnt = ds_send_item5_mech.getColumn(0,"rbpnt");
  9442. ds_send_item5_mech.clearData();
  9443. ds_send_item5_mech.addRow();
  9444. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "N");
  9445. ds_send_item5_mech.setColumn(0, "ediupdateyn", "N");
  9446. //퇴장방지장려비가 있다면 추가 by 설승민 2020/04/08
  9447. if(leprotflag == "A" || leprotflag == "B"){
  9448. ds_send_item5_mech.setColumn(0, "leprotflag", leprotflag);
  9449. ds_send_item5_mech.setColumn(0, "leprotamt", leprotamt);
  9450. ds_send_item5_mech.setColumn(0, "rbpnt", rbpnt);
  9451. }
  9452. var drugqty = ds_list2_clod.getColumn(i, "drugqty");
  9453. if (utlf_isNull(drugqty) || drugqty == "0")
  9454. {
  9455. ds_list2_clod.setColumn(i, "drugqty", "1");
  9456. }
  9457. var tims = ds_list2_clod.getColumn(i, "tims");
  9458. if (utlf_isNull(tims) || tims == "0")
  9459. {
  9460. ds_list2_clod.setColumn(i, "tims", "1");
  9461. }
  9462. var dayno = ds_list2_clod.getColumn(i, "dayno");
  9463. if (utlf_isNull(dayno) || dayno == "0")
  9464. {
  9465. ds_list2_clod.setColumn(i, "dayno", "1");
  9466. }
  9467. var edidrugqty = ds_list2_clod.getColumn(i, "edidrugqty");
  9468. if (utlf_isNull(edidrugqty) || edidrugqty == "0")
  9469. {
  9470. ds_list2_clod.setColumn(i, "edidrugqty", "1");
  9471. }
  9472. var edidayno = ds_list2_clod.getColumn(i, "edidayno");
  9473. if (utlf_isNull(edidayno)|| edidayno == "0")
  9474. {
  9475. ds_list2_clod.setColumn(i, "edidayno", "1");
  9476. }
  9477. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidrugqty"))
  9478. {
  9479. // edi1회투여량이 변경된 경우
  9480. ds_list2_clod.setColumn(i, "drugqty", ds_list2_clod.getColumn(i, "edidrugqty"));
  9481. }
  9482. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidayno"))
  9483. {
  9484. // edi일수가 변경된 경우
  9485. ds_list2_clod.setColumn(i, "dayno", ds_list2_clod.getColumn(i, "edidayno"));
  9486. }
  9487. var sDrugqty = ds_list2_clod.getColumn(i, "drugqty");
  9488. var sTims = ds_list2_clod.getColumn(i, "tims");
  9489. var sDayno = ds_list2_clod.getColumn(i, "dayno");
  9490. var sUnitcost = ds_list2_clod.getColumn(i, "unitcost");
  9491. var sAmt = ds_list2_clod.getColumn(i, "amt");
  9492. var sEdiAmt = ds_list2_clod.getColumn(i, "ediamt");
  9493. var sDruglimitamt = ds_list2_clod.getColumn(i, "druglimitamt");
  9494. var sEdiDruglimitamt = ds_list2_clod.getColumn(i, "edidruglimitamt");
  9495. var sLimitdiffamt = ds_list2_clod.getColumn(i, "limitdiffamt");
  9496. var sEdiLimitdiffamt = ds_list2_clod.getColumn(i, "edilimitdiffamt");
  9497. var sEdiDrugqty = ds_list2_clod.getColumn(i, "edidrugqty");
  9498. var sEdiDayno = ds_list2_clod.getColumn(i, "edidayno");
  9499. var sEdiUnitcost = ds_list2_clod.getColumn(i, "ediunitcost");
  9500. var drugqty = parseFloat(sDrugqty);
  9501. var tims = parseFloat(sTims);
  9502. var dayno = parseInt(sDayno);
  9503. var unitcost = parseFloat(sUnitcost);
  9504. var amt = parseInt(sAmt);
  9505. var ediamt = parseInt(sEdiAmt);
  9506. var druglimitamt = parseInt(sDruglimitamt);
  9507. var edidruglimitamt = parseInt(sEdiDruglimitamt);
  9508. var limitdiffamt = parseInt(sLimitdiffamt);
  9509. var edilimitdiffamt = parseInt(sEdiLimitdiffamt);
  9510. var edidrugqty = parseFloat(sEdiDrugqty);
  9511. var edidayno = parseInt(sEdiDayno);
  9512. var ediunitcost = parseInt(sEdiUnitcost);
  9513. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "drugqty"))
  9514. {
  9515. // 1회투여량이 변경된 경우
  9516. if (utlf_isNull(sDrugqty) || drugqty <= 0)
  9517. {
  9518. // 처방이전상태 복구
  9519. lf_fCancelClodStatusChng();
  9520. return false;
  9521. }
  9522. else
  9523. {
  9524. ds_send_item5_mech.setColumn(0, "dayno", sDrugqty);
  9525. }
  9526. }
  9527. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "tims"))
  9528. {
  9529. // 횟수가 변경된 경우
  9530. if (utlf_isNull(sTims) || tims <= 0)
  9531. {
  9532. lf_fCancelClodStatusChng();
  9533. return false;
  9534. }
  9535. else
  9536. {
  9537. ds_send_item5_mech.setColumn(0, "edidrugqty", edidrugqty);
  9538. ds_send_item5_mech.setColumn(0, "dayno", sTims);
  9539. }
  9540. }
  9541. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "dayno"))
  9542. {
  9543. // 일수가 변경된 경우
  9544. if (utlf_isNull(sDayno) || dayno <= 0)
  9545. {
  9546. lf_fCancelClodStatusChng();
  9547. return false;
  9548. }
  9549. else
  9550. {
  9551. ds_send_item5_mech.setColumn(0, "dayno", sDayno);
  9552. }
  9553. }
  9554. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "unitcost"))
  9555. {
  9556. // 단가 변경된 경우(추가청구인경우만 해당)
  9557. if (utlf_isNull(sUnitcost) || unitcost <= 0)
  9558. {
  9559. lf_fCancelClodStatusChng();
  9560. return false;
  9561. }
  9562. else
  9563. {
  9564. // 단가변경여부
  9565. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9566. }
  9567. }
  9568. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "ediunitcost"))
  9569. {
  9570. // 단가가 변경된 경우
  9571. if (utlf_isNull(sEdiUnitcost) || ediunitcost <= 0)
  9572. {
  9573. lf_fCancelClodStatusChng();
  9574. return false;
  9575. }
  9576. else
  9577. {
  9578. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9579. }
  9580. }
  9581. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "amt"))
  9582. {
  9583. // 단가가 변경된 경우
  9584. if (utlf_isNull(sAmt) || amt <= 0)
  9585. {
  9586. lf_fCancelClodStatusChng();
  9587. return false;
  9588. }
  9589. else
  9590. {
  9591. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9592. }
  9593. }
  9594. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "ediamt"))
  9595. {
  9596. if (utlf_isNull(sEdiAmt) || ediamt <= 0)
  9597. {
  9598. lf_fCancelClodStatusChng();
  9599. return false;
  9600. }
  9601. else
  9602. {
  9603. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9604. }
  9605. }
  9606. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "druglimitamt"))
  9607. {
  9608. if (utlf_isNull(sDruglimitamt) || druglimitamt <= 0)
  9609. {
  9610. lf_fCancelClodStatusChng();
  9611. return false;
  9612. }
  9613. else
  9614. {
  9615. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9616. }
  9617. }
  9618. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidruglimitamt"))
  9619. {
  9620. if (utlf_isNull(sEdiDruglimitamt) || edidruglimitamt <= 0)
  9621. {
  9622. lf_fCancelClodStatusChng();
  9623. return false;
  9624. }
  9625. else
  9626. {
  9627. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9628. }
  9629. }
  9630. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "limitdiffamt"))
  9631. {
  9632. // edi1회투여량이 변경된 경우
  9633. if (utlf_isNull(sLimitdiffamt) || limitdiffamt <= 0)
  9634. {
  9635. lf_fCancelClodStatusChng();
  9636. return false;
  9637. }
  9638. else
  9639. {
  9640. // edi변경여부
  9641. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9642. }
  9643. }
  9644. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edilimitdiffamt"))
  9645. {
  9646. // edi일수가 변경된 경우
  9647. if (utlf_isNull(sEdiLimitdiffamt) || edilimitdiffamt <= 0)
  9648. {
  9649. lf_fCancelClodStatusChng();
  9650. return false;
  9651. }
  9652. else
  9653. {
  9654. // edi변경여부
  9655. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "Y");
  9656. }
  9657. }
  9658. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidrugqty"))
  9659. {
  9660. // edi일수가 변경된 경우
  9661. if (utlf_isNull(sEdiDrugqty) || edidrugqty <= 0)
  9662. {
  9663. lf_fCancelClodStatusChng();
  9664. return false;
  9665. }
  9666. else
  9667. {
  9668. // edi변경여부
  9669. ds_send_item5_mech.setColumn(0, "ediupdateyn", "Y");
  9670. }
  9671. }
  9672. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidayno"))
  9673. {
  9674. // edi일수가 변경된 경우
  9675. if (utlf_isNull(sEdiDayno) || edidayno <= 0)
  9676. {
  9677. lf_fCancelClodStatusChng();
  9678. return false;
  9679. }
  9680. else
  9681. {
  9682. // edi변경여부
  9683. ds_send_item5_mech.setColumn(0, "ediupdateyn", "Y");
  9684. }
  9685. }
  9686. var ordfromdd = ds_list2_clod.getColumn(i, "ordfromdd");
  9687. var ordtodd = ds_list2_clod.getColumn(i, "ordtodd");
  9688. var dayno = ds_list2_clod.getColumn(i, "dayno");
  9689. var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  9690. if (utlf_isNull(ordfromdd) || utlf_isNull(dayno) || utlf_isNull(snglcalcscorcd))
  9691. {
  9692. return false;
  9693. }
  9694. // 두일자사이의 차를 일단위로 반환
  9695. if (parseInt(dayno) < 0)
  9696. {
  9697. return false;
  9698. }
  9699. else if (parseInt(dayno) > 365)
  9700. {
  9701. return false;
  9702. }
  9703. ds_send_item5_mech.setColumn(0, "ordfromdd" , ordfromdd);
  9704. ds_send_item5_mech.setColumn(0, "ordtodd" , ordtodd);
  9705. ds_send_item5_mech.setColumn(0, "drugqty" , edidrugqty);
  9706. ds_send_item5_mech.setColumn(0, "tims" , sTims);
  9707. ds_send_item5_mech.setColumn(0, "dayno" , sDayno);
  9708. ds_send_item5_mech.setColumn(0, "unitcost" , sUnitcost);
  9709. ds_send_item5_mech.setColumn(0, "amt" , sAmt);
  9710. ds_send_item5_mech.setColumn(0, "ediamt" , sEdiAmt);
  9711. ds_send_item5_mech.setColumn(0, "druglimitamt" , sDruglimitamt);
  9712. ds_send_item5_mech.setColumn(0, "edidruglimitamt", sEdiDruglimitamt);
  9713. ds_send_item5_mech.setColumn(0, "limitdiffamt" , sLimitdiffamt);
  9714. ds_send_item5_mech.setColumn(0, "edilimitdiffamt", sEdiLimitdiffamt);
  9715. ds_send_item5_mech.setColumn(0, "edidrugqty" , edidrugqty);
  9716. ds_send_item5_mech.setColumn(0, "edidayno" , sEdiDayno);
  9717. var grupcalcscorcd = ds_list2_clod.getColumn(i, "grupcalcscorcd");
  9718. if (!utlf_isNull(grupcalcscorcd) && grupcalcscorcd != "-" )
  9719. {
  9720. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", grupcalcscorcd);
  9721. }
  9722. else
  9723. {
  9724. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  9725. }
  9726. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", snglcalcscorcd);
  9727. ds_send_item5_mech.setColumn(0, "basecd" , "");
  9728. ds_send_item5_mech.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  9729. ds_send_item5_mech.setColumn(0, "suppkind" , ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  9730. var orddeptcd = ds_list2_clod.getColumn(i, "orddeptcd");
  9731. if (orddeptcd)
  9732. {
  9733. ds_send_item5_mech.setColumn(0, "orddeptcd", orddeptcd);
  9734. }
  9735. else
  9736. {
  9737. ds_send_item5_mech.setColumn(0, "orddeptcd", ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  9738. }
  9739. var orddrid = ds_list2_clod.getColumn(i, "orddrid");
  9740. if (orddrid)
  9741. {
  9742. ds_send_item5_mech.setColumn(0, "orddrid", orddrid);
  9743. }
  9744. else
  9745. {
  9746. ds_send_item5_mech.setColumn(0, "orddrid", ds_main_item1_clbs.getColumn(0, "orddrid"));
  9747. }
  9748. var estmmncd = ds_list2_clod.getColumn(i, "estmmncd");
  9749. if (!utlf_isNull(estmmncd) && estmmncd != "-")
  9750. {
  9751. ds_send_item5_mech.setColumn(0, "estmmncd", estmmncd);
  9752. }
  9753. ds_send_item5_mech.setColumn(0, "adjtresncd" , ds_list2_clod.getColumn(i, "adjtresncd"));
  9754. ds_send_item5_mech.setColumn(0, "undersixageyn" , ds_main_item1_clbs.getColumn(0, "undersixageyn"));
  9755. ds_send_item5_mech.setColumn(0, "mechage" , ds_main_item1_clbs.getColumn(0, "mechage"));
  9756. ds_send_item5_mech.setColumn(0, "hosinresncd" , ds_list2_clod.getColumn(i, "hosinresncd"));
  9757. ds_send_item5_mech.setColumn(0, "payflag" , ds_list2_clod.getColumn(i, "payflag"));
  9758. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  9759. ds_send_item5_mech.setColumn(0, "clamflagcd" , ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  9760. ds_send_item5_mech.setColumn(0, "prcpflagyn" , ds_list2_clod.getColumn(i, "prcpflagyn"));
  9761. // if (utlf_isNull(ds_list2_clod.getColumn(i, "seqno")))
  9762. // {
  9763. // // EDI환산치, 위탁진료 적용
  9764. // ds_send_item5_mech.setColumn(0, "mode", "n");
  9765. // }
  9766. // else
  9767. // {
  9768. ds_send_item5_mech.setColumn(0, "mode", "u");
  9769. // }
  9770. // 그룹,싱글,EDI코드 입력에 따라 조회 / 또는 SMPIC00200_수가조회 검색 결과
  9771. var oParam = {};
  9772. oParam.id = "2";
  9773. oParam.service = "aftjudgapp.InAftJudg";
  9774. oParam.method = "reqGetCalcScorCd";
  9775. oParam.inds = "req=ds_send_item5_mech";
  9776. oParam.outds = "ds_main_item5_mech=mech";
  9777. oParam.async = false;
  9778. //oParam.callback = "cf_TRPID20303";
  9779. tranf_submit(oParam);
  9780. var clod = ds_main_item5_mech.rowcount;
  9781. if (clod == 1)
  9782. {
  9783. // 조회한 수가코드의 금액정보를 표시한다.
  9784. lf_fSetCalcScorAmt(clod, "update");
  9785. }
  9786. else
  9787. {
  9788. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidrugqty"))
  9789. {
  9790. lf_fCancelClodStatusChng();
  9791. }
  9792. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "tims"))
  9793. {
  9794. lf_fCancelClodStatusChng();
  9795. }
  9796. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "edidayno"))
  9797. {
  9798. lf_fCancelClodStatusChng();
  9799. }
  9800. sysf_messageBox("조회된 처방 계산 내역이", "I004");
  9801. }
  9802. return true;
  9803. }
  9804. /****************************************************************************************
  9805. * Argument : function
  9806. * Description : 조회된 심사대상자의 특이 인적사항, 보조/요율 등을 계산하여 보여준다.
  9807. ****************************************************************************************/
  9808. function lf_fGetPersonalData()
  9809. {
  9810. var srchrslt = "";
  9811. ds_hidden_rarecancermsg.clearData();
  9812. var suppkind = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  9813. var rooa = ds_main_item1_clbs.getColumn(0, "rooamsg");
  9814. var sdoa = ds_main_item1_clbs.getColumn(0, "sdoamsg");
  9815. var rooamsg ;
  9816. var sdoamsg ;
  9817. if(!utlf_isNull(rooa))
  9818. {
  9819. rooamsg = rooa.length;
  9820. }
  9821. if(!utlf_isNull(sdoa))
  9822. {
  9823. sdoamsg = sdoa.length;
  9824. }
  9825. if ((rooamsg > 1) && (sdoamsg > 1))
  9826. {
  9827. cmb_rarecancermsg.visible = true;
  9828. if ( suppkind == "06" || suppkind == "11" || suppkind == "32" || suppkind == "40")
  9829. {
  9830. ds_hidden_rarecancermsg.addRow();
  9831. ds_hidden_rarecancermsg.addRow();
  9832. ds_hidden_rarecancermsg.setColumn(0, "msg", sdoa);
  9833. ds_hidden_rarecancermsg.setColumn(1, "msg", rooa);
  9834. }
  9835. else
  9836. {
  9837. ds_hidden_rarecancermsg.addRow();
  9838. ds_hidden_rarecancermsg.addRow();
  9839. ds_hidden_rarecancermsg.setColumn(0, "msg", rooa);
  9840. ds_hidden_rarecancermsg.setColumn(1, "msg", sdoa);
  9841. }
  9842. }
  9843. else if (rooamsg > 1)
  9844. {
  9845. srchrslt += ds_main_item1_clbs.getColumn(0, "rooamsg"); // 희귀등록번호
  9846. cmb_rarecancermsg.visible = true;
  9847. ds_hidden_rarecancermsg.addRow();
  9848. ds_hidden_rarecancermsg.setColumn(0, "msg", srchrslt);
  9849. }
  9850. else if (sdoamsg > 1)
  9851. {
  9852. srchrslt += ds_main_item1_clbs.getColumn(0, "sdoamsg"); // 중증등록정보
  9853. cmb_rarecancermsg.visible = true;
  9854. ds_hidden_rarecancermsg.addRow();
  9855. ds_hidden_rarecancermsg.setColumn(0, "msg", srchrslt);
  9856. }
  9857. else
  9858. {
  9859. cmb_rarecancermsg.visible = false;
  9860. }
  9861. var suppkindcd = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  9862. var payownbrate = ds_main_item1_clbs.getColumn(0, "payownbrate");
  9863. var supprate = suppkindcd + "/" + payownbrate;
  9864. ds_hidden_item1_clbs.setColumn(0, "patsupprate", supprate);
  9865. }
  9866. /****************************************************************************************
  9867. * Argument : function
  9868. * Description :
  9869. ****************************************************************************************/
  9870. function lf_fSaveClspList()
  9871. {
  9872. if (grp_biz.btn_save.enable == true && "M" == "S")
  9873. {
  9874. ds_send_item1_clbs.copyData(ds_main_item1_clbs); //model.copyNode("/root/send/item1/clbs", "/root/main/item1/clbs");
  9875. dsf_makeValue(ds_send_item1_clbs, "clbsupdateyn", "string", "N", 0);
  9876. dsf_makeValue(ds_send_item1_clbs, "judgendyn", "string", "B", 0);
  9877. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  9878. {
  9879. var spclLnNo = ds_list3_clsp.getColumn(j, "seqno");
  9880. if (spclLnNo.substr(0, 1) == "D")
  9881. {
  9882. ds_list3_clsp.setColumn(j, "seqno", spclLnNo.substr(1, spclLnNo.length));
  9883. }
  9884. }
  9885. lf_fSetSpclSpecJX999();
  9886. dsf_setDefaultVal(ds_send_item1_clbs, "insuno:-,certno:-,rsvordgubn:N,ownbflag:-,oprcpdayno:0,direcprcptims:0,ordtims:0,prockindflag:-,offcharm:0,reclopedilnnoyn:N,fixrateyn:-,suppkindchgresn:-");
  9887. dsf_setDefaultVal(ds_list3_clsp, "usermemoyn:N,clsoyn:N,mpsno:-");
  9888. dsf_setDefaultVal(ds_send_item3_lnunitmemo, "usermemoyn:N,unitflag:J,spclcd:JX999,clsoyn:N,workflag:12");
  9889. var oParam = {};
  9890. oParam.id = "TXPID20315";
  9891. oParam.service = "aftjudgapp.InAftJudg";
  9892. oParam.method = "reqExePidhclsp";
  9893. oParam.inds = "clbs=ds_send_item1_clbs clsp=ds_list3_clsp lnunitmemo=ds_send_item3_lnunitmemo";
  9894. oParam.outds = "ds_list3_clsp=clsp";
  9895. oParam.async = false;
  9896. //oParam.callback = "cf_TXPID20315";
  9897. tranf_submit(oParam);
  9898. lf_fSelectSpclRadio();
  9899. }
  9900. }
  9901. /****************************************************************************************
  9902. * Argument : button
  9903. * Description : 알림 메세지 닫기 이벤트
  9904. ****************************************************************************************/
  9905. function grp_msg_button25_onclick(obj:Button, e:ClickEventInfo)
  9906. {
  9907. grp_msg.visible = false;
  9908. ds_grd_msg.clearData();
  9909. }
  9910. /****************************************************************************************
  9911. * Argument : function
  9912. * Description : CLOP 저장전 점검
  9913. ****************************************************************************************/
  9914. function lf_fCheckSaveOutAftJudgInfoCLOP()
  9915. {
  9916. // 저장할 정보를 체크한다.
  9917. // 원외처방 Grid
  9918. var clopList = ds_list7_clop.rowcount;
  9919. if (clopList < 0)
  9920. {
  9921. return true;
  9922. }
  9923. var clopNode = ds_list7_clop.rowcount;
  9924. for (var i = 0; i < clopNode; i++)
  9925. {
  9926. if ( utlf_isNull(ds_list7_clop.getColumn(i, "snglcalcscorcd")))
  9927. {
  9928. //원외처방 수가코드를 입력하십시오.
  9929. sysf_messageBox("원외처방 수가코드를", "C001");
  9930. return false;
  9931. }
  9932. }
  9933. return true;
  9934. }
  9935. /****************************************************************************************
  9936. * Argument : enterkeydown
  9937. * Description : 원외처방 수정
  9938. ****************************************************************************************/
  9939. function grp_biz_grd_oprcphist_onenterdown(obj:Grid, e:GridEditEventInfo)
  9940. {
  9941. // 수가코드, EDI코드
  9942. var row = e.row;
  9943. var adjtresncd = ds_list7_clop.getColumn(row, "adjtresncd");
  9944. if ( e.col == obj.getBindCellIndex("body", "snglcalcscorcd") || e.col == obj.getBindCellIndex("body", "edicd"))
  9945. {
  9946. lf_fSetSrchOutCalcScorCd(adjtresncd);
  9947. }
  9948. }
  9949. function grp_biz_grd_oprcphist_ontextchanged(obj:Grid, e:GridEditTextChangedEventInfo)
  9950. {
  9951. var row = e.row;
  9952. var col = e.col;
  9953. var adjtresncd = ds_list7_clop.getColumn(row, "adjtresncd");
  9954. if( e.col != obj.getBindCellIndex("body", "edidrugdaynomax"))
  9955. {
  9956. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  9957. {
  9958. var cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  9959. if (utlf_isNull(cmbAdjtresncd) || cmbAdjtresncd == "-")
  9960. {
  9961. var sppiz01000 = new Object();
  9962. sppiz01000.sCdCls = "aftout";
  9963. sppiz01000.sCdid = adjtresncd;
  9964. sppiz01000.sAdjtresndesc = "";
  9965. var rtn = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  9966. if (!utlf_isNull(rtn))
  9967. {
  9968. adjtresncd = rtn.sCdid;
  9969. }
  9970. }
  9971. else
  9972. {
  9973. adjtresncd = cmbAdjtresncd;
  9974. }
  9975. }
  9976. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  9977. {
  9978. // 사유 없으면 원상복귀
  9979. ds_list7_clop.setColumn(row, "clopdd", ds_hidden_list7_clop.getColumn(0, "oldclopdd")); // 교부일자
  9980. ds_list7_clop.setColumn(row, "clopno", ds_hidden_list7_clop.getColumn(0, "oldclopno")); // 교부번호
  9981. ds_list7_clop.setColumn(row, "snglcalcscorcd", ds_hidden_list7_clop.getColumn(0, "oldsnglcalcscorcd")); // 수가코드
  9982. ds_list7_clop.setColumn(row, "edicd", ds_hidden_list7_clop.getColumn(0, "oldedicd")); // edi코드
  9983. ds_list7_clop.setColumn(row, "edidrugqty", ds_hidden_list7_clop.getColumn(0, "oldedidrugqty")); // edi수량
  9984. ds_list7_clop.setColumn(row, "drugtims", ds_hidden_list7_clop.getColumn(0, "olddrugtims")); // 횟수
  9985. ds_list7_clop.setColumn(row, "edidrugdayno", ds_hidden_list7_clop.getColumn(0, "oldedidrugdayno")); // edi일수
  9986. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  9987. return;
  9988. }
  9989. }
  9990. var newclopdd = utlf_transNullToEmpty(ds_list7_clop.getColumn(row, "clopdd"));
  9991. var newclopno = utlf_transNullToEmpty(ds_list7_clop.getColumn(row, "clopno"));
  9992. var curmpsno = utlf_transNullToEmpty(ds_list7_clop.getColumn(row, "mpsno"));
  9993. var newmpsno = newclopdd+newclopno;
  9994. // 교부일자
  9995. if ( e.col == obj.getBindCellIndex("body", "clopdd"))
  9996. {
  9997. newclopdd = e.posttext;
  9998. if ( !utlf_isValidDateTime(newclopdd) || curmpsno == newmpsno )
  9999. {
  10000. ds_list7_clop.setColumn(row, "clopdd", ds_hidden_list7_clop.getColumn(0, "oldclopdd"));
  10001. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10002. }
  10003. else
  10004. {
  10005. for (var i = 0; i < ds_list7_clop.rows; i++)
  10006. {
  10007. var mpsno = ds_list7_clop.getColumn(i, "mpsno");
  10008. if (curmpsno == mpsno)
  10009. {
  10010. ds_list7_clop.setColumn(i, "clopdd", newclopdd);
  10011. ds_list7_clop.setColumn(i, "newmpsno", newmpsno);
  10012. ds_list7_clop.setColumn(i, "adjtresncd", adjtresncd); // 조정사유
  10013. if ( ds_list7_clop.getRowType(i) == 1 )
  10014. {
  10015. ds_list7_clop.updatecontrol = false;
  10016. ds_list7_clop.setRowType(i, "u");
  10017. ds_list7_clop.updatecontrol = true;
  10018. }
  10019. }
  10020. }
  10021. // 원외처방 특정내역이 있는 경우
  10022. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  10023. {
  10024. var spclmpsno = utlf_transNullToEmpty(ds_list3_clsp.getColumn(j, "mpsno")); // mpsno
  10025. var clsoyn = utlf_transNullToEmpty(ds_list3_clsp.getColumn(j, "clsoyn")); // 원외처방 특정내역 여부
  10026. if (curmpsno == mpsno && clsoyn == "Y")
  10027. {
  10028. ds_list3_clsp.setColumn(j, "mpsno", newmpsno);
  10029. if ( ds_list3_clsp.getRowType(j) == 1 )
  10030. {
  10031. ds_list3_clsp.updatecontrol = false;
  10032. ds_list3_clsp.setRowType(i, "u");
  10033. ds_list3_clsp.updatecontrol = true;
  10034. }
  10035. }
  10036. }
  10037. }
  10038. }
  10039. // 교부번호
  10040. else if ( e.col == obj.getBindCellIndex("body", "clopno"))
  10041. {
  10042. newclopdd = utlf_transNullToEmpty(ds_list7_clop.getColumn(row, "clopdd"));
  10043. newclopno = e.posttext;
  10044. curmpsno = utlf_transNullToEmpty(ds_list7_clop.getColumn(row, "mpsno"));
  10045. newmpsno = newclopdd+newclopno;
  10046. //trace(">>>>"+curmpsno + " === " + newmpsno)
  10047. if (utlf_isNull(newclopno) || curmpsno == newmpsno )
  10048. {
  10049. ds_list7_clop.setColumn(row, "clopno", ds_hidden_list7_clop.getColumn(0 , "oldclopno"));
  10050. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10051. //trace("11"+newmpsno)
  10052. }
  10053. else
  10054. {
  10055. //trace("@@@"+curmpsno + " === " + newmpsno)
  10056. // for (var i = 0; i < ds_list7_clop.rows; i++)
  10057. // {
  10058. // var mpsno = utlf_transNullToEmpty(ds_list7_clop.getColumn(i, "mpsno"));
  10059. //
  10060. // if (curmpsno == mpsno)
  10061. // { // 수정된 row와 처방전 교부번호가 같은 경우
  10062. //
  10063. // ds_list7_clop.setColumn(i, "clopno", newclopno);
  10064. // ds_list7_clop.setColumn(i, "newmpsno", newmpsno);
  10065. // ds_list7_clop.setColumn(i, "adjtresncd", adjtresncd); // 조정사유
  10066. //
  10067. // if ( ds_list7_clop.getRowType(i) == 1 )
  10068. // {
  10069. // ds_list7_clop.updatecontrol = false;
  10070. // ds_list7_clop.setRowType(i, "u");
  10071. // ds_list7_clop.updatecontrol = true;
  10072. // }
  10073. // }
  10074. // }
  10075. ds_list7_clop.setColumn(row, "clopno", newclopno);
  10076. ds_list7_clop.setColumn(row, "newmpsno", newmpsno);
  10077. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd); // 조정사유
  10078. if ( ds_list7_clop.getRowType(i) == 1 )
  10079. {
  10080. ds_list7_clop.updatecontrol = false;
  10081. ds_list7_clop.setRowType(row, "u");
  10082. ds_list7_clop.updatecontrol = true;
  10083. }
  10084. //alert();
  10085. // 원외처방 특정내역이 있는 경우
  10086. for (var j = 0; j < ds_list3_clsp.rowcount; j++)
  10087. {
  10088. var spclmpsno = utlf_transNullToEmpty(ds_list3_clsp.getColumn(j, "mpsno")); // mpsno
  10089. var clsoyn = utlf_transNullToEmpty(ds_list3_clsp.getColumn(j, "clsoyn")); // 원외처방 특정내역 여부
  10090. if (curmpsno == mpsno && clsoyn == "Y")
  10091. {
  10092. ds_list3_clsp.setColumn(j, "mpsno", newmpsno);
  10093. if ( ds_list3_clsp.getRowType(j) == 1 )
  10094. {
  10095. ds_list3_clsp.updatecontrol = false;
  10096. ds_list3_clsp.setRowType(i, "u");
  10097. ds_list3_clsp.updatecontrol = true;
  10098. }
  10099. }
  10100. }
  10101. }
  10102. }
  10103. // edi수량
  10104. else if (e.col == obj.getBindCellIndex("body", "edidrugqty"))
  10105. {
  10106. var oldedidrugqty = ds_hidden_list7_clop.getColumn(0, "oldedidrugqty");
  10107. var edidrugqty = e.posttext;
  10108. if ( utlf_isNull(edidrugqty) || edidrugqty == "0" )
  10109. {
  10110. ds_list7_clop.setColumn(row, "edidrugqty", oldedidrugqty);
  10111. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10112. }
  10113. else
  10114. {
  10115. ds_list7_clop.setColumn(row, "drugqty", edidrugqty); // 수량 같이 변경
  10116. ds_list7_clop.setColumn(row, "edidrugqty", edidrugqty); // 수량 같이 변경
  10117. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd); // 조정사유
  10118. ds_list7_clop.setColumn(row, "daydrugqty", edidrugqty); // 조정사유
  10119. if ( ds_list7_clop.getRowType(i) == 1 )
  10120. {
  10121. ds_list7_clop.updatecontrol = false;
  10122. ds_list7_clop.setRowType(i, "u");
  10123. ds_list7_clop.updatecontrol = true;
  10124. }
  10125. }
  10126. }
  10127. // 횟수
  10128. else if (e.col == obj.getBindCellIndex("body", "drugtims"))
  10129. {
  10130. var olddrugtims = ds_hidden_list7_clop.getColumn(0, "olddrugtims");
  10131. var drugtims = e.posttext;
  10132. if ( utlf_isNull(drugtims) || drugtims == "0" )
  10133. {
  10134. ds_list7_clop.setColumn(row, "drugtims", olddrugtims);
  10135. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10136. }
  10137. else
  10138. {
  10139. ds_list7_clop.setColumn(row, "drugtims", drugtims); // 수량 같이 변경
  10140. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd); // 조정사유
  10141. if ( ds_list7_clop.getRowType(i) == 1 )
  10142. {
  10143. ds_list7_clop.updatecontrol = false;
  10144. ds_list7_clop.setRowType(i, "u");
  10145. ds_list7_clop.updatecontrol = true;
  10146. }
  10147. }
  10148. }
  10149. // edi일수
  10150. else if (e.col == obj.getBindCellIndex("body", "edidrugdayno"))
  10151. {
  10152. var oldedidrugdayno = ds_hidden_list7_clop.getColumn(0, "oldedidrugdayno");
  10153. var edidrugdayno = e.posttext;
  10154. if ( utlf_isNull(edidrugdayno) || edidrugdayno == "0" )
  10155. {
  10156. ds_list7_clop.setColumn(row, "edidrugdayno", oldedidrugdayno);
  10157. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10158. }
  10159. else
  10160. {
  10161. ds_list7_clop.setColumn(row, "drugdayno", edidrugdayno); // 수량 같이 변경
  10162. ds_list7_clop.setColumn(row, "edidrugdayno", edidrugdayno); // 수량 같이 변경
  10163. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd); // 조정사유
  10164. if ( ds_list7_clop.getRowType(i) == 1 )
  10165. {
  10166. ds_list7_clop.updatecontrol = false;
  10167. ds_list7_clop.setRowType(i, "u");
  10168. ds_list7_clop.updatecontrol = true;
  10169. }
  10170. }
  10171. }
  10172. // 최대일수
  10173. else if ( e.col == obj.getBindCellIndex("body", "edidrugdaynomax"))
  10174. {
  10175. for(var i = 0; i < ds_list7_clop.rowcount; i++)
  10176. {
  10177. ds_list7_clop.setColumn(i, "edidrugdaynomax", e.posttext);
  10178. }
  10179. } else {
  10180. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd);
  10181. }
  10182. }
  10183. /****************************************************************************************
  10184. * Argument : function
  10185. * Description : 수가코드, EDI코드를 조회한 후 원외처방으로 행 추가를 한다.
  10186. ****************************************************************************************/
  10187. function lf_fSetSrchOutCalcScorCd(adjtresncd)
  10188. {
  10189. var col = grp_biz.grd_oprcphist.currentcol;
  10190. var row = grp_biz.grd_oprcphist.currentrow;
  10191. ds_cond_smpic00200.clearData();
  10192. ds_cond_smpic00200.addRow();
  10193. ds_send_item5_mech.clearData();
  10194. ds_send_item5_mech.addRow();
  10195. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "N"); // 단가변경여부
  10196. ds_send_item5_mech.setColumn(0, "ediupdateyn", "N"); // edi변경여부
  10197. if (col == grp_biz.grd_oprcphist.getBindCellIndex("body", "snglcalcscorcd"))
  10198. {
  10199. var oldsnglcalcscorcd = ds_hidden_list7_clop.getColumn(0, "oldsnglcalcscorcd");
  10200. var snglcalcscorcd = ds_list7_clop.getColumn(row, "snglcalcscorcd");
  10201. if (utlf_isNull(snglcalcscorcd))
  10202. {
  10203. ds_list7_clop.setColumn(row, "snglcalcscorcd", oldsnglcalcscorcd);
  10204. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10205. return;
  10206. }
  10207. ds_cond_smpic00200.setColumn(0, "con4_search2" , snglcalcscorcd);
  10208. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", snglcalcscorcd);
  10209. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  10210. ds_send_item5_mech.setColumn(0, "basecd", "");
  10211. }
  10212. else if (col == grp_biz.grd_oprcphist.getBindCellIndex("body", "edicd"))
  10213. { // EDI코드
  10214. var oldedicd = ds_hidden_list7_clop.getColumn(0, "oldedicd");
  10215. var edicd = ds_list7_clop.getColumn(row, "edicd");
  10216. if (utlf_isNull(edicd))
  10217. {
  10218. ds_list7_clop.setColumn(row, "edicd", oldedicd);
  10219. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10220. return;
  10221. }
  10222. ds_cond_smpic00200.setColumn(0, "con4_search2" , edicd);
  10223. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", edicd);
  10224. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  10225. ds_send_item5_mech.setColumn(0, "basecd", "");
  10226. }
  10227. var ordfromdd = ds_list7_clop.getColumn(row, "clopdd");
  10228. ds_send_item5_mech.setColumn(0, "indd", ds_main_item1_clbs.getColumn(0, "indd"));
  10229. ds_send_item5_mech.setColumn(0, "ordfromdd", ordfromdd);
  10230. ds_send_item5_mech.setColumn(0, "ordtodd", ordfromdd);
  10231. ds_send_item5_mech.setColumn(0, "insukind", ds_main_item1_clbs.getColumn(0, "insukind"));
  10232. ds_send_item5_mech.setColumn(0, "suppkind", ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  10233. ds_send_item5_mech.setColumn(0, "orddeptcd", ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  10234. ds_send_item5_mech.setColumn(0, "orddrid", ds_main_item1_clbs.getColumn(0, "orddrid"));
  10235. var edidrugqty = ds_list7_clop.getColumn(row, "edidrugqty");
  10236. var drugtims = ds_list7_clop.getColumn(row, "drugtims");
  10237. var edidrugdayno = ds_list7_clop.getColumn(row, "edidrugdayno");
  10238. ds_send_item5_mech.setColumn(0, "drugqty", edidrugqty);
  10239. ds_send_item5_mech.setColumn(0, "tims", drugtims);
  10240. ds_send_item5_mech.setColumn(0, "dayno", edidrugdayno);
  10241. ds_send_item5_mech.setColumn(0, "adjtresncd", adjtresncd);
  10242. ds_send_item5_mech.setColumn(0, "undersixageyn", ds_main_item1_clbs.getColumn(0, "insukind"));
  10243. ds_send_item5_mech.setColumn(0, "mechage", ds_main_item1_clbs.getColumn(0, "insukind"));
  10244. ds_send_item5_mech.setColumn(0, "hosinresncd", "-");
  10245. ds_send_item5_mech.setColumn(0, "payflag", ds_list7_clop.getColumn(row, "payflag"));
  10246. ds_send_item5_mech.setColumn(0, "clbsordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  10247. ds_send_item5_mech.setColumn(0, "ioflag", ds_main_item1_clbs.getColumn(0, "ioflag"));
  10248. ds_send_item5_mech.setColumn(0, "clamflagcd", ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  10249. ds_send_item5_mech.setColumn(0, "mode", "n");
  10250. ds_send_item5_mech.setColumn(0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  10251. var cloplength = 0;
  10252. var clopSelect = "";
  10253. var clop = "";
  10254. var oParam = {};
  10255. oParam.id = "TRPID20303";
  10256. oParam.service = "aftjudgapp.InAftJudg";
  10257. oParam.method = "reqGetCalcScorCd";
  10258. oParam.inds = "req=ds_send_item5_mech";
  10259. oParam.outds = "ds_main_item5_mech=mech";
  10260. oParam.async = false;
  10261. //oParam.callback = "cf_TRPID20303";
  10262. tranf_submit(oParam);
  10263. cloplength = ds_main_item5_mech.rowcount;
  10264. // 입력한 코드에 대해 조회된 결과가 없거나, 하나의 EDI코드에 여러 수가코드가 존재할 때
  10265. if (cloplength == 0)
  10266. {
  10267. // 검색된 결과가 여러 수가코드인 경우 이를 초기화하고 수가조회 Popup 창에서 새로 결과를 얻는다.
  10268. ds_main_item5_mech.clearData();
  10269. ds_main_item5_mech.addRow();
  10270. var insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  10271. if (insukindcd == "11")
  10272. {
  10273. ds_cond_smpic00200.setColumn(0, "con5_insu", "insu");
  10274. }
  10275. else if (insukindcd == "21" || insukindcd == "22")
  10276. {
  10277. ds_cond_smpic00200.setColumn(0, "con5_insu", "proc");
  10278. }
  10279. else if (insukindcd == "31")
  10280. {
  10281. ds_cond_smpic00200.setColumn(0, "con5_insu", "autm");
  10282. }
  10283. else if (insukindcd == "41")
  10284. {
  10285. ds_cond_smpic00200.setColumn(0, "con5_insu", "indus");
  10286. }
  10287. else
  10288. {
  10289. ds_cond_smpic00200.setColumn(0, "con5_insu", "insu");
  10290. }
  10291. // SMPIC00200_수가조회 화면의 그룹,싱글 combo 조건값 설정
  10292. if (col == grp_biz.grd_oprcphist.getBindCellIndex("body", "snglcalcscorcd"))
  10293. {
  10294. ds_cond_smpic00200.setColumn(0, "con2_gsflag", "S");
  10295. }
  10296. // SMPIC00200_수가조회 화면의 검색조건 combo 조건값 설정
  10297. if (col == grp_biz.grd_oprcphist.getBindCellIndex("body", "edicd"))
  10298. {
  10299. ds_cond_smpic00200.setColumn(0, "con3_search1", "edicd");
  10300. }
  10301. else
  10302. {
  10303. ds_cond_smpic00200.setColumn(0, "con3_search1", "calcscorcd");
  10304. }
  10305. // 처방시작일을 수가조회 기준일자로 설정
  10306. if (ordfromdd)
  10307. {
  10308. ds_cond_smpic00200.setColumn(0, "con1_dd", ordfromdd);
  10309. }
  10310. ds_cond_smpic00200.setColumn(0, "con_ordinptflag", "PAM");
  10311. var objArg = new Object();
  10312. objArg.arg_ds_temp = ds_cond_smpic00200;
  10313. ds_rslt_smpic00200.clearData();
  10314. var mechSelect = frmf_modal("SMPIC00200", "SMPIC00200", objArg, "", "", "", "", "", "", "", "", "", "M");
  10315. // SMPIC00200_수가조회 화면에서 보낸 결과 값에 대한 처리
  10316. if (ds_temp_picmmech.getColumn(0, "picmmech_temp_grupsnglflag") != "S")
  10317. { // 그룹코드인 경우의 그룹코드에 속하는 싱글코드를 조회함.
  10318. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", ds_temp_picmmech.getColumn(0, "picmmech_calcscorcd"));
  10319. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", "");
  10320. ds_send_item5_mech.setColumn(0, "basecd" , "");
  10321. ds_send_item5_mech.setColumn(0, "estmmncd" , "");
  10322. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  10323. var oParam = {};
  10324. oParam.id = "TRPID20303";
  10325. oParam.service = "aftjudgapp.InAftJudg";
  10326. oParam.method = "reqGetCalcScorCd";
  10327. oParam.inds = "req=ds_send_item5_mech";
  10328. oParam.outds = "ds_main_item5_mech=mech";
  10329. oParam.async = false;
  10330. //oParam.callback = "cf_TRPID20303";
  10331. tranf_submit(oParam);
  10332. }
  10333. else
  10334. { // 싱글코드를 선택했을 때
  10335. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  10336. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", ds_temp_picmmech.getColumn(0, "picmmech_calcscorcd"));
  10337. ds_send_item5_mech.setColumn(0, "basecd" , "");
  10338. ds_send_item5_mech.setColumn(0, "estmmncd" , "");
  10339. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  10340. var oParam = {};
  10341. oParam.id = "TRPID20303";
  10342. oParam.service = "aftjudgapp.InAftJudg";
  10343. oParam.method = "reqGetCalcScorCd";
  10344. oParam.inds = "req=ds_send_item5_mech";
  10345. oParam.outds = "ds_main_item5_mech=mech";
  10346. oParam.async = false;
  10347. //oParam.callback = "cf_TRPID20303";
  10348. tranf_submit(oParam);
  10349. }
  10350. }
  10351. var clop = ds_main_item5_mech.rowcount;
  10352. if (clop < 0)
  10353. {
  10354. ds_list7_clop.setColumn(row, "edicd", "");
  10355. ds_list7_clop.setColumn(row, "snglcalcscorcd", "");
  10356. ds_list7_clop.setRowType(row, ds_hidden_list7_clop.getColumn(0, "oldrowstatus"));
  10357. sysf_messageBox("처방이 불가한 코드입니다. 수가조회 화면에서 선택한 그룹코드에 대해 조회한 결과가", "I004");
  10358. return;
  10359. }
  10360. else
  10361. {
  10362. for (var i = 0; i < clop; i++)
  10363. {
  10364. ds_list7_clop.setColumn(row, "snglcalcscorcd", ds_main_item5_mech.getColumn(i, "snglcalcscorcd"));
  10365. ds_list7_clop.setColumn(row, "edicd", ds_main_item5_mech.getColumn(i, "edicd"));
  10366. ds_list7_clop.setColumn(row, "hngnm", ds_main_item5_mech.getColumn(i, "hngnm"));
  10367. ds_list7_clop.setColumn(row, "ordnm", ds_main_item5_mech.getColumn(i, "ordnm"));
  10368. ds_list7_clop.setColumn(row, "payflag", ds_main_item5_mech.getColumn(i, "payflag"));
  10369. ds_list7_clop.setColumn(row, "edicdflag", ds_main_item5_mech.getColumn(i, "edicdflag"));
  10370. ds_list7_clop.setColumn(row, "efcyclscd", ds_main_item5_mech.getColumn(i, "efcyclscd"));
  10371. ds_list7_clop.setColumn(row, "efcyclsnm", ds_main_item5_mech.getColumn(i, "efcyclsnm"));
  10372. ds_list7_clop.setColumn(row, "efcynm2", ds_main_item5_mech.getColumn(i, "efcynm2"));
  10373. ds_list7_clop.setColumn(row, "efcynm3", ds_main_item5_mech.getColumn(i, "efcynm3"));
  10374. ds_list7_clop.setColumn(row, "adjtresncd", adjtresncd );
  10375. // 신규입력된 처방은 seqno는 최종번호를 셋팅하고 maxseqno에 최종값을 +1한다.
  10376. if ( ds_list7_clop.getColumn(row, "seqno") == "0" || utlf_isNull(ds_list7_clop.getColumn(row, "seqno")))
  10377. {
  10378. var cur_seqno = ds_rslt_clopmaxseqno.getColumn(0, "seqno");
  10379. ds_list7_clop.setColumn(row, "seqno", cur_seqno);
  10380. ds_rslt_clopmaxseqno.setColumn(0, "seqno", parseInt(cur_seqno)+1);
  10381. }
  10382. }
  10383. }
  10384. }
  10385. /****************************************************************************************
  10386. * Argument : function
  10387. * Description : 수가조회 이후 신규처방 추가처리
  10388. ****************************************************************************************/
  10389. function lf_fSetNewCalcScorCd()
  10390. {
  10391. var row = ds_list2_clod.rowposition;
  10392. var clod = ds_main_item5_mech.rowcount;
  10393. if( clod > 0 )
  10394. {
  10395. lf_fSetCalcScorAmt(clod, "new");
  10396. ds_list2_clod.setColumn(row, "toot", "");
  10397. //lf_fSetOrderLnNo();
  10398. lf_fSetNewCnfmCd();
  10399. }
  10400. else
  10401. {
  10402. sysf_messageBox("처방이 불가한 코드입니다. 수가조회 화면에서 선택한 그룹코드에 대해 조회한 결과가", "I004");
  10403. lf_fCancelClodStatusChng();
  10404. }
  10405. }
  10406. /****************************************************************************************
  10407. * Argument : function
  10408. * Description : 정렬
  10409. ****************************************************************************************/
  10410. function lf_fSetOrderLnNo()
  10411. {
  10412. var row = ds_list2_clod.rowposition;
  10413. var seqno = ds_list2_clod.getColumn(row, "seqno");
  10414. var ediitem1 = ds_list2_clod.getColumn(row, "ediitem1");
  10415. var ediitem2 = ds_list2_clod.getColumn(row, "ediitem2");
  10416. var grupcalcscorcd = ds_list2_clod.getColumn(row, "grupcalcscorcd");
  10417. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  10418. var estmmncd = ds_list2_clod.getColumn(row, "estmmncd");
  10419. ds_list2_clod.keystring = "S:+ediitem1+ediitem2+grupcalcscorcd+grupseqno+snglcalcscorcd+edicd";
  10420. ds_list2_clod.rowposition = -1;
  10421. }
  10422. /****************************************************************************************
  10423. * Argument : function
  10424. * Description : 확인코드, 분업예외코드 검체검사위탁, 준용코드를 특정내역에 자동으로 추가한다.
  10425. ****************************************************************************************/
  10426. function lf_fSetNewCnfmCd()
  10427. {
  10428. var isClspChange = false;
  10429. //처방전체로 for문을 돌리면 특정내역에 중복으로 들어가는 문제 발생으로 인해 for 삭제
  10430. //대신 i를 rowposition으로 변경 by 설승민 2020/04/09
  10431. var i = ds_list2_clod.rowposition;
  10432. //for ( var i = 0; i < ds_list2_clod.rowcount; i++ )
  10433. //{
  10434. var rowstatus = ds_list2_clod.getRowType(i);
  10435. if ( rowstatus == 2 )
  10436. {
  10437. var seqno = ds_list2_clod.getColumn(i, "seqno");
  10438. var cnfmcd = ds_list2_clod.getColumn(i, "cnfmcd");
  10439. var basecd = ds_list2_clod.getColumn(i, "basecd");
  10440. var hosinresncd = ds_list2_clod.getColumn(i, "hosinresncd");
  10441. var trustinstno = ds_main_item5_mech.getColumn(0, "trustinstno");
  10442. var clamspclcd = ds_main_item5_mech.getColumn(0, "clamspclcd");
  10443. var edicd = ds_main_item5_mech.getColumn(0, "edicd");
  10444. var edicdflag = ds_main_item5_mech.getColumn(0, "edicdflag");
  10445. var okmsg = "";
  10446. var spclcd = "";
  10447. var cdnm = "";
  10448. var spclspec = "";
  10449. var spclformat = "";
  10450. var detldesc = "";
  10451. //퇴장방지장려비를 선택했을시에 예외코드 99로 세팅하도록 함 by 설승민 2020/04/09
  10452. if(ds_main_item5_mech.getColumn(0,"rdoleprot") == "A")
  10453. {
  10454. hosinresncd = "99";
  10455. ds_list2_clod.setColumn(i,"hosinresncd","99");
  10456. }
  10457. if (cnfmcd)
  10458. {
  10459. okmsg = "확인코드";
  10460. spclcd = "JT001";
  10461. cdnm = "확인코드";
  10462. spclspec = cnfmcd;
  10463. spclformat = "X(5)";
  10464. detldesc = "진료행위에 대한 추가기술 사항을 구분하는 코드로서 확인코드가 여러개 발생할 경우 '/'로 구분하여 기재";
  10465. }
  10466. else if (!utlf_isNull(hosinresncd) && hosinresncd != "00" && hosinresncd != "-")
  10467. {
  10468. okmsg = "분업예외코드";
  10469. spclcd = "JS002";
  10470. cdnm = "분업예외코드";
  10471. spclspec = hosinresncd;
  10472. spclformat = "9(2)";
  10473. detldesc = "의약분업 예외사항 발생으로 의료기관에서 원내 조제/투약이 이루어진 경우 해당 예외구분코드를 기재하고, 원외처방발행기에서 퇴장방지의약품 원외처방시 해당의약품의 사용장려비를 청구할 경우 구분코드 99를 기재";
  10474. }
  10475. else if (!utlf_isNull(trustinstno) && clamspclcd == "1")
  10476. {
  10477. okmsg = "검체검사위탁";
  10478. spclcd = "JS005";
  10479. cdnm = "검체검사위탁";
  10480. spclspec = trustinstno + "/" + ds_list2_clod.getColumn(i, "ordfromdd");
  10481. spclformat = "9(8)/ccyymmdd";
  10482. detldesc = "수탁기관에 검체검사를 의뢰한 경우 수탁기관기호와 검사의뢰일을 기재";
  10483. }
  10484. else if (basecd == "JJJJJJ")
  10485. {
  10486. okmsg = "준용명";
  10487. spclcd = "JS009";
  10488. cdnm = "준용명";
  10489. spclspec = ds_list2_clod.getColumn(i, "hngnm");
  10490. spclformat = "X(700)";
  10491. detldesc = "상대가치점수표에 분류되지 않은 항목을 상대가치점수표상의 비슷한 진료행위로 준용하여 'JJJJJJ'코드로 청구시 진료행위명과 산출식을 기재하고, 한의사의 임의처방 청구시에는 임의 처방명을 기재";
  10492. }
  10493. if (okmsg)
  10494. {
  10495. var isFind = false;
  10496. var edilnno = ds_list2_clod.getColumn(i, "edilnno");
  10497. if ( utlf_isNull(edilnno) || edilnno == "0" )
  10498. {
  10499. // 기존에 없었던 경우
  10500. if (isFind == false)
  10501. {
  10502. var aRow = ds_list3_clsp.addRow();
  10503. ds_list3_clsp.setColumn(aRow, "unitflag" , "J");
  10504. ds_list3_clsp.setColumn(aRow, "edilnno" , edilnno);
  10505. ds_list3_clsp.setColumn(aRow, "snglcalcscorcd" , ds_list2_clod.getColumn(i, "snglcalcscorcd"));
  10506. ds_list3_clsp.setColumn(aRow, "spclcd" , spclcd);
  10507. ds_list3_clsp.setColumn(aRow, "cdnm" , cdnm);
  10508. ds_list3_clsp.setColumn(aRow, "spclspec" , spclspec);
  10509. ds_list3_clsp.setColumn(aRow, "spclformat" , spclformat);
  10510. ds_list3_clsp.setColumn(aRow, "detldesc" , detldesc);
  10511. ds_list3_clsp.setColumn(aRow, "oldedilnno" , edilnno);
  10512. ds_list3_clsp.setColumn(aRow, "clodseqno" , seqno);
  10513. ds_list3_clsp.setColumn(aRow, "edicd" , edicd);
  10514. ds_list3_clsp.setColumn(aRow, "edicdflag" , edicdflag);
  10515. ds_list3_clsp.setColumn(aRow, "clsoyn" , "N");
  10516. ds_list3_clsp.rowposition = aRow;
  10517. isClspChange = true;
  10518. }
  10519. ds_hidden_list3.setColumn(0, "msgspclformat", cdnm + " - " + spclcd + " / " + "입력코드내역 : " + spclspec + " / 기재형식 : " + spclformat);
  10520. }
  10521. }
  10522. }
  10523. //}
  10524. if (isClspChange == true)
  10525. {
  10526. lf_fSortSpclNo();
  10527. }
  10528. }
  10529. /****************************************************************************************
  10530. * Argument : button
  10531. * Description : 상단 버튼 탭 화면 X 이벤트
  10532. ****************************************************************************************/
  10533. function grp_dropdownmenu_Button00_onclick(obj:Button, e:ClickEventInfo)
  10534. {
  10535. grp_dropdownmenu.visible = false;
  10536. }
  10537. /****************************************************************************************
  10538. * Argument : button
  10539. * Description : 상단 버튼 탭 화면 닫기 이벤트
  10540. ****************************************************************************************/
  10541. function grp_dropdownmenu_btn_closedropdownmenu_onclick(obj:Button, e:ClickEventInfo)
  10542. {
  10543. grp_dropdownmenu.visible = false;
  10544. }
  10545. /****************************************************************************************
  10546. * Argument : function
  10547. * Description : 처방주석입력
  10548. ****************************************************************************************/
  10549. function lf_fOrderGridInsertCmt()
  10550. {
  10551. ds_rslt_sppiz00500.clearData();
  10552. ds_cond_sppiz00500.clearData();
  10553. ds_cond_sppiz00500_list.clearData();
  10554. var row = ds_list2_clod.rowposition;
  10555. var seqno = ds_list2_clod.getColumn(row, "seqno");
  10556. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  10557. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  10558. if (!utlf_isNull(seqno) && seqno != "0")
  10559. {
  10560. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(row, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  10561. if (utlf_isNull(lnunitspclspecyn))
  10562. {
  10563. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "I", 0);
  10564. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  10565. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  10566. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string",seqno, 0);
  10567. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", "JX999", 0);
  10568. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string","특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  10569. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", "", 0);
  10570. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", "X(700)", 0);
  10571. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", "", 0);
  10572. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", "기타내역", 0);
  10573. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", "J", 0);
  10574. }
  10575. else
  10576. {
  10577. var rowcnt = 0;
  10578. var setrow = 0;
  10579. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  10580. {
  10581. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  10582. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  10583. if (spcClodseqno == seqno && spcClsoyn == "N")
  10584. {
  10585. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  10586. if (!utlf_isNull(spclcd) && spclcd != "JT001" && ds_list3_clsp.getRowType(i) != 8)
  10587. {
  10588. dsf_makeValue(ds_cond_sppiz00500_list, "flag", "string", "", rowcnt);
  10589. dsf_makeValue(ds_cond_sppiz00500_list, "rownum", "string", i, rowcnt);
  10590. dsf_makeValue(ds_cond_sppiz00500_list, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  10591. dsf_makeValue(ds_cond_sppiz00500_list, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  10592. dsf_makeValue(ds_cond_sppiz00500_list, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  10593. dsf_makeValue(ds_cond_sppiz00500_list, "spclcd", "string", spclcd, rowcnt);
  10594. dsf_makeValue(ds_cond_sppiz00500_list, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  10595. dsf_makeValue(ds_cond_sppiz00500_list, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), rowcnt);
  10596. dsf_makeValue(ds_cond_sppiz00500_list, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  10597. dsf_makeValue(ds_cond_sppiz00500_list, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), rowcnt);
  10598. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclcd", "string", spclcd, rowcnt);
  10599. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  10600. if (spclcd == "JX999")
  10601. {
  10602. setrow = i;
  10603. }
  10604. rowcnt++;
  10605. }
  10606. }
  10607. }
  10608. if (setrow > 0)
  10609. {
  10610. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "", 0);
  10611. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  10612. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  10613. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", seqno, 0);
  10614. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", ds_list3_clsp.getColumn(setrow, "spclcd"), 0);
  10615. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", ds_list3_clsp.getColumn(setrow, "detldesc"), 0);
  10616. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", ds_list3_clsp.getColumn(setrow, "spclspec"), 0);
  10617. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", ds_list3_clsp.getColumn(setrow, "spclformat"), 0);
  10618. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", setrow, 0);
  10619. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", ds_list3_clsp.getColumn(setrow, "cdnm"), 0);
  10620. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", "J", 0);
  10621. }
  10622. else
  10623. {
  10624. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "I", 0);
  10625. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  10626. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  10627. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", seqno, 0);
  10628. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", "JX999", 0);
  10629. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  10630. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", "", 0);
  10631. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", "X(700)", 0);
  10632. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", "", 0);
  10633. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", "기타내역", 0);
  10634. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", "J", 0);
  10635. }
  10636. }
  10637. var objArg = new Object();
  10638. objArg.arg_ds_hidden_clsp = ds_cond_sppiz00500;
  10639. objArg.arg_ds_hidden_clsp_list = ds_cond_sppiz00500_list;
  10640. var rtn = frmf_modal("SPPIZ00500", "SPPIZ00500", objArg, "", "", "", "", "", "", "", "", "", "M");
  10641. var rsltcnt = ds_rslt_sppiz00500.rowcount;
  10642. if (rsltcnt > 0)
  10643. {
  10644. for (var i = 0; i < rsltcnt; i++)
  10645. {
  10646. var flag = ds_rslt_sppiz00500.getColumn(i, "flag");
  10647. var rownum = ds_rslt_sppiz00500.getColumn(i, "rownum");
  10648. var newspclcd = ds_rslt_sppiz00500.getColumn(i, "spclcd");
  10649. var newcdnm = ds_rslt_sppiz00500.getColumn(i, "cdnm");
  10650. var newspclspec = ds_rslt_sppiz00500.getColumn(i, "spclspec");
  10651. var newspclformat = ds_rslt_sppiz00500.getColumn(i, "spclformat");
  10652. var newdetldesc = ds_rslt_sppiz00500.getColumn(i, "detldesc");
  10653. if (flag == "I")
  10654. {
  10655. var clsprow = ds_list3_clsp.addRow();
  10656. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  10657. ds_list3_clsp.setColumn(clsprow, "clodseqno", seqno);
  10658. ds_list3_clsp.setColumn(clsprow, "edilnno", edilnno);
  10659. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", snglcalcscorcd);
  10660. ds_list3_clsp.setColumn(clsprow, "spclcd", newspclcd);
  10661. ds_list3_clsp.setColumn(clsprow, "cdnm", newcdnm);
  10662. ds_list3_clsp.setColumn(clsprow, "spclspec", newspclspec);
  10663. ds_list3_clsp.setColumn(clsprow, "detldesc", newdetldesc);
  10664. ds_list3_clsp.setColumn(clsprow, "oldedilnno", edilnno);
  10665. ds_list3_clsp.setColumn(clsprow, "oldspclcd", "");
  10666. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  10667. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  10668. }
  10669. else if (flag == "U")
  10670. {
  10671. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd", snglcalcscorcd);
  10672. ds_list3_clsp.setColumn(rownum, "spclcd", newspclcd);
  10673. ds_list3_clsp.setColumn(rownum, "cdnm", newcdnm);
  10674. ds_list3_clsp.setColumn(rownum, "spclspec", newspclspec);
  10675. ds_list3_clsp.setColumn(rownum, "spclformat", newspclformat);
  10676. ds_list3_clsp.setColumn(rownum, "detldesc", newdetldesc);
  10677. var oldspclcd = ds_rslt_sppiz00500.getColumn(i, "oldspclcd");
  10678. var oldspclspec = ds_rslt_sppiz00500.getColumn(i, "oldspclspec");
  10679. var rowstatus = ds_list3_clsp.getRowType(rownum);
  10680. if (rowstatus == 2)
  10681. {
  10682. }
  10683. else
  10684. {
  10685. var arrRow = new Array();
  10686. arrRow[0] = rownum;
  10687. grdf_setStatus(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, "U", arrRow);
  10688. }
  10689. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  10690. }
  10691. else if (flag == "D" && !utlf_isNull(rownum))
  10692. {
  10693. var rowstatus = ds_list3_clsp.getRowType(rownum);
  10694. if (rowstatus == 2)
  10695. {
  10696. ds_list3_clsp.deleteRow(rownum);
  10697. }
  10698. else
  10699. {
  10700. ds_list3_clsp.setColumn(rownum, "rowstat","D");
  10701. ds_list3_clsp.updatecontrol = false;
  10702. ds_list3_clsp.setRowType(rownum, 'd');
  10703. ds_list3_clsp.updatecontrol = true;
  10704. lf_fSetSpclSpecJX999()
  10705. ds_list3_clsp.deleteRow(rownum);
  10706. }
  10707. ds_list3_clsp.rowposition = rownum;
  10708. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  10709. }
  10710. }
  10711. }
  10712. lf_fSortSpclNo();
  10713. lf_fSaveClspList();
  10714. }
  10715. else
  10716. {
  10717. sysf_messageBox("줄번호가 부여되지 않았으며 해당 줄단위 특정내역이", "I004"); ///줄번호가 부여되지 않았으며 해당 줄단위 특정내역이 없습니다.
  10718. }
  10719. }
  10720. /****************************************************************************************
  10721. * Argument : function
  10722. * Description : 일괄처방주석입력
  10723. ****************************************************************************************/
  10724. function lf_fOrderGridInsertAllCmt()
  10725. {
  10726. ds_rslt_sppiz00500.clearData();
  10727. ds_cond_sppiz00500.clearData();
  10728. ds_cond_sppiz00500_list.clearData();
  10729. var rows = grdf_getSelectedRows(grp_biz.grd_clodhist);
  10730. for (var k = 0; k < rows.length; k++ )
  10731. {
  10732. var row = rows[k];
  10733. var seqno = ds_list2_clod.getColumn(row, "seqno");
  10734. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  10735. if (!utlf_isNull(seqno) && seqno != "0")
  10736. {
  10737. }
  10738. else
  10739. {
  10740. sysf_messageBox("줄번호가 부여되지 않았으며 해당 줄단위 특정내역이", "I004");
  10741. return;
  10742. }
  10743. }
  10744. var rowcnt = 0;
  10745. var setrow = 0;
  10746. for (var k = 0; k < rows.length; k++ )
  10747. {
  10748. var row = rows[k];
  10749. var seqno = ds_list2_clod.getColumn(row, "seqno");
  10750. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  10751. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  10752. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(row, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  10753. if (utlf_isNull(lnunitspclspecyn))
  10754. {
  10755. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "I", 0);
  10756. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  10757. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  10758. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", seqno, 0);
  10759. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", "JX999", 0);
  10760. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  10761. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", "", 0);
  10762. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", "X(700)", 0);
  10763. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", "", 0);
  10764. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", "기타내역", 0);
  10765. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", "J", 0);
  10766. dsf_makeValue(ds_cond_sppiz00500_list, "flag", "string", "I", rowcnt);
  10767. dsf_makeValue(ds_cond_sppiz00500_list, "rownum", "string", "", rowcnt);
  10768. dsf_makeValue(ds_cond_sppiz00500_list, "snglcalcscorcd", "string", snglcalcscorcd, rowcnt);
  10769. dsf_makeValue(ds_cond_sppiz00500_list, "clodseqno", "string", seqno, rowcnt);
  10770. dsf_makeValue(ds_cond_sppiz00500_list, "edilnno", "string", edilnno, rowcnt);
  10771. dsf_makeValue(ds_cond_sppiz00500_list, "spclcd", "string", "JX999", rowcnt);
  10772. dsf_makeValue(ds_cond_sppiz00500_list, "spclspec", "string", "", rowcnt);
  10773. dsf_makeValue(ds_cond_sppiz00500_list, "spclformat", "string", "X(700)", rowcnt);
  10774. dsf_makeValue(ds_cond_sppiz00500_list, "cdnm", "string", "기타내역", rowcnt);
  10775. dsf_makeValue(ds_cond_sppiz00500_list, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", rowcnt);
  10776. rowcnt++;
  10777. }
  10778. else
  10779. {
  10780. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  10781. {
  10782. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  10783. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  10784. if (spcClodseqno == seqno && spcClsoyn == "N")
  10785. {
  10786. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  10787. var spclcdJX999 = ds_list3_clsp.lookupExpr("insntstat!='D' && spclcd=='JX999' && snglcalcscorcd='"+snglcalcscorcd+"'", "spclcd");
  10788. if (!utlf_isNull(spclcd) && spclcd == "JX999" && ds_list3_clsp.getRowType(i) != 8)
  10789. {
  10790. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "U", 0);
  10791. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), 0);
  10792. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), 0);
  10793. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), 0);
  10794. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", spclcd, 0);
  10795. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), 0);
  10796. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), 0);
  10797. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", "X(700)", 0);
  10798. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", i, 0);
  10799. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), 0);
  10800. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", ds_list3_clsp.getColumn(i, "unitflag"), 0);
  10801. dsf_makeValue(ds_cond_sppiz00500_list, "flag", "string", "U", rowcnt);
  10802. dsf_makeValue(ds_cond_sppiz00500_list, "rownum", "string", i, rowcnt);
  10803. dsf_makeValue(ds_cond_sppiz00500_list, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  10804. dsf_makeValue(ds_cond_sppiz00500_list, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  10805. dsf_makeValue(ds_cond_sppiz00500_list, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  10806. dsf_makeValue(ds_cond_sppiz00500_list, "spclcd", "string", spclcd, rowcnt);
  10807. dsf_makeValue(ds_cond_sppiz00500_list, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  10808. dsf_makeValue(ds_cond_sppiz00500_list, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), rowcnt);
  10809. dsf_makeValue(ds_cond_sppiz00500_list, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  10810. dsf_makeValue(ds_cond_sppiz00500_list, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), rowcnt);
  10811. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclcd", "string", spclcd, rowcnt);
  10812. dsf_makeValue(ds_cond_sppiz00500_list, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  10813. if (spclcd == "JX999")
  10814. {
  10815. setrow = i;
  10816. }
  10817. rowcnt++;
  10818. }
  10819. else if (!utlf_isNull(spclcd) && spclcd != "JT001" && utlf_isNull(spclcdJX999) && ds_list3_clsp.getRowType(i) != 8)
  10820. {
  10821. dsf_makeValue(ds_cond_sppiz00500, "flag", "string", "I", 0);
  10822. dsf_makeValue(ds_cond_sppiz00500, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  10823. dsf_makeValue(ds_cond_sppiz00500, "edilnno", "string", edilnno, 0);
  10824. dsf_makeValue(ds_cond_sppiz00500, "clodseqno", "string", seqno, 0);
  10825. dsf_makeValue(ds_cond_sppiz00500, "spclcd", "string", "JX999", 0);
  10826. dsf_makeValue(ds_cond_sppiz00500, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  10827. dsf_makeValue(ds_cond_sppiz00500, "spclspec", "string", "", 0);
  10828. dsf_makeValue(ds_cond_sppiz00500, "spclformat", "string", "X(700)", 0);
  10829. dsf_makeValue(ds_cond_sppiz00500, "rownum", "string", "", 0);
  10830. dsf_makeValue(ds_cond_sppiz00500, "cdnm", "string", "기타내역", 0);
  10831. dsf_makeValue(ds_cond_sppiz00500, "unitflag", "string", "J", 0);
  10832. dsf_makeValue(ds_cond_sppiz00500_list, "flag", "string", "I", rowcnt);
  10833. dsf_makeValue(ds_cond_sppiz00500_list, "rownum", "string", "", rowcnt);
  10834. dsf_makeValue(ds_cond_sppiz00500_list, "snglcalcscorcd", "string", snglcalcscorcd, rowcnt);
  10835. dsf_makeValue(ds_cond_sppiz00500_list, "clodseqno", "string", seqno, rowcnt);
  10836. dsf_makeValue(ds_cond_sppiz00500_list, "edilnno", "string", edilnno, rowcnt);
  10837. dsf_makeValue(ds_cond_sppiz00500_list, "spclcd", "string", "JX999", rowcnt);
  10838. dsf_makeValue(ds_cond_sppiz00500_list, "spclspec", "string", "", rowcnt);
  10839. dsf_makeValue(ds_cond_sppiz00500_list, "spclformat", "string", "X(700)", rowcnt);
  10840. dsf_makeValue(ds_cond_sppiz00500_list, "cdnm", "string", "기타내역", rowcnt);
  10841. dsf_makeValue(ds_cond_sppiz00500_list, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", rowcnt);
  10842. rowcnt++;
  10843. }
  10844. }
  10845. }
  10846. }
  10847. }
  10848. var objArg = new Object();
  10849. objArg.arg_ds_hidden_clsp = ds_cond_sppiz00500;
  10850. objArg.arg_ds_hidden_clsp_list = ds_cond_sppiz00500_list;
  10851. var rtn = frmf_modal("SPPIZ00500", "SPPIZ00500", objArg, "", "", "", "", "", "", "", "", "", "M");
  10852. var rsltcnt = ds_rslt_sppiz00500.rowcount;
  10853. if (rsltcnt > 0)
  10854. {
  10855. ds_list2_clod.updatecontrol = false;
  10856. for (var i = 0; i < rsltcnt; i++)
  10857. {
  10858. var flag = ds_rslt_sppiz00500.getColumn(i, "flag");
  10859. var rownum = ds_rslt_sppiz00500.getColumn(i, "rownum");
  10860. var newspclcd = ds_rslt_sppiz00500.getColumn(i, "spclcd");
  10861. var newcdnm = ds_rslt_sppiz00500.getColumn(i, "cdnm");
  10862. var newspclspec = ds_rslt_sppiz00500.getColumn(ds_rslt_sppiz00500.rowcount-1, "spclspec");
  10863. var newspclformat = ds_rslt_sppiz00500.getColumn(i, "spclformat");
  10864. var newdetldesc = ds_rslt_sppiz00500.getColumn(i, "detldesc");
  10865. var newclodseqno = ds_rslt_sppiz00500.getColumn(i, "clodseqno");
  10866. var newsnglcalcscorcd = ds_rslt_sppiz00500.getColumn(i, "snglcalcscorcd");
  10867. var newedilnno = ds_rslt_sppiz00500.getColumn(i, "edilnno");
  10868. if (flag == "I")
  10869. {
  10870. var clsprow = ds_list3_clsp.addRow();
  10871. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  10872. ds_list3_clsp.setColumn(clsprow, "clodseqno", newclodseqno);
  10873. ds_list3_clsp.setColumn(clsprow, "edilnno", newedilnno);
  10874. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", newsnglcalcscorcd);
  10875. ds_list3_clsp.setColumn(clsprow, "spclcd", newspclcd);
  10876. ds_list3_clsp.setColumn(clsprow, "cdnm", newcdnm);
  10877. ds_list3_clsp.setColumn(clsprow, "spclspec", newspclspec);
  10878. ds_list3_clsp.setColumn(clsprow, "spclformat", newspclformat);
  10879. ds_list3_clsp.setColumn(clsprow, "detldesc", newdetldesc);
  10880. ds_list3_clsp.setColumn(clsprow, "oldedilnno", newedilnno);
  10881. ds_list3_clsp.setColumn(clsprow, "oldspclcd", "");
  10882. ds_list3_clsp.setColumn(clsprow, "clsoyn", "N");
  10883. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  10884. // var find = ds_list2_clod.findRow("seqno", newclodseqno);
  10885. // var srow = ds_list2_clod.findRow("seqno", newclodseqno);
  10886. //
  10887. // if (newspclcd == "JX999")
  10888. // {
  10889. // //grid_obj.cellStyle("background-color", srow, grid_obj.colRef("lnunitspclspecyn")) = "#f7a08b"; // class="color_6" 다홍색
  10890. // }
  10891. // else if (newspclcd != "JT001")
  10892. // {
  10893. // //grid_obj.cellStyle("background-color", srow, grid_obj.colRef("lnunitspclspecyn")) = "#b5a5d1"; // 연한 보라색
  10894. // }
  10895. }
  10896. else if (flag == "U")
  10897. {
  10898. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd", newsnglcalcscorcd);
  10899. ds_list3_clsp.setColumn(rownum, "spclcd", newspclcd);
  10900. ds_list3_clsp.setColumn(rownum, "cdnm", newcdnm);
  10901. ds_list3_clsp.setColumn(rownum, "spclspec", newspclspec);
  10902. ds_list3_clsp.setColumn(rownum, "spclformat", newspclformat);
  10903. ds_list3_clsp.setColumn(rownum, "detldesc", newdetldesc);
  10904. var oldspclcd = ds_rslt_sppiz00500.getColumn(i, "oldspclcd");
  10905. var oldspclspec = ds_rslt_sppiz00500.getColumn(i, "oldspclspec");
  10906. var rowstatus = ds_list3_clsp.getRowType(rownum);
  10907. if (rowstatus == 2)
  10908. {
  10909. }
  10910. else
  10911. {
  10912. var arrRow = new Array();
  10913. arrRow[0] = rownum;
  10914. grdf_setStatus(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, "U", arrRow);
  10915. }
  10916. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  10917. }
  10918. else if (flag == "D" && !utlf_isNull(rownum))
  10919. {
  10920. var rowstatus = ds_list3_clsp.getRowType(rownum);
  10921. if (rowstatus == 2)
  10922. {
  10923. ds_list3_clsp.deleteRow(rownum);
  10924. }
  10925. else
  10926. {
  10927. ds_list3_clsp.setColumn(rownum, "insntstat","D");
  10928. ds_list3_clsp.updatecontrol = false;
  10929. ds_list3_clsp.setRowType(rownum, 'd');
  10930. ds_list3_clsp.updatecontrol = true;
  10931. lf_fSetSpclSpecJX999()
  10932. ds_list3_clsp.deleteRow(rownum);
  10933. }
  10934. ds_list3_clsp.setColumn(rownum, "insntstat", "D");
  10935. ds_list3_clsp.rowposition = rownum;
  10936. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  10937. }
  10938. }
  10939. }
  10940. ds_list2_clod.updatecontrol = true;
  10941. lf_fSortSpclNo();
  10942. lf_fSaveClspList();
  10943. }
  10944. /****************************************************************************************
  10945. * Argument : function
  10946. * Description : 1회량 일괄수정
  10947. ****************************************************************************************/
  10948. function lf_fAllSetDrugqtyCol()
  10949. {
  10950. var rows = grdf_getSelectedRows(grp_biz.grd_clodhist);
  10951. if (rows.length > 0)
  10952. {
  10953. var setrow = rows[0];
  10954. var edidrugqty = parseFloat(ds_list2_clod.getColumn(setrow, "edidrugqty"));
  10955. if (utlf_isNull(edidrugqty) || edidrugqty == 0)
  10956. {
  10957. return;
  10958. }
  10959. var rCnt = 0;
  10960. for (var i = 0; i < rows.length; i++)
  10961. {
  10962. var clodrow = rows[i];
  10963. ds_list2_clod.setColumn(clodrow, "drugqty", edidrugqty);
  10964. ds_list2_clod.setColumn(clodrow, "edidrugqty", edidrugqty);
  10965. ds_list2_clod.setColumn(clodrow, "adjtresncd", "A");
  10966. var arrRow = new Array();
  10967. arrRow[0] = clodrow;
  10968. grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  10969. ds_list2_clod.clearSelect();
  10970. ds_list2_clod.rowposition = clodrow;
  10971. ds_list2_clod.selectRow(clodrow);
  10972. lf_fSetTotDrugQtyAmt(); //1회량수정 후 계산
  10973. }
  10974. }
  10975. }
  10976. /****************************************************************************************
  10977. * Argument : function
  10978. * Description : 진료정보 버튼 이벤트 함수
  10979. ****************************************************************************************/
  10980. function lf_fGetEmrInformation()
  10981. {
  10982. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  10983. if(pid)
  10984. {
  10985. fOpenSMMMO02500_1(pid);
  10986. }
  10987. }
  10988. /****************************************************************************************
  10989. * Argument : function
  10990. * Description : 횟수 일괄 수정
  10991. ****************************************************************************************/
  10992. function lf_fAllSetTimsCol()
  10993. {
  10994. var rows = grdf_getSelectedRows(grp_biz.grd_clodhist);
  10995. if (rows.length > 0)
  10996. {
  10997. var setrow = rows[0];
  10998. var tims = ds_list2_clod.getColumn(setrow, "tims");
  10999. if (utlf_isNull(tims) || tims == "0")
  11000. {
  11001. return;
  11002. }
  11003. for (var i = 0; i < rows.length; i++)
  11004. {
  11005. var clodrow = rows[i];
  11006. ds_list2_clod.setColumn(clodrow, "tims", tims);
  11007. ds_list2_clod.setColumn(clodrow, "adjtresncd", "A");
  11008. var arrRow = new Array();
  11009. arrRow[0] = clodrow;
  11010. grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  11011. ds_list2_clod.clearSelect();
  11012. ds_list2_clod.rowposition = clodrow;
  11013. ds_list2_clod.selectRow(clodrow);
  11014. lf_fSetTotDrugQtyAmt();
  11015. }
  11016. }
  11017. }
  11018. /****************************************************************************************
  11019. * Argument : button
  11020. * Description : 수술 버튼 이벤트
  11021. ****************************************************************************************/
  11022. function grp_biz_btn_opyn_onclick(obj:Button, e:ClickEventInfo)
  11023. {
  11024. var clamkey = ds_main_item1_clbs.getColumn(0, "clamkey");
  11025. if (clamkey)
  11026. {
  11027. var judgOpenWindow = frmf_findPopup("SPPIZ01300"); // SPPIZ01300_수술정보조회
  11028. if (utlf_isNull(judgOpenWindow))
  11029. {
  11030. ds_cond_sppiz01300.clearData();
  11031. ds_cond_sppiz01300.addRow();
  11032. ds_cond_sppiz01300.setColumn(0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  11033. ds_cond_sppiz01300.setColumn(0, "indd", ds_main_item1_clbs.getColumn(0, "indd"));
  11034. ds_cond_sppiz01300.setColumn(0, "cretno", ds_main_item1_clbs.getColumn(0, "cretno"));
  11035. ds_cond_sppiz01300.setColumn(0, "instcd", sysf_getUserInfo("dutplceinstcd"));
  11036. ds_cond_sppiz01300.setColumn(0, "instcd", ds_main_item1_clbs.getColumn(0, "ioflag"));
  11037. var objArg = new Object();
  11038. objArg.objDs = ds_cond_sppiz01300;
  11039. frmf_modal("SPPIZ01300", "SPPIZ01300", objArg, "", "", "", "", "", "", "", "", "", "M");
  11040. }
  11041. else
  11042. {
  11043. judgOpenWindow.fSrchInfo();
  11044. frmf_setFocusPop("SPPIZ01300");
  11045. }
  11046. }
  11047. }
  11048. /****************************************************************************************
  11049. * Argument : function
  11050. * Description : 기존코드 수정 1회량/횟수/일수 수정시
  11051. ****************************************************************************************/
  11052. // function fSetTotDrugQtyAmt(col)
  11053. // {
  11054. // var i = ds_list2_clod.rowposition;
  11055. // var col = col;
  11056. //
  11057. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "N", 0);
  11058. // dsf_makeValue(ds_send_item5_mech, "ediupdateyn", "string", "N", 0);
  11059. //
  11060. // var drugqty = ds_list2_clod.getColumn(i, "drugqty");
  11061. //
  11062. // if (utlf_isNull(drugqty) || drugqty == "0")
  11063. // {
  11064. // ds_list2_clod.setColumn(i, "drugqty", "1");
  11065. // }
  11066. //
  11067. // var tims = ds_list2_clod.getColumn(i, "tims");
  11068. //
  11069. // if (utlf_isNull(tims) || tims == "0")
  11070. // {
  11071. // ds_list2_clod.setColumn(i, "tims", "1");
  11072. // }
  11073. //
  11074. // var dayno = ds_list2_clod.getColumn(i, "dayno");
  11075. //
  11076. // if (utlf_isNull(dayno) || dayno == "0")
  11077. // {
  11078. // ds_list2_clod.setColumn(i, "dayno", "1");
  11079. // }
  11080. //
  11081. // var dayno = ds_list2_clod.getColumn(i, "edidrugqty");
  11082. //
  11083. // if (utlf_isNull(dayno)|| dayno == "0")
  11084. // {
  11085. // ds_list2_clod.setColumn(i, "edidrugqty", "1");
  11086. // }
  11087. // var dayno = ds_list2_clod.getColumn(i, "edidayno");
  11088. //
  11089. // if (utlf_isNull(dayno)|| dayno == "0")
  11090. // {
  11091. // ds_list2_clod.setColumn(i, "edidayno", "1");
  11092. // }
  11093. //
  11094. // if(col == "edidrugqty")
  11095. // {
  11096. // ds_list2_clod.setColumn(i, "drugqty", ds_list2_clod.getColumn(i, "edidrugqty"));
  11097. // ds_list2_clod.setColumn(i, "daydrugqty", ds_list2_clod.getColumn(i, "edidrugqty"));
  11098. // col = "drugqty";
  11099. // }
  11100. // else if(col == "edidayno")
  11101. // {
  11102. // ds_list2_clod.setColumn(i, "dayno", ds_list2_clod.getColumn(i, "edidayno"));
  11103. // col = "dayno";
  11104. // }
  11105. //
  11106. // var sDrugqty = ds_list2_clod.getColumn(i, "drugqty");
  11107. // var sTims = ds_list2_clod.getColumn(i, "tims");
  11108. // var sDayno = ds_list2_clod.getColumn(i, "dayno");
  11109. // var sUnitcost = ds_list2_clod.getColumn(i, "unitcost");
  11110. // var sEdiUnitcost = ds_list2_clod.getColumn(i, "ediunitcost");
  11111. // var sAmt = ds_list2_clod.getColumn(i, "amt");
  11112. // var sEdiAmt = ds_list2_clod.getColumn(i, "ediamt");
  11113. // var sDruglimitamt = ds_list2_clod.getColumn(i, "druglimitamt");
  11114. // var sEdiDruglimitamt = ds_list2_clod.getColumn(i, "edidruglimitamt");
  11115. // var sLimitdiffamt = ds_list2_clod.getColumn(i, "limitdiffamt");
  11116. // var sEdiLimitdiffamt = ds_list2_clod.getColumn(i, "edilimitdiffamt");
  11117. // var sEdiDrugqty = ds_list2_clod.getColumn(i, "edidrugqty");
  11118. // var sEdiDayno = ds_list2_clod.getColumn(i, "edidayno");
  11119. //
  11120. // var drugqty = parseFloat(sDrugqty);
  11121. // var tims = parseInt(sTims);
  11122. // var dayno = parseInt(sDayno);
  11123. // var unitcost = parseInt(sUnitcost);
  11124. // var ediunitcost = parseInt(sEdiUnitcost);
  11125. // var amt = parseInt(sAmt);
  11126. // var ediamt = parseInt(sEdiAmt);
  11127. // var druglimitamt = parseInt(sDruglimitamt);
  11128. // var edidruglimitamt = parseInt(sEdiDruglimitamt);
  11129. // var limitdiffamt = parseInt(sLimitdiffamt);
  11130. // var edilimitdiffamt = parseInt(sEdiLimitdiffamt);
  11131. //
  11132. // var edidrugqty = parseFloat(sEdiDrugqty);
  11133. // var edidayno = parseInt(sEdiDayno);
  11134. //
  11135. // if(col == "drugqty")
  11136. // {
  11137. // if(utlf_isNull(sDrugqty) || drugqty <= 0)
  11138. // {
  11139. // lf_fCancelClodStatusChng();
  11140. // return false;
  11141. // }
  11142. // else
  11143. // {
  11144. // dsf_makeValue(ds_send_item5_mech, "dayno", "string", sDrugqty, 0);
  11145. //
  11146. // }
  11147. // }
  11148. // else if(col == "tims")
  11149. // {
  11150. // if(utlf_isNull(sTims) || tims <= 0)
  11151. // {
  11152. // lf_fCancelClodStatusChng(); // 처방이전상태 복구
  11153. // return false;
  11154. // }
  11155. // else
  11156. // {
  11157. // dsf_makeValue(ds_send_item5_mech, "dayno", "string", sTims, 0);
  11158. // }
  11159. // }
  11160. // else if(col == "dayno")
  11161. // {
  11162. // if (utlf_isNull(sDayno) || dayno <= 0)
  11163. // {
  11164. // lf_fCancelClodStatusChng(); // 처방이전상태 복구
  11165. // return false;
  11166. // }
  11167. // else
  11168. // {
  11169. // dsf_makeValue(ds_send_item5_mech, "dayno", "string", sDayno, 0);
  11170. // }
  11171. // }
  11172. // else if (col == "unitcost")
  11173. // {
  11174. // if (utlf_isNull(sUnitcost) || unitcost <= 0)
  11175. // {
  11176. // lf_fCancelClodStatusChng();
  11177. // return false;
  11178. // }
  11179. // else
  11180. // {
  11181. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11182. // }
  11183. // }
  11184. // else if (col == "ediunitcost")
  11185. // {
  11186. // if(utlf_isNull(sEdiUnitcost) || ediunitcost <= 0)
  11187. // {
  11188. // lf_fCancelClodStatusChng();
  11189. // return false;
  11190. // }
  11191. // else
  11192. // {
  11193. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11194. // }
  11195. // }
  11196. // else if (col == "amt")
  11197. // {
  11198. // if (utlf_isNull(sAmt) || amt <= 0)
  11199. // {
  11200. // lf_fCancelClodStatusChng();
  11201. // return false;
  11202. // }
  11203. // else
  11204. // {
  11205. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11206. // }
  11207. // }
  11208. // else if (col == "ediamt")
  11209. // {
  11210. // if (utlf_isNull(sEdiAmt) || ediamt <= 0)
  11211. // {
  11212. // lf_fCancelClodStatusChng();
  11213. // return false;
  11214. // }
  11215. // else
  11216. // {
  11217. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11218. // }
  11219. // }
  11220. // else if (col == grd_clodhist.colRef("druglimitamt"))
  11221. // {
  11222. // if (utlf_isNull(sDruglimitamt) || druglimitamt <= 0)
  11223. // {
  11224. // lf_fCancelClodStatusChng();
  11225. // return false;
  11226. // }
  11227. // else
  11228. // {
  11229. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11230. // }
  11231. // }
  11232. // else if (col == "edidruglimitamt")
  11233. // {
  11234. // if (utlf_isNull(sEdiDruglimitamt) || edidruglimitamt <= 0)
  11235. // {
  11236. // lf_fCancelClodStatusChng();
  11237. // return false;
  11238. // }
  11239. // else
  11240. // {
  11241. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11242. // }
  11243. // }
  11244. // else if (col == "limitdiffamt")
  11245. // {
  11246. // if (utlf_isNull(sLimitdiffamt)|| limitdiffamt <= 0)
  11247. // {
  11248. // lf_fCancelClodStatusChng(); // 처방이전상태 복구
  11249. // return false;
  11250. // }
  11251. // else
  11252. // {
  11253. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11254. // }
  11255. // }
  11256. // else if (col == "edilimitdiffamt")
  11257. // {
  11258. // if (utlf_isNull(sEdiLimitdiffamt) || edilimitdiffamt <= 0)
  11259. // {
  11260. // lf_fCancelClodStatusChng();
  11261. // return false;
  11262. // }
  11263. // else
  11264. // {
  11265. // dsf_makeValue(ds_send_item5_mech, "unitcostupdateyn", "string", "Y", 0);
  11266. // }
  11267. // }
  11268. // else if (col == "edidrugqty")
  11269. // {
  11270. // if (utlf_isNull(sEdiDrugqty) || edidrugqty <= 0)
  11271. // {
  11272. // lf_fCancelClodStatusChng();
  11273. // return false;
  11274. // }
  11275. // else
  11276. // {
  11277. // dsf_makeValue(ds_send_item5_mech, "ediupdateyn", "string", "Y", 0);
  11278. // }
  11279. // }
  11280. // else if (col == "edidayno")
  11281. // {
  11282. // if (utlf_isNull(sEdiDayno) || edidayno <= 0)
  11283. // {
  11284. // lf_fCancelClodStatusChng();
  11285. // return false;
  11286. // }
  11287. // else
  11288. // {
  11289. // dsf_makeValue(ds_send_item5_mech, "ediupdateyn", "string", "Y", 0);
  11290. // }
  11291. // }
  11292. //
  11293. // var ordfromdd = ds_list2_clod.getColumn(i, "ordfromdd");
  11294. // var ordtodd = ds_list2_clod.getColumn(i, "ordtodd");
  11295. // var dayno = ds_list2_clod.getColumn(i, "dayno");
  11296. // var snglcalcscorcd = ds_list2_clod.getColumn(i, "snglcalcscorcd");
  11297. //
  11298. // if ( utlf_isNull(ordfromdd)|| utlf_isNull(dayno)|| utlf_isNull(snglcalcscorcd))
  11299. // {
  11300. // return false;
  11301. // }
  11302. // if (parseInt(dayno) < 0)
  11303. // {
  11304. // return false;
  11305. // }
  11306. // else if (parseInt(dayno) > 365)
  11307. // {
  11308. // return false;
  11309. // }
  11310. //
  11311. // dsf_makeValue(ds_send_item5_mech, "ordfromdd", "string", ordfromdd, 0);
  11312. // dsf_makeValue(ds_send_item5_mech, "ordtodd", "string", ordtodd, 0);
  11313. // dsf_makeValue(ds_send_item5_mech, "drugqty", "string", sEdiDrugqty, 0);
  11314. // dsf_makeValue(ds_send_item5_mech, "tims", "string", sTims, 0);
  11315. // dsf_makeValue(ds_send_item5_mech, "dayno", "string", sDayno, 0);
  11316. // dsf_makeValue(ds_send_item5_mech, "unitcost", "string", sUnitcost, 0);
  11317. // dsf_makeValue(ds_send_item5_mech, "ediunitcost", "string", sEdiUnitcost, 0);
  11318. // dsf_makeValue(ds_send_item5_mech, "amt", "string", sAmt, 0);
  11319. // dsf_makeValue(ds_send_item5_mech, "ediamt", "string", sEdiAmt, 0);
  11320. // dsf_makeValue(ds_send_item5_mech, "druglimitamt", "string", sDruglimitamt, 0);
  11321. // dsf_makeValue(ds_send_item5_mech, "edidruglimitamt", "string", sEdiDruglimitamt, 0);
  11322. // dsf_makeValue(ds_send_item5_mech, "limitdiffamt", "string", sLimitdiffamt, 0);
  11323. // dsf_makeValue(ds_send_item5_mech, "edilimitdiffamt", "string", sEdiLimitdiffamt, 0);
  11324. // dsf_makeValue(ds_send_item5_mech, "edidrugqty", "string", sEdiDrugqty, 0);
  11325. // dsf_makeValue(ds_send_item5_mech, "edidayno", "string", sEdiDayno, 0);
  11326. //
  11327. // var grupcalcscorcd = ds_list2_clod.getColumn(i, "grupcalcscorcd");
  11328. //
  11329. // if (!utlf_isNull(grupcalcscorcd) && grupcalcscorcd != "-")
  11330. // {
  11331. // dsf_makeValue(ds_send_item5_mech, "grupcalcscorcd", "string", grupcalcscorcd, 0);
  11332. // }
  11333. // else
  11334. // {
  11335. // dsf_makeValue(ds_send_item5_mech, "grupcalcscorcd", "string", "", 0);
  11336. // }
  11337. //
  11338. // dsf_makeValue(ds_send_item5_mech, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  11339. // dsf_makeValue(ds_send_item5_mech, "basecd", "string", "", 0);
  11340. //
  11341. // dsf_makeValue(ds_send_item5_mech, "insukind", "string", ds_main_item1_clbs.getColumn(0, "insukindcd"), 0);
  11342. // dsf_makeValue(ds_send_item5_mech, "suppkind", "string", ds_main_item1_clbs.getColumn(0, "suppkindcd"), 0);
  11343. //
  11344. // var orddeptcd = ds_list2_clod.getColumn(i, "orddeptcd");
  11345. //
  11346. // if (orddeptcd)
  11347. // {
  11348. // dsf_makeValue(ds_send_item5_mech, "orddeptcd", "string", orddeptcd, 0);
  11349. // }
  11350. // else
  11351. // {
  11352. // dsf_makeValue(ds_send_item5_mech, "orddeptcd", "string", ds_main_item1_clbs.getColumn(0, "orddeptcd"), 0);
  11353. // }
  11354. // var orddrid = ds_list2_clod.getColumn(i, "orddrid");
  11355. //
  11356. // if (orddrid)
  11357. // {
  11358. // dsf_makeValue(ds_send_item5_mech, "orddrid", "string", orddrid, 0);
  11359. // }
  11360. // else
  11361. // {
  11362. // dsf_makeValue(ds_send_item5_mech, "orddrid", "string", ds_main_item1_clbs.getColumn(0, "orddrid"), 0);
  11363. // }
  11364. //
  11365. // var estmmncd = ds_list2_clod.getColumn(i, "estmmncd");
  11366. //
  11367. // if (!utlf_isNull(estmmncd) && estmmncd != "-")
  11368. // {
  11369. // dsf_makeValue(ds_send_item5_mech, "estmmncd", "string", estmmncd, 0);
  11370. // }
  11371. //
  11372. // dsf_makeValue(ds_send_item5_mech, "adjtresncd", "string", ds_list2_clod.getColumn(i, "adjtresncd"), 0);
  11373. // dsf_makeValue(ds_send_item5_mech, "undersixageyn", "string", ds_main_item1_clbs.getColumn(0, "undersixageyn"), 0);
  11374. // dsf_makeValue(ds_send_item5_mech, "mechage", "string", ds_main_item1_clbs.getColumn(0, "mechage"), 0);
  11375. // dsf_makeValue(ds_send_item5_mech, "hosinresncd", "string", ds_list2_clod.getColumn(i, "hosinresncd"), 0);
  11376. // dsf_makeValue(ds_send_item5_mech, "ioflag", "string", ds_main_item1_clbs.getColumn(0, "ioflag"), 0);
  11377. // dsf_makeValue(ds_send_item5_mech, "clamflagcd", "string", ds_main_item1_clbs.getColumn(0, "clamflagcd"), 0);
  11378. //
  11379. // if (utlf_isNull(ds_list2_clod.getColumn(i, "seqno")))
  11380. // {
  11381. // dsf_makeValue(ds_send_item5_mech, "mode", "string", "n", 0);
  11382. // }
  11383. // else
  11384. // {
  11385. // dsf_makeValue(ds_send_item5_mech, "mode", "string", "u", 0);
  11386. // }
  11387. //
  11388. //
  11389. // var oParam = {};
  11390. // oParam.id = "TRPID20303";
  11391. // oParam.service = "aftjudgapp.InAftJudg";
  11392. // oParam.method = "reqGetCalcScorCd";
  11393. // oParam.inds = "req=ds_send_item5_mech";
  11394. // oParam.outds = "ds_main_item5_mech=mech";
  11395. // oParam.async = false;
  11396. // //oParam.callback = "cf_TRPID20303";
  11397. //
  11398. // tranf_submit(oParam);
  11399. //
  11400. // var clod = ds_main_item5_mech.rowcount;
  11401. //
  11402. // if (ds_main_item5_mech.rowcount == 1)
  11403. // {
  11404. // lf_fSetCalcScorAmt(clod, "update");
  11405. // }
  11406. // else
  11407. // {
  11408. // if (col == "drugqty")
  11409. // {
  11410. // lf_fCancelClodStatusChng();
  11411. // }
  11412. // else if (col == "tims")
  11413. // {
  11414. // lf_fCancelClodStatusChng();
  11415. // }
  11416. // else if (col == "dayno")
  11417. // {
  11418. // lf_fCancelClodStatusChng();
  11419. // }
  11420. // sysf_messageBox("조회된 처방 계산 내역이", "I004");
  11421. // }
  11422. // return true;
  11423. // }
  11424. /****************************************************************************************
  11425. * Argument : function
  11426. * Description : 일수 일괄수정
  11427. ****************************************************************************************/
  11428. function lf_fAllSetDaynoCol()
  11429. {
  11430. var rows = grdf_getSelectedRows(grp_biz.grd_clodhist);
  11431. if(rows.length > 0)
  11432. {
  11433. var setrow = rows[0];
  11434. var dayno = ds_list2_clod.getColumn(setrow, "edidayno");
  11435. if(utlf_isNull(dayno) || dayno == "0")
  11436. {
  11437. return;
  11438. }
  11439. for(var i = 0; i < rows.length; i++)
  11440. {
  11441. var clodrow = rows[i];
  11442. ds_list2_clod.setColumn(clodrow, "adjtresncd", "A");
  11443. ds_list2_clod.setColumn(clodrow, "edidayno", dayno);
  11444. ds_list2_clod.setColumn(clodrow, "dayno", dayno);
  11445. var arrRow = new Array();
  11446. arrRow[0] = clodrow;
  11447. grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  11448. var Sdayno = ds_list2_clod.getColumn(clodrow, "edidayno");
  11449. var dayno = parseInt(Sdayno);
  11450. var ordfromdd = ds_list2_clod.getColumn(clodrow, "ordfromdd");
  11451. var ordtodd = ds_list2_clod.getColumn(clodrow, "ordtodd");
  11452. var item1 = ds_list2_clod.getColumn(clodrow, "item1");
  11453. var clbsordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  11454. var clbsordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  11455. var insukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  11456. if (lgv_ioflag == "O") {
  11457. if (utlf_isNull(Sdayno)|| dayno <= 0)
  11458. {
  11459. }
  11460. else if (ordfromdd)
  11461. {
  11462. var fromDate = ordfromdd.toDate();
  11463. var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  11464. ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  11465. if (insukind == "41" && clbsordfromdd && clbsordtodd)
  11466. {
  11467. if (ordtodd > clbsordtodd)
  11468. {
  11469. ds_main_item1_clbs.setColumn(0, "ordtodd", ordtodd);
  11470. }
  11471. ds_list2_clod.setColumn(clodrow, "ordtodd", ordtodd);
  11472. }
  11473. }
  11474. } else if (lgv_ioflag == "I") {
  11475. if (utlf_isNull(Sdayno)|| dayno <= 0)
  11476. {
  11477. }
  11478. else if (!utlf_isNull(ordfromdd))
  11479. {
  11480. var fromDate = ordfromdd.toDate();
  11481. var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  11482. ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  11483. if (item1 != "03" && clbsordfromdd && clbsordtodd) {
  11484. if (ordtodd < clbsordfromdd || ordtodd > clbsordtodd) {
  11485. sysf_messageBox("일수를 기준으로 계산된 처방종료일자가 [진료 개시일자~종료일자]를 벗어나", "E016"); // /일수(총투)를 기준으로 계산된처방 종료일자가 입원 개시일자~종료일자를 벗어나 유효하지 않습니다. 처방 data 및 row status를 변경 이전 상태로 복구한다.
  11486. ds_list2_clod.setColumn(clodrow, "dayno", dayno);
  11487. return;
  11488. }
  11489. }
  11490. } else if (!utlf_isNull(ordtodd)) {
  11491. var toDate = ordtodd.toDate();
  11492. var fromDate = toDate.getAddDate((dayno - 1) * -1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  11493. ordfromdd = fromDate.getDateFormat("YYYY") + fromDate.getDateFormat("MM") + fromDate.getDateFormat("DD");
  11494. if (item1 != "03" && !utlf_isNull(clbsordfromdd) && !utlf_isNull(clbsordtodd)) {
  11495. if (ordfromdd < clbsordfromdd || ordfromdd > clbsordtodd) {
  11496. sysf_messageBox("일수를 기준으로 계산된 처방시작일자가 [진료 개시일자~종료일자]를 벗어나", "E016"); // /일수(총투)를 기준으로 계산된 처방
  11497. // 시작일자가 입원 개시일자~종료일자를 벗어나 유효하지 않습니다. 처방 data 및 row status를 변경 이전 상태로 복구한다.
  11498. ds_list2_clod.setColumn(clodrow, "dayno", dayno);
  11499. return;
  11500. }
  11501. }
  11502. // 일수를 기준으로 구한 날짜가 올바른 경우
  11503. ds_list2_clod.setColumn(clodrow, "ordfromdd", ordfromdd);
  11504. }
  11505. }
  11506. ds_list2_clod.clearSelect();
  11507. ds_list2_clod.rowposition = clodrow;
  11508. ds_list2_clod.selectRow(clodrow);
  11509. lf_fSetTotDrugQtyAmt();
  11510. }
  11511. }
  11512. }
  11513. /****************************************************************************************
  11514. * Argument : function
  11515. * Description : 수가 코드 조회 이벤트 함수
  11516. ****************************************************************************************/
  11517. function lf_fSetSrchCalcScorCd()
  11518. {
  11519. var col = grp_biz.grd_clodhist.currentcol;
  11520. var row = grp_biz.grd_clodhist.currentrow;
  11521. var calcscorcd = "";
  11522. ds_cond_smpic00200.clearData();
  11523. ds_cond_smpic00200.addRow();
  11524. ds_send_item5_mech.clearData();
  11525. ds_send_item5_mech.addRow();
  11526. ds_send_item5_mech.setColumn(0, "unitcostupdateyn", "N");
  11527. ds_send_item5_mech.setColumn(0, "ediupdateyn", "N");
  11528. var cnfmcd = ds_list2_clod.getColumn(row, "cnfmcd");
  11529. var lnunitspclspecyn = grp_biz.grd_clodhist.getCellText(row, grp_biz.grd_clodhist.getBindCellIndex("body", "lnunitspclspecyn"));
  11530. if (!utlf_isNull(lnunitspclspecyn))
  11531. {
  11532. var ans = sysf_messageBox("입력된 줄단위 특정내역을 삭제하고 코드를 변경", "S001");
  11533. if (ans == 6)
  11534. {
  11535. ds_list2_clod.setColumn(row, "cnfmcd", "");
  11536. bgcExpr = "EXPR( !utlf_isNull(cnfmcd) || !utlf_isNull(lnunitspclspecyn) ? '#ffffff' : 'default')"; // White
  11537. grp_biz.grd_clodhist.setCellProperty('Body',32, "background" , bgcExpr); // lnunitspclspecyn
  11538. grp_biz.grd_clodhist.setCellProperty('Body',32, "background2", bgcExpr); // lnunitspclspecyn
  11539. var edilnno = ds_list2_clod.getColumn(row, "edilnno");
  11540. var clspgridrow;
  11541. for ( var j = 0; j < ds_list3_clsp.rowcount; j++)
  11542. {
  11543. var spclLnNo = ds_list3_clsp.getColumn(j, "edilnno");
  11544. if (spclLnNo == edilnno)
  11545. {
  11546. var rowstatus = ds_list3_clsp.getRowType(j);
  11547. if (rowstatus == 2 )
  11548. {
  11549. ds_list3_clsp.setColumn(j, "spclcd" ,"");
  11550. ds_list3_clsp.setColumn(j, "spclspec","");
  11551. }
  11552. else
  11553. {
  11554. ds_list3_clsp.updatecontrol = false;
  11555. ds_list3_clsp.setRowType(j, "d");
  11556. ds_list3_clsp.updatecontrol = true;
  11557. }
  11558. }
  11559. }
  11560. lf_fSortSpclNo();
  11561. }
  11562. else if (ans == 7 || ans == 2)
  11563. {
  11564. lf_fCancelClodStatusChng();
  11565. return;
  11566. }
  11567. }
  11568. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "grupcalcscorcd"))
  11569. {
  11570. var grupcalcscorcd = ds_list2_clod.getColumn(row, "grupcalcscorcd");
  11571. if (utlf_isNull(grupcalcscorcd))
  11572. {
  11573. lf_fCancelClodStatusChng();
  11574. return;
  11575. }
  11576. // SMPIC00200_수가조회 용
  11577. ds_cond_smpic00200.setColumn(0, "con4_search2" , grupcalcscorcd);
  11578. // submit("TRPID20303") 용
  11579. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", grupcalcscorcd);
  11580. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", "");
  11581. ds_send_item5_mech.setColumn(0, "basecd", "");
  11582. }
  11583. else if (col == grp_biz.grd_clodhist.getBindCellIndex("Body", "snglcalcscorcd"))
  11584. {
  11585. var snglcalcscorcd = ds_list2_clod.getColumn(row, "snglcalcscorcd");
  11586. if (utlf_isNull(snglcalcscorcd))
  11587. {
  11588. lf_fCancelClodStatusChng();
  11589. return;
  11590. }
  11591. ds_cond_smpic00200.setColumn(0, "con4_search2", snglcalcscorcd);
  11592. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", snglcalcscorcd);
  11593. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  11594. ds_send_item5_mech.setColumn(0, "basecd", "");
  11595. }
  11596. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "basecd"))
  11597. {
  11598. var basecd = ds_list2_clod.getColumn(row, "basecd");
  11599. if (utlf_isNull(basecd))
  11600. {
  11601. lf_fCancelClodStatusChng();
  11602. return;
  11603. }
  11604. else if ( ds_hidden_item5_clod.getColumn(0, "basecd") == basecd )
  11605. {
  11606. return;
  11607. }
  11608. ds_cond_smpic00200.setColumn(0, "con4_search2", basecd);
  11609. ds_send_item5_mech.setColumn(0, "basecd", basecd);
  11610. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  11611. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", "");
  11612. }
  11613. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "hngnm"))
  11614. {
  11615. var hngnm = ds_list2_clod.getColumn(row, "hngnm");
  11616. if (utlf_isNull(hngnm))
  11617. {
  11618. lf_fCancelClodStatusChng();
  11619. return;
  11620. }
  11621. else if ( ds_hidden_item5_clod.getColumn(0, "hngnm") == hngnm )
  11622. {
  11623. return;
  11624. }
  11625. ds_cond_smpic00200.setColumn(0, "con4_search2", hngnm);
  11626. ds_send_item5_mech.setColumn(0, "basecd", "");
  11627. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  11628. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", "");
  11629. }
  11630. var ordfromdd = ds_list2_clod.getColumn(row, "ordfromdd");
  11631. var ordtodd = ds_list2_clod.getColumn(row, "ordtodd");
  11632. if (utlf_isValidDateTime(ordfromdd))
  11633. {
  11634. if (!utlf_isValidDateTime(ordtodd))
  11635. {
  11636. ds_list2_clod.setColumn(row, "ordtodd", ordfromdd);
  11637. ds_list2_clod.setColumn(row, "orddd", ordfromdd);
  11638. ordtodd = ordfromdd;
  11639. }
  11640. }
  11641. else
  11642. {
  11643. lf_fCancelClodStatusChng();
  11644. sysf_messageBox("처방시작일 & 종료일은", "I003"); // /처방시작일 & 종료일은 필수입력입니다.
  11645. return;
  11646. }
  11647. var dayno = utlf_getDateInterval(ordfromdd, ordtodd);
  11648. if (dayno < 0)
  11649. {
  11650. sysf_messageBox("처방종료일자가 처방시작일자 보다 이전 날짜", "E008");
  11651. return;
  11652. }
  11653. else if (dayno > 365)
  11654. {
  11655. sysf_messageBox("처방일이 잘못", "E005"); // /처방일이 잘못 선택되었습니다.
  11656. return;
  11657. }
  11658. ds_send_item5_mech.setColumn(0, "indd" , ds_main_item1_clbs.getColumn(0, "indd"));
  11659. ds_send_item5_mech.setColumn(0, "ordfromdd", ordfromdd);
  11660. ds_send_item5_mech.setColumn(0, "ordtodd" , ordfromdd);
  11661. ds_send_item5_mech.setColumn(0, "insukind" , ds_main_item1_clbs.getColumn(0, "insukindcd"));
  11662. ds_send_item5_mech.setColumn(0, "suppkind" , ds_main_item1_clbs.getColumn(0, "suppkindcd"));
  11663. var orddeptcd = ds_list2_clod.getColumn(row, "orddeptcd");
  11664. if (orddeptcd)
  11665. {
  11666. ds_send_item5_mech.setColumn(0, "orddeptcd" , orddeptcd);
  11667. }
  11668. else
  11669. {
  11670. ds_send_item5_mech.setColumn(0, "orddeptcd" , ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  11671. }
  11672. var orddrid = ds_list2_clod.getColumn(row, "orddrid");
  11673. if (orddrid)
  11674. {
  11675. ds_send_item5_mech.setColumn(0, "orddrid" , orddrid);
  11676. }
  11677. else
  11678. {
  11679. ds_send_item5_mech.setColumn(0, "orddrid" , ds_main_item1_clbs.getColumn(0, "orddrid"));
  11680. }
  11681. var drugqty = ds_list2_clod.getColumn(row, "drugqty");
  11682. if (utlf_isNull(drugqty))
  11683. {
  11684. drugqty = "1";
  11685. }
  11686. ds_send_item5_mech.setColumn(0, "drugqty", drugqty);
  11687. var tims = ds_list2_clod.getColumn(row, "tims");
  11688. if (utlf_isNull(tims))
  11689. {
  11690. tims = "1";
  11691. }
  11692. ds_send_item5_mech.setColumn(0, "tims", tims);
  11693. var dayno = ds_list2_clod.getColumn(row, "dayno");
  11694. if (utlf_isNull(dayno))
  11695. {
  11696. dayno = "1";
  11697. }
  11698. ds_send_item5_mech.setColumn(0, "dayno" , dayno);
  11699. ds_send_item5_mech.setColumn(0, "adjtresncd" , ds_list2_clod.getColumn(row, "adjtresncd"));
  11700. ds_send_item5_mech.setColumn(0, "undersixageyn" , ds_main_item1_clbs.getColumn(0, "undersixageyn"));
  11701. ds_send_item5_mech.setColumn(0, "mechage" , ds_main_item1_clbs.getColumn(0, "mechage"));
  11702. ds_send_item5_mech.setColumn(0, "hosinresncd" , ds_list2_clod.getColumn(row, "hosinresncd"));
  11703. ds_send_item5_mech.setColumn(0, "payflag" , ds_list2_clod.getColumn(row, "payflag"));
  11704. ds_send_item5_mech.setColumn(0, "clbsordfromdd" , ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  11705. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  11706. ds_send_item5_mech.setColumn(0, "clamflagcd" , ds_main_item1_clbs.getColumn(0, "clamflagcd"));
  11707. ds_send_item5_mech.setColumn(0, "mode" , "n");
  11708. ds_send_item5_mech.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  11709. ds_send_item5_mech.setColumn(0, "clamdeptcd" , ds_main_item1_clbs.getColumn(0, "clamdeptcd"));
  11710. var clodlength;
  11711. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "hngnm"))
  11712. {
  11713. clodlength = 0;
  11714. } else {
  11715. var oParam = {};
  11716. oParam.id = "TRPID20303";
  11717. oParam.service = "aftjudgapp.InAftJudg";
  11718. oParam.method = "reqGetCalcScorCd";
  11719. oParam.inds = "req=ds_send_item5_mech";
  11720. oParam.outds = "ds_main_item5_mech=mech";
  11721. oParam.async = false;
  11722. //oParam.callback = "cf_TRPID20303";
  11723. tranf_submit(oParam);
  11724. clodlength = ds_main_item5_mech.rowcount;
  11725. }
  11726. if ((clodlength == 0) || (col == grp_biz.grd_clodhist.getBindCellIndex("body", "basecd") && clodlength > 1))
  11727. {
  11728. ds_main_item5_mech.clearData();
  11729. ds_main_item5_mech.addRow();
  11730. var insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  11731. if (insukindcd == "11")
  11732. {
  11733. ds_cond_smpic00200.setColumn(0, "con5_insu", "insu");
  11734. }
  11735. else if (insukindcd == "21" || insukindcd == "22")
  11736. {
  11737. ds_cond_smpic00200.setColumn(0, "con5_insu", "proc");
  11738. }
  11739. else if (insukindcd == "31")
  11740. {
  11741. ds_cond_smpic00200.setColumn(0, "con5_insu", "autm");
  11742. }
  11743. else if (insukindcd == "41")
  11744. {
  11745. ds_cond_smpic00200.setColumn(0, "con5_insu", "indus");
  11746. }
  11747. else
  11748. {
  11749. ds_cond_smpic00200.setColumn(0, "con5_insu", "insu");
  11750. }
  11751. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "grupcalcscorcd"))
  11752. {
  11753. ds_cond_smpic00200.setColumn(0, "con2_gsflag", "G");
  11754. }
  11755. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "snglcalcscorcd"))
  11756. {
  11757. ds_cond_smpic00200.setColumn(0, "con2_gsflag", "S");
  11758. }
  11759. if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "basecd"))
  11760. {
  11761. ds_cond_smpic00200.setColumn(0, "con3_search1", "edicd");
  11762. }
  11763. else if (col == grp_biz.grd_clodhist.getBindCellIndex("body", "hngnm"))
  11764. {
  11765. ds_cond_smpic00200.setColumn(0, "con3_search1", "hngnm");
  11766. }
  11767. else
  11768. {
  11769. ds_cond_smpic00200.setColumn(0, "con3_search1", "calcscorcd");
  11770. }
  11771. if (ordfromdd)
  11772. {
  11773. ds_cond_smpic00200.setColumn(0, "con1_dd", ordfromdd);
  11774. }
  11775. var objArg = new Object();
  11776. objArg.arg_ds_temp = ds_cond_smpic00200;
  11777. ds_rslt_smpic00200.clearData();
  11778. var mechSelect = frmf_modal("SMPIC00200", "SMPIC00200", objArg, "", "", "", "", "", "", "", "", "", "M");
  11779. if (utlf_isNull(mechSelect))
  11780. {
  11781. ds_list2_clod.setColumn(row, "grupcalcscorcd", ds_hidden_item5_clod.getColumn(0, "grupcalcscorcd"));
  11782. ds_list2_clod.setColumn(row, "snglcalcscorcd", ds_hidden_item5_clod.getColumn(0, "snglcalcscorcd"));
  11783. ds_list2_clod.setColumn(row, "basecd" , ds_hidden_item5_clod.getColumn(0, "basecd"));
  11784. sysf_messageBox("수가조회 화면에서 선택한 결과가", "I004");
  11785. return;
  11786. }
  11787. if (ds_temp_picmmech.getColumn(0, "picmmech_ordinptflag") != "A" && ds_temp_picmmech.getColumn(0, "picmmech_ordinptflag") != "I")
  11788. {
  11789. ds_list2_clod.setColumn(row, "grupcalcscorcd", ds_hidden_item5_clod.getColumn(0, "grupcalcscorcd"));
  11790. ds_list2_clod.setColumn(row, "snglcalcscorcd", ds_hidden_item5_clod.getColumn(0, "snglcalcscorcd"));
  11791. ds_list2_clod.setColumn(row, "basecd", ds_hidden_item5_clod.getColumn(0, "basecd"));
  11792. sysf_messageBox("처방이 불가한 코드", "E008"); // /처방이 불가한 코드입니다.
  11793. return;
  11794. }
  11795. if (ds_temp_picmmech.getColumn(0, "picmmech_temp_grupsnglflag") != "S")
  11796. {
  11797. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", ds_temp_picmmech.getColumn(0, "picmmech_calcscorcd"));
  11798. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", "");
  11799. ds_send_item5_mech.setColumn(0, "basecd" , "");
  11800. ds_send_item5_mech.setColumn(0, "estmmncd" , "");
  11801. ds_send_item5_mech.setColumn(0, "ioflag" , ds_main_item1_clbs.getColumn(0, "ioflag"));
  11802. var oParam = {};
  11803. oParam.id = "TRPID20303";
  11804. oParam.service = "aftjudgapp.InAftJudg";
  11805. oParam.method = "reqGetCalcScorCd";
  11806. oParam.inds = "req=ds_send_item5_mech";
  11807. oParam.outds = "ds_main_item5_mech=mech";
  11808. oParam.async = false;
  11809. //oParam.callback = "cf_TRPID20303";
  11810. tranf_submit(oParam);
  11811. }
  11812. else
  11813. {
  11814. ds_send_item5_mech.setColumn(0, "grupcalcscorcd", "");
  11815. ds_send_item5_mech.setColumn(0, "snglcalcscorcd", ds_temp_picmmech.getColumn(0, "picmmech_calcscorcd"));
  11816. ds_send_item5_mech.setColumn(0, "basecd" , "");
  11817. ds_send_item5_mech.setColumn(0, "estmmncd" , "");
  11818. ds_send_item5_mech.setColumn(0, "ioflag" , lgv_ioflag);
  11819. var oParam = {};
  11820. oParam.id = "TRPID20303";
  11821. oParam.service = "aftjudgapp.InAftJudg";
  11822. oParam.method = "reqGetCalcScorCd";
  11823. oParam.inds = "req=ds_send_item5_mech";
  11824. oParam.outds = "ds_main_item5_mech=mech";
  11825. oParam.async = false;
  11826. //oParam.callback = "cf_TRPID20303";
  11827. tranf_submit(oParam);
  11828. }
  11829. }
  11830. if(ds_main_item5_mech.getColumn(0,"leprotamt") > 0){
  11831. grp_leprot.visible = true;
  11832. }
  11833. if(!grp_leprot.visible){
  11834. lf_fSetNewCalcScorCd();
  11835. }
  11836. grp_biz.grd_clodhist.showEditor(false);
  11837. }
  11838. /****************************************************************************************
  11839. * Argument : callback
  11840. * Description : TRPID20331 submid callback 함수
  11841. ****************************************************************************************/
  11842. function cf_TRPID20331(sSvcId, nErrorCode, sErrorMsg)
  11843. {
  11844. if(nErrorCode < 0)
  11845. {
  11846. alert("["+sSvcId+"]"+sErrorMsg);
  11847. return;
  11848. }
  11849. var bfafamtdiff = ds_rslt_bfafamtdiff.rowcount;
  11850. var payamt = ds_rslt_bfafamtdiff.getColumn(0, "payamt");
  11851. var tot12 = ds_rslt_bfafamtdiff.getColumn(0, "tot12");
  11852. var ownbamt = ds_rslt_bfafamtdiff.getColumn(0, "ownbamt");
  11853. var ownb12 = ds_rslt_bfafamtdiff.getColumn(0, "ownb12");
  11854. var insubamt = ds_rslt_bfafamtdiff.getColumn(0, "insubamt");
  11855. var clam12 = ds_rslt_bfafamtdiff.getColumn(0, "clam12");
  11856. var handcapfund = ds_rslt_bfafamtdiff.getColumn(0, "handcapfund");
  11857. var handcap12 = ds_rslt_bfafamtdiff.getColumn(0, "handcap12");
  11858. var procsubtamt = ds_rslt_bfafamtdiff.getColumn(0, "procsubtamt");
  11859. var subt12 = ds_rslt_bfafamtdiff.getColumn(0, "subt12");
  11860. var suppamt = ds_rslt_bfafamtdiff.getColumn(0, "suppamt");
  11861. var supp12 = ds_rslt_bfafamtdiff.getColumn(0, "supp12");
  11862. var max12 = ds_rslt_bfafamtdiff.getColumn(0, "max12");
  11863. var payownblimamt = ds_rslt_bfafamtdiff.getColumn(0, "payownblimamt");
  11864. if (bfafamtdiff > 0 )
  11865. {
  11866. // lf_setAlramMessage("원무사후차액이 10,000원 이상입니다." + "\n" +
  11867. // "원무급여총액:[" + payamt + "] 사후급여총액:[" + tot12 + "]\n" +
  11868. // "원무본인부담액:[" + ownbamt + "] 사후본인부담액:[" + ownb12 + "]\n" +
  11869. // "원무청구액:[" + insubamt + "] 사후청구액:[" + clam12 + "]\n" +
  11870. // "원무장애인금액:[" + handcapfund + "] 사후장애인금액:[" + handcap12 + "]\n" +
  11871. // "원무대불금:[" + procsubtamt + "] 사후대불금:[" + subt12 + "]\n" +
  11872. // "원무지원금:[" + suppamt + "] 사후지원금:[" + supp12 + "]\n" +
  11873. // "원무본인부담상한액:[" + payownblimamt + "] 사후본인부담상한액:[" + max12 + "]\n"
  11874. // + "확인하쉽시오.");
  11875. ds_tmp_difflist.clearData();
  11876. grp_clod00.visible = true;
  11877. grp_clod00.position.x = 343;
  11878. grp_clod00.position.y = 241;
  11879. var arow = ds_tmp_difflist.addRow();
  11880. ds_tmp_difflist.setColumn(arow,"nm", "급여총액");
  11881. ds_tmp_difflist.setColumn(arow,"bf", payamt);
  11882. ds_tmp_difflist.setColumn(arow,"af", tot12);
  11883. arow = ds_tmp_difflist.addRow();
  11884. ds_tmp_difflist.setColumn(arow,"nm", "본인부담액");
  11885. ds_tmp_difflist.setColumn(arow,"bf", ownbamt);
  11886. ds_tmp_difflist.setColumn(arow,"af", ownb12);
  11887. arow = ds_tmp_difflist.addRow();
  11888. ds_tmp_difflist.setColumn(arow,"nm", "청구액");
  11889. ds_tmp_difflist.setColumn(arow,"bf", insubamt);
  11890. ds_tmp_difflist.setColumn(arow,"af", clam12);
  11891. arow = ds_tmp_difflist.addRow();
  11892. ds_tmp_difflist.setColumn(arow,"nm", "장애인금액");
  11893. ds_tmp_difflist.setColumn(arow,"bf", handcapfund);
  11894. ds_tmp_difflist.setColumn(arow,"af", handcap12);
  11895. arow = ds_tmp_difflist.addRow();
  11896. ds_tmp_difflist.setColumn(arow,"nm", "대불금");
  11897. ds_tmp_difflist.setColumn(arow,"bf", procsubtamt);
  11898. ds_tmp_difflist.setColumn(arow,"af", subt12);
  11899. arow = ds_tmp_difflist.addRow();
  11900. ds_tmp_difflist.setColumn(arow,"nm", "지원금");
  11901. ds_tmp_difflist.setColumn(arow,"bf", suppamt);
  11902. ds_tmp_difflist.setColumn(arow,"af", supp12);
  11903. arow = ds_tmp_difflist.addRow();
  11904. ds_tmp_difflist.setColumn(arow,"nm", "본인부담상한액");
  11905. ds_tmp_difflist.setColumn(arow,"bf", payownblimamt);
  11906. ds_tmp_difflist.setColumn(arow,"af", max12);
  11907. }
  11908. }
  11909. function grp_clod00_Button00_onclick(obj:Button, e:ClickEventInfo)
  11910. {
  11911. ds_tmp_difflist.clearData();
  11912. grp_clod00.visible = false;
  11913. }
  11914. /****************************************************************************************
  11915. * Argument :
  11916. * Description : TRPID20332 submid callback 함수
  11917. ****************************************************************************************/
  11918. function cf_TRPID20332(sSvcId, nErrorCode, sErrorMsg)
  11919. {
  11920. if(nErrorCode < 0)
  11921. {
  11922. alert("["+sSvcId+"]"+sErrorMsg);
  11923. return;
  11924. }
  11925. var rsvcnt = ds_list9_trnpt.getColumn(0, "trnptcnt");
  11926. var rsvname = ds_list9_trnpt.getColumn(0, "rsvname");
  11927. var rsvrrgstno = ds_list9_trnpt.getColumn(0, "rsvrrgstno");
  11928. if (rsvcnt > "1")
  11929. {
  11930. lf_setAlramMessage("이식건수가 2건 이상인 공여자입니다 이식 정보를 확인하세요 ");
  11931. }
  11932. if (rsvcnt == "1")
  11933. {
  11934. var msg = sysf_messageBox("공여자입니다 정보를 수혜자로 변경(변경후 저장해야 적용) ", "S001");
  11935. if (msg == "6")
  11936. {
  11937. if (ds_list9_trnpt.rowcount > 0 ) {
  11938. ds_main_item1_clbs.setColumn(0, "patnm", rsvname);
  11939. ds_main_item1_clbs.setColumn(0, "patrrgstno", rsvrrgstno);
  11940. }
  11941. }
  11942. }
  11943. }
  11944. /****************************************************************************************
  11945. * Argument :
  11946. * Description : TRPID20327 submid callback 함수
  11947. ****************************************************************************************/
  11948. function cf_TRPID20327(sSvcId, nErrorCode, sErrorMsg)
  11949. {
  11950. if(nErrorCode < 0) { alert("["+sSvcId+"]"+sErrorMsg); return; }
  11951. lf_fCheckSpclSpecData();
  11952. lf_fSelectSpclRadio();
  11953. }
  11954. /****************************************************************************************
  11955. * Argument : function
  11956. * Description : 환자기준 메세지작성
  11957. ****************************************************************************************/
  11958. function lf_fPatJudgPatMsgTrsm()
  11959. {
  11960. if (!utlf_isNull(ds_main_item1_clbs.getColumn(0, "pid")))
  11961. {
  11962. ds_msgtrsm_info.clearData();
  11963. ds_msgtrsm_info.addRow();
  11964. // 값셋팅
  11965. // 세션값 받기
  11966. var sUserInfosS = sysf_getUserInfos();
  11967. sUserInfosS = sUserInfosS + "|";
  11968. var UserInfosS_Array = sUserInfosS.split("|");
  11969. var userid = UserInfosS_Array[0]; //사용자번호
  11970. var usernm = UserInfosS_Array[1]; //사용자이름
  11971. var posinstcd = UserInfosS_Array[6]; //근무지기관코드 2009.04.15
  11972. var posinstnm = UserInfosS_Array[7]; //근무지기관명 2009.04.15
  11973. var posdeptcd = UserInfosS_Array[4]; //소속부서코드
  11974. var posdeptnm = UserInfosS_Array[5]; //소속부서명
  11975. if (utlf_isNull(userid) || userid == " " || userid == "-") userid = "pam";
  11976. ds_msgtrsm_info.setColumn(0, "instcd" , "");
  11977. ds_msgtrsm_info.setColumn(0, "msgwrtedd" , utlf_getCurrentDate());
  11978. ds_msgtrsm_info.setColumn(0, "msgwrteno" , "");
  11979. ds_msgtrsm_info.setColumn(0, "msgwrtehistno" , "");
  11980. ds_msgtrsm_info.setColumn(0, "histstat" , "Y");
  11981. ds_msgtrsm_info.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  11982. ds_msgtrsm_info.setColumn(0, "orddd" , ds_main_item1_clbs.getColumn(0, "indd"));
  11983. ds_msgtrsm_info.setColumn(0, "cretno" , ds_main_item1_clbs.getColumn(0, "cretno"));
  11984. ds_msgtrsm_info.setColumn(0, "mskind" , "M");
  11985. ds_msgtrsm_info.setColumn(0, "orddeptcd" , ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  11986. var drid = ds_main_item1_clbs.getColumn(0, "orddrid");
  11987. var fRow = ds_init_orddrid2.findRow("cd", drid);
  11988. var drnm = ds_init_orddrid2.getColumn(fRow, "nm");
  11989. ds_msgtrsm_info.setColumn(0, "orddrid", drid); // chk, TABLE에 적용안함.(값만확인)
  11990. ds_msgtrsm_info.setColumn(0, "orddrnm", drnm ); // chk, TABLE에 적용안함.(값만확인)
  11991. ds_msgtrsm_info.setColumn(0, "ordtype" , "O"); // 외래기본 'O', chk
  11992. ds_msgtrsm_info.setColumn(0, "kindflag" , "P"); // 환자기준 'P', chk
  11993. ds_msgtrsm_info.setColumn(0, "grupcalcscorcd", "-");
  11994. ds_msgtrsm_info.setColumn(0, "snglcalcscorcd", "-");
  11995. ds_msgtrsm_info.setColumn(0, "ordqty" , 0);
  11996. ds_msgtrsm_info.setColumn(0, "ordtims" , 0);
  11997. ds_msgtrsm_info.setColumn(0, "orddays" , 0);
  11998. ds_msgtrsm_info.setColumn(0, "prcpdd" , "-");
  11999. ds_msgtrsm_info.setColumn(0, "prcpno" , 0);
  12000. ds_msgtrsm_info.setColumn(0, "prcppayflag" , "-");
  12001. ds_msgtrsm_info.setColumn(0, "rgstrid" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12002. ds_msgtrsm_info.setColumn(0, "rgstdd" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12003. ds_msgtrsm_info.setColumn(0, "rgsttm" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12004. ds_msgtrsm_info.setColumn(0, "sendphone" , ""); // 서버단에서 조회하여 가져와야함. chk
  12005. ds_msgtrsm_info.setColumn(0, "anybodyyn" , "N"); // 누구나 기본 'N', chk
  12006. ds_msgtrsm_info.setColumn(0, "sendflag" , "O"); // 진료기본 'O', chk
  12007. ds_msgtrsm_info.setColumn(0, "senddate" , ""); //쿼리에서 timestamp chk
  12008. ds_msgtrsm_info.setColumn(0, "sendid" , userid); //chk
  12009. ds_msgtrsm_info.setColumn(0, "deliveid" , "-"); // 화면에서선택. chk
  12010. ds_msgtrsm_info.setColumn(0, "recvdate" , ""); // chk
  12011. ds_msgtrsm_info.setColumn(0, "recvid" , ""); // chk
  12012. ds_msgtrsm_info.setColumn(0, "recvcnfmyn" , "N"); // 기본 비연속 'N', chk
  12013. ds_msgtrsm_info.setColumn(0, "recvcnfmid" , userid); //chk
  12014. ds_msgtrsm_info.setColumn(0, "sendmsg" , ""); //sendmsgvalue); // 기본 처방코드, 처방명값가지고 시작. chk
  12015. ds_msgtrsm_info.setColumn(0, "recvmsg" , ""); // chk
  12016. ds_msgtrsm_info.setColumn(0, "fstrgstrid" , ""); // chk
  12017. ds_msgtrsm_info.setColumn(0, "fstrgstdt" , ""); // chk
  12018. ds_msgtrsm_info.setColumn(0, "lastupdtrid" , ""); // chk
  12019. ds_msgtrsm_info.setColumn(0, "lastupdtdt" , ""); // chk
  12020. }
  12021. else
  12022. {
  12023. lf_setAlramMessage("기본정보가 없습니다.");
  12024. }
  12025. var objArg = new Object();
  12026. objArg.sName = this.name;
  12027. var rtn = frmf_modal("SPPIZ01900", "SPPIZ01900", objArg, "", "", "", "", "", "", "", "", "", "M");// SPPIZ01900_심사환자메세지작성
  12028. if (!utlf_isNull(rtn)) {
  12029. img_msg.visible = true;
  12030. }
  12031. }
  12032. /****************************************************************************************
  12033. * Argument : function
  12034. * Description : 처방기준 전송메세지작성
  12035. ****************************************************************************************/
  12036. function lf_fOrderJudgPatMsgTrsm()
  12037. {
  12038. if (!utlf_isNull(ds_main_item1_clbs.getColumn(0, "pid")))
  12039. {
  12040. ds_msgtrsm_info.clearData();
  12041. ds_msgtrsm_info.addRow();
  12042. // 값셋팅
  12043. // 처방이므로 처방row선택여부 확인
  12044. if(ds_list2_clod.rowcount < 0)
  12045. {
  12046. return;
  12047. }
  12048. // 세션값 받기
  12049. var sUserInfosS = sysf_getUserInfos();
  12050. sUserInfosS = sUserInfosS + "|";
  12051. var UserInfosS_Array = sUserInfosS.split("|");
  12052. var userid = UserInfosS_Array[0]; //사용자번호
  12053. var usernm = UserInfosS_Array[1]; //사용자이름
  12054. var posinstcd = UserInfosS_Array[6]; //근무지기관코드 2009.04.15
  12055. var posinstnm = UserInfosS_Array[7]; //근무지기관명 2009.04.15
  12056. var posdeptcd = UserInfosS_Array[4]; //소속부서코드
  12057. var posdeptnm = UserInfosS_Array[5]; //소속부서명
  12058. if (utlf_isNull(userid) || userid == " " || userid == "-")
  12059. {
  12060. userid = "pam";
  12061. }
  12062. ds_msgtrsm_info.setColumn(0, "instcd" , "");
  12063. ds_msgtrsm_info.setColumn(0, "msgwrtedd" , utlf_getCurrentDate());
  12064. ds_msgtrsm_info.setColumn(0, "msgwrteno" , "");
  12065. ds_msgtrsm_info.setColumn(0, "msgwrtehistno" , "");
  12066. ds_msgtrsm_info.setColumn(0, "histstat" , "Y");
  12067. ds_msgtrsm_info.setColumn(0, "pid" , ds_main_item1_clbs.getColumn(0, "pid"));
  12068. ds_msgtrsm_info.setColumn(0, "orddd" , ds_main_item1_clbs.getColumn(0, "indd"));
  12069. ds_msgtrsm_info.setColumn(0, "cretno" , ds_main_item1_clbs.getColumn(0, "cretno"));
  12070. ds_msgtrsm_info.setColumn(0, "mskind" , "M");
  12071. ds_msgtrsm_info.setColumn(0, "orddeptcd" , ds_main_item1_clbs.getColumn(0, "orddeptcd"));
  12072. var drid = ds_main_item1_clbs.getColumn(0, "orddrid");
  12073. var fRow = ds_init_orddrid2.findRow("cd", drid);
  12074. var drnm = ds_init_orddrid2.getColumn(fRow, "nm");
  12075. ds_msgtrsm_info.setColumn(0, "orddrid" , ds_main_item1_clbs.getColumn(0, "orddrid")); // chk, TABLE에 적용안함.(값만확인)
  12076. ds_msgtrsm_info.setColumn(0, "orddrnm" , drnm); // chk, TABLE에 적용안함.(값만확인)
  12077. ds_msgtrsm_info.setColumn(0, "ordtype" , "O"); // 외래기본 'O', chk
  12078. ds_msgtrsm_info.setColumn(0, "kindflag" , "O");
  12079. ds_msgtrsm_info.setColumn(0, "grupcalcscorcd", ds_list2_clod.getColumn(ds_list2_clod.rowposition, "grupcalcscorcd"));
  12080. ds_msgtrsm_info.setColumn(0, "snglcalcscorcd", ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd"));
  12081. ds_msgtrsm_info.setColumn(0, "ordqty" , ds_list2_clod.getColumn(ds_list2_clod.rowposition, "drugqty"));
  12082. ds_msgtrsm_info.setColumn(0, "ordtims" , ds_list2_clod.getColumn(ds_list2_clod.rowposition, "tims"));
  12083. ds_msgtrsm_info.setColumn(0, "orddays" , ds_list2_clod.getColumn(ds_list2_clod.rowposition, "dayno"));
  12084. ds_msgtrsm_info.setColumn(0, "prcpdd" , "");
  12085. ds_msgtrsm_info.setColumn(0, "prcpno" , "");
  12086. ds_msgtrsm_info.setColumn(0, "prcppayflag" , ds_list2_clod.getColumn(ds_list2_clod.rowposition, "payflag"));
  12087. ds_msgtrsm_info.setColumn(0, "rgstrid" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12088. ds_msgtrsm_info.setColumn(0, "rgstdd" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12089. ds_msgtrsm_info.setColumn(0, "rgsttm" , "-"); // 서버단에서 조회하여 가져와야함. chk
  12090. ds_msgtrsm_info.setColumn(0, "sendphone" , ""); // 서버단에서 조회하여 가져와야함. chk
  12091. ds_msgtrsm_info.setColumn(0, "anybodyyn" , "N"); // 누구나 기본 'N', chk
  12092. ds_msgtrsm_info.setColumn(0, "sendflag" , "O"); // 진료기본 'O', chk
  12093. ds_msgtrsm_info.setColumn(0, "senddate" , ""); //쿼리에서 timestamp chk
  12094. ds_msgtrsm_info.setColumn(0, "sendid" , userid); //chk
  12095. ds_msgtrsm_info.setColumn(0, "deliveid" , "-"); // 화면에서선택. chk
  12096. ds_msgtrsm_info.setColumn(0, "recvdate" , ""); // chk
  12097. ds_msgtrsm_info.setColumn(0, "recvid" , ""); // chk
  12098. ds_msgtrsm_info.setColumn(0, "recvcnfmyn" , "N"); // 기본 비연속 'N', chk
  12099. ds_msgtrsm_info.setColumn(0, "recvcnfmid" , userid); //chk
  12100. ds_msgtrsm_info.setColumn(0, "sendmsg" , ""); //sendmsgvalue); // 기본 처방코드, 처방명값가지고 시작. chk
  12101. ds_msgtrsm_info.setColumn(0, "recvmsg" , ""); // chk
  12102. ds_msgtrsm_info.setColumn(0, "fstrgstrid" , ""); // chk
  12103. ds_msgtrsm_info.setColumn(0, "fstrgstdt" , ""); // chk
  12104. ds_msgtrsm_info.setColumn(0, "lastupdtrid" , ""); // chk
  12105. ds_msgtrsm_info.setColumn(0, "lastupdtdt" , ""); // chk
  12106. }
  12107. else
  12108. {
  12109. lf_setAlramMessage("기본정보가 없습니다.");
  12110. }
  12111. var objArg = new Object();
  12112. objArg.sName = this.name;
  12113. var rtn = frmf_modal("SPPIZ01900", "SPPIZ01900", objArg, "", "", "", "", "", "", "", "", "", "M");// SPPIZ01900_심사환자메세지작성
  12114. if (!utlf_isNull(rtn)) {
  12115. img_msg.visible = true;
  12116. }
  12117. }
  12118. /****************************************************************************************
  12119. * Argument : function
  12120. * Description : 약품편람 이벤트 함수
  12121. ****************************************************************************************/
  12122. function lf_fOrderDrugHBook()
  12123. {
  12124. var sInDsnm = dsf_createDsRow("ds_cond_SMADB01900", [
  12125. {col:"srchdrugcd", type:"STRING", size:256, val:ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd")}
  12126. ]);
  12127. var objArg = new Object();
  12128. objArg.arg_ds_hidden_receivedata = eval(sInDsnm);
  12129. var rtn = frmf_open("SMADB01900", "SMADB01900", objArg, "", "", "", "", "", "", "", "", "", "M");
  12130. dsf_deleteDs(sInDsnm)
  12131. }
  12132. /****************************************************************************************
  12133. * Argument : function
  12134. * Description : 수가조회 이벤트 함수
  12135. ****************************************************************************************/
  12136. function lf_fOrderCalcScorSrch(isAll)
  12137. {
  12138. frmf_setParameter("calcscorcd", ds_list2_clod.getColumn(ds_list2_clod.rowposition, "snglcalcscorcd"));
  12139. frmf_setParameter("judgflag", "Y" );
  12140. var trgtManWindow = frmf_getChildWindow("SMPIC00100");
  12141. if (utlf_isNull(trgtManWindow))
  12142. {
  12143. frmf_open("SMPIC00100", "SMPIC00100", "", "", "", "", "", "", "", "", "", "", "M");
  12144. } else {
  12145. trgtManWindow.fPopupMode();
  12146. }
  12147. }
  12148. /****************************************************************************************
  12149. * Argument : oncellclick
  12150. * Description : 상단 버튼 탭
  12151. ****************************************************************************************/
  12152. function grp_dropdownmenu_grd_popup_oncellclick(obj:Grid, e:GridClickEventInfo)
  12153. {
  12154. // 바인드된 Dataset의 Row
  12155. var nCrow = obj.getTreeChildRow(ds_popup.rowposition, 0);
  12156. if (nCrow >= 0)
  12157. {
  12158. var nGrow = obj.getTreeRow(ds_popup.rowposition);
  12159. //보여지지 않는 Row인지 확인
  12160. if (obj.isTreeCollapsedRow(nCrow))
  12161. {
  12162. obj.setTreeStatus(nGrow, true);
  12163. }
  12164. else
  12165. {
  12166. obj.setTreeStatus(nGrow, false);
  12167. }
  12168. }
  12169. var trgtWindow = ds_popup.getColumn(e.row, "popupid");
  12170. frmf_setParameter("pid", ds_main_item1_clbs.getColumn(0, "pid"));
  12171. if (trgtWindow == "SMMRI00400"){
  12172. fOpenSMMRI00400(ds_main_item1_clbs.getColumn(0, "pid"));
  12173. } else if(trgtWindow == "SMMNR02500"){
  12174. frmf_setParameter("SMMNR02500_pid", "");
  12175. frmf_setParameter("SMMNR02500_dschdd", "");
  12176. frmf_setParameter("SMMNR02500_wardcd", "");
  12177. frmf_open("SMMNR02500", "SMMNR02500", null, null, null, null, null, null, null, null, null, null, "M");
  12178. } else if(trgtWindow == "SMAEA00300"){
  12179. var objArg = new Object();
  12180. objArg.sArg01 = ds_main_item1_clbs.getColumn(0, "pid");
  12181. objArg.sArg02 = ds_main_item1_clbs.getColumn(0, "patnm");
  12182. frmf_open(trgtWindow, trgtWindow, objArg, null, null, null, null, null, null, null, null, null, "M");
  12183. } else {
  12184. frmf_open(trgtWindow, trgtWindow, null, null, null, null, null, null, null, null, null, null, "M");
  12185. }
  12186. }
  12187. /****************************************************************************************
  12188. * Argument : submit
  12189. * Description : TRPID20322
  12190. ****************************************************************************************/
  12191. function cf_TRPID20322(sSvcId, nErrorCode, sErrorMsg)
  12192. {
  12193. if(nErrorCode < 0) { alert("["+sSvcId+"]"+sErrorMsg); return; }
  12194. else
  12195. {
  12196. }
  12197. }
  12198. /****************************************************************************************
  12199. * Argument : radio
  12200. * Description : 원외처방 라디오 버튼 이벤트
  12201. ****************************************************************************************/
  12202. function grp_biz_rdo_cloppayflag_onitemchanged(obj:Radio, e:ItemChangeEventInfo)
  12203. {
  12204. var selectedRdoPay = obj.value;
  12205. if (selectedRdoPay == "0" || selectedRdoPay == "1")
  12206. {
  12207. ds_list7_clop.filterstr = "payflag == '"+selectedRdoPay+"'";
  12208. }
  12209. else
  12210. {
  12211. ds_list7_clop.filterstr = "";
  12212. }
  12213. }
  12214. function grp_biz_grd_clodhist_onlbuttonup(obj:Grid, e:GridMouseEventInfo)
  12215. {
  12216. if ( e.col == obj.getBindCellIndex("body", "hosinresncd"))
  12217. {
  12218. // '원내사유코드' 필드
  12219. lf_fSetHosInResnCd();
  12220. }
  12221. }
  12222. function btn_spclup_onclick(obj:Button, e:ClickEventInfo)
  12223. {
  12224. if(obj.visible) {
  12225. grp_biz.btn_spcldown.visible = true;
  12226. obj.visible = false;
  12227. } else {
  12228. obj.visible = false;
  12229. }
  12230. grp_biz.swt_spclmemo.bringToFront();
  12231. grp_biz.btn_spclup.bringToFront();
  12232. grp_biz.btn_spcldown.bringToFront();
  12233. grp_biz.swt_spclmemo.position.height = swt_spclmemo_cheight;
  12234. grp_biz.btn_preresncd.bringToFront();
  12235. grp_biz.opt_preresncdnm.bringToFront();
  12236. grp_biz.btn_mt0004.bringToFront();
  12237. grp_biz.btn_memohist.bringToFront();
  12238. grp_biz.btn_attData.bringToFront();
  12239. grp_biz.opt_preresncd.bringToFront();
  12240. }
  12241. function btn_spcldown_onclick(obj:Button, e:ClickEventInfo)
  12242. {
  12243. if(obj.visible) {
  12244. grp_biz.btn_spclup.visible = true;
  12245. obj.visible = false;
  12246. } else {
  12247. obj.visible = false;
  12248. }
  12249. grp_biz.swt_spclmemo.bringToFront();
  12250. grp_biz.swt_spclmemo.position.height = 500;
  12251. grp_biz.btn_spclup.bringToFront();
  12252. grp_biz.btn_spcldown.bringToFront();
  12253. grp_biz.btn_preresncd.bringToFront();
  12254. grp_biz.opt_preresncdnm.bringToFront();
  12255. grp_biz.btn_mt0004.bringToFront();
  12256. grp_biz.btn_memohist.bringToFront();
  12257. grp_biz.btn_attData.bringToFront();
  12258. grp_biz.opt_preresncd.bringToFront();
  12259. }
  12260. function grp_biz_grd_cldihist_onchar(obj:Grid, e:GridEditCharEventInfo)
  12261. {
  12262. var cur_row = obj.currentrow;
  12263. ds_hidden_list1_cldi.setColumn(0, "oldseq", ds_list1_cldi.getColumn(cur_row, "diagseq"));
  12264. ds_hidden_list1_cldi.setColumn(0, "olddiagcd", ds_list1_cldi.getColumn(cur_row, "diagcd"));
  12265. ds_hidden_list1_cldi.setColumn(0, "olddiagnm", ds_list1_cldi.getColumn(cur_row, "diagnm"));
  12266. ds_hidden_list1_cldi.setColumn(0, "oldengnm", ds_list1_cldi.getColumn(cur_row, "diagengnm"));
  12267. ds_hidden_list1_cldi.setColumn(0, "oldrowstat", ds_list1_cldi.getRowType(cur_row));
  12268. ds_hidden_list1_cldi.setColumn(0, "oldordfromdd", ds_list1_cldi.getColumn(cur_row, "ordfromdd"));
  12269. }
  12270. function grp_biz_button5_onclick(obj:Button, e:ClickEventInfo)
  12271. {
  12272. fSaveSetInfo();
  12273. }
  12274. function fSaveSetInfo(){
  12275. grdf_SaveOrderInfoOfCol(grp_biz.grd_cldihist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  12276. grdf_SaveOrderInfoOfCol(grp_biz.grd_clodhist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  12277. grdf_SaveOrderInfoOfCol(grp_biz.grd_oprcphist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  12278. grdf_SaveOrderInfoOfCol(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  12279. grdf_GetUuee("ds_send_listval_uuee", "ds_hidden_listval_uuee",frmf_getScreenID(), "cf_Uuee_"+frmf_getScreenID());
  12280. }
  12281. function cf_TXPID20301(sSvcId, nErrorCode, sErrorMsg) {
  12282. arErrorCode.push(sSvcId, nErrorCode);
  12283. }
  12284. function fSetTextSpclJudgOrder(clopseqno,clopyn)
  12285. {
  12286. var ctext = "";
  12287. if (clopyn=="Y"){
  12288. ctext = " && clsoyn=='Y'";
  12289. }
  12290. if (ds_list3_clsp.findRowExpr("spclcd != 'JT001' && ds_list3_clsp.getRowType(currow) != 8 && clodseqno=='"+clopseqno+"'" + ctext) > -1 )
  12291. {
  12292. return "*";
  12293. }
  12294. else {
  12295. return "";
  12296. }
  12297. }
  12298. function lf_tooltipSet(grdObj, currow, curcell)
  12299. {
  12300. if(currow > -1 && curcell > 0)
  12301. {
  12302. grdObj.tooltiptext = grdObj.getCellText(currow, curcell);
  12303. }
  12304. else
  12305. {
  12306. grdObj.tooltiptext = "";
  12307. }
  12308. }
  12309. function grp_biz_grd_oprcphist_onmousemove(obj:Grid, e:GridMouseEventInfo){
  12310. if ( e.col == obj.getBindCellIndex("body", "adjtresncd")) {
  12311. // '심사사유' 필드
  12312. var adjtresncd = ds_list7_clop.getColumn(e.row, "adjtresncd");
  12313. if ( !utlf_isNull(adjtresncd) && adjtresncd != "-" ) {
  12314. lf_fSetAdjtResnCdClop();
  12315. }
  12316. }
  12317. if ( e.col == obj.getBindCellIndex("body", "spclspecyn")) {
  12318. obj.tooltiptext = obj.getCellText(e.row, obj.getBindCellIndex("body", "lnunitspclspec"));
  12319. } else {
  12320. obj.tooltiptext = "";
  12321. }
  12322. }
  12323. function grp_biz_grd_oprcphist_onkeydown(obj:Grid, e:KeyEventInfo)
  12324. {
  12325. if (e.ctrlKey && e.keycode == 67 ) {
  12326. system.setClipboard("CF_TEXT", obj.getCellText(obj.currentrow, obj.currentcol));
  12327. }
  12328. }
  12329. function grp_biz_grd_clodhist_onmousemove(obj:Grid, e:GridMouseEventInfo)
  12330. {
  12331. if ( e.col == obj.getBindCellIndex("body", "lnunitspclspecyn")){
  12332. obj.tooltiptext = eval(obj.binddataset).getColumn(e.row, "lnunitspclspec");
  12333. } else if (e.col == obj.getBindCellIndex("body", "cnfmcd") || e.col == obj.getBindCellIndex("body", "toot1") || e.col == obj.getBindCellIndex("body", "toot")){
  12334. lf_tooltipSet(obj, e.row, e.cell);
  12335. } else if( (!utlf_isNull(eval(obj.binddataset).getColumn(e.row, "estmcls")) && !utlf_isNull(eval(obj.binddataset).getColumn(e.row, "estmmncd")) && !utlf_isNull(eval(obj.binddataset).getColumn(e.row, "estmcdnm"))) && (e.col == obj.getBindCellIndex("body", "estmcd") || e.col == obj.getBindCellIndex("body", "estmmncd"))){
  12336. obj.tooltiptext = '[산정의미코드: ' + eval(obj.binddataset).getColumn(e.row, "estmmncd") + '] ' + eval(obj.binddataset).getColumn(e.row, "estmcdnm")
  12337. } else {
  12338. obj.tooltiptext = "";
  12339. }
  12340. }
  12341. function grp_biz_grd_oprcphist_oncellclick(obj:Grid, e:GridClickEventInfo){
  12342. var row = e.row;
  12343. ds_hidden_list7_clop.setColumn(0, "oldclopdd", ds_list7_clop.getColumn(row, "clopdd"));
  12344. ds_hidden_list7_clop.setColumn(0, "oldclopno", ds_list7_clop.getColumn(row, "clopno"));
  12345. ds_hidden_list7_clop.setColumn(0, "oldrowstatus", ds_list7_clop.getRowType(row));
  12346. ds_hidden_list7_clop.setColumn(0, "oldsnglcalcscorcd", ds_list7_clop.getColumn(row, "snglcalcscorcd"));
  12347. ds_hidden_list7_clop.setColumn(0, "oldedicd", ds_list7_clop.getColumn(row, "edicd"));
  12348. ds_hidden_list7_clop.setColumn(0, "oldedidrugqty", ds_list7_clop.getColumn(row, "edidrugqty"));
  12349. ds_hidden_list7_clop.setColumn(0, "olddrugtims", ds_list7_clop.getColumn(row, "drugtims"));
  12350. ds_hidden_list7_clop.setColumn(0, "oldedidrugdayno", ds_list7_clop.getColumn(row, "edidrugdayno"));
  12351. }
  12352. /****************************************************************************************
  12353. * Argument : function
  12354. * Description :
  12355. 1. 중증/산정특례 상병 체크- 상병 화면 주상병(no=1)의 MT002에 V Code 있으면 중증/산정특례 V252, V027은 제외
  12356. 2. 특정내역에 MT002 체크 - 중증/산정특례 특정기호 관련 특정내역
  12357. 3. 특정내역에 MT014 체크 - 중증/산정특례 자격 번호 관련 특정내역
  12358. //주상병이 v252이고 특정내역에 ct002코드가 없을때 발생 2012.07.05 plet2
  12359. //특정내역이 ct002이고 주상병에 v252코드가 없을때 발생 2012.07.05 plet2
  12360. //불완전상병체크
  12361. ****************************************************************************************/
  12362. function lf_fGetDiagSpclcdCheck()
  12363. {
  12364. var chk_vcode = ds_list1_cldi.lookup("diagseq", "1", "vcode");
  12365. var chk_vcodeR = ds_list1_cldi.lookupExpr("diagseq == '1' && diagkindcd != 'R'", "vcode");
  12366. var chk_CT002 = ds_list3_clsp.lookupExpr("spclcd == 'CT002' && rowstat != 'D'", "spclcd");
  12367. var chk_MT002 = ds_list3_clsp.lookupExpr("spclcd == 'MT002' && rowstat != 'D'", "spclcd");
  12368. var chk_F = ds_list3_clsp.lookupExpr("spclcd == 'MT002' && String(spclspec).indexOf('F') >= 0 && rowstat != 'D'", "spclcd");
  12369. var chk_V001 = ds_list3_clsp.lookupExpr("spclcd == 'MT002' && spclspec == 'V001' && rowstat != 'D'", "spclspec");
  12370. var chk_V008 = ds_list3_clsp.lookupExpr("spclcd == 'MT002' && spclspec == 'V008' && rowstat != 'D'", "spclcd");
  12371. var chk_MT014 = ds_list3_clsp.lookupExpr("spclcd == 'MT014' && rowstat != 'D'", "spclcd");
  12372. var kcd6chk = ds_list1_cldi.lookupExpr("kcd6chk == 'Y' && rowstat != 'U'", "kcd6chk"); // 불완전상병체크
  12373. var snglcalcscorcdcnt = ds_list7_clop.rowcount;
  12374. var chk_396 = ds_list7_clop.lookup("efcyclscd", "396", "efcyclscd");
  12375. var chk_insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  12376. var chk_suppkindcd = ds_main_item1_clbs.getColumn(0, "suppkindcd");
  12377. var chk_diagcd = ds_main_item1_clbs.lookup("diagseq", "1", "diagcd");
  12378. var chk_diagcdR = ds_main_item1_clbs.lookupExpr("diagseq == '1' && diagkindcd != 'R'", "diagcd");
  12379. var chk_pid = ds_main_item1_clbs.getColumn(0, "pid");
  12380. var chk_ioflag = ds_main_item1_clbs.getColumn(0, "ioflag");
  12381. var chk_ordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  12382. var chk_clamym = ds_main_item1_clbs.getColumn(0, "clamym");
  12383. var chk_clamdg = ds_main_item1_clbs.getColumn(0, "clamdg");
  12384. var chk_pidsn = ds_main_item1_clbs.getColumn(0, "pidsn");
  12385. var chk_O3420 = ds_main_item1_clbs.lookup("diagcd", "O3420", "diagcd");
  12386. var chk_JT005 = ds_list3_clsp.lookupExpr("spclcd == 'JT005' && rowstat != 'D'", "spclspec");
  12387. var chk_MS004 = ds_list3_clsp.lookupExpr("spclcd == 'MS004' && rowstat != 'D'", "spclspec");
  12388. var chk_O365 = ds_main_item1_clbs.lookupExpr("diagcd == 'O365' && diagcd != 'O366'", "diagcd");
  12389. var chk_rareobstflag = ds_main_item1_clbs.lookupExpr("suppamt > 0 && rareobstflag=='L'", "rareobstflag");
  12390. var cnt_MT002 = ds_list3_clsp.getCaseCount("spclcd=='MT002' && rowstat !='D' && spclspec!='V206' && spclspec!='V246' && spclspec!='V231' && spclspec!='F008'");
  12391. var chk_orddeptcd = ds_main_item1_clbs.getColumn(0, "orddeptcd");
  12392. var result = true;
  12393. if (chk_vcodeR != "V252" && chk_vcodeR != "V027" && chk_vcodeR != "V191" && chk_vcodeR != "V192")
  12394. {
  12395. if((utlf_isNull(chk_MT002) || utlf_isNull(chk_MT014)) && !utlf_isNull(chk_vcodeR))
  12396. {
  12397. if ((chk_diagcdR >= "N180" && chk_diagcdR <= "N189") && chk_V001 == "V001" && utlf_isNull(chk_MT014))
  12398. {
  12399. if(sysf_messageBox("주상병과 특정내역이 일치 하지 않습니다.!! (중증/산정특례)", "Q003") == 6)
  12400. {
  12401. result = true;
  12402. }
  12403. else
  12404. {
  12405. result = false;
  12406. }
  12407. }
  12408. else
  12409. {
  12410. if ((chk_vcodeR == "V103") || (chk_insukindcd == "21" || chk_insukindcd == "22" )|| (chk_insukindcd == "11" && (chk_suppkindcd == "32" || chk_suppkindcd == "33" || chk_suppkindcd == "60" || chk_suppkindcd == "88"))|| chk_suppkindcd == "00")
  12411. {
  12412. result = true;
  12413. }
  12414. else
  12415. {
  12416. if(sysf_messageBox("주상병과 특정내역이 일치 하지 않습니다.!! (중증/산정특례).", "Q003") == 6)
  12417. {
  12418. result = true;
  12419. }
  12420. else
  12421. {
  12422. result = false;
  12423. }
  12424. }
  12425. }
  12426. }
  12427. else if ((!utlf_isNull(chk_MT002) || !utlf_isNull(chk_MT014)) && utlf_isNull(chk_vcodeR))
  12428. {
  12429. if (!utlf_isNull(chk_F) || chk_V008)
  12430. {
  12431. result = true;
  12432. }
  12433. else
  12434. {
  12435. if (((!utlf_isNull(chk_MT002) || !utlf_isNull(chk_MT014)) && utlf_isNull(chk_vcodeR) && !((chk_insukindcd == "21" || chk_insukindcd == "22" ) && chk_suppkindcd == "00" )) || ((utlf_isNull(chk_MT002) || utlf_isNull(chk_MT014)) && !utlf_isNull(chk_vcodeR)))
  12436. {
  12437. if(sysf_messageBox("주상병과 특정내역이 일치 하지 않습니다.!! (중증/산정특례),", "Q003") == 6)
  12438. {
  12439. result = true;
  12440. }
  12441. else
  12442. {
  12443. result = false;
  12444. }
  12445. }
  12446. }
  12447. }
  12448. else if (chk_vcodeR == "V103" && utlf_isNull(chk_MT002))
  12449. {
  12450. if(sysf_messageBox("주상병과 특정내역이 일치 하지 않습니다.!! (중증/산정특례)...", "Q003") == 6)
  12451. {
  12452. result = true;
  12453. }
  12454. else
  12455. {
  12456. result = false;
  12457. }
  12458. }
  12459. else if (!utlf_isNull(chk_vcodeR) && chk_rareobstflag == "L" && cnt_MT002 > "0" )
  12460. {
  12461. if(sysf_messageBox("결핵환자는 결핵관련 특정기호(MT002) 이외에는 기재 할 수 없습니다.", "Q003") == 6)
  12462. {
  12463. result = true;
  12464. }
  12465. else
  12466. {
  12467. result = false;
  12468. }
  12469. }
  12470. }
  12471. if ((chk_vcodeR == "V252" && utlf_isNull(chk_CT002) && snglcalcscorcdcnt > 0 && (chk_insukindcd == "11" && chk_suppkindcd == "00")) || (chk_vcodeR != "V252" && !utlf_isNull(chk_CT002) && snglcalcscorcdcnt > 0 && (chk_insukindcd == "11" && chk_suppkindcd == "00")))
  12472. {
  12473. if ((chk_diagcdR >= "E10" && chk_diagcdR <= "E149") && chk_396 != "396")
  12474. {
  12475. if(sysf_messageBox("주상병과 특정내역이 일치 하지 않습니다.!! (경증)", "Q003") == 6)
  12476. {
  12477. result = true;
  12478. }
  12479. else
  12480. {
  12481. result = false;
  12482. }
  12483. }
  12484. }
  12485. if (kcd6chk == "Y")
  12486. {
  12487. if(sysf_messageBox("불완전상병이 존재 합니다.", "Q003") == 6)
  12488. {
  12489. result = true;
  12490. }
  12491. else
  12492. {
  12493. result = false;
  12494. }
  12495. }
  12496. if (utlf_transNullToEmpty(chk_vcodeR).length > 0)
  12497. {
  12498. dsf_createDsRow("ds_send_chksuppkindflag_cond", [{ col: "diagcd", type: "string", size: 256, val: chk_diagcdR}
  12499. , { col: "spclcd", type: "string", size: 256, val: chk_vcodeR}
  12500. , { col: "ioflag", type: "string", size: 256, val: chk_ioflag}
  12501. , { col: "ordfromdd", type: "string", size: 256, val: chk_ordfromdd}
  12502. , { col: "clamym", type: "string", size: 256, val: chk_clamym}
  12503. , { col: "clamdg", type: "string", size: 256, val: chk_clamdg}
  12504. , { col: "pidsn", type: "string", size: 256, val: chk_clamdg}
  12505. , { col: "pid", type: "string", size: 256, val: chk_pid}
  12506. , { col: "insukindcd", type: "string", size: 256, val: chk_insukindcd}]);
  12507. dsf_createDs("ds_hidden_chksuppkindflag_rslt", [{ col: "chksuppkindflag", type: "string", size: 256}]);
  12508. var oParam = {};
  12509. oParam.id = "TRPID20313";
  12510. oParam.service = "aftjudgapp.InAftJudg";
  12511. oParam.method = "reqGetChkSuppkindFlag";
  12512. oParam.inds = "req=ds_send_chksuppkindflag_cond";
  12513. oParam.outds = "ds_hidden_chksuppkindflag_rslt=rslt";
  12514. oParam.async = false;
  12515. //oParam.callback = "cf_TRPID20313";
  12516. tranf_submit(oParam);
  12517. var chksuppkindflag = ds_hidden_chksuppkindflag_rslt.getColumn(0, "chksuppkindflag");
  12518. if (!utlf_isNull(chksuppkindflag) && chksuppkindflag != chk_suppkindcd && !utlf_isNull(chk_diagcdR) && chk_suppkindcd != "00" )
  12519. {
  12520. if(sysf_messageBox("주상병과 보조유형이 일치 하지 않습니다.", "Q003") == 6)
  12521. {
  12522. result = true;
  12523. }
  12524. else
  12525. {
  12526. result = false;
  12527. }
  12528. }
  12529. }
  12530. if (chk_diagcd == "O820" && utlf_transNullToEmpty(chk_O3420).length == 0 )
  12531. {
  12532. if(sysf_messageBox("반복제왕절개 환자입니다.", "Q003") == 6)
  12533. {
  12534. result = true;
  12535. }
  12536. else
  12537. {
  12538. var ans = sysf_messageBox("O3420 상병을 입력" , "S001");
  12539. if (ans == 6)
  12540. {
  12541. grp_biz.grd_cldihist.setFocus();
  12542. lf_fDiagGridInsertRow("Y", "N");
  12543. var maxseq = ds_main_item1_clbs.getMax("diagseq"); // var maxseq = model.getXPathValue("max(/root/main/list1/cldi[*]/diagseq)");
  12544. ds_main_item1_clbs.setColumn(maxseq, "diagcd", "O3420"); //model.setValue("/root/main/list1/cldi[diagseq='"+maxseq+"']/diagcd","O3420");
  12545. ds_main_item1_clbs.setColumn(maxseq, "diagnm", "이전의 제왕절개로 인한 흉터의 산모 관리"); //model.setValue("/root/main/list1/cldi[diagseq='"+maxseq+"']/diagnm","이전의 제왕절개로 인한 흉터의 산모 관리");
  12546. }
  12547. result = false;
  12548. }
  12549. }
  12550. if (utlf_transNullToEmpty(chk_JT005).length > 0 && utlf_transNullToEmpty(chk_MS004).length > 0)
  12551. {
  12552. var nwbabyweight = parseInt(chk_MS004);
  12553. var minweight = parseInt(ds_rslt_nbwt.lookup("prgntweek", chk_JT005, "minweight")); //getValue("/root/main/nbwt/nbwtlist[prgntweek='"+chk_JT005+"']/minweight"));
  12554. var maxweight = parseInt(ds_rslt_nbwt.lookup("prgntweek", chk_JT005, "maxweight")); //getValue("/root/main/nbwt/nbwtlist[prgntweek='"+chk_JT005+"']/maxweight"));
  12555. if (utlf_transNullToEmpty(chk_O365).length == 0 && (nwbabyweight <= minweight || nwbabyweight >= maxweight ))
  12556. {
  12557. if(sysf_messageBox("신생아 체중관련 상병누락 환자입니다.", "Q003") == 6)
  12558. {
  12559. result = true;
  12560. }
  12561. else
  12562. {
  12563. result = false;
  12564. }
  12565. }
  12566. }
  12567. var clbs_licnsno = ds_main_item1_clbs.getColumn(0, "licnsno");
  12568. var cldi_licnsno = ds_list1_cldi.lookup("diagseq", "1", "licnsno");
  12569. var clod_licnsno = ds_list2_clod.lookupExpr("item == '0101' || item == '0102'", "licnsno"); //getValue("/root/main/list2/clod[item='0101' or item='0102']/licnsno");
  12570. var clod_snglcalcscorcd = ds_list2_clod.lookupExpr("item == '0101' || item == '0102'", "snglcalcscorcd"); //model.getValue("/root/main/list2/clod[item='0101' or item='0102']/snglcalcscorcd");
  12571. if(clbs_licnsno != cldi_licnsno && ds_list1_cldi.getRowType(0) != 2)
  12572. {
  12573. var arrRow = new Array();
  12574. arrRow[0] = 0;
  12575. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  12576. }
  12577. // if (clbs_licnsno != clod_licnsno && ds_list2_clod.getRowType(0) != 2)
  12578. // {
  12579. // var arrRow = new Array();
  12580. // arrRow[0] = ds_list2_clod.findRow("snglcalcscorcd", clod_snglcalcscorcd);
  12581. //
  12582. // grdf_setStatus(grp_biz.grd_clodhist, "U", arrRow);
  12583. // }
  12584. var holigbn = ds_rslt_aftjudgbtn.getColumn(0, "holigbn");
  12585. var holifromdd = ds_rslt_aftjudgbtn.getColumn(0, "holifromdd");
  12586. var holitodd = ds_rslt_aftjudgbtn.getColumn(0, "holitodd");
  12587. if(holigbn == "Y" && utlf_transNullToEmpty(clod_snglcalcscorcd).length > 0)
  12588. {
  12589. if(sysf_messageBox("진료의가 "+holifromdd+" ~ "+holitodd+" 기간동안 해외 출장입니다. 진료의사를 변경하세요.", "Q003") == 6)
  12590. {
  12591. result = true;
  12592. }
  12593. else
  12594. {
  12595. result = false;
  12596. }
  12597. }
  12598. return result;
  12599. }
  12600. /****************************************************************************************
  12601. * Argument : function
  12602. * Description : 하단 우측 화살표 버튼 이벤트 "<<"
  12603. ****************************************************************************************/
  12604. function lf_fClickPrevNext(flag, judgendyn)
  12605. {
  12606. var iCompVal = -1;
  12607. var trgtManWindow = frmf_getChildWindow(lgv_trgtManWindow); // SMPID20400_외래사후심사대상자조회.xrw
  12608. if (!utlf_isNull(trgtManWindow))
  12609. {
  12610. var srchmode = trgtManWindow.ds_hidden_clbs.getColumn(0,"srchmode");
  12611. var trgtmanlist = trgtManWindow.ds_grid_grd_clbsmast;
  12612. var selectedRow = "";
  12613. if (srchmode == "specclbs")
  12614. { // 선별심사 모드인 경우
  12615. selectedRow = trgtManWindow.ds_grid_grd_specclbs.rowposition; // row 선택 후 타이틀 부분 조정시 row = 0으로 바뀌므로 selectedRow로 체크함
  12616. trgtmanlist = trgtManWindow.ds_grid_grd_specclbs;
  12617. }
  12618. else
  12619. {
  12620. selectedRow = trgtManWindow.ds_grid_grd_clbsmast.rowposition; // row 선택 후 타이틀 부분 조정시 row = 0으로 바뀌므로 selectedRow로 체크함
  12621. }
  12622. if (selectedRow > -1)
  12623. {
  12624. if ( flag == "N" )
  12625. { // 이후선택
  12626. var maxRow = trgtmanlist.rowcount;
  12627. iCompVal = maxRow-1;
  12628. }
  12629. else
  12630. { // 이전선택
  12631. iCompVal = -1;
  12632. }
  12633. if (( flag == "P" && selectedRow > iCompVal ) || ( flag == "N" && selectedRow < iCompVal ))
  12634. {
  12635. if (grp_biz.btn_save.enable == true || grp_biz.btn_unjudg.enable == true)
  12636. {
  12637. // "심사중" 상태를 해제한다. "심사저장" 상태로 대상자 화면 갱신
  12638. var tarjudgendyn = ds_main_item1_clbs.getColumn(0,"judgendyn");
  12639. lf_fSetJudgSaveState(tarjudgendyn);
  12640. }
  12641. if (utlf_isNull(judgendyn) != true){
  12642. var nextclamkey = trgtManWindow.lf_fSrchNextJudgTrgtManCLBS1(selectedRow, judgendyn)
  12643. selectedRow= trgtManWindow.ds_grid_grd_clbsmast.findRow("clamkey", nextclamkey);
  12644. if (utlf_isNull(selectedRow) || selectedRow == -1){
  12645. sysf_messageBox("조회된 마지막 심사대상자 입니다. 이후 심사 대상자가", "I004"); ///조회된 마지막 심사대상자 입니다. 이후 심사 대상자가 없습니다.
  12646. return;
  12647. }
  12648. } else {
  12649. if ( flag == "N" )
  12650. {
  12651. selectedRow = selectedRow + 1;
  12652. }
  12653. else
  12654. {
  12655. selectedRow = selectedRow - 1;
  12656. }
  12657. }
  12658. var trgtmanclamym = trgtmanlist.getColumn(selectedRow, "clamym");
  12659. var trgtmanclamdg = trgtmanlist.getColumn(selectedRow, "clamdg");
  12660. var trgtmanpid = trgtmanlist.getColumn(selectedRow, "pid");
  12661. var trgtmanpidsn = trgtmanlist.getColumn(selectedRow, "pidsn");
  12662. var trgtmancutprcpyn = trgtManWindow.ds_send.getColumn(0, "cutprcpsel");
  12663. var trgtmanjudgendyn = trgtmanlist.getColumn(selectedRow, "judgendyn");
  12664. var trgtmantootpopyn = lgv_ioflag == "O" ? trgtManWindow.grp_biz.checkbox10.value : "";
  12665. var judgenddd = trgtmanlist.getColumn(selectedRow, "judgenddd");
  12666. if (trgtmanclamym)
  12667. {
  12668. // 저장 후 결과를 다시 조회하기 위해
  12669. lgv_ds_rslt.clearData();
  12670. lgv_ds_rslt.addRow();
  12671. lgv_ds_rslt.setColumn(0, "clamym", trgtmanclamym);
  12672. lgv_ds_rslt.setColumn(0, "clamdg", trgtmanclamdg);
  12673. lgv_ds_rslt.setColumn(0, "pid" , trgtmanpid);
  12674. lgv_ds_rslt.setColumn(0, "pidsn" , trgtmanpidsn);
  12675. lgv_ds_rslt.setColumn(0, "cutprcpyn", trgtmancutprcpyn);
  12676. lgv_ds_rslt.setColumn(0, "judgendyn", trgtmanjudgendyn);
  12677. lgv_ds_rslt.setColumn(0, "tootpopupyn", trgtmantootpopyn);
  12678. lgv_ds_rslt.setColumn(0, "judgenddd", judgenddd);
  12679. lgv_ds_rslt.setColumn(0, "selectedRow", selectedRow);
  12680. var srchmode = trgtManWindow.ds_hidden_clbs.getColumn(0,"srchmode");
  12681. if (srchmode == "specclbs")
  12682. { // 선별심사 모드인 경우
  12683. trgtManWindow.ds_grid_grd_specclbs.clearSelect();
  12684. trgtManWindow.ds_grid_grd_specclbs.rowposition = selectedRow;
  12685. trgtManWindow.ds_grid_grd_specclbs.selectRow(selectedRow);
  12686. }
  12687. else
  12688. {
  12689. trgtManWindow.ds_grid_grd_clbsmast.clearSelect();
  12690. trgtManWindow.ds_grid_grd_clbsmast.rowposition = selectedRow;
  12691. trgtManWindow.ds_grid_grd_clbsmast.selectRow(selectedRow);
  12692. }
  12693. lf_fGetAftJudgMngt(lgv_ds_rslt);
  12694. trgtManWindow.setPopupRefresh(trgtmanpid);
  12695. }
  12696. return;
  12697. }
  12698. else
  12699. { // 마지막 줄인 경우 이후 대상자가 없다.
  12700. var judgendyn = ds_main_item1_clbs.getColumn(0,"judgendyn");
  12701. lf_fSetJudgSaveState(judgendyn);
  12702. sysf_messageBox("조회된 마지막 심사대상자 입니다. 이후 심사 대상자가", "I004"); ///조회된 마지막 심사대상자 입니다. 이후 심사 대상자가 없습니다.
  12703. return;
  12704. }
  12705. }
  12706. }
  12707. if (frmf_isPopup()) {
  12708. ds_tmp_clbs.setColumn(0, "clamym", ds_main_item1_clbs.getColumn(0, "clamym"));
  12709. ds_tmp_clbs.setColumn(0, "clamdg", ds_main_item1_clbs.getColumn(0, "clamdg"));
  12710. ds_tmp_clbs.setColumn(0, "pid", ds_main_item1_clbs.getColumn(0, "pid"));
  12711. ds_tmp_clbs.setColumn(0, "pidsn", ds_main_item1_clbs.getColumn(0, "pidsn"));
  12712. ds_tmp_clbs.setColumn(0, "cutprcpyn", "N");
  12713. lf_fGetAftJudgMngt(ds_tmp_clbs)
  12714. } else {
  12715. sysf_messageBox("외래사후심사대상자 조회에서 선택된 심사 대상자가", "I004"); ///외래사후심사대상자 조회에서 선택된 심사 대상자가 없습니다.
  12716. }
  12717. }
  12718. function grp_biz_cap_clod_onclick(obj:Static, e:ClickEventInfo){
  12719. fClopSizeChange(gClopSize);
  12720. }
  12721. function btn_clopmax_onclick(obj:Button, e:ClickEventInfo)
  12722. {
  12723. fClopSizeChange("MAX");
  12724. }
  12725. function btn_clopauto_onclick(obj:Button, e:ClickEventInfo)
  12726. {
  12727. fClopSizeChange("AUTO");
  12728. }
  12729. function btn_clopmin_onclick(obj:Button, e:ClickEventInfo)
  12730. {
  12731. fClopSizeChange("MIN");
  12732. }
  12733. function fClopSizeChange(tSize){
  12734. if (tSize == "MAX"){
  12735. grp_biz.cap_clop.position.y = gClop_cap_clop - 100;
  12736. grp_biz.btn_clopmax.position.y = gClop_btn_clopmax - 100;
  12737. grp_biz.btn_clopmin.position.y = gClop_btn_clopmin - 100;
  12738. grp_biz.btn_clopauto.position.y = gClop_btn_clopauto - 100;
  12739. grp_biz.btn_clopadd.position.y = gClop_btn_clopadd - 100;
  12740. grp_biz.btn_clopdel.position.y = gClop_btn_clopdel - 100;
  12741. grp_biz.btn_clop_idx.position.y = gClop_btn_clop_idx - 100;
  12742. grp_biz.btn_samedateyn.position.y = gClop_btn_samedateyn - 100;
  12743. grp_biz.grd_oprcphist.position.top = gClop_grd_oprcphist_top - 100;
  12744. grp_biz.grd_clodhist.position.bottom = gClop_cap_clop - 100 - 5;
  12745. grp_biz.rdo_cloppayflag.position.y = gClop_btn_clopmax - 100;
  12746. grp_biz.button5.position.y = gClop_btn_clopmax - 100;
  12747. grp_biz.button3.position.y = gClop_btn_clopmax - 100;
  12748. grp_biz.button1.position.y = gClop_btn_clopmax - 100;
  12749. grp_biz.stc_v252.position.y = gClop_stc_v252 - 100;
  12750. grp_biz.line02.position.y = gClop_line02 - 100;
  12751. if(grp_biz.cap_clop.visible == false) {
  12752. grp_biz.grd_clodhist.position.bottom = grp_biz.grp_aftamt.position.y;
  12753. }
  12754. gClopSize = "MIN";
  12755. } else if (tSize == "AUTO" ) {
  12756. grp_biz.cap_clop.position.y = gClop_cap_clop;
  12757. grp_biz.btn_clopmax.position.y = gClop_btn_clopmax;
  12758. grp_biz.btn_clopmin.position.y = gClop_btn_clopmin;
  12759. grp_biz.btn_clopauto.position.y = gClop_btn_clopauto;
  12760. grp_biz.btn_clopadd.position.y = gClop_btn_clopadd;
  12761. grp_biz.btn_clopdel.position.y = gClop_btn_clopdel;
  12762. grp_biz.btn_clop_idx.position.y = gClop_btn_clop_idx;
  12763. grp_biz.btn_samedateyn.position.y = gClop_btn_samedateyn;
  12764. grp_biz.grd_oprcphist.position.top = gClop_grd_oprcphist_top ;
  12765. grp_biz.grd_clodhist.position.bottom = gClop_cap_clop - 5;
  12766. grp_biz.rdo_cloppayflag.position.y = gClop_btn_clopmax;
  12767. grp_biz.button5.position.y = gClop_btn_samedateyn;
  12768. grp_biz.button3.position.y = gClop_btn_samedateyn;
  12769. grp_biz.button1.position.y = gClop_btn_samedateyn;
  12770. grp_biz.stc_v252.position.y = gClop_stc_v252;
  12771. grp_biz.line02.position.y = gClop_line02;
  12772. gClopSize = "MAX";
  12773. } else if (tSize == "MIN") {
  12774. grp_biz.cap_clop.position.y = gClop_cap_clop + 50;
  12775. grp_biz.btn_clopmax.position.y = gClop_btn_clopmax + 50;
  12776. grp_biz.btn_clopmin.position.y = gClop_btn_clopmin + 50;
  12777. grp_biz.btn_clopauto.position.y = gClop_btn_clopauto + 50;
  12778. grp_biz.btn_clopadd.position.y = gClop_btn_clopadd + 50;
  12779. grp_biz.btn_clopdel.position.y = gClop_btn_clopdel + 50;
  12780. grp_biz.btn_clop_idx.position.y = gClop_btn_clop_idx + 50;
  12781. grp_biz.btn_samedateyn.position.y = gClop_btn_samedateyn + 50;
  12782. grp_biz.grd_oprcphist.position.top = gClop_grd_oprcphist_top + 50;
  12783. grp_biz.grd_clodhist.position.bottom = gClop_cap_clop + 50 - 5;
  12784. grp_biz.rdo_cloppayflag.position.y = gClop_btn_clopmax + 50;
  12785. grp_biz.button5.position.y = gClop_btn_samedateyn + 50;
  12786. grp_biz.button3.position.y = gClop_btn_samedateyn + 50;
  12787. grp_biz.button1.position.y = gClop_btn_samedateyn + 50;
  12788. grp_biz.stc_v252.position.y = gClop_stc_v252 + 50;
  12789. grp_biz.line02.position.y = gClop_line02 + 50;
  12790. gClopSize = "AUTO";
  12791. }
  12792. grp_biz.cap_clop.bringToFront();
  12793. grp_biz.btn_clopmax.bringToFront();
  12794. grp_biz.btn_clopmin.bringToFront();
  12795. grp_biz.btn_clopauto.bringToFront();
  12796. grp_biz.btn_clopadd.bringToFront();
  12797. grp_biz.btn_clopdel.bringToFront();
  12798. grp_biz.btn_clop_idx.bringToFront();
  12799. grp_biz.btn_samedateyn.bringToFront();
  12800. grp_biz.cap_clop.bringToFront();
  12801. grp_biz.rdo_cloppayflag.bringToFront();
  12802. grp_biz.button5.bringToFront();
  12803. grp_biz.button3.bringToFront();
  12804. grp_biz.button1.bringToFront();
  12805. grp_biz.stc_v252.bringToFront();
  12806. grp_biz.line02.bringToFront();
  12807. }
  12808. function ds_list7_clop_oncolumnchanged(obj:Dataset, e:DSColChangeEventInfo)
  12809. {
  12810. // var clopdd = utlf_transNullToEmpty(obj.getColumn(e.row, "clopdd"));
  12811. // var clopno = utlf_transNullToEmpty(e.newvalue);
  12812. //
  12813. // obj.setColumn(e.row, "newmpsno", clopdd + clopno)
  12814. // if( e.columnid == "clopno" ){
  12815. // trace("dfdfdfdf"+e.newvalue)
  12816. // obj.setColumn(e.row, "clopno", e.newvalue);
  12817. // }
  12818. }
  12819. function cap_diag_onclick(obj:Static, e:ClickEventInfo){
  12820. var tSize = "CHANGE";
  12821. if ( tSize == "CHANGE" ) {
  12822. if ( gCldiSize == "MAX" ) {
  12823. tSize = "AUTO";
  12824. } else if ( gCldiSize == "AUTO" ) {
  12825. tSize = "MAX";
  12826. }
  12827. }
  12828. if ( tSize == "MAX" ) {
  12829. // 처방 그리드 : 진료분야 치과와 구분
  12830. grp_biz.grd_cldihist.position.bottom = parseInt(grp_biz.grp_sea02.position.bottom) + (lgv_ioflag == "I" ? 300 : 45);
  12831. } else if (tSize == "AUTO") {
  12832. // 처방 그리드 : 진료분야 치과와 구분
  12833. grp_biz.grd_cldihist.position.bottom = parseInt(grp_biz.grp_sea02.position.top) - + (lgv_ioflag == "I" ? 21 : 1);
  12834. }
  12835. grp_biz.grd_cldihist.bringToFront();
  12836. gCldiSize = tSize;
  12837. }
  12838. function grp_biz_grp_sea00_ipt_insuno_onkeydown(obj:Edit, e:KeyEventInfo){
  12839. if ( e.keycode == 13 ) {
  12840. obj.updateToDataset();
  12841. // 조합기호(ipt_insuno)를 입력하면 해당 조합명칭을 조회한다.
  12842. lf_fGetOutAftJudgTrgtManInsunm();
  12843. }
  12844. }
  12845. // 조합기호(ipt_insuno)를 입력하면 해당 조합명칭을 조회한다.
  12846. function lf_fGetOutAftJudgTrgtManInsunm() {
  12847. ds_send_item2_incd.setColumn(0, "insucd" , ds_main_item1_clbs.getColumn(0, "insuno"));
  12848. ds_send_item2_incd.setColumn(0, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  12849. var oParam = {};
  12850. oParam.id = "TRPID20302";
  12851. oParam.service = "aftjudgapp.InAftJudg";
  12852. oParam.method = "reqGetInAftJudgTrgtManInsunm";
  12853. oParam.inds = "req=ds_send_item2_incd";
  12854. oParam.outds = "ds_item2_incd=incd";
  12855. oParam.async = true;
  12856. oParam.progress = false;
  12857. oParam.callback = "cf_TRPID20302";
  12858. tranf_submit(oParam);
  12859. }
  12860. function cf_TRPID20302(sSvcId, nErrorCode, sErrorMsg) {
  12861. if(nErrorCode < 0) return;
  12862. var insucdnm = ds_item2_incd.getColumn(0, "insucdnm");
  12863. if (!utlf_isNull(insucdnm)){
  12864. ds_main_item1_clbs.setColumn(0, "insunm", insucdnm);
  12865. } else {
  12866. ds_main_item1_clbs.setColumn(0, "insunm", "");
  12867. grp_biz_grp_sea00_btn_insuno_onclick();
  12868. }
  12869. }
  12870. function grp_biz_grp_sea00_btn_insuno_onclick(obj:Button, e:ClickEventInfo){
  12871. var ipt_pid = grp_sea00.ipt_pid.value;
  12872. if (!utlf_isNull(ipt_pid)) {
  12873. ds_hidden_sppmc02500.setColumn(0,"srchcond", "1");// 검색조건 : 등록번호로 설정
  12874. ds_hidden_sppmc02500.setColumn(0,"pid", ipt_pid);
  12875. } else {
  12876. ds_hidden_sppmc02500.clearData();
  12877. ds_hidden_sppmc02500.addRow();
  12878. }
  12879. var objArg = new Object();
  12880. objArg.arg_ds_send = ds_hidden_sppmc02500;
  12881. frmf_modal("SPPMC02500", "SPPMC02500", objArg, null, 1, 150, 150, null, null, null, null, null, "M");
  12882. if(!utlf_isNull(this.objects["ds_patinfolist"])) {
  12883. var srch_pid = ds_patinfolist.getColumn(0, "pid");
  12884. var srch_hngnm = ds_patinfolist.getColumn(0, "hngnm");
  12885. grp_sea00.ipt_pid.value = srch_pid;
  12886. grp_sea00.opt_patnm.value = srch_hngnm;
  12887. }
  12888. }
  12889. function btn_no_onclick(obj:Button, e:ClickEventInfo)
  12890. {
  12891. var pid = ds_main_item1_clbs.getColumn(0, "pid");
  12892. if (pid) { // 조회된 심사대상자가 있으면
  12893. // 의료급여자격조회
  12894. var ordtype = ds_main_item1_clbs.getColumn(0, "stsioflag");
  12895. if (ordtype == "-") {
  12896. ordtype = "O";
  12897. }
  12898. }
  12899. var parm = ds_main_item1_clbs.getColumn(0, "patrrgstno").substr(0,6) +
  12900. ds_main_item1_clbs.getColumn(0, "patrrgstno").substr(6,7) + "▦" + //주민번호
  12901. ds_main_item1_clbs.getColumn(0, "patnm") + "▦" + //이름
  12902. ds_main_item1_clbs.getColumn(0, "ordfromdd") + "▦" + //입원일
  12903. ds_main_item1_clbs.getColumn(0, "cretno") + "▦" + //생성번호
  12904. ordtype + "▦" + //진료형태
  12905. ds_main_item1_clbs.getColumn(0, "ordtodd") + "▦" + //퇴원일자
  12906. "" + "▦" + //본인일부부담금
  12907. "" + "▦" + //기관부담금
  12908. pid + "▦" + //등록번호
  12909. ds_main_item1_clbs.getColumn(0, "orddeptcd") + "▦" ; //진료과
  12910. frmf_setParameter("SPPMC03900_PARM",parm);
  12911. frmf_modal("SPPMC03900", "SPPMC03900", "" ,"","", 10, 10, "","","","","","M");
  12912. var oParam = {};
  12913. oParam.id = "TRPIJ00340";
  12914. oParam.service = "bfjudgapp.InHospJudg";
  12915. oParam.method = "reqGetRareCancerMsg_xp";
  12916. oParam.inds = "req=ds_main_item1_clbs";
  12917. oParam.outds = "ds_init_cmb_rarecancermsg=rarecancermsg";
  12918. oParam.async = true;
  12919. oParam.progress = false;
  12920. oParam.callback = "cf_TRPIJ00340";
  12921. tranf_submit(oParam);
  12922. if (frmf_getParameter("SPPMC03900_RTN") == "Y") {
  12923. var ptin_insdnm = frmf_getParameter("SPPMC03900_insdnm"); // 세대주성명
  12924. var ptin_insucd = frmf_getParameter("SPPMC03900_insucd"); // 보장기관기호(사업장기호)
  12925. var ptin_insuno = frmf_getParameter("SPPMC03900_insuno"); // 시설기호(증번호)
  12926. if (utlf_isNull(ptin_insdnm)) {
  12927. ptin_insdnm = "-";
  12928. }
  12929. if (utlf_isNull(ptin_insucd)) {
  12930. ptin_insucd = "-";
  12931. }
  12932. if (utlf_isNull(ptin_insuno)) {
  12933. ptin_insuno = "-";
  12934. }
  12935. ds_main_item1_clbs.setColumn(0,"insdnm",ptin_insdnm);
  12936. ds_main_item1_clbs.setColumn(0,"insuno",ptin_insucd);
  12937. ds_main_item1_clbs.setColumn(0,"certno",ptin_insuno);
  12938. // 조합기호에 해당하는 조합명칭을 조회한다.
  12939. ds_send_item2_incd.setColumn(0, "insucd", ds_main_item1_clbs.getColumn(0, "insuno"));
  12940. ds_send_item2_incd.setColumn(0, "ordfromdd", ds_main_item1_clbs.getColumn(0, "ordfromdd"));
  12941. var oParam = {};
  12942. oParam.id = "TRPID20302";
  12943. oParam.service = "aftjudgapp.InAftJudg";
  12944. oParam.method = "reqGetInAftJudgTrgtManInsunm";
  12945. oParam.inds = "req=ds_send_item2_incd";
  12946. oParam.outds = "ds_item2_incd=incd";
  12947. oParam.async = false;
  12948. tranf_submit(oParam);
  12949. var insucdnm = ds_item2_incd.getColumn(0, "insucdnm");
  12950. ds_main_item1_clbs.setColumn(0, "insunm", insucdnm);
  12951. }
  12952. }
  12953. function lf_fPreListOnDblClick(){
  12954. var row = ds_list4_clbs.rowposition;
  12955. var clamym = ds_list4_clbs.getColumn(row, "clamym");
  12956. var clamdg = ds_list4_clbs.getColumn(row, "clamdg");
  12957. var pid = ds_list4_clbs.getColumn(row, "pid");
  12958. var pidsn = ds_list4_clbs.getColumn(row, "pidsn");
  12959. var ioflag = ds_list4_clbs.getColumn(row, "ioflag");
  12960. if ((clamym == ds_main_item1_clbs.getColumn(0, "clamym")) &&
  12961. (clamdg == ds_main_item1_clbs.getColumn(0, "clamdg")) &&
  12962. (pid == ds_main_item1_clbs.getColumn(0, "pid")) &&
  12963. (pidsn == ds_main_item1_clbs.getColumn(0, "pidsn"))) {
  12964. //현재 심사중인 명세서와 동일한 명세서가 선택되었습니다.
  12965. sysf_messageBox("현재 심사중인 명세서와 동일한 명세서가", "E005");
  12966. return;
  12967. }
  12968. if(!utlf_isNull(clamym))
  12969. {
  12970. if(ioflag == "I")
  12971. {
  12972. var preDocuWindow = frmf_getChildWindow("SMPID20300");
  12973. }
  12974. else
  12975. {
  12976. var preDocuWindow = frmf_getChildWindow("SMPID20500");
  12977. }
  12978. if(utlf_isNull(preDocuWindow))
  12979. {
  12980. ds_send_item1_clbs.setColumn(0, "workflag", "12");
  12981. ds_send_item1_clbs.setColumn(0, "clamym", clamym);
  12982. ds_send_item1_clbs.setColumn(0, "clamdg", clamdg);
  12983. ds_send_item1_clbs.setColumn(0, "pid", pid);
  12984. ds_send_item1_clbs.setColumn(0, "pidsn", pidsn);
  12985. ds_send_item1_clbs.setColumn(0, "ioflag", ioflag);
  12986. if(ioflag == "I")
  12987. {
  12988. frmf_open("SMPID20300", "SMPID20300", {objDs:ds_send_item1_clbs}, "", "", "", "", "", "", "", "", "", "M");
  12989. }
  12990. else
  12991. {
  12992. frmf_open("SMPID20500", "SMPID20500", {objDs:ds_send_item1_clbs}, "", "", "", "", "", "", "", "", "", "M");
  12993. }
  12994. }
  12995. else
  12996. {
  12997. ds_cond_smpid20500.setColumn(0, "workflag", "12");
  12998. ds_cond_smpid20500.setColumn(0, "clamym", clamym);
  12999. ds_cond_smpid20500.setColumn(0, "clamdg", clamdg);
  13000. ds_cond_smpid20500.setColumn(0, "pid", pid);
  13001. ds_cond_smpid20500.setColumn(0, "pidsn", pidsn);
  13002. ds_cond_smpid20500.setColumn(0, "cutprcpyn", "N");
  13003. preDocuWindow.lf_fGetAftJudgMngt(ds_cond_smpid20500);
  13004. if(ioflag == "I")
  13005. {
  13006. frmf_setFocusPop("SMPID20300");
  13007. }
  13008. else
  13009. {
  13010. frmf_setFocusPop("SMPID20500");
  13011. }
  13012. }
  13013. }
  13014. }
  13015. function grp_predoculist_grd_predocu_oncelldblclick(obj:Grid, e:GridClickEventInfo){
  13016. // 이전 명세서 목록
  13017. lf_fPreListOnDblClick();
  13018. }
  13019. /****************************************************************************************
  13020. * Argument : function
  13021. * Description : 일괄처방주석입력
  13022. ****************************************************************************************/
  13023. function lf_fCallClsoSpclAllSpec()
  13024. {
  13025. lf_fSetLnUnitClsoSpclAllSpec("grp_biz.grd_oprcphist");
  13026. }
  13027. /****************************************************************************************
  13028. * Argument : function
  13029. * Description :
  13030. ****************************************************************************************/
  13031. function lf_fSetLnUnitClsoSpclAllSpec(sgrid)
  13032. {
  13033. ds_rslt_sppiz01700.clearData();
  13034. ds_cond_sppiz01700.clearData();
  13035. ds_list_sppiz01700.clearData();
  13036. var grid_obj = eval(sgrid);
  13037. var grid_ds = eval(grid_obj.binddataset); //ds_list7_clop
  13038. var rowcnt = 0;
  13039. var setrow = 0;
  13040. var rows = grdf_getSelectedRows(grp_biz.grd_oprcphist);
  13041. for (var k = 0; k < rows.length; k++ )
  13042. {
  13043. var row = rows[k];
  13044. var seqno = grid_ds.getColumn(row, "seqno");
  13045. var edilnno = grid_ds.getColumn(row, "edilnno");
  13046. var snglcalcscorcd = grid_ds.getColumn(row, "snglcalcscorcd");
  13047. var mpsno = grid_ds.getColumn(row, "mpsno");
  13048. if (sgrid == "grp_biz.grd_oprcphist")
  13049. {
  13050. var clopdd = grid_ds.getColumn(row, "clopdd");
  13051. var clopno = grid_ds.getColumn(row, "clopno");
  13052. }
  13053. else if (sgrid == "grd_clsphist")
  13054. {
  13055. var clopdd = String(grid_ds.getColumn(row, "mpsno")).substr(0,8);
  13056. var clopno = String(grid_ds.getColumn(row, "mpsno")).substr(8,5);
  13057. }
  13058. if (seqno != "0")
  13059. {
  13060. if (sgrid == "grp_biz.grd_oprcphist")
  13061. {
  13062. var lnunitspclspecyn = grid_obj.getCellText(row, grid_obj.getBindCellIndex("body", "spclspecyn"));
  13063. }
  13064. else if (sgrid == "grd_clsphist")
  13065. {
  13066. var lnunitspclspecyn = "*";
  13067. }
  13068. if (utlf_isNull(lnunitspclspecyn))
  13069. {
  13070. dsf_makeValue(ds_cond_sppiz01700, "flag", "string", "I", 0);
  13071. dsf_makeValue(ds_cond_sppiz01700, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  13072. dsf_makeValue(ds_cond_sppiz01700, "clopdd", "string", clopdd, 0);
  13073. dsf_makeValue(ds_cond_sppiz01700, "clopno", "string", clopno, 0);
  13074. dsf_makeValue(ds_cond_sppiz01700, "edilnno", "string", edilnno, 0);
  13075. dsf_makeValue(ds_cond_sppiz01700, "clodseqno", "string", seqno, 0);
  13076. dsf_makeValue(ds_cond_sppiz01700, "spclcd", "string", "JX999", 0);
  13077. dsf_makeValue(ds_cond_sppiz01700, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  13078. dsf_makeValue(ds_cond_sppiz01700, "spclspec", "string", "", 0);
  13079. dsf_makeValue(ds_cond_sppiz01700, "spclformat", "string", "X(700)", 0);
  13080. dsf_makeValue(ds_cond_sppiz01700, "rownum", "string", "", 0);
  13081. dsf_makeValue(ds_cond_sppiz01700, "cdnm", "string", "기타내역", 0);
  13082. dsf_makeValue(ds_cond_sppiz01700, "unitflag", "string", "J", 0);
  13083. dsf_makeValue(ds_list_sppiz01700, "flag", "string", "I", rowcnt);
  13084. dsf_makeValue(ds_list_sppiz01700, "rownum", "string", "", rowcnt);
  13085. dsf_makeValue(ds_list_sppiz01700, "snglcalcscorcd", "string", snglcalcscorcd, rowcnt);
  13086. dsf_makeValue(ds_list_sppiz01700, "clopdd", "string", clopdd, rowcnt);
  13087. dsf_makeValue(ds_list_sppiz01700, "clopno", "string", clopno, rowcnt);
  13088. dsf_makeValue(ds_list_sppiz01700, "clodseqno", "string", seqno, rowcnt);
  13089. dsf_makeValue(ds_list_sppiz01700, "edilnno", "string", edilnno, rowcnt);
  13090. dsf_makeValue(ds_list_sppiz01700, "spclcd", "string", "JX999", rowcnt);
  13091. dsf_makeValue(ds_list_sppiz01700, "spclspec", "string", "", rowcnt);
  13092. dsf_makeValue(ds_list_sppiz01700, "spclformat", "string", "X(700)", rowcnt);
  13093. dsf_makeValue(ds_list_sppiz01700, "cdnm", "string", "기타내역", rowcnt);
  13094. dsf_makeValue(ds_list_sppiz01700, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", rowcnt);
  13095. dsf_makeValue(ds_list_sppiz01700, "unitflag", "string", "J", rowcnt);
  13096. dsf_makeValue(ds_list_sppiz01700, "oldspclcd", "string", spclcd, rowcnt);
  13097. dsf_makeValue(ds_list_sppiz01700, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  13098. dsf_makeValue(ds_list_sppiz01700, "mpsno", "string", ds_list3_clsp.getColumn(i, "mpsno"), rowcnt);
  13099. rowcnt++;
  13100. }
  13101. else
  13102. {
  13103. for (var i = 0; i < ds_list3_clsp.rowcount; i++)
  13104. {
  13105. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  13106. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  13107. if (spcClodseqno == seqno && spcClsoyn == "Y")
  13108. {
  13109. var spclcd = ds_list3_clsp.getColumn(i, "spclcd");
  13110. var spclcdJX999 = ds_list3_clsp.lookupExpr("spclcd=='JX999' && snglcalcscorcd == '"+ snglcalcscorcd +"'", "spclcd");
  13111. if (!utlf_isNull(spclcd) && spclcd != "JT001" && spclcd == "JX999" && ds_list3_clsp.getRowType(i) != 8)
  13112. {
  13113. dsf_makeValue(ds_cond_sppiz01700, "flag", "string", "", 0);
  13114. dsf_makeValue(ds_cond_sppiz01700, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  13115. dsf_makeValue(ds_cond_sppiz01700, "clopdd", "string", clopdd, 0);
  13116. dsf_makeValue(ds_cond_sppiz01700, "clopno", "string", clopno, 0);
  13117. dsf_makeValue(ds_cond_sppiz01700, "clodseqno", "string", seqno, 0);
  13118. dsf_makeValue(ds_cond_sppiz01700, "edilnno", "string", edilnno, 0);
  13119. dsf_makeValue(ds_cond_sppiz01700, "spclcd", "string", ds_list3_clsp.getColumn(i, "spclcd"), 0);
  13120. dsf_makeValue(ds_cond_sppiz01700, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), 0);
  13121. dsf_makeValue(ds_cond_sppiz01700, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), 0);
  13122. dsf_makeValue(ds_cond_sppiz01700, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), 0);
  13123. dsf_makeValue(ds_cond_sppiz01700, "rownum", "string", setrow, 0);
  13124. dsf_makeValue(ds_cond_sppiz01700, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), 0);
  13125. dsf_makeValue(ds_cond_sppiz01700, "unitflag", "string", "J", 0);
  13126. dsf_makeValue(ds_list_sppiz01700, "flag", "string", "", rowcnt);
  13127. dsf_makeValue(ds_list_sppiz01700, "rownum", "string", i, rowcnt);
  13128. dsf_makeValue(ds_list_sppiz01700, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  13129. dsf_makeValue(ds_list_sppiz01700, "clopdd", "string", String(ds_list3_clsp.getColumn(i, "mpsno")).substr(0,8), rowcnt);
  13130. dsf_makeValue(ds_list_sppiz01700, "clopno", "string", String(ds_list3_clsp.getColumn(i, "mpsno")).substr(8,5), rowcnt);
  13131. dsf_makeValue(ds_list_sppiz01700, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  13132. dsf_makeValue(ds_list_sppiz01700, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  13133. dsf_makeValue(ds_list_sppiz01700, "spclcd", "string", spclcd, rowcnt);
  13134. dsf_makeValue(ds_list_sppiz01700, "spclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  13135. dsf_makeValue(ds_list_sppiz01700, "spclformat", "string", ds_list3_clsp.getColumn(i, "spclformat"), rowcnt);
  13136. dsf_makeValue(ds_list_sppiz01700, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  13137. dsf_makeValue(ds_list_sppiz01700, "detldesc", "string", ds_list3_clsp.getColumn(i, "detldesc"), rowcnt);
  13138. dsf_makeValue(ds_list_sppiz01700, "oldspclcd", "string", spclcd, rowcnt);
  13139. dsf_makeValue(ds_list_sppiz01700, "oldspclspec", "string", ds_list3_clsp.getColumn(i, "spclspec"), rowcnt);
  13140. dsf_makeValue(ds_list_sppiz01700, "mpsno", "string", ds_list3_clsp.getColumn(i, "mpsno"), rowcnt);
  13141. if (spclcd == "JX999")
  13142. {
  13143. setrow = i;
  13144. }
  13145. rowcnt++;
  13146. }
  13147. else if (!utlf_isNull(spclcd) && spclcd != "JT001" && utlf_isNull(spclcdJX999) && ds_list3_clsp.getRowType(i) != 8)
  13148. {
  13149. dsf_makeValue(ds_cond_sppiz01700, "flag", "string", "I", 0);
  13150. dsf_makeValue(ds_cond_sppiz01700, "snglcalcscorcd", "string", snglcalcscorcd, 0);
  13151. dsf_makeValue(ds_cond_sppiz01700, "clopdd", "string", clopdd, 0);
  13152. dsf_makeValue(ds_cond_sppiz01700, "clopno", "string", clopno, 0);
  13153. dsf_makeValue(ds_cond_sppiz01700, "clodseqno", "string", seqno, 0);
  13154. dsf_makeValue(ds_cond_sppiz01700, "edilnno", "string", edilnno, 0);
  13155. dsf_makeValue(ds_cond_sppiz01700, "spclcd", "string", "JX999", 0);
  13156. dsf_makeValue(ds_cond_sppiz01700, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", 0);
  13157. dsf_makeValue(ds_cond_sppiz01700, "spclspec", "string", "", 0);
  13158. dsf_makeValue(ds_cond_sppiz01700, "spclformat", "string", "X(700)", 0);
  13159. dsf_makeValue(ds_cond_sppiz01700, "rownum", "string", "", 0);
  13160. dsf_makeValue(ds_cond_sppiz01700, "cdnm", "string", "기타내역", 0);
  13161. dsf_makeValue(ds_cond_sppiz01700, "unitflag", "string", "J", 0);
  13162. dsf_makeValue(ds_list_sppiz01700, "flag", "string", "I", rowcnt);
  13163. dsf_makeValue(ds_list_sppiz01700, "rownum", "string", i, rowcnt);
  13164. dsf_makeValue(ds_list_sppiz01700, "snglcalcscorcd", "string", ds_list3_clsp.getColumn(i, "snglcalcscorcd"), rowcnt);
  13165. dsf_makeValue(ds_list_sppiz01700, "clopdd", "string", String(ds_list3_clsp.getColumn(i, "mpsno")).substr(0,8), rowcnt);
  13166. dsf_makeValue(ds_list_sppiz01700, "clopno", "string", String(ds_list3_clsp.getColumn(i, "mpsno")).substr(8,5), rowcnt);
  13167. dsf_makeValue(ds_list_sppiz01700, "clodseqno", "string", ds_list3_clsp.getColumn(i, "clodseqno"), rowcnt);
  13168. dsf_makeValue(ds_list_sppiz01700, "edilnno", "string", ds_list3_clsp.getColumn(i, "edilnno"), rowcnt);
  13169. dsf_makeValue(ds_list_sppiz01700, "spclcd", "string", "JX999", rowcnt);
  13170. dsf_makeValue(ds_list_sppiz01700, "spclspec", "string", "", rowcnt);
  13171. dsf_makeValue(ds_list_sppiz01700, "spclformat", "string", "X(700)", rowcnt);
  13172. dsf_makeValue(ds_list_sppiz01700, "cdnm", "string", ds_list3_clsp.getColumn(i, "cdnm"), rowcnt);
  13173. dsf_makeValue(ds_list_sppiz01700, "detldesc", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", rowcnt);
  13174. dsf_makeValue(ds_list_sppiz01700, "oldspclcd", "string", "JX999", rowcnt);
  13175. dsf_makeValue(ds_list_sppiz01700, "oldspclspec", "string", "특정내역의 구분코드가 없는 경우에는 기타 줄번호(확장 번호)단위의 기타내역에 기재", rowcnt);
  13176. dsf_makeValue(ds_list_sppiz01700, "mpsno", "string", ds_list3_clsp.getColumn(i, "mpsno"), rowcnt);
  13177. rowcnt ++;
  13178. }
  13179. }
  13180. }
  13181. }
  13182. }
  13183. else
  13184. {
  13185. sysf_messageBox("처방번호가 부여되지 않았으며 해당 줄단위 특정내역이", "I004");
  13186. }
  13187. }
  13188. var objArg = new Object();
  13189. objArg.arg_ds_hidden_clsp_cond = ds_cond_sppiz01700;
  13190. objArg.arg_ds_hidden_clsp_cond_list = ds_list_sppiz01700;
  13191. frmf_modal("SPPIZ01700", "SPPIZ01700", objArg, "", "", "", "", "", "", "", "", "", "M");
  13192. var rsltcnt = ds_rslt_sppiz01700.rowcount;
  13193. if(rsltcnt > 0)
  13194. {
  13195. for(var i = 0; i < rsltcnt; i++)
  13196. {
  13197. var flag = ds_rslt_sppiz01700.getColumn(i, "flag");
  13198. var rownum = ds_rslt_sppiz01700.getColumn(i, "rownum");
  13199. var newspclcd = ds_rslt_sppiz01700.getColumn(i, "spclcd");
  13200. var newcdnm = ds_rslt_sppiz01700.getColumn(i, "cdnm");
  13201. var newspclspec = ds_rslt_sppiz01700.getColumn(ds_rslt_sppiz01700.rowcount-1, "spclspec");
  13202. var newspclformat = ds_rslt_sppiz01700.getColumn(i, "spclformat");
  13203. var newdetldesc = ds_rslt_sppiz01700.getColumn(i, "detldesc");
  13204. var newclodseqno = ds_rslt_sppiz01700.getColumn(i, "clodseqno");
  13205. var newsnglcalcscorcd = ds_rslt_sppiz01700.getColumn(i, "snglcalcscorcd");
  13206. var newedilnno = ds_rslt_sppiz01700.getColumn(i, "edilnno");
  13207. if(flag == "I")
  13208. {
  13209. var clsprow = ds_list3_clsp.addRow();
  13210. if(newspclcd == "CT001")
  13211. {
  13212. ds_list3_clsp.setColumn(clsprow, "unitflag", "C");
  13213. ds_list3_clsp.setColumn(clsprow, "clodseqno", "0");
  13214. ds_list3_clsp.setColumn(clsprow, "edilnno", "0");
  13215. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", "-");
  13216. }
  13217. else if( newspclcd == "CT002")
  13218. {
  13219. ds_list3_clsp.setColumn(clsprow, "unitflag", "C");
  13220. ds_list3_clsp.setColumn(clsprow, "clodseqno", "0");
  13221. ds_list3_clsp.setColumn(clsprow, "edilnno", "0");
  13222. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", "-");
  13223. }
  13224. else
  13225. {
  13226. ds_list3_clsp.setColumn(clsprow, "unitflag", "J");
  13227. ds_list3_clsp.setColumn(clsprow, "clodseqno", newclodseqno);
  13228. ds_list3_clsp.setColumn(clsprow, "edilnno", newedilnno);
  13229. ds_list3_clsp.setColumn(clsprow, "snglcalcscorcd", newsnglcalcscorcd);
  13230. }
  13231. var snglcalcscorcdcnt = ds_list7_clop.rowcount;
  13232. var clopdd = ds_list7_clop.getColumn(0, "clopdd");
  13233. var clopno = ds_list7_clop.getColumn(0, "clopno");
  13234. if(snglcalcscorcdcnt > 0)
  13235. {
  13236. ds_list3_clsp.setColumn(clsprow, "mpsno", clopdd +""+clopno);
  13237. }
  13238. ds_list3_clsp.setColumn(clsprow, "spclcd", newspclcd);
  13239. ds_list3_clsp.setColumn(clsprow, "cdnm", newcdnm);
  13240. ds_list3_clsp.setColumn(clsprow, "spclspec", newspclspec);
  13241. ds_list3_clsp.setColumn(clsprow, "spclformat", newspclformat);
  13242. ds_list3_clsp.setColumn(clsprow, "detldesc", newdetldesc);
  13243. ds_list3_clsp.setColumn(clsprow, "oldedilnno", newedilnno);
  13244. ds_list3_clsp.setColumn(clsprow, "oldspclcd", "");
  13245. ds_list3_clsp.setColumn(clsprow, "clsoyn", "Y");
  13246. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  13247. }
  13248. else if (flag == "U")
  13249. {
  13250. ds_list3_clsp.setColumn(rownum, "snglcalcscorcd", newsnglcalcscorcd);
  13251. ds_list3_clsp.setColumn(rownum, "spclcd", newspclcd);
  13252. ds_list3_clsp.setColumn(rownum, "cdnm", newcdnm);
  13253. ds_list3_clsp.setColumn(rownum, "spclspec", newspclspec);
  13254. ds_list3_clsp.setColumn(rownum, "spclformat", newspclformat);
  13255. ds_list3_clsp.setColumn(rownum, "detldesc", newdetldesc);
  13256. var oldspclcd = ds_rslt_sppiz01700.getColumn(i, "oldspclcd");
  13257. var oldspclspec = ds_rslt_sppiz01700.getColumn(i, "oldspclspec");
  13258. var rowstatus = ds_list3_clsp.getRowType(rownum);
  13259. if(rowstatus == 2)
  13260. {
  13261. }
  13262. else
  13263. {
  13264. var arrRow = new Array();
  13265. arrRow[0] = rownum;
  13266. grdf_setStatus(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, "I", arrRow);
  13267. }
  13268. ds_hidden_list3.setColumn(0, "msgspclformat", "코드: "+ newspclcd +" / 명칭: "+ newcdnm +" / 내역: "+ newspclspec +" / 형식: "+ newspclformat);
  13269. }
  13270. else if (flag == "D" && !utlf_isNull(rownum))
  13271. {
  13272. var rowstatus = ds_list3_clsp.getRowType(rownum);
  13273. if(rowstatus == 2)
  13274. {
  13275. ds_list3_clsp.deleteRow(rownum);
  13276. }
  13277. else
  13278. {
  13279. ds_list3_clsp.setColumn(rownum, "insntstat","D");
  13280. ds_list3_clsp.updatecontrol = false;
  13281. ds_list3_clsp.setRowType(rownum, 'd');
  13282. ds_list3_clsp.updatecontrol = true;
  13283. lf_fSetSpclSpecJX999()
  13284. ds_list3_clsp.deleteRow(rownum);
  13285. }
  13286. ds_list3_clsp.setColumn(rownum, "insntstat", "D");
  13287. ds_list3_clsp.rowposition = rownum;
  13288. ds_hidden_list3.setColumn(0, "msgspclformat", "입력된 줄단위 특정내역이 없습니다.");
  13289. } // 특정 코드 상태 따른 if end
  13290. } // for end
  13291. var cnt = 0;
  13292. for(var i = 0; i < ds_list3_clsp.rowcount; i++)
  13293. {
  13294. if(ds_list3_clsp.getRowType(i) != 8)
  13295. {
  13296. var spcmpsno = ds_list3_clsp.getColumn(i, "mpsno");
  13297. var spcClodseqno = ds_list3_clsp.getColumn(i, "clodseqno");
  13298. var spcClsoyn = ds_list3_clsp.getColumn(i, "clsoyn");
  13299. if (spcmpsno == mpsno && spcClodseqno == seqno && spcClsoyn == "Y")
  13300. {
  13301. cnt++;
  13302. break;
  13303. }
  13304. }
  13305. }
  13306. ds_list7_clop.updatecontrol = false;
  13307. if (cnt > 0)
  13308. {
  13309. for (var i = 0; i < ds_list7_clop.rowcount; i++)
  13310. {
  13311. var mpsno = ds_list7_clop.getColumn(i, "mpsno");
  13312. var seqno = ds_list7_clop.getColumn(i, "seqno");
  13313. if (spcmpsno == mpsno && spcClodseqno == seqno && spcClsoyn == "Y")
  13314. {
  13315. ds_list7_clop.setColumn(i, "spclspecyn", "*");
  13316. break;
  13317. }
  13318. }
  13319. }
  13320. ds_list7_clop.updatecontrol = true;
  13321. lf_fSortSpclNo();
  13322. lf_fSaveClspList();
  13323. }
  13324. }
  13325. // 보조유형 및 요율 combo(cmb_supprate)의 선택 값이 변경된 경우 각각을 해당 output에 설정한다.
  13326. function lf_fSetPatSuppRate() {
  13327. // 보조유형ID과 요율%로 combo 의 value
  13328. // 보조유형NM과 요율%로 combo 의 label
  13329. var patsupprate = utlf_transNullToEmpty(ds_main_item1_clbs.getColumn(0, "patsupprate"));
  13330. var suppkindcd = patsupprate.substr(0, 2);
  13331. var insukindcd = ds_main_item1_clbs.getColumn(0, "insukindcd");
  13332. var payownbrate = patsupprate.substr(3, patsupprate.length);
  13333. ds_main_item1_clbs.addColumn("recalcyn", "string");
  13334. ds_main_item1_clbs.setColumn(0, "suppkindcd", suppkindcd);
  13335. ds_main_item1_clbs.setColumn(0, "payownbrate", payownbrate);
  13336. ds_main_item1_clbs.setColumn(0, "recalcyn", "Y"); // 저장 시에 재계산할지 여부를 설정함
  13337. // 공상구분(offcharm) :1:공상, C:차상위본인부담경감자, 0:무
  13338. if (lgv_ioflag == "O") {
  13339. if (suppkindcd == "42"){
  13340. ds_main_item1_clbs.setColumn(0, "offcharm", "1");
  13341. } else if (suppkindcd == "32"){
  13342. ds_main_item1_clbs.setColumn(0, "offcharm", "C");
  13343. } else {
  13344. ds_main_item1_clbs.setColumn(0, "offcharm", "0");
  13345. }
  13346. }
  13347. if (!utlf_isNull(suppkindcd) && suppkindcd != "00") {
  13348. grp_sea00.opt_suppkind.style.backgroundColor = "#f7a08b";
  13349. grp_sea00.opt_payownbrate.style.backgroundColor = "#f7a08b";
  13350. } else {
  13351. grp_sea00.opt_suppkind.style.backgroundColor = "#f2f2f2"; // output_fix 클래스의 background-color
  13352. grp_sea00.opt_payownbrate.style.backgroundColor = "#f2f2f2";
  13353. }
  13354. }
  13355. /****************************************************************************************
  13356. * Argument : function
  13357. * Description :
  13358. ****************************************************************************************/
  13359. function lf_fGetToothPop()
  13360. {
  13361. var tootSelectcnt = ds_rslt_sppiz00600.rowcount;
  13362. var flag = "";
  13363. var row = "";
  13364. var toot = "";
  13365. tootSelectcnt = eval(tootSelectcnt);
  13366. for ( var i = 0; i < tootSelectcnt; i++)
  13367. {
  13368. flag = ds_rslt_sppiz00600.getColumn(i, "flag");
  13369. row = ds_rslt_sppiz00600.getColumn(i, "row");
  13370. var rlsttoot = ds_rslt_sppiz00600.getColumn(i, "toot");
  13371. var rlsttoot1 = ds_rslt_sppiz00600.getColumn(i, "toot1");
  13372. if (utlf_isNull(rlsttoot))
  13373. {
  13374. rlsttoot = "-";
  13375. }
  13376. if (utlf_isNull(rlsttoot1))
  13377. {
  13378. rlsttoot1 = "-";
  13379. }
  13380. if (flag == "1")
  13381. {
  13382. toot = ds_list1_cldi.getColumn(row, "toot");
  13383. ds_list1_cldi.setColumn(row, "toot" , rlsttoot);
  13384. ds_list1_cldi.setColumn(row, "toot1", rlsttoot1);
  13385. if (rlsttoot != toot)
  13386. {
  13387. var cldistatus = ds_list1_cldi.getRowType(row);
  13388. if (cldistatus == 4)
  13389. {
  13390. // update
  13391. ds_list1_cldi.updatecontrol = false;
  13392. ds_list1_cldi.setRowType(row, "u");
  13393. ds_list1_cldi.updatecontrol = true;
  13394. }
  13395. }
  13396. }
  13397. else if (flag == "2")
  13398. {
  13399. toot = ds_list2_clod.getColumn(row, "toot");
  13400. ds_list2_clod.setColumn(row, "toot" , rlsttoot);
  13401. ds_list2_clod.setColumn(row, "toot1", rlsttoot1);
  13402. if (rlsttoot != toot)
  13403. {
  13404. // 치식번호가 변경된 경우 처방의 수정된 row 상태를 표시한다.
  13405. lf_fSetOrderChangeRowStat(row);
  13406. }
  13407. }
  13408. }
  13409. }
  13410. /****************************************************************************************
  13411. * Argument : 버튼 이벤트
  13412. * Description : 인적사항 우측 버튼 이벤트
  13413. ****************************************************************************************/
  13414. function grp_biz_btn_patspcfyn_onclick(obj:Button, e:ClickEventInfo)
  13415. {
  13416. ds_hidden_smpmc01300_cond.setColumn(0, "srchcond", "1");
  13417. ds_hidden_smpmc01300_cond.setColumn(0, "srchcond", ds_main_item1_clbs.getColumn(0, "pid"));
  13418. var objArg = new Object();
  13419. objArg.arg_ds_source= ds_hidden_smpmc01300_cond;
  13420. frmf_modal("SMPMC01300", "SMPMC01300", objArg, "", "", "", "", "", "", "", "", "", "M");
  13421. var indd = ds_main_item1_clbs.getColumn(0, "indd");
  13422. if(indd)
  13423. {
  13424. ds_hidden_smpmc01300_cond.setColumn(0, "indd", indd);
  13425. var oParam = {};
  13426. oParam.id = "TRPID20308";
  13427. oParam.service = "aftjudgapp.InAftJudg";
  13428. oParam.method = "reqExeProbJudgFlag";
  13429. oParam.inds = "req=ds_hidden_smpmc01300_cond";
  13430. oParam.outds = "ds_hidden_smpmc01300_cond=cond ds_hidden_smpmc01300_rslt=rslt";
  13431. oParam.async = false;
  13432. //oParam.callback = "cf_TRPID20308";
  13433. tranf_submit(oParam);
  13434. }
  13435. }
  13436. function grp_biz_grp_sea00_cmb_orddrid_ondropdown(obj:Combo, e:EventInfo)
  13437. {
  13438. ds_init_orddrid2.filter("dp == '"+ ds_main_item1_clbs.getColumn(0,"orddeptcd") +"'");
  13439. }
  13440. /****************************************************************************************
  13441. * Argument : dataset
  13442. * Description : 처방 그리드 데이터 셋 컬럼 변경 이벤트
  13443. ****************************************************************************************/
  13444. function ds_list2_clod_oncolumnchanged(obj:Dataset, e:DSColChangeEventInfo)
  13445. {
  13446. var row = e.row
  13447. var col = e.columnid;
  13448. if (col == "ordfromdd")
  13449. {
  13450. if (lgv_ioflag=="I") {
  13451. var ordfromdd = e.newvalue;
  13452. var ordtodd = obj.getColumn(row, "ordtodd");
  13453. var item1 = obj.getColumn(row, "item1");
  13454. if(ds_hidden_item5_clod.getColumn(0, "ordfromdd") == ordfromdd) {
  13455. return;
  13456. }
  13457. if (utlf_isValidDateTime(ordfromdd) == false){
  13458. lf_fCancelClodStatusChng();
  13459. return;
  13460. }
  13461. var clbsordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  13462. var clbsordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  13463. if (item1 != "03" && clbsordfromdd && clbsordtodd) {
  13464. if (ordfromdd < clbsordfromdd || ordfromdd > clbsordtodd) {
  13465. sysf_messageBox("진료 개시일자~종료일자를 벗어난 처방 시작일자가", "E005");
  13466. lf_fCancelClodStatusChng();
  13467. return;
  13468. }
  13469. }
  13470. var mechfromdd = obj.getColumn(row, "mechfromdd");
  13471. var mechtodd = obj.getColumn(row, "mechtodd");
  13472. var rowstatus = obj.getRowType(row);
  13473. if (rowstatus == 2) { // 1 : insert, 3 : insert & new
  13474. obj.setColumn(row, "orddd", ordfromdd);
  13475. }
  13476. var dayno = obj.getColumn(row, "dayno");
  13477. if (dayno) {
  13478. dayno = parseInt(dayno);
  13479. if (dayno >= 0) {
  13480. var fromDate = ordfromdd.toDate();
  13481. var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13482. ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  13483. if (item1 != "03" && clbsordfromdd && clbsordtodd) {
  13484. if (ordtodd < clbsordfromdd || ordtodd > clbsordtodd) {
  13485. sysf_messageBox("일수(총투)를 기준으로 계산된 처방 종료일자가 진료 개시일자~종료일자를 벗어나", "E016");
  13486. lf_fCancelClodStatusChng();
  13487. return;
  13488. }
  13489. }
  13490. obj.setColumn(e.row, "ordtodd", ordtodd);
  13491. } else {
  13492. lf_fCancelClodStatusChng();
  13493. return;
  13494. }
  13495. } else {
  13496. if (ordtodd) {
  13497. var dayno = utlf_getDateInterval(ordfromdd, ordtodd);
  13498. if (dayno >= 0) {
  13499. obj.setColumn(row, "dayno", dayno+1);
  13500. // 기존에 줄번호가 부여안된 경우
  13501. if(utlf_isNull(obj.getColumn(row, "edilnno"))) {
  13502. var snglcalcscorcd = obj.getColumn(row, "snglcalcscorcd");
  13503. if (snglcalcscorcd) {
  13504. col = "snglcalcscorcd";
  13505. lf_fSetSrchCalcScorCd();
  13506. }
  13507. } else {
  13508. col = "dayno";
  13509. lf_fSetTotDrugQtyAmt();
  13510. lf_fSetOrderChangeRowStat(row);
  13511. }
  13512. } else {
  13513. obj.setColumn(row, "ordtodd", ordfromdd);
  13514. }
  13515. } else {
  13516. obj.setColumn(row, "ordtodd", ordfromdd);
  13517. }
  13518. }
  13519. var updtdd = obj.getColumn(row, "updtdd");
  13520. if (updtdd) {
  13521. fChkUpdtdd();
  13522. }
  13523. if (mechfromdd && mechtodd) {
  13524. if (mechfromdd > ordfromdd || mechtodd < ordfromdd){
  13525. lf_fSetTotDrugQtyAmt();
  13526. }
  13527. }
  13528. } else if (lgv_ioflag=="O") {
  13529. var ordfromdd = e.newvalue;
  13530. if(ds_hidden_item5_clod.getColumn(0, "ordfromdd") == ordfromdd) {
  13531. return;
  13532. } else {
  13533. if (utlf_isValidDateTime(ordfromdd)) { // (dateHelper.js) 유효한 날짜, 시간 인지 점검
  13534. // 신규입력된 처방만 처방일수를 변경한다.
  13535. var rowstatus = obj.getRowType(row);
  13536. if (rowstatus == 2) { // 1 : insert, 3 : insert & new
  13537. obj.setColumn(row, "orddd", ordfromdd);
  13538. }
  13539. obj.setColumn(row, "ordfromdd", ordfromdd);
  13540. obj.setColumn(row, "ordtodd", ordfromdd);
  13541. // 처방의 수정된 row 상태를 표시한다.
  13542. lf_fSetOrderChangeRowStat(row);
  13543. // 2009-01-30 실시일자를 변경한 경우 현재 수가의 적용일자를 벗어나면 수가를 다시 조회한다.
  13544. var mechfromdd = obj.getColumn(row, "mechfromdd");
  13545. var mechtodd = obj.getColumn(row, "mechtodd");
  13546. if (mechfromdd && mechtodd) { // 신규 추가된 row를 제외한다.
  13547. if (mechfromdd > ordfromdd || mechtodd < ordfromdd) { // 입력된 처방일자가 수가적용~종료일자를 벗어난 경우
  13548. lf_fSetTotDrugQtyAmt();
  13549. }
  13550. }
  13551. } else {
  13552. // 처방 data 및 row status를 변경 이전 상태로 복구한다.
  13553. lf_fCancelClodStatusChng();
  13554. }
  13555. }
  13556. }
  13557. }
  13558. else if (col == "ordtodd")
  13559. {
  13560. if (lgv_ioflag=="I") {
  13561. var ordfromdd = obj.getColumn(row, "ordfromdd");
  13562. var ordtodd = e.newvalue;
  13563. var item1 = obj.getColumn(row, "item1");
  13564. if(ds_hidden_item5_clod.getColumn(0, "ordtodd") == ordtodd) {
  13565. return;
  13566. }
  13567. if (utlf_isValidDateTime(ordtodd) == false) {
  13568. lf_fCancelClodStatusChng();
  13569. return;
  13570. }
  13571. var clbsordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  13572. var clbsordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  13573. if (item1 != "03" && clbsordfromdd && clbsordtodd)
  13574. {
  13575. if (ordtodd < clbsordfromdd || ordtodd > clbsordtodd)
  13576. {
  13577. sysf_messageBox("진료 개시일자~종료일자를 벗어난 처방 종료일자가", "E005");
  13578. lf_fCancelClodStatusChng();
  13579. return;
  13580. }
  13581. }
  13582. var mechfromdd = obj.getColumn(row, "mechfromdd");
  13583. var mechtodd = obj.getColumn(row, "mechtodd");
  13584. if (ordfromdd)
  13585. {
  13586. var dayno = utlf_getDateInterval(ordfromdd, ordtodd);
  13587. if (dayno >= 0)
  13588. {
  13589. obj.setColumn(row, "dayno", dayno+1);
  13590. if(utlf_isNull(obj.getColumn(row, "edilnno")))
  13591. {
  13592. var snglcalcscorcd = obj.getColumn(row, "snglcalcscorcd");
  13593. if (snglcalcscorcd)
  13594. {
  13595. col = "snglcalcscorcd";
  13596. lf_fSetSrchCalcScorCd();
  13597. }
  13598. }
  13599. else
  13600. {
  13601. col = "dayno";
  13602. lf_fSetTotDrugQtyAmt();
  13603. lf_fSetOrderChangeRowStat(row);
  13604. }
  13605. }
  13606. else
  13607. {
  13608. sysf_messageBox("처방 시작일자가 처방 종료일자 보다 이후", "E008");
  13609. lf_fCancelClodStatusChng();
  13610. }
  13611. }
  13612. else
  13613. {
  13614. var dayno = obj.getColumn(row, "dayno");
  13615. if (dayno)
  13616. {
  13617. dayno = parseInt(dayno);
  13618. if (dayno >= 0)
  13619. {
  13620. var toDate = ordtodd.toDate();
  13621. var fromDate = toDate.getAddDate((dayno - 1) * -1, "D");
  13622. ordfromdd = fromDate.getDateFormat("YYYY") + fromDate.getDateFormat("MM") + fromDate.getDateFormat("DD");
  13623. if (item1 != "03" && clbsordfromdd && clbsordtodd)
  13624. {
  13625. if (ordfromdd < clbsordfromdd || ordfromdd > clbsordtodd)
  13626. {
  13627. }
  13628. }
  13629. obj.setColumn(row, "ordfromdd", ordfromdd);
  13630. obj.setColumn(row, "orddd", ordfromdd);
  13631. if(utlf_isNull(obj.getColumn(row, "edilnno")))
  13632. {
  13633. var snglcalcscorcd = obj.getColumn(row, "snglcalcscorcd");
  13634. if (snglcalcscorcd)
  13635. {
  13636. col = "snglcalcscorcd";
  13637. lf_fSetSrchCalcScorCd();
  13638. }
  13639. }
  13640. else
  13641. {
  13642. col = "dayno"; //grd_clodhist.col = grd_clodhist.colRef("dayno"); // 일수
  13643. lf_fSetTotDrugQtyAmt();
  13644. lf_fSetOrderChangeRowStat(row);
  13645. }
  13646. }
  13647. else
  13648. {
  13649. lf_fCancelClodStatusChng();
  13650. }
  13651. }
  13652. else
  13653. {
  13654. obj.setColumn(row, "ordfromdd", ordtodd);
  13655. obj.setColumn(row, "orddd", ordtodd);
  13656. }
  13657. }
  13658. }
  13659. }
  13660. else if (col == "updtdd")
  13661. {
  13662. var updtdd = obj.getColumn(row, "updtdd");
  13663. if (ds_hidden_item5_clod.getColumn(0, "updtdd") == updtdd)
  13664. {
  13665. return;
  13666. }
  13667. if (utlf_isValidDateTime(updtdd) == false)
  13668. {
  13669. lf_fCancelClodStatusChng();
  13670. return;
  13671. }
  13672. }
  13673. else if (col == "edidrugqty")
  13674. {
  13675. if(obj.getColumn(row, "edidrugqty") != ds_hidden_item5_clod.getColumn(0, "edidrugqty"))
  13676. {
  13677. lf_fSetTotDrugQtyAmt();
  13678. }
  13679. grp_biz.grd_clodhist.setCellPos(grp_biz.grd_clodhist.getBindCellIndex("body", "tims"));
  13680. grp_biz.grd_clodhist.showEditor(true);
  13681. }
  13682. else if (col == "unitcost")
  13683. {
  13684. if ( obj.getColumn(row, "unitcost") != ds_hidden_item5_clod.getColumn(0, "unitcost"))
  13685. {
  13686. lf_fSetTotDrugQtyAmt();
  13687. }
  13688. }
  13689. else if (col == "ediunitcost")
  13690. {
  13691. if ( obj.getColumn(row, "ediunitcost") != ds_hidden_item5_clod.getColumn(0, "ediunitcost"))
  13692. {
  13693. var ediunitcost = ds_list2_clod.getColumn(row, "ediunitcost");
  13694. var totdrugqty = ds_list2_clod.getColumn(row, "totdrugqty");
  13695. var ediamt = eval(ediunitcost) * eval(totdrugqty);
  13696. obj.setColumn(row, "ediamt", ediamt);
  13697. }
  13698. }
  13699. else if (col == "edidruglimitamt")
  13700. {
  13701. if ( obj.getColumn(row, "edidruglimitamt") != ds_hidden_item5_clod.getColumn(0, "edidruglimitamt"))
  13702. {
  13703. var edidruglimitamt = ds_list2_clod.getColumn(row, "edidruglimitamt");
  13704. var totdrugqty = ds_list2_clod.getColumn(row, "totdrugqty");
  13705. var ediunitcost = ds_list2_clod.getColumn(row, "ediunitcost");
  13706. var edilimitdiffamt = (eval(edidruglimitamt) - eval(ediunitcost)) * 0.7 * eval(totdrugqty);
  13707. ds_list2_clod.setColumn(row, "edilimitdiffamt", edilimitdiffamt);
  13708. }
  13709. }
  13710. else if (col == "edidayno")
  13711. {
  13712. if ( e.newvalue != ds_hidden_item5_clod.getColumn(0, "edidayno")) {
  13713. if (lgv_ioflag=="I") {
  13714. var Sdayno = e.newvalue;
  13715. var dayno = parseInt(Sdayno);
  13716. var ordfromdd = obj.getColumn(row, "ordfromdd");
  13717. var ordtodd = obj.getColumn(row, "ordtodd");
  13718. var item1 = obj.getColumn(row, "item1");
  13719. var edilnno = obj.getColumn(row, "edilnno");
  13720. // 진료개시일과 종료일 사이의 일자인지 체크
  13721. var clbsordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  13722. var clbsordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  13723. var insukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  13724. if ( utlf_isNull(Sdayno) || dayno <= 0 )
  13725. {
  13726. }
  13727. else if (!utlf_isNull(ordfromdd))
  13728. {
  13729. var fromDate = ordfromdd.toDate();
  13730. var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13731. ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  13732. if(obj.getColumn(row,"prcpflagyn") != "Y"){
  13733. obj.setColumn(row, "ordtodd", ordtodd);
  13734. }
  13735. } else if (ordtodd) {
  13736. var toDate = ordtodd.toDate();
  13737. var fromDate = toDate.getAddDate((dayno - 1) * -1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13738. ordfromdd = fromDate.getDateFormat("YYYY") + fromDate.getDateFormat("MM") + fromDate.getDateFormat("DD");
  13739. // 일수를 기준으로 구한 날짜가 올바른 경우
  13740. obj.setColumn(row, "ordfromdd", ordfromdd);
  13741. }
  13742. // 기존에 줄번호가 부여안된 경우
  13743. if (utlf_isNull(edilnno)) {
  13744. var snglcalcscorcd = obj.getColumn(row, "snglcalcscorcd");
  13745. if (!utlf_isNull(snglcalcscorcd)) {
  13746. //grd_clodhist.col = grd_clodhist.colRef("snglcalcscorcd");
  13747. //lf_fSetSrchCalcScorCd(); // 처방 종료일자를 입력했는데 일수가 자동계산된 경우
  13748. }
  13749. }
  13750. }
  13751. lf_fSetTotDrugQtyAmt();
  13752. }
  13753. }
  13754. else if (col == "drugqty")
  13755. {
  13756. //if ( ds_list2_clod.getColumn(row, "drugqty") != ds_hidden_item5_clod.getColumn(0, "drugqty"))
  13757. //{
  13758. lf_fSetTotDrugQtyAmt();
  13759. //}
  13760. }
  13761. else if (col == "tims")
  13762. {
  13763. //if ( ds_list2_clod.getColumn(row, "tims") != ds_hidden_item5_clod.getColumn(0, "tims"))
  13764. //{
  13765. lf_fSetTotDrugQtyAmt();
  13766. //}
  13767. }
  13768. else if (col == "dayno")
  13769. { //일수수정은 없다 일단 막아보자 plet2 20180103
  13770. // if ( ds_list2_clod.getColumn(row, "dayno") != ds_hidden_item5_clod.getColumn(0, "dayno"))
  13771. // {
  13772. // var Sdayno = ds_list2_clod.getColumn(row, "dayno");
  13773. // var dayno = parseInt(Sdayno);
  13774. // var ordfromdd = ds_list2_clod.getColumn(row, "ordfromdd");
  13775. // var ordtodd = ds_list2_clod.getColumn(row, "ordtodd");
  13776. // var item1 = ds_list2_clod.getColumn(row, "item1");
  13777. //
  13778. // // 진료개시일과 종료일 사이의 일자인지 체크
  13779. // var clbsordfromdd = ds_main_item1_clbs.getColumn(0, "ordfromdd");
  13780. // var clbsordtodd = ds_main_item1_clbs.getColumn(0, "ordtodd");
  13781. // var insukind = ds_main_item1_clbs.getColumn(0, "insukindcd");
  13782. //
  13783. // if (lgv_ioflag=="O") {
  13784. // if ( utlf_isNull(Sdayno) || dayno <= 0 )
  13785. // {
  13786. // }
  13787. // else if (!utlf_isNull(ordfromdd))
  13788. // {
  13789. // var fromDate = ordfromdd.toDate();
  13790. // var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13791. // ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  13792. //
  13793. // if ( insukind == "41" && !utlf_isNull(clbsordfromdd) && !utlf_isNull(clbsordtodd))
  13794. // {
  13795. // if (ordtodd > clbsordtodd)
  13796. // {
  13797. // ds_main_item1_clbs.setColumn(0, "ordtodd", ordtodd);
  13798. // }
  13799. // ds_list2_clod.setColumn(row, "ordtodd", ordtodd);
  13800. // }
  13801. // }
  13802. // } else if (lgv_ioflag=="I") {
  13803. // if ( utlf_isNull(Sdayno) || dayno <= 0 )
  13804. // {
  13805. // }
  13806. // else if (!utlf_isNull(ordfromdd))
  13807. // {
  13808. // var fromDate = ordfromdd.toDate();
  13809. // var toDate = fromDate.getAddDate(dayno - 1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13810. // ordtodd = toDate.getDateFormat("YYYY") + toDate.getDateFormat("MM") + toDate.getDateFormat("DD");
  13811. //
  13812. // obj.setColumn(row, "ordtodd", ordtodd);
  13813. // } else if (ordtodd) {
  13814. // var toDate = ordtodd.toDate();
  13815. // var fromDate = toDate.getAddDate((dayno - 1) * -1, "D"); // (dateHelper.js) 특정일자의 상대일자(+/-)를 계산
  13816. // ordfromdd = fromDate.getDateFormat("YYYY") + fromDate.getDateFormat("MM") + fromDate.getDateFormat("DD");
  13817. //
  13818. // // 일수를 기준으로 구한 날짜가 올바른 경우
  13819. // obj.setColumn(row, "ordfromdd", ordfromdd);
  13820. // }
  13821. //
  13822. // // 기존에 줄번호가 부여안된 경우
  13823. // if (utlf_isNull(edilnno)) {
  13824. // var snglcalcscorcd = obj.getColumn(row, "snglcalcscorcd");
  13825. // if (!utlf_isNull(snglcalcscorcd)) {
  13826. // //grd_clodhist.col = grd_clodhist.colRef("snglcalcscorcd");
  13827. // lf_fSetSrchCalcScorCd(); // 처방 종료일자를 입력했는데 일수가 자동계산된 경우
  13828. // }
  13829. // }
  13830. //
  13831. // }
  13832. // lf_fSetTotDrugQtyAmt();
  13833. // }
  13834. }
  13835. var rowstat = ds_list2_clod.getRowType(row);
  13836. var adjtresncd = ds_list2_clod.getColumn(row, "adjtresncd");
  13837. var cmbAdjtresncd,newcd,newdesc = "";
  13838. if (col != "adjtresncd" && col != "adjtresndesc" && col != "cnfmcd" && col != "hosinresncd" && col != "toot" && col != "toot1") {
  13839. if (utlf_isNull(adjtresncd) || rowstat == 4 || rowstat == 2)
  13840. {
  13841. // 심사(조정)사유가 입력되지 않은 경우
  13842. cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0,"cmbAdjtresncd");
  13843. if (!utlf_isNull(cmbAdjtresncd)|| !utlf_isNull(adjtresncd))
  13844. {
  13845. }
  13846. else
  13847. {
  13848. var sppiz01000 = new Object();
  13849. sppiz01000.sCdCls = "aftin";
  13850. sppiz01000.sCdid = adjtresncd;
  13851. sppiz01000.sAdjtresndesc = "";
  13852. // SPPIZ01000_심사수정사유관리.xrw
  13853. var rtn = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  13854. if (utlf_isNull(rtn))
  13855. {
  13856. // 처방 data 및 row status를 변경 이전 상태로 복구한다.
  13857. lf_fCancelClodStatusChng();
  13858. }
  13859. else
  13860. {
  13861. newcd = rtn.sCdid;
  13862. newdesc = rtn.sAdjtresndesc;
  13863. }
  13864. }
  13865. }
  13866. if (ds_list2_clod.getRowType(row) == 4)
  13867. {
  13868. if (!utlf_isNull(newcd) && adjtresncd != "G")
  13869. {
  13870. ds_list2_clod.setColumn(row, "adjtresncd", newcd);
  13871. ds_list2_clod.setColumn(row, "adjtresndesc", newdesc);
  13872. }
  13873. lf_fOrderBkColorNew(row);
  13874. }
  13875. }
  13876. }
  13877. function grp_biz_grd_clodhist_onkeydown(obj:Grid, e:KeyEventInfo)
  13878. {
  13879. var col = obj.currentcol
  13880. var row = obj.currentrow;
  13881. var cmbAdjtresncd = "";
  13882. var adjtresncd = ds_list2_clod.getColumn(row, "adjtresncd");
  13883. var rowstat = ds_list2_clod.getRowType(row);
  13884. var cmbAdjtresncd = "";
  13885. var newcd,newdesc = "";
  13886. if (e.keycode == 13)
  13887. {
  13888. obj.updateToDataset();
  13889. if (col == obj.getBindCellIndex("Body", "edidrugqty"))
  13890. {
  13891. //if(ds_list2_clod.getColumn(row, "edidrugqty") != ds_hidden_item5_clod.getColumn(0, "edidrugqty"))
  13892. //{
  13893. //lf_fSetTotDrugQtyAmt();
  13894. //}
  13895. grp_biz.grd_clodhist.setCellPos(grp_biz.grd_clodhist.getBindCellIndex("body", "tims"));
  13896. grp_biz.grd_clodhist.showEditor(true);
  13897. }
  13898. else if (col == obj.getBindCellIndex("body", "unitcost"))
  13899. {
  13900. //if ( ds_list2_clod.getColumn(row, "unitcost") != ds_hidden_item5_clod.getColumn(0, "unitcost"))
  13901. //{
  13902. // lf_fSetTotDrugQtyAmt();
  13903. //}
  13904. }
  13905. else if (col == obj.getBindCellIndex("body", "ediunitcost"))
  13906. {
  13907. if ( ds_list2_clod.getColumn(row, "ediunitcost") != ds_hidden_item5_clod.getColumn(0, "ediunitcost"))
  13908. {
  13909. var ediunitcost = ds_list2_clod.getColumn(row, "ediunitcost");
  13910. var totdrugqty = ds_list2_clod.getColumn(row, "totdrugqty");
  13911. var ediamt = eval(ediunitcost) * eval(totdrugqty);
  13912. ds_list2_clod.setColumn(row, "ediamt", ediamt);
  13913. }
  13914. }
  13915. else if ( col == obj.getBindCellIndex("body", "edidruglimitamt"))
  13916. {
  13917. if ( ds_list2_clod.getColumn(row, "edidruglimitamt") != ds_hidden_item5_clod.getColumn(0, "edidruglimitamt"))
  13918. {
  13919. var edidruglimitamt = ds_list2_clod.getColumn(row, "edidruglimitamt");
  13920. var totdrugqty = ds_list2_clod.getColumn(row, "totdrugqty");
  13921. var ediunitcost = ds_list2_clod.getColumn(row, "ediunitcost");
  13922. var edilimitdiffamt = (eval(edidruglimitamt) - eval(ediunitcost)) * 0.7 * eval(totdrugqty);
  13923. ds_list2_clod.setColumn(row, "edilimitdiffamt", edilimitdiffamt);
  13924. }
  13925. }
  13926. else if ( col == obj.getBindCellIndex("body", "drugqty"))
  13927. {
  13928. //if ( ds_list2_clod.getColumn(row, "drugqty") != ds_hidden_item5_clod.getColumn(0, "drugqty"))
  13929. //{
  13930. // lf_fSetTotDrugQtyAmt();
  13931. //}
  13932. }
  13933. else if ( col == obj.getBindCellIndex("body", "tims"))
  13934. {
  13935. //if ( ds_list2_clod.getColumn(row, "tims") != ds_hidden_item5_clod.getColumn(0, "tims"))
  13936. //{
  13937. // lf_fSetTotDrugQtyAmt();
  13938. //}
  13939. grp_biz.grd_clodhist.setCellPos(grp_biz.grd_clodhist.getBindCellIndex("body", "edidayno"));
  13940. grp_biz.grd_clodhist.showEditor(true);
  13941. }
  13942. else if ( col == obj.getBindCellIndex("body", "dayno"))
  13943. {
  13944. lf_fSetTotDrugQtyAmt();
  13945. }
  13946. else if ( col == obj.getBindCellIndex("body", "edidayno"))
  13947. {
  13948. lf_fSetTotDrugQtyAmt();
  13949. ds_list2_clod.rowposition = row + 1;
  13950. grp_biz.grd_clodhist.setCellPos(grp_biz.grd_clodhist.getBindCellIndex("body", "edidrugqty"));
  13951. grp_biz.grd_clodhist.showEditor(true);
  13952. }
  13953. }
  13954. if (e.ctrlKey && e.keycode == 67 && ( obj.currentcol == obj.getBindCellIndex("Body","grupcalcscorcd") ||
  13955. obj.currentcol == obj.getBindCellIndex("Body","snglcalcscorcd") ||
  13956. obj.currentcol == obj.getBindCellIndex("Body","basecd") ||
  13957. obj.currentcol == obj.getBindCellIndex("Body","hngnm")) ) {
  13958. system.setClipboard("CF_TEXT", obj.getCellText(obj.currentrow, obj.currentcol));
  13959. }
  13960. }
  13961. /****************************************************************************************
  13962. * Argument : onenterdown
  13963. * Description : 처방 그리드 enter key 이벤트
  13964. ****************************************************************************************/
  13965. function grp_biz_grd_clodhist_onenterdown(obj:Grid, e:GridEditEventInfo)
  13966. {
  13967. var col = e.col;
  13968. var row = e.row;
  13969. var adjtresncd = ds_list2_clod.getColumn(row, "adjtresncd");
  13970. var cmbAdjtresncd = "";
  13971. var newcd = "";
  13972. if (utlf_isNull(adjtresncd) || adjtresncd == "-")
  13973. {
  13974. cmbAdjtresncd = ds_hidden_list2_clodstat.getColumn(0, "cmbAdjtresncd");
  13975. if (cmbAdjtresncd)
  13976. {
  13977. }
  13978. else
  13979. {
  13980. var sppiz01000 = new Object();
  13981. sppiz01000.sCdCls = "aftin";
  13982. sppiz01000.sCdid = adjtresncd;
  13983. sppiz01000.sAdjtresndesc = "";
  13984. var objArg = frmf_modal("SPPIZ01000","SPPIZ01000", sppiz01000, "", "", "", "", "", "", "", "", "", "M");
  13985. newcd = objArg.sCdid;
  13986. newdesc = objArg.sAdjtresndesc;
  13987. if (utlf_isNull(newcd) || newcd == "-")
  13988. {
  13989. lf_fCancelClodStatusChng();
  13990. return;
  13991. }
  13992. }
  13993. }
  13994. if (col == obj.getBindCellIndex("Body", "grupcalcscorcd") || col == obj.getBindCellIndex("Body","snglcalcscorcd") || col == obj.getBindCellIndex("Body","basecd") || col == obj.getBindCellIndex("Body","hngnm"))
  13995. {
  13996. lf_fSetSrchCalcScorCd();
  13997. }
  13998. }
  13999. function grp_biz_btn_clopadd_onclick(obj:Button, e:ClickEventInfo)
  14000. {
  14001. lf_fOutOrderGridInsertRow();
  14002. }
  14003. function grp_biz_btn_clopdel_onclick(obj:Button, e:ClickEventInfo)
  14004. {
  14005. lf_fClopGridDeleteRow();
  14006. }
  14007. function grp_biz_swt_spclmemo_case_spclspec_grd_clsphist_ondropdown(obj:Grid, e:GridEditEventInfo)
  14008. {
  14009. var row = e.row;
  14010. var rowstatus = ds_list3_clsp.getRowType(row);
  14011. if (rowstatus == 1 || rowstatus == 4 || rowstatus == 8) { // DB에 저장된 data인 경우
  14012. } else { // 신규로 추가한 경우
  14013. var unitflag = ds_list3_clsp.getColumn(row,"unitflag");
  14014. if (unitflag == "J") {
  14015. if (ds_list3_clsp.getColumn(row,"spclcd") == "JT001") {
  14016. // 확인코드의 경우 전용 팝업창을 사용하므로 특정내역 Grid에서 수정하지 않는다.
  14017. fds_init_P0117.filterstr = "cdid=='JT001'";
  14018. } else {
  14019. fds_init_P0117.filterstr = "minval == 'J' && cdid != 'JT001'";
  14020. }
  14021. } else {
  14022. fds_init_P0117.filterstr = "minval == 'M' && cdid != 'MX999'";
  14023. }
  14024. }
  14025. }
  14026. /****************************************************************************************
  14027. * Argument : function
  14028. * Description : 환경 초기화 이벤트
  14029. ****************************************************************************************/
  14030. function fClearSetInfo()
  14031. {
  14032. var msg = sysf_messageBox("환경저장 데이터가 모두 삭제 됩니다.","Q003");
  14033. if (msg == 6) { // 6세미만 요율을 적용한다.
  14034. grdf_DelUuee(grp_biz.grd_cldihist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  14035. grp_biz.grd_cldihist.formatid = "default";
  14036. grdf_DelUuee(grp_biz.grd_clodhist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  14037. grp_biz.grd_clodhist.formatid = "default";
  14038. grdf_DelUuee(grp_biz.grd_oprcphist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  14039. grp_biz.grd_oprcphist.formatid = "default";
  14040. grdf_DelUuee(grp_biz.swt_spclmemo.case_spclspec.grd_clsphist, ds_hidden_listval_uuee, frmf_getScreenID(), "cf_Cnfm_"+frmf_getScreenID());
  14041. grp_biz.swt_spclmemo.case_spclspec.grd_clsphist.formatid = "default";
  14042. grdf_GetUuee("ds_send_listval_uuee", "ds_hidden_listval_uuee",frmf_getScreenID(), "cf_Uuee_"+frmf_getScreenID());
  14043. }
  14044. }
  14045. /****************************************************************************************
  14046. * Argument : button
  14047. * Description : 환경초기화 버튼 이벤트
  14048. ****************************************************************************************/
  14049. function grp_biz_grp_sea02_button3_onclick(obj:Button, e:ClickEventInfo)
  14050. {
  14051. fClearSetInfo();
  14052. }
  14053. function fGetLglydisInfo() {
  14054. var dsnm = dsf_createDsRow("ds_cond_lglydisinfo", [{col:"reptflag", type:"STRING", size:256 , val : ""}]);
  14055. var oParam = {};
  14056. oParam.id = "TRASB02301";
  14057. oParam.service = "infcmngtapp.LglyDisMngt";
  14058. oParam.method = "reqGetLglyDisInfo";
  14059. oParam.inds = "req="+dsnm;
  14060. oParam.outds = "ds_lglydisinfo=list";
  14061. oParam.async = true;
  14062. oParam.callback = "cf_TRASB02301";
  14063. tranf_submit(oParam);
  14064. }
  14065. function cf_TRASB02301(sSvcId, nErrorCode, sErrorMsg) {
  14066. if(nErrorCode < 0) return;
  14067. ds_lglydisinfo.addColumn("fromdiag","string");
  14068. ds_lglydisinfo.addColumn("todiag","string");
  14069. var fromicd10cd = "";
  14070. var toicd10cd = "";
  14071. for (var i=0,rcount = ds_lglydisinfo.rowcount; i < rcount; i++){
  14072. var fromicd10cd = String(ds_lglydisinfo.getColumn(i,"fromicd10cd"));
  14073. var toicd10cd = String(ds_lglydisinfo.getColumn(i,"toicd10cd"));
  14074. ds_lglydisinfo.setColumn(i,"fromdiag", fromicd10cd.indexOf(".") > -1 ? fromicd10cd.split(".")[0] : fromicd10cd )
  14075. ds_lglydisinfo.setColumn(i,"todiag", toicd10cd.indexOf(".") > -1 ? toicd10cd.split(".")[0] : toicd10cd )
  14076. }
  14077. }
  14078. function grp_sea00_cmb_orddrid_onitemchanged(obj:Combo, e:ItemChangeEventInfo)
  14079. {
  14080. var arrRow = new Array();
  14081. arrRow[0] = 0;
  14082. grdf_setStatus(grp_biz.grd_cldihist, "U", arrRow);
  14083. }]]></Script>