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

GMTSOBA.m

Go to the documentation of this file.
  1. GMTSOBA ;SLC/KER,PWC - HS Object - Ask ;July 17, 2019@10:12 AM
  1. ;;2.7;Health Summary;**58,89,130**;Oct 20, 1995;Build 1
  1. ;
  1. ; External References
  1. ; DBIA 10018 ^DIE (file #142.5)
  1. ; DBIA 10026 ^DIR
  1. ; DBIA 10103 $$FMTE^XLFDT
  1. ; DBIA 10103 $$NOW^XLFDT
  1. ;
  1. OBJ ; Create/Edit Object
  1. N DA,X,Y,DIE,DR,GMTSED,GMTSCON,GMTSLBL,GMTSLBB,GMTSULB,GMTSHDR
  1. N GMTSRDT,GMTSCON,GMTSRHD,GMTSNEW,GMTSNEWO,GMTSDES,GMTSCHD,GMTSLIM
  1. N GMTSBLK,GMTSQ,GMTSDEC,GMTSNOD,GMTSOWN,GMTSDT,GMTSI,GMTSDA,GMTSUND
  1. N GMTSTIM,GMTSTI,GMTSOI,GMTSNDAT
  1. S (GMTSHDR,GMTSRDT,GMTSCON,GMTSRHD,GMTSCHD,GMTSUND,GMTSLIM,GMTSULB,GMTSLBB,GMTSBLK,GMTSDEC,GMTSNOD)=0,GMTSOWN="",GMTSDES=1
  1. S:'$L($G(GMTSNAM)) DA=$$LK^GMTSOBL Q:+($G(GMTSQ))>0
  1. S:$L($G(GMTSNAM)) DA=$$HSO^GMTSOBL($G(GMTSNAM)) Q:+($G(GMTSQ))>0 Q:+($G(DA))'>0
  1. S:$L($G(GMTSNAM)) GMTSNEW=+($P($G(DA),"^",3)),DA=+($P($G(DA),"^",1))
  1. Q:+($G(DA))'>0 S (GMTSDA,GMTSOI)=+($G(DA)),GMTSTI=$P($G(^GMT(142.5,+GMTSOI,0)),"^",3) Q:+GMTSTI'>0
  1. S GMTSLBL="" K GMTSOBJ S GMTSCON=1
  1. I $L($G(GMTSNAM)),+GMTSNEW'>0,+DA>0 D Q:+($G(GMTSCON))'>0 Q:+($G(GMTSQ))>0
  1. . N GMTSOWN S GMTSOWN=$P($G(^GMT(142.5,+DA,0)),"^",17)
  1. . I +GMTSOWN>0,+($G(DUZ))>0,+GMTSOWN'=+($G(DUZ)),'$D(^XUSEC("GMTSMGR",DUZ)) S GMTSCON=0 Q
  1. . W !," Object '",GMTSNAM,"' already exist" S GMTSCON=$$CONT Q:+($G(GMTSCON))'>0
  1. . N X,Y,DIR,DIE,DR,GMTSDEF,GMTSDICA,GMTSNAM,GMTSTYPE
  1. . W ! S GMTSDEF=+($P($G(^GMT(142.5,+($G(DA)),0)),"^",3))
  1. . S GMTSDEF=$S(+GMTSDEF>0:+GMTSDEF,1:"")
  1. . S GMTSDICA=" Enter/Edit HEALTH SUMMARY TYPE: "
  1. . K DTOUT,DUOUT,DIRUT,DIROUT
  1. . S GMTSTYPE=$$TY^GMTSOBL(GMTSDEF)
  1. . I $D(DTOUT)!($D(DUOUT))!($D(DIRUT))!($D(DIROUT)) S GMTSQ=1 Q
  1. . ;VSR - pwc GMTS*2.7*130 change //// to /// for validation before storage
  1. . S DR=".03///^S X=$G(GMTSTYPE)"
  1. . S DIE="^GMT(142.5,",DA=+($G(DA)) S GMTSED=0
  1. . F GMTSI=1:1:3 Q:GMTSI>3 L +^GMT(142.5,+($G(DA))):0 H:'$T 1 I $T D
  1. . . D ^DIE S GMTSED=1 S $P(^GMT(142.5,+DA,0),U,19)=$$NOW^XLFDT,GMTSI=4
  1. . . S:+($G(DUZ))>0 $P(^GMT(142.5,+DA,0),"^",17)=+($G(DUZ))
  1. . I 'GMTSED S GMTSQ=1 K GMTSOBJ W !," Record Locked by another user" Q
  1. . L -^GMT(142.5,+($G(DA))) S GMTST=+($P($G(^GMT(142.5,+DA,0)),U,3))
  1. K:+($G(GMTSQ))>0 GMTSOBJ Q:+($G(GMTSQ))>0
  1. D ALL K:+($G(GMTSQ))>0 GMTSOBJ S:+($G(GMTSQ))>0 GMTSDES=0 Q:+($G(GMTSQ))>0 N DIE,DR
  1. S GMTSHDR=+($G(GMTSOBJ("HEADER")))
  1. S GMTSLBL=$G(GMTSLBL) I GMTSHDR>0 D
  1. . S GMTSRDT=$S($D(GMTSOBJ("DATE LINE")):1,1:0)
  1. . S GMTSCON=$S($D(GMTSOBJ("CONFIDENTIAL")):1,1:0)
  1. . S GMTSRHD=$S($D(GMTSOBJ("REPORT HEADER")):1,1:0)
  1. . S GMTSCHD=$S($D(GMTSOBJ("COMPONENT HEADER")):1,1:0)
  1. . S GMTSUND=$S($D(GMTSOBJ("UNDERLINE")):1,1:0)
  1. . S GMTSLIM=$S($D(GMTSOBJ("LIMITS")):1,1:0)
  1. . S GMTSBLK=$S($D(GMTSOBJ("BLANK LINE")):1,1:0)
  1. . S GMTSDEC=$S($D(GMTSOBJ("DECEASED")):1,1:0)
  1. . S GMTSULB=$S($D(GMTSOBJ("USE LABEL")):1,1:0)
  1. . S GMTSLBB=$S($D(GMTSOBJ("LABEL BLANK LINE")):1,1:0)
  1. . S GMTSNDAT=$G(GMTSOBJ("NO DATA"))
  1. I GMTSHDR'>0 S (GMTSRDT,GMTSCON,GMTSRHD,GMTSCHD,GMTSUND,GMTSLIM,GMTSBLK,GMTSDEC,GMTSULB,GMTSLBB)=0,GMTSLBL=""
  1. S GMTSNOD=$S($D(GMTSOBJ("SUPPRESS COMPONENTS")):1,1:0)
  1. S:+GMTSCHD'>0 (GMTSLIM,GMTSBLK)=0
  1. S:'$L($G(GMTSLBL)) GMTSLBL="@",(GMTSULB,GMTSLBB)=0
  1. ; ;VSR pwc GMTS*2.7*130 replace //// with /// for validation before storage
  1. N DR S DR=".02///^S X=$G(GMTSLBL);"
  1. S:$L($G(GMTSTIM))&($G(GMTSTIM)'="@") DR=DR_".04///^S X=$G(GMTSTIM);"
  1. S DR=DR_".05///^S X=$G(GMTSNOD);",DR=DR_".06///^S X=$G(GMTSHDR);"
  1. S DR=DR_".07///^S X=$G(GMTSULB);",DR=DR_".08///^S X=$G(GMTSLBB);"
  1. S DR=DR_".09///^S X=$G(GMTSRDT);",DR=DR_".1///^S X=$G(GMTSCON);"
  1. S DR=DR_".11///^S X=$G(GMTSRHD);",DR=DR_".12///^S X=$G(GMTSCHD);"
  1. S DR=DR_".13///^S X=$G(GMTSUND);",DR=DR_".14///^S X=$G(GMTSLIM);"
  1. S DR=DR_".15///^S X=$G(GMTSBLK);",DR=DR_".16///^S X=$G(GMTSDEC);"
  1. S DR=DR_"2///^S X=$G(GMTSNDAT);"
  1. ; End of VSR patch GMTS*2.7*130
  1. S:+($G(GMTSDES))>0 DR=DR_"1" S:$E(DR,1)=";" DR=$E(DR,2,$L(DR)) S:$E(DR,$L(DR))=";" DR=$E(DR,1,($L(DR)-1))
  1. S DIE="^GMT(142.5,",DA=+($G(DA)) S GMTSED=0 W:+($G(GMTSDES))>0 !
  1. F GMTSI=1:1:3 Q:GMTSI>3 L +^GMT(142.5,+($G(DA))):0 H:'$T 1 I $T D
  1. . D ^DIE S GMTSED=1 S $P(^GMT(142.5,+DA,0),U,19)=$$NOW^XLFDT,GMTSI=4
  1. . S:$G(GMTSTIM)="@" $P(^GMT(142.5,+DA,0),U,4)=""
  1. I 'GMTSED S GMTSQ=1 K GMTSOBJ W !," Record Locked by another user" Q
  1. L -^GMT(142.5,+($G(DA))) S GMTST=+($P($G(^GMT(142.5,+DA,0)),U,3))
  1. K GMTSOBJ Q
  1. ;
  1. ALL ; Print HS Header
  1. N X,Y,DIR,DIROUT,DUOUT,DTOUT S GMTSOBJ="",GMTSQ=0 D RP Q:+($G(GMTSQ))>0
  1. S DIR("A")=" Print standard Health Summary Header with the Object? "
  1. S DIR("B")="N",DIR(0)="YAO",(DIR("?"),DIR("??"))="^D ALL^GMTSOBH"
  1. W ! D ^DIR S:$D(DIROUT)!($D(DTOUT)) GMTSQ=1
  1. S:Y["^"!(X["^") GMTSE=1,GMTSQ=1,GMTSDES=0
  1. K:+($G(GMTSQ))>0!($D(DUOUT)) GMTSOBJ Q:+($G(GMTSQ))>0!($D(DUOUT))
  1. S X=+($G(Y)) K:+X>0 GMTSOBJ S:+X'>0 GMTSOBJ=""
  1. S GMTSOBJ("HEADER")=$S(+X'>0:1,1:0)
  1. I +X'>0 D
  1. . W ! D PART Q:+($G(GMTSQ))>1 W ! S GMTSLBL="" D LBL^GMTSOBA2
  1. . S GMTSLBL=$S($L($G(GMTSOBJ("LABEL"))):$G(GMTSOBJ("LABEL")),1:"@")
  1. . K:'$L($G(GMTSOBJ("LABEL"))) GMTSLBL,GMTSOBJ("LABEL BLANK LINE"),GMTSOBJ("USE LABEL")
  1. W ! D SC^GMTSOBA2 K:+($G(GMTSQ))>0 GMTSOBJ
  1. W ! D NODATA^GMTSOBA2 K:+($G(GMTSQ))>0 GMTSOBJ
  1. Q
  1. ;
  1. RP ; Report Period
  1. Q:+($G(GMTSQ))>0 N X,Y,DIR,DIROUT,DUOUT,DTOUT,GMTSDEF
  1. S GMTSTIM=$$RP^GMTSOBT($G(GMTSTI),$G(GMTSOI)) S:+GMTSTIM<0 GMTSQ=1
  1. Q
  1. ;
  1. PART ; Print Partial Header
  1. K:+($G(GMTSQ))>0 GMTSOBJ Q:+($G(GMTSQ))>0 W !," Partial Header:"
  1. D:$D(GMTSOBJ) RD,RC,RH,CH^GMTSOBA2,DE^GMTSOBA2 Q
  1. RD ; Report Date
  1. Q:+($G(GMTSQ))>0 N X,Y,DIR,DIROUT,DUOUT,DTOUT,GMTSDEF
  1. S GMTSDEF=$P($G(^GMT(142.5,+($G(GMTSDA)),0)),U,9)
  1. S GMTSDEF=$S(+GMTSDEF>0:"Y",1:"N")
  1. S GMTSOBJ("DATE LINE")="",DIR("A")=" Print Report Date? "
  1. S DIR("B")=GMTSDEF,DIR(0)="YAO",(DIR("?"),DIR("??"))="^D RD^GMTSOBH"
  1. D ^DIR S:$D(DIROUT)!($D(DTOUT)) GMTSQ=1
  1. S:Y["^"!(X["^") GMTSE=1,GMTSQ=1,GMTSDES=0
  1. K:+($G(GMTSQ))>0 GMTSOBJ("DATE LINE") Q:+($G(GMTSQ))>0
  1. S X=+($G(Y)) K:+X'>0 GMTSOBJ("DATE LINE") Q
  1. RC ; Confidentiality Banner
  1. Q:+($G(GMTSQ))>0 N X,Y,DIR,DIROUT,DUOUT,DTOUT,GMTSDEF
  1. S GMTSOBJ("CONFIDENTIAL")="",DIR("A")=" Print Confidentiality Banner? "
  1. S GMTSDEF=$P($G(^GMT(142.5,+($G(GMTSDA)),0)),U,10)
  1. S GMTSDEF=$S(+GMTSDEF>0:"Y",1:"N")
  1. S DIR("B")=GMTSDEF,DIR(0)="YAO",(DIR("?"),DIR("??"))="^D RC^GMTSOBH"
  1. D ^DIR S:$D(DIROUT)!($D(DTOUT)) GMTSQ=1
  1. S:Y["^"!(X["^") GMTSE=1,GMTSQ=1,GMTSDES=0
  1. K:+($G(GMTSQ))>0 GMTSOBJ("CONFIDENNTIAL") Q:+($G(GMTSQ))>0
  1. S X=+($G(Y)) K:+X'>0 GMTSOBJ("CONFIDENTIAL") Q
  1. RH ; Report Header
  1. Q:+($G(GMTSQ))>0 N X,Y,DIR,DIROUT,DUOUT,DTOUT,GMTSDEF
  1. S GMTSOBJ("REPORT HEADER")="",DIR("A")=" Print Report Header? "
  1. S GMTSDEF=$P($G(^GMT(142.5,+($G(GMTSDA)),0)),U,11)
  1. S GMTSDEF=$S(+GMTSDEF>0:"Y",1:"N")
  1. S DIR("B")=GMTSDEF,DIR(0)="YAO",(DIR("?"),DIR("??"))="^D RH^GMTSOBH"
  1. D ^DIR S:$D(DIROUT)!($D(DTOUT)) GMTSQ=1
  1. S:Y["^"!(X["^") GMTSE=1,GMTSQ=1,GMTSDES=0
  1. K:+($G(GMTSQ))>0 GMTSOBJ("REPORT HEADER") Q:+($G(GMTSQ))>0
  1. S X=+($G(Y)) K:+X'>0 GMTSOBJ("REPORT HEADER") Q
  1. ;
  1. CONT(X) ; Continue with Edit
  1. N DIR,DIROUT,DTOUT
  1. S DIR(0)="YAO",DIR("B")="NO",DIR("A")=" Do you want to edit the object? Y/N "
  1. D ^DIR S X=+($G(Y)) Q X