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/DSS_EXTRACTS-ECX/ECXUSUR.m

    r613 r623  
    1 ECXUSUR ;ALB/TJL-Surgery Extract Unusual Volume Report ; 9/4/07 8:19am
    2         ;;3.0;DSS EXTRACTS;**49,71,84,93,105**;July 1, 2003;Build 70
    3         ;
    4 EN      ; entry point
    5         N X,Y,DATE,ECRUN,ECXDESC,ECXSAVE,ECXTL,ECTHLD
    6         N ECSD,ECSD1,ECSTART,ECED,ECEND,ECXERR,QFLG,ECXFLAG
    7         S QFLG=0,ECTHLD="",ECXFLAG=$G(FLAG)
    8         ; get today's date
    9         D NOW^%DTC S DATE=X,Y=$E(%,1,12) D DD^%DT S ECRUN=$P(Y,"@") K %DT
    10         I 'ECXFLAG D BEGIN Q:QFLG
    11         D SELECT Q:QFLG
    12         S ECXDESC=$S(ECXFLAG:"SUR Volume Report",1:"Surgery Extract Unusual Volume Report")
    13         S ECXSAVE("EC*")=""
    14         W !!,"This report requires 132-column format."
    15         D EN^XUTMDEVQ("PROCESS^ECXUSUR",ECXDESC,.ECXSAVE)
    16         I POP W !!,"No device selected...exiting.",! Q
    17         I IO'=IO(0) D ^%ZISC
    18         D HOME^%ZIS
    19         D AUDIT^ECXKILL
    20         Q
    21         ;
    22 BEGIN   ; display report description
    23         W @IOF
    24         W !,"This report prints a listing of unusual volumes that would be"
    25         W !,"generated by the Surgery extract (SUR) as determined by a"
    26         W !,"user-defined threshold value.  It should be run prior to the"
    27         W !,"generation of the actual extract(s) to identify and fix, as"
    28         W !,"necessary, any volumes determined to be erroneous."
    29         W !!,"Unusual volumes are those where either the Operation Time,"
    30         W !,"Patient Time, Anesthesia Time, Recovery Room Time, OR Clean Time"
    31         W !,"or Pt Holding Time field is greater than the threshold value."
    32         W !!,"Note: The threshold can be set after a report is selected."
    33         W !!,"Run times for this report will vary depending upon the size of"
    34         W !,"the extract and could take as long as 30 minutes or more to"
    35         W !,"complete.  This report has no effect on the actual extracts and"
    36         W !,"can be run as needed."
    37         W !!,"The report is sorted by descending Volume and Case Number."
    38         S DIR(0)="E" W ! D ^DIR K DIR I 'Y S QFLG=1 Q
    39         W:$Y!($E(IOST)="C") @IOF,!!
    40         Q
    41         ;
    42 SELECT  ; user inputs for threshold volume and date range
    43         N DONE,OUT
    44         ; allow user to set threshold volume
    45         I 'ECXFLAG D
    46         .S ECTHLD=25
    47         .W !!,"The default threshold volume for the Surgery extract is "_ECTHLD_"."
    48         .W !,"The default threshold volume ("_ECTHLD_") equates to 6 hours."
    49         .S DIR(0)="Y",DIR("A")="Would you like to change the threshold?",DIR("B")="NO" D ^DIR K DIR I X["^" S QFLG=1 Q
    50         .I Y D
    51         ..W !!,"Volume > threshold"
    52         ..S DIR(0)="N^0:99",DIR("A")="Enter the new threshold volume" D ^DIR K DIR S ECTHLD=Y I X["^" S QFLG=1 Q
    53         ; get date range from user
    54         Q:QFLG
    55         W !!,"Enter the date range for which you would like to scan the"
    56         W !,"Surgery Extract records.",!
    57         S DONE=0 F  S (ECED,ECSD)="" D  Q:QFLG!DONE
    58         .K %DT S %DT="AEX",%DT("A")="Starting with Date: ",%DT(0)=-DATE D ^%DT
    59         .I Y<0 S QFLG=1 Q
    60         .S ECSD=Y,ECSD1=ECSD-.1
    61         .D DD^%DT S ECSTART=Y
    62         .K %DT S %DT="AEX",%DT("A")="Ending with Date: ",%DT(0)=-DATE D ^%DT
    63         .I Y<0 S QFLG=1 Q
    64         .I Y<ECSD D  Q
    65         ..W !!,"The ending date cannot be earlier than the starting date."
    66         ..W !,"Please try again.",!!
    67         .I $E(Y,1,5)'=$E(ECSD,1,5) D  Q
    68         ..W !!,"Beginning and ending dates must be in the same month and year"
    69         ..W !,"Please try again.",!!
    70         .S ECED=Y
    71         .D DD^%DT S ECEND=Y
    72         .S DONE=1
    73         Q
    74         ;
    75 PROCESS ; entry point for queued report
    76         S ZTREQ="@"
    77         S ECXERR=0 D EN^ECXUSUR1 Q:ECXERR
    78         S QFLG=0 D PRINT
    79         Q
    80         ;
    81 PRINT   ; process temp file and print report
    82         N PG,QFLG,GTOT,LN,COUNT,VOL,SUB,REC
    83         U IO
    84         I $D(ZTQUEUED),$$S^%ZTLOAD S ZTSTOP=1 K ZTREQ Q
    85         S (PG,QFLG,GTOT,COUNT)=0,$P(LN,"-",132)=""
    86         D HEADER Q:QFLG
    87         S VOL=-999999 F  S VOL=$O(^TMP($J,VOL)) Q:VOL=""!QFLG  D
    88         .S SUB="" F  S SUB=$O(^TMP($J,VOL,SUB)) Q:SUB=""!QFLG  S REC=^(SUB)  D
    89         ..S COUNT=COUNT+1
    90         ..I $Y+3>IOSL D HEADER Q:QFLG
    91         ..W !,?1,$P(REC,U),?7,$P(REC,U,2),?18,$P(REC,U,3),?27,$P(REC,U,4)
    92         ..W ?34,$P(REC,U,5),?55,$$RJ^XLFSTR($P(REC,U,7),4)
    93         ..W ?66,$$RJ^XLFSTR($P(REC,U,11),4),?77,$$RJ^XLFSTR($P(REC,U,9),4)
    94         ..W ?86,$$RJ^XLFSTR($P(REC,U,10),4),?93,$$RJ^XLFSTR($P(REC,U,6),4)
    95         ..W ?103,$$RJ^XLFSTR($P(REC,U,8),4),?113,$P(REC,U,14)
    96         ..W ?117,$P(REC,U,13)
    97         Q:QFLG
    98         I COUNT=0 W !!,?8,$S(ECXFLAG=1:"No surgery volumes to report for this extract",1:"No unusual volumes to report for this extract")
    99 CLOSE   ;
    100         I $E(IOST)="C",'QFLG D
    101         .S SS=22-$Y F JJ=1:1:SS W !
    102         .S DIR(0)="E" W ! D ^DIR K DIR
    103         Q
    104         ;
    105 HEADER  ;header and page control
    106         N SS,JJ
    107         I $E(IOST)="C" D
    108         .S SS=22-$Y F JJ=1:1:SS W !
    109         .I PG>0 S DIR(0)="E" W ! D ^DIR K DIR S:'Y QFLG=1
    110         Q:QFLG
    111         W:$Y!($E(IOST)="C") @IOF S PG=PG+1
    112         W !,$S(ECXFLAG:"SUR Volume Report",1:"Surgery Extract Unusual Volume Report"),?124,"Page: "_PG
    113         W !,"Start Date: ",ECSTART,?97,"Report Run Date/Time: "_ECRUN
    114         W !,"  End Date: ",ECEND I 'ECXFLAG W ?97,"     Threshold Value: ",ECTHLD
    115         W !!,?28,"Case",?38,"Encounter",?52,"Pt Holding",?63,"Anesthesia",?75,"Patient",?83,"Operation",?93,"PACU",?101,"OR Clean",?111,"Canc/",?121,"Principal"
    116         W !,?1,"Name",?10,"SSN",?20,"Day",?27,"Number",?40,"Number"
    117         W ?54,"Time",?66,"Time",?77,"Time",?86,"Time",?93,"Time",?103,"Time"
    118         W ?111,"Abort",?121,"Procedure"
    119         W !,LN,!
    120         Q
    121         ;
     1ECXUSUR ;ALB/TJL-Surgery Extract Unusual Volume Report ; 4/11/06 10:44AM
     2 ;;3.0;DSS EXTRACTS;**49,71,84,93**;July 1, 2003
     3 ;
     4EN ; entry point
     5 N X,Y,DATE,ECRUN,ECXDESC,ECXSAVE,ECXTL,ECTHLD
     6 N ECSD,ECSD1,ECSTART,ECED,ECEND,ECXERR,QFLG,ECXFLAG
     7 S QFLG=0,ECTHLD="",ECXFLAG=$G(FLAG)
     8 ; get today's date
     9 D NOW^%DTC S DATE=X,Y=$E(%,1,12) D DD^%DT S ECRUN=$P(Y,"@") K %DT
     10 I 'ECXFLAG D BEGIN Q:QFLG
     11 D SELECT Q:QFLG
     12 S ECXDESC=$S(ECXFLAG:"SUR Volume Report",1:"Surgery Extract Unusual Volume Report")
     13 S ECXSAVE("EC*")=""
     14 W !!,"This report requires 132-column format."
     15 D EN^XUTMDEVQ("PROCESS^ECXUSUR",ECXDESC,.ECXSAVE)
     16 I POP W !!,"No device selected...exiting.",! Q
     17 I IO'=IO(0) D ^%ZISC
     18 D HOME^%ZIS
     19 D AUDIT^ECXKILL
     20 Q
     21 ;
     22BEGIN ; display report description
     23 W @IOF
     24 W !,"This report prints a listing of unusual volumes that would be"
     25 W !,"generated by the Surgery extract (SUR) as determined by a"
     26 W !,"user-defined threshold value.  It should be run prior to the"
     27 W !,"generation of the actual extract(s) to identify and fix, as"
     28 W !,"necessary, any volumes determined to be erroneous."
     29 W !!,"Unusual volumes are those where either the Operation Time,"
     30 W !,"Patient Time, Anesthesia Time, Recovery Room Time, OR Clean Time"
     31 W !,"or Pt Holding Time field is greater than the threshold value."
     32 W !!,"Note: The threshold can be set after a report is selected."
     33 W !!,"Run times for this report will vary depending upon the size of"
     34 W !,"the extract and could take as long as 30 minutes or more to"
     35 W !,"complete.  This report has no effect on the actual extracts and"
     36 W !,"can be run as needed."
     37 W !!,"The report is sorted by descending Volume and Case Number."
     38 S DIR(0)="E" W ! D ^DIR K DIR I 'Y S QFLG=1 Q
     39 W:$Y!($E(IOST)="C") @IOF,!!
     40 Q
     41 ;
     42SELECT ; user inputs for threshold volume and date range
     43 N DONE,OUT
     44 ; allow user to set threshold volume
     45 I 'ECXFLAG D
     46 .S ECTHLD=25
     47 .W !!,"The default threshold volume for the Surgery extract is "_ECTHLD_"."
     48 .W !,"The default threshold volume ("_ECTHLD_") equates to 6 hours."
     49 .S DIR(0)="Y",DIR("A")="Would you like to change the threshold?",DIR("B")="NO" D ^DIR K DIR I X["^" S QFLG=1 Q
     50 .I Y D
     51 ..W !!,"Volume > threshold"
     52 ..S DIR(0)="N^0:99",DIR("A")="Enter the new threshold volume" D ^DIR K DIR S ECTHLD=Y I X["^" S QFLG=1 Q
     53 ; get date range from user
     54 Q:QFLG
     55 W !!,"Enter the date range for which you would like to scan the"
     56 W !,"Surgery Extract records.",!
     57 S DONE=0 F  S (ECED,ECSD)="" D  Q:QFLG!DONE
     58 .K %DT S %DT="AEX",%DT("A")="Starting with Date: ",%DT(0)=-DATE D ^%DT
     59 .I Y<0 S QFLG=1 Q
     60 .S ECSD=Y,ECSD1=ECSD-.1
     61 .D DD^%DT S ECSTART=Y
     62 .K %DT S %DT="AEX",%DT("A")="Ending with Date: ",%DT(0)=-DATE D ^%DT
     63 .I Y<0 S QFLG=1 Q
     64 .I Y<ECSD D  Q
     65 ..W !!,"The ending date cannot be earlier than the starting date."
     66 ..W !,"Please try again.",!!
     67 .I $E(Y,1,5)'=$E(ECSD,1,5) D  Q
     68 ..W !!,"Beginning and ending dates must be in the same month and year"
     69 ..W !,"Please try again.",!!
     70 .S ECED=Y
     71 .D DD^%DT S ECEND=Y
     72 .S DONE=1
     73 Q
     74 ;
     75PROCESS ; entry point for queued report
     76 S ZTREQ="@"
     77 S ECXERR=0 D EN^ECXUSUR1 Q:ECXERR
     78 S QFLG=0 D PRINT
     79 Q
     80 ;
     81PRINT ; process temp file and print report
     82 N PG,QFLG,GTOT,LN,COUNT,VOL,SUB,REC
     83 U IO
     84 I $D(ZTQUEUED),$$S^%ZTLOAD S ZTSTOP=1 K ZTREQ Q
     85 S (PG,QFLG,GTOT,COUNT)=0,$P(LN,"-",132)=""
     86 D HEADER Q:QFLG
     87 S VOL=-999999 F  S VOL=$O(^TMP($J,VOL)) Q:VOL=""!QFLG  D
     88 .S SUB="" F  S SUB=$O(^TMP($J,VOL,SUB)) Q:SUB=""!QFLG  S REC=^(SUB)  D
     89 ..S COUNT=COUNT+1
     90 ..I $Y+3>IOSL D HEADER Q:QFLG
     91 ..W !,$P(REC,U),?6,$P(REC,U,2),?17,$P(REC,U,3),?26,$P(REC,U,4)
     92 ..W ?33,$P(REC,U,5),?55,$$RJ^XLFSTR($P(REC,U,9),4)
     93 ..W ?63,$$RJ^XLFSTR($P(REC,U,10),4),?74,$$RJ^XLFSTR($P(REC,U,11),4)
     94 ..W ?83,$$RJ^XLFSTR($P(REC,U,6),4),?90,$$RJ^XLFSTR($P(REC,U,8),4)
     95 ..W ?101,$$RJ^XLFSTR($P(REC,U,7),4),?114,$P(REC,U,13)
     96 Q:QFLG
     97 I COUNT=0 W !!,?8,$S(ECXFLAG=1:"No surgery volumes to report for this extract",1:"No unusual volumes to report for this extract")
     98CLOSE ;
     99 I $E(IOST)="C",'QFLG D
     100 .S SS=22-$Y F JJ=1:1:SS W !
     101 .S DIR(0)="E" W ! D ^DIR K DIR
     102 Q
     103 ;
     104HEADER ;header and page control
     105 N SS,JJ
     106 I $E(IOST)="C" D
     107 .S SS=22-$Y F JJ=1:1:SS W !
     108 .I PG>0 S DIR(0)="E" W ! D ^DIR K DIR S:'Y QFLG=1
     109 Q:QFLG
     110 W:$Y!($E(IOST)="C") @IOF S PG=PG+1
     111 W !,$S(ECXFLAG:"SUR Volume Report",1:"Surgery Extract Unusual Volume Report"),?124,"Page: "_PG
     112 W !,"Start Date: ",ECSTART,?97,"Report Run Date/Time: "_ECRUN
     113 W !,"  End Date: ",ECEND I 'ECXFLAG W ?97,"     Threshold Value: ",ECTHLD
     114 W !!,?27,"Case",?37,"Encounter",?53,"Patient",?61,"Operation",?71,"Anesthesia",?83,"PACU",?89,"OR Clean",?99,"Pt Holding",?114,"Principal"
     115 W !,"Name",?9,"SSN",?19,"Day",?26,"Number",?39,"Number"
     116 W ?55,"Time",?63,"Time",?74,"Time",?83,"Time",?90,"Time",?101,"Time"
     117 W ?114,"Procedure"
     118 W !,LN,!
     119 Q
     120 ;
Note: See TracChangeset for help on using the changeset viewer.