| 1 | IBCRHBA ;ALB/ARH - RATES: UPLOAD HOST FILES (AWP) ; 11-FEB-1997
 | 
|---|
| 2 |  ;;2.0;INTEGRATED BILLING;**52,106**;21-MAR-94
 | 
|---|
| 3 |  ;;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 | AWP ; OPTION: upload an AVERAGE WHOLESALE PRICE file from a VMS file into ^XTMP
 | 
|---|
| 7 |  ;
 | 
|---|
| 8 |  N DIR,DIRUT,DUOUT,X,Y,IBI,IBFILE,IBPATH,IBXRF,IBXRF1,IBXRF2,IBFLINE,IBX,IBY
 | 
|---|
| 9 |  N IBEFDT,IBNDC,IBNDCO,IBNDCN,IBCHGD,IBCHGC,IBCHG
 | 
|---|
| 10 |  W !!,"Upload Average Wholesale Price list from a host file:   'AWP_mmddyy.TXT'"
 | 
|---|
| 11 |  ;
 | 
|---|
| 12 |  S IBPATH=$$PATH I IBPATH<0 Q
 | 
|---|
| 13 |  I '$$FNDHOST(IBPATH) Q
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 |  S DIR("?")="Enter a AWP Host File Name of format:  'AWP_mmddyy.TXT'"
 | 
|---|
| 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 ($E(IBFILE,1,4)'="AWP_")!($E(IBFILE,5,10)'?6N)!($E(IBFILE,11,14)'=".TXT") W !!,"**** File not an AWP file: must be 'AWP_mmddyy.TXT'.",! Q
 | 
|---|
| 19 |  ;
 | 
|---|
| 20 |  S IBEFDT=$$GETDT^IBCRU1(2961101) I IBEFDT'?7N Q
 | 
|---|
| 21 |  W !!,"All NDC numbers will be added to the Charge Master with the form of: 5n-4n-2n.",!!
 | 
|---|
| 22 |  ;
 | 
|---|
| 23 |  S IBXRF="IBCR UPLOAD "_IBFILE I '$$CONT(IBXRF) Q
 | 
|---|
| 24 |  I '$$CONT1 Q
 | 
|---|
| 25 |  ;
 | 
|---|
| 26 |  ;
 | 
|---|
| 27 |  D OPEN^%ZISH("AWP UPLOAD",IBPATH,IBFILE,"R") I POP W !!,"**** Unable to open ",IBPATH,IBFILE,! Q
 | 
|---|
| 28 |  ;
 | 
|---|
| 29 |  U IO(0) W !!,"Loading ",IBFILE," into ^XTMP "
 | 
|---|
| 30 |  ;
 | 
|---|
| 31 |  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 "."
 | 
|---|
| 32 |  ;
 | 
|---|
| 33 |  D CLOSE^%ZISH("AWP UPLOAD")
 | 
|---|
| 34 |  ;
 | 
|---|
| 35 |  ;
 | 
|---|
| 36 |  W !!,"Done. ",(IBI-1)," lines processed."
 | 
|---|
| 37 |  W !,"The following files were created, they will be purged in 2 days:" D DISP1^IBCRHU1(IBXRF)
 | 
|---|
| 38 |  Q
 | 
|---|
| 39 |  ;
 | 
|---|
| 40 | ENDF() N IBX S IBX=1 I $T,IBFLINE'="" S IBX=0
 | 
|---|
| 41 |  I $$STATUS^%ZISH S IBX=1
 | 
|---|
| 42 |  I IBFLINE?36"9" S IBX=1
 | 
|---|
| 43 |  I 'IBX,IBFLINE'?36N D
 | 
|---|
| 44 |  . U IO(0)
 | 
|---|
| 45 |  . W !!,"**** Error while reading file: line not expected format (36 numeric characters):"
 | 
|---|
| 46 |  . W !!,"Line Length=",$L(IBFLINE)," characters" W:IBFLINE="" ?40,"Line read is null"
 | 
|---|
| 47 |  . W !,"LINE='",IBFLINE,"'",!!,"Upload Aborted!"
 | 
|---|
| 48 |  . S IBX=1 H 7 U IO
 | 
|---|
| 49 |  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
 | 
|---|
| 50 |  Q IBX
 | 
|---|
| 51 |  ;
 | 
|---|
| 52 | PARSE ; process a single line from a AWP file: parse out into individual fields and store the line in XTMP
 | 
|---|
| 53 |  ;
 | 
|---|
| 54 |  S IBNDCO=$E(IBFLINE,1,11) ; old NDC #
 | 
|---|
| 55 |  S IBNDCN=$E(IBFLINE,12,22) ; new NDC #
 | 
|---|
| 56 |  S IBCHGD=$E(IBFLINE,23,25) ; charge, dollars
 | 
|---|
| 57 |  S IBCHGC=$E(IBFLINE,26,29) ; charge, cents
 | 
|---|
| 58 |  Q
 | 
|---|
| 59 |  ;
 | 
|---|
| 60 | STORE ;
 | 
|---|
| 61 |  S IBXRF1=IBXRF
 | 
|---|
| 62 |  S IBXRF2="AWP"
 | 
|---|
| 63 |  S IBNDC=IBNDCO I +IBNDCN S IBNDC=IBNDCN
 | 
|---|
| 64 |  S IBNDC=$$NDCSET(IBNDC)
 | 
|---|
| 65 |  S IBCHG=IBCHGD_"."_IBCHGC
 | 
|---|
| 66 |  S IBCHG=+$FN(+IBCHG,"",2)
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 |  D SET
 | 
|---|
| 69 |  ;
 | 
|---|
| 70 |  Q
 | 
|---|
| 71 |  ;
 | 
|---|
| 72 | SET ;
 | 
|---|
| 73 |  N IBX S IBX=$G(^XTMP(IBXRF1,0)) I IBX="" D SETHDR
 | 
|---|
| 74 |  S $P(^XTMP(IBXRF1,0),U,4)=+$P(IBX,U,4)+1
 | 
|---|
| 75 |  S ^XTMP(IBXRF1,IBXRF2)=(+$G(^XTMP(IBXRF1,IBXRF2))+1)_U_3
 | 
|---|
| 76 |  S ^XTMP(IBXRF1,IBXRF2,IBI)=IBNDC_U_IBEFDT_U_U_IBCHG
 | 
|---|
| 77 |  Q
 | 
|---|
| 78 |  ;
 | 
|---|
| 79 | SETHDR ;
 | 
|---|
| 80 |  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)
 | 
|---|
| 81 |  S ^XTMP(IBXRF1,0)=$$FMADD^XLFDT(DT,2)_U_DT_U_IBX
 | 
|---|
| 82 |  Q
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 | CONT(XREF) ; check for existing files stored in XREF with same host file name
 | 
|---|
| 85 |  ; returns true if user wants to continue and these files are deleted
 | 
|---|
| 86 |  ;
 | 
|---|
| 87 |  N ARR,IBX,IBY,IBZ,DIR,DIRUT,DUOUT,X,Y S ARR=0,IBZ=1 W !
 | 
|---|
| 88 |  ;
 | 
|---|
| 89 |  D DISP1^IBCRHU1(XREF,.ARR)
 | 
|---|
| 90 |  ;
 | 
|---|
| 91 |  I +ARR S IBZ=0 D  W !
 | 
|---|
| 92 |  . 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."
 | 
|---|
| 93 |  . S DIR("A")="Delete the above files and continue with upload",DIR(0)="Y" D ^DIR K DIR
 | 
|---|
| 94 |  . ;
 | 
|---|
| 95 |  . I Y=1 S IBZ=1,IBX="" F  S IBX=$O(ARR(IBX)) Q:IBX=""  K ^XTMP(IBX) W "."
 | 
|---|
| 96 |  ;
 | 
|---|
| 97 |  Q IBZ
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 | CONT1() ; get final OK to start upload
 | 
|---|
| 100 |  N IBZ,DIR,DIRUT,DUOUT,X,Y S IBZ=0 W !
 | 
|---|
| 101 |  S DIR("A")="Proceed with upload now",DIR(0)="Y" D ^DIR K DIR I Y=1 S IBZ=1
 | 
|---|
| 102 |  Q IBZ
 | 
|---|
| 103 |  ;
 | 
|---|
| 104 | PATH() ; return directory or -1
 | 
|---|
| 105 |  N IBPATH,DIR,DIRUT,DUOUT,X,Y S IBPATH=""
 | 
|---|
| 106 |  S DIR("?",1)="Enter the full path specification where the host files may be found"
 | 
|---|
| 107 |  S DIR("?")="or press return for the default directory "_$$PWD^%ZISH
 | 
|---|
| 108 |  S DIR(0)="FO^3:60",DIR("A")="Enter the file path",DIR("B")=$$PWD^%ZISH D ^DIR K DIR
 | 
|---|
| 109 |  S IBPATH=$S($D(DUOUT)!$D(DTOUT):-1,1:Y)
 | 
|---|
| 110 |  Q IBPATH
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 | FNDHOST(IBPATH) ; find and display any host files available for upload: 1 if some, 0 none found
 | 
|---|
| 113 |  N IBX,IBY,IBZ S IBZ=0
 | 
|---|
| 114 |  ;
 | 
|---|
| 115 |  W !,"AWP Host files available for upload in ",IBPATH,":",!!
 | 
|---|
| 116 |  S IBX("AWP*")="",IBZ=$$LIST^%ZISH(IBPATH,"IBX","IBY")
 | 
|---|
| 117 |  I 'IBZ W "**** No AWP files found ",IBPATH,"AWP_mmddyy.TXT, can not continue.",!
 | 
|---|
| 118 |  I +IBZ S IBX="" F  S IBX=$O(IBY(IBX)) Q:IBX=""  W ?30,$P(IBX,";",1),!
 | 
|---|
| 119 |  Q IBZ
 | 
|---|
| 120 |  ;
 | 
|---|
| 121 | NDCSET(X) ; parse NDC number:  raw form from VMS file is 11 numbers, parsed to 5n-4n-2n
 | 
|---|
| 122 |  N Y S Y="" S Y=$E(X,1,5)_"-"_$E(X,6,9)_"-"_$E(X,10,11)
 | 
|---|
| 123 |  Q Y
 | 
|---|