PSSPOIM1 ;BIR/RTR,WRT - Manual create of Orderable Item continued ;Jun 23, 2020@13:14:33
;;1.0;PHARMACY DATA MANAGEMENT;**29,38,47,141,153,159,166,191,198,204,220,242**;9/30/97;Build 19
;
CHK S PSNO=0 I $G(PSMAN) W !!,"Matching ",PSNAME,!," to",!,SPHOLD," ",$P($G(^PS(50.606,+DOSEPTR,0)),"^"),!
I '$G(PSMAN) S PSMC=$P($G(^PS(50.7,PSSP,0)),"^") W !!,"Matching ",PSNAME,!," to",!,PSMC," ",$P($G(^PS(50.606,+$P(^PS(50.7,PSSP,0),"^",2),0)),"^"),!
K DIR S DIR(0)="Y",DIR("B")="YES",DIR("A")="Is this OK" D ^DIR
S:Y=0 PSNO=1 I Y'=1,'PSNO S PSOUT=1
;Add trace of whether inactive date is present.
;If one is added erroneously by code logic when the
;orderable item should remain active,
;the inactive date will be deleted at INACT^PSSPOIM1.
K ^TMP($J,"INACTIVE_DATE")
N PSOITMP
S PSOITMP=$S($G(PSPOINT):PSPOINT,$G(PSSP):PSSP,1:"")
I PSOITMP]"" S ^TMP($J,"INACTIVE_DATE",PSOITMP)=$P($G(^PS(50.7,PSOITMP,0)),"^",4)
K PSMAN,PSOITMP
Q
END K ^TMP($J,"PSSOO"),PSSSSS,PSCREATE,^TMP("PSSLOOP",$J),^TMP($J,"INACTIVE_DATE")
K AAA,ANS,APLU,COMM,DA,DIC,DIE,DOSEFORM,DOSEFV,DOSEPTR,DR,FFF,MATCH,NEWSP,NODE,NOFLAG,OTH,POINT,PSCNT,PSIEN,PSMAN,PSMC,PSNAME,PSNO,PSSP,PSND,PSOUT,SPHOLD,SPR,TMPTR,TT,VAGEN,X,Y,ZZ,PSOOOUT,PSXDATE,PSXADATE,PSXSDATE,AAAAA,BBBBB,ZXX,PSXDDATE
K PSSDACT,PSSSACT,PSSAACT,PSSINACT,PSSDTENT,PSSCOMP,PSSDGDT,PSSDGIDL,PSSARR,PSSACT,PSSNEWIA
Q
MESS W !!,"This option enables you to match Dispense Drugs to an entry in the Pharmacy",!,"Orderable Item file, or create a new Pharmacy Orderable Item entry for a",!,"Dispense Drug.",! Q
MESSZ S ^TMP("PSSLOOP",$J,DUZ)="" W !!,"This option is for matching IV Additives, IV Solutions, and all Dispense Drugs",!,"marked with an I, O, or U in the Application Packages' Use field to an",!,"Orderable Item."
W !,"You will need to keep accessing this option until all drugs are matched.",!,"A check will be done every time this option is exited to see if the matching",!,"process is complete.",!!
K DIR S DIR(0)="E" D ^DIR K DIR I X["^"!($D(DTOUT)) S PSOUT=1
Q
CHECK W !!!,"Checking Drug files, please wait..."
S X1=DT,X2=-365 D C^%DTC S PSZXDATE=X,DONEFLAG=1
F FFFF=0:0 S FFFF=$O(^PSDRUG(FFFF)) Q:'FFFF!('DONEFLAG) S QQNM=$P($G(^PSDRUG(FFFF,0)),"^") I QQNM'="",$D(^PSDRUG("B",QQNM)) D I ZZG I USAGE["O"!(USAGE["I")!(USAGE["U") I '$P($G(^PSDRUG(FFFF,2)),"^") S DONEFLAG=0
.S USAGE=$P($G(^PSDRUG(FFFF,2)),"^",3)
.S ZZG=1 S PSZZDATE=+$P($G(^PSDRUG(FFFF,"I")),"^") I PSZZDATE,PSZZDATE<PSZXDATE S ZZG=0
I DONEFLAG=1 D
.F QQQ=0:0 S QQQ=$O(^PS(52.6,QQQ)) Q:'QQQ!('DONEFLAG) S PSZNAME=$P($G(^PS(52.6,QQQ,0)),"^") I PSZNAME'="",$D(^PS(52.6,"B",PSZNAME)),$P($G(^PS(52.6,QQQ,0)),"^",2),'$P($G(^(0)),"^",11) D I ZZG S DONEFLAG=0
..S ZZG=1 S PSZZDATE=+$P($G(^PS(52.6,QQQ,"I")),"^") I PSZZDATE,PSZZDATE<PSZXDATE S ZZG=0
.I DONEFLAG F QQQ=0:0 S QQQ=$O(^PS(52.7,QQQ)) Q:'QQQ!('DONEFLAG) S PSZNAME=$P($G(^PS(52.7,QQQ,0)),"^") I PSZNAME'="",$D(^PS(52.7,"B",PSZNAME)),$P($G(^PS(52.7,QQQ,0)),"^",2),'$P($G(^(0)),"^",11) D I ZZG S DONEFLAG=0
..S ZZG=1 S PSZZDATE=+$P($G(^PS(52.7,QQQ,"I")),"^") I PSZZDATE,PSZZDATE<PSZXDATE S ZZG=0
MAIL I DONEFLAG W !!!,?3,"You are finished matching to the Orderable Item File!",!!,"A clean-up job is being queued now, and when it is finished, you will"
I W !,"receive a mail message informing you of its completion.",! K DIR S DIR(0)="E",DIR("A")="Press Return to continue" D ^DIR K DIR
I $G(DONEFLAG) S PSSOMAIL=1,PSOUDUZ=DUZ S ZTRTN="DATE^PSSPOIM1",ZTIO="",ZTDTH=$H,ZTDESC="ORDERABLE ITEM CLEAN UP",ZTSAVE("DUZ")="",ZTSAVE("PSSOMAIL")="" D ^%ZTLOAD
I 'DONEFLAG W $C(7),$C(7),!!?5,"There are still Drugs not matched, you will need to come back",!?5,"and continue matching Drugs!",! K DIR S DIR(0)="E",DIR("A")="Press Return to continue" D ^DIR K DIR
K DONEFLAG,QQQ,QQNM,PSZZDATE,PSZXDATE,ZZG,USAGE,FFFF,PSZNAME Q
OTHER W @IOF W !,"There are other Dispense Drugs with the same VA Generic Name and same Dose",!,"Form already matched to orderable items. Choose a number to match, or enter",!,"'^' to enter a new one.",!!?6,"Disp. drug -> ",PSNAME,! Q
EN(PSVAR) ;
N PSSDACT,PSSSACT,PSSAACT,PSSINACT,PSSDTENT
N PSSCOMP,PSSDGDT,PSSDGIDL,PSSARR,PSSACT
W !?3,"Now editing Orderable Item:",!?3,$P(^PS(50.7,PSVAR,0),"^")," ",$P($G(^PS(50.606,+$P(^(0),"^",2),0)),"^")
W ! K DIE,DA,DR N MFLG S PSBEFORE1=+$P(^PS(50.7,PSVAR,0),"^",2),PSAFTER=0,PSINORDE=""
S DIE="^PS(50.7,",DA=PSVAR,DR="5;6" D ^DIE K DIE,DA,DR I $D(DTOUT)!($D(Y)>10) Q
D INACT
I $G(Y)["^"!($D(DTOUT))!($G(DUOUT)) Q
D EN1
Q
;
INACT ;
;check to see if an inactive date was added by code logic
;(not by a user) but was erroneously added since there is
;an active component for this orderable item
;
;The inactive date can be erroneously added at EN1+15^PSSPOIDT
;when there is only one active component on an orderable item
;and that component is being edited.
;
;The logic in PSSPOIDT cannot be changed without restructuring
;much of the core logic. Hence, the decision to insert the
;following check to determine whether the inactive date
;was not present when the user invoked option PSS MAINTAIN
;ORDERABLE ITEM and was erroneously added to file 50.7 by
;EN1^PSSPOIDT.
;
D CHECK^PSSPOID2(PSVAR)
S PSBEFORE=$P(^PS(50.7,PSVAR,0),"^",4)
I $G(^TMP($J,"INACTIVE_DATE",PSVAR))="",PSBEFORE]"" D
. ;Information returned by CHECK^PSSPOID2(PSVAR):
. ; PSSDACT = array of active dispense drugs
. ; PSSSACT = array of active solutions
. ; PSSAACT = array of active additives
. I $O(PSSDACT(0))!($O(PSSSACT(0)))!($O(PSSAACT(0))) D
. . ;Attempt to delete the inactive date since it
. . ;may have been added erroneously.
. . ;An inactive date may still be present after this call
. . ;if all components have an inactive date and
. . ;and one or more of those dates are in the future
. . S DIE="^PS(50.7,",DA=PSVAR,DR=".04////@" D ^DIE K DIE,DA,DR
. . S PSBEFORE=$P(^PS(50.7,PSVAR,0),"^",4)
;
;Check to see if an inactive date did not exist when user
;invoked the option and one has been added that is incorrect.
;This can occur if all components have an inactive date on
;file, and all inactive dates are today or in the past.
;If user is working on a component with the latest inactive
;date, that date was not set as the orderable item inactive
;date as it should have.
;
D IACHK
I $G(^TMP($J,"INACTIVE_DATE",PSVAR))="",PSSDGIDL]"",PSBEFORE]"",PSSDGIDL'=PSBEFORE D
. S PSBEFORE=PSSDGIDL
. S DIE="^PS(50.7,",DA=PSVAR,DR=".04////"_PSSDGIDL
. D ^DIE K DIE,DA,DR
D INACT1
I $G(Y)["^"!($D(DTOUT))!($G(DUOUT)) Q
D IACHK1
Q
;
INACT1 ;
N PSSNEWIA S PSSNEWIA=""
;Does the user wish to add or change the inactive date
K DIR S DIR(0)="DO",DIR("A")="INACTIVE DATE" D D ^DIR K DIR I $G(Y)["^"!($D(DTOUT))!($G(DUOUT)) Q
.I $G(PSBEFORE) S Y=PSBEFORE D DD^%DT S DIR("B")=$G(Y)
S DIE="^PS(50.7,",DA=PSVAR,PSSNEWIA=Y
I $G(PSBEFORE),'PSSNEWIA D
. I '$O(PSSDACT(0)),'$O(PSSSACT(0)),'$O(PSSAACT(0)) D Q
. . W !!,?15,"All Drugs/Additives/Solutions matched to this"
. . W !,?15,"Orderable Item are inactive."
. . W !!,?15,"The INACTIVE DATE cannot be deleted.",!
. S DR=".04////@"
. D ^DIE K DIE,DA,DR
. ;An inactive date may have been set if all components
. ;are defined with an inactive date and one or more
. ;of those dates are in the future.
. I $P(^PS(50.7,PSVAR,0),"^",4)="" D
. . W ?35,"The inactive date has been deleted.",!
I PSSNEWIA D
. S DR=".04////"_PSSNEWIA
. D DD^%DT W ?40,Y,!
. D ^DIE K DIE,DA,DR
S PSSINACT=$P(^PS(50.7,PSVAR,0),"^",4)
I PSSINACT="" Q
;
;Inform user if user specified that inactive date should
;be deleted.
;
I 'PSSNEWIA D
. W !,?15,"The Inactive Date is: "
. S Y=PSSINACT D DD^%DT W Y,"."
Q
;
IACHK ;
;Check to see if the inactive date on the orderable item
;is greater than the greatest inactive date on
;corresponding Drugs/Additives/Solutions.
;Not automatically setting to that value unless the inactive date
;was null when user invoked the option.
;Otherwise, leave as is in case user wishes it defined as such.
;
S PSSCOMP="",PSSACT=0
F S PSSCOMP=$O(^PS(50.7,"A50",PSVAR,PSSCOMP)) Q:PSSCOMP="" D
. S PSSARR(PSSCOMP)=""
;Latest inactive date = PSSDGIDL
;Inactive date on each component = PSSDGDT
S PSSDGIDL=""
F S PSSCOMP=$O(PSSARR(PSSCOMP)) Q:PSSCOMP="" D
. S PSSDGDT=$G(^PSDRUG(PSSCOMP,"I"))
. I PSSDGDT="" S PSSACT=1
. I PSSDGDT>PSSDGIDL S PSSDGIDL=PSSDGDT
Q
;
IACHK1 ;
;message to user
I PSSDGIDL]"",'PSSACT D
. S Y=PSSDGIDL D DD^%DT
. I PSSDGIDL<PSSINACT D Q
. . W !!,?15,"**** **** NOTE **** ****",!
. . W !,?15,"All Drugs/Additives/Solutions for this orderable item"
. . W !,?15,"are inactive as of ",Y,".",!
. . S Y=$P(^PS(50.7,PSVAR,0),"^",4) D DD^%DT
. . W !,?15,"However, the orderable item ",$P(^PS(50.7,PSVAR,0),"^")
. . W !,?15,"is inactive on ",Y,".",!
. . W !,?15,"You may need to change the inactive date on the orderable item"
. . W !,?15,"using option PSS EDIT ORDERABLE ITEMS.",!
. . W !,?15,"**** **** **** **** ****",!
. ;
. W !,?15,"All Drugs/Additives/Solutions matched to this"
. W !,?15,"Orderable Item are inactive as of ",Y,".",!
Q
;
EN1 ;
;PSSDTENT is used by routine PSSPOIMO
N PSSDTENT
S PSSDTENT=PSSINACT
S PSSOTH=$P($G(^PS(59.7,1,40.2)),"^"),DIE="^PS(50.7,",DA=PSVAR
S DR=".05;@1;D SETF^PSSPOIMO;.06;D DFR^PSSPOIMO(PSBEFORE1);10//YES;I X=""Y"" S Y=""@2"";S:$G(DUOUT) Y=""@3"";" D
.S DR=DR_"D PDCHK^PSSPOIMO S:PSSFG Y=""@1"";S:$G(DUOUT) Y=""@3"";@2;K DIE(""NO^""),DIRUT;D MRSEL^PSSPOIMO;.07;.08;1;12//0;7;S:'$G(PSSOTH) Y=""@3"";7.1;@3" ;*191
D ^DIE S PSAFTER=$P(^PS(50.7,PSVAR,0),"^",4) K DIE,DA,DR,PSSOTH,^TMP("PSJMR",$J),^TMP("PSSDMR",$J) I $D(PSSOU),'$G(PSSOU) D MRSEL^PSSPOIMO K ^TMP("PSJMR",$J)
S:PSBEFORE&('PSAFTER) PSINORDE="D" S:PSAFTER PSINORDE="I"
I PSINORDE'="" D REST^PSSPOIDT(PSVAR)
K PSBEFORE,PSBEFORE1,PSAFTER,PSINORDE
N DIE,DA,DR ; Indications for Use fields PSS*1*204,*242 - Other lang
S DIE="^PS(50.7,",DA=PSVAR,DR="D LIND^PSSPOIMO;14;13;14.1T;14.2" D ^DIE K DIE
IMMUN ;PSS*1*141 FOR 'IMMUNIZATIONS DOCUMENTATION BY BCMA'
I $O(^PSDRUG("AOC",PSVAR,"IM000"))'["IM" G SYN ;ASK WHEN APPROPRIATE
W ! S DIE="^PS(50.7,",DA=PSVAR,DR=9 D ^DIE K DIE
SYN I $G(Y)["^"!($G(DIRUT))!$D(DTOUT)!($D(Y)>10) G FINS
W ! K DIC S:'$D(^PS(50.7,PSVAR,2,0)) ^PS(50.7,PSVAR,2,0)="^50.72^0^0" S DIC="^PS(50.7,"_PSVAR_",2,",DA(1)=PSVAR,DIC(0)="QEAMZL",DIC("A")="Select SYNONYM: ",DLAYGO=50.72 D ^DIC K DIC
I Y<0!($D(DTOUT))!($D(DUOUT)) K:'$O(^PS(50.7,PSVAR,2,0)) ^PS(50.7,PSVAR,2,0) S PSSNOOI=1 G FIN
W ! S DA=+Y,DIE="^PS(50.7,"_PSVAR_",2,",DA(1)=PSVAR,DR=.01 D ^DIE K DIE G SYN
FIN D EN^PSSPOIDT(PSVAR) I $G(PSVAR1) D EN2^PSSHL1(PSVAR,"MAD") G FINS
D EN2^PSSHL1(PSVAR,"MUP")
FINS K PSVAR,PSVAR1 Q
;
DATE ;
F ZZZ=0:0 S ZZZ=$O(^PS(50.7,ZZZ)) Q:'ZZZ S PSOTYPE=$P($G(^PS(50.7,ZZZ,0)),"^",3) D
.I PSOTYPE,'$D(^PS(52.6,"AOI",ZZZ)),'$D(^PS(52.7,"AOI",ZZZ)),'$P($G(^PS(50.7,ZZZ,0)),"^",4) K DIE S DIE="^PS(50.7,",DA=ZZZ,DR=".04////"_DT D ^DIE K DIE Q
.Q:PSOTYPE
.D SUPP
.I '$D(^PSDRUG("ASP",ZZZ)),'$P($G(^PS(50.7,ZZZ,0)),"^",4) K DIE S DIE="^PS(50.7,",DA=ZZZ,DR=".04////"_DT D ^DIE K DIE Q
.D:'$P($G(^PS(50.7,ZZZ,0)),"^",4)
..S PSDFLAG=0 F WW=0:0 S WW=$O(^PSDRUG("ASP",ZZZ,WW)) Q:'WW!(PSDFLAG) S PSAPPL=$P($G(^PSDRUG(WW,2)),"^",3) I PSAPPL["I"!(PSAPPL["O")!(PSAPPL["U") S PSDFLAG=1
..I 'PSDFLAG K DIE S DIE="^PS(50.7,",DA=ZZZ,DR=".04////"_DT D ^DIE K DIE
F ZZZ=0:0 S ZZZ=$O(^PS(52.7,ZZZ)) Q:'ZZZ S RRRR=$P($G(^PS(52.7,ZZZ,0)),"^",11) I RRRR,'$P($G(^PS(50.7,RRRR,0)),"^",3) K DIE S DA=ZZZ,DIE="^PS(52.7,",DR="9////"_"@" D ^DIE K DIE
F ZZZ=0:0 S ZZZ=$O(^PS(52.6,ZZZ)) Q:'ZZZ S RRRR=$P($G(^PS(52.6,ZZZ,0)),"^",11) I RRRR,'$P($G(^PS(50.7,RRRR,0)),"^",3) K DIE S DA=ZZZ,DIE="^PS(52.6,",DR="15////"_"@" D ^DIE K DIE
D:$G(PSCREATE) MAIL^PSSCREAT
I '$G(PSSOMAIL) K PSOTYPE,DA,DIE,WW,RRRR,PSDFLAG,PSAPPL,GGG,HHH,ZZZZZ Q
S PSOTEXT(1)="You have completed the matching process required for the installation of",PSOTEXT(2)="Outpatient V. 7.0 and Inpatient Medications V. 5.0!"
S XMDUZ=.5,XMY(DUZ)="",XMTEXT="PSOTEXT(",XMSUB="Pharmacy Orderable Item File" D ^XMD
S PSSITE=+$O(^PS(59.7,0)) S $P(^PS(59.7,PSSITE,80),"^",2)=3 K PSSITE
D ^%ZISC K PSOTYPE,DA,DIE,WW,RRRR,PSDFLAG,PSAPPL,GGG,HHH,ZZZZZ,PSSOMAIL S:$D(ZTQUEUED) ZTREQ="@" Q
RMES W !!,"This report takes a long time to first build the data to print, then to",!,"actually print the data. To avoid tying up a terminal for a long period of time,",!,"the report must be QUEUED to a printer."
W !!,"This report must be QUEUED to a printer!"
Q
KMES W !!,"Due to the length of this report, and to avoid tying up a terminal for a long",!,"time, this report must be QUEUED to a printer!"
Q
SUPP ;Mark as supply
N SSSUP,SSSIN,SSSAP,SSLOOP,SSSQUE,SSSQUEY,SSSQDATE,SLIP,SLDO,SLDP
S (SSSQUE,SSSQUEY)=0 F SSLOOP=0:0 S SSLOOP=$O(^PSDRUG("ASP",ZZZ,SSLOOP)) Q:'SSLOOP!(SSSQUEY) D
.I $P($G(^PSDRUG(SSLOOP,0)),"^",3)["S" S SSSAP=$P($G(^(2)),"^",3),SSSIN=$P($G(^("I")),"^") D
..I SSSAP["O"!(SSSAP["I")!(SSSAP["U") I 'SSSIN S $P(^PS(50.7,ZZZ,0),"^",9)=1 S (SSSQUEY,SSSQUE)=1 Q
..I SSSAP["O"!(SSSAP["I")!(SSSAP["U") I +SSSIN>DT S $P(^PS(50.7,ZZZ,0),"^",9)=1 S SSSQUE=1,SSSQDATE($E(SSSIN,1,7))=""
I 'SSSQUEY,SSSQUE,$O(SSSQDATE(0)) F SLIP=0:0 S SLIP=$O(SSSQDATE(SLIP)) Q:'SLIP D
.S ZTRTN="ENT^PSSPOIDT",ZTDESC="Supply update for Orderable Item",ZTIO="",ZTDTH=SLIP_.01 S SLDO=$G(PSSORDIT),SLDP=$G(PSSCROSS) S PSSORDIT=ZZZ,PSSCROSS=1 S ZTSAVE("PSSORDIT")="",ZTSAVE("PSSCROSS")="" D ^%ZTLOAD D
..S PSSORDIT=$G(SLDO) K:'PSSORDIT PSSORDIT
..S PSSCROSS=$G(SLDP) K:'PSSCROSS PSSCROSS
Q
;
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSSPOIM1 13711 printed Dec 13, 2024@02:34:01 Page 2
PSSPOIM1 ;BIR/RTR,WRT - Manual create of Orderable Item continued ;Jun 23, 2020@13:14:33
+1 ;;1.0;PHARMACY DATA MANAGEMENT;**29,38,47,141,153,159,166,191,198,204,220,242**;9/30/97;Build 19
+2 ;
CHK SET PSNO=0
IF $GET(PSMAN)
WRITE !!,"Matching ",PSNAME,!," to",!,SPHOLD," ",$PIECE($GET(^PS(50.606,+DOSEPTR,0)),"^"),!
+1 IF '$GET(PSMAN)
SET PSMC=$PIECE($GET(^PS(50.7,PSSP,0)),"^")
WRITE !!,"Matching ",PSNAME,!," to",!,PSMC," ",$PIECE($GET(^PS(50.606,+$PIECE(^PS(50.7,PSSP,0),"^",2),0)),"^"),!
+2 KILL DIR
SET DIR(0)="Y"
SET DIR("B")="YES"
SET DIR("A")="Is this OK"
DO ^DIR
+3 if Y=0
SET PSNO=1
IF Y'=1
IF 'PSNO
SET PSOUT=1
+4 ;Add trace of whether inactive date is present.
+5 ;If one is added erroneously by code logic when the
+6 ;orderable item should remain active,
+7 ;the inactive date will be deleted at INACT^PSSPOIM1.
+8 KILL ^TMP($JOB,"INACTIVE_DATE")
+9 NEW PSOITMP
+10 SET PSOITMP=$SELECT($GET(PSPOINT):PSPOINT,$GET(PSSP):PSSP,1:"")
+11 IF PSOITMP]""
SET ^TMP($JOB,"INACTIVE_DATE",PSOITMP)=$PIECE($GET(^PS(50.7,PSOITMP,0)),"^",4)
+12 KILL PSMAN,PSOITMP
+13 QUIT
END KILL ^TMP($JOB,"PSSOO"),PSSSSS,PSCREATE,^TMP("PSSLOOP",$JOB),^TMP($JOB,"INACTIVE_DATE")
+1 KILL AAA,ANS,APLU,COMM,DA,DIC,DIE,DOSEFORM,DOSEFV,DOSEPTR,DR,FFF,MATCH,NEWSP,NODE,NOFLAG,OTH,POINT,PSCNT,PSIEN,PSMAN,PSMC,PSNAME,PSNO,PSSP,PSND,PSOUT,SPHOLD,SPR,TMPTR,TT,VAGEN,X,Y,ZZ,PSOOOUT,PSXDATE,PSXADATE,PSXSDATE,AAAAA,BBBBB,ZXX,PSXDDATE
+2 KILL PSSDACT,PSSSACT,PSSAACT,PSSINACT,PSSDTENT,PSSCOMP,PSSDGDT,PSSDGIDL,PSSARR,PSSACT,PSSNEWIA
+3 QUIT
MESS WRITE !!,"This option enables you to match Dispense Drugs to an entry in the Pharmacy",!,"Orderable Item file, or create a new Pharmacy Orderable Item entry for a",!,"Dispense Drug.",!
QUIT
MESSZ SET ^TMP("PSSLOOP",$JOB,DUZ)=""
WRITE !!,"This option is for matching IV Additives, IV Solutions, and all Dispense Drugs",!,"marked with an I, O, or U in the Application Packages' Use field to an",!,"Orderable Item."
+1 WRITE !,"You will need to keep accessing this option until all drugs are matched.",!,"A check will be done every time this option is exited to see if the matching",!,"process is complete.",!!
+2 KILL DIR
SET DIR(0)="E"
DO ^DIR
KILL DIR
IF X["^"!($DATA(DTOUT))
SET PSOUT=1
+3 QUIT
CHECK WRITE !!!,"Checking Drug files, please wait..."
+1 SET X1=DT
SET X2=-365
DO C^%DTC
SET PSZXDATE=X
SET DONEFLAG=1
+2 FOR FFFF=0:0
SET FFFF=$ORDER(^PSDRUG(FFFF))
if 'FFFF!('DONEFLAG)
QUIT
SET QQNM=$PIECE($GET(^PSDRUG(FFFF,0)),"^")
IF QQNM'=""
IF $DATA(^PSDRUG("B",QQNM))
Begin DoDot:1
+3 SET USAGE=$PIECE($GET(^PSDRUG(FFFF,2)),"^",3)
+4 SET ZZG=1
SET PSZZDATE=+$PIECE($GET(^PSDRUG(FFFF,"I")),"^")
IF PSZZDATE
IF PSZZDATE<PSZXDATE
SET ZZG=0
End DoDot:1
IF ZZG
IF USAGE["O"!(USAGE["I")!(USAGE["U")
IF '$PIECE($GET(^PSDRUG(FFFF,2)),"^")
SET DONEFLAG=0
+5 IF DONEFLAG=1
Begin DoDot:1
+6 FOR QQQ=0:0
SET QQQ=$ORDER(^PS(52.6,QQQ))
if 'QQQ!('DONEFLAG)
QUIT
SET PSZNAME=$PIECE($GET(^PS(52.6,QQQ,0)),"^")
IF PSZNAME'=""
IF $DATA(^PS(52.6,"B",PSZNAME))
IF $PIECE($GET(^PS(52.6,QQQ,0)),"^",2)
IF '$PIECE($GET(^(0)),"^",11)
Begin DoDot:2
+7 SET ZZG=1
SET PSZZDATE=+$PIECE($GET(^PS(52.6,QQQ,"I")),"^")
IF PSZZDATE
IF PSZZDATE<PSZXDATE
SET ZZG=0
End DoDot:2
IF ZZG
SET DONEFLAG=0
+8 IF DONEFLAG
FOR QQQ=0:0
SET QQQ=$ORDER(^PS(52.7,QQQ))
if 'QQQ!('DONEFLAG)
QUIT
SET PSZNAME=$PIECE($GET(^PS(52.7,QQQ,0)),"^")
IF PSZNAME'=""
IF $DATA(^PS(52.7,"B",PSZNAME))
IF $PIECE($GET(^PS(52.7,QQQ,0)),"^",2)
IF '$PIECE($GET(^(0)),"^",11)
Begin DoDot:2
+9 SET ZZG=1
SET PSZZDATE=+$PIECE($GET(^PS(52.7,QQQ,"I")),"^")
IF PSZZDATE
IF PSZZDATE<PSZXDATE
SET ZZG=0
End DoDot:2
IF ZZG
SET DONEFLAG=0
End DoDot:1
MAIL IF DONEFLAG
WRITE !!!,?3,"You are finished matching to the Orderable Item File!",!!,"A clean-up job is being queued now, and when it is finished, you will"
+1 IF $TEST
WRITE !,"receive a mail message informing you of its completion.",!
KILL DIR
SET DIR(0)="E"
SET DIR("A")="Press Return to continue"
DO ^DIR
KILL DIR
+2 IF $GET(DONEFLAG)
SET PSSOMAIL=1
SET PSOUDUZ=DUZ
SET ZTRTN="DATE^PSSPOIM1"
SET ZTIO=""
SET ZTDTH=$HOROLOG
SET ZTDESC="ORDERABLE ITEM CLEAN UP"
SET ZTSAVE("DUZ")=""
SET ZTSAVE("PSSOMAIL")=""
DO ^%ZTLOAD
+3 IF 'DONEFLAG
WRITE $CHAR(7),$CHAR(7),!!?5,"There are still Drugs not matched, you will need to come back",!?5,"and continue matching Drugs!",!
KILL DIR
SET DIR(0)="E"
SET DIR("A")="Press Return to continue"
DO ^DIR
KILL DIR
+4 KILL DONEFLAG,QQQ,QQNM,PSZZDATE,PSZXDATE,ZZG,USAGE,FFFF,PSZNAME
QUIT
OTHER WRITE @IOF
WRITE !,"There are other Dispense Drugs with the same VA Generic Name and same Dose",!,"Form already matched to orderable items. Choose a number to match, or enter",!,"'^' to enter a new one.",!!?6,"Disp. drug -> ",PSNAME,!
QUIT
EN(PSVAR) ;
+1 NEW PSSDACT,PSSSACT,PSSAACT,PSSINACT,PSSDTENT
+2 NEW PSSCOMP,PSSDGDT,PSSDGIDL,PSSARR,PSSACT
+3 WRITE !?3,"Now editing Orderable Item:",!?3,$PIECE(^PS(50.7,PSVAR,0),"^")," ",$PIECE($GET(^PS(50.606,+$PIECE(^(0),"^",2),0)),"^")
+4 WRITE !
KILL DIE,DA,DR
NEW MFLG
SET PSBEFORE1=+$PIECE(^PS(50.7,PSVAR,0),"^",2)
SET PSAFTER=0
SET PSINORDE=""
+5 SET DIE="^PS(50.7,"
SET DA=PSVAR
SET DR="5;6"
DO ^DIE
KILL DIE,DA,DR
IF $DATA(DTOUT)!($DATA(Y)>10)
QUIT
+6 DO INACT
+7 IF $GET(Y)["^"!($DATA(DTOUT))!($GET(DUOUT))
QUIT
+8 DO EN1
+9 QUIT
+10 ;
INACT ;
+1 ;check to see if an inactive date was added by code logic
+2 ;(not by a user) but was erroneously added since there is
+3 ;an active component for this orderable item
+4 ;
+5 ;The inactive date can be erroneously added at EN1+15^PSSPOIDT
+6 ;when there is only one active component on an orderable item
+7 ;and that component is being edited.
+8 ;
+9 ;The logic in PSSPOIDT cannot be changed without restructuring
+10 ;much of the core logic. Hence, the decision to insert the
+11 ;following check to determine whether the inactive date
+12 ;was not present when the user invoked option PSS MAINTAIN
+13 ;ORDERABLE ITEM and was erroneously added to file 50.7 by
+14 ;EN1^PSSPOIDT.
+15 ;
+16 DO CHECK^PSSPOID2(PSVAR)
+17 SET PSBEFORE=$PIECE(^PS(50.7,PSVAR,0),"^",4)
+18 IF $GET(^TMP($JOB,"INACTIVE_DATE",PSVAR))=""
IF PSBEFORE]""
Begin DoDot:1
+19 ;Information returned by CHECK^PSSPOID2(PSVAR):
+20 ; PSSDACT = array of active dispense drugs
+21 ; PSSSACT = array of active solutions
+22 ; PSSAACT = array of active additives
+23 IF $ORDER(PSSDACT(0))!($ORDER(PSSSACT(0)))!($ORDER(PSSAACT(0)))
Begin DoDot:2
+24 ;Attempt to delete the inactive date since it
+25 ;may have been added erroneously.
+26 ;An inactive date may still be present after this call
+27 ;if all components have an inactive date and
+28 ;and one or more of those dates are in the future
+29 SET DIE="^PS(50.7,"
SET DA=PSVAR
SET DR=".04////@"
DO ^DIE
KILL DIE,DA,DR
+30 SET PSBEFORE=$PIECE(^PS(50.7,PSVAR,0),"^",4)
End DoDot:2
End DoDot:1
+31 ;
+32 ;Check to see if an inactive date did not exist when user
+33 ;invoked the option and one has been added that is incorrect.
+34 ;This can occur if all components have an inactive date on
+35 ;file, and all inactive dates are today or in the past.
+36 ;If user is working on a component with the latest inactive
+37 ;date, that date was not set as the orderable item inactive
+38 ;date as it should have.
+39 ;
+40 DO IACHK
+41 IF $GET(^TMP($JOB,"INACTIVE_DATE",PSVAR))=""
IF PSSDGIDL]""
IF PSBEFORE]""
IF PSSDGIDL'=PSBEFORE
Begin DoDot:1
+42 SET PSBEFORE=PSSDGIDL
+43 SET DIE="^PS(50.7,"
SET DA=PSVAR
SET DR=".04////"_PSSDGIDL
+44 DO ^DIE
KILL DIE,DA,DR
End DoDot:1
+45 DO INACT1
+46 IF $GET(Y)["^"!($DATA(DTOUT))!($GET(DUOUT))
QUIT
+47 DO IACHK1
+48 QUIT
+49 ;
INACT1 ;
+1 NEW PSSNEWIA
SET PSSNEWIA=""
+2 ;Does the user wish to add or change the inactive date
+3 KILL DIR
SET DIR(0)="DO"
SET DIR("A")="INACTIVE DATE"
Begin DoDot:1
+4 IF $GET(PSBEFORE)
SET Y=PSBEFORE
DO DD^%DT
SET DIR("B")=$GET(Y)
End DoDot:1
DO ^DIR
KILL DIR
IF $GET(Y)["^"!($DATA(DTOUT))!($GET(DUOUT))
QUIT
+5 SET DIE="^PS(50.7,"
SET DA=PSVAR
SET PSSNEWIA=Y
+6 IF $GET(PSBEFORE)
IF 'PSSNEWIA
Begin DoDot:1
+7 IF '$ORDER(PSSDACT(0))
IF '$ORDER(PSSSACT(0))
IF '$ORDER(PSSAACT(0))
Begin DoDot:2
+8 WRITE !!,?15,"All Drugs/Additives/Solutions matched to this"
+9 WRITE !,?15,"Orderable Item are inactive."
+10 WRITE !!,?15,"The INACTIVE DATE cannot be deleted.",!
End DoDot:2
QUIT
+11 SET DR=".04////@"
+12 DO ^DIE
KILL DIE,DA,DR
+13 ;An inactive date may have been set if all components
+14 ;are defined with an inactive date and one or more
+15 ;of those dates are in the future.
+16 IF $PIECE(^PS(50.7,PSVAR,0),"^",4)=""
Begin DoDot:2
+17 WRITE ?35,"The inactive date has been deleted.",!
End DoDot:2
End DoDot:1
+18 IF PSSNEWIA
Begin DoDot:1
+19 SET DR=".04////"_PSSNEWIA
+20 DO DD^%DT
WRITE ?40,Y,!
+21 DO ^DIE
KILL DIE,DA,DR
End DoDot:1
+22 SET PSSINACT=$PIECE(^PS(50.7,PSVAR,0),"^",4)
+23 IF PSSINACT=""
QUIT
+24 ;
+25 ;Inform user if user specified that inactive date should
+26 ;be deleted.
+27 ;
+28 IF 'PSSNEWIA
Begin DoDot:1
+29 WRITE !,?15,"The Inactive Date is: "
+30 SET Y=PSSINACT
DO DD^%DT
WRITE Y,"."
End DoDot:1
+31 QUIT
+32 ;
IACHK ;
+1 ;Check to see if the inactive date on the orderable item
+2 ;is greater than the greatest inactive date on
+3 ;corresponding Drugs/Additives/Solutions.
+4 ;Not automatically setting to that value unless the inactive date
+5 ;was null when user invoked the option.
+6 ;Otherwise, leave as is in case user wishes it defined as such.
+7 ;
+8 SET PSSCOMP=""
SET PSSACT=0
+9 FOR
SET PSSCOMP=$ORDER(^PS(50.7,"A50",PSVAR,PSSCOMP))
if PSSCOMP=""
QUIT
Begin DoDot:1
+10 SET PSSARR(PSSCOMP)=""
End DoDot:1
+11 ;Latest inactive date = PSSDGIDL
+12 ;Inactive date on each component = PSSDGDT
+13 SET PSSDGIDL=""
+14 FOR
SET PSSCOMP=$ORDER(PSSARR(PSSCOMP))
if PSSCOMP=""
QUIT
Begin DoDot:1
+15 SET PSSDGDT=$GET(^PSDRUG(PSSCOMP,"I"))
+16 IF PSSDGDT=""
SET PSSACT=1
+17 IF PSSDGDT>PSSDGIDL
SET PSSDGIDL=PSSDGDT
End DoDot:1
+18 QUIT
+19 ;
IACHK1 ;
+1 ;message to user
+2 IF PSSDGIDL]""
IF 'PSSACT
Begin DoDot:1
+3 SET Y=PSSDGIDL
DO DD^%DT
+4 IF PSSDGIDL<PSSINACT
Begin DoDot:2
+5 WRITE !!,?15,"**** **** NOTE **** ****",!
+6 WRITE !,?15,"All Drugs/Additives/Solutions for this orderable item"
+7 WRITE !,?15,"are inactive as of ",Y,".",!
+8 SET Y=$PIECE(^PS(50.7,PSVAR,0),"^",4)
DO DD^%DT
+9 WRITE !,?15,"However, the orderable item ",$PIECE(^PS(50.7,PSVAR,0),"^")
+10 WRITE !,?15,"is inactive on ",Y,".",!
+11 WRITE !,?15,"You may need to change the inactive date on the orderable item"
+12 WRITE !,?15,"using option PSS EDIT ORDERABLE ITEMS.",!
+13 WRITE !,?15,"**** **** **** **** ****",!
End DoDot:2
QUIT
+14 ;
+15 WRITE !,?15,"All Drugs/Additives/Solutions matched to this"
+16 WRITE !,?15,"Orderable Item are inactive as of ",Y,".",!
End DoDot:1
+17 QUIT
+18 ;
EN1 ;
+1 ;PSSDTENT is used by routine PSSPOIMO
+2 NEW PSSDTENT
+3 SET PSSDTENT=PSSINACT
+4 SET PSSOTH=$PIECE($GET(^PS(59.7,1,40.2)),"^")
SET DIE="^PS(50.7,"
SET DA=PSVAR
+5 SET DR=".05;@1;D SETF^PSSPOIMO;.06;D DFR^PSSPOIMO(PSBEFORE1);10//YES;I X=""Y"" S Y=""@2"";S:$G(DUOUT) Y=""@3"";"
Begin DoDot:1
+6 ;*191
SET DR=DR_"D PDCHK^PSSPOIMO S:PSSFG Y=""@1"";S:$G(DUOUT) Y=""@3"";@2;K DIE(""NO^""),DIRUT;D MRSEL^PSSPOIMO;.07;.08;1;12//0;7;S:'$G(PSSOTH) Y=""@3"";7.1;@3"
End DoDot:1
+7 DO ^DIE
SET PSAFTER=$PIECE(^PS(50.7,PSVAR,0),"^",4)
KILL DIE,DA,DR,PSSOTH,^TMP("PSJMR",$JOB),^TMP("PSSDMR",$JOB)
IF $DATA(PSSOU)
IF '$GET(PSSOU)
DO MRSEL^PSSPOIMO
KILL ^TMP("PSJMR",$JOB)
+8 if PSBEFORE&('PSAFTER)
SET PSINORDE="D"
if PSAFTER
SET PSINORDE="I"
+9 IF PSINORDE'=""
DO REST^PSSPOIDT(PSVAR)
+10 KILL PSBEFORE,PSBEFORE1,PSAFTER,PSINORDE
+11 ; Indications for Use fields PSS*1*204,*242 - Other lang
NEW DIE,DA,DR
+12 SET DIE="^PS(50.7,"
SET DA=PSVAR
SET DR="D LIND^PSSPOIMO;14;13;14.1T;14.2"
DO ^DIE
KILL DIE
IMMUN ;PSS*1*141 FOR 'IMMUNIZATIONS DOCUMENTATION BY BCMA'
+1 ;ASK WHEN APPROPRIATE
IF $ORDER(^PSDRUG("AOC",PSVAR,"IM000"))'["IM"
GOTO SYN
+2 WRITE !
SET DIE="^PS(50.7,"
SET DA=PSVAR
SET DR=9
DO ^DIE
KILL DIE
SYN IF $GET(Y)["^"!($GET(DIRUT))!$DATA(DTOUT)!($DATA(Y)>10)
GOTO FINS
+1 WRITE !
KILL DIC
if '$DATA(^PS(50.7,PSVAR,2,0))
SET ^PS(50.7,PSVAR,2,0)="^50.72^0^0"
SET DIC="^PS(50.7,"_PSVAR_",2,"
SET DA(1)=PSVAR
SET DIC(0)="QEAMZL"
SET DIC("A")="Select SYNONYM: "
SET DLAYGO=50.72
DO ^DIC
KILL DIC
+2 IF Y<0!($DATA(DTOUT))!($DATA(DUOUT))
if '$ORDER(^PS(50.7,PSVAR,2,0))
KILL ^PS(50.7,PSVAR,2,0)
SET PSSNOOI=1
GOTO FIN
+3 WRITE !
SET DA=+Y
SET DIE="^PS(50.7,"_PSVAR_",2,"
SET DA(1)=PSVAR
SET DR=.01
DO ^DIE
KILL DIE
GOTO SYN
FIN DO EN^PSSPOIDT(PSVAR)
IF $GET(PSVAR1)
DO EN2^PSSHL1(PSVAR,"MAD")
GOTO FINS
+1 DO EN2^PSSHL1(PSVAR,"MUP")
FINS KILL PSVAR,PSVAR1
QUIT
+1 ;
DATE ;
+1 FOR ZZZ=0:0
SET ZZZ=$ORDER(^PS(50.7,ZZZ))
if 'ZZZ
QUIT
SET PSOTYPE=$PIECE($GET(^PS(50.7,ZZZ,0)),"^",3)
Begin DoDot:1
+2 IF PSOTYPE
IF '$DATA(^PS(52.6,"AOI",ZZZ))
IF '$DATA(^PS(52.7,"AOI",ZZZ))
IF '$PIECE($GET(^PS(50.7,ZZZ,0)),"^",4)
KILL DIE
SET DIE="^PS(50.7,"
SET DA=ZZZ
SET DR=".04////"_DT
DO ^DIE
KILL DIE
QUIT
+3 if PSOTYPE
QUIT
+4 DO SUPP
+5 IF '$DATA(^PSDRUG("ASP",ZZZ))
IF '$PIECE($GET(^PS(50.7,ZZZ,0)),"^",4)
KILL DIE
SET DIE="^PS(50.7,"
SET DA=ZZZ
SET DR=".04////"_DT
DO ^DIE
KILL DIE
QUIT
+6 if '$PIECE($GET(^PS(50.7,ZZZ,0)),"^",4)
Begin DoDot:2
+7 SET PSDFLAG=0
FOR WW=0:0
SET WW=$ORDER(^PSDRUG("ASP",ZZZ,WW))
if 'WW!(PSDFLAG)
QUIT
SET PSAPPL=$PIECE($GET(^PSDRUG(WW,2)),"^",3)
IF PSAPPL["I"!(PSAPPL["O")!(PSAPPL["U")
SET PSDFLAG=1
+8 IF 'PSDFLAG
KILL DIE
SET DIE="^PS(50.7,"
SET DA=ZZZ
SET DR=".04////"_DT
DO ^DIE
KILL DIE
End DoDot:2
End DoDot:1
+9 FOR ZZZ=0:0
SET ZZZ=$ORDER(^PS(52.7,ZZZ))
if 'ZZZ
QUIT
SET RRRR=$PIECE($GET(^PS(52.7,ZZZ,0)),"^",11)
IF RRRR
IF '$PIECE($GET(^PS(50.7,RRRR,0)),"^",3)
KILL DIE
SET DA=ZZZ
SET DIE="^PS(52.7,"
SET DR="9////"_"@"
DO ^DIE
KILL DIE
+10 FOR ZZZ=0:0
SET ZZZ=$ORDER(^PS(52.6,ZZZ))
if 'ZZZ
QUIT
SET RRRR=$PIECE($GET(^PS(52.6,ZZZ,0)),"^",11)
IF RRRR
IF '$PIECE($GET(^PS(50.7,RRRR,0)),"^",3)
KILL DIE
SET DA=ZZZ
SET DIE="^PS(52.6,"
SET DR="15////"_"@"
DO ^DIE
KILL DIE
+11 if $GET(PSCREATE)
DO MAIL^PSSCREAT
+12 IF '$GET(PSSOMAIL)
KILL PSOTYPE,DA,DIE,WW,RRRR,PSDFLAG,PSAPPL,GGG,HHH,ZZZZZ
QUIT
+13 SET PSOTEXT(1)="You have completed the matching process required for the installation of"
SET PSOTEXT(2)="Outpatient V. 7.0 and Inpatient Medications V. 5.0!"
+14 SET XMDUZ=.5
SET XMY(DUZ)=""
SET XMTEXT="PSOTEXT("
SET XMSUB="Pharmacy Orderable Item File"
DO ^XMD
+15 SET PSSITE=+$ORDER(^PS(59.7,0))
SET $PIECE(^PS(59.7,PSSITE,80),"^",2)=3
KILL PSSITE
+16 DO ^%ZISC
KILL PSOTYPE,DA,DIE,WW,RRRR,PSDFLAG,PSAPPL,GGG,HHH,ZZZZZ,PSSOMAIL
if $DATA(ZTQUEUED)
SET ZTREQ="@"
QUIT
RMES WRITE !!,"This report takes a long time to first build the data to print, then to",!,"actually print the data. To avoid tying up a terminal for a long period of time,",!,"the report must be QUEUED to a printer."
+1 WRITE !!,"This report must be QUEUED to a printer!"
+2 QUIT
KMES WRITE !!,"Due to the length of this report, and to avoid tying up a terminal for a long",!,"time, this report must be QUEUED to a printer!"
+1 QUIT
SUPP ;Mark as supply
+1 NEW SSSUP,SSSIN,SSSAP,SSLOOP,SSSQUE,SSSQUEY,SSSQDATE,SLIP,SLDO,SLDP
+2 SET (SSSQUE,SSSQUEY)=0
FOR SSLOOP=0:0
SET SSLOOP=$ORDER(^PSDRUG("ASP",ZZZ,SSLOOP))
if 'SSLOOP!(SSSQUEY)
QUIT
Begin DoDot:1
+3 IF $PIECE($GET(^PSDRUG(SSLOOP,0)),"^",3)["S"
SET SSSAP=$PIECE($GET(^(2)),"^",3)
SET SSSIN=$PIECE($GET(^("I")),"^")
Begin DoDot:2
+4 IF SSSAP["O"!(SSSAP["I")!(SSSAP["U")
IF 'SSSIN
SET $PIECE(^PS(50.7,ZZZ,0),"^",9)=1
SET (SSSQUEY,SSSQUE)=1
QUIT
+5 IF SSSAP["O"!(SSSAP["I")!(SSSAP["U")
IF +SSSIN>DT
SET $PIECE(^PS(50.7,ZZZ,0),"^",9)=1
SET SSSQUE=1
SET SSSQDATE($EXTRACT(SSSIN,1,7))=""
End DoDot:2
End DoDot:1
+6 IF 'SSSQUEY
IF SSSQUE
IF $ORDER(SSSQDATE(0))
FOR SLIP=0:0
SET SLIP=$ORDER(SSSQDATE(SLIP))
if 'SLIP
QUIT
Begin DoDot:1
+7 SET ZTRTN="ENT^PSSPOIDT"
SET ZTDESC="Supply update for Orderable Item"
SET ZTIO=""
SET ZTDTH=SLIP_.01
SET SLDO=$GET(PSSORDIT)
SET SLDP=$GET(PSSCROSS)
SET PSSORDIT=ZZZ
SET PSSCROSS=1
SET ZTSAVE("PSSORDIT")=""
SET ZTSAVE("PSSCROSS")=""
DO ^%ZTLOAD
Begin DoDot:2
+8 SET PSSORDIT=$GET(SLDO)
if 'PSSORDIT
KILL PSSORDIT
+9 SET PSSCROSS=$GET(SLDP)
if 'PSSCROSS
KILL PSSCROSS
End DoDot:2
End DoDot:1
+10 QUIT
+11 ;