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

MCARDPL.m

Go to the documentation of this file.
  1. MCARDPL ;WISC/TJK,FDJW,JA-DISPLAY SCREEN ;8/31/92 09:03
  1. ;;2.3;Medicine;;09/13/1996
  1. S:'$D(DJDPL) DJDPL="" I DJDPL'=DJNM S DJN=$O(^MCAR(697.3,"B",DJNM,0)) S:DJN="" DJN=-1 G ER:DJN<1
  1. N S:'$D(DJFF) DJFF=0
  1. K DJJ,DJF,DJKEY,DJY S:DJN'=+DJN DJN=$O(^MCAR(697.3,"B",DJN,0)) S:DJN="" DJN=-1 G ER:DJN<0 S DJ0=^MCAR(697.3,DJN,0),DJDPL=$P(DJ0,U,1),DJJ=$P(DJ0,U,2,5),DJDD=$P(DJ0,U,6),V=$O(^MCAR(697.3,DJN,1,"A",0)) S:V="" V=-1 S (DJL,DJF)=V
  1. G ER:+V<0
  1. D:'DJFF HDH I DJDD'=+DJDD S DIC="^MCAR(697.3,DJN,1," G N1
  1. S DJ0="",DJ1=DJDD F V=1:1 Q:'$D(^DD(DJ1,0,"UP")) S DJ1=^("UP"),DJ2=$O(^("NM",0)) S:DJ2="" DJ2=-1 S DJ2=$O(^DD(DJ1,"B",DJ2,"")) S:DJ2="" DJ2=-1 S DJ2=$P($P(^DD(DJ1,DJ2,0),U,4),";",1) S:DJ2'=+DJ2 DJ2=""""_DJ2_"""" S DJ0="DA("_V_"),"_DJ2_","
  1. S DIC=^DIC(DJ1,0,"GL")_DJ0,V=DJF,DIE=DIC I $D(DJST),DJST>1 S DIC=^TMP($J,"DJST",DJST,"DIC")
  1. IF '$D(^MCAR(697.3,DJN,1,"A",V)) D
  1. . S YMLH=$O(^MCAR(697.3,DJN,1,"A",V))
  1. . I YMLH="" S YMLH=-1
  1. . S (DJF,V)=YMLH
  1. . Q
  1. ;END IF
  1. ;
  1. N1 ;
  1. S DJK=$O(^MCAR(697.3,DJN,1,"A",V,0)) S:DJK="" DJK=-1
  1. G ER:DJK<0!($D(^MCAR(697.3,DJN,1,DJK,0))<0)
  1. S DJ0=^MCAR(697.3,DJN,1,DJK,0)
  1. S:$P(DJ0,U,5)=.01 DJKEY=V G:$P(DJ0,U,2)="" ER S @$P(DJ0,U,2) X XY I V#1=0 W DJHIN X XY W $J(V,2)," ",DJLIN
  1. I '$P(DJ0,U,8) W:(V#1<1)&(V#1>0) DJHIN W $P(DJ0,U,1) W DJLIN W:$P(DJ0,U,5)>0 ":"
  1. I V#1=0!(V=.5) S DJJ(V)=$P(DJ0,U,3,7)_"^"_$P(DJ0,U,12),@$P(DJ0,U,4) X XY K:$P(DJ0,U,5)<0 V(V)
  1. I $P(DJ0,U,12)]"" D
  1. .S DJNO=$O(^MCAR(697.3,"B",$P(DJ0,U,12),0))
  1. .S DJJ(V)=DJJ(V)_U_$P(^MCAR(697.3,DJNO,1,0),U,4)
  1. .K DJNO
  1. I V#1=0!(V=.5) S $P(DJJ(V),U,8)=$P(DJ0,U,2)
  1. G:V#1'=0 N2
  1. ;
  1. ; Is there data in the field?
  1. IF $G(V(V))]"",DJJ(V) D ; yes, prepare it for display
  1. . W DJHIN
  1. . X XY
  1. . I DJJ(V)["M" S V(V)=$E(V(V),1,+DJJ(V))
  1. . S DJDB=""
  1. . I DJJ(V)-$L(V(V)) S $P(DJDB," ",DJJ(V)-$L(V(V)))=" "
  1. . S DJDB=V(V)_DJDB
  1. . ;W V(V)
  1. . ;I $D(DJDB) W DJDB
  1. . ;K DJDB
  1. . ;W DJLIN
  1. . Q
  1. ELSE D ; there is no data in the field, just write dots
  1. . S $P(DJDB,".",DJJ(V))="."
  1. . W DJLIN ;,DJDB
  1. . ;K DJDB
  1. . Q
  1. ;END IF
  1. ;
  1. ; Are we going to spill over to the next line?
  1. I $L(DJDB)<80 W DJDB ; no
  1. E W $E(DJDB,1,80-DX),!,$E(DJDB,80-DX+1,$L(DJDB)) ; yes
  1. K DJDB
  1. ;
  1. N2 S V=$O(^MCAR(697.3,DJN,1,"A",V)) S:V="" V=-1 S:V>DJL DJL=V G N1:V>0 S V=DJF
  1. K DJ0,DJ1,DJ2 Q
  1. EN S DJFF=0 G N
  1. EN1 S DJFF=1 G N
  1. ;Q
  1. HDH ;HEADING
  1. S DJT=$P(DJ0,U,7) S DY=0,DX=0 X DJCP W @IOF,?(80-$L(DJT))/2-5,DJT," ",$E(DT,4,5),"/",$E(DT,6,7),"/",$E(DT,2,3)
  1. ;I $D(DJST),DJST>1 F DJK=1:1:DJST-1 W !,?DJK*2,"***",^TMP($J,"DJST",DJK,"TITLE"),"***"
  1. ;I $D(DJST),$P(DJJ,U,2)'="" W !,?3,"***",^TMP($J,"DJST",DJST,"TITLE"),"***"
  1. Q
  1. ER ;
  1. Q
  1. X DJCL W "SCREEN **",DJNM,"** HAS NOT BEEN PROPERLY CREATED. Check your 'A' XREF",*7 H 2
  1. K DIC,DIE,DJ0,DJ1,DJDD,DJDPL,DJF,DJJ,DJK,DJKL,DJKL,DJL,DJNM,DJT,V
  1. S DJY=-1 Q