source: FOIAVistA/trunk/r/LAB_SERVICE-LR-LS/LR7OGMG.m@ 635

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

initial load of FOIAVistA 6/30/08 version

File size: 3.1 KB
Line 
1LR7OGMG ;DALOI/STAFF- Interim report rpc memo grid ;July 19, 2006
2 ;;5.2;LAB SERVICE;**187,230,286,290,331,364**;Sep 27, 1994;Build 3
3 ;
4GRID(OUTCNT) ; from LR7OGMC
5 N ACC,AGE,CDT,CMNT,DATA,DOC,FLAG,IDT,INTP,LINE,LRCW,LRX,MPLS,PLS,PORDER,PRNTCODE,RANGE,SEX,SPEC,SUB,TCNT,TESTNAME,TESTNUM
6 N UNITS,VALUE,X,ZERO,INEXACT,DISPDATE
7 ; the variables AGE, SEX, LRCW, and X are used withing the lab's print codes and ref ranges
8 K ^TMP("LRMPLS",$J)
9 S AGE=$P(^TMP("LR7OG",$J,"G"),U,4),SEX=$P(^("G"),U,5),LRCW=$P(^("G"),U,6)
10 S CDT=+$O(^TMP("LR7OG",$J,"TP",0)) Q:'CDT
11 S IDT=9999999-CDT
12 S ZERO=$S($D(^TMP("LR7OG",$J,"TP",CDT))#2:^(CDT),1:"")
13 I '$P(ZERO,U,3) Q
14 S SPEC=+$P(ZERO,U,5)
15 S INEXACT=$P(ZERO,U,2),DISPDATE=$S(INEXACT:CDT\1,1:CDT)
16 S DOC=$$NAME^LR7OGMP(+$P(ZERO,U,10))
17 S ACC=$P(ZERO,U,6)
18 S $P(^TMP("LR7OGX",$J,"OUTPUT",1),U,4,6)=SPEC_U_$P($G(^LAB(61,SPEC,0)),U)_U_ACC_U_DOC
19 S $P(^TMP("LR7OGX",$J,"OUTPUT",1),U,10)=DISPDATE
20 S (TCNT,MPLS,PORDER,PLS)=0
21 S PLS=$O(^TMP("LRPLS",$J,0))
22 I $O(^TMP("LRPLS",$J,PLS)) S MPLS=1 ; multiple performing labs
23 F S PORDER=$O(^TMP("LR7OG",$J,"TP",CDT,PORDER)) Q:PORDER'>0 S DATA=^(PORDER) D
24 . I $P(DATA,U,7)="" Q
25 . S TCNT=TCNT+1
26 . S TESTNUM=+DATA,TESTNAME=$P(DATA,U,2),PRNTCODE=$P(DATA,U,5),SUB=$P(DATA,U,6),FLAG=$P(DATA,U,8),X=$P(DATA,U,7),UNITS=$P(DATA,U,9),RANGE=$P(DATA,U,10),PLS=$P(DATA,U,11)
27 . I MPLS,PLS S ^TMP("LRMPLS",$J,PLS,TESTNAME)=""
28 . I PRNTCODE="" S VALUE=$J(X,8)
29 . E S @("VALUE="_PRNTCODE)
30 . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=TESTNUM_U_TESTNAME_U_VALUE_U_FLAG_U_UNITS_U_RANGE
31 . S OUTCNT=OUTCNT+1
32 S $P(^TMP("LR7OGX",$J,"OUTPUT",1),U)=TCNT
33 ;
34 S PORDER=0
35 F S PORDER=$O(^TMP("LR7OG",$J,"TP",CDT,PORDER)) Q:PORDER'>0 S DATA=^(PORDER) D
36 . I $O(^TMP("LR7OG",$J,"TP",CDT,PORDER,0))>0 D
37 . . S TESTNAME=$P(DATA,U,3)
38 . . S INTP=0
39 . . F S INTP=+$O(^TMP("LR7OG",$J,"TP",CDT,PORDER,INTP)) Q:INTP<1 D
40 . . . S LINE=TESTNAME_" Eval: "_^TMP("LR7OG",$J,"TP",CDT,PORDER,INTP)
41 . . . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=LINE
42 . . . S OUTCNT=OUTCNT+1
43 ;
44 I $D(^TMP("LR7OG",$J,"TP",CDT,"C")) D
45 . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)="Comment: "
46 . S OUTCNT=OUTCNT+1,CMNT=0
47 . F S CMNT=+$O(^TMP("LR7OG",$J,"TP",CDT,"C",CMNT)) Q:CMNT<1 S LINE=^(CMNT) D
48 . . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=" "_LINE
49 . . S OUTCNT=OUTCNT+1
50 ;
51 D PLS
52 Q
53 ;
54 ;
55PLS ; List performing laboratories
56 ; If multiple performing labs then list tests associated with each lab.
57 ;
58 N CNT,LINE,LRPLS,X
59 S (CNT,LRPLS)=0
60 F S LRPLS=$O(^TMP("LRPLS",$J,LRPLS)) Q:LRPLS<1 D
61 . I CNT S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=" ",OUTCNT=OUTCNT+1
62 . I $D(^TMP("LRMPLS",$J,LRPLS)) D
63 . . S TESTNAME="",LINE="For test(s): "
64 . . F S TESTNAME=$O(^TMP("LRMPLS",$J,LRPLS,TESTNAME)) Q:TESTNAME="" D
65 . . . I ($L(LINE)+$L(TESTNAME))>240 D
66 . . . . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=LINE
67 . . . . S OUTCNT=OUTCNT+1,LINE=""
68 . . . S LINE=LINE_TESTNAME_", "
69 . . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)=LINE,OUTCNT=OUTCNT+1
70 . S LINE=$$NAME^XUAF4(LRPLS)
71 . S X=$$PADD^XUAF4(LRPLS)
72 . S LINE=LINE_" "_$P(X,U)_" "_$P(X,U,2)_", "_$P(X,U,3)_" "_$P(X,U,4)
73 . S ^TMP("LR7OGX",$J,"OUTPUT",OUTCNT)="Performing Lab: "_LINE
74 . S OUTCNT=OUTCNT+1,CNT=CNT+1
75 ;
76 K ^TMP("LRPLS",$J),^TMP("LRMPLS",$J)
77 Q
Note: See TracBrowser for help on using the repository browser.