- Timestamp:
- Dec 4, 2009, 12:11:15 AM (14 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
WorldVistAEHR/trunk/r/PHARMACY_DATA_MANAGEMENT-PSS/PSS51P1.m
r613 r623 1 PSS51P1 ;BIR/LDT - API FOR INFORMATION FROM FILE 51.1 ;5 Sep 03 2 ;;1.0;PHARMACY DATA MANAGEMENT;**85,91,108,118,94**;9/30/97;Build 26 3 ; 4 ZERO(PSSIEN,PSSFT,PSSPP,PSSTSCH,LIST) ; 5 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 6 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 7 ;PSSPP - PACKAGE PREFIX field (#4) in ADMINISTRATION SCHEDULE file (#51.1). Screens for Administration 8 ;Schedules for the Package Prefix passed. 9 ;PSSTSCH - TYPE OF SCHEDULE field (#5) of ADMINISTRATION SCHEDULE file (#51.1). Screens for 10 ; One-time "O" if PSSTSCH passed in. 11 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 12 ; Field Number of the data piece being returned. 13 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 14 ;MAXIMUM DAYS FOR ORDERS field (#2.5), PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), 15 ;STANDARD SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), and OTHER LANGUAGE EXPANSIONS field (#8.1) 16 ;of ADMINISTRATION SCHEDULE file (#51.1). 17 N DIERR,ZZERR,PSS51P1,SCR,PSS 18 I $G(LIST)']"" Q 19 K ^TMP($J,LIST) 20 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 21 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 22 I $G(PSSTSCH)]"",PSSTSCH'="O" S PSSTSCH="" 23 S SCR("S")="" I $G(PSSTSCH)]""!$G(PSSPP)]"" D SETSCR 24 I +$G(PSSIEN)>0 N PSSIEN2 S PSSIEN2=$$FIND1^DIC(51.1,"","A","`"_PSSIEN,"B",SCR("S"),"") D 25 .I +PSSIEN2'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 26 .S ^TMP($J,LIST,0)=1 27 .D GETS^DIQ(51.1,+PSSIEN2,".01;1;2;4;5;6;2.5;8;8.1","IE","PSS51P1") S PSS(1)=0 28 .F S PSS(1)=$O(PSS51P1(51.1,PSS(1))) Q:'PSS(1) D SETZRO^PSS51P1B 29 I +$G(PSSIEN)'>0,$G(PSSFT)]"" D 30 .I PSSFT["??" D LOOP^PSS51P1B(1) Q 31 .D FIND^DIC(51.1,,"@;.01;1","QP",PSSFT,,"B",SCR("S"),,"") 32 .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 33 .I +^TMP("DILIST",$J,0)>0 S ^TMP($J,LIST,0)=+^TMP("DILIST",$J,0) N PSSXX S PSSXX=0 F S PSSXX=$O(^TMP("DILIST",$J,PSSXX)) Q:'PSSXX D 34 ..S PSSIEN=+^TMP("DILIST",$J,PSSXX,0) K PSS51P1 D GETS^DIQ(51.1,+PSSIEN,".01;1;2;4;5;6;2.5;8;8.1","IE","PSS51P1") S PSS(1)=0 35 ..F S PSS(1)=$O(PSS51P1(51.1,PSS(1))) Q:'PSS(1) D SETZRO^PSS51P1B 36 K ^TMP("DILIST",$J) 37 Q 38 ; 39 WARD(PSSIEN,PSSFT,PSSIEN2,LIST) ; 40 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 41 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 42 ;PSSIEN2 - IEN of entry in WARD sub-file (#51.11) 43 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 44 ; Field Number of the data piece being returned. 45 ;Returns NAME field (#.01), WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 46 ;of ADMINISTRATION SCHEDULE file (#51.1). 47 N DIERR,ZZERR,PSS51P1,PSS,CNT 48 S CNT=0 49 I $G(LIST)']"" Q 50 K ^TMP($J,LIST) 51 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 52 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 53 I $G(PSSIEN2)]"",+$G(PSSIEN2)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 54 D WARD^PSS51P1C 55 Q 56 ; 57 HOSP(PSSIEN,PSSFT,LIST) ; 58 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 59 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 60 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 61 ; Field Number of the data piece being returned. 62 ;Returns NAME field (#.01), HOSPITAL LOCATION multiple (#51.17) HOSPITAL LOCATION field (#.01), ADMINISTRATION TIMES field (#1), 63 ;and SHIFTS field (#2) of ADMINISTRATION SCHEDULE file (#51.1). 64 N DIERR,ZZERR,PSS51P1,SCR,PSS,CNT 65 I $G(LIST)']"" Q 66 D HOSP^PSS51P1A 67 Q 68 ; 69 IEN(PSSFT,LIST) ; 70 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 71 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 72 ; Field Number of the data piece being returned. 73 ;Returns NAME field (#.01) and STANDARD ADMINISTRATION TIMES field (#1) of ADMINISTRATION SCHEDULE file (#51.1). 74 N DIERR,ZZERR,PSS51P1,SCR,PSS 75 I $G(LIST)']"" Q 76 K ^TMP($J,LIST) 77 I $G(PSSFT)']"" S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 78 D IEN^PSS51P1A 79 Q 80 ; 81 AP(PSSPP,PSSFT,PSSWDIEN,PSSTYP,LIST,PSSFREQ) ; 82 ;PSSPP - PACKAGE PREFIX in ADMINISTRATION SCHEDULE file (#51.1). 83 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 84 ;PSSWDIEN - IEN of entry of WARD multiple in ADMINISTRATION SCHEDULE file (#51.1). 85 ;PSSSTYP - TYPE OF SCHEDULE field (#5) in ADMINISTRATION SCHEDULE file (#51.1). 86 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 87 ; Field Number of the data piece being returned. 88 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), and PACKAGE PREFIX field (#4) 89 ;of ADMINISTRATION SCHEDULE file (#51.1). 90 ;If PSSWDIEN is passed in then the WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 91 ;of ADMINISTRATION SCHEDULE file (#51.1) is returned. 92 N DIERR,ZZERR,PSS51P1,SCR,PSS,PSSIEN,PSSVAL,PSSTMP 93 I $G(PSSFREQ)']"" S PSSFREQ="" 94 I $G(LIST)']"" Q 95 D AP^PSS51P1A 96 Q 97 ; 98 IX(PSSFT,PSSPP,LIST) ; 99 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 100 ;PSSPP - PACKAGE PREFIX in ADMINISTRATION SCHEDULE file (#51.1). 101 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 102 ; Field Number of the data piece being returned. 103 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 104 ;MAXIMUM DAYS FOR ORDERS field (#2.5),PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), STANDARD 105 ;SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), and OTHER LANGUAGE EXPANSION field (#8.1) of 106 ;ADMINISTRATION SCHEDULE file (#51.1). 107 N DIERR,ZZERR,PSS51P1,PSS 108 I $G(LIST)']"" Q 109 D IX^PSS51P1A 110 Q 111 ; 112 ADM(PSSADM) ; admin times 113 N X S X=PSSADM 114 I $S($L($P(X,"-"))>4:1,$L(X)>119:1,$L(X)<2:1,X'>0:1,1:X'?.ANP) K X Q "^" 115 S X(1)=$P(X,"-") I X(1)'?2N,X(1)'?4N K X Q "^" 116 S X(1)=$L(X(1)) F X(2)=2:1:$L(X,"-") S X(3)=$P(X,"-",X(2)) I $S($L(X(3))'=X(1):1,X(3)>$S(X(1)=2:24,1:2400):1,1:X(3)'>$P(X,"-",X(2)-1)) K X Q 117 I '$D(X) Q "^" 118 K:$D(X) X(1),X(2),X(3) Q PSSADM 119 ; 120 ALL(PSSIEN,PSSFT,LIST) ; 121 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 122 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 123 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 124 ; Field Number of the data piece being returned. 125 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 126 ;MAXIMUM DAYS FOR ORDERS field (#2.5), PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), 127 ;STANDARD SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), OTHER LANGUAGE EXPANSIONS field (#8.1), 128 ; HOSPITAL LOCATION multiple (#51.17) HOSPITAL LOCATION field (#.01), ADMINISTRATION TIMES field (#1), 129 ;SHIFTS field (#2), WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 130 ;of ADMINISTRATION SCHEDULE file (#51.1). 131 N DIERR,ZZERR,PSS 132 I $G(LIST)']"" Q 133 K ^TMP($J,LIST) 134 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 135 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 136 D ALL^PSS51P1C 137 Q 138 ; 139 SETSCR ;Set Screen for One-time schedule type 140 ;Naked reference below refers to ^PS(51.1,+Y,0) 141 I $G(PSSTSCH)]"" S SCR("S")="I $P(^(0),""^"",5)=""O""" 142 ;Naked reference below refers to ^PS(51.1,+Y,0) 143 I $G(PSSPP)]"" S SCR("S")=$S(SCR("S")]"":SCR("S")_" I $P(^(0),""^"",4)=PSSPP",1:"I $P(^(0),""^"",4)=PSSPP") 144 Q 145 FREQ(PSSVAL,PSSFREQ) ; VALIDATES FREQUNCY FIELD 146 S PSSTMP=0 147 I PSSVAL>PSSFREQ S PSSTMP=1 148 I PSSVAL<1 S PSSTMP=1 149 I PSSFREQ="" S PSSTMP=0 150 Q PSSTMP 151 PSSDQ ;DQ^DICQ call on 51.1 152 N DIC,D,DZ S DIC="^PS(51.1,",D="B",DIC(0)="EQS",DZ="??" D DQ^DICQ Q 153 ; 154 SCHED(PSSWIEN,PSSARRY) ; 155 I $G(PSSWIEN)="" S PSSWIEN=0 156 D SCHED^PSSSCHED(PSSWIEN,.PSSARRY) Q 1 PSS51P1 ;BIR/LDT - API FOR INFORMATION FROM FILE 51.1 ;5 Sep 03 2 ;;1.0;PHARMACY DATA MANAGEMENT;**85,91,108,118**;9/30/97;Build 8 3 ; 4 ZERO(PSSIEN,PSSFT,PSSPP,PSSTSCH,LIST) ; 5 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 6 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 7 ;PSSPP - PACKAGE PREFIX field (#4) in ADMINISTRATION SCHEDULE file (#51.1). Screens for Administration 8 ;Schedules for the Package Prefix passed. 9 ;PSSTSCH - TYPE OF SCHEDULE field (#5) of ADMINISTRATION SCHEDULE file (#51.1). Screens for 10 ; One-time "O" if PSSTSCH passed in. 11 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 12 ; Field Number of the data piece being returned. 13 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 14 ;MAXIMUM DAYS FOR ORDERS field (#2.5), PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), 15 ;STANDARD SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), and OTHER LANGUAGE EXPANSIONS field (#8.1) 16 ;of ADMINISTRATION SCHEDULE file (#51.1). 17 N DIERR,ZZERR,PSS51P1,SCR,PSS 18 I $G(LIST)']"" Q 19 K ^TMP($J,LIST) 20 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 21 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 22 I $G(PSSTSCH)]"",PSSTSCH'="O" S PSSTSCH="" 23 S SCR("S")="" I $G(PSSTSCH)]""!$G(PSSPP)]"" D SETSCR 24 I +$G(PSSIEN)>0 N PSSIEN2 S PSSIEN2=$$FIND1^DIC(51.1,"","A","`"_PSSIEN,"B",SCR("S"),"") D 25 .I +PSSIEN2'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 26 .S ^TMP($J,LIST,0)=1 27 .D GETS^DIQ(51.1,+PSSIEN2,".01;1;2;4;5;6;2.5;8;8.1","IE","PSS51P1") S PSS(1)=0 28 .F S PSS(1)=$O(PSS51P1(51.1,PSS(1))) Q:'PSS(1) D SETZRO^PSS51P1B 29 I +$G(PSSIEN)'>0,$G(PSSFT)]"" D 30 .I PSSFT["??" D LOOP^PSS51P1B(1) Q 31 .D FIND^DIC(51.1,,"@;.01;1","QP",PSSFT,,"B",SCR("S"),,"") 32 .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 33 .I +^TMP("DILIST",$J,0)>0 S ^TMP($J,LIST,0)=+^TMP("DILIST",$J,0) N PSSXX S PSSXX=0 F S PSSXX=$O(^TMP("DILIST",$J,PSSXX)) Q:'PSSXX D 34 ..S PSSIEN=+^TMP("DILIST",$J,PSSXX,0) K PSS51P1 D GETS^DIQ(51.1,+PSSIEN,".01;1;2;4;5;6;2.5;8;8.1","IE","PSS51P1") S PSS(1)=0 35 ..F S PSS(1)=$O(PSS51P1(51.1,PSS(1))) Q:'PSS(1) D SETZRO^PSS51P1B 36 K ^TMP("DILIST",$J) 37 Q 38 ; 39 WARD(PSSIEN,PSSFT,PSSIEN2,LIST) ; 40 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 41 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 42 ;PSSIEN2 - IEN of entry in WARD sub-file (#51.11) 43 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 44 ; Field Number of the data piece being returned. 45 ;Returns NAME field (#.01), WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 46 ;of ADMINISTRATION SCHEDULE file (#51.1). 47 N DIERR,ZZERR,PSS51P1,PSS,CNT 48 S CNT=0 49 I $G(LIST)']"" Q 50 K ^TMP($J,LIST) 51 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 52 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 53 I $G(PSSIEN2)]"",+$G(PSSIEN2)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 54 D WARD^PSS51P1C 55 Q 56 ; 57 HOSP(PSSIEN,PSSFT,LIST) ; 58 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 59 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 60 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 61 ; Field Number of the data piece being returned. 62 ;Returns NAME field (#.01), HOSPITAL LOCATION multiple (#51.17) HOSPITAL LOCATION field (#.01), ADMINISTRATION TIMES field (#1), 63 ;and SHIFTS field (#2) of ADMINISTRATION SCHEDULE file (#51.1). 64 N DIERR,ZZERR,PSS51P1,SCR,PSS,CNT 65 I $G(LIST)']"" Q 66 D HOSP^PSS51P1A 67 Q 68 ; 69 IEN(PSSFT,LIST) ; 70 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 71 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 72 ; Field Number of the data piece being returned. 73 ;Returns NAME field (#.01) and STANDARD ADMINISTRATION TIMES field (#1) of ADMINISTRATION SCHEDULE file (#51.1). 74 N DIERR,ZZERR,PSS51P1,SCR,PSS 75 I $G(LIST)']"" Q 76 K ^TMP($J,LIST) 77 I $G(PSSFT)']"" S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 78 D IEN^PSS51P1A 79 Q 80 ; 81 AP(PSSPP,PSSFT,PSSWDIEN,PSSTYP,LIST,PSSFREQ) ; 82 ;PSSPP - PACKAGE PREFIX in ADMINISTRATION SCHEDULE file (#51.1). 83 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 84 ;PSSWDIEN - IEN of entry of WARD multiple in ADMINISTRATION SCHEDULE file (#51.1). 85 ;PSSSTYP - TYPE OF SCHEDULE field (#5) in ADMINISTRATION SCHEDULE file (#51.1). 86 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 87 ; Field Number of the data piece being returned. 88 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), and PACKAGE PREFIX field (#4) 89 ;of ADMINISTRATION SCHEDULE file (#51.1). 90 ;If PSSWDIEN is passed in then the WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 91 ;of ADMINISTRATION SCHEDULE file (#51.1) is returned. 92 N DIERR,ZZERR,PSS51P1,SCR,PSS,PSSIEN,PSSVAL,PSSTMP 93 I $G(PSSFREQ)']"" S PSSFREQ="" 94 I $G(LIST)']"" Q 95 D AP^PSS51P1A 96 Q 97 ; 98 IX(PSSFT,PSSPP,LIST) ; 99 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 100 ;PSSPP - PACKAGE PREFIX in ADMINISTRATION SCHEDULE file (#51.1). 101 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 102 ; Field Number of the data piece being returned. 103 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 104 ;MAXIMUM DAYS FOR ORDERS field (#2.5),PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), STANDARD 105 ;SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), and OTHER LANGUAGE EXPANSION field (#8.1) of 106 ;ADMINISTRATION SCHEDULE file (#51.1). 107 N DIERR,ZZERR,PSS51P1,PSS 108 I $G(LIST)']"" Q 109 D IX^PSS51P1A 110 Q 111 ; 112 ADM(PSSADM) ; admin times 113 N X S X=PSSADM 114 I $S($L($P(X,"-"))>4:1,$L(X)>119:1,$L(X)<2:1,X'>0:1,1:X'?.ANP) K X Q "^" 115 S X(1)=$P(X,"-") I X(1)'?2N,X(1)'?4N K X Q "^" 116 S X(1)=$L(X(1)) F X(2)=2:1:$L(X,"-") S X(3)=$P(X,"-",X(2)) I $S($L(X(3))'=X(1):1,X(3)>$S(X(1)=2:24,1:2400):1,1:X(3)'>$P(X,"-",X(2)-1)) K X Q 117 I '$D(X) Q "^" 118 K:$D(X) X(1),X(2),X(3) Q PSSADM 119 ; 120 ALL(PSSIEN,PSSFT,LIST) ; 121 ;PSSIEN - IEN of entry in ADMINISTRATION SCHEDULE file (#51.1). 122 ;PSSFT - Free Text name in ADMINISTRATION SCHEDULE file (#51.1). 123 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the 124 ; Field Number of the data piece being returned. 125 ;Returns NAME field (#.01), STANDARD ADMINISTRATION TIMES field (#1), FREQUENCY (IN MINUTES) field (#2), 126 ;MAXIMUM DAYS FOR ORDERS field (#2.5), PACKAGE PREFIX field (#4), TYPE OF SCHEDULE field (#5), 127 ;STANDARD SHIFTS field (#6), OUTPATIENT EXPANSION field (#8), OTHER LANGUAGE EXPANSIONS field (#8.1), 128 ; HOSPITAL LOCATION multiple (#51.17) HOSPITAL LOCATION field (#.01), ADMINISTRATION TIMES field (#1), 129 ;SHIFTS field (#2), WARD multiple (#51.11) WARD field (#.01), and WARD ADMINISTRATION TIMES field (#1) 130 ;of ADMINISTRATION SCHEDULE file (#51.1). 131 N DIERR,ZZERR,PSS 132 I $G(LIST)']"" Q 133 K ^TMP($J,LIST) 134 I +$G(PSSIEN)'>0,($G(PSSFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 135 I $G(PSSIEN)]"",+$G(PSSIEN)'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q 136 D ALL^PSS51P1C 137 Q 138 ; 139 SETSCR ;Set Screen for One-time schedule type 140 ;Naked reference below refers to ^PS(51.1,+Y,0) 141 I $G(PSSTSCH)]"" S SCR("S")="I $P(^(0),""^"",5)=""O""" 142 ;Naked reference below refers to ^PS(51.1,+Y,0) 143 I $G(PSSPP)]"" S SCR("S")=$S(SCR("S")]"":SCR("S")_" I $P(^(0),""^"",4)=PSSPP",1:"I $P(^(0),""^"",4)=PSSPP") 144 Q 145 FREQ(PSSVAL,PSSFREQ) ; VALIDATES FREQUNCY FIELD 146 S PSSTMP=0 147 I PSSVAL>PSSFREQ S PSSTMP=1 148 I PSSVAL<1 S PSSTMP=1 149 I PSSFREQ="" S PSSTMP=0 150 Q PSSTMP 151 PSSDQ ;DQ^DICQ call on 51.1 152 N DIC,D,DZ S DIC="^PS(51.1,",D="B",DIC(0)="EQS",DZ="??" D DQ^DICQ Q
Note:
See TracChangeset
for help on using the changeset viewer.