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
|
---|