1 | PSAUDP ;BIR/LTL,JMB-Nightly Background Job - CONT'D ;7/23/97
|
---|
2 | ;;3.0; DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**6,3,12,14,25,64,66**; 10/24/97;Build 2
|
---|
3 | ;
|
---|
4 | ;Reference to ^PS(57.6 are covered by IA #772
|
---|
5 | PICKLST ;ask for parameters PSA*3*25
|
---|
6 | I '$D(^PSD(58.812,1,"T","B","UNIT DOSE"))!('$D(^PSD(58.812,1,"T"))) D
|
---|
7 | .S ^PSD(58.812,1,"T",0)="^58.8123A^1^1"
|
---|
8 | .S X="T-2W" D ^%DT S ^PSD(58.812,1,"T",1,0)="UNIT DOSE^"_Y_"^",X="T-1W" D ^%DT S $P(^PSD(58.812,1,"T",1,0),"^",3)=Y K X,Y
|
---|
9 | .S ^PSD(58.812,1,"T","B","UNIT DOSE",1)=""
|
---|
10 | S XX=$O(^PSD(58.812,1,"T","B","UNIT DOSE",0)) Q:XX'>0 S JOBIEN=XX D NOW^%DTC S STRTDATE=%,PARDATA=$G(^PSD(58.812,1,"T",JOBIEN,0))
|
---|
11 | S PSABGN=$P(PARDATA,"^",2),PSAEND=$P(PARDATA,"^",3)
|
---|
12 | S X="T-7" D ^%DT I Y'=PSAEND G DONE
|
---|
13 | S $P(^PSD(58.812,1,"T",JOBIEN,0),"^",2)=PSAEND,X1=PSAEND,X2=7 D C^%DTC S $P(^PSD(58.812,1,"T",JOBIEN,0),"^",3)=X ;Reset date parameters
|
---|
14 | ;Go back two weeks, gather 1 weeks worth of data
|
---|
15 | S PSAD0=PSABGN-.000001
|
---|
16 | S PSAEND=PSAEND_".2359"
|
---|
17 | DATE ;Loop through dates
|
---|
18 | S PSAD0=$O(^PS(57.6,PSAD0)) G DONE:PSAD0'>0 G DONE:PSAD0>PSAEND K PSAD1
|
---|
19 | WRD S PSAD1=$S('$D(PSAD1):$O(^PS(57.6,PSAD0,1,0)),1:$O(^PS(57.6,PSAD0,1,PSAD1))) G DATE:PSAD1'>0 K PSAD2
|
---|
20 | PVDR ;Loop through providers
|
---|
21 | S PSAD2=$S('$D(PSAD2):$O(^PS(57.6,PSAD0,1,PSAD1,1,0)),1:$O(^PS(57.6,PSAD0,1,PSAD1,1,PSAD2))) G WRD:PSAD2'>0 K PSAD3
|
---|
22 | DRG S PSAD3=$S('$D(PSAD3):$O(^PS(57.6,PSAD0,1,PSAD1,1,PSAD2,1,0)),1:$O(^PS(57.6,PSAD0,1,PSAD1,1,PSAD2,1,PSAD3))) G PVDR:PSAD3'>0 S DATA=$G(^PS(57.6,PSAD0,1,PSAD1,1,PSAD2,1,PSAD3,0))
|
---|
23 | S PSAIP=PSAD1,PSA50=PSAD3,PSADT=PSAD0 K PSALOC
|
---|
24 | LOC S PSALOC=$S('$D(PSALOC):$O(^PSD(58.8,"AB",PSAD1,0)),1:$O(^PSD(58.8,"AB",PSAD1,PSALOC))) G DRG:PSALOC'>0 I $D(^PSD(58.8,PSALOC,"I")),$P($G(^PSD(58.8,PSALOC,"I")),"^")'>DT G LOC
|
---|
25 | S PSAQTY=$P($G(DATA),"^",2)-$P($G(DATA),"^",4)
|
---|
26 | I $D(^PSD(58.8,PSALOC,1,PSA50)) D PROCESS
|
---|
27 | G LOC
|
---|
28 | ;
|
---|
29 | Q
|
---|
30 | DONE ;
|
---|
31 | END K DA,DATA,DIC,DIE,DR,PSA50,PSAD0,PSAD1,PSAD2,PSAD3,PSADT,PSAIP,PSALOC,PSANUM,PSAQTY,X,Y,PSABGN,PSAEND,PARDATA,JOBIEN,X
|
---|
32 | Q
|
---|
33 | PROCESS ;Stuff last UD dispensing fld with DT
|
---|
34 | F L +^PSD(58.8,PSALOC,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q
|
---|
35 | S DIE="^PSD(58.8,",DA=PSALOC,DR="27////"_PSADT D ^DIE K DIE,DA,DR
|
---|
36 | ;Subtract dispensing from balance
|
---|
37 | S PSABAL=$P($G(^PSD(58.8,PSALOC,1,PSA50,0)),"^",4)
|
---|
38 | S $P(^PSD(58.8,PSALOC,1,PSA50,0),"^",4)=PSABAL-$G(PSAQTY)
|
---|
39 | ;If no monthly activity node, add node with beginning balance.
|
---|
40 | I '$D(^PSD(58.8,PSALOC,1,PSA50,5,+$E(PSADT,1,5)*100,0)) D
|
---|
41 | .S DIC="^PSD(58.8,PSALOC,1,PSA50,5,",DIC(0)="L",DIC("P")=$P(^DD(58.8001,20,0),U,2),(X,DINUM)=$E(PSADT,1,5)*100,DA(2)=PSALOC,DA(1)=PSA50
|
---|
42 | .S DIC("DR")="1////^S X=$G(PSABAL)",DLAYGO=58.8 D ^DIC K DIC,DLAYGO
|
---|
43 | .;Add current month's node and stuff beginning & ending balance.
|
---|
44 | .S DIC="^PSD(58.8,PSALOC,1,PSA50,5,",DIC(0)="L",(X,DINUM)=$E(PSADT-100-(+$E(PSADT,4,5)=1*8800),1,5)*100,DA(2)=PSALOC,DA(1)=PSA50,DLAYGO=58.8 D ^DIC K DIC,DLAYGO S DA=+Y
|
---|
45 | .S DIE="^PSD(58.8,PSALOC,1,PSA50,5,",DA(2)=PSALOC,DA(1)=PSA50,DR="3////^S X=$G(PSABAL)" D ^DIE K DIE
|
---|
46 | ;Stuff total dispensed
|
---|
47 | S DIE="^PSD(58.8,PSALOC,1,PSA50,5,",DA(2)=PSALOC,DA(1)=PSA50,DA=$E(PSADT,1,5)*100,DR="9////^S X=$P($G(^(0)),U,6)+PSAQTY" D ^DIE K DIE,DA
|
---|
48 | ;Get next transaction node number
|
---|
49 | F L +^PSD(58.81,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q ;; << *66 RJS
|
---|
50 | FIND S PSANUM=$P(^PSD(58.81,0),"^",3)+1 I $D(^PSD(58.81,PSANUM)) S $P(^PSD(58.81,0),"^",3)=$P(^PSD(58.81,0),"^",3)+1 G FIND
|
---|
51 | ;Add next transaction node with data.
|
---|
52 | S DIC="^PSD(58.81,",DIC(0)="L",DLAYGO=58.81,(DINUM,X)=PSANUM D ^DIC K DIC,DLAYGO
|
---|
53 | S DIE="^PSD(58.81,",DA=PSANUM
|
---|
54 | S DR="1////2;2////^S X=PSALOC;3////^S X=PSADT;4////^S X=PSA50;5////^S X=PSAQTY;9////^S X=$G(PSABAL)" D ^DIE K DIE,DA
|
---|
55 | L -^PSD(58.81,0) ;; >> *66 RJS
|
---|
56 | ;Add activity node
|
---|
57 | S DIC="^PSD(58.8,PSALOC,1,PSA50,4,",DIC(0)="L",(X,DINUM)=PSANUM,DIC("P")=$P(^DD(58.8001,19,0),"^",2),DA(2)=PSALOC,DA(1)=PSA50,DLAYGO=58.8 D ^DIC K DA,DIC,DLAYGO
|
---|
58 | L -^PSD(58.8,PSALOC,0)
|
---|
59 | Q
|
---|