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

BGP8GM.m

Go to the documentation of this file.
  1. BGP8GM ; IHS/CMI/LAB - BGPG Visual CRS Reports ;
  1. ;;18.1;IHS CLINICAL REPORTING;;MAY 25, 2018;Build 66
  1. MUEP(RETVAL,BGPSTR) ;sel measures by comm
  1. S X="MERR^BGP8GU",@^%ZOSF("TRAP")
  1. N BGPI,BGPJ,BGPDATA,BGPDA,P,BGPERR,BGPCT,BGPOT,BGPOPT,BGPRT,P,R,A
  1. N BGPTP,BGPQTR,BGPRDT,BGPRE,BGPBAS,BGPPATT,BGPLIST,BGPPRV,BGPPROV,BGPIND,BGPINDI,BGPLSTI
  1. S P="|",R="~",A="*"
  1. I $G(BGPSTR)="" D CATSTR(.BGPSTR,.BGPSTR)
  1. S BGPI=0
  1. S BGPERR=""
  1. S BGPCT=$P($P(BGPSTR,P),R) ;THIS WILL BE NULL AS WE DON'T NEED COMMUNITY TAXONOMY
  1. S BGPTP=$E($P(BGPSTR,P,2)) ;Will be A, C, M, S for indicators selected
  1. S BGPQTR=$P(BGPSTR,P,3) ; will be 1 for 90 days, 2 for one year (see BGPMUEP)
  1. S BGPRDT=$P(BGPSTR,P,4) ;time to run the report
  1. S BGPRE=$P(BGPSTR,P,5) ;beginning date for report user entered e.g. 3110901
  1. S BGPOPT="CRS 18 EP MU REPORT"
  1. S BGPBAS=$P(BGPSTR,P,6) ;BASE LINE YEAR IN 3000000 FORMAT (YEAR ONLY)
  1. S BGPBEB=$P(BGPSTR,P,7) ;beneficiary
  1. S BGPLSTT=$P(BGPSTR,P,8) ; TYPE OF LIST: D Pts. Not in numerator N Pts in numerator A All Patients - THIS IS DIFFERENT THAN OUR REPORTS
  1. S BGPPRV=$P($P(BGPSTR,P,9),R) ;provider name they are running the report for
  1. S BGPPROV=$P($P(BGPSTR,P,9),R,2) ;provider ien they are running the report for
  1. I $G(BGPPROV)="" S BGPPROV=$P($G(^VA(200,BGPPRV,0)),U)
  1. S BGPOT=$P(BGPSTR,P,10) ;output type D, P, B, X -NOTE: X IS XML - not sure how you will deal with this
  1. S BGPFN=$P(BGPSTR,P,14) ;FILENAME
  1. S BGPINDI=$P(BGPSTR,P,12) ;string with indicators from BGPMU 11 MEASURES
  1. S BGPMFITI=$P(BGPSTR,P,13) ;will be null, we don't need MFI stuff
  1. S BGPLSTI=$P(BGPSTR,P,11) ;list of measures from BGPMU 11 MEASURES.
  1. ;NOTE: BGPINDI IS only necessary if M or S is selected
  1. N I
  1. F I=2:1 D Q:$P(BGPLSTI,A,I)=""
  1. . Q:$P(BGPLSTI,A,I)=""
  1. . N BGPL
  1. . S BGPL=$P($P(BGPLSTI,A,I),R)
  1. . Q:'$G(BGPL)
  1. . S BGPLIST(BGPL)=""
  1. N J
  1. F J=2:1 D Q:$P(BGPINDI,A,J)=""
  1. . Q:$P(BGPINDI,A,J)=""
  1. . N BGPL
  1. . S BGPL=$P($P(BGPINDI,A,J),R)
  1. . S BGPIND(BGPL)=""
  1. K ^BGPTMP($J)
  1. S RETVAL="^BGPTMP("_$J_")"
  1. S ^BGPTMP($J,BGPI)="T00250DATA"_$C(30)
  1. D EP^BGP8GMUE(.BGPERR,DUZ,DUZ(2),BGPOPT,BGPCT,BGPTP,.BGPIND,BGPQTR,BGPRE,BGPBAS,$G(BGPBEB),BGPLSTT,.BGPLIST,BGPPRV,BGPPROV,$G(BGPOT),BGPRDT,BGPMFITI,BGPFN)
  1. S BGPI=BGPI+1
  1. S ^BGPTMP($J,BGPI)=+$G(BGPERR)_$C(30)
  1. S ^BGPTMP($J,BGPI+1)=$C(31)
  1. D EN^XBVK("BGP")
  1. Q
  1. ;
  1. MUHOS(RETVAL,BGPSTR) ;sel measures by comm
  1. S X="MERR^BGP8GU",@^%ZOSF("TRAP")
  1. N BGPI,BGPJ,BGPDATA,BGPDA,P,BGPERR,BGPCT,BGPOT,BGPOPT,BGPRT,P,R,A
  1. N BGPTP,BGPQTR,BGPRDT,BGPRE,BGPBAS,BGPPATT,BGPLIST,BGPPRV,BGPPROV,BGPIND,BGPINDI,BGPLSTI
  1. S P="|",R="~",A="*"
  1. I $G(BGPSTR)="" D CATSTR(.BGPSTR,.BGPSTR)
  1. S BGPI=0
  1. S BGPERR=""
  1. S BGPCT=$P($P(BGPSTR,P),R) ;THIS WILL BE NULL AS WE DON'T NEED COMMUNITY TAXONOMY
  1. S BGPTP=$E($P(BGPSTR,P,2)) ;Will be A, C, M, S for indicators selected
  1. S BGPQTR=$P(BGPSTR,P,3) ; will be 1 for 90 days, 2 for one year (see BGPMUEP)
  1. S BGPRDT=$P(BGPSTR,P,4) ;time to run the report
  1. S BGPRE=$P(BGPSTR,P,5) ;beginning date for report user entered e.g. 3110901
  1. S BGPOPT="CRS 18 HOS MU REPORT"
  1. S BGPBAS=$P(BGPSTR,P,6) ;BASE LINE YEAR IN 3000000 FORMAT (YEAR ONLY)
  1. S BGPBEB=$P(BGPSTR,P,7) ;beneficiary
  1. S BGPLSTT=$P(BGPSTR,P,8) ; TYPE OF LIST: D Pts. Not in numerator N Pts in numerator A All Patients - THIS IS DIFFERENT THAN OUR REPORTS
  1. S BGPPRV=$P($P(BGPSTR,P,9),R) ;provider name they are running the report for
  1. S BGPPROV=$P($P(BGPSTR,P,9),R,2) ;provider ien they are running the report for
  1. S BGPOT=$P(BGPSTR,P,10) ;output type D, P, B, X -NOTE: X IS XML - not sure how you will deal with this
  1. S BGPFN=$P(BGPSTR,P,14) ;FILENAME
  1. S BGPINDI=$P(BGPSTR,P,12) ;string with indicators from BGPMU 11 MEASURES
  1. S BGPMFITI=$P(BGPSTR,P,13) ;will be null, we don't need MFI stuff
  1. S BGPLSTI=$P(BGPSTR,P,11) ;list of measures from BGPMU 11 MEASURES.
  1. ;NOTE: BGPINDI IS only necessary if M or S is selected
  1. N I
  1. F I=2:1 D Q:$P(BGPLSTI,A,I)=""
  1. . Q:$P(BGPLSTI,A,I)=""
  1. . N BGPL
  1. . S BGPL=$P($P(BGPLSTI,A,I),R)
  1. . Q:'$G(BGPL)
  1. . S BGPLIST(BGPL)=""
  1. N J
  1. F J=2:1 D Q:$P(BGPINDI,A,J)=""
  1. . Q:$P(BGPINDI,A,J)=""
  1. . N BGPL
  1. . S BGPL=$P($P(BGPINDI,A,J),R)
  1. . S BGPIND(BGPL)=""
  1. K ^BGPTMP($J)
  1. S RETVAL="^BGPTMP("_$J_")"
  1. S ^BGPTMP($J,BGPI)="T00250DATA"_$C(30)
  1. D EP^BGP8GMUH(.BGPERR,DUZ,DUZ(2),BGPOPT,BGPCT,BGPTP,.BGPIND,BGPQTR,BGPRE,BGPBAS,$G(BGPBEB),BGPLSTT,.BGPLIST,BGPPRV,BGPPROV,$G(BGPOT),BGPRDT,BGPMFITI,BGPFN)
  1. S BGPI=BGPI+1
  1. S ^BGPTMP($J,BGPI)=+$G(BGPERR)_$C(30)
  1. S ^BGPTMP($J,BGPI+1)=$C(31)
  1. D EN^XBVK("BGP")
  1. Q
  1. ;
  1. CATSTR(BGPSRET,STR) ;EP
  1. N BGPDA
  1. S BGPSRET=""
  1. S BGPDA=0 F S BGPDA=$O(STR(BGPDA)) Q:'BGPDA D
  1. . S BGPSRET=BGPSRET_$G(STR(BGPDA))
  1. Q
  1. ;