[613] | 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
|
---|