- GMRVKPN0 ;HCIOFO/YH-KYOCERA PAIN CHART - DATA ARRAY ;2/12/99
- ;;4.0;Vitals/Measurements;**9**;Apr 25, 1997
- EN1 ;ENTRY POINT TO PRINT KYOCERA PAIN CHART
- ;S DFN=72,GMRSTRT=2990201,GMRFIN=2990215
- S GMROUT=0 K ^TMP($J,"GMR"),^TMP($J,"GMRK"),^TMP($J,"GDT"),^TMP($J,"GMRVG"),^TMP($J,"GTNM") F GI=1:1:200 S ^TMP($J,"GMRK","G"_GI)=""
- S GSTART1=(9999999-GMRFIN)-.0001,GEND1=9999999-GMRSTRT,^TMP($J,"GMRK","G50M")=0.4
- F GTYPE="PN" D SETT^GMRVHPN0
- U IO D GRAPH
- Q1 K GSOL,GIVDT,GMRHLOC,GMRVJ,GDATA,GDT,GEN,GEND1,GI,GJ,GK,GMRVX,GSTART1,GTNM,GTYP,GTYPE,GX,I D KVAR^VADPT K VA,VAROOT
- K GMRRMBD,GAGE,GCNT,GDOB,GCNTB,GCNTD,GCNTP,GCNTR,GCNTT,GCNTT1,GCNTI,GCNTO,GDT1,GCNTPD,GCNTTD,GCNTW,GPG,GPGS,GTYPE1,GCNTB3,GDTA,XDT,XIO,XX,^TMP($J,"GMRK"),^TMP($J,"GMR"),^TMP($J,"GDT"),^TMP($J,"GMRVG")
- K ^TMP($J,"GTNM") Q
- GRAPH D DEM^VADPT,INP^VADPT,SETV^GMRVGR1
- S GK="PN",^TMP($J,"GTNM",GK)=0 F GI=0:0 S GI=$O(^TMP($J,"GMRVG",GK,GI)) Q:GI'>0 S GJ="" F X=0:0 S GJ=$O(^TMP($J,"GMRVG",GK,GI,GJ)) Q:GJ="" S ^TMP($J,"GTNM",GK)=^TMP($J,"GTNM",GK)+1,^TMP($J,"GDT",GI)=""
- S GTNM=0 F X=0:0 S X=$O(^TMP($J,"GDT",X)) Q:X'>0 S GTNM=GTNM+1
- S GPG=$S(GTNM=0:1,1:GTNM\10+''(GTNM#10)),GDT1=0
- F GPGS=1:1:GPG S ^TMP($J,"GMRK","G199")="Page "_GPGS D SETP,DATE S ^TMP($J,"GMRK","G200")=GMRRMBD D PAGE,^GMRVKPN1,^GMRVKPN2
- D KVAR^VADPT K VA,GRAPHR,GRAPHP,GRAPHS,GRAPHD,GPA Q
- PAGE ;SET GRAPH DATA
- ;DATA FOR PAIN CHART
- F GI=50:1:59 S ^TMP($J,"GMRK","G50")=^TMP($J,"GMRK","G"_GI),^TMP($J,"GMRK","G50M")=0.4+(1.6*(GI-50)) Q:^TMP($J,"GMRK","G50")'=""
- Q
- DATE F GCNTD=1:1:10 S:$L(GDT1) GDT1=$O(^TMP($J,"GDT",GDT1)) S ^TMP($J,"GMRK","G"_GCNTD)=$S($L(GDT1):$E(GDT1,4,5)_"-"_$E(GDT1,6,7)_"-"_$E(GDT1,2,3),1:"") D DATE1
- Q
- DATE1 S Y=$E($P(GDT1,".",2)_"0000",1,4),^TMP($J,"GMRK","G"_(GCNTD+16))=$S($L(GDT1):$E(Y,1,2)_":"_$E(Y,3,4),1:"") D SETD
- Q
- SETD S GI="PN" S GJ=48,GK=$S($L(GDT1):$O(^TMP($J,"GMRVG",GI,GDT1,"")),1:"") D SETA
- Q
- SETP ;INITIALIZE ^TMP FOR QUALIFIERS
- ; 410 - STORE P
- ; 250+I - DATA
- F I=1:1:10 S (^TMP($J,"GMRK","G"_(410+I)),^("G"_(250+I)))=""
- Q
- SETA ;
- I GK="Unavailable" S GK="Unavail"
- S ^TMP($J,"GMRK","G"_(GJ+200+GCNTD+1))=GK
- I (GK=99)!("PASSREFUSEDUNAVAIL"[$$UP^XLFSTR(GK)) S ^TMP($J,"GMRK","G"_(49+GCNTD))="" Q
- S ^TMP($J,"GMRK","G"_(49+GCNTD))=12-GK
- S ^TMP($J,"GMRK","G"_(410+GCNTD))="P"
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HGMRVKPN0 2315 printed Feb 18, 2025@23:23:18 Page 2
- GMRVKPN0 ;HCIOFO/YH-KYOCERA PAIN CHART - DATA ARRAY ;2/12/99
- +1 ;;4.0;Vitals/Measurements;**9**;Apr 25, 1997
- EN1 ;ENTRY POINT TO PRINT KYOCERA PAIN CHART
- +1 ;S DFN=72,GMRSTRT=2990201,GMRFIN=2990215
- +2 SET GMROUT=0
- KILL ^TMP($JOB,"GMR"),^TMP($JOB,"GMRK"),^TMP($JOB,"GDT"),^TMP($JOB,"GMRVG"),^TMP($JOB,"GTNM")
- FOR GI=1:1:200
- SET ^TMP($JOB,"GMRK","G"_GI)=""
- +3 SET GSTART1=(9999999-GMRFIN)-.0001
- SET GEND1=9999999-GMRSTRT
- SET ^TMP($JOB,"GMRK","G50M")=0.4
- +4 FOR GTYPE="PN"
- DO SETT^GMRVHPN0
- +5 USE IO
- DO GRAPH
- Q1 KILL GSOL,GIVDT,GMRHLOC,GMRVJ,GDATA,GDT,GEN,GEND1,GI,GJ,GK,GMRVX,GSTART1,GTNM,GTYP,GTYPE,GX,I
- DO KVAR^VADPT
- KILL VA,VAROOT
- +1 KILL GMRRMBD,GAGE,GCNT,GDOB,GCNTB,GCNTD,GCNTP,GCNTR,GCNTT,GCNTT1,GCNTI,GCNTO,GDT1,GCNTPD,GCNTTD,GCNTW,GPG,GPGS,GTYPE1,GCNTB3,GDTA,XDT,XIO,XX,^TMP($JOB,"GMRK"),^TMP($JOB,"GMR"),^TMP($JOB,"GDT"),^TMP($JOB,"GMRVG")
- +2 KILL ^TMP($JOB,"GTNM")
- QUIT
- GRAPH DO DEM^VADPT
- DO INP^VADPT
- DO SETV^GMRVGR1
- +1 SET GK="PN"
- SET ^TMP($JOB,"GTNM",GK)=0
- FOR GI=0:0
- SET GI=$ORDER(^TMP($JOB,"GMRVG",GK,GI))
- if GI'>0
- QUIT
- SET GJ=""
- FOR X=0:0
- SET GJ=$ORDER(^TMP($JOB,"GMRVG",GK,GI,GJ))
- if GJ=""
- QUIT
- SET ^TMP($JOB,"GTNM",GK)=^TMP($JOB,"GTNM",GK)+1
- SET ^TMP($JOB,"GDT",GI)=""
- +2 SET GTNM=0
- FOR X=0:0
- SET X=$ORDER(^TMP($JOB,"GDT",X))
- if X'>0
- QUIT
- SET GTNM=GTNM+1
- +3 SET GPG=$SELECT(GTNM=0:1,1:GTNM\10+''(GTNM#10))
- SET GDT1=0
- +4 FOR GPGS=1:1:GPG
- SET ^TMP($JOB,"GMRK","G199")="Page "_GPGS
- DO SETP
- DO DATE
- SET ^TMP($JOB,"GMRK","G200")=GMRRMBD
- DO PAGE
- DO ^GMRVKPN1
- DO ^GMRVKPN2
- +5 DO KVAR^VADPT
- KILL VA,GRAPHR,GRAPHP,GRAPHS,GRAPHD,GPA
- QUIT
- PAGE ;SET GRAPH DATA
- +1 ;DATA FOR PAIN CHART
- +2 FOR GI=50:1:59
- SET ^TMP($JOB,"GMRK","G50")=^TMP($JOB,"GMRK","G"_GI)
- SET ^TMP($JOB,"GMRK","G50M")=0.4+(1.6*(GI-50))
- if ^TMP($JOB,"GMRK","G50")'=""
- QUIT
- +3 QUIT
- DATE FOR GCNTD=1:1:10
- if $LENGTH(GDT1)
- SET GDT1=$ORDER(^TMP($JOB,"GDT",GDT1))
- SET ^TMP($JOB,"GMRK","G"_GCNTD)=$SELECT($LENGTH(GDT1):$EXTRACT(GDT1,4,5)_"-"_$EXTRACT(GDT1,6,7)_"-"_$EXTRACT(GDT1,2,3),1:"")
- DO DATE1
- +1 QUIT
- DATE1 SET Y=$EXTRACT($PIECE(GDT1,".",2)_"0000",1,4)
- SET ^TMP($JOB,"GMRK","G"_(GCNTD+16))=$SELECT($LENGTH(GDT1):$EXTRACT(Y,1,2)_":"_$EXTRACT(Y,3,4),1:"")
- DO SETD
- +1 QUIT
- SETD SET GI="PN"
- SET GJ=48
- SET GK=$SELECT($LENGTH(GDT1):$ORDER(^TMP($JOB,"GMRVG",GI,GDT1,"")),1:"")
- DO SETA
- +1 QUIT
- SETP ;INITIALIZE ^TMP FOR QUALIFIERS
- +1 ; 410 - STORE P
- +2 ; 250+I - DATA
- +3 FOR I=1:1:10
- SET (^TMP($JOB,"GMRK","G"_(410+I)),^("G"_(250+I)))=""
- +4 QUIT
- SETA ;
- +1 IF GK="Unavailable"
- SET GK="Unavail"
- +2 SET ^TMP($JOB,"GMRK","G"_(GJ+200+GCNTD+1))=GK
- +3 IF (GK=99)!("PASSREFUSEDUNAVAIL"[$$UP^XLFSTR(GK))
- SET ^TMP($JOB,"GMRK","G"_(49+GCNTD))=""
- QUIT
- +4 SET ^TMP($JOB,"GMRK","G"_(49+GCNTD))=12-GK
- +5 SET ^TMP($JOB,"GMRK","G"_(410+GCNTD))="P"
- +6 QUIT