| [613] | 1 | TIUPRPN3 ;SLC/MJC-Sort PNs for Prting;;6/26/01
 | 
|---|
 | 2 |  ;;1.0;TEXT INTEGRATION UTILITIES;**100,121**;Jun 20, 1997
 | 
|---|
 | 3 |  ;
 | 
|---|
 | 4 | SETUP(TITLE) ;displays centered option hdr
 | 
|---|
 | 5 |  N TIULINE
 | 
|---|
 | 6 |  S $P(TIULINE,"-",80)=""
 | 
|---|
 | 7 |  W @IOF,!!?(IOM-$L(TITLE)\2),TITLE,!,TIULINE,!
 | 
|---|
 | 8 |  Q
 | 
|---|
 | 9 | PT ;sorts PNs to prt by pt for selected date range
 | 
|---|
 | 10 |  ;these notes are chartable either contiguous or separate pgs
 | 
|---|
 | 11 |  ;[TIU PRINT PN PT]
 | 
|---|
 | 12 |  ;
 | 
|---|
 | 13 |  N TIUDFN,TIUQT,DIC,Y,TIUXREF,CTR1
 | 
|---|
 | 14 |  D SETUP("Print Progress Notes for a Selected PATIENT")
 | 
|---|
 | 15 |  F  W ! S DIC=2,DIC(0)="AEQMN" D ^DIC Q:Y<0  D  K TIUQT
 | 
|---|
 | 16 |  .N TIUFLAG,TIUSPG
 | 
|---|
 | 17 |  .S CTR1=0,TIUDFN=Y,TIUXREF="APTP" ;pt/pt x-ref
 | 
|---|
 | 18 |  .D FETCH(TIUXREF,TIUDFN,.CTR1) Q:$D(TIUQT)
 | 
|---|
 | 19 |  .S TIUFLAG=$$FLAG() Q:TIUFLAG']""
 | 
|---|
 | 20 |  .I +$G(TIUFLAG),CTR1>1 S TIUSPG=$$PAGE Q:TIUSPG']""
 | 
|---|
 | 21 |  .S TIUSPG=$S(+$G(TIUSPG):0,1:1)
 | 
|---|
 | 22 |  .D DEVICE^TIUPRPN(TIUFLAG,TIUSPG)
 | 
|---|
 | 23 |  Q
 | 
|---|
 | 24 |  ;
 | 
|---|
 | 25 | AUTHOR ;sorts PNs to prt by author for selected date range
 | 
|---|
 | 26 |  ;these guys are only chartable if prted on separate pages
 | 
|---|
 | 27 |  ;[TIU PRINT PN AUTHOR]
 | 
|---|
 | 28 |  ;
 | 
|---|
 | 29 |  N TIUDUZ,TIUQT,DIC,Y,TIUXREF
 | 
|---|
 | 30 |  D SETUP("Print Progress Notes for a Selected AUTHOR")
 | 
|---|
 | 31 |  S DIC=200,DIC(0)="AEQMN",DIC("A")="AUTHOR: "
 | 
|---|
 | 32 |  F  W ! D ^DIC Q:Y<0  D  K TIUQT
 | 
|---|
 | 33 |  .N TIUFLAG,TIUSPG
 | 
|---|
 | 34 |  .S TIUDUZ=Y,TIUXREF="AAUP" ;author/author x-ref
 | 
|---|
 | 35 |  .D FETCH(TIUXREF,TIUDUZ) Q:$D(TIUQT)
 | 
|---|
 | 36 |  .S TIUFLAG=$$FLAG() Q:TIUFLAG']""
 | 
|---|
 | 37 |  .S TIUSPG=$S(+$G(TIUFLAG):0,1:1)
 | 
|---|
 | 38 |  .D DEVICE^TIUPRPN(TIUFLAG,TIUSPG)
 | 
|---|
 | 39 |  Q
 | 
|---|
 | 40 |  ;
 | 
|---|
 | 41 | LOC ;sorts PNs to prt by location for selected date range
 | 
|---|
 | 42 |  ;they are only chartable if prted on separate pages
 | 
|---|
 | 43 |  ;[TIU PRINT PN LOC]
 | 
|---|
 | 44 |  ;
 | 
|---|
 | 45 |  N TIUDUZ,TIUQT,DIC,Y,TIUXREF
 | 
|---|
 | 46 |  D SETUP("Print Progress Notes for a Selected LOCATION")
 | 
|---|
 | 47 |  S DIC=44,DIC(0)="AEQMN"
 | 
|---|
 | 48 |  F  W ! D ^DIC Q:Y<0  D  K TIUQT
 | 
|---|
 | 49 |  .N TIUFLAG,TIUSPG
 | 
|---|
 | 50 |  .S TIULOC=Y,TIUXREF="ALOCP" ;location/location x-ref
 | 
|---|
 | 51 |  .D FETCH(TIUXREF,TIULOC) Q:$D(TIUQT)
 | 
|---|
 | 52 |  .S TIUFLAG=$$FLAG() Q:TIUFLAG']""
 | 
|---|
 | 53 |  .S TIUSPG=$S(+$G(TIUFLAG):0,1:1)
 | 
|---|
 | 54 |  .D DEVICE^TIUPRPN(TIUFLAG,TIUSPG)
 | 
|---|
 | 55 |  Q
 | 
|---|
 | 56 |  ;
 | 
|---|
 | 57 | FETCH(TIUXREF,ENTITY,CTR1) ;get available notes, select date range
 | 
|---|
 | 58 |  ; Passes back optional CTR1 = # of notes
 | 
|---|
 | 59 |  N OLD,NEW,BEG,END,HOLD,SORT,DFN,IFN,Y,DATE
 | 
|---|
 | 60 |  S OLD=0 S OLD=$O(^TIU(8925,TIUXREF,+ENTITY,OLD))
 | 
|---|
 | 61 |  I 'OLD D  S TIUQT=1 Q
 | 
|---|
 | 62 |  .W !!,$C(7),"No signed notes available for "_$P(ENTITY,U,2),!
 | 
|---|
 | 63 |  S OLD=$O(^TIU(8925,TIUXREF,+ENTITY,0))
 | 
|---|
 | 64 |  S NEW=$O(^TIU(8925,TIUXREF,+ENTITY,9999999),-1)
 | 
|---|
 | 65 |  W !!,"Available note",$S(OLD'=NEW:"s",1:""),": "
 | 
|---|
 | 66 |  W $$FMTE^XLFDT(OLD,"D")
 | 
|---|
 | 67 |  I OLD'=NEW W " thru ",$$FMTE^XLFDT(NEW,"D")
 | 
|---|
 | 68 | FISH I OLD=NEW S (BEG,END)=$E(OLD,1,7)
 | 
|---|
 | 69 |  E  D  W ! K %DT G:$D(TIUQT) FETCHX
 | 
|---|
 | 70 |  .S %DT="AEPTX",%DT(0)="-NOW",%DT("A")="Print Notes Beginning: "
 | 
|---|
 | 71 |  .D ^%DT I $D(DTOUT)!(Y<0) S TIUQT=1 Q
 | 
|---|
 | 72 |  .S BEG=Y,%DT("A")="                 Thru: "
 | 
|---|
 | 73 |  .S %DT="AEPTX" D ^%DT I $D(DTOUT)!(Y<0) S TIUQT=1 Q
 | 
|---|
 | 74 |  .S END=Y I END<BEG S HOLD=BEG,BEG=END,END=HOLD
 | 
|---|
 | 75 |  ; load up the notes
 | 
|---|
 | 76 |  W !!,"Searching for the notes"
 | 
|---|
 | 77 |  K ^TMP("TIUPR",$J),^TMP("TIUREPLACE",$J)
 | 
|---|
 | 78 |  S DATE=BEG,END=END+.9999999
 | 
|---|
 | 79 |  F  S DATE=$O(^TIU(8925,TIUXREF,+ENTITY,DATE)) Q:'DATE!(DATE>END)  D
 | 
|---|
 | 80 |  .S IFN=0 F  S IFN=$O(^TIU(8925,TIUXREF,+ENTITY,DATE,IFN)) Q:'IFN  D
 | 
|---|
 | 81 |  ..W "." D REPLACE(IFN,DATE,1501)
 | 
|---|
 | 82 |  S IFN=0 F  S IFN=$O(^TMP("TIUREPLACE",$J,IFN)) Q:'IFN  Q:'^TMP("TIUREPLACE",$J,IFN)  D
 | 
|---|
 | 83 |  .S DFN=$P(^TIU(8925,IFN,0),U,2),SORT=$P(^DPT(DFN,0),U)_";"_DFN
 | 
|---|
 | 84 |  .S DATE=^TMP("TIUREPLACE",$J,IFN,"DT")
 | 
|---|
 | 85 |  .S ^TMP("TIUPR",$J,SORT,DATE,IFN)="Vice SF 509"
 | 
|---|
 | 86 |  I '$D(^TMP("TIUPR",$J)) W !!,"No notes found- try again!",! G FISH
 | 
|---|
 | 87 |  S CTR1=+$G(^TMP("TIUREPLACE",$J))
 | 
|---|
 | 88 |  W !,">> "_CTR1_" note"_$S(CTR1>1:"s",1:"")_" found for "_$P(ENTITY,U,2)
 | 
|---|
 | 89 | FETCHX ;
 | 
|---|
 | 90 |  K ^TMP("TIUREPLACE",$J)
 | 
|---|
 | 91 |  Q
 | 
|---|
 | 92 |  ;
 | 
|---|
 | 93 | REPLACE(TIUDA,DATTIM,DTFIELD,CKCANVW) ; Populate TMP array
 | 
|---|
 | 94 |  ;w record received, replacing ID kids or addenda with their parents.
 | 
|---|
 | 95 |  ; Requires TIUDA. 
 | 
|---|
 | 96 |  ; Sets ^TMP("TIUREPLACE",$J,IFN)=1 or 1^TIUDA, or 0,
 | 
|---|
 | 97 |  ;where IFN is TIUDA or its ID parent.
 | 
|---|
 | 98 |  ; If TIUDA is replaced by its parent, then
 | 
|---|
 | 99 |  ;^TMP("TIUREPLACE",$J,IFN)=1^TIUDA,
 | 
|---|
 | 100 |  ;to know what child the parent was included in the list for.
 | 
|---|
 | 101 |  ; If CKCANVW = 1 is received, code checks CAN VIEW before
 | 
|---|
 | 102 |  ;setting TMP array.
 | 
|---|
 | 103 |  ; Sets ^TMP("TIUREPLACE",$J) = # of [viewable] elements in array
 | 
|---|
 | 104 |  ; Optional DATTIM = 
 | 
|---|
 | 105 |  ;      Signature date/time of record, NOT inverse, if DTFIELD = 1501
 | 
|---|
 | 106 |  ;      Reference date/time of record, inverse, if DTFIELD = 1301
 | 
|---|
 | 107 |  ;If DATTIM received=non null, sets
 | 
|---|
 | 108 |  ; ^TMP("TIUREPLACE",$J,IFN,"DT")=DATTIM
 | 
|---|
 | 109 |  ;  Optional DTFIELD = 1501 or 1301; default = 1501
 | 
|---|
 | 110 |  ; 1/11/01 cf REPLACE^TIUSRVLL.
 | 
|---|
 | 111 |  N IDPRNT,PDATTIM,DTNODE,PCANDO,CANDO
 | 
|---|
 | 112 |  S ^TMP("TIUREPLACE",$J)=+$G(^TMP("TIUREPLACE",$J))
 | 
|---|
 | 113 |  S IDPRNT=+$G(^TIU(8925,TIUDA,21)) ; ID parent
 | 
|---|
 | 114 |  ; -- If user can't view record, quit and
 | 
|---|
 | 115 |  ;    if it is parent, track it as already processed
 | 
|---|
 | 116 |  ;    (but not a 'good' record):
 | 
|---|
 | 117 |  I $G(CKCANVW) D  Q:'$G(CANDO)
 | 
|---|
 | 118 |  . S CANDO=+$$CANDO^TIULP(TIUDA,"VIEW")
 | 
|---|
 | 119 |  . I '$G(CANDO),$O(^TIU(8925,"GDAD",TIUDA,0)) S ^TMP("TIUREPLACE",$J,TIUDA)=0
 | 
|---|
 | 120 |  S DTNODE=$S($G(DTFIELD)=1301:13,1:15)
 | 
|---|
 | 121 |  ; -- If record is child with nonexistent parent,
 | 
|---|
 | 122 |  ;    treat record as stand-alone:
 | 
|---|
 | 123 |  I '$D(^TIU(8925,IDPRNT,0)) S IDPRNT=0
 | 
|---|
 | 124 |  ; -- If record is child, & parent already in array
 | 
|---|
 | 125 |  ;    from previous cycle (viewable or not), just quit:
 | 
|---|
 | 126 |  I IDPRNT,$D(^TMP("TIUREPLACE",$J,IDPRNT)) G REPX
 | 
|---|
 | 127 |  ; -- If record is child, & parent not viewable,
 | 
|---|
 | 128 |  ;    track parent as processed but not 'good' & quit:
 | 
|---|
 | 129 |  I IDPRNT,$G(CKCANVW) D  I '$G(PCANDO) G REPX
 | 
|---|
 | 130 |  . S PCANDO=+$$CANDO^TIULP(IDPRNT,"VIEW")
 | 
|---|
 | 131 |  . I '$G(PCANDO) S ^TMP("TIUREPLACE",$J,IDPRNT)=0
 | 
|---|
 | 132 |  ; -- If record is not child, just put it
 | 
|---|
 | 133 |  ;    in array and quit: --
 | 
|---|
 | 134 |  I 'IDPRNT D  G REPX
 | 
|---|
 | 135 |  . ; -- If record is already in array as parent from previous cycle
 | 
|---|
 | 136 |  . ;    (viewable or not), and is now received on its own merit,
 | 
|---|
 | 137 |  . ;    quit & don't consider it there because of a child:
 | 
|---|
 | 138 |  . I $D(^TMP("TIUREPLACE",$J,TIUDA)) S ^TMP("TIUREPLACE",$J,TIUDA)=+^TMP("TIUREPLACE",$J,TIUDA) Q
 | 
|---|
 | 139 |  . S ^TMP("TIUREPLACE",$J,TIUDA)=1
 | 
|---|
 | 140 |  . I $G(DATTIM)'="" S ^TMP("TIUREPLACE",$J,TIUDA,"DT")=DATTIM
 | 
|---|
 | 141 |  . S ^TMP("TIUREPLACE",$J)=$G(^TMP("TIUREPLACE",$J))+1
 | 
|---|
 | 142 |  ; -- If record is child, put its parent in array:
 | 
|---|
 | 143 |  I IDPRNT,$G(DATTIM)'="" D
 | 
|---|
 | 144 |  . S PDATTIM=+$G(^TIU(8925,IDPRNT,DTNODE))
 | 
|---|
 | 145 |  . I PDATTIM,DTNODE=13 S PDATTIM=9999999-PDATTIM
 | 
|---|
 | 146 |  I IDPRNT D  G REPX
 | 
|---|
 | 147 |  . S ^TMP("TIUREPLACE",$J,IDPRNT)=1_U_TIUDA ;parent in array because of child TIUDA
 | 
|---|
 | 148 |  . I $G(DATTIM)'="" S ^TMP("TIUREPLACE",$J,IDPRNT,"DT")=PDATTIM
 | 
|---|
 | 149 |  . S ^TMP("TIUREPLACE",$J)=$G(^TMP("TIUREPLACE",$J))+1
 | 
|---|
 | 150 | REPX Q
 | 
|---|
 | 151 |  ;
 | 
|---|
 | 152 | FLAG() ;asks question for CHART vs. WORK copies
 | 
|---|
 | 153 |  ;returns TIUFLAG=1 if CHART copy - TIUFLAG=0 if WORK copy - NULL if '^'
 | 
|---|
 | 154 |  S TIUFLAG=$$READ^TIUU("SA^C:CHART;W:WORK","Do you want WORK copies or CHART copies? ","CHART","^D HELP^TIUPRPN3")
 | 
|---|
 | 155 |  I $E(TIUFLAG)="^" S TIUFLAG=""
 | 
|---|
 | 156 |  E  S TIUFLAG=$S($P(TIUFLAG,U)="C":1,1:0)
 | 
|---|
 | 157 |  Q TIUFLAG
 | 
|---|
 | 158 |  ;
 | 
|---|
 | 159 | PAGE() ;asks question for CONTIGUOUS vs. SEPARATE PAGE print
 | 
|---|
 | 160 |  ;returns TIUSPG=0 for CONTIGUOUS - TIUSPG=1 SEPARATE PAGE - NULL if '^'
 | 
|---|
 | 161 |  S TIUSPG=$$READ^TIUU("YA","Do you want to start each note on a new page? ","NO","^D HELP1^TIUPRPN3")
 | 
|---|
 | 162 |  I $E(TIUSPG)="^" S TIUSPG=""
 | 
|---|
 | 163 |  E  S TIUSPG=$S(+$G(TIUSPG):1,1:0)
 | 
|---|
 | 164 |  Q TIUSPG
 | 
|---|
 | 165 | HELP ; answers questions regarding WORK vs. CHART copies
 | 
|---|
 | 166 |  W !!?5,"The FOOTERS of WORK/CHART copies vary significantly.  The WORK"
 | 
|---|
 | 167 |  W !?5,"FOOTER has the patient's phone number and is clearly marked:"
 | 
|---|
 | 168 |  W !?5,"'NOT FOR MEDICAL RECORD'.  Unless you really intend to file the"
 | 
|---|
 | 169 |  W !?5,"note(s) in the chart- print a WORK copy."
 | 
|---|
 | 170 |  Q
 | 
|---|
 | 171 | HELP1 ; answers the 'ea note on a new page' question
 | 
|---|
 | 172 |  W !!?5,"The option selected will produce CHARTABLE contiguous notes."
 | 
|---|
 | 173 |  W !?5,"If you are filling in a chart that has handwritten notes, or,"
 | 
|---|
 | 174 |  W !?5,"you'd prefer to begin each note on a new page; answer 'YES'."
 | 
|---|
 | 175 |  Q
 | 
|---|