| 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
 | 
|---|