Ignore:
Timestamp:
Dec 4, 2009, 12:11:15 AM (14 years ago)
Author:
George Lilly
Message:

revised back to 6/30/08 version

File:
1 edited

Legend:

Unmodified
Added
Removed
  • WorldVistAEHR/trunk/r/ADVERSE_REACTION_TRACKING-GMRA-GMA/GMRACMR4.m

    r613 r623  
    1 GMRACMR4        ;HIRMFO/WAA-PATIENT NOT ASKED ABOUT ALLERGIES ;10/1/92
    2         ;;4.0;Adverse Reaction Tracking;**33**;Mar 29, 1996;Build 5
    3 EN1     ;This is the main entry point for this program
    4         D EN1^GMRACMR G:GMRAOUT EXIT
    5 DEV     ; *** Select output device, force queuing
    6         S GMRAZIS=""
    7         S:GMRASEL'="1," GMRAZIS="Q"
    8         W !! D DEV^GMRAUTL I POP S GMRAOUT=1 G EXIT
    9         I $D(IO("Q")) D  G EXIT
    10         . K IO("Q")
    11         . S ZTRTN="ENTSK^GMRACMR4"
    12         . S ZTSAVE("GMRA*")="",ZTSAVE("^TMP($J,")=""
    13         . S ZTDESC="List of patients without ID band or Chart marked"
    14         . D ^%ZTLOAD
    15         . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try later...")
    16         . Q
    17         E  D ENTSK
    18         Q
    19 ENTSK   U IO
    20         D EN1^GMRACMR2,EN1^GMRACMR3
    21         S GMRAPAGE=0,X="NOW" D ^%DT S GMRAPDT=$$DATE^GMRAUTL1(Y)
    22         D SITE^GMRAUTL S GMRASITE=$G(^GMRD(120.84,GMRASITE,0))
    23         D PRINT
    24         G EXIT
    25 PRINT   ;PRINT THE DATE
    26         D PRE^GMRAPNA
    27         S GMRAHLOC="" F  S GMRAHLOC=$O(^TMP($J,"GMRAWC","C",GMRAHLOC)) Q:GMRAHLOC=""  S GMRAX=0 Q:GMRAOUT  F  S GMRAX=$O(^(GMRAHLOC,GMRAX)) Q:GMRAX<1  D  Q:GMRAOUT
    28         .S GMRA=^TMP($J,"GMRAWC",GMRAX)
    29         .D HEAD Q:GMRAOUT
    30         .W !!,?10,$S(GMRA="W":"WARD",GMRA="M":"MODULE",GMRA="C":"CLINIC",1:"UNKNOWN"),": ",$P(^SC(GMRAX,0),U)
    31         .S GMRACNT=0
    32         .S GMRADATE=0 F  S GMRADATE=$O(^TMP($J,"GMRAWC",GMRAX,GMRADATE))  Q:GMRADATE=""  S (GMRAFLG,GMRADFN)=0 F  S GMRADFN=$O(^TMP($J,"GMRAWC",GMRAX,GMRADATE,GMRADFN)) Q:GMRADFN<1  D  Q:GMRAOUT
    33         ..Q:'$$PRDTST^GMRAUTL1(GMRADFN)  ;GMRA*4*33 Exclude test patient from report if production or legacy environment.
    34         ..S GMRAI=0 F  S GMRAI=$O(^GMR(120.8,"B",GMRADFN,GMRAI)) Q:GMRAI<1  D  Q:GMRAOUT
    35         ...Q:'$D(^GMR(120.8,GMRAI,0))  Q:$P($G(^GMR(120.86,GMRADFN,0)),U,2)'=1
    36         ...Q:$D(^GMR(120.8,GMRAI,"ER"))
    37         ...Q:$P(^GMR(120.8,GMRAI,0),U,2)=""
    38         ...S (GMRA("C"),GMRA("I"),GMRA("M"))=1
    39         ...I '$O(^GMR(120.8,GMRAI,13,0)) S (GMRA("C"),GMRA("M"))=0
    40         ...I GMRA'="W",GMRA("M") Q
    41         ...I GMRA="W",$P(GMRASITE,U,5)'=0,'$$IDMARK^GMRACMR5(GMRADFN,GMRADATE,GMRAI) S (GMRA("I"),GMRA("M"))=0
    42         ...I GMRA("M") Q
    43         ...S GMRACNT=GMRACNT+1
    44         ...W ! I GMRAFLG'=GMRADFN W $E($P(^DPT(GMRADFN,0),U),1,30) S (DFN,GMRAFLG)=GMRADFN S GMRAPID="" D VAD^GMRAUTL1(GMRADFN,"","","","","","","",.GMRAPID) W ?30,GMRAPID K GMRAPID
    45         ...W ?45,$E($P(^GMR(120.8,GMRAI,0),U,2),1,20)
    46         ...I GMRA="W" W ?66,$S(('GMRA("C")&'GMRA("I")):"ID BAND/CHART",('GMRA("C")):"CHART",('GMRA("I")):"ID BAND",1:"ERROR")
    47         ...E  W ?66,$S('GMRA("C"):"CHART",1:"ERROR")
    48         ...I $Y>(IOSL-4) D HEAD Q:GMRAOUT
    49         ...Q
    50         ..Q
    51         .D NOPAT^GMRAPNA
    52         .Q
    53         D CLOSE^GMRAUTL
    54         Q
    55 HEAD    ;HEADER PAGE FOR PRINTOUT
    56         S GMRAPAGE=GMRAPAGE+1,GMRATL="" I $E(IOST,1)="C",GMRAPAGE=1 W @IOF
    57         I $E(IOST,1)="C",GMRAPAGE'=1 D  Q:GMRAOUT
    58         .S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
    59         .K Y
    60         .Q
    61         W:GMRAPAGE'=1 @IOF
    62         W !,GMRAPDT,?22,"PATIENTS WITH UNMARKED ID BAND/CHART",?70,"PAGE ",GMRAPAGE
    63         I GMRASEL["1" S GMRATL="CURRENT INPATIENTS"
    64         I GMRASEL["2" S GMRATL=$S(GMRATL="":"OUTPATIENTS",1:GMRATL_" / OUTPATIENTS")
    65         I GMRASEL["3" S GMRATL=$S(GMRATL="":"NEW ADMISSIONS",1:GMRATL_" / NEW ADMISSIONS")
    66         W !,?(40-($L(GMRATL)/2)),GMRATL
    67         I (GMRASEL["2"!(GMRASEL["3")) W !,?22,"FROM ",$$DATE^GMRAUTL1(GMRAST),?43,"TO ",$$DATE^GMRAUTL1(GMRAED)
    68         W !!,"PATIENT",?30,"SSN",?45,"ALLERGY",?66,"UNMARKED"
    69         W !,$$REPEAT^XLFSTR("-",79)
    70         I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
    71         Q
    72 EXIT    ;
    73         K ^TMP($J,"GMRAWC")
    74         D KILL^XUSCLEAN
    75         Q
     1GMRACMR4 ;HIRMFO/WAA-PATIENT NOT ASKED ABOUT ALLERGIES ; 10/1/92
     2 ;;4.0;Adverse Reaction Tracking;;Mar 29, 1996
     3EN1 ;This is the main entry point for this program
     4 D EN1^GMRACMR G:GMRAOUT EXIT
     5DEV ; *** Select output device, force queueing
     6 S GMRAZIS=""
     7 S:GMRASEL'="1," GMRAZIS="Q"
     8 W !! D DEV^GMRAUTL I POP S GMRAOUT=1 G EXIT
     9 I $D(IO("Q")) D  G EXIT
     10 . K IO("Q")
     11 . S ZTRTN="ENTSK^GMRACMR4"
     12 . S ZTSAVE("GMRA*")="",ZTSAVE("^TMP($J,")=""
     13 . S ZTDESC="List of patients without ID band or Chart marked"
     14 . D ^%ZTLOAD
     15 . W !!,$S($D(ZTSK):"Request queued...",1:"Request NOT queued please try later...")
     16 . Q
     17 E  D ENTSK
     18 Q
     19ENTSK U IO
     20 D EN1^GMRACMR2,EN1^GMRACMR3
     21 S GMRAPAGE=0,X="NOW" D ^%DT S GMRAPDT=$$DATE^GMRAUTL1(Y)
     22 D SITE^GMRAUTL S GMRASITE=$G(^GMRD(120.84,GMRASITE,0))
     23 D PRINT
     24 G EXIT
     25PRINT ;PRINT THE DATE
     26 D PRE^GMRAPNA
     27 S GMRAHLOC="" F  S GMRAHLOC=$O(^TMP($J,"GMRAWC","C",GMRAHLOC)) Q:GMRAHLOC=""  S GMRAX=0 Q:GMRAOUT  F  S GMRAX=$O(^(GMRAHLOC,GMRAX)) Q:GMRAX<1  D  Q:GMRAOUT
     28 .S GMRA=^TMP($J,"GMRAWC",GMRAX)
     29 .D HEAD Q:GMRAOUT
     30 .W !!,?10,$S(GMRA="W":"WARD",GMRA="M":"MODULE",GMRA="C":"CLINIC",1:"UNKNOWN"),": ",$P(^SC(GMRAX,0),U)
     31 .S GMRACNT=0
     32 .S GMRADATE=0 F  S GMRADATE=$O(^TMP($J,"GMRAWC",GMRAX,GMRADATE))  Q:GMRADATE=""  S (GMRAFLG,GMRADFN)=0 F  S GMRADFN=$O(^TMP($J,"GMRAWC",GMRAX,GMRADATE,GMRADFN)) Q:GMRADFN<1  D  Q:GMRAOUT
     33 ..S GMRAI=0 F  S GMRAI=$O(^GMR(120.8,"B",GMRADFN,GMRAI)) Q:GMRAI<1  D  Q:GMRAOUT
     34 ...Q:'$D(^GMR(120.8,GMRAI,0))  Q:$P($G(^GMR(120.86,GMRADFN,0)),U,2)'=1
     35 ...Q:$D(^GMR(120.8,GMRAI,"ER"))
     36 ...Q:$P(^GMR(120.8,GMRAI,0),U,2)=""
     37 ...S (GMRA("C"),GMRA("I"),GMRA("M"))=1
     38 ...I '$O(^GMR(120.8,GMRAI,13,0)) S (GMRA("C"),GMRA("M"))=0
     39 ...I GMRA'="W",GMRA("M") Q
     40 ...I GMRA="W",$P(GMRASITE,U,5)'=0,'$$IDMARK^GMRACMR5(GMRADFN,GMRADATE,GMRAI) S (GMRA("I"),GMRA("M"))=0
     41 ...I GMRA("M") Q
     42 ...S GMRACNT=GMRACNT+1
     43 ...W ! I GMRAFLG'=GMRADFN W $E($P(^DPT(GMRADFN,0),U),1,30) S (DFN,GMRAFLG)=GMRADFN S GMRAPID="" D VAD^GMRAUTL1(GMRADFN,"","","","","","","",.GMRAPID) W ?30,GMRAPID K GMRAPID
     44 ...W ?45,$E($P(^GMR(120.8,GMRAI,0),U,2),1,20)
     45 ...I GMRA="W" W ?66,$S(('GMRA("C")&'GMRA("I")):"ID BAND/CHART",('GMRA("C")):"CHART",('GMRA("I")):"ID BAND",1:"ERROR")
     46 ...E  W ?66,$S('GMRA("C"):"CHART",1:"ERROR")
     47 ...I $Y>(IOSL-4) D HEAD Q:GMRAOUT
     48 ...Q
     49 ..Q
     50 .D NOPAT^GMRAPNA
     51 .Q
     52 D CLOSE^GMRAUTL
     53 Q
     54HEAD ;HEADER PAGE FOR PRINTOUT
     55 S GMRAPAGE=GMRAPAGE+1,GMRATL="" I $E(IOST,1)="C",GMRAPAGE=1 W @IOF
     56 I $E(IOST,1)="C",GMRAPAGE'=1 D  Q:GMRAOUT
     57 .S DIR(0)="E" D ^DIR I 'Y S GMRAOUT=1
     58 .K Y
     59 .Q
     60 W:GMRAPAGE'=1 @IOF
     61 W !,GMRAPDT,?22,"PATIENTS WITH UNMARKED ID BAND/CHART",?70,"PAGE ",GMRAPAGE
     62 I GMRASEL["1" S GMRATL="CURRENT INPATIENTS"
     63 I GMRASEL["2" S GMRATL=$S(GMRATL="":"OUTPATIENTS",1:GMRATL_" / OUTPATIENTS")
     64 I GMRASEL["3" S GMRATL=$S(GMRATL="":"NEW ADMISSIONS",1:GMRATL_" / NEW ADMISSIONS")
     65 W !,?(40-($L(GMRATL)/2)),GMRATL
     66 I (GMRASEL["2"!(GMRASEL["3")) W !,?22,"FROM ",$$DATE^GMRAUTL1(GMRAST),?43,"TO ",$$DATE^GMRAUTL1(GMRAED)
     67 W !!,"PATIENT",?30,"SSN",?45,"ALLERGY",?66,"UNMARKED"
     68 W !,$$REPEAT^XLFSTR("-",79)
     69 I $D(ZTQUEUED) S:$$STPCK^GMRAUTL1 GMRAOUT=1 ; Check if stopped by user
     70 Q
     71EXIT ;
     72 K ^TMP($J,"GMRAWC")
     73 D KILL^XUSCLEAN
     74 Q
Note: See TracChangeset for help on using the changeset viewer.