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

MCARDHLP.m

Go to the documentation of this file.
  1. MCARDHLP ;WISC/DCB-HELP FOR SCREEN INPUT ;8/27/96 10:06
  1. ;;2.3;Medicine;;09/13/1996
  1. Q
  1. START ;
  1. N SPACE,X,Y S MCARGDA=DJDN
  1. N VAL,MCERR,FLAG,TMP,XHOLD
  1. N SPACE S SPACE="" S $P(SPACE," ",80)=""
  1. I $D(MCDID) S DX=1,DY=1 X XY W SPACE
  1. Q:'$D(DJJ(+V))
  1. S @$P(DJJ(V),U,2) X XY
  1. I $D(MCHELPSW),('$D(MCHELPS2)) D FUNC^MCARDNQ2 K MCMASS D SKIP Q
  1. I $D(MCDID),$D(MCHELPSW),'$D(MCHELPS2) Q
  1. I (DJ4["200")!(DJ4["690") D FUNC Q
  1. S VAL=$P(DJ0,U,2)
  1. I VAL["F" G FUNC
  1. I VAL["S" D SETH(DJDD,DJAT,DJ0) D SKIP Q
  1. I DJ4["M" D MULT(DJDD,DJAT,DJDN,.FLAG)
  1. I VAL["P" D POINTER(DJDD,DJAT) D FUNC:$D(MCERR),SKIP Q
  1. I DJ4["M",VAL["D" D Q ; New line & dot block DAD 7-23-96
  1. . N %DT,DJAT,DJDD,DJX,MCMASS,X
  1. . S DJDD=+$P(DJ0,U,2),DJAT=.01
  1. . S X=$P($P(DJ0,U,5)," D ^%DT") S:X="" X="S %DT=""E""" X X
  1. . I $D(DJCP) X DJCP X XY W DJLIN
  1. . D HELP^MCARDNQ,FUNC
  1. . Q
  1. I DJ4["M",$TR(VAL,"aeAIM")=+VAL D Q ; New line & dot block DAD 8-14-96
  1. . N DJAT,DJDD
  1. . S DJDD=+$P(DJ0,U,2),DJAT=.01
  1. . I $D(DJCP) X DJCP X XY W DJLIN
  1. . D FUNC
  1. . Q
  1. FUNC ;
  1. D NUMBER(DJDD,DJAT)
  1. I $G(MCERR) D FUNC^MCARDNQ2
  1. SKIP ;
  1. S MCDID=1
  1. S @$P(DJJ(V),U,2) X XY Q
  1. POINTER(XFILE,FLD) ;
  1. N LINE,PTER,SUB,GL,XFLD,HOLD S HOLD=XFILE
  1. S LINE=$G(^DD(XFILE,FLD,0)) I LINE="" S MCERR=0 Q
  1. S GL=$P(LINE,U,3),LINE=$P(LINE,U,2)
  1. I GL'="" S PTER=+$P(LINE,"P",2)
  1. E S XFILE=+LINE,XFLD=.01,PTER=+$P($P($G(^DD(XFILE,XFLD,0)),U,2),"P",2)
  1. I +PTER=0 S MCERR=0 Q
  1. I PTER=200 S MCERR=0 Q
  1. D POINTERH(XFILE,PTER,FLD,HOLD)
  1. Q
  1. POINTERH(XFILE,MFILE,FLD,HOLD) ;
  1. N DIC,TMP,REC,LOOP,TOTAL,LEN,GLOBAL,Y,SETLOC
  1. N FIELDS,TYPE,EXC,TEMP,ERROR,X,XREF,SWITCH
  1. D RTNELM^MCDBELM(MFILE,1,".01","","","E","",.TEMP,.ERROR)
  1. S GLOBAL=TEMP("DIC"),XREF=GLOBAL_"""B"")"
  1. S GLOBAL=TEMP("GLO")
  1. S REC=+$P($G(@GLOBAL@(0)),U,4) I REC>200!(REC<1) S MCERR=1 Q
  1. S SETLOC=$$SCRN(HOLD,FLD),LOOP=0,D0=DJDN,HOLD=""
  1. W !
  1. F S HOLD=$O(@XREF@(HOLD)) Q:HOLD="" D
  1. .S Y=$O(@XREF@(HOLD,0))
  1. .S TEP=$G(@GLOBAL@(Y,0)),REC=Y X SETLOC
  1. .I $T D
  1. ..S $P(TEMP(1),U,2)=Y D GETDATA^MCDBSAVE(.TEMP,.ERROR)
  1. ..S XHOLD=$D(XHOLD(REC)),LOOP=LOOP+1
  1. ..S TMP(TEMP("FLD",.01))=XHOLD S SWITCH=XHOLD
  1. I (LOOP<1) S MCERR=1 Q
  1. I (LOOP>70) D:SWITCH'=0 ADJUST
  1. D HEADER("{Current choices}")
  1. D POINTER2(LOOP)
  1. Q
  1. ADJUST ;
  1. N %X,%Y,HOLD,TOTAL,XTEMP S XTEMP(1)="CURENTLY IN LIST",TOTAL=1
  1. F HOLD=1:1:LOOP D
  1. .I $D(TMP(HOLD,0)) S TOTAL=TOTAL+1,XTEMP(TOTAL)=TMP(HOLD,0)
  1. S LOOP=TOTAL K TMP
  1. S %X="XTEMP(",%Y="TMP(" D %XY^%RCR
  1. Q
  1. POINTER2(TOTAL) ;Help display for pointers
  1. N MAX,COL,SP,VAL,TYPE S VAL=""
  1. I TOTAL=0 S MCERR=1 Q
  1. S SP=" ",$P(SP," ",80)="",CT=0,COL=(TOTAL\7)
  1. S:(TOTAL/7)'=(TOTAL\7) COL=COL+1
  1. S MAX=80\COL,MLEN=MAX-2,COL=COL-1
  1. I $D(DJCP) X DJCP X XY W DJLIN
  1. F LOOP=1:1:TOTAL S VAL=$O(TMP(VAL)) Q:VAL="" D
  1. .S TYPE=TMP(VAL)
  1. .I CT>COL S CT=0 W !
  1. .I $G(VAL)'="" D
  1. ..S CT=CT+1
  1. ..W $S(TYPE:$G(DJHIN),1:"")_$E($E(VAL,1,MLEN)_SP,1,MAX)_$S(TYPE:$G(DJLIN),1:"")
  1. Q
  1. SETH(FILE,FIELD,TEMP) ;
  1. N DIC,LOOP,ITEMS,TMP,LOP,MAX,MLEN1,MLEN2,TOTAL
  1. I +$P(TEMP,U,2)'=0 S FILE=+$P(TEMP,U,2),FIELD=.01,TEMP=""
  1. S:$P($G(TEMP),U,3)="" TEMP=$G(^DD(FILE,FIELD,0))
  1. S TMP=$P(TEMP,U,3),MLEN1=0,MLEN2=0
  1. S DIC("S")=$$SCRN(FILE,FIELD),LOOP(0)=0,ITEMS=""
  1. Q:TMP=""
  1. F LOOP=1:1:$L(TMP,";") S MAX=$P(TMP,";",LOOP) Q:MAX="" D
  1. .I $G(DIC("S"))]"" S Y=$P(MAX,":") I Y]"" X DIC("S") Q:'$T
  1. .S LOOP(0)=LOOP(0)+1,ITEMS=ITEMS_MAX_";"
  1. .S LEN1=$L($P(MAX,":",1)) S:LEN1>MLEN1 MLEN1=LEN1
  1. .S LEN2=$L($P(MAX,":",2)) S:LEN2>MLEN2 MLEN2=LEN2
  1. S TOTAL=LOOP(0) D SET2(ITEMS,TOTAL,MLEN1,MLEN2)
  1. Q
  1. SET2(TMP,TOTAL,MLEN1,MLEN2) ;
  1. N MAX,COL,CT,LOOP,F1,F2,SP,Y
  1. S SP="",$P(SP," ",80)="",MLEN=MLEN1+3+MLEN2+2,CT=0
  1. S COL=(TOTAL\7) S:(TOTAL/7)'=(TOTAL\7) COL=COL+1
  1. S MAX=80\COL,MAX=MAX-2 S:MAX<MLEN MLEN=MAX
  1. S COL=COL-1
  1. S:COL=3&(TOTAL<8) COL=1 I $D(DJCP) X DJCP X XY W DJLIN
  1. F LOOP=1:1:TOTAL D
  1. .S TEMP=$P(TMP,";",LOOP),F1=$P(TEMP,":",1),F2=$P(TEMP,":",2)
  1. .S F1=$E(F1_SP,1,MLEN1),F2=$E(F2_SP,1,MLEN2)
  1. .I CT>COL S CT=0 W !
  1. .W $G(DJHIN),F1,$G(DJLIN)," - ",F2," "
  1. .S CT=CT+1
  1. D HEADER("{Help prompt for Set of Codes}")
  1. Q
  1. NUMBER(FILE,FIELD) ;
  1. N VAL
  1. S VAL=$G(^DD(FILE,FIELD,3)) I VAL="" S MCERR=1 Q
  1. D HEADER("{Help prompt}")
  1. I $D(DJCP) X DJCP X XY W DJLIN
  1. W !!,VAL
  1. Q
  1. MULT(FILE,FIELD,XREC,FLAG) ;
  1. N FIELDS,REC,EXC,DATA,TYPE,USER,TEMP,ERROR,LOOP,TOTAL,GLO,LEVEL
  1. S LEVEL=1,FIELDS=FIELD,REC=""
  1. D MAIN(FILE,.FIELDS,.LEVEL)
  1. I LEVEL>1 F LOOP=1:1:LEVEL S REC=REC_^TMP($J,"DJST",LOOP,"DA")_U
  1. E S REC=XREC_U,FIELDS=FIELD_U
  1. S REC=REC_1,FIELDS=FIELDS_".01"
  1. ;; ***ORIGINAL*** ;; S:$D(^DD(FILE,0,"UP")) FILE=^DD(FILE,0,"UP")
  1. F S FILE(0)=$G(^DD(FILE,0,"UP")) Q:FILE(0)'>0 S FILE=FILE(0) ;DAD81496
  1. D RTNELM^MCDBELM(FILE,REC,FIELDS,"","","E","",.TEMP,.ERROR)
  1. S GLO=TEMP("GLO")
  1. F LOOP=0:0 S LOOP=+$O(@GLO@(LOOP)) Q:LOOP=0 D
  1. .S REC=+$P($G(@GLO@(LOOP,0)),U,1),XHOLD(REC)=""
  1. Q
  1. MAIN(FILE,FIELDS,LEVEL) ;
  1. N HOLD,NAME
  1. S HOLD=$G(^DD(FILE,0,"UP"))
  1. I HOLD="" S FIELDS=$$REORDER(FIELDS,LEVEL) Q
  1. S NAME=$O(^DD(FILE,0,"NM","")),LEVEL=LEVEL+1
  1. S FIELDS=$G(FIELDS)_U_+$O(^DD(HOLD,"B",NAME,0))
  1. D MAIN(HOLD,.FIELDS,LEVEL)
  1. Q
  1. REORDER(FIELDS,LEVEL) ;
  1. N LOOP,HOLD S HOLD="" I LEVEL<2 Q ""
  1. F LOOP=LEVEL:-1:1 D
  1. .S HOLD=HOLD_$P(FIELDS,U,LOOP)_U
  1. Q HOLD
  1. N SPACE,TEMP,TMP S SPACE="",$P(SPACE," ",80)=" "
  1. S DX=1,DY=1 X XY
  1. S TMP=40-$L(MCHELP)
  1. S TEMP=$E(SPACE,1,TMP)_MCHELP
  1. W DJHIN,"*** Commands: ^C ",$S($D(DJTOGGLE):"or KP1 ",1:""),"***",?40,TEMP,DJLIN
  1. Q
  1. SCRN(SFILE,SFLD) ;
  1. N SCREEN
  1. I $G(^DD(SFILE,SFLD,12.1))'="" D SCSET
  1. I '$D(SCREEN) D
  1. .S SFILE=+$P(^DD(SFILE,SFLD,0),U,2),SFLD=.01
  1. .I 'SFILE?1N.N1".".N S SFILE=+$P(SFILE,"P",2)
  1. .I $G(^DD(SFILE,SFLD,12.1))'="" D SCSET
  1. Q $S($D(SCREEN):SCREEN,1:"I 1")
  1. SCSET ;
  1. I ^DD(SFILE,SFLD,12.1)["S DIC(""S"")" X ^(12.1) S SCREEN=DIC("S") K DIC("S") Q
  1. S SCREEN=^DD(SFILE,SFLD,12.1) Q