VistA-WorldVistAEHR/r/WOMENS_HEALTH-WV/WVPURP.m

191 lines
5.6 KiB
Mathematica

WVPURP ;HIOFO/FT,JR-NOTIFICATION TABLES MAINTENANC; ;8/28/03 16:38
;;1.0;WOMEN'S HEALTH;**4,9,16**;Sep 30, 1998
;; Original routine created by IHS/ANMC/MWR
;;* MICHAEL REMILLARD, DDS * ALASKA NATIVE MEDICAL CENTER *
;; ADD/EDIT/PRINT NOTIFICATION PURPOSE FILE ENTRIES, EDIT PCD DAYS,
;; EDIT NOTIFICATION TYPE SYNONYMS, ADD/EDIT NOTIFICATION OUTCOMES.
;
; This routine uses the following IAs:
; #10089 - ^%ZISC call (supported)
; #10103 - ^XLFDT calls (supported)
; #10104 - ^XLFSTR calls (supported)
;
PRINTPUR ; Called by option "WV PRINT NOTIF PURPOSE&LETTER"
D SETVARS^WVUTL5
D DEVICE
I WVPOP D KILL Q
PRINT ; Print purpose and letter entries
U IO
S WVNAME="",(WVPAGE,WVPOP)=0
S WVDATE=$$FMTE^XLFDT($$NOW^XLFDT(),"1P") ;current date/time
S WVDASH=$$REPEAT^XLFSTR("-",79) ;line of dashes
; loop thru File 790.404 (B x-ref)
F S WVNAME=$O(^WV(790.404,"B",WVNAME)) Q:WVNAME=""!(WVPOP) S WVIEN=0 F S WVIEN=$O(^WV(790.404,"B",WVNAME,WVIEN)) Q:'WVIEN!(WVPOP) D
.S WVNODE=$G(^WV(790.404,WVIEN,0)) Q:WVNODE=""
.D HEADER
.D RESOLVE
.W !!?3,"PURPOSE: "_$P(WVNODE,U,1),?55,"SYNONYM: "_$P(WVNODE,U,3)
.W !?2,"PRIORITY: "_$G(WVARRAY(790.404,WVIEN_",",.02,"E")),?56,"ACTIVE: "_$G(WVARRAY(790.404,WVIEN_",",.04,"E"))
.W !?2,"BR or CX: "_$G(WVARRAY(790.404,WVIEN_",",.05,"E"))
.W !?4,"LETTER: "_$G(WVARRAY(790.404,WVIEN_",",.06,"E"))
.W !,"BR TX NEED: "_$G(WVARRAY(790.404,WVIEN_",",.07,"E"))
.S WVDUE=$$DMY($G(WVARRAY(790.404,WVIEN_",",.08,"E")))
.W ?48,"BR TX DUE DATE: "_WVDUE
.W !,"CX TX NEED: "_$G(WVARRAY(790.404,WVIEN_",",.09,"E"))
.S WVDUE=$$DMY($G(WVARRAY(790.404,WVIEN_",",.1,"E")))
.W ?48,"CX TX DUE DATE: "_WVDUE,!!
.S WVLINE=0
.F S WVLINE=$O(^WV(790.404,WVIEN,1,WVLINE)) Q:'WVLINE!(WVPOP) D
..I ($Y+4)>IOSL D:$E(IOST)="C" DIRZ^WVUTL3 Q:WVPOP D HEADER
..W !,$G(^WV(790.404,WVIEN,1,WVLINE,0))
..Q
.Q:WVPOP
.I $E(IOST)="C" D DIRZ^WVUTL3
.Q
I $D(ZTQUEUED) S ZTREQ="@"
KILL ; Kill variables
K WVARRAY,WVDASH,WVDATE,WVDUE,WVIEN,WVLINE
K WVNAME,WVNODE,WVPAGE,WVPOP,X,Y
D ^%ZISC
Q
HEADER ; Report header
W:$Y>0 @IOF
S WVPAGE=WVPAGE+1
W "NOTIFICATION PURPOSE & LETTER LIST",?45,WVDATE,?70,"PAGE: "_WVPAGE
W !,WVDASH
Q
RESOLVE ; Resolve data to external values
K WVARRAY
D CLEAN^DILF
D GETS^DIQ(790.404,WVIEN_",",".02;.04:.1","E","WVARRAY")
Q
DEVICE ; Get device and possibly queue to taskman
N ZTRTN
S ZTRTN="DEQUEUE^WVPURP"
D ZIS^WVUTL2(.WVPOP,1,"HOME")
Q
DEQUEUE ; Taskman queue of printout
D PRINT
Q
;
EDITPUR ;EP
;---> CALLED BY OPTION "WV EDIT NOTIF PURPOSE&LETTER".
D SETVARS^WVUTL5
;---> DISPLAY MENU TITLE FROM WV MENU OPTIONS.
F D Q:$G(Y)<0
.D TITLE^WVUTL5("EDIT NOTIFICATION PURPOSE & LETTER FILE")
.D DIC^WVFMAN(790.404,"QEMAL",.Y)
.Q:Y<0
.S DA=+Y
.D:$P(Y,U,3) ADDLET
.D:'$P(Y,U,3) REPLACE
.Q:WVPOP
.;---> EDIT WITH SCREENMAN.
.S DR="[WV NOTIFPURPOSE-FORM-1]"
.D DDS^WVFMAN(790.404,DR,DA,"","",.WVPOP)
D KILLALL^WVUTL8
Q
;
;
ADDLET ;EP
;---> CALLED BY OPTION "WV ADD NOTIF PURPOSE&LETTER".
K ^WV(790.404,DA,1)
N N S N=0
F S N=$O(^WV(790.6,1,1,N)) Q:'N D
.S ^WV(790.404,DA,1,N,0)=^WV(790.6,1,1,N,0)
S ^WV(790.404,DA,1,0)=^WV(790.6,1,1,0)
Q
;
REPLACE ;EP
;---> REPLACE OLD LETTER FOR THIS NOTIF PURPOSE WITH GENERIC SAMPLE.
N DIR,DIRUT,Y
W !!?3,"Do you wish to delete the old letter for this Purpose of "
W "Notification",!?3,"and replace it with the generic sample letter?"
S DIR(0)="YA",DIR("B")="NO"
S DIR("A")=" Enter Yes or No: " D HELP1
D ^DIR W !
S:$D(DIRUT) WVPOP=1
I Y D ADDLET
Q
;
HELP1 ;EP
;;Enter YES to delete the old letter for this Purpose of Notification
;;and to begin with a fresh copy of the generic sample letter.
S WVTAB=5,WVLINL="HELP1" D HELPTX
Q
;
HELPTX ;EP
N I,T,X S T=$$REPEAT^XLFSTR(" ",WVTAB)
F I=1:1 S X=$T(@WVLINL+I) Q:X'[";;" S DIR("?",I)=T_$P(X,";;",2)
S DIR("?")=DIR("?",I-1) K DIR("?",I-1)
Q
;
TYPE ;EP
;---> EDIT SYNONYMS FOR NOTIFICATION TYPES.
D SETVARS^WVUTL5
F D Q:$G(Y)<0
.D TITLE^WVUTL5("EDIT SYNONYMS FOR NOTIFICATION TYPES") D TEXT1
.N A S A=" Select NOTIFICATION TYPE: "
.D DIC^WVFMAN(790.403,"QEMA",.Y,A)
.Q:Y<0
.D DIE^WVFMAN(790.403,.03,+Y,.WVPOP)
W @IOF
D KILLALL^WVUTL8
Q
;
OUTCOME ;EP
;---> ADD/EDIT NOTIFICATION OUTCOME FILE.
D SETVARS^WVUTL5
F D Q:$G(Y)<0
.D TITLE^WVUTL5("ADD/EDIT NOTIFICATION OUTCOME FILE")
.D DIC^WVFMAN(790.405,"QEMAL",.Y," Select OUTCOME: ")
.Q:Y<0
.D DIE^WVFMAN(790.405,.02,+Y,.WVPOP)
W @IOF
D KILLALL^WVUTL8
Q
;
TEXT1 ;EP
;;You may enter a synonym for each Notification Type. The synonym will
;;allow the Notification Type to be called up by typing only a few
;;characters. Synonyms should be unique and less than 4 characters.
;;
;;For example, "L1" might be used for LETTER,FIRST; "L2" for
;;LETTER,SECOND; "L3" for LETTER,THIRD, and so on.
;;
;;
S WVTAB=5,WVLINL="TEXT1" D PRINTX
Q
;
PRINTX ;EP
N I,T,X S T=$$REPEAT^XLFSTR(" ",WVTAB)
F I=1:1 S X=$T(@WVLINL+I) Q:X'[";;" W !,T,$P(X,";;",2)
Q
;
GENSTUFF ;EP
;---> STUFF THE GENERIC SAMPLE LETTER INTO ALL PURPOSES OF NOTIF.
N DA
S DA=0
F S DA=$O(^WV(790.404,DA)) Q:'DA W !,DA D ADDLET^WVPURP
Q
DMY(WVDUE) ; Spell out Days, Months or Years
N WVDUE1,WVDUE2
I WVDUE="" Q ""
I '$S(WVDUE["D":1,WVDUE["M":1,WVDUE["Y":1,1:0) Q WVDUE
S WVDUE1=+WVDUE
S WVDUE2=$S(WVDUE["D":"Day",WVDUE["M":"Month",WVDUE["Y":"Year",1:"")
S:WVDUE1>1 WVDUE2=WVDUE2_"s"
S:WVDUE2="s" WVDUE2=""
S WVDUE=WVDUE1_" "_WVDUE2
Q WVDUE
;
DMYCHECK ; Called from ^DD(790.404,.8,0) - BR TX DUE DATE
; and ^DD(790.404,.1,0) - CX TX DUE DATE
; Check X to see if it is a date offset (e.g., 365D, 12M or 1Y).
; Returns -1 if not an exceptable value
Q:'$D(X)
I $L(X)>4!($L(X)<2) S X=-1 Q
S X=$$UP^XLFSTR(X)
I X'?1.3N1"D",X'?1.3N1"M",X'?1.3N1"Y" S X=-1
Q