| [613] | 1 | IBCRHBT ;LL/ELZ - RATES: UPLOAD HOST FILES (TP) ; 19-MAR-1999 | 
|---|
|  | 2 | ;;2.0;INTEGRATED BILLING;**115,140**;21-MAR-94 | 
|---|
|  | 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified. | 
|---|
|  | 4 | ; | 
|---|
|  | 5 | TP ; OPTION: upload an IBAT file from a VMS file into ^XTMP | 
|---|
|  | 6 | ; | 
|---|
|  | 7 | N DIR,DIRUT,DUOUT,X,Y,IBI,IBFILE,IBPATH,IBXRF,IBLOC,IBXRF1,IBXRF2,IBFLINE,IBX,IBY,IBTYPE,POP,IBCHRG,IBCODE | 
|---|
|  | 8 | N IBCPT,IBEFDT,IBTRDT,IBINACT,IBMOD,IBCHG,IBPATH | 
|---|
|  | 9 | W !!,"Upload the IBAT from a host file:   'IBATaxxxx.TXT'   w/a = C for CPT or D for DRG",!,?49," & xxxx = year effective",! | 
|---|
|  | 10 | ; | 
|---|
|  | 11 | S IBPATH=$$PATH I IBPATH<0 Q | 
|---|
|  | 12 | I '$$FNDHOST(IBPATH) Q | 
|---|
|  | 13 | ;I '$$FNDHOST Q | 
|---|
|  | 14 | ; | 
|---|
|  | 15 | S DIR("?")="Enter an IBAT Host File Name of format:  'IBATaxxxx.TXT'   w/xxxx = year effective" | 
|---|
|  | 16 | S DIR(0)="FO^3:60",DIR("A")="Enter a Host File Name" D ^DIR K DIR Q:$D(DIRUT)  S IBFILE=Y | 
|---|
|  | 17 | ; | 
|---|
|  | 18 | I $$CHECK(IBFILE) Q | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | ; | 
|---|
|  | 21 | S IBXRF="IBCR UPLOAD "_IBFILE,IBLOC="" I '$$CONT(IBXRF) Q | 
|---|
|  | 22 | I '$$CONT1 Q | 
|---|
|  | 23 | ; | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | D OPEN^%ZISH("IBAT UPLOAD",IBPATH,IBFILE,"R") I POP W !!,"**** Unable to open ",IBPATH,IBFILE,! Q | 
|---|
|  | 26 | ; | 
|---|
|  | 27 | U IO(0) W !!,"Loading ",IBFILE," into ^XTMP " | 
|---|
|  | 28 | ; | 
|---|
|  | 29 | S IBI=0 F  S IBI=IBI+1 U IO R IBFLINE:5 Q:$$ENDF  D PARSE,STORE I '(IBI#100) U IO(0) W "." | 
|---|
|  | 30 | ; | 
|---|
|  | 31 | D CLOSE^%ZISH("IBAT UPLOAD") | 
|---|
|  | 32 | ; | 
|---|
|  | 33 | ; | 
|---|
|  | 34 | W !!,"Done. ",(IBI-1)," lines processed." | 
|---|
|  | 35 | W !,"The following files were created, they will be purged in 2 days:" D DISP1^IBCRHU1(IBXRF) | 
|---|
|  | 36 | Q | 
|---|
|  | 37 | ; | 
|---|
|  | 38 | ENDF() N IBX S IBX=1 I $T,IBFLINE'="" S IBX=0 | 
|---|
|  | 39 | I $$STATUS^%ZISH S IBX=1 | 
|---|
|  | 40 | I 'IBX,IBFLINE'?3U29N D | 
|---|
|  | 41 | . U IO(0) | 
|---|
|  | 42 | . W !!,"**** Error while reading file: line not expected format" | 
|---|
|  | 43 | . W !,"(3 upper case letters & 29 numeric characters):" | 
|---|
|  | 44 | . W !!,"Line Length=",$L(IBFLINE)," characters" W:IBFLINE="" ?40,"Line read is null" | 
|---|
|  | 45 | . W !,"LINE='",IBFLINE,"'",!!,"Upload Aborted!" | 
|---|
|  | 46 | . S IBX=1 H 7 U IO | 
|---|
|  | 47 | I IBI=1,IBFLINE="" U IO(0) W !!,"First line of file has no data, can not continue!" S IBX=1 H 7 U IO | 
|---|
|  | 48 | Q IBX | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | PARSE ; process a single line from an IBAT file: parse out into individual fields and store the line in XTMP | 
|---|
|  | 51 | ; | 
|---|
|  | 52 | ; format: 3 alpha letters and 29 numbers | 
|---|
|  | 53 | ; | 
|---|
|  | 54 | S IBTYPE=$E(IBFLINE,1,3) ; type, either CPT or DRG | 
|---|
|  | 55 | S IBCODE=$E(IBFLINE,4,8) ; CPT procedure or DRG code | 
|---|
|  | 56 | I IBTYPE="DRG" S IBCODE=IBTYPE_+IBCODE | 
|---|
|  | 57 | S IBCHRG=$E(IBFLINE,9,16) ; charge | 
|---|
|  | 58 | S IBEFDT=$E(IBFLINE,17,24) ; effective date | 
|---|
|  | 59 | S IBTRDT=$E(IBFLINE,25,32) ; termination date | 
|---|
|  | 60 | S IBCS=$$CS(IBTYPE) | 
|---|
|  | 61 | Q | 
|---|
|  | 62 | ; | 
|---|
|  | 63 | STORE ; | 
|---|
|  | 64 | S IBXRF1=IBXRF_"  "_IBLOC | 
|---|
|  | 65 | ; | 
|---|
|  | 66 | S IBMOD="",IBEFDT=$$DATE(IBEFDT),IBINACT="" I IBTRDT'=999999,+IBTRDT S IBINACT=$$DATE(IBTRDT) | 
|---|
|  | 67 | ; | 
|---|
|  | 68 | I +IBCHRG S IBXRF2=IBTYPE,IBCHG=$E(IBCHRG,1,6)_"."_$E(IBCHRG,7,8) D SET ; charge | 
|---|
|  | 69 | ; | 
|---|
|  | 70 | Q | 
|---|
|  | 71 | ; | 
|---|
|  | 72 | DATE(X) ; reformats dates | 
|---|
|  | 73 | N Y,DTOUT,%DT | 
|---|
|  | 74 | I X S %DT="X" D ^%DT | 
|---|
|  | 75 | Q $G(Y,X) | 
|---|
|  | 76 | SET ; | 
|---|
|  | 77 | N IBX S IBX=$G(^XTMP(IBXRF1,0)) I IBX="" D SETHDR | 
|---|
|  | 78 | S $P(^XTMP(IBXRF1,0),U,4)=+$P(IBX,U,4)+1 | 
|---|
|  | 79 | S ^XTMP(IBXRF1,IBXRF2)=(+$G(^XTMP(IBXRF1,IBXRF2))+1)_U_$S(IBTYPE="CPT":2,1:4)_U_IBCS | 
|---|
|  | 80 | S ^XTMP(IBXRF1,IBXRF2,IBI)=IBCODE_U_IBEFDT_U_IBINACT_U_+IBCHG | 
|---|
|  | 81 | Q | 
|---|
|  | 82 | ; | 
|---|
|  | 83 | SETHDR ; | 
|---|
|  | 84 | N IBX S IBX="IB upload of Host file "_IBFILE_", on "_$$HTE^XLFDT($H,2)_" by "_$P($G(^VA(200,+$G(DUZ),0)),U,1) | 
|---|
|  | 85 | S ^XTMP(IBXRF1,0)=$$FMADD^XLFDT(DT,2)_U_DT_U_IBX | 
|---|
|  | 86 | Q | 
|---|
|  | 87 | ; | 
|---|
|  | 88 | CONT(XREF) ; check for existing files stored in XREF with same host file name | 
|---|
|  | 89 | ; returns true if user wants to continue and these files are deleted | 
|---|
|  | 90 | ; | 
|---|
|  | 91 | N ARR,IBX,IBY,IBZ,DIR,DIRUT,DUOUT,X,Y S ARR=0,IBZ=1 W ! | 
|---|
|  | 92 | ; | 
|---|
|  | 93 | D DISP1^IBCRHU1(XREF,.ARR) | 
|---|
|  | 94 | ; | 
|---|
|  | 95 | I +ARR S IBZ=0 D  W ! | 
|---|
|  | 96 | . W !!,"The above files already exist in XTMP." S DIR("?")="Enter either 'Y' or 'N'.  This files use the same name as the new upload would use and therefore must be deleted before the upload can proceed." | 
|---|
|  | 97 | . S DIR("A")="Delete the above files and continue with upload",DIR(0)="Y" D ^DIR K DIR | 
|---|
|  | 98 | . ; | 
|---|
|  | 99 | . I Y=1 S IBZ=1,IBX="" F  S IBX=$O(ARR(IBX)) Q:IBX=""  K ^XTMP(IBX) W "." | 
|---|
|  | 100 | ; | 
|---|
|  | 101 | Q IBZ | 
|---|
|  | 102 | ; | 
|---|
|  | 103 | ; | 
|---|
|  | 104 | CONT1() ; get final OK to start upload | 
|---|
|  | 105 | N IBZ,DIR,DIRUT,DUOUT,X,Y S IBZ=0 W ! | 
|---|
|  | 106 | S DIR("A")="Proceed with upload now",DIR(0)="Y" D ^DIR K DIR I Y=1 S IBZ=1 | 
|---|
|  | 107 | Q IBZ | 
|---|
|  | 108 | ; | 
|---|
|  | 109 | PATH() ; return directory or -1 | 
|---|
|  | 110 | N IBPATH,DIR,DIRUT,DUOUT,X,Y S IBPATH="" | 
|---|
|  | 111 | S DIR("?",1)="Enter the full path specification where the host files may be found" | 
|---|
|  | 112 | S DIR("?")="or press return for the default directory "_$$PWD^%ZISH | 
|---|
|  | 113 | S DIR(0)="FO^3:60",DIR("A")="Enter the file path",DIR("B")=$$PWD^%ZISH D ^DIR K DIR | 
|---|
|  | 114 | S IBPATH=$S($D(DUOUT)!$D(DTOUT):-1,1:Y) | 
|---|
|  | 115 | Q IBPATH | 
|---|
|  | 116 | ; | 
|---|
|  | 117 | FNDHOST(IBPATH) ; find and display any host files available for upload: 1 if some, 0 none found | 
|---|
|  | 118 | N IBX,IBY,IBZ,IBQ S (IBZ,IBQ)=0 | 
|---|
|  | 119 | ; | 
|---|
|  | 120 | W !,"IBAT Host files available for upload in: ",IBPATH,!! | 
|---|
|  | 121 | S IBX("IBAT*.TXT")="",IBZ=$$LIST^%ZISH(IBPATH,"IBX","IBY") | 
|---|
|  | 122 | I +IBZ S IBQ=IBZ,IBX="" F  S IBX=$O(IBY(IBX)) Q:IBX=""  W ?30,$P(IBX,";",1),! | 
|---|
|  | 123 | K IBX,IBY S IBX("TP*.TXT")="",IBZ=$$LIST^%ZISH(IBPATH,"IBX","IBY") | 
|---|
|  | 124 | I 'IBZ,'IBQ W "**** No IBAT files found ",IBPATH,"IBATaxxxx.TXT, can not continue.",! | 
|---|
|  | 125 | I +IBZ S IBX="" F  S IBX=$O(IBY(IBX)) Q:IBX=""  W ?30,$P(IBX,";",1),! | 
|---|
|  | 126 | Q $S(IBQ:IBQ,1:IBZ) | 
|---|
|  | 127 | ; | 
|---|
|  | 128 | CS(X) ; find charge set ien from X (name) | 
|---|
|  | 129 | N IBX S X=$S(X="CPT":"TP-OPT",X="DRG":"TP-INPT",1:""),IBX=0 | 
|---|
|  | 130 | I X'="" S IBX=$O(^IBE(363.1,"B",X,IBX)) | 
|---|
|  | 131 | Q IBX | 
|---|
|  | 132 | ; | 
|---|
|  | 133 | CHECK(IBFILE) ; returns if file name is not in correct format | 
|---|
|  | 134 | N IBZ S IBZ=1 | 
|---|
|  | 135 | I ($E(IBFILE,1,4)="IBAT"),(($E(IBFILE,5)="C")!($E(IBFILE,5)="D")),($E(IBFILE,6,9)?4N),($E(IBFILE,10,13)=".TXT") S IBZ=0 | 
|---|
|  | 136 | I IBZ,($E(IBFILE,1,2)="TP"),(($E(IBFILE,3)="C")!($E(IBFILE,3)="D")),($E(IBFILE,4,7)?4N),($E(IBFILE,8,11)=".TXT") S IBZ=0 | 
|---|
|  | 137 | I IBZ W !!,"****  File not an IBAT file: must be 'IBATaxxxx.TXT'.",! | 
|---|
|  | 138 | Q IBZ | 
|---|