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

BSDX27.m

Go to the documentation of this file.
BSDX27 ; IHS/OIT/HMW/MSC/SAT - WINDOWS SCHEDULING RPCS ;
 ;;3.0;IHS WINDOWS SCHEDULING;;DEC 09, 2010
 ;
 ;
 Q
 ;
PADISPD(BSDXY,BSDXPAT) ;EP
 ;Entry point for debugging
 ;
 ;D DEBUG^%Serenji("PADISP^BSDX27(.BSDXY,BSDXPAT)")
 Q
 ;
PADISP(BSDXY,BSDXPAT) ;EP
 ;Return recordset of patient appointments used in listing
 ;a patient's appointments and generating patient letters.
 ;Called by rpc BSDX PATIENT APPT DISPLAY
 ;
 N BSDXI,BSDXIEN,BSDXNOD,BSDXNAM,BSDXDOB,BSDXHRN,BSDXSEX,BSDXCNID,BSDXCNOD,BSDXMADE,BSDXCLRK,BSDXNOT,BSDXQ
 N BSDXSTRT
 N BSDXSTRE,BSDXCITY,BSDXST,BSDXZIP,BSDXPHON
 S BSDXY="^BSDXTMP("_$J_")"
 S BSDXI=0
 S ^BSDXTMP($J,BSDXI)="T00030Name^D00020DOB^T00030Sex^T00030HRN^D00030ApptDate^T00030Clinic^T00030TypeStatus"
 S ^BSDXTMP($J,BSDXI)=^(BSDXI)_"^I00010RESOURCEID^T00030APPT_MADE_BY^D00020DATE_APPT_MADE^T00250NOTE^T00030STREET^T00030CITY^T00030STATE^T00030ZIP^T00030HOMEPHONE"_$C(30)
 S X="ERROR^BSDX27",@^%ZOSF("TRAP")
 ;Get patient info
 ;
 I '+BSDXPAT S ^BSDXTMP($J,1)=$C(31) Q
 I '$D(^DPT(+BSDXPAT,0)) S ^BSDXTMP($J,1)=$C(31) Q
 S BSDXNOD=$$PATINFO(BSDXPAT)
 S BSDXNAM=$P(BSDXNOD,U) ;NAME
 S BSDXSEX=$P(BSDXNOD,U,2) ;SEX
 S BSDXDOB=$P(BSDXNOD,U,3) ;DOB
 S BSDXHRN=$P(BSDXNOD,U,4) ;Health Record Number for location DUZ(2)
 S BSDXSTRE=$P(BSDXNOD,U,5) ;Street
 S BSDXCITY=$P(BSDXNOD,U,6) ;City
 S BSDXST=$P(BSDXNOD,U,7) ;State
 S BSDXZIP=$P(BSDXNOD,U,8) ;zip
 S BSDXPHON=$P(BSDXNOD,U,9) ;homephone
 ;
 ;Organize ^DPT(BSDXPAT,"S," nodes
 ; into BSDXDPT(CLINIC,DATE)
 ;
 I $D(^DPT(BSDXPAT,"S")) S BSDXDT=0 F  S BSDXDT=$O(^DPT(BSDXPAT,"S",BSDXDT)) Q:'+BSDXDT  D
 . S BSDXNOD=$G(^DPT(BSDXPAT,"S",BSDXDT,0))
 . S BSDXCID=$P(BSDXNOD,U)
 . Q:'+BSDXCID
 . Q:'$D(^SC(BSDXCID,0))
 . S BSDXDPT(BSDXCID,BSDXDT)=BSDXNOD
 ;
 ;$O Through ^BSDX("CPAT",
 S BSDXIEN=0
 I $D(^BSDXAPPT("CPAT",BSDXPAT)) F  S BSDXIEN=$O(^BSDXAPPT("CPAT",BSDXPAT,BSDXIEN)) Q:'BSDXIEN  D
 . N BSDXNOD,BSDXAPT,BSDXCID,BSDXCNOD,BSDXCLN,BSDX44,BSDXDNOD,BSDXSTAT,BSDX,BSDXTYPE,BSDXLIN
 . S BSDXNOD=$G(^BSDXAPPT(BSDXIEN,0))
 . Q:BSDXNOD=""
 . Q:$P(BSDXNOD,U,12)]""  ;CANCELLED
 . S Y=$P(BSDXNOD,U)
 . Q:'+Y
 . X ^DD("DD") S Y=$TR(Y,"@"," ")
 . S BSDXAPT=Y ;Appointment date time
 . S BSDXCLRK=$P(BSDXNOD,U,8) ;Appointment made by
 . S:+BSDXCLRK BSDXCLRK=$G(^VA(200,BSDXCLRK,0)),BSDXCLRK=$P(BSDXCLRK,U)
 . S Y=$P(BSDXNOD,U,9) ;Date Appointment Made
 . I +Y X ^DD("DD") S Y=$TR(Y,"@"," ")
 . S BSDXMADE=Y
 . ;NOTE
 . S BSDXNOT=""
 . I $D(^BSDXAPPT(BSDXIEN,1,0)) S BSDXNOT="",BSDXQ=0 F  S BSDXQ=$O(^BSDXAPPT(BSDXIEN,1,BSDXQ)) Q:'+BSDXQ  D
 . . S BSDXLIN=$G(^BSDXAPPT(BSDXIEN,1,BSDXQ,0))
 . . S:(BSDXLIN'="")&($E(BSDXLIN,$L(BSDXLIN)-1,$L(BSDXLIN))'=" ") BSDXLIN=BSDXLIN_" "
 . . S BSDXNOT=BSDXNOT_BSDXLIN
 . ;Resource
 . S BSDXCID=$P(BSDXNOD,U,7) ;IEN of BSDX RESOURCE
 . Q:'+BSDXCID
 . Q:'$D(^BSDXRES(BSDXCID,0))
 . S BSDXCNOD=$G(^BSDXRES(BSDXCID,0)) ;BSDX RESOURCE node
 . Q:BSDXCNOD=""
 . S BSDXCLN=$P(BSDXCNOD,U) ;Text name of BSDX Resource
 . S BSDX44=$P(BSDXCNOD,U,4) ;File 44 pointer
 . ;If appt entry in ^DPT(PAT,"S" exists for this clinic, get the TYPE/STATUS info from
 . ;the BSDXDPT array and delete the BSDXDPT node
 . S BSDXTYPE=""
 . I +BSDX44,$D(BSDXDPT(BSDX44,$P(BSDXNOD,U))) D  ;BSDXNOD is the BSDX APPOINTMENT node
 . . S BSDXDNOD=BSDXDPT(BSDX44,$P(BSDXNOD,U)) ;BSDXDNOD is a copy of the ^DPT(PAT,"S" node
 . . S BSDXTYPE=$$STATUS(BSDXPAT,$P(BSDXNOD,U),BSDXDNOD) ;IHS/OIT/HMW 20050208 Added
 . . K BSDXDPT(BSDX44,$P(BSDXNOD,U))
 . S BSDXI=BSDXI+1
 . S ^BSDXTMP($J,BSDXI)=BSDXNAM_"^"_BSDXDOB_"^"_BSDXSEX_"^"_BSDXHRN_"^"_BSDXAPT_"^"_BSDXCLN_"^"_BSDXTYPE_"^"_BSDXCID_"^"_BSDXCLRK_"^"_BSDXMADE_"^"_BSDXNOT_"^"_BSDXSTRE_"^"_BSDXCITY_"^"_BSDXST_"^"_BSDXZIP_"^"_BSDXPHON_$C(30)
 . Q
 ;
 ;Go through remaining BSDXDPT( entries
 I $D(BSDXDPT) S BSDX44=0 D
 . F  S BSDX44=$O(BSDXDPT(BSDX44)) Q:'+BSDX44  S BSDXDT=0 D
 . . F  S BSDXDT=$O(BSDXDPT(BSDX44,BSDXDT)) Q:'+BSDXDT  D
 . . . S BSDXDNOD=BSDXDPT(BSDX44,BSDXDT)
 . . . S Y=BSDXDT
 . . . Q:'+Y
 . . . X ^DD("DD") S Y=$TR(Y,"@"," ")
 . . . S BSDXAPT=Y
 . . . S BSDXTYPE=$$STATUS(BSDXPAT,BSDXDT,BSDXDNOD) ;IHS/OIT/HMW 20050208 Added
 . . . S BSDXCLN=$P($G(^SC(BSDX44,0)),U)
 . . . S BSDXCLRK=$P(BSDXDNOD,U,18)
 . . . S:+BSDXCLRK BSDXCLRK=$G(^VA(200,BSDXCLRK,0)),BSDXCLRK=$P(BSDXCLRK,U)
 . . . S Y=$P(BSDXDNOD,U,19)
 . . . I +Y X ^DD("DD") S Y=$TR(Y,"@"," ")
 . . . S BSDXMADE=Y
 . . . S BSDXNOT=""
 . . . S BSDXI=BSDXI+1
 . . . S ^BSDXTMP($J,BSDXI)=BSDXNAM_"^"_BSDXDOB_"^"_BSDXSEX_"^"_BSDXHRN_"^"_BSDXAPT_"^"_BSDXCLN_"^"_BSDXTYPE_"^"_"^"_BSDXCLRK_"^"_BSDXMADE_"^"_BSDXNOT_"^"_BSDXSTRE_"^"_BSDXCITY_"^"_BSDXST_"^"_BSDXZIP_"^"_BSDXPHON_$C(30)
 . . . K BSDXDPT(BSDX44,BSDXDT)
 ;
 S BSDXI=BSDXI+1
 S ^BSDXTMP($J,BSDXI)=$C(31)
 Q
 ;
STATUS(PAT,DATE,NODE) ; returns appt status
 ;IHS/OIT/HMW 20050208 Added from BSDDPA
 NEW TYP
 S TYP=$$APPTYP^BSDU2(PAT,DATE)    ;sched vs. walkin
 I $P(NODE,U,2)["C" Q TYP_" - CANCELLED"
 I $P(NODE,U,2)'="NT",$P(NODE,U,2)["N" Q TYP_" - NO SHOW"
 I $$CO^BSDU2(PAT,+NODE,DATE) Q TYP_" - CHECKED OUT"
 I $$CI^BSDU2(PAT,+NODE,DATE) Q TYP_" - CHECKED IN"
 Q TYP
 ;
ERROR ;
 D ERR("RPMS Error")
 Q
 ;
ERR(ERRNO) ;Error processing
 S:'$D(BSDXI) BSDXI=999
 I +ERRNO S BSDXERR=ERRNO+134234112 ;vbObjectError
 E  S BSDXERR=ERRNO
 S BSDXI=BSDXI+1
 S ^BSDXTMP($J,BSDXI)="^^^^^^^^^^^^^^^"_$C(30)
 S BSDXI=BSDXI+1
 S ^BSDXTMP($J,BSDXI)=$C(31)
 Q
PATINFO(BSDXPAT) ;EP
 ;Intrisic Function returns NAME^SEX^DOB^HRN^STREET^CITY^STATE^ZIP^PHONE for patient ien BSDXPAT
 ;DOB is in external format
 ;HRN depends on existence of DUZ(2)
 ;
 N BSDXNOD,BSDXNAM,BSDXSEX,BSDXDOB,BSDXHRN,BSDXSTRT,BSDXCITY,BSDXST,BSDXZIP,BSDXPHON
 S BSDXNOD=^DPT(+BSDXPAT,0)
 S BSDXNAM=$P(BSDXNOD,U) ;NAME
 S BSDXSEX=$P(BSDXNOD,U,2)
 S BSDXSEX=$S(BSDXSEX="F":"FEMALE",BSDXSEX="M":"MALE",1:"")
 S Y=$P(BSDXNOD,U,3) I Y]""  X ^DD("DD") S Y=$TR(Y,"@"," ")
 S BSDXDOB=Y ;DOB
 S BSDXHRN=""
 I $D(DUZ(2)) I DUZ(2)>0 S BSDXHRN=$P($G(^AUPNPAT(BSDXPAT,41,DUZ(2),0)),U,2) ;HRN
 ;
 S BSDXNOD=$G(^DPT(+BSDXPAT,.11))
 S (BSDXSTRT,BSDXCITY,BSDXST,BSDXZIP)=""
 I BSDXNOD]"" D
 . S BSDXSTRT=$E($P(BSDXNOD,U),1,50) ;STREET
 . S BSDXCITY=$P(BSDXNOD,U,4) ;CITY
 . S BSDXST=$P(BSDXNOD,U,5) ;STATE
 . I +BSDXST,$D(^DIC(5,+BSDXST,0)) S BSDXST=$P(^DIC(5,+BSDXST,0),U,2)
 . S BSDXZIP=$P(BSDXNOD,U,6) ;ZIP
 ;
 S BSDXNOD=$G(^DPT(+BSDXPAT,.13)) ;PHONE
 S BSDXPHON=$P(BSDXNOD,U)
 ;
 Q BSDXNAM_U_BSDXSEX_U_BSDXDOB_U_BSDXHRN_U_BSDXSTRT_U_BSDXCITY_U_BSDXST_U_BSDXZIP_U_BSDXPHON
 ;
CLDISPD(BSDXY,BSDXCLST,BSDXBEG,BSDXEND) ;EP
 ;Entry point for debugging
 ;
 ;D DEBUG^%Serenji("CLDISP^BSDX27(.BSDXY,BSDXCLST,BSDXBEG,BSDXEND)")
 Q
 ;
CLDISP(BSDXY,BSDXCLST,BSDXBEG,BSDXEND,BSDXWI) ;EP
 ;Return recordset of patient appointments
 ;between dates BSDXBEG and BSDXEND for each clinic in BSDXCLST.
 ;Used in listing a patient's appointments and generating patient letters.
 ;BSDXCLST is a |-delimited list of BSDX RESOURCE iens.  (The last |-piece is null, so discard it.)
 ;BSDXBEG and BSDXEND are in external date form.
 ;BSDXWI = return only appointments where the WALKIN field is yes
 ;Called by BSDX CLINIC LETTERS
 ;
 N BSDXI,BSDXNOD,BSDXNAM,BSDXDOB,BSDXHRN,BSDXSEX,BSDXCID,BSDXCNOD,BSDXDT
 N BSDXJ,BSDXAID,BSDXPAT,BSDXPNOD,BSDXCLN,BSDXCLRK,BSDXMADE,BSDXNOT,BSDXLIN
 N BSDXSTRT
 N BSDXSTRE,BSDXCITY,BSDXST,BSDXZIP,BSDXPHON
 S BSDXY="^BSDXTMP("_$J_")"
 K ^BSDXTMP($J)
 S BSDXI=0
 S ^BSDXTMP($J,BSDXI)="T00030Name^D00020DOB^T00030Sex^T00030HRN^D00030ApptDate^T00030Clinic^T00030TypeStatus"
 S ^BSDXTMP($J,BSDXI)=^BSDXTMP($J,BSDXI)_"^I00010RESOURCEID^T00030APPT_MADE_BY^D00020DATE_APPT_MADE^T00250NOTE^T00030STREET^T00030CITY^T00030STATE^T00030ZIP^T00030HOMEPHONE"_$C(30)
 S X="ERROR^BSDX27",@^%ZOSF("TRAP")
 ;
 ;Convert beginning and ending dates
 ;
 S X=BSDXBEG,%DT="X" D ^%DT S BSDXBEG=$P(Y,"."),BSDXBEG=BSDXBEG-1,BSDXBEG=BSDXBEG_".9999"
 I Y=-1 D ERR(BSDXI,0,"Routine: BSDX27, Error: Invalid Date") Q
 S X=BSDXEND,%DT="X" D ^%DT S BSDXEND=$P(Y,"."),BSDXEND=BSDXEND_".9999"
 I Y=-1 D ERR(BSDXI,0,"Routine: BSDX27, Error: Invalid Date") Q
 I BSDXCLST="" D ERR(BSDXI,0,"Routine: BSDX27, Error: Null clinic list") Q
 ;
 ;For each clinic in BSDXCLST $O through ^BSDXAPPT("ARSRC",ResourceIEN,FMDate,ApptIEN)
 ;
 F BSDXJ=1:1:$L(BSDXCLST,"|")-1 S BSDXCID=$P(BSDXCLST,"|",BSDXJ) D
 . S BSDXCLN=$G(^BSDXRES(BSDXCID,0)) S BSDXCLN=$P(BSDXCLN,U) Q:BSDXCLN=""
 . S BSDXSTRT=BSDXBEG F  S BSDXSTRT=$O(^BSDXAPPT("ARSRC",BSDXCID,BSDXSTRT)) Q:'+BSDXSTRT  Q:BSDXSTRT>BSDXEND  D
 . . S BSDXAID=0 F  S BSDXAID=$O(^BSDXAPPT("ARSRC",BSDXCID,BSDXSTRT,BSDXAID)) Q:'+BSDXAID  D
 . . . S BSDXNOD=$G(^BSDXAPPT(BSDXAID,0))
 . . . Q:BSDXNOD=""
 . . . Q:$P(BSDXNOD,U,12)]""  ;CANCELLED
 . . . I '$G(BSDXWI),$P(BSDXNOD,U,13)="y" Q  ;DO NOT ALLOW WALKIN
 . . . I $G(BSDXWI),$P(BSDXNOD,U,13)'="y" Q  ;ONLY ALLOW WALKIN
 . . . S Y=$P(BSDXNOD,U)
 . . . Q:'+Y
 . . . X ^DD("DD") S Y=$TR(Y,"@"," ")
 . . . S BSDXAPT=Y ;Appointment date time
 . . . ;
 . . . ;NOTE
 . . . S BSDXNOT=""
 . . . I $D(^BSDXAPPT(BSDXAID,1,0)) S BSDXQ=0 F  S BSDXQ=$O(^BSDXAPPT(BSDXAID,1,BSDXQ)) Q:'+BSDXQ  D
 . . . . S BSDXLIN=$G(^BSDXAPPT(BSDXAID,1,BSDXQ,0))
 . . . . S:(BSDXLIN'="")&($E(BSDXLIN,$L(BSDXLIN)-1,$L(BSDXLIN))'=" ") BSDXLIN=BSDXLIN_" "
 . . . . S BSDXNOT=BSDXNOT_BSDXLIN
 . . . ;
 . . . S BSDXPAT=$P(BSDXNOD,U,5)
 . . . S BSDXPNOD=$$PATINFO(BSDXPAT)
 . . . S BSDXNAM=$P(BSDXPNOD,U) ;NAME
 . . . S BSDXSEX=$P(BSDXPNOD,U,2) ;SEX
 . . . S BSDXDOB=$P(BSDXPNOD,U,3) ;DOB
 . . . S BSDXHRN=$P(BSDXPNOD,U,4) ;Health Record Number for location DUZ(2)
 . . . S BSDXSTRE=$P(BSDXPNOD,U,5) ;Street
 . . . S BSDXCITY=$P(BSDXPNOD,U,6) ;City
 . . . S BSDXST=$P(BSDXPNOD,U,7) ;State
 . . . S BSDXZIP=$P(BSDXPNOD,U,8) ;zip
 . . . S BSDXPHON=$P(BSDXPNOD,U,9) ;homephone
 . . . S BSDXTYPE="" ;Type/status doesn't exist for BSDX APPT clinics and it's not needed for clinic letters
 . . . S BSDXCLRK=$P(BSDXNOD,U,8)
 . . . S:+BSDXCLRK BSDXCLRK=$G(^VA(200,BSDXCLRK,0)),BSDXCLRK=$P(BSDXCLRK,U)
 . . . S Y=$P(BSDXNOD,U,9)
 . . . I +Y X ^DD("DD") S Y=$TR(Y,"@"," ")
 . . . S BSDXMADE=Y
 . . . S BSDXI=BSDXI+1
 . . . S ^BSDXTMP($J,BSDXI)=BSDXNAM_"^"_BSDXDOB_"^"_BSDXSEX_"^"_BSDXHRN_"^"_BSDXAPT_"^"_BSDXCLN_"^"_BSDXTYPE_"^"_BSDXCID_"^"_BSDXCLRK_"^"_BSDXMADE_"^"_BSDXNOT_"^"_BSDXSTRE_"^"_BSDXCITY_"^"_BSDXST_"^"_BSDXZIP_"^"_BSDXPHON_$C(30)
 ;
 S BSDXI=BSDXI+1
 S ^BSDXTMP($J,BSDXI)=$C(31)
 Q
 ;
CLDISPW(BSDXY,BSDXCLST,BSDXBEG,BSDXEND) ;EP
 ;Return recordset of patient walk-in appointments
 ;between dates BSDXBEG and BSDXEND for each clinic in BSDXCLST.
 ;Used in listing a patient's walk-in appointments and generating patient letters.
 ;BSDXCLST is a |-delimited list of BSDX RESOURCE iens.  (The last |-piece is null, so discard it.)
 ;BSDXBEG and BSDXEND are in external date form.
 ;Called by BSDX CLINIC LETTERS WALKIN
 S:$G(U)="" U="^"
 D CLDISP(.BSDXY,BSDXCLST,BSDXBEG,BSDXEND,1)
 Q