| 1 | RMPR29S ;PHX/JLT-ASSIGN WORK ORDER[ 09/30/94  3:55 PM ] | 
|---|
| 2 | ;;3.0;PROSTHETICS;**50**;Feb 09, 1996 | 
|---|
| 3 | ; | 
|---|
| 4 | ;ODJ - Patch 50 - 7/13/00 - put in call to set patient vars. to | 
|---|
| 5 | ;                           prevent undef errs. cf nois MIW-1098-41197 | 
|---|
| 6 | ; | 
|---|
| 7 | ASK ;ASK FOR MUTLIPLE ASSGIN | 
|---|
| 8 | D DIV4^RMPRSIT G:$D(X) EXIT | 
|---|
| 9 | S DIR(0)="Y",DIR("A")="Would you like assign Multiple 2529-3's",DIR("B")="YES" D ^DIR G:$D(DIRUT)!($D(DTOUT)) EXIT I +Y=1 S PCOUNT=0 G MUL | 
|---|
| 10 | APP ;ASSIGN SINGLE 2529-3 TO TECHNICIAN | 
|---|
| 11 | S DIC="^RMPR(664.1,",DIC(0)="AEQM",DIC("S")="I $P(^(0),U,3)=RMPR(""STA""),'$P(^(0),U,20),($P(^(0),U,17)=""P""!($P(^(0),U,17)=""A""))",DIC("W")="D EN3^RMPRD1" D ^DIC G:+Y'>0 EXIT | 
|---|
| 12 | S RMPRDA=+Y,PASS=1 | 
|---|
| 13 | ASM ;check/lock record | 
|---|
| 14 | ;S RMPRDA=+Y | 
|---|
| 15 | Q:$G(RMPRDA)<1 | 
|---|
| 16 | L +^RMPR(664.1,RMPRDA,0):1 I '$T W !!,$C(7),?5,"Someone else is editing this entry" G EXIT | 
|---|
| 17 | S RMPRWO=$P(^RMPR(664.1,RMPRDA,0),U,13) G DISP^RMPR29D | 
|---|
| 18 | ATCH ;attach technician/status to record | 
|---|
| 19 | ;CALLED BY RMPR29T | 
|---|
| 20 | ;VARIABLE REQUIRED: RMPRDA - ENTRY NUMBER IN FILE 664.1 | 
|---|
| 21 | ;                   RMPR ARRAY - MISCELLANEOUS SITE DATASET BY | 
|---|
| 22 | ;                                A CALL TO DIV4^RMPRSIT | 
|---|
| 23 | ;                   RMPR("L") - A LINE OF DIRECTIONS | 
|---|
| 24 | K DIC,Y S DIC("B")=$S($P(^RMPR(664.1,+RMPRDA,0),U,16):$$EMP^RMPR31U($P(^(0),U,16)),1:""),DIC="^VA(200,",DIC(0)="AEQMZ",DIC("A")="LAB TECHNICIAN: " D ^DIC G:+Y'>0 EXIT S PEMP=+Y D ST^RMPR29U | 
|---|
| 25 | S DIE="^RMPR(664.1,",DR=$S($P($G(^RMPR(664.1,RMPRDA,7)),U):"19R",1:"19R///^S X=DT"),DA=RMPRDA D ^DIE G:$D(DTOUT)!($D(Y)) EXIT | 
|---|
| 26 | G DISP^RMPR29D | 
|---|
| 27 | EXIT ;common exit point | 
|---|
| 28 | ;CALLED BY RMPR29T | 
|---|
| 29 | L -^RMPR(664.1,+$G(RMPRDA),0) | 
|---|
| 30 | K DIC,DIE,DIR,DA,DIRUT,DR,DTOUT,PEMP,PREV,PSM,RMPRDA,RMPRDFN,RMPRWO,RI | 
|---|
| 31 | K PASS,PCOUNT Q | 
|---|
| 32 | MUL ;MULTIPLE ASSIGN | 
|---|
| 33 | S RMPRBAC1=1 | 
|---|
| 34 | K PDCA F RI=0:0 S RI=$O(^RMPR(664.1,"E","P",RI)) Q:+RI'>0  I +RI,$P($G(^RMPR(664.1,RI,0)),U,3)=RMPR("STA") S PDCA(RI)="",PREV(-RI)="" | 
|---|
| 35 | I '$D(PDCA) D MESS G EXIT | 
|---|
| 36 | S PCOUNT=$O(PDCA(PCOUNT)) G:$G(PCOUNT)<1 EXIT | 
|---|
| 37 | I +PCOUNT S Y=PCOUNT,RMPRDA=Y,PSM=1 | 
|---|
| 38 | D ASM | 
|---|
| 39 | Q | 
|---|
| 40 | NEXT ;LOOK THRU EXITING 2529-3's | 
|---|
| 41 | ;CALLED BY RMPR29T | 
|---|
| 42 | ;VARIABLES REQUIRED: PDCA - AN ARRAY | 
|---|
| 43 | ;                    RMPRDA - ENTRY IN FILE 664 | 
|---|
| 44 | ;                    PCOUNT - AN INDEX | 
|---|
| 45 | ;                    RMPR ARRAY - MISCELLANEOUS SET BY | 
|---|
| 46 | ;                                 A CALL TO DIV4^RMPRSIT | 
|---|
| 47 | ;I +$O(PDCA(RMPRDA))=0 W $C(7) S Y=RMPRDA G ASM | 
|---|
| 48 | ;S PCOUNT=$O(PDCA(PCOUNT)) I +PCOUNT S Y=PCOUNT G ASM | 
|---|
| 49 | I +$O(PDCA(RMPRDA))=0 W $C(7),!!,"There are no more 'next' jobs to assign." H 2 Q  ;G ASM | 
|---|
| 50 | S RMPRDA=$O(PDCA(RMPRDA)) I $G(RMPRDA)>0 G ASM | 
|---|
| 51 | Q | 
|---|
| 52 | PREV ;previous record | 
|---|
| 53 | ;CALLED BY RMPR29T | 
|---|
| 54 | ;VARIABLE REQUIRED: RMPRDA - SUPSCRIPT IN PREV ARRAY | 
|---|
| 55 | ;                   PREV - AN ARRAY | 
|---|
| 56 | I +$O(PREV(-RMPRDA))=0 W $C(7) S Y=RMPRDA G ASM | 
|---|
| 57 | S Y=$O(PREV(-RMPRDA)) I $G(Y)'="" S (PCOUNT,Y)=Y*-1,PSM=1,RMPRDA=Y G ASM | 
|---|
| 58 | Q | 
|---|
| 59 | MESS ;message/pause | 
|---|
| 60 | W !!,$C(7),?5,"No Lab 2529-3's need to be assigned" H 3 | 
|---|
| 61 | Q | 
|---|
| 62 | PRC ;entry point from option RMPR PROCESS 2529-3 JOB | 
|---|
| 63 | ;PROCESS 2529-3 TO CREATE WORK ORDER | 
|---|
| 64 | ;CALLED BY RMPR29A | 
|---|
| 65 | ;VARIABLES REQUIRED: NONE | 
|---|
| 66 | D KVAR^VADPT,HOME^%ZIS K X,Y,DIC | 
|---|
| 67 | D DIV4^RMPRSIT G:$D(X) EXIT | 
|---|
| 68 | S DIC="^RMPR(664.1,",DIC(0)="AEQM" | 
|---|
| 69 | ;screen | 
|---|
| 70 | ;if STATION = site selected | 
|---|
| 71 | ;if WORK ORDER NUMBER not null | 
|---|
| 72 | ;if NO LAB COUNT null | 
|---|
| 73 | ;if STATUS "A" Assigned to tech | 
|---|
| 74 | S DIC("S")="I $P(^(0),U,3)=RMPR(""STA""),$P(^(0),U,13)'="""",'$P(^(0),U,20),($P(^(0),U,17)=""A""" | 
|---|
| 75 | S DIC("W")="D EN3^RMPRD1" | 
|---|
| 76 | ;change to screen | 
|---|
| 77 | ;if supervisor key, add to screen | 
|---|
| 78 | ;if STATUS = "R"  returned to tech | 
|---|
| 79 | ;if STATUS = "PC" pending completion | 
|---|
| 80 | ;if STATUS = "P"  pending assignment | 
|---|
| 81 | ;or if not supervisor key, add to screen | 
|---|
| 82 | ;if STATUS = "R" | 
|---|
| 83 | S DIC("S")=$S($D(^XUSEC("RMPR LAB SUPERVISOR",DUZ)):DIC("S")_"!($P(^(0),U,17)=""R"")!($P(^(0),U,17)=""PC"")!($P(^(0),U,17)=""P""))",1:DIC("S")_"!($P(^(0),U,17)=""R""))") | 
|---|
| 84 | D ^DIC S:+Y RMPRDA=+Y K DIC G:+Y'>0 EXIT | 
|---|
| 85 | ; | 
|---|
| 86 | L +^RMPR(664.1,+Y,0):1 I '$T W !!,?5,$C(7),"Someone is already editing this entry" G EXIT | 
|---|
| 87 | S RMPRDFN=$P(^RMPR(664.1,+Y,0),U,2) I '$P(^(0),U,16) S RMPRWO=$P(^(0),U,13) | 
|---|
| 88 | D  ;preserve value of $T | 
|---|
| 89 | . D DPTVARS(RMPRDFN) ; set patient vars. required for display later on | 
|---|
| 90 | . Q | 
|---|
| 91 | I  S DIR(0)="Y",DIR("A")="You are self Assigning WORK ORDER #: "_RMPRWO_" ",DIR("B")="YES" | 
|---|
| 92 | ;if TECHNICIAN null | 
|---|
| 93 | I  W !! D ^DIR G:$D(DIRUT)!($D(DTOUT))!(+Y=0) EXIT I +Y=1 D EN4^RMPR29U(RMPRDA) S PEMP=DUZ S DIE="^RMPR(664.1,",DA=RMPRDA,DR="19///^S X=DT" D ^DIE D ST^RMPR29U G DISP^RMPR29D | 
|---|
| 94 | D EN4^RMPR29U(RMPRDA) G DISP^RMPR29D | 
|---|
| 95 | ;exit from RMPR29D | 
|---|
| 96 | ; | 
|---|
| 97 | ; Get patient vars using same code as in RMPRUTIL | 
|---|
| 98 | DPTVARS(DFN) ; | 
|---|
| 99 | N VADM,VAEL | 
|---|
| 100 | D DEM^VADPT | 
|---|
| 101 | D ELIG^VADPT | 
|---|
| 102 | ;set prosthetic variables | 
|---|
| 103 | ;rmprssn is number nnnnnnnnn | 
|---|
| 104 | ;rmprssne is external format of ssn nnn-nn-nnnn | 
|---|
| 105 | S RMPRNAM=$P(VADM(1),U),RMPRSSN=$P(VADM(2),U) | 
|---|
| 106 | S RMPRDOB=$P(VADM(3),U),RMPRSSNE=VA("PID") | 
|---|
| 107 | S RMPRCNUM=VAEL(7) | 
|---|
| 108 | Q | 
|---|