source: FOIAVistA/tag/r/INTEGRATED_BILLING-IB-PRQ--IBD--IBQ--PRQS/IBCRHBA.m@ 628

Last change on this file since 628 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.5 KB
Line 
1IBCRHBA ;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 ;
6AWP ; 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 ;
40ENDF() 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 ;
52PARSE ; 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 ;
60STORE ;
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 ;
72SET ;
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 ;
79SETHDR ;
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 ;
84CONT(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 ;
99CONT1() ; 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 ;
104PATH() ; 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 ;
112FNDHOST(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 ;
121NDCSET(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
Note: See TracBrowser for help on using the repository browser.