- PSN50P6 ;BIR/LDT - API FOR INFORMATION FROM FILE 50.6; 5 Sep 03
- ;;4.0; NATIONAL DRUG FILE;**80**; 30 Oct 98
- ;
- ZERO(PSNIEN,PSNFT,PSNFL,PSNX,LIST) ;
- ;PSNIEN - IEN of entry in VA GENERIC file (#50.6).
- ;PSNFT - Free Text name in VA GENERIC file (#50.6).
- ;PSNFL - Inactive flag - "" - All entries
- ; FileMan Date - Only entries with no Inactive Date or an Inactive Date
- ; greater than this date.
- ;PSNX - exact match flag 1 - exact match wanted
- ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the
- ; Field Number of the data piece being returned.
- ;Returns NAME field (#.01), and INACTIVE DATE field (#1) of VA GENERIC file (#50.6).
- N DIERR,ZZERR,PSNP50P6,SCR,PSN
- I $G(LIST)']"" Q
- K ^TMP($J,LIST)
- I $G(PSNIEN)']"",($G(PSNFT)']"") S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
- I $G(PSNIEN)]"",(+$G(PSNIEN)'>0) S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
- S SCR("S")=""
- I +$G(PSNFL)>0 N ND D SETSCRN
- I $G(PSNIEN)]"" N PSNIEN2 S PSNIEN2=$$FIND1^DIC(50.6,"","A","`"_PSNIEN,,SCR("S"),"") D
- .I +PSNIEN2'>0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
- .S ^TMP($J,LIST,0)=1
- .D GETS^DIQ(50.6,+PSNIEN2,".01;1","IE","PSNP50P6") S PSN(1)=0
- .F S PSN(1)=$O(PSNP50P6(50.6,PSN(1))) Q:'PSN(1) D SETALL
- I $G(PSNIEN)="",$G(PSNFT)]"" D
- .I PSNFT["??" D LOOP Q
- .D FIND^DIC(50.6,,"@;.01;","QP"_$S($G(PSNX)=1:"X",1:""),PSNFT,,"B",SCR("S"),,"")
- .I +$G(^TMP("DILIST",$J,0))=0 S ^TMP($J,LIST,0)=-1_"^"_"NO DATA FOUND" Q
- .I +^TMP("DILIST",$J,0)>0 S ^TMP($J,LIST,0)=+^TMP("DILIST",$J,0) N PSNXX S PSNXX=0 F S PSNXX=$O(^TMP("DILIST",$J,PSNXX)) Q:'PSNXX D
- ..S PSNIEN=+^TMP("DILIST",$J,PSNXX,0) K PSNP50P6 D GETS^DIQ(50.6,+PSNIEN,".01;1","IE","PSNP50P6") S PSN(1)=0
- ..F S PSN(1)=$O(PSNP50P6(50.6,PSN(1))) Q:'PSN(1) D SETALL
- K ^TMP("DILIST",$J)
- Q
- ;
- ROOT() ;
- ;get version dependent NDF reference
- I $$VERSION^XPDUTL("PSN")<4 Q "^PSNDF("
- Q "^PSNDF(50.6," ; new reference for ver 4.0
- ;
- SETALL ;
- S ^TMP($J,LIST,+PSN(1),.01)=$G(PSNP50P6(50.6,PSN(1),.01,"I"))
- S ^TMP($J,LIST,"B",$G(PSNP50P6(50.6,PSN(1),.01,"I")),+PSN(1))=""
- S ^TMP($J,LIST,+PSN(1),1)=$S($G(PSNP50P6(50.6,PSN(1),1,"I"))="":"",1:PSNP50P6(50.6,PSN(1),1,"I")_"^"_PSNP50P6(50.6,PSN(1),1,"E"))
- Q
- ;
- SETSCRN ;Set Screen for inactive VA Generic
- ;Naked reference below refers to ^PS(50.6,+Y,0)
- S SCR("S")="S ND=$P($G(^(0)),U,2) I ND=""""!(ND>PSNFL)"
- Q
- ;
- LOOP ;
- N PSNIEN,CNT S CNT=0
- S PSNIEN=0 F S PSNIEN=$O(^PSNDF(50.6,PSNIEN)) Q:'PSNIEN D
- .I $G(PSNFL),$P($G(^PSNDF(50.6,PSNIEN,0)),"^",2),$P($G(^(0)),"^",2)'>PSNFL Q
- .K PSNP50P6 D GETS^DIQ(50.6,+PSNIEN,".01;1","IE","PSNP50P6") S PSN(1)=0 D
- ..F S PSN(1)=$O(PSNP50P6(50.6,PSN(1))) Q:'PSN(1) D SETALL S CNT=CNT+1
- S ^TMP($J,LIST,0)=+CNT
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSN50P6 2832 printed Feb 18, 2025@23:48:46 Page 2
- PSN50P6 ;BIR/LDT - API FOR INFORMATION FROM FILE 50.6; 5 Sep 03
- +1 ;;4.0; NATIONAL DRUG FILE;**80**; 30 Oct 98
- +2 ;
- ZERO(PSNIEN,PSNFT,PSNFL,PSNX,LIST) ;
- +1 ;PSNIEN - IEN of entry in VA GENERIC file (#50.6).
- +2 ;PSNFT - Free Text name in VA GENERIC file (#50.6).
- +3 ;PSNFL - Inactive flag - "" - All entries
- +4 ; FileMan Date - Only entries with no Inactive Date or an Inactive Date
- +5 ; greater than this date.
- +6 ;PSNX - exact match flag 1 - exact match wanted
- +7 ;LIST - Subscript of ^TMP array in the form ^TMP($J,LIST,Field Number where Field Number is the
- +8 ; Field Number of the data piece being returned.
- +9 ;Returns NAME field (#.01), and INACTIVE DATE field (#1) of VA GENERIC file (#50.6).
- +10 NEW DIERR,ZZERR,PSNP50P6,SCR,PSN
- +11 IF $GET(LIST)']""
- QUIT
- +12 KILL ^TMP($JOB,LIST)
- +13 IF $GET(PSNIEN)']""
- IF ($GET(PSNFT)']"")
- SET ^TMP($JOB,LIST,0)=-1_"^"_"NO DATA FOUND"
- QUIT
- +14 IF $GET(PSNIEN)]""
- IF (+$GET(PSNIEN)'>0)
- SET ^TMP($JOB,LIST,0)=-1_"^"_"NO DATA FOUND"
- QUIT
- +15 SET SCR("S")=""
- +16 IF +$GET(PSNFL)>0
- NEW ND
- DO SETSCRN
- +17 IF $GET(PSNIEN)]""
- NEW PSNIEN2
- SET PSNIEN2=$$FIND1^DIC(50.6,"","A","`"_PSNIEN,,SCR("S"),"")
- Begin DoDot:1
- +18 IF +PSNIEN2'>0
- SET ^TMP($JOB,LIST,0)=-1_"^"_"NO DATA FOUND"
- QUIT
- +19 SET ^TMP($JOB,LIST,0)=1
- +20 DO GETS^DIQ(50.6,+PSNIEN2,".01;1","IE","PSNP50P6")
- SET PSN(1)=0
- +21 FOR
- SET PSN(1)=$ORDER(PSNP50P6(50.6,PSN(1)))
- if 'PSN(1)
- QUIT
- DO SETALL
- End DoDot:1
- +22 IF $GET(PSNIEN)=""
- IF $GET(PSNFT)]""
- Begin DoDot:1
- +23 IF PSNFT["??"
- DO LOOP
- QUIT
- +24 DO FIND^DIC(50.6,,"@;.01;","QP"_$SELECT($GET(PSNX)=1:"X",1:""),PSNFT,,"B",SCR("S"),,"")
- +25 IF +$GET(^TMP("DILIST",$JOB,0))=0
- SET ^TMP($JOB,LIST,0)=-1_"^"_"NO DATA FOUND"
- QUIT
- +26 IF +^TMP("DILIST",$JOB,0)>0
- SET ^TMP($JOB,LIST,0)=+^TMP("DILIST",$JOB,0)
- NEW PSNXX
- SET PSNXX=0
- FOR
- SET PSNXX=$ORDER(^TMP("DILIST",$JOB,PSNXX))
- if 'PSNXX
- QUIT
- Begin DoDot:2
- +27 SET PSNIEN=+^TMP("DILIST",$JOB,PSNXX,0)
- KILL PSNP50P6
- DO GETS^DIQ(50.6,+PSNIEN,".01;1","IE","PSNP50P6")
- SET PSN(1)=0
- +28 FOR
- SET PSN(1)=$ORDER(PSNP50P6(50.6,PSN(1)))
- if 'PSN(1)
- QUIT
- DO SETALL
- End DoDot:2
- End DoDot:1
- +29 KILL ^TMP("DILIST",$JOB)
- +30 QUIT
- +31 ;
- ROOT() ;
- +1 ;get version dependent NDF reference
- +2 IF $$VERSION^XPDUTL("PSN")<4
- QUIT "^PSNDF("
- +3 ; new reference for ver 4.0
- QUIT "^PSNDF(50.6,"
- +4 ;
- SETALL ;
- +1 SET ^TMP($JOB,LIST,+PSN(1),.01)=$GET(PSNP50P6(50.6,PSN(1),.01,"I"))
- +2 SET ^TMP($JOB,LIST,"B",$GET(PSNP50P6(50.6,PSN(1),.01,"I")),+PSN(1))=""
- +3 SET ^TMP($JOB,LIST,+PSN(1),1)=$SELECT($GET(PSNP50P6(50.6,PSN(1),1,"I"))="":"",1:PSNP50P6(50.6,PSN(1),1,"I")_"^"_PSNP50P6(50.6,PSN(1),1,"E"))
- +4 QUIT
- +5 ;
- SETSCRN ;Set Screen for inactive VA Generic
- +1 ;Naked reference below refers to ^PS(50.6,+Y,0)
- +2 SET SCR("S")="S ND=$P($G(^(0)),U,2) I ND=""""!(ND>PSNFL)"
- +3 QUIT
- +4 ;
- LOOP ;
- +1 NEW PSNIEN,CNT
- SET CNT=0
- +2 SET PSNIEN=0
- FOR
- SET PSNIEN=$ORDER(^PSNDF(50.6,PSNIEN))
- if 'PSNIEN
- QUIT
- Begin DoDot:1
- +3 IF $GET(PSNFL)
- IF $PIECE($GET(^PSNDF(50.6,PSNIEN,0)),"^",2)
- IF $PIECE($GET(^(0)),"^",2)'>PSNFL
- QUIT
- +4 KILL PSNP50P6
- DO GETS^DIQ(50.6,+PSNIEN,".01;1","IE","PSNP50P6")
- SET PSN(1)=0
- Begin DoDot:2
- +5 FOR
- SET PSN(1)=$ORDER(PSNP50P6(50.6,PSN(1)))
- if 'PSN(1)
- QUIT
- DO SETALL
- SET CNT=CNT+1
- End DoDot:2
- End DoDot:1
- +6 SET ^TMP($JOB,LIST,0)=+CNT
- +7 QUIT