VistA-GuiMail/p/CWMAIL0.m

88 lines
4.4 KiB
Mathematica

CWMAIL0 ;INDPLS/PLS- DELPHI MAIL SERVER, CONT'D ;21-Jun-2005 06:34;CLC
;;2.3;CWMAIL;;Jul 19, 2005
Q ;ROUTINE CAN'T BE CALLED DIRECTLY
;
PROCMS(CWDATA,CWMSGN,CWNMFLG) ;PROCESS MAIL MESSAGE THREAD
N CWRE,CWCNT,CWRSP,CWNWMSG,CWDATT,CWLCNT,CWLP,CWCONFRM,CW
N CWIM,CWIU,CWINSTR,CWFLAGS,CWIR
D INMSG^XMXUTIL2(XMDUZ,$$BSKT^XMXUTIL2(XMDUZ,CWMSGN),CWMSGN,,"F",.CWIM,.CWINSTR,.CWIU) ;SET-UP MESSAGE INFO
S CWDATA=$NA(^TMP($J,"CWMAIL"))
S CWNWMSG=$G(CWIM("FROM"))["@" ;NETWORK MESSAGE
S CWCNT=2,CWLCNT=0
S @CWDATA@(CWCNT)="Mail Message From: "_$G(CWIM("FROM NAME"))_" "_"Dated: "_$$FMDTE^CWMAIL4(CWIM("DATE FM"),"5MZ")
S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)="Subject: "_$G(CWIM("SUBJ"))
S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)=""
;I 'CWNMFLG!(CWNMFLG&($G(CWIM("RESP"))<1))!(CWNMFLG&(+$G(CWIM("RESP"))=+$G(CWIM("RESPS"))))
I 'CWNMFLG!(CWNMFLG&(+$G(CWIU("RESP"))<1))!(CWNMFLG&(+$G(CWIU("RESP"))=+$G(CWIM("RESPS")))) D READM(.CWDATA,CWMSGN,.CWCNT)
S CWCONFRM=""
D LASTACC(CWMSGN,$$BSKT^XMXUTIL2(XMDUZ,CWMSGN),0,.CWCONFRM) ;UPDATE LAST ACCESS DATE/TIME
;PROCESS RESPONSES
I $G(CWIM("RESPS"))>0 D
. S CWLP=$S(+$G(CWIU("RESP"))=+$G(CWIM("RESPS")):1,+$G(CWIU("RESP"))<1:1,CWNMFLG:+$G(CWIU("RESP")),1:1) F CWLP=CWLP:1:CWIM("RESPS") D
. . D INRESP^XMXUTIL2(CWMSGN,CWLP,"F",.CWIR) ;gather details on specific response
. . S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)=""
. . S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)="Response: "_CWLP_") "_$G(CWIR("FROM NAME"))_" "_$$FMDTE^CWMAIL4($G(CWIR("DATE FM")),"5MZ")
. . S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)=""
. . D READM(.CWDATA,CWIR("XMZ"),.CWCNT)
. . D LASTACC(CWMSGN,$$BSKT^XMXUTIL2(XMDUZ,CWMSGN),CWLP) ;UPDATES LAST RESPONSE READ
D NONEW^XMXUTIL(XMDUZ,$$BSKT^XMXUTIL2(XMDUZ,CWMSGN),CWMSGN,1) ;UNNEW MESSAGE
I +CWCONFRM D ;SEND CONFIRMATION IF NEEDED
. S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)=""
. S CWCNT=$$INCNT(CWCNT),@CWDATA@(CWCNT)=">>Confirmation Message Sent to Sender.<<"
I $O(@CWDATA@(1)) D
. S @CWDATA@(1)="1^^DATA HAS BEEN FOUND"
E S @CWDATA@(1)="1^^Message text could not be found."
S $P(@CWDATA@(1),U,2)=CWCNT-2
Q
;
LASTACC(XMZ,CWBIEN,CWLRSP,XMCONFRM) ;UPDATE LAST RESPONSE READ DATE
;INPUT XMZ = MESSAGE NUMBER
; CWBIEN = BASKET IEN
; CWLRSP = LAST RESPONSE READ
;
N CWIM,CWIU,CWINSTR,CWXINSTR,CWFLAGS
D INMSG1^XMXUTIL2(XMDUZ,XMZ,,.CWFLAGS,.CWIM,.CWIU) ;SET-UP FOR CALL
D INMSG2^XMXUTIL2(XMDUZ,XMZ,,.CWIM,.CWXINSTR,.CWIU)
S CWINSTR("FLAGS")=$S($G(CWXINSTR("FLAGS"))["R":"R",1:"")
D LASTACC^XMXUTIL(XMDUZ,CWBIEN,XMZ,CWLRSP,.CWIM,.CWINSTR,.CWIU,.XMCONFRM)
Q
;
READM(CWDATA,CWINPUT,CWCNT) ;OUTPUT MAIL MESSAGE IN ARRAY
S $ZT="READMER^CWMAIL"
N CWRDATA,XMZ,CWMTYPE,CWTFLG,XMER,XMPOS
S XMZ=+$G(CWINPUT),CWTFLG=0,CWMTYPE=$G(CWINSTR("TYPE"))
F S CWRDATA=$$READ^XMGAPI1() Q:XMER<0!(CWTFLG) S CWCNT=CWCNT+1,@CWDATA@(CWCNT)=CWRDATA I CWMTYPE="K"!(CWMTYPE="X") S:CWRDATA["$END TXT" CWTFLG=1
;
READMER Q
;
INCNT(CWCNT) ;INCREMENT COUNTER
Q CWCNT+1
;
ADDMP(CWXMZ,CWVAL) ;set data into DAT based on subscripted CWVAL
;INPUT - CWXMZ = message ien
; CWVAL = input array (i.e. CWVAL(1)=first piece...CWVAL(n)=last piece
;OUTPUT - data string holding delimited ('^') data
S CWXMZ=$G(CWXMZ,0)
I +$G(CWXMZ) D
. N X,CWCONFRM,CWTYPE,CWCLOSED,CWINFO,CWCONFID,CWSDRDUZ,CWBRDCAS,CWSDRNAM,CWTRECPT,CWTREPLY
. N CWIM,CWIU,CWINSTR,CWPMSG,CWLP,CWDAT
. D INMSG^XMXUTIL2(XMDUZ,$$BSKT^XMXUTIL2(XMDUZ,CWXMZ),CWXMZ,,"F",.CWIM,.CWINSTR,.CWIU) ;SET-UP MESSAGE INFO
. S CWVAL(6)=$$UP^XLFSTR($G(CWINSTR("TYPE"))) ;message type(s)
. S:$G(CWINSTR("FLAGS"))["P" CWVAL(6)="P"_CWVAL(6) ;add priority flag as a type
. S CWVAL(7)=$G(CWINSTR("FLAGS"))["R" ;confirmation flag
. S CWVAL(8)=$G(CWINSTR("FLAGS"))["X" ;closed flag
. S CWVAL(9)=$G(CWINSTR("FLAGS"))["I" ;informational flag
. S CWVAL(10)=$G(CWINSTR("FLAGS"))["C" ;confidential flag
. S CWVAL(11)=$G(CWIM("FROM DUZ")) ;sender ien
. S CWVAL(13)=$G(CWIM("FROM NAME")) ;sender full name
. S CWVAL(12)=$$BCAST^XMXSEC(CWXMZ) ;broadcast flag
. S CWVAL(14)=$G(CWIM("RECIPS")) ;total # of recipients
. S CWVAL(15)=$G(CWIM("RESPS")) ;total # of replies
. S CWVAL(16)=$G(CWINSTR("FLAGS"))["P" ;priority flag
. S CWVAL(17)=+$G(CWIU("RESP")) ;# of last response read
. S CWVAL(20)=+$$ANSWER^XMXSEC(XMDUZ,CWXMZ,$$ZNODE^XMXUTIL2(CWXMZ)) ;can user answer message
;set data into node
S CWLP="" F S CWLP=$O(CWVAL(CWLP)) Q:CWLP<1 D
. S $P(CWDAT,U,CWLP)=CWVAL(CWLP)
Q CWDAT