PSGWPOST ;BHAM/CML-POST INIT CONVERSION ROUTINE ; 27 Dec 93 / 11:12 AM
;;2.3; Automatic Replenishment/Ward Stock ;;4 JAN 94
START ;
S XQABT4=$H
W !!,"Beginning post-init..." S RRFLG=0 D POST1,POST2,POST3,POST4,^PSGWPST1
FINAL ;Set AR/WS node in file #59.7
I '$D(^PS(59.7,1,0)) S X=$S($D(^DD("SITE"))[0:"UNKNOWN",^("SITE")]"":^("SITE"),1:"UNKNOWN"),$P(^PS(59.7,0),"^",3,4)="1^1",^(1,0)=X,^PS(59.7,"B",X,1)=""
S $P(^PS(59.7,1,59.99),"^")="2.3",$P(^(59.99),"^",2)=INITDT S:RRFLG $P(^(59.99),"^",6)=INITDT
QUIT D NOW^%DTC S (DONE,Y)=% X ^DD("DD") S PRT=Y I $D(START) D TIME
W !!,"Post-init completed ",PRT,".",!,"AR/WS Version 2.3 has been successfully installed!",!!,"Initialization process took ",MIN," minutes."
S XQABT5=$H,X="PSGWINIY" X ^%ZOSF("TEST") I $T D @("^"_X)
K AOU,CNT,INITDT,ITM,REA,RET,RRFLG,DONE,MIN,PRT,START,X1,X2,%,X,Y,XQABT1,XQABT2,XQABT3,XQABT4,XQABT5 Q
TIME S X=START,X1=DONE,Y=$E(X1_"000",9,10)-$E(X_"000",9,10)*60+$E(X1_"00000",11,12)-$E(X_"00000",11,12),X2=X,X=$P(X,".",1)'=$P(X1,".",1) D ^%DTC:X S X=X*1440+Y,MIN=X Q
POST1 ;Convert RETURN REASON subfield to new location as multiple
I $D(^PS(59.7,1,59.99)),$P(^(59.99),"^",6)]"" W !!,"Post-init conversion of RETURN REASON subfield has already been done!" Q
W !!,"Now moving existing RETURN REASON data to new location"
F AOU=0:0 S AOU=$O(^PSI(58.1,AOU)) Q:'AOU F ITM=0:0 S ITM=$O(^PSI(58.1,AOU,1,ITM)) Q:'ITM F RET=0:0 S RET=$O(^PSI(58.1,AOU,1,ITM,3,RET)) Q:'RET I $D(^PSI(58.1,AOU,1,ITM,3,RET,0)) D MOVE
S RRFLG=1 Q
MOVE ;
S REA=$P(^PSI(58.1,AOU,1,ITM,3,RET,0),"^",3)
I REA]"" S ^PSI(58.1,AOU,1,ITM,3,RET,1,0)="^58.152S^1^1",^PSI(58.1,AOU,1,ITM,3,RET,1,1,0)=REA W "." S $P(^PSI(58.1,AOU,1,ITM,3,RET,0),"^",3)=""
Q
POST2 ;Re-index "IU" cross-reference in the Drug file (#50)
W !!,"Now re-indexing the ""IU"" cross-reference in the Drug file (#50)"
K ^PSDRUG("IU") S CNT=0 F DRG=0:0 S DRG=$O(^PSDRUG(DRG)) Q:'DRG I $D(^PSDRUG(DRG,2)),$P(^(2),"^",3)]"" S ^PSDRUG("IU",$P(^(2),"^",3),DRG)="" S CNT=CNT+1 W:CNT#50=0 "."
K DRG Q
POST3 ;Re-initialize sort keys for AOU Inventory Groups
Q:'$O(^PSI(58.2,0))
W !!,"Now re-initializing sort keys for AOUs in AOU Inventory Group file (#58.2)" D IG^PSGWUTL1
Q
POST4 ;Check for duplicate entries in ITEM subfile (#58.11) of 58.1
W !!,"Now checking for duplicate entries in the ITEM subfile of the Pharmacy",!,"AOU Stock file."
D NOW^%DTC S PSGWDT=X,CNT=0
F AOU=0:0 S AOU=$O(^PSI(58.1,AOU)) Q:'AOU F DRG=0:0 S DRG=$O(^PSI(58.1,AOU,1,"B",DRG)) Q:'DRG S ITM=$O(^PSI(58.1,AOU,1,"B",DRG,0)) I $O(^PSI(58.1,AOU,1,"B",DRG,ITM)) S ACNT=0 D
.S ITMT=ITM,IDT=$P($G(^PSI(58.1,AOU,1,ITMT,0)),"^",3) S:IDT=""!(IDT>PSGWDT) ACNT=1 F S ITMT=$O(^PSI(58.1,AOU,1,"B",DRG,ITMT)) Q:'ITMT D ACHK I ACNT'<2 S CNT=CNT+1
I CNT=0 W !!,"No duplicate entries exist !" G EPST4
W !!,"Duplicate entries exist.",!,"A MailMan message is being sent to you regarding the problem." D
.K XMY S ^TMP("PSGWDUP",$J,1,0)="Duplicate entries exist in the ITEM subfile (#58.11) of the PHARMACY AOU"
.S ^TMP("PSGWDUP",$J,2,0)="STOCK file (#58.1). Please execute the following procedures to clean the",^TMP("PSGWDUP",$J,3,0)="subfile:",(^TMP("PSGWDUP",$J,4,0),^TMP("PSGWDUP",$J,5,0))=""
.S ^TMP("PSGWDUP",$J,6,0)=" 1. Run the option Duplicate Entry Report to obtain a listing of the",^TMP("PSGWDUP",$J,7,0)=" duplicates with their inventory, on-demand, and return data."
.S ^TMP("PSGWDUP",$J,8,0)=""
.S ^TMP("PSGWDUP",$J,9,0)=" 2. With the information provided on the report, choose the duplicate",^TMP("PSGWDUP",$J,10,0)=" that needs to be removed.",^TMP("PSGWDUP",$J,11,0)=""
.S ^TMP("PSGWDUP",$J,12,0)=" 3. Enter a phrase such as ""DO NOT USE"" in the LOCATION field of the",^TMP("PSGWDUP",$J,13,0)=" inactivated item. The option Stock Items - Enter/Edit will allow"
.S ^TMP("PSGWDUP",$J,14,0)=" one to edit the LOCATION field.",(^TMP("PSGWDUP",$J,15,0),^TMP("PSGWDUP",$J,16,0))=""
.S ^TMP("PSGWDUP",$J,17,0)=" 4. Inactivate the chosen item in the option Inactivate AOU Stock Item.",^TMP("PSGWDUP",$J,18,0)=""
.S ^TMP("PSGWDUP",$J,19,0)="The Purge Dispensing Data option will purge the item from the subfile 100 days from the date of the item's last activity."
.S XMSUB="Duplicate entries in ITEM subfile.",XMTEXT="^TMP(""PSGWDUP"",$J," S XMDUZ="INPATIENT PHARMACY AR/WS"
.S XMY(DUZ)="" F PSGWDUZ=0:0 S PSGWDUZ=$O(^XUSEC("PSGWMGR",PSGWDUZ)) Q:'PSGWDUZ S XMY(PSGWDUZ)=""
.D ^XMD K XMY,^TMP("PSGWDUP",$J),XMDUZ,XMTEXT,XMSUB,PSGWDUZ
EPST4 K ACNT,IDT,ITMT,PSGWDT
Q
ACHK ;** continue checking for number of active items
S IDT=$P($G(^PSI(58.1,AOU,1,ITMT,0)),"^",3) S:IDT=""!(IDT>PSGWDT) ACNT=ACNT+1
Q
PSGWPOST ;BHAM/CML-POST INIT CONVERSION ROUTINE ; 27 Dec 93 / 11:12 AM
+1 ;;2.3; Automatic Replenishment/Ward Stock ;;4 JAN 94
START ;
+1 SET XQABT4=$HOROLOG
+2 WRITE !!,"Beginning post-init..."
SET RRFLG=0
DO POST1
DO POST2
DO POST3
DO POST4
DO ^PSGWPST1
FINAL ;Set AR/WS node in file #59.7
+1 IF '$DATA(^PS(59.7,1,0))
SET X=$SELECT($DATA(^DD("SITE"))[0:"UNKNOWN",^("SITE")]"":^("SITE"),1:"UNKNOWN")
SET $PIECE(^PS(59.7,0),"^",3,4)="1^1"
SET ^(1,0)=X
SET ^PS(59.7,"B",X,1)=""
+2 SET $PIECE(^PS(59.7,1,59.99),"^")="2.3"
SET $PIECE(^(59.99),"^",2)=INITDT
IF RRFLG
SET $PIECE(^(59.99),"^",6)=INITDT
QUIT DO NOW^%DTC
SET (DONE,Y)=%
XECUTE ^DD("DD")
SET PRT=Y
IF $DATA(START)
DO TIME
+1 WRITE !!,"Post-init completed ",PRT,".",!,"AR/WS Version 2.3 has been successfully installed!",!!,"Initialization process took ",MIN," minutes."
+2 SET XQABT5=$HOROLOG
SET X="PSGWINIY"
XECUTE ^%ZOSF("TEST")
IF $TEST
DO @("^"_X)
+3 KILL AOU,CNT,INITDT,ITM,REA,RET,RRFLG,DONE,MIN,PRT,START,X1,X2,%,X,Y,XQABT1,XQABT2,XQABT3,XQABT4,XQABT5
QUIT
TIME SET X=START
SET X1=DONE
SET Y=$EXTRACT(X1_"000",9,10)-$EXTRACT(X_"000",9,10)*60+$EXTRACT(X1_"00000",11,12)-$EXTRACT(X_"00000",11,12)
SET X2=X
SET X=$PIECE(X,".",1)'=$PIECE(X1,".",1)
IF X
DO ^%DTC
SET X=X*1440+Y
SET MIN=X
QUIT
POST1 ;Convert RETURN REASON subfield to new location as multiple
+1 IF $DATA(^PS(59.7,1,59.99))
IF $PIECE(^(59.99),"^",6)]""
WRITE !!,"Post-init conversion of RETURN REASON subfield has already been done!"
QUIT
+2 WRITE !!,"Now moving existing RETURN REASON data to new location"
+3 FOR AOU=0:0
SET AOU=$ORDER(^PSI(58.1,AOU))
IF 'AOU
QUIT
FOR ITM=0:0
SET ITM=$ORDER(^PSI(58.1,AOU,1,ITM))
IF 'ITM
QUIT
FOR RET=0:0
SET RET=$ORDER(^PSI(58.1,AOU,1,ITM,3,RET))
IF 'RET
QUIT
IF $DATA(^PSI(58.1,AOU,1,ITM,3,RET,0))
DO MOVE
+4 SET RRFLG=1
QUIT
MOVE ;
+1 SET REA=$PIECE(^PSI(58.1,AOU,1,ITM,3,RET,0),"^",3)
+2 IF REA]""
SET ^PSI(58.1,AOU,1,ITM,3,RET,1,0)="^58.152S^1^1"
SET ^PSI(58.1,AOU,1,ITM,3,RET,1,1,0)=REA
WRITE "."
SET $PIECE(^PSI(58.1,AOU,1,ITM,3,RET,0),"^",3)=""
+3 QUIT
POST2 ;Re-index "IU" cross-reference in the Drug file (#50)
+1 WRITE !!,"Now re-indexing the ""IU"" cross-reference in the Drug file (#50)"
+2 KILL ^PSDRUG("IU")
SET CNT=0
FOR DRG=0:0
SET DRG=$ORDER(^PSDRUG(DRG))
IF 'DRG
QUIT
IF $DATA(^PSDRUG(DRG,2))
IF $PIECE(^(2),"^",3)]""
SET ^PSDRUG("IU",$PIECE(^(2),"^",3),DRG)=""
SET CNT=CNT+1
IF CNT#50=0
WRITE "."
+3 KILL DRG
QUIT
POST3 ;Re-initialize sort keys for AOU Inventory Groups
+1 IF '$ORDER(^PSI(58.2,0))
QUIT
+2 WRITE !!,"Now re-initializing sort keys for AOUs in AOU Inventory Group file (#58.2)"
DO IG^PSGWUTL1
+3 QUIT
POST4 ;Check for duplicate entries in ITEM subfile (#58.11) of 58.1
+1 WRITE !!,"Now checking for duplicate entries in the ITEM subfile of the Pharmacy",!,"AOU Stock file."
+2 DO NOW^%DTC
SET PSGWDT=X
SET CNT=0
+3 FOR AOU=0:0
SET AOU=$ORDER(^PSI(58.1,AOU))
IF 'AOU
QUIT
FOR DRG=0:0
SET DRG=$ORDER(^PSI(58.1,AOU,1,"B",DRG))
IF 'DRG
QUIT
SET ITM=$ORDER(^PSI(58.1,AOU,1,"B",DRG,0))
IF $ORDER(^PSI(58.1,AOU,1,"B",DRG,ITM))
SET ACNT=0
Begin DoDot:1
+4 SET ITMT=ITM
SET IDT=$PIECE($GET(^PSI(58.1,AOU,1,ITMT,0)),"^",3)
IF IDT=""!(IDT>PSGWDT)
SET ACNT=1
FOR
SET ITMT=$ORDER(^PSI(58.1,AOU,1,"B",DRG,ITMT))
IF 'ITMT
QUIT
DO ACHK
IF ACNT'<2
SET CNT=CNT+1
End DoDot:1
+5 IF CNT=0
WRITE !!,"No duplicate entries exist !"
GOTO EPST4
+6 WRITE !!,"Duplicate entries exist.",!,"A MailMan message is being sent to you regarding the problem."
Begin DoDot:1
+7 KILL XMY
SET ^TMP("PSGWDUP",$JOB,1,0)="Duplicate entries exist in the ITEM subfile (#58.11) of the PHARMACY AOU"
+8 SET ^TMP("PSGWDUP",$JOB,2,0)="STOCK file (#58.1). Please execute the following procedures to clean the"
SET ^TMP("PSGWDUP",$JOB,3,0)="subfile:"
SET (^TMP("PSGWDUP",$JOB,4,0),^TMP("PSGWDUP",$JOB,5,0))=""
+9 SET ^TMP("PSGWDUP",$JOB,6,0)=" 1. Run the option Duplicate Entry Report to obtain a listing of the"
SET ^TMP("PSGWDUP",$JOB,7,0)=" duplicates with their inventory, on-demand, and return data."
+10 SET ^TMP("PSGWDUP",$JOB,8,0)=""
+11 SET ^TMP("PSGWDUP",$JOB,9,0)=" 2. With the information provided on the report, choose the duplicate"
SET ^TMP("PSGWDUP",$JOB,10,0)=" that needs to be removed."
SET ^TMP("PSGWDUP",$JOB,11,0)=""
+12 SET ^TMP("PSGWDUP",$JOB,12,0)=" 3. Enter a phrase such as ""DO NOT USE"" in the LOCATION field of the"
SET ^TMP("PSGWDUP",$JOB,13,0)=" inactivated item. The option Stock Items - Enter/Edit will allow"
+13 SET ^TMP("PSGWDUP",$JOB,14,0)=" one to edit the LOCATION field."
SET (^TMP("PSGWDUP",$JOB,15,0),^TMP("PSGWDUP",$JOB,16,0))=""
+14 SET ^TMP("PSGWDUP",$JOB,17,0)=" 4. Inactivate the chosen item in the option Inactivate AOU Stock Item."
SET ^TMP("PSGWDUP",$JOB,18,0)=""
+15 SET ^TMP("PSGWDUP",$JOB,19,0)="The Purge Dispensing Data option will purge the item from the subfile 100 days from the date of the item's last activity."
+16 SET XMSUB="Duplicate entries in ITEM subfile."
SET XMTEXT="^TMP(""PSGWDUP"",$J,"
SET XMDUZ="INPATIENT PHARMACY AR/WS"
+17 SET XMY(DUZ)=""
FOR PSGWDUZ=0:0
SET PSGWDUZ=$ORDER(^XUSEC("PSGWMGR",PSGWDUZ))
IF 'PSGWDUZ
QUIT
SET XMY(PSGWDUZ)=""
+18 DO ^XMD
KILL XMY,^TMP("PSGWDUP",$JOB),XMDUZ,XMTEXT,XMSUB,PSGWDUZ
End DoDot:1
EPST4 KILL ACNT,IDT,ITMT,PSGWDT
+1 QUIT
ACHK ;** continue checking for number of active items
+1 SET IDT=$PIECE($GET(^PSI(58.1,AOU,1,ITMT,0)),"^",3)
IF IDT=""!(IDT>PSGWDT)
SET ACNT=ACNT+1
+2 QUIT