1 | PSOCPBK3 ;BIR/GN-Copay Back Bill for Automated-release refills ;10/6/05 4:57pm
|
---|
2 | ;;7.0;OUTPATIENT PHARMACY;**217**;DEC 1997
|
---|
3 | ;External reference to ^XUSEC supported by DBIA 10076
|
---|
4 | ;External reference to IBARX supported by DBIA 125
|
---|
5 | ;External reference to $$PROD^XUPROD(1) supported by DBIA 4440
|
---|
6 | ;
|
---|
7 | N NAMSP,DTOUT,DUOUT,ZTSK,ZTRTN,ZTIO,ZTDTH,ZTDESC,QUIT,RUNOPT,JOBN,Y
|
---|
8 | S NAMSP=$$NAMSP
|
---|
9 | S JOBN="Back Bill"
|
---|
10 | ;
|
---|
11 | L +^XTMP(NAMSP):0 I '$T D Q
|
---|
12 | . D BMES^XPDUTL(JOBN_" job is already running. Halting...")
|
---|
13 | . D MES^XPDUTL("")
|
---|
14 | . D QUIT
|
---|
15 | ;
|
---|
16 | I '$D(^XTMP(NAMSP)) D INITXTMP(NAMSP,"BACK BILLING of unbilled copays for refills via OPAI, PSO*7*217",90) ;90 day life
|
---|
17 | S QUIT=0
|
---|
18 | ;
|
---|
19 | ;ques 1, if running from mumps prompt
|
---|
20 | I '$D(XPDQUES("POS1")) D I QUIT D QUIT Q
|
---|
21 | . ;selected cancel run at last install, dont allow to run manually
|
---|
22 | . I $G(^XTMP(NAMSP,0,"LAST"))["CANCEL" D Q
|
---|
23 | . . S QUIT=1
|
---|
24 | . . W !!,*7,"The last install of this patch you selected to NOT Run Back-Billing"
|
---|
25 | . . W !,"If you have changed your mind, you must re-install the patch to run",!!
|
---|
26 | . K DIR
|
---|
27 | . S DIR("A",1)="****************** SELECT RUN OPTION ******************"
|
---|
28 | . S DIR("A")="Do you want to run the Back-Billing process? "
|
---|
29 | . S DIR(0)="YA^^"
|
---|
30 | . D ^DIR I $D(DTOUT)!($D(DUOUT)) W !,"Halting..." S QUIT=1 Q
|
---|
31 | . S RUNOPT=Y
|
---|
32 | . S:'RUNOPT QUIT=1
|
---|
33 | ;
|
---|
34 | ;ques 1, if running from kids install
|
---|
35 | I $D(XPDQUES("POS1")) D I 'RUNOPT D QUIT Q
|
---|
36 | . S RUNOPT=XPDQUES("POS1")
|
---|
37 | . S:'RUNOPT ^XTMP(NAMSP,0,"LAST")="CANCEL RUN^"_$$NOW^XLFDT_"^^^"
|
---|
38 | . D BMES^XPDUTL("***** SELECTED "_$S('RUNOPT:"NOT ",1:"")_"TO RUN BACK-BILLING *****")
|
---|
39 | ;
|
---|
40 | I $G(^XTMP(NAMSP,0,"LAST"))["COMPLETED" D Q
|
---|
41 | . W !!,*7,"This job has been run before to completion on "
|
---|
42 | . W $$FMTE^XLFDT($P($G(^XTMP(NAMSP,0,"LAST")),"^",2)),!!
|
---|
43 | . D QUIT
|
---|
44 | ;
|
---|
45 | ;ques 2, if running from mumps prompt
|
---|
46 | I '$D(XPDQUES("POS2")) D I 'ZTDTH D QUIT Q
|
---|
47 | . K DIR
|
---|
48 | . S DIR("A")="Enter when to Queue the "_JOBN_" job to run in date@time format "
|
---|
49 | . S DIR("B")="NOW"
|
---|
50 | . S DIR(0)="D^::%DT"
|
---|
51 | . S DIR("?")="Enter when to start the job. The default is Now. You can enter a date and time in the format like this: 081505@3:30p"
|
---|
52 | . D ^DIR I $D(DTOUT)!($D(DUOUT)) W !,"Halting..." S ZTDTH="" Q
|
---|
53 | . S ZTDTH=$$FMTH^XLFDT(Y)
|
---|
54 | ;
|
---|
55 | ;ques 2, if running from kids install
|
---|
56 | I $D(XPDQUES("POS2")) S ZTDTH=$$FMTH^XLFDT(XPDQUES("POS2"))
|
---|
57 | ;
|
---|
58 | D BMES^XPDUTL("===================================================")
|
---|
59 | D MES^XPDUTL("Queuing background job to "_JOBN_" unbilled refills...")
|
---|
60 | D MES^XPDUTL("Start time: "_$$HTE^XLFDT(ZTDTH))
|
---|
61 | D MES^XPDUTL("===================================================")
|
---|
62 | I ZTDTH="" D BMES^XPDUTL(JOBN_" NOT QUEUED") D QUIT Q
|
---|
63 | ;
|
---|
64 | I $P($G(^XTMP(NAMSP,0,"LAST")),"^")="STOP" D
|
---|
65 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="RUN^"_$$NOW^XLFDT
|
---|
66 | E D
|
---|
67 | . S ^XTMP(NAMSP,0,"LAST")="RUN^"_$$NOW^XLFDT_"^^^"
|
---|
68 | ;
|
---|
69 | S ZTRTN="EN^PSOCPBK3",ZTIO=""
|
---|
70 | S ZTDESC="Background job to "_JOBN_" unbilled copays for refills via OPAI"
|
---|
71 | S ZTSAVE("JOBN")=""
|
---|
72 | L -^XTMP(NAMSP)
|
---|
73 | D ^%ZTLOAD
|
---|
74 | D:$D(ZTSK)
|
---|
75 | . D MES^XPDUTL("*** Task #"_ZTSK_" Queued! ***")
|
---|
76 | . D BMES^XPDUTL("")
|
---|
77 | D BMES^XPDUTL("")
|
---|
78 | K XPDQUES
|
---|
79 | Q
|
---|
80 | QUIT ;
|
---|
81 | L -^XTMP(NAMSP)
|
---|
82 | Q
|
---|
83 | EN ;
|
---|
84 | N NAMSP S NAMSP=$$NAMSP
|
---|
85 | ;if can't get Lock, then already running.
|
---|
86 | L +^XTMP(NAMSP):3 I '$T D Q
|
---|
87 | . S:$D(ZTQUEUED) ZTREQ="@"
|
---|
88 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="LOCKED^"_$$NOW^XLFDT
|
---|
89 | ;
|
---|
90 | N PSODT,RXP,PSOTEXT,XX,YY,PSOCNT,PSOSTART,PSOEND,PSOVETS,PSOTRX,XIEN
|
---|
91 | N PSOSCMX,PSODFN,PSOREL,PSOAMT,FOUND,V24,PSOTRF,PSOEND2,PSOSTRT2,CC
|
---|
92 | N PSOTIME,PSOSTNM,PSOS1,PSOINST,I,PSOTC,PSOCNTS,LIN,%,X1,XMY,STO
|
---|
93 | D NOW^%DTC S (Y,PSOS1)=% D DD^%DT S PSOSTART=Y
|
---|
94 | S PSOSTRT2=$$FMTE^XLFDT(%,"1PS")
|
---|
95 | I '$G(DT) S DT=$$DT^XLFDT
|
---|
96 | S PSODT=+$P($G(^XTMP(NAMSP,0,"LAST")),"^",3)
|
---|
97 | S RXP=+$P($G(^XTMP(NAMSP,0,"LAST")),"^",4)
|
---|
98 | ;
|
---|
99 | ;get 1st occurence of install date of patch PSO*7*156 (OPAI)
|
---|
100 | S XIEN=+$O(^XPD(9.7,"B","PSO*7.0*156",0))
|
---|
101 | S:'PSODT PSODT=+$P($G(^XPD(9.7,XIEN,1)),"^",3)
|
---|
102 | I 'PSODT D Q
|
---|
103 | . S ^XTMP(NAMSP,0,.1)="OPAI PATCH PSO*7*156 IS NOT INSTALLED"
|
---|
104 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="COMPLETED^"_$$NOW^XLFDT
|
---|
105 | . D MAIL3^PSOCPBK5(^XTMP(NAMSP,0,.1))
|
---|
106 | ;
|
---|
107 | ;check if any division is on v2.4 (OPAI interface)
|
---|
108 | S V24=0
|
---|
109 | F XX=0:0 S XX=$O(^PS(59,XX)) Q:'XX D Q:V24
|
---|
110 | . S:+$G(^PS(59,XX,"DISP"))=2.4 V24=1
|
---|
111 | I 'V24 D Q
|
---|
112 | . S ^XTMP(NAMSP,0,.2)="OPAI IS INSTALLED BUT IS NOT TURNED ON"
|
---|
113 | . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="COMPLETED^"_$$NOW^XLFDT
|
---|
114 | . D MAIL3^PSOCPBK5(^XTMP(NAMSP,0,.2))
|
---|
115 | ;
|
---|
116 | S (PSOTRX,PSOTRF)=1
|
---|
117 | N STOP K ^XTMP(NAMSP,0,"STOP") S STOP=0 ;init stop flag to 0
|
---|
118 | F CC=1:1 S PSODT=$O(^PSRX("AL",PSODT)) Q:'PSODT D Q:STOP
|
---|
119 | . I CC#100=0,$D(^XTMP(NAMSP,0,"STOP")) D Q
|
---|
120 | . . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="STOP^"_$$NOW^XLFDT,STOP=1
|
---|
121 | . F PSOTRX=PSOTRX+1:1 S RXP=$O(^PSRX("AL",PSODT,RXP)) Q:'RXP D
|
---|
122 | .. ;save last date & fill info
|
---|
123 | .. S $P(^XTMP(NAMSP,0,"LAST"),"^",3,5)=PSODT_"^"_RXP_"^"_PSOTRX
|
---|
124 | .. S PSODFN=$P($G(^PSRX(RXP,0)),"^",2)
|
---|
125 | .. Q:('PSODFN)!('$D(^DPT(PSODFN,0))) ;quit, no valid DFN info
|
---|
126 | .. D XTYPE^PSOCPBK4
|
---|
127 | .. Q:+PSOSCMX=0 ;quit, Exempt or deceased
|
---|
128 | .. ;search refills only, ignore 0=orig fill
|
---|
129 | .. F YY=0:0 S YY=$O(^PSRX("AL",PSODT,RXP,YY)) Q:'YY D ADDBILL^PSOCPBK4
|
---|
130 | Q:STOP
|
---|
131 | ;
|
---|
132 | S PSOCNT=0
|
---|
133 | D BILLIT^PSOCPBK4 Q:STOP
|
---|
134 | D TOTAL^PSOCPBK4
|
---|
135 | S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="COMPLETED^"_$$NOW^XLFDT
|
---|
136 | D MAIL^PSOCPBK5
|
---|
137 | D MAIL2^PSOCPBK5
|
---|
138 | D MAILAAC^PSOCPBK5
|
---|
139 | L -^XTMP(NAMSP)
|
---|
140 | S:$D(ZTQUEUED) ZTREQ="@"
|
---|
141 | K JOBN
|
---|
142 | Q
|
---|
143 | ;
|
---|
144 | STATUS ;show status of job running
|
---|
145 | I $$ST D
|
---|
146 | . W !,"Currently processing:"
|
---|
147 | . I ^XTMP($$NAMSP,0,"LAST")["COMPLETED" D
|
---|
148 | . . W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
|
---|
149 | . W !?5,"Released Date > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",3)
|
---|
150 | . W !?5," RX # > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",4)
|
---|
151 | . W !?5," TOTAL RX's > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",5),!
|
---|
152 | . E D
|
---|
153 | . I ^XTMP($$NAMSP,0,"LAST")["COMPLETED" D
|
---|
154 | . . W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
|
---|
155 | Q
|
---|
156 | ;
|
---|
157 | STOP ;stop job command
|
---|
158 | I $$ST S ^XTMP($$NAMSP,0,"STOP")="" D
|
---|
159 | . W !,"Outpatient RX Copay Tally Job - set to STOP Soon"
|
---|
160 | . W !!,"Check Status to be sure it has stopped and is not running..."
|
---|
161 | . W !," (D STATUS^PSOCPBK3)"
|
---|
162 | Q
|
---|
163 | ST() ;status
|
---|
164 | L +^XTMP($$NAMSP):3 I $T D Q 0
|
---|
165 | . L -^XTMP($$NAMSP)
|
---|
166 | . W !,"*** NOT CURRENTLY RUNNING! ***",!
|
---|
167 | Q 1
|
---|
168 | INITXTMP(NAMSP,TITLE,LIFE) ;create ^Xtmp according to SAC std
|
---|
169 | N BEGDT,PURGDT
|
---|
170 | S BEGDT=$$NOW^XLFDT()
|
---|
171 | S PURGDT=$$FMADD^XLFDT(BEGDT,LIFE)
|
---|
172 | S ^XTMP(NAMSP,0)=PURGDT_"^"_BEGDT_"^"_TITLE
|
---|
173 | Q
|
---|
174 | NAMSP() ;
|
---|
175 | Q $T(+0)
|
---|