GMTSP92I ;BIR/RMS - Post Install GMTS*2.7*92    ; 4/6/10 11:30am
 ;;2.7;Health Summary;**92**;Oct 20, 1995;Build 4
 Q
CI ; Component Install
 N GMTSIN,GMTSLIM,GMTSINST,GMTSTL,GMTSINST,GMTSTOT,GMTSBLD,GMTSCPS,GMTSCP,GMTSCI
 S GMTSCPS="MRT2"
 F GMTSCI=1:1 Q:'$L($P(GMTSCPS,";",GMTSCI))  D
 . S GMTSCP=$P(GMTSCPS,";",GMTSCI) K GMTSIN
 . D ARRAY Q:'$D(GMTSIN)
 . I $L($G(GMTSIN("TIM"))),+($G(GMTSIN(0)))>0 S GMTSLIM(+($G(GMTSIN(0))),"TIM")=$G(GMTSIN("TIM"))
 . I $L($G(GMTSIN("OCC"))),+($G(GMTSIN(0)))>0 S GMTSLIM(+($G(GMTSIN(0))),"OCC")=$G(GMTSIN("OCC"))
 . S GMTSINST=$$ADD^GMTSXPD1(.GMTSIN),GMTSTOT=+($G(GMTSTOT))+($G(GMTSINST))
 ; Rebuild Ad Hoc Health Summary Type
 D:+($G(GMTSTOT))>0 BUILD^GMTSXPD3
 D LIM
 I +$$ROK("GMTSXPS1")>0 D
 . N GMTSHORT S GMTSHORT=1,GMTSINST="",GMTSBLD="GMTS*2.7*92" D SEND^GMTSXPS1
 Q
ARRAY ; Build Array
 K GMTSIN N GMTSI,GMTSTXT,GMTSEX,GMTSFLD,GMTSUB,GMTSVAL,GMTSPDX S GMTSPDX=1,GMTSCP=$G(GMTSCP) Q:'$L(GMTSCP)
 F GMTSI=1:1 D  Q:'$L(GMTSTXT)
 . S GMTSTXT="",GMTSEX="S GMTSTXT=$T("_GMTSCP_"+"_GMTSI_")" X GMTSEX S:$L(GMTSTXT,";")'>3 GMTSTXT="" Q:'$L(GMTSTXT)
 . S GMTSFLD=$P(GMTSTXT,";",2),GMTSUB=$P(GMTSTXT,";",3),GMTSVAL=$P(GMTSTXT,";",4)
 . S:$E(GMTSFLD,1)=1&(+GMTSFLD<2) GMTSVAL=$P(GMTSTXT,";",4,5)
 . S:$E(GMTSFLD,1)=" "!('$L(GMTSFLD)) GMTSTXT="" Q:GMTSTXT=""
 . S:$L(GMTSFLD)&('$L(GMTSUB)) GMTSIN(GMTSFLD)=GMTSVAL Q:$L(GMTSFLD)&('$L(GMTSUB))  S:$L(GMTSFLD)&($L(GMTSUB)) GMTSIN(GMTSFLD,GMTSUB)=GMTSVAL
 . S:$G(GMTSFLD)=7&(+($G(GMTSUB))>0) GMTSPDX=0
 K:+($G(GMTSPDX))=0 GMTSIN("PDX")
 Q
LIM ; Limits
 N GMTSI,GMTST,GMTSO,GMTSA S GMTSI=0 F  S GMTSI=$O(GMTSLIM(GMTSI)) Q:+GMTSI=0  D
 . S GMTSA=$P($G(^GMT(142.1,+($G(GMTSI)),0)),"^",3),GMTST=$G(GMTSLIM(+GMTSI,"TIM")) S:'$L(GMTST) GMTST=$S(GMTSA="Y ":"1Y ",1:"")
 . S GMTSA=$P($G(^GMT(142.1,+($G(GMTSI)),0)),"^",5),GMTSO=$G(GMTSLIM(+GMTSI,"OCC")) S:'$L(GMTSO) GMTSO=$S(GMTSA="Y ":"10 ",1:"")
 . D TO^GMTSXPD3(GMTSI,GMTST,GMTSO)
 Q
ROK(X) ; Routine OK
 S X=$G(X) Q:'$L(X) 0 N GMTSEX,GMTSTXT S GMTSEX="S GMTSTXT=$T(+1^"_X_")" X GMTSEX
 Q:'$L(GMTSTXT) 0  Q 1
 ;                
MRT2 ; Medication Worksheet Component Data
 ;0;;252
 ;.01;;Medication Worksheet (Tool #2)
 ;1;;TOOL2;GMTSPST2
 ;1.1;;0
 ;2;;
 ;3;;MRT2
 ;3.5;;3
 ;3.5;1;This component displays a list of the patient's active and pending
 ;3.5;2;outpatient prescriptions in a patient-friendly worksheet format with space
 ;3.5;3;intended for written notes by the patient, provider or caregiver.
 ;4;;
 ;5;;
 ;6;;
 ;7;;0
 ;8;;
 ;9;;Medication Worksheet
 ;10;;
 ;11;;
 ;12;;
 ;13;;
 ;14;;
 ;PDX;;1
 ;
 Q
 ;
 
--- Routine Detail   --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HGMTSP92I   2607     printed  Sep 23, 2025@19:35:10                                                                                                                                                                                                    Page 2
GMTSP92I  ;BIR/RMS - Post Install GMTS*2.7*92    ; 4/6/10 11:30am
 +1       ;;2.7;Health Summary;**92**;Oct 20, 1995;Build 4
 +2        QUIT 
CI        ; Component Install
 +1        NEW GMTSIN,GMTSLIM,GMTSINST,GMTSTL,GMTSINST,GMTSTOT,GMTSBLD,GMTSCPS,GMTSCP,GMTSCI
 +2        SET GMTSCPS="MRT2"
 +3        FOR GMTSCI=1:1
               if '$LENGTH($PIECE(GMTSCPS,";",GMTSCI))
                   QUIT 
               Begin DoDot:1
 +4                SET GMTSCP=$PIECE(GMTSCPS,";",GMTSCI)
                   KILL GMTSIN
 +5                DO ARRAY
                   if '$DATA(GMTSIN)
                       QUIT 
 +6                IF $LENGTH($GET(GMTSIN("TIM")))
                       IF +($GET(GMTSIN(0)))>0
                           SET GMTSLIM(+($GET(GMTSIN(0))),"TIM")=$GET(GMTSIN("TIM"))
 +7                IF $LENGTH($GET(GMTSIN("OCC")))
                       IF +($GET(GMTSIN(0)))>0
                           SET GMTSLIM(+($GET(GMTSIN(0))),"OCC")=$GET(GMTSIN("OCC"))
 +8                SET GMTSINST=$$ADD^GMTSXPD1(.GMTSIN)
                   SET GMTSTOT=+($GET(GMTSTOT))+($GET(GMTSINST))
               End DoDot:1
 +9       ; Rebuild Ad Hoc Health Summary Type
 +10       if +($GET(GMTSTOT))>0
               DO BUILD^GMTSXPD3
 +11       DO LIM
 +12       IF +$$ROK("GMTSXPS1")>0
               Begin DoDot:1
 +13               NEW GMTSHORT
                   SET GMTSHORT=1
                   SET GMTSINST=""
                   SET GMTSBLD="GMTS*2.7*92"
                   DO SEND^GMTSXPS1
               End DoDot:1
 +14       QUIT 
ARRAY     ; Build Array
 +1        KILL GMTSIN
           NEW GMTSI,GMTSTXT,GMTSEX,GMTSFLD,GMTSUB,GMTSVAL,GMTSPDX
           SET GMTSPDX=1
           SET GMTSCP=$GET(GMTSCP)
           if '$LENGTH(GMTSCP)
               QUIT 
 +2        FOR GMTSI=1:1
               Begin DoDot:1
 +3                SET GMTSTXT=""
                   SET GMTSEX="S GMTSTXT=$T("_GMTSCP_"+"_GMTSI_")"
                   XECUTE GMTSEX
                   if $LENGTH(GMTSTXT,";")'>3
                       SET GMTSTXT=""
                   if '$LENGTH(GMTSTXT)
                       QUIT 
 +4                SET GMTSFLD=$PIECE(GMTSTXT,";",2)
                   SET GMTSUB=$PIECE(GMTSTXT,";",3)
                   SET GMTSVAL=$PIECE(GMTSTXT,";",4)
 +5                if $EXTRACT(GMTSFLD,1)=1&(+GMTSFLD<2)
                       SET GMTSVAL=$PIECE(GMTSTXT,";",4,5)
 +6                if $EXTRACT(GMTSFLD,1)=" "!('$LENGTH(GMTSFLD))
                       SET GMTSTXT=""
                   if GMTSTXT=""
                       QUIT 
 +7                if $LENGTH(GMTSFLD)&('$LENGTH(GMTSUB))
                       SET GMTSIN(GMTSFLD)=GMTSVAL
                   if $LENGTH(GMTSFLD)&('$LENGTH(GMTSUB))
                       QUIT 
                   if $LENGTH(GMTSFLD)&($LENGTH(GMTSUB))
                       SET GMTSIN(GMTSFLD,GMTSUB)=GMTSVAL
 +8                if $GET(GMTSFLD)=7&(+($GET(GMTSUB))>0)
                       SET GMTSPDX=0
               End DoDot:1
               if '$LENGTH(GMTSTXT)
                   QUIT 
 +9        if +($GET(GMTSPDX))=0
               KILL GMTSIN("PDX")
 +10       QUIT 
LIM       ; Limits
 +1        NEW GMTSI,GMTST,GMTSO,GMTSA
           SET GMTSI=0
           FOR 
               SET GMTSI=$ORDER(GMTSLIM(GMTSI))
               if +GMTSI=0
                   QUIT 
               Begin DoDot:1
 +2                SET GMTSA=$PIECE($GET(^GMT(142.1,+($GET(GMTSI)),0)),"^",3)
                   SET GMTST=$GET(GMTSLIM(+GMTSI,"TIM"))
                   if '$LENGTH(GMTST)
                       SET GMTST=$SELECT(GMTSA="Y ":"1Y ",1:"")
 +3                SET GMTSA=$PIECE($GET(^GMT(142.1,+($GET(GMTSI)),0)),"^",5)
                   SET GMTSO=$GET(GMTSLIM(+GMTSI,"OCC"))
                   if '$LENGTH(GMTSO)
                       SET GMTSO=$SELECT(GMTSA="Y ":"10 ",1:"")
 +4                DO TO^GMTSXPD3(GMTSI,GMTST,GMTSO)
               End DoDot:1
 +5        QUIT 
ROK(X)    ; Routine OK
 +1        SET X=$GET(X)
           if '$LENGTH(X)
               QUIT 0
           NEW GMTSEX,GMTSTXT
           SET GMTSEX="S GMTSTXT=$T(+1^"_X_")"
           XECUTE GMTSEX
 +2        if '$LENGTH(GMTSTXT)
               QUIT 0
           QUIT 1
 +3       ;                
MRT2      ; Medication Worksheet Component Data
 +1       ;0;;252
 +2       ;.01;;Medication Worksheet (Tool #2)
 +3       ;1;;TOOL2;GMTSPST2
 +4       ;1.1;;0
 +5       ;2;;
 +6       ;3;;MRT2
 +7       ;3.5;;3
 +8       ;3.5;1;This component displays a list of the patient's active and pending
 +9       ;3.5;2;outpatient prescriptions in a patient-friendly worksheet format with space
 +10      ;3.5;3;intended for written notes by the patient, provider or caregiver.
 +11      ;4;;
 +12      ;5;;
 +13      ;6;;
 +14      ;7;;0
 +15      ;8;;
 +16      ;9;;Medication Worksheet
 +17      ;10;;
 +18      ;11;;
 +19      ;12;;
 +20      ;13;;
 +21      ;14;;
 +22      ;PDX;;1
 +23      ;
 +24       QUIT 
 +25      ;