| 1 | ECXWRDX ;ALB/JAP - Assign DSS Dept. to Ward ;July 16, 1998 | 
|---|
| 2 | ;;3.0;DSS EXTRACTS;**8**;Dec 22, 1997 | 
|---|
| 3 | ; | 
|---|
| 4 | EN ;entry point from menu option | 
|---|
| 5 | ;lookup ward | 
|---|
| 6 | N DIC,DIR,DTOUT,DUOUT,DIRUT,X,Y,DSSID,OUT | 
|---|
| 7 | S DIC(0)="AEMQZ",DIC="^DIC(42," D ^DIC G:$D(DTOUT)!($D(DUOUT))!(+Y<1) EXIT | 
|---|
| 8 | S ECXWARD=+Y,DSSID="" | 
|---|
| 9 | S DR=".01;.02;.03;.015;.017",DIQ(0)="IE",DIQ="ECX",DA=ECXWARD,DIC="^DIC(42," K ECX D EN^DIQ1 | 
|---|
| 10 | S ECXWARD=ECXWARD_U_$G(ECX(42,+ECXWARD,.01,"E")) | 
|---|
| 11 | W !!,"Ward: ",?18,$P(ECXWARD,U,2) | 
|---|
| 12 | S ECXDIV=$G(ECX(42,+ECXWARD,.015,"I")) | 
|---|
| 13 | I +ECXDIV>0 D | 
|---|
| 14 | .;division may not exist in file #727.3, or it may not have a dss id | 
|---|
| 15 | .S DSSID=$P($G(^ECX(727.3,+ECXDIV,0)),U,2) S:DSSID="" DSSID="Not defined" | 
|---|
| 16 | .S ECXDIV=ECXDIV_U_ECX(42,+ECXWARD,.015,"E")_"/"_$P(^DG(40.8,+ECXDIV,0),U,2)_" <"_DSSID_">" | 
|---|
| 17 | W !,"Ward Bedsection: ",?18,$G(ECX(42,+ECXWARD,.02,"E")) | 
|---|
| 18 | W !,"Ward Specialty: ",?18,$G(ECX(42,+ECXWARD,.017,"E")) | 
|---|
| 19 | W !,"Ward Service: ",?18,$G(ECX(42,+ECXWARD,.03,"E")) | 
|---|
| 20 | I +ECXDIV>0 W !,"Division: ",?18,$P(ECXDIV,U,2) | 
|---|
| 21 | ;dss id for division is needed to derive dss dept code | 
|---|
| 22 | I DSSID["Not" D  G EN | 
|---|
| 23 | .W !!,"Cannot proceed with assignment of DSS Department code for ward," | 
|---|
| 24 | .W !,"because the "_ECX(42,+ECXWARD,.015,"E")_" division does not have a DSS Division Identifier." | 
|---|
| 25 | .W ! | 
|---|
| 26 | .W !,"Use the Enter/Edit DSS Division Identifier option to associate an" | 
|---|
| 27 | .W !,"identifier with "_ECX(42,+ECXWARD,.015,"E")_"." | 
|---|
| 28 | .I $E(IOST)="C" D | 
|---|
| 29 | ..S SS=22-$Y F JJ=1:1:SS W ! | 
|---|
| 30 | ..S DIR(0)="E" W ! D ^DIR K DIR,JJ,SS W ! | 
|---|
| 31 | I ECXDIV="" D  G EN | 
|---|
| 32 | .W !!,"Cannot proceed with assignment of DSS Department code for ward," | 
|---|
| 33 | .W !,"because the ward is not associated with a Medical Center Division." | 
|---|
| 34 | .W ! | 
|---|
| 35 | .I $E(IOST)="C" D | 
|---|
| 36 | ..S SS=22-$Y F JJ=1:1:SS W ! | 
|---|
| 37 | ..S DIR(0)="E" W ! D ^DIR K DIR W ! | 
|---|
| 38 | I '$D(ECX(727.4,+ECXWARD)) D | 
|---|
| 39 | .S (X,DINUM)=+ECXWARD,DIC(0)="L",DLAYGO=727.4,DIC="^ECX(727.4," | 
|---|
| 40 | .K DD,DO D FILE^DICN K DIC,DINUM,DLAYGO,X,Y | 
|---|
| 41 | S DR="1;",DIQ(0)="E",DIQ="ECX",DA=+ECXWARD,DIC="^ECX(727.4," K ECX D EN^DIQ1 | 
|---|
| 42 | S ECXDEPT=$G(ECX(727.4,+ECXWARD,1,"E")) | 
|---|
| 43 | S ECXDEPT0=ECXDEPT K X,Y | 
|---|
| 44 | ;if ward has dss dept, then edit | 
|---|
| 45 | I ECXDEPT]"" D | 
|---|
| 46 | .D REVERSE^ECXDSSD(ECXDEPT,.ECXDESC) | 
|---|
| 47 | .W !!,"DSS Department for Ward "_$P(ECXWARD,U,2) | 
|---|
| 48 | .W !?5,"Service ",?20,"<"_$E(ECXDEPT,1)_">  = "_$P(ECXDESC,U,1) | 
|---|
| 49 | .W !?5,"Prod. Unit ",?20,"<"_$E(ECXDEPT,2,3)_"> = "_$P(ECXDESC,U,2) | 
|---|
| 50 | .W !?5,"Division ",?20,"<"_$E(ECXDEPT,4)_">  = "_$P(ECXDESC,U,3) | 
|---|
| 51 | .W !?5,"Suffix ",?22,"   = "_$E(ECXDEPT,5,7),!! | 
|---|
| 52 | .S DIR(0)="YA",DIR("A")="Do you want edit this DSS Department? ",DIR("B")="YES" K X,Y | 
|---|
| 53 | .D ^DIR K DIR W !! | 
|---|
| 54 | .Q:$D(DIRUT) | 
|---|
| 55 | .I Y=1 D DEPT(ECXWARD,ECXDIV,.ECXDEPT) | 
|---|
| 56 | G:ECXDEPT0]"" EN | 
|---|
| 57 | ;if ward doesn't have dss dept, then enter | 
|---|
| 58 | I ECXDEPT0="" D DEPT(ECXWARD,ECXDIV,.ECXDEPT) | 
|---|
| 59 | G EN | 
|---|
| 60 | ; | 
|---|
| 61 | DEPT(ECXWARD,ECXDIV,ECXDEPT) ;allow user to enter/edit dss dept for ward | 
|---|
| 62 | ;division is already known from file #42 (above) | 
|---|
| 63 | ;service is 'nursing' by definition - ien 27 in file #730 | 
|---|
| 64 | ; input | 
|---|
| 65 | ; ECXWARD = 1st piece is ien to file #42 & file #727.4; required | 
|---|
| 66 | ; ECXDIV = 1st piece is ien to file $40.8 & file #727.3; required | 
|---|
| 67 | ; output | 
|---|
| 68 | ; ECXDEPT = current dss department code for ward or null | 
|---|
| 69 | N ECXSVC,ECXPUNIT,ECXDESC,ECXSUF,OUT,X,Y,SS,JJ,DIRUT,DTOUT,DUOUT | 
|---|
| 70 | I ECXDEPT="" D | 
|---|
| 71 | .W !,"The medical center division for the ward selected is" | 
|---|
| 72 | .W !,"already known.  The service associated with all ward" | 
|---|
| 73 | .W !,"production units is 'Nursing'.",! | 
|---|
| 74 | .W !!,"You must identify the DSS Production Unit for this ward," | 
|---|
| 75 | .W !,"and a suffix (if needed) to complete the DSS Department code." | 
|---|
| 76 | .I $E(IOST)="C" D | 
|---|
| 77 | ..S SS=22-$Y F JJ=1:1:SS W ! | 
|---|
| 78 | ..S DIR(0)="E" W ! D ^DIR K DIR W ! | 
|---|
| 79 | I ECXDEPT]"" D | 
|---|
| 80 | .W !,"You may edit the DSS Production Unit and suffix," | 
|---|
| 81 | F  D  Q:$D(DIRUT)!(OUT=1) | 
|---|
| 82 | .S ECXDEPT="" | 
|---|
| 83 | .S ECXSVC=27,(ECXPUNIT,ECXSUF)="",OUT=0 | 
|---|
| 84 | .S ECXDEPT=$$DERIVE^ECXDSSD(ECXSVC,ECXPUNIT,+ECXDIV,ECXSUF) | 
|---|
| 85 | .;diplay dss dept code to user | 
|---|
| 86 | .I ECXDEPT="" S OUT=1 Q | 
|---|
| 87 | .D REVERSE^ECXDSSD(ECXDEPT,.ECXDESC) | 
|---|
| 88 | .W !!,"DSS Department for Ward "_$P(ECXWARD,U,2) | 
|---|
| 89 | .W !?5,"Service ",?20,"<"_$E(ECXDEPT,1)_">  = "_$P(ECXDESC,U,1) | 
|---|
| 90 | .W !?5,"Prod. Unit ",?20,"<"_$E(ECXDEPT,2,3)_"> = "_$P(ECXDESC,U,2) | 
|---|
| 91 | .W !?5,"Division ",?20,"<"_$E(ECXDEPT,4)_">  = "_$P(ECXDESC,U,3) | 
|---|
| 92 | .W !?5,"Suffix ",?22,"   = "_$E(ECXDEPT,5,7),!! | 
|---|
| 93 | .S DIR(0)="YA",DIR("A")="Is this ok? ",DIR("B")="YES" K X,Y | 
|---|
| 94 | .D ^DIR K DIR | 
|---|
| 95 | .I $D(DIRUT)!(Y=0) S ECXDEPT="" Q | 
|---|
| 96 | .I Y S OUT=1 | 
|---|
| 97 | Q:$D(DIRUT) | 
|---|
| 98 | I ECXDEPT]"" S DIE="^ECX(727.4,",DA=+ECXWARD,DR="1////^S X=ECXDEPT;" D ^DIE | 
|---|
| 99 | W !! | 
|---|
| 100 | Q | 
|---|
| 101 | ; | 
|---|
| 102 | EXIT ;common exit point | 
|---|
| 103 | K ECX,ECXWARD,ECXDEPT,ECXSVC,ECXDIV,ECXPUNIT,ECXSUF,ECXDESC | 
|---|
| 104 | Q | 
|---|