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

GMTSPP.m

Go to the documentation of this file.
  1. GMTSPP ;SLC/KER - Define HS Print-by-Location Parameters ; 09/21/2001
  1. ;;2.7;Health Summary;**2,30,47**;Oct 20, 1995
  1. ;
  1. ; External References
  1. ; DBIA 10003 DD^%DT
  1. ; DBIA 10006 ^DIC
  1. ; DBIA 2051 FIND^DIC
  1. ; DBIA 10018 ^DIE
  1. ; DBIA 2056 $$GET1^DIQ
  1. ; DBIA 10026 ^DIR
  1. ;
  1. MAIN ; Print by Location
  1. K DIC,DIE,DIR
  1. S DIC=19.2,DIC(0)="F",X="GMTS TASK STARTUP" S Y=$$SDT(X)
  1. I Y<0 D ALERT K X,Y G MAIN1
  1. I Y>DT D QUEOK K Y G MAIN1
  1. D ALERT
  1. MAIN1 ; Controls Branching
  1. F D GETDATA Q:$D(PPQIT)!$D(DTOUT)
  1. K CLINIC,DIROUT,DIRUT,DTOUT,DUOUT,GMTSIFN,GMTSLOC,J1,J2,NEWTYP,PPQIT,X,B,C,D0,DI,DIJ,DISYS,DP,DQ,P
  1. Q
  1. QUEOK ; Informs user of print time if queued to print
  1. D DD^%DT S QTIM=Y K Y
  1. W !!,"For your information:",!
  1. W "Health Summary Batches are queued to print nightly at ",QTIM,!
  1. W "and should be available for distribution by early morning.",!
  1. K QTIM
  1. Q
  1. ALERT ; Warns user that summaries have not been queued
  1. W !!," ***Alert***",!!
  1. W "Health Summary batches have not been queued to print or date is not current.",!
  1. W "Please ask your IRM SERVICE to queue option GMTS TASK STARTUP",!
  1. W "to run nightly. Parameters may be set now but will not produce",!
  1. W "Health Summaries until option is queued."
  1. Q
  1. GETDATA ; Selects Location/Health Summary Type and Edits parameters
  1. S DIC=44,DIC(0)="AEMQZ",DIC("A")="Select Hospital Location: ",DIC("S")="I ""WCOR""[$P(^(0),U,3)" W ! D ^DIC K DIC
  1. I Y=-1 K X,Y S PPQIT=1 Q
  1. S GMTSLOC=+Y,GMTSLNM=$P(Y,U,2),CLINIC=$S("COR"[$P(Y(0),U,3):1,1:0) K X,Y
  1. I $O(^GMT(142,"D",GMTSLOC,0)) D DISPLAY
  1. K GMTSLNM
  1. S DIC=142,DIC(0)="AEQ",DIC("A")="Select Health Summary Type: " S Y=$$TYPE^GMTSULT K DIC
  1. I X="" K X,Y Q
  1. I Y=-1 K X,Y S PPQIT=1 Q
  1. S GMTSIFN=+Y,NEWTYP=1,TYP1=0
  1. F S TYP1=$O(^GMT(142,"D",GMTSLOC,TYP1)) Q:TYP1="" I GMTSIFN=TYP1 S NEWTYP=0 Q
  1. S GMTSUM=$P(Y,U,2),GMTSNEW=0,EXISTS=1,GMTSQIT=0 K X,Y D LIST^GMTSRM
  1. K GMTSNEW,EXISTS,GMTSQIT,GMTSUM,TYP1
  1. Q:$D(DUOUT) I $D(DIRUT) S PPQIT=1 Q
  1. I NEWTYP=1 D NEW Q
  1. S DIR(0)="Y",DIR("A")="Do you wish to delete this Health Summary Type from the nightly print",DIR("B")="NO"
  1. W ! D ^DIR K DIR
  1. Q:$D(DUOUT) I $D(DIRUT) S PPQIT=1 Q
  1. S DIE="^GMT(142,"_GMTSIFN_",20,",DIE("NO^")="OUTOK",DA(1)=GMTSIFN
  1. S DA=$O(^GMT(142,"D",GMTSLOC,GMTSIFN,0)),DEL=0
  1. I Y=1 S DR=".01///@",DEL=1
  1. K X,Y
  1. E S:CLINIC DR=".02;I $P($G(^GMT(142.99,1,0)),U,2)'=""Y"" S Y=""@1"";.03;@1;.04//0" S:'CLINIC DR=".02;I $P($G(^GMT(142.99,1,0)),U,2)'=""Y"" S Y=0;.03" W !
  1. D ^DIE
  1. I DEL W !!,"**Print for Health Summary Type deleted**"
  1. K DIE,DA,DR,X,Y,DEL
  1. Q
  1. DISPLAY ; Displays Health Summary Types associated with Location
  1. W !!,"At present the following Health Summary Types are printed for ",GMTSLNM,":"
  1. W !?70,"Action",!?2,"Type",?32,"Device" W:CLINIC ?54,"Days Ahead" W ?70,"Profile",!
  1. S DEVFLG=0
  1. S TYP=0 F J1=1:1 S TYP=$O(^GMT(142,"D",GMTSLOC,TYP)) Q:TYP="" D WRITE
  1. I DEVFLG W !!,"*This Type will not print since Device is invalid or has not been entered"
  1. W !!,"You may edit a Health Summary Type from the list or enter a new Type",!
  1. K TYP,DEVFLG
  1. Q
  1. WRITE ; Writes Health Summary Type with parameters
  1. S TYPNM=$P(^GMT(142,TYP,0),U),LOCIFN=$O(^GMT(142,"D",GMTSLOC,TYP,0))
  1. S DATA=^GMT(142,TYP,20,LOCIFN,0),DEV=$P(DATA,U,2)
  1. S X="`"_DEV,DIC=3.5,DIC(0)="" D ^DIC
  1. I +Y'>0 S DEVFLG=1
  1. S DEVNM=$S(+Y>0:$P(Y,U,2),DEV="":"None",1:DEV_" (Invalid)")
  1. W !,$S(+Y'>0:"*",1:" "),TYPNM,?32,$E(DEVNM,1,21),?59,$P(DATA,U,4),?72,$S($P(DATA,U,3)="Y":"Yes",1:"No") K DIC,X,Y
  1. K DATA,DAYS,DEV,DEVNM,LOCIFN,TYPNM
  1. Q
  1. NEW ; Sets parameters for new Health Summary Type
  1. S (NI,LI)=0 I $D(^GMT(142,GMTSIFN,20,0)) F S NI=$O(^GMT(142,GMTSIFN,20,NI)) Q:NI'>0 S LI=NI
  1. S:'$D(^GMT(142,GMTSIFN,20,0)) ^(0)="^142.2P^^"
  1. S DIE="^GMT(142,"_GMTSIFN_",20,",DA(1)=GMTSIFN,DA=LI+1,DIE("NO^")="OUTOK"
  1. I CLINIC S DR=".01////"_GMTSLOC_";.02;I $P($G(^GMT(142.99,1,0)),U,2)'=""Y"" S Y=""@1"";.03;@1;.04//0"
  1. E S DR=".01////"_GMTSLOC_";.02;I $P($G(^GMT(142.99,1,0)),U,2)'=""Y"" S Y=0;.03"
  1. W ! D ^DIE K DIE,DA,DR,X,Y,NI,LI,J3
  1. Q
  1. SDT(X) ; Get the last schedule date/time
  1. N GMTSM,GMTSR,GMTSI,GMTSE,GMTSDA S (GMTSI,GMTSM)=0
  1. D FIND^DIC(19.2,,,"X",X,5,,,,"GMTSDA")
  1. F S GMTSI=$O(GMTSDA("DILIST",2,GMTSI)) Q:GMTSI'>0 D
  1. . S GMTSE=GMTSDA("DILIST",2,GMTSI) Q:+GMTSE'>0
  1. . S GMTSR=$$GET1^DIQ(19.2,(GMTSE_","),2,"I")
  1. . S:+GMTSR>GMTSM GMTSM=+GMTSR
  1. S X=$S(+($G(GMTSM))>0:+($G(GMTSM)),1:-1) Q X