Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSS50D

PSS50D.m

Go to the documentation of this file.
  1. PSS50D ;BIR/LDT - API FOR INFORMATION FROM FILE 50; 5 Sep 03
  1. ;;1.0;PHARMACY DATA MANAGEMENT;**85,105**;9/30/97
  1. ;
  1. B ;
  1. ;PSSFT - Free Text name in 50
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;PSSRTOI - Orderable Item - return only entries matched to a Pharmacy Orderable Item
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. N DIERR,ZZERR,PSSP50,SCR,PSSIEN
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I $G(PSSFT)']"" S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S SCR("S")=""
  1. I +$G(PSSFL)>0!($G(PSSPK)]"")!($G(PSSRTOI)=1) N PSS5ND,PSSZ3,PSSZ4 D SETSCRN^PSS50A
  1. I $G(PSSFT)]"" D
  1. .I PSSFT["??" D LOOPB^PSS50C1 Q
  1. .K ^TMP("DILIST",$J)
  1. .D FIND^DIC(50,,"@;.01","QP",PSSFT,,"B",SCR("S"),,"")
  1. .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. .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
  1. ..S PSSIEN=+$G(^TMP("DILIST",$J,PSSXX,0)) I PSSIEN,$P($G(^TMP("DILIST",$J,PSSXX,0)),"^",2)'="" D
  1. ...S ^TMP($J,LIST,PSSIEN,.01)=$P(^TMP("DILIST",$J,PSSXX,0),"^",2)
  1. ...S ^TMP($J,LIST,"B",$P(^TMP("DILIST",$J,PSSXX,0),"^",2),PSSIEN)=""
  1. K ^TMP("DILIST",$J)
  1. Q
  1. ;
  1. VAC ;
  1. ;PSSVAL - NATIONAL DRUG CLASS field (#25) of the DRUG file (#50)
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. N DIERR,ZZERR,PSSP50,SCR,PSSIEN
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I ($G(PSSVAL)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S SCR("S")="I $P($G(^PSDRUG(+Y,""ND"")),""^"",6)=PSSVAL"
  1. I +$G(PSSFL)>0!($G(PSSPK)]"") N PSS5ND,PSSZ3,PSSZ4 D SETSCRN^PSS50C1
  1. I $G(PSSVAL)]"" D
  1. .K ^TMP("DILIST",$J)
  1. .D FIND^DIC(50,,"@;.01","QP",PSSVAL,,"VAC",SCR("S"),,"")
  1. .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. .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
  1. ..S PSSIEN=+$G(^TMP("DILIST",$J,PSSXX,0)) I PSSIEN,$P($G(^TMP("DILIST",$J,PSSXX,0)),"^",2)'="" D
  1. ...S ^TMP($J,LIST,PSSIEN,.01)=$P(^TMP("DILIST",$J,PSSXX,0),"^",2)
  1. ...S ^TMP($J,LIST,"VAC",$P(^TMP("DILIST",$J,PSSXX,0),"^",2),PSSIEN)=""
  1. K ^TMP("DILIST",$J)
  1. Q
  1. ;
  1. NDC ;
  1. ;PSSVAL - NDC field (#31) of the DRUG file (#50)
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. ;
  1. ; Must change to look directly at the NDC cross reference
  1. N PSSNDC,PSSNDC1,PSSNDC2
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I ($G(PSSVAL)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S PSSNDC=0 F PSSNDC1=0:0 S PSSNDC1=$O(^PSDRUG("NDC",PSSVAL,PSSNDC1)) Q:'PSSNDC1 D
  1. .S PSSNDC2=$P($G(^PSDRUG(PSSNDC1,0)),"^")
  1. .I PSSNDC2="" Q
  1. .I $G(PSSFL),$P($G(^PSDRUG(PSSNDC1,"I")),"^"),$P($G(^("I")),"^")'>PSSFL Q
  1. .;Naked reference below refers to ^PSDRUG(PSSNDC1,"I"), or ^PSDRUG(PSSNDC1,0)
  1. .I $G(PSSPK)]"" N PSSZ5,PSSZ6 S PSSZ5=0 F PSSZ6=1:1:$L(PSSPK) Q:PSSZ5 I $P($G(^(2)),"^",3)[$E(PSSPK,PSSZ6) S PSSZ5=1
  1. .I $G(PSSPK)]"",'PSSZ5 Q
  1. .S ^TMP($J,LIST,PSSNDC1,.01)=PSSNDC2
  1. .S ^TMP($J,LIST,"NDC",PSSNDC2,PSSNDC1)=""
  1. .S PSSNDC=PSSNDC+1
  1. S ^TMP($J,LIST,0)=$S($G(PSSNDC):$G(PSSNDC),1:"-1^NO DATA FOUND")
  1. Q
  1. ;
  1. ASP ;
  1. ;PSSVAL - PHARMACY ORDERABLE ITEM field (#2.1) of the DRUG file (#50)
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. N DIERR,ZZERR,PSSP50,SCR,PSSIEN
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I ($G(PSSVAL)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S SCR("S")=""
  1. I +$G(PSSFL)>0!($G(PSSPK)]"") N PSS5ND,PSSZ3,PSSZ4 D SETSCRN^PSS50A
  1. S SCR("S")=SCR("S")_" I +$G(^PSDRUG(+Y,2))=PSSVAL"
  1. I $G(PSSVAL)]"" D
  1. .D FIND^DIC(50,,"@;.01","QP",PSSVAL,,"ASP",SCR("S"),,"")
  1. .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. .I +^TMP("DILIST",$J,0)>0 S ^TMP($J,LIST,0)=+^TMP("DILIST",$J,0) N XX S XX=0 F S XX=$O(^TMP("DILIST",$J,XX)) Q:'XX D
  1. ..S PSSIEN=+^TMP("DILIST",$J,XX,0),^TMP($J,LIST,PSSIEN,.01)=$P(^TMP("DILIST",$J,XX,0),"^",2)
  1. ..S ^TMP($J,LIST,"ASP",$P(^TMP("DILIST",$J,XX,0),"^",2),PSSIEN)=""
  1. K ^TMP("DILIST",$J)
  1. Q
  1. ;
  1. AND ;
  1. ;PSSVAL -NATIONAL DRUG FILE ENTRY field (#20) of the DRUG file (#50)
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. N DIERR,ZZERR,PSSP50,SCR,PSSIEN,CNT
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I ($G(PSSVAL)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S SCR("S")=""
  1. I +$G(PSSFL)>0!($G(PSSPK)]"") N PSS5ND,PSSZ3,PSSZ4 D SETSCRN^PSS50A
  1. I $G(PSSVAL)]"" D
  1. .S CNT=0
  1. .D FIND^DIC(50,,"@;.01","QP",PSSVAL,,"AND",SCR("S"),,"")
  1. .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. .I +^TMP("DILIST",$J,0)>0 N PSSXX S PSSXX=0 F S PSSXX=$O(^TMP("DILIST",$J,PSSXX)) Q:'PSSXX D
  1. ..S PSSIEN=+^TMP("DILIST",$J,PSSXX,0) K PSS50 D GETS^DIQ(50,+PSSIEN,".01;20","IE","PSS50") S PSS(1)=0
  1. ..F S PSS(1)=$O(PSS50(50,PSS(1))) Q:'PSS(1) D
  1. ...Q:PSS50(50,PSS(1),20,"I")'=PSSVAL
  1. ...S ^TMP($J,LIST,PSSIEN,.01)=$G(PSS50(50,PSS(1),.01,"E")),CNT=CNT+1
  1. ...S ^TMP($J,LIST,"AND",$G(PSS50(50,PSS(1),.01,"E")),PSSIEN)=""
  1. ..S ^TMP($J,LIST,0)=$S(CNT>0:CNT,1:"-1^NO DATA FOUND")
  1. K ^TMP("DILIST",$J),PSS50
  1. Q
  1. ;
  1. AP ;
  1. ;PSSVAL - PRIMARY DRUG field (#64) of the DRUG file (#50)
  1. ;PSSFL - Inactive flag - "" - All entries
  1. ; FileMan Date - Only entries with no Inactive Date or an Inactive Date greater than this date.
  1. ;PSSPK - Application Package's Use - "" - All entries
  1. ; Alphabetic codes that represent the DHCP packages that consider this drug to be
  1. ; part of their formulary.
  1. ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the Field Number of the data
  1. ; piece being returned.
  1. ;Returns list of drugs meeting input criteria
  1. N DIERR,ZZERR,PSSP50,SCR,PSSIEN
  1. I $G(LIST)']"" Q
  1. K ^TMP($J,LIST)
  1. I ($G(PSSVAL)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. S SCR("S")=""
  1. I +$G(PSSFL)>0!($G(PSSPK)]"") N PSS5ND,PSSZ3,PSSZ4 D SETSCRN^PSS50A
  1. S SCR("S")=SCR("S")_" I +$P($G(^PSDRUG(+Y,2)),""^"",6)=PSSVAL"
  1. I $G(PSSVAL)]"" D
  1. .D FIND^DIC(50,,"@;.01","QP",PSSVAL,,"AP",SCR("S"),,"")
  1. .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
  1. .I +^TMP("DILIST",$J,0)>0 S ^TMP($J,LIST,0)=+^TMP("DILIST",$J,0) N XX S XX=0 F S XX=$O(^TMP("DILIST",$J,XX)) Q:'XX D
  1. ..S PSSIEN=+^TMP("DILIST",$J,XX,0),^TMP($J,LIST,PSSIEN,.01)=$P(^TMP("DILIST",$J,XX,0),"^",2)
  1. ..S ^TMP($J,LIST,"AP",$P(^TMP("DILIST",$J,XX,0),"^",2),PSSIEN)=""
  1. K ^TMP("DILIST",$J)
  1. Q