Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSODEDT

PSODEDT.m

Go to the documentation of this file.
  1. PSODEDT ;BHAM ISC/SAB - edit due answer sheet ; 06/03/92 17:26
  1. ;;7.0;OUTPATIENT PHARMACY;**2,268**;DEC 1997;Build 9
  1. SEQNUM K DIC S DIC="^PS(50.0731,",DIC("A")="Select DUE ANSWER SEQUENCE NUMBER ('^S' to Search): ",DIC(0)="QEAM" D ^DIC K DIC
  1. G:(X="^")!($D(DTOUT))!(X="") EXIT
  1. S PSA=+Y
  1. I (PSA<1)&($E(X,1,2)="^S") D SEARCH G:PSA<1 SEQNUM
  1. I PSA<1 W " ??",$C(7) G SEQNUM
  1. EDIT S DIE="^PS(50.0731,",(DA,PSODUEL)=PSA,DR=".01" L +^PS(50.0731,PSODUEL):$S(+$G(^DD("DILOCKTM"))>0:+^DD("DILOCKTM"),1:3) I '$T W !,"Entry is being edited by another user. Try Later!" G EXIT
  1. D ^DIE L -^PS(50.0731,PSODUEL) K DIE,DA,DR,PSODUEL
  1. G:$D(Y) EXIT
  1. D:$D(^PS(50.0731,PSA,0)) DIE^PSODLKP
  1. G PSODEDT
  1. EXIT K ^TMP("PSOD",$J)
  1. K DA,DIC,DIE,DIQ,DIR,DIROUT,DIRUT,DR,DTOUT,DUOUT,DX,DY,FLD,I,ID,IX,IXN
  1. K IXS,N,PID,PSDPOP,PSA,PSCH,PSDIG,PSEED,PSFLAG,PSHI,PSHIT,PSIX,PSL,PSLEN
  1. K PSLO,PSMARG,PSQ,PSQN,PSQNUM,PSQP,PSTXT,PSTYP,PSWRAP,X,Y
  1. QUIT
  1. ;
  1. W !!!!!,"If you do not know the Sequence Number, you may search by any or all of the",!,"following fields: "
  1. W !!?5,"QUESTIONNAIRE",!?5,"DRUG",!?5,"PROVIDER",!!?5,"Type '^' to exit.",!
  1. S PSFLAG=0
  1. F FLD=1,2,4 Q:$D(DTOUT)!$D(DUOUT) S DIR(0)="50.0731,"_FLD_"O" D ASK
  1. Q:'PSFLAG
  1. S IXS=""
  1. F FLD=1,2,4 I $D(PSCH(FLD)),PSCH(FLD) S IXS=$S(FLD=1:"Q",FLD=2:"D",1:"P")_IXS
  1. I $L(IXS)>1 S PSEED=$E(IXS) F N=0:0 S IX=PSEED D GETIXN S N=$O(^PS(50.0731,PSEED,PSCH(IXN),N)) Q:'N S PSHIT=1 D GETN I PSHIT S ^TMP("PSOD",$J,N)=""
  1. I $L(IXS)=1 S IX=IXS D GETIXN F N=0:0 S N=$O(^PS(50.0731,IXS,PSCH(IXN),N)) Q:'N S ^TMP("PSOD",$J,N)=""
  1. I '$D(^TMP("PSOD",$J)) W !!?5,"No Matches Found!!!",!! Q
  1. I '$O(^TMP("PSOD",$J,$O(^TMP("PSOD",$J,0)))) S PSA=$O(^TMP("PSOD",$J,0)) W !! Q
  1. S PSDPOP=0
  1. CHOICES W !!?2,"CHOOSE FROM...",!!
  1. S DIC="^PS(50.0731,",DR="1:9",DIQ="PID",DIQ(0)="E"
  1. S PSL=$S($D(IOSL):IOSL-3,1:21),(DX,DY)=0 X ^%ZOSF("XY")
  1. F N=0:0 S N=$O(^TMP("PSOD",$J,N)) Q:'N D DISPLAY Q:PSDPOP
  1. K DIC,DIQ
  1. S PSA=0
  1. Q
  1. ASK K DA
  1. D ^DIR K DIR
  1. S PSCH(FLD)=+Y,PSFLAG=PSFLAG+Y
  1. Q
  1. GETN F I=2:1:$L(IXS) S IX=$E(IXS,I) D GETIXN S PSHIT=PSHIT*$D(^PS(50.0731,IX,PSCH(IXN),N))
  1. Q
  1. GETIXN S IXN=$S(IX="Q":1,IX="D":2,1:4)
  1. Q
  1. DISPLAY I $Y,$Y>PSL S (DX,DY)=0 X ^%ZOSF("XY") S DIR(0)="E" D ^DIR W $C(13),$J("",45),$C(13) I 'Y S PSDPOP=1 Q
  1. S (PSQNUM,DA)=N,PSQ=""
  1. D EN^DIQ1
  1. F ID=.01:0 S ID=$O(PID(50.0731,DA,ID)) Q:'ID S PSQ=PSQ_PID(50.0731,DA,ID,"E")_$S($L(PID(50.0731,DA,ID,"E")):"/",1:"")
  1. D WRAP
  1. Q
  1. WRAP ;Enter here from PSODACT,PSODLKP,PSODEDT to format Question
  1. ;Needs PSQ=text, PSQNUM=question number
  1. NEW I,K
  1. S PSTXT=$P(PSQ,"^") W !,PSQNUM,"."
  1. S PSWRAP=1,PSMARG=$S('$G(PSORM):80,$D(IOM):IOM,1:80)-5
  1. W1 S:$L(PSTXT)<PSMARG PSWRAP(PSWRAP)=PSTXT I $L(PSTXT)'<PSMARG F I=PSMARG:-1:0 I $E(PSTXT,I)?1P S PSWRAP(PSWRAP)=$E(PSTXT,1,I),PSTXT=$E(PSTXT,I+1,999),PSWRAP=PSWRAP+1 G W1
  1. F K=1:1:PSWRAP W ?($L(PSQNUM)+2),PSWRAP(K),!
  1. Q
  1. QUES2 I PSTYP=1 W !!,?5,"Enter Y for YES, N for NO, U for UNKNOWN."
  1. I PSTYP=2 W !!,?5,"Enter a FREE TEXT answer from 1 to ",PSLEN," characters."
  1. I PSTYP=3 W !!,?5,"Enter a number between ",PSLO," and ",PSHI,!,?5,"with a maximum of ",PSDIG," decimal digits."
  1. W !?5,"Enter carriage return to bypass."
  1. W !?5,"Enter '^' to exit."
  1. D WRAP
  1. Q