| 1 | PSUMAP0 ;BHM/PDW-MAP OAU,NAOU,DA LOCATION TO DIVISION/OUTPATIENT SITES ; 4/12/07 2:12pm | 
|---|
| 2 | ;;4.0;PHARMACY BENEFITS MANAGEMENT;**12**;MARCH, 2005;Build 19 | 
|---|
| 3 | ; | 
|---|
| 4 | ;DBIA's | 
|---|
| 5 | ;Reference to file (#59.7) supported by DBIA 2854 | 
|---|
| 6 | ; | 
|---|
| 7 | EN ; select Editing or Report of Mapping | 
|---|
| 8 | W @IOF,!,?10,"MAPPING PHARMACY LOCATIONS FOR PBM EXTRACTS",!! | 
|---|
| 9 | ; | 
|---|
| 10 | MODP ; module selection prompt | 
|---|
| 11 | W !!,?5,"This option allows the mapping of dispensing/procurement locations" | 
|---|
| 12 | W !,?5,"from the AR/WS, Controlled Substances, and Drug Accountability" | 
|---|
| 13 | W !,?5,"applications to either a Medical Center Division or an Outpatient Site." | 
|---|
| 14 | W !,?5,"Any dispensing/procurement data associated with an AR/WS AOU, CS NAOU" | 
|---|
| 15 | W !,?5,"or DA Pharmacy Location that has not been mapped will be attributed to" | 
|---|
| 16 | W !,?5,"to the facility at which the database resides.  Any unmapped locations" | 
|---|
| 17 | W !,?5,"will be displayed upon entering the option.",! | 
|---|
| 18 | ; | 
|---|
| 19 | D EN1^PSUMAPR ;scan and report unmapped locations | 
|---|
| 20 | W @IOF | 
|---|
| 21 | ; | 
|---|
| 22 | MODULE ; | 
|---|
| 23 | W !!,"Select the dispensing/procurement location to map:",! | 
|---|
| 24 | S PSUA(1)="1.  AR/WS Area of Use (AOU)" | 
|---|
| 25 | S PSUA(2)="2.  Controlled Substances (CS) Narcotic Area of Use (NAOU)" | 
|---|
| 26 | S PSUA(3)="3.  Drug Accountability (DA) Pharmacy location" | 
|---|
| 27 | S PSUA(4)="4.  Print Report of Mapped/Unmapped Locations" | 
|---|
| 28 | F I=1:1:4 W !,?10,PSUA(I) | 
|---|
| 29 | W !!,?2,"You may select all by entering 'A' for ALL or by using '1:4'.",! | 
|---|
| 30 | W !,?2,"Select the dispensing/procurement location: " | 
|---|
| 31 | R X:DTIME E  W !!,"Nothing Selected - Exiting",! H 3 G EXIT | 
|---|
| 32 | I X["^" G EXIT:X="^" | 
|---|
| 33 | I X="" W "  <??>",$C(7) S X="?" | 
|---|
| 34 | ; | 
|---|
| 35 | S:"Aa"[$E(X) X="1:4" | 
|---|
| 36 | MODHLP I X["?" D  G MODULE | 
|---|
| 37 | .W !!,"Enter:  A single number to edit (or print) that selection." | 
|---|
| 38 | .W !,?8,"A range of code numbers.  Example:  1:3" | 
|---|
| 39 | .W !,?8,"Multiple code numbers separated by commas.  Example:  1,3" | 
|---|
| 40 | .W !,?8,"The letter A to select ALL items." | 
|---|
| 41 | .W !,?8,"A single up-arrow ( ^ ) to exit now without any action." | 
|---|
| 42 | S X=$TR(X,"-;_><.A","::::::") | 
|---|
| 43 | K PSUMOD | 
|---|
| 44 | F PII=1:1:$L(X,",") D | 
|---|
| 45 | .S X1=$P(X,",",PII) | 
|---|
| 46 | .Q:X1="" | 
|---|
| 47 | .I X1[":" D  Q | 
|---|
| 48 | ..S XBEG=$P(X1,":",1),XEND=$P(X1,":",2) | 
|---|
| 49 | ..I (XBEG="")!(XEND="") Q | 
|---|
| 50 | ..F PJJ=XBEG:1:XEND S PSUMOD(PJJ)="" | 
|---|
| 51 | ..K PJJ,XBEG,XEND | 
|---|
| 52 | .S PSUMOD(X1)="" | 
|---|
| 53 | ; modified to fix <UNDEFINED> PSU*3*12 BAJ | 
|---|
| 54 | S X="",ERC=0 F  S X=$O(PSUMOD(X)) Q:X=""  I '$D(PSUA(X)) S ERC=1 Q | 
|---|
| 55 | I ERC W !!,"<INVALID CHOICE - ",X,", TRY AGAIN>",$C(7) G MODP | 
|---|
| 56 | I '$D(PSUMOD) W !!,"No choices were made." K DIR S DIR(0)="E",DIR("A")="EXITING" D ^DIR G EXIT | 
|---|
| 57 | ; | 
|---|
| 58 | ; | 
|---|
| 59 | W !!,"You have selected: " | 
|---|
| 60 | S X="",PSUOPTS="" F  S X=$O(PSUMOD(X)) Q:X=""  W !,?10,PSUA(X) | 
|---|
| 61 | W ! K DIR S DIR(0)="E" D ^DIR G:'Y EXIT | 
|---|
| 62 | I $D(PSUMOD(4)) D REPORT K PSUA(4) | 
|---|
| 63 | I $D(PSUMOD(1)) D E9001 | 
|---|
| 64 | I $D(PSUMOD(2)) D E9002 | 
|---|
| 65 | I $D(PSUMOD(3)) D E9003 | 
|---|
| 66 | Q | 
|---|
| 67 | E9001 ;EDIT 90.01 AR/WS AOU MAPPING | 
|---|
| 68 | W @IOF,!!,?20,"EDITING Mapping of AR/WS AOUs",!! | 
|---|
| 69 | K DIC,DA,DIE | 
|---|
| 70 | K Z,ZZ,IENS | 
|---|
| 71 | S DA(1)=1 | 
|---|
| 72 | S DIC="^PS(59.7,1,90.01,",DA(1)=1,DIC(0)="ACEQML" | 
|---|
| 73 | S DIC("W")="X XX1,XX2" | 
|---|
| 74 | S XX1="S IENS=+Y_"",""_DA(1) S Z=$$GET1^DIQ(59.79001,IENS,.02),ZZ=$$GET1^DIQ(59.79001,IENS,.03) W:$L(Z) ?35,""Div: "",Z W:$L(ZZ) ?35,""OP:  "",ZZ" | 
|---|
| 75 | S XX2="S ZZ=$$GET1^DIQ(58.1,+Y,3,""I"") W:ZZ ?65,""**INACTIVE**""" | 
|---|
| 76 | D ^DIC | 
|---|
| 77 | Q:Y'>0 | 
|---|
| 78 | S DA=+Y,DIE=DIC | 
|---|
| 79 | S ZZ=^PS(59.7,1,90.01,DA,0),XX=$P(ZZ,U,2),YY=$P(ZZ,U,3) | 
|---|
| 80 | I YY S DR=".01;.03;S:X'="""" Y=0;.02" I 1 | 
|---|
| 81 | E  S DR=".01;.02;S:X'="""" Y=0;.03" | 
|---|
| 82 | D ^DIE W ! | 
|---|
| 83 | G E9001 | 
|---|
| 84 | ; | 
|---|
| 85 | CHK1 ;check that AOUs are mapped | 
|---|
| 86 | K IENS | 
|---|
| 87 | S DA=0,DA(1)=1 F  S DA=$O(^PS(59.7,1,90.01,DA)) Q:DA'>0  D | 
|---|
| 88 | . S Z=^PS(59.7,1,90.01,DA,0),X=$P(Z,U,2),Y=$P(Z,U,3) | 
|---|
| 89 | . I Y,'X Q | 
|---|
| 90 | . I 'Y,X Q | 
|---|
| 91 | . S IENS=DA_",1" W !,?3,"AR/WS AOU",?15,$$GET1^DIQ(59.79001,IENS,.01),?25," is not mapped." | 
|---|
| 92 | I $G(STOP),$G(IENS) K DIR S DIR(0)="E" D ^DIR I X="^" S PSUSTOP=1 I 1 | 
|---|
| 93 | Q | 
|---|
| 94 | ; | 
|---|
| 95 | E9002 ;EDIT 90.02 CS NAOU MAPPING | 
|---|
| 96 | W @IOF,!!,?20,"EDITING Mapping of CS NAOUs",!! | 
|---|
| 97 | K DIC,DA,DIE | 
|---|
| 98 | K Z,ZZ,IENS | 
|---|
| 99 | S DA(1)=1 | 
|---|
| 100 | S DIC="^PS(59.7,DA(1),90.02,",DIC(0)="AEQMLCZ" | 
|---|
| 101 | S DIC("W")="X XX1,XX2" | 
|---|
| 102 | S XX1="S IENS=+Y_"",""_DA(1) S Z=$$GET1^DIQ(59.79002,IENS,.02),ZZ=$$GET1^DIQ(59.79002,IENS,.03) W:$L(Z) ?35,""Div: "",Z W:$L(ZZ) ?35,""OP:  "",ZZ" | 
|---|
| 103 | S XX2="S ZZ=$$GET1^DIQ(58.8,+Y,4,""I"") W:ZZ ?65,""**INACTIVE** """ | 
|---|
| 104 | D ^DIC | 
|---|
| 105 | Q:Y'>0 | 
|---|
| 106 | S DA=+Y,DIE=DIC | 
|---|
| 107 | S ZZ=^PS(59.7,1,90.02,DA,0),XX=$P(ZZ,U,2),YY=$P(ZZ,U,3) | 
|---|
| 108 | I YY S DR=".01;.03;S:X'="""" Y=0;.02" I 1 | 
|---|
| 109 | E  S DR=".01;.02;S:X'="""" Y=0;.03" | 
|---|
| 110 | D ^DIE W ! | 
|---|
| 111 | G E9002 | 
|---|
| 112 | ; | 
|---|
| 113 | CHK2 ;check that NAOUs are mapped | 
|---|
| 114 | K IENS | 
|---|
| 115 | S DA=0,DA(1)=1 F  S DA=$O(^PS(59.7,1,90.02,DA)) Q:DA'>0  D | 
|---|
| 116 | . S Z=^PS(59.7,1,90.02,DA,0),X=$P(Z,U,2),Y=$P(Z,U,3) | 
|---|
| 117 | . I Y,'X Q | 
|---|
| 118 | . I 'Y,X Q | 
|---|
| 119 | . S IENS=DA_",1" W !,?3,"CS NAOU",?15,$$GET1^DIQ(59.79002,IENS,.01),?25," is not mapped." | 
|---|
| 120 | Q | 
|---|
| 121 | E9003 ;EDIT 90.03 DRUG ACCOUNTABILITY LOCATION MAPPING | 
|---|
| 122 | W @IOF,!!,?20,"EDITING Mapping of DA Pharmacy Locations",!! | 
|---|
| 123 | K DIC,DA,DIE | 
|---|
| 124 | K Z,ZZ,IENS | 
|---|
| 125 | S DA(1)=1 | 
|---|
| 126 | S DIC="^PS(59.7,DA(1),90.03,",DIC(0)="AEQMLZ" | 
|---|
| 127 | S DIC("W")="X XX1,XX2" | 
|---|
| 128 | S XX1="S IENS=+Y_"",""_DA(1) S Z=$$GET1^DIQ(59.79003,IENS,.02),ZZ=$$GET1^DIQ(59.79003,IENS,.03) W:$L(Z) ?35,"" Div: "",Z W:$L(ZZ) ?35,""OP:  "",ZZ" | 
|---|
| 129 | S XX2="S ZZ=$$GET1^DIQ(58.8,+Y,4,""I"") W:ZZ ?65,""**INACTIVE** """ | 
|---|
| 130 | D ^DIC | 
|---|
| 131 | Q:Y'>0 | 
|---|
| 132 | S DA=+Y,DIE=DIC | 
|---|
| 133 | S ZZ=^PS(59.7,1,90.03,DA,0),XX=$P(ZZ,U,2),YY=$P(ZZ,U,3) | 
|---|
| 134 | I YY S DR=".01;.03;S:X'="""" Y=0;.02" I 1 | 
|---|
| 135 | E  S DR=".01;.02;S:X'="""" Y=0;.03" | 
|---|
| 136 | D ^DIE W ! | 
|---|
| 137 | G E9003 | 
|---|
| 138 | ; | 
|---|
| 139 | CHK3 ;check that DRUG ACCOUNTABILITY LOCATIONs are mapped | 
|---|
| 140 | K IENS | 
|---|
| 141 | S DA=0,DA(1)=1 F  S DA=$O(^PS(59.7,1,90.03,DA)) Q:DA'>0  D | 
|---|
| 142 | . S Z=^PS(59.7,1,90.03,DA,0),X=$P(Z,U,2),Y=$P(Z,U,3) | 
|---|
| 143 | . I Y,'X Q | 
|---|
| 144 | . I 'Y,X Q | 
|---|
| 145 | . S IENS=DA_",1" W !,?3,"DA Phar Loc",?15,$$GET1^DIQ(59.79003,IENS,.01),?25," is not mapped." | 
|---|
| 146 | I $G(STOP),$G(IENS) K DIR S DIR(0)="E" D ^DIR I X="^" S PSUSTOP=1 I 1 | 
|---|
| 147 | Q | 
|---|
| 148 | REPORT ;Print Mapping Report | 
|---|
| 149 | W @IOF,!,"Print Pharmacy Location PBM Extract Mapping Report",! | 
|---|
| 150 | S %ZIS="Q" D ^%ZIS | 
|---|
| 151 | Q:POP | 
|---|
| 152 | I $D(IO("Q")) D QUEUE Q | 
|---|
| 153 | D EN^PSUMAPR | 
|---|
| 154 | Q | 
|---|
| 155 | QUEUE S ZTRTN="EN^PSUMAPR",ZTDESC="PRINT REPORT OF PBM EXTRACT MAPPING" | 
|---|
| 156 | S ZTREQ="@" D ^%ZTLOAD | 
|---|
| 157 | W !,"TASKED with ",$G(ZTSK) I '$G(ZTSK) W ">> DID NOT Task !!",! H 3 | 
|---|
| 158 | Q | 
|---|
| 159 | EXIT ; | 
|---|
| 160 | Q | 
|---|