source: FOIAVistA/tag/r/REGISTRATION-DGQE-DG-DPT-GRPX-VAD-VAF-VAS-VAT-VAU--VA-VIC--DGBT--DGJ--DGYA--VALM/DGAINP4.m@ 636

Last change on this file since 636 was 628, checked in by George Lilly, 14 years ago

initial load of FOIAVistA 6/30/08 version

File size: 3.1 KB
Line 
1DGAINP4 ;ALB/RMO - Print Inpatient AMIS's 334-341 ; 27 DEC 89 1:37 pm
2 ;;5.3;Registration;;Aug 13, 1993
3 ;==============================================================
4 ;Print inpatient AMIS segment fields for each division.
5 ;
6 ;Input:
7 ; DGMYR -Month/Year being printed in internal date format
8 ; ^UTILITY-Contains stats by Month/Year, Segment and Division
9 ;==============================================================
10 S DGPGE=0,DGLNE="",DGIOM=$S('IOM:80,1:IOM),$P(DGLNE,"=",(DGIOM-1))="",DGX="",DGMAR=DGIOM-38
11 F DGSEG=0:0 S DGSEG=$O(^UTILITY($J,"DGAINP",DGMYR,DGSEG)) Q:'DGSEG!(DGX["^") D SET,PRT
12 ;
13Q K DGDIVNB,DGFLD,DGIOM,DGLNE,DGMAR,DGPGE,DGSEG,DGTAB,DGX,I,X,Y
14 Q
15 ;
16SET ;Set Tab Variable for Print
17 S DGDIVNB=0 F I=0:0 S I=$O(^UTILITY($J,"DGAINP",DGMYR,DGSEG,I)) Q:'I S DGDIVNB=DGDIVNB+1
18 S DGTAB=$S(DGMAR\DGDIVNB>20:20,1:DGMAR\DGDIVNB)
19 Q
20 ;
21PRT ;Print AMIS Segment
22 D HD Q:DGX["^"
23 S DGFLD="001^TOTAL ADMISSIONS" D FLD Q:DGX["^"
24 S DGFLD="002^TRANSFERS IN" D FLD Q:DGX["^"
25 S DGFLD="003^CHANGES IN BEDSECTION(+)" D FLD Q:DGX["^"
26 S DGFLD="004^DEATHS,BO AND ABO" D FLD Q:DGX["^"
27 S DGFLD="005^DISCHARGE TO OPT/NSC" D FLD Q:DGX["^"
28 S DGFLD="006^DISCHARGES NOT TO OPT/NSC" D FLD Q:DGX["^"
29 S DGFLD="007^TRANSFERS OUT" D FLD Q:DGX["^"
30 S DGFLD="008^CHANGES IN BEDSECTION(-)" D FLD Q:DGX["^"
31 S DGFLD="009^BED OCCUPANTS EOM" D FLD Q:DGX["^"
32 S DGFLD="010^ABSENT BED OCCUPANTS EOM" D FLD Q:DGX["^"
33 S DGFLD="011^PATIENT DAYS OF CARE"_$S(DGSEG=334:" (1-45)",1:"") D FLD Q:DGX["^"
34 I DGSEG=334 S DGFLD="012^PATIENT DAYS OF CARE ( >45)" D FLD Q:DGX["^"
35 S DGFLD=$S(DGSEG>334:"012",1:"013")_"^DAYS OF AUTH ABSENCE <96HRS" D FLD Q:DGX["^"
36 S DGFLD=$S(DGSEG>334:"013",1:"014")_"^OPERATING BEDS EOM" D FLD Q:DGX["^"
37 S DGFLD=$S(DGSEG>334:"014",1:"015")_"^FEMALE PATIENTS REMAINING EOM" D FLD Q:DGX["^"
38 I DGSEG=336 S DGFLD="015^DIALYSIS OPERATING BEDS" D FLD Q:DGX["^"
39 D LEG
40 Q
41 ;
42FLD ;Print Field for AMIS Segment
43 D HD:($Y+7)>IOSL Q:DGX["^" W !,"(",$P(DGFLD,"^"),") ",$P(DGFLD,"^",2),?38
44 F I=0:0 S I=$O(^UTILITY($J,"DGAINP",DGMYR,DGSEG,I)) Q:'I W $J(+$P(^(I),"^",+DGFLD),DGTAB-2)
45 Q
46 ;
47HD D CRCHK Q:DGX["^" W @IOF,!?30,"AMIS ",DGSEG," REPORT" S DGPGE=DGPGE+1 S Y=DT X ^DD("DD") W ?60,"DATE: ",Y
48 W !?30,$S(DGSEG=334:"PSYCHIATRY",DGSEG=335:"INTERMEDIATE MEDICINE",DGSEG=336:"MEDICINE",DGSEG=337:"NEUROLOGY",DGSEG=338:"REHABILITATION MED",DGSEG=339:"BLIND REHABILITATION",DGSEG=340:"SPINAL CORD INJURY",DGSEG=341:"SURGERY",1:"UNKNOWN")
49 S Y=DGMYR X ^DD("DD") W !?32,"for ",Y
50 W !!?38 F I=0:0 S I=$O(^UTILITY($J,"DGAINP",DGMYR,DGSEG,I)) Q:'I W $J($E($S($D(^DG(40.8,I,0)):$P(^(0),"^"),1:"UNKNOWN"),1,DGTAB-2),DGTAB)
51 W !,DGLNE
52 Q
53 ;
54LEG D CRCHK:($Y+7)>IOSL Q:DGX["^" W !,DGLNE,!,"FOR THIS SEGMENT FIELDS SHOULD BALANCE AS FOLLOWS:"
55 W !!,?3,"Fields 009 and 010 prior period plus 001,002,003 current period"
56 W !,?3,"less fields 004 thru 008 current period must equal fields",!?3,"009 and 010 current period."
57 I $D(^DGAM(334,DGMYR,"SE",DGSEG,0)),'$P(^(0),"^",2) W !!,"*** This segment ",$S($P(^(0),"^",2)="":"has Not been Balanced",1:"is Out of Balance"),". ***"
58 W !,DGLNE
59 Q
60 ;
61CRCHK I DGPGE,$E(IOST,1)="C" W !!,*7,"Press RETURN to continue or '^' to stop " R X:DTIME S:'$T X="^" S DGX=X
62 Q
Note: See TracBrowser for help on using the repository browser.