source: FOIAVistA/trunk/r/SURGERY-SR/SROAPAS.m@ 1800

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

initial load of FOIAVistA 6/30/08 version

File size: 5.2 KB
Line 
1SROAPAS ;BIR/MAM - PRINT A COMPLETE ASSESSMENT ;03/03/08
2 ;;3.0; Surgery ;**38,47,81,88,111,112,100,125,153,166**;24 Jun 93;Build 6
3 S SRSOUT=0,SRPG=0,SR("RA")=$G(^SRF(SRTN,"RA")),SRATYPE=$P(SR("RA"),"^",2) F I=200:1:208,200.1 S SRA(I)=$G(^SRF(SRTN,I))
4 S SRA("OP")=^SRF(SRTN,"OP"),SRA("CON")=$G(^SRF(SRTN,"CON"))
5 S SR(0)=^SRF(SRTN,0),DFN=$P(SR(0),"^"),SRSDATE=$P(SR(0),"^",9) D DEM^VADPT S SRANM=VADM(1)_" "_VA("PID"),Z=$P(VADM(3),"^"),Y=$E(SRSDATE,1,7),AGE=$E(Y,1,3)-$E(Z,1,3)-($E(Y,4,7)<$E(Z,4,7))
6 I $P(SR("RA"),"^",2)="C" D ^SROAPCA G END
7 W:$E(IOST)'="P" @IOF D HDR G:SRSOUT END
8 W !,"Medical Center: "_SRSITE("SITE")
9 W !,"Age: ",?16,AGE S Y=SRSDATE D D^DIQ W ?40,"Operation Date: ",?59,$P(Y,"@")
10 S Y=$P($G(^SRF(SRTN,208)),"^",10),C=$P(^DD(130,417,0),"^",2) D Y^DIQ S X=$S(Y'="":Y,1:"NOT ENTERED")
11 ;
12 D DEM^VADPT
13 ;Find patient's ethnicity
14 S SROETH=""
15 I $G(VADM(11)) S SROETH=$P(VADM(11,1),U,2)
16 I '$G(VADM(11)) S SROETH="UNANSWERED"
17 ;
18 ;Find all race entries and place into a string with commas inbetween
19 S SRORC=0,C=1,SRORACE="",SROLINE="",N=1,SROL=""
20 F S SRORC=$O(VADM(12,SRORC)) Q:SRORC="" Q:C=11 D
21 .I $G(VADM(12,SRORC)) S SRORACE(C)=$P(VADM(12,SRORC),U,2)
22 .I SROLINE'="" S SROLINE=SROLINE_", "_SRORACE(C)
23 .I SROLINE="" S SROLINE=SRORACE(C)
24 .S C=C+1
25 ;
26 ;Find total length of 'race' string and wrap the text if necessary
27 I $L(SROLINE)=29!$L(SROLINE)<29 S SROL(N)=SROLINE,SRNUM1=2
28 I $L(SROLINE)>29 D WRAP
29 ;
30 W !,"Sex: ",?16,$P(VADM(5),"^",2),?40,"Ethnicity:",?51,SROETH
31 W !,?40,"Race:"
32 I $G(VADM(12)) F D=1:1:SRNUM1-1 D
33 .W:D=1 ?51,SROL(D)
34 .W:D'=1 !,?51,SROL(D)
35 I '$G(VADM(12)) W ?51,"UNANSWERED"
36 ;
37 K SROL,SROLINE,SRORC,SRORACE,SROLN,SROLN1,SROWRAP,SRNUM1
38 ;
39 S Y=$P($G(^SRF(SRTN,208)),"^",11),C=$P(^DD(130,413,0),"^",2) D Y^DIQ S X=$S(Y'="":Y,1:"NOT ENTERED") W !,"Transfer Status: ",X
40 F J=1,2,3 S Y=$P($G(^SRF(SRTN,208.1)),"^",J) D
41 .I J'=3 X:Y ^DD("DD") S Z=$P(Y,"@")_" "_$E($P(Y,"@",2),1,5)
42 .I J=3 S C=$P(^DD(130,454,0),"^",2) D Y^DIQ S Z=Y
43 .W !,"Observation "_$S(J=1:"Admission Date:",J=2:"Discharge Date:",1:"Treating Specialty:"),?47,Z
44 F J=14:1:17 S Y=$P($G(^SRF(SRTN,208)),"^",J) X ^DD("DD") S SRPTMODT(J)=Y
45 S (X,Z)=SRPTMODT(14) S:X'="" Z=$P(X,"@")_" "_$E($P(X,"@",2),1,5) W !,"Hospital Admission Date:",?47,Z
46 S (X,Z)=SRPTMODT(15) S:X'="" Z=$P(X,"@")_" "_$E($P(X,"@",2),1,5) W !,"Hospital Discharge Date:",?47,Z
47 S (X,Z)=SRPTMODT(16) S:X'="" Z=$P(X,"@")_" "_$E($P(X,"@",2),1,5) W !,"Admitted/Transferred to Surgical Service:",?47,Z
48 S (X,Z)=SRPTMODT(17) S:X'="" Z=$P(X,"@")_" "_$E($P(X,"@",2),1,5) W !,"Discharged/Transferred to Chronic Care:",?47,Z
49 W !,"In/Out-Patient Status:",?47,$S($P($G(^SRF(SRTN,0)),"^",12)="I":"INPATIENT",$P($G(^SRF(SRTN,0)),"^",12)="O":"OUTPATIENT",1:"")
50 S Y=$P($G(^SRF(SRTN,209)),"^",17) X ^DD("DD") W !,"Date Surgery Consult Requested:",?47,Y
51 S Y=$P($G(^SRF(SRTN,209)),"^",15) X ^DD("DD") W !,"Surgery Consult Date:",?47,Y
52 I $E(IOST)="P" W ! F MOE=1:1:80 W "-"
53 I $E(IOST)'="P" D PAGE I SRSOUT G END
54 D ^SROAPRT1 G:SRSOUT END I $Y+20>IOSL D PAGE I SRSOUT G END
55 D ^SROAPRT2 G:SRSOUT END I $Y+20>IOSL D PAGE I SRSOUT G END
56 D OPTIMES^SROAPRT3 G:SRSOUT END I $Y+20>IOSL D PAGE I SRSOUT G END
57 D ^SROAPRT3 G:SRSOUT END I $Y+24>IOSL D PAGE I SRSOUT G END
58 D ^SROAPRT4 G:SRSOUT END I $Y+20>IOSL D PAGE I SRSOUT G END
59 D ^SROAPRT5 G:SRSOUT END I $Y+20>IOSL D PAGE I SRSOUT G END
60 D ^SROAPRT6
61END Q:$D(SRABATCH) I 'SRSOUT,$E(IOST)'="P" W !!,"Press <RET> to continue " R X:DTIME
62 W:$E(IOST)="P" @IOF I $D(ZTQUEUED) Q:$G(ZTSTOP) S ZTREQ="@" Q
63 D ^%ZISC K SROETH,SRTN W @IOF D ^SRSKILL
64 Q
65 ;
66WRAP ;Wrap multiple race entries so that wrapped line
67 ;does not break in the middle of a word
68 ;
69 S SROLNGTH=$L(SROLINE),E=29,SROWRAP="",SROLN="",SROLN1="",SROL=""
70 F I=1:29:SROLNGTH S SROLN(I)=SROWRAP_$E(SROLINE,I,E) D
71 .F K=29:-1:1 I $E(SROLN(I),K)[" " D Q ;Break lines at space
72 ..S SROLN1(I)=$E(SROLN(I),1,K-1)
73 ..S SROWRAP=$E(SROLN(I),K+1,E)
74 .S E=E+29
75 ;
76 S:'$D(SROLN1(I)) SROLN1(I)=SROLN(I),SROWRAP=""
77 I $L(SROLN1(I))+$L(SROWRAP)>28 S SROLN1(I+1)=SROWRAP ;Last line
78 I $L(SROLN1(I))+$L(SROWRAP)'>28 S SROLN1(I)=SROLN1(I)_" "_SROWRAP
79 ;
80 ;Renumber the SROLN1 array to be in numeric order
81 S SRNUM=0,SRNUM1=1
82 F S SRNUM=$O(SROLN1(SRNUM)) Q:SRNUM="" D
83 .S SROL(SRNUM1)=SROLN1(SRNUM)
84 .S SRNUM1=SRNUM1+1
85 Q
86 ;
87LOOP ; break procedures
88 S SROPS(M)="" F LOOP=1:1 S MM=$P(SROPER," "),MMM=$P(SROPER," ",2,200) Q:MMM="" Q:$L(SROPS(M))+$L(MM)'<55 S SROPS(M)=SROPS(M)_MM_" ",SROPER=MMM
89 Q
90PAGE I $E(IOST)'="P" W !!,"Press <RET> to continue, or '^' to quit " R X:DTIME I '$T!(X["^") S SRSOUT=1 Q
91 I X["?" W !!,"Enter <RET> to continue printing the remaining pages of this assessment, or",!,"'^' to exit this option." G PAGE
92 W @IOF
93HDR ; print heading
94 I $D(ZTQUEUED) D ^SROSTOP I SRHALT S SRSOUT=1 Q
95 S SRPG=SRPG+1
96 I $Y'=0 W @IOF
97 I SRATYPE="C" W !,"VA CARDIAC RISK ASSESSMENT",?70,"PAGE "_SRPG
98 I SRATYPE="N" W !,"VA NON-CARDIAC RISK ASSESSMENT Assessment: "_SRTN,?69,"PAGE "_SRPG
99 W !,"FOR "_SRANM S X=$P(SR("RA"),"^") W " ("_$S(X="I":"INCOMPLETE",X="C":"COMPLETED",X="T":"TRANSMITTED",1:"NO ASSESSMENT") I X="T" S Y=$P(SR("RA"),"^",4) W " "_$E(Y,4,5)_"/"_$E(Y,6,7)_"/"_$E(Y,2,3)
100 W ")",! F LINE=1:1:80 W "="
101 W !
102 Q
103CODE ; print CPT Code
104 S X=$P(^SRF(SRTN,13,SR,0),"^",2) I X W " ("_$P($$CPT^ICPTCOD(X),"^",2)_")"
105 Q
Note: See TracBrowser for help on using the repository browser.