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

PXRRWLS2.m

Go to the documentation of this file.
  1. PXRRWLS2 ;ISA/Zoltan - Sort encounters for encounter summary report.;12/1/1998
  1. ;;1.0;PCE PATIENT CARE ENCOUNTER;**58,61**;Aug 12, 1996
  1. ;
  1. ; Code migrated from PXRRWLSE.
  1. ;
  1. ; Part 1: migrated code.
  1. SORT2 ; Migrated from PXRRWLSE
  1. I '(PXRRQUE!$D(IO("S"))) D INIT^PXRRBUSY(.BUSY)
  1. ;
  1. ;Location is true if we are screening by location.
  1. I $P(PXRRWLSC,U,1)="L" D
  1. . S LOCATION=1
  1. . S ^XTMP(PXRRXTMP,"STOIND","LOCATION")=""
  1. E S LOCATION=0
  1. ;
  1. ;CSSCR is true if we want selected clinics.
  1. I $P($G(PXRRLCSC),U,1)="CS" S CSSCR=1
  1. E S CSSCR=0
  1. ;
  1. ;CLINIC is true if we want clinics instead of hospital locations.
  1. I $P($G(PXRRLCSC),U,1)["C" D
  1. . S CLINIC=1
  1. . S BYCLOC=$S($P(PXRRLCSC,U,3):1,1:0)
  1. E D
  1. . S CLINIC=0
  1. . S BYCLOC=0
  1. ;
  1. ;HSSCR is true if we want selected hospital locations.
  1. I $P($G(PXRRLCSC),U,1)="HS" S HSSCR=1
  1. E S HSSCR=0
  1. ;
  1. ;PROVIDER is true if we select by provider.
  1. I $P($G(PXRRWLSC),U,1)="P" D
  1. . S PROVIDER=1
  1. . S ^XTMP(PXRRXTMP,"STOIND","PROVIDER")=""
  1. E S PROVIDER=0
  1. ;
  1. ;PRVSCR is true if we have selected providers.
  1. I $D(NPL) S PRVSCR=1
  1. E S PRVSCR=0
  1. ;
  1. ;Allow the task to be cleaned up upon successful completion.
  1. S ZTREQ="@"
  1. Q
  1. ;
  1. VISIT2 ; Migrated from PXRRWLSE
  1. ;Clinic screen.
  1. I CSSCR D
  1. . S FOUND=0
  1. . S CLINIEN=$P(VISIT,U,8)
  1. . F IC=1:1:NCS I $P(PXRRCS(IC),U,2)=CLINIEN D Q
  1. ..;Mark the clinic as being matched.
  1. .. S $P(PXRRCS(IC),U,4)="M"
  1. .. S HLOCNAM=$P(^DIC(40.7,CLINIEN,0),U,1)_U_CLINIEN
  1. .. S FOUND=1
  1. ;
  1. ;Hospital location screen.
  1. I HSSCR D
  1. . S FOUND=0
  1. . S HLOCIEN=$P(VISIT,U,22)
  1. . F IC=1:1:NHL I $P(PXRRLCHL(IC),U,2)=HLOCIEN D Q
  1. ..;Mark the hospital location as being matched.
  1. .. S $P(PXRRLCHL(IC),U,4)="M"
  1. .. S CLINIEN=$P(^SC(HLOCIEN,0),U,7)
  1. .. S HLOCNAM=$P(^SC(HLOCIEN,0),U,1)_U_HLOCIEN
  1. .. S FOUND=1
  1. Q
  1. ;
  1. PRV2 ; Migrated from PXRRWLSE
  1. ;At this point we have an encounter that can be added to the list.
  1. ;
  1. ;Get the hospital location or clinic and stop code.
  1. I $L(HLOCNAM)'>0 D
  1. . I 'CLINIC D
  1. .. ;Get the hospital location.
  1. .. S HLOCIEN=$P(VISIT,U,22)
  1. .. I HLOCIEN>0 D
  1. ... S HLOCNAM=$P(^SC(HLOCIEN,0),U,1)_U_HLOCIEN
  1. ... S CLINIEN=$P(^SC(HLOCIEN,0),U,7)
  1. .. E D
  1. ...;No hospital location, see if we can at least find the clinic.
  1. ... S HLOCNAM="Unknown"
  1. ... S CLINIEN=$P(VISIT,U,8)
  1. . E D
  1. .. ;Get the clinic.
  1. .. S CLINIEN=$P(VISIT,U,8)
  1. .. I $D(^DIC(40.7,CLINIEN,0))[0 S CLINIEN=0
  1. .. I CLINIEN>0 S HLOCNAM=$P(^DIC(40.7,CLINIEN,0),U,1)_U_CLINIEN
  1. .. E S HLOCNAM="Unknown"
  1. ;
  1. ;Append the clinic stop code.
  1. I CLINIEN>0 S HLOCNAM=HLOCNAM_U_$P(^DIC(40.7,CLINIEN,0),U,2)
  1. ;
  1. I LOCATION S STOIND=HLOCNAM
  1. ;Make sure that all providers are stored with the person class.
  1. I PROVIDER D
  1. . I $P(PPNAME,U,3)="" D
  1. .. S PCLASS=$$OCCUP^PXBGPRV(NEWPIEN,BD,"",1,"")
  1. .. S PPNAME=PPNAME_U_$P(PCLASS,U,7)
  1. . S STOIND=PPNAME_U
  1. . I PXRRPRLL S STOIND=STOIND_HLOCNAM
  1. ;
  1. ;Save the patient information.
  1. S TEMP=^AUPNVSIT(VIEN,0)
  1. S DATE=$P(TEMP,U,1)
  1. S DAY=$P(DATE,".",1)
  1. S DFN=$P(TEMP,U,5)
  1. ;Get the patient status, 1 is in, 0 is out.
  1. S INOUT=$P(VISIT150,U,2)
  1. I $L(INOUT)=0 S INOUT=-1
  1. Q
  1. ;
  1. GC2 ; Migrated from PXRRWLSE
  1. S CPT=$P(^AUPNVCPT(IC,0),U,1)
  1. I +CPT'>0 D
  1. . W !,"WARNING AUPNVCPT IS CORRUPTED! ENTRY ",IC," does not have a CPT code."
  1. . S CPT=0
  1. E D
  1. . S EM=$P($G(^IBE(357.69,CPT,0)),U,5)
  1. . I EM="" S EM=0
  1. ;
  1. ;Increment the CPT and E&M counts.
  1. S ^XTMP(PXRRXTMP,FACILITY,STOIND,"CPT")=$G(^XTMP(PXRRXTMP,FACILITY,STOIND,"CPT"))+1
  1. S ^XTMP(PXRRXTMP,FACILITY,STOIND,"EM",EM)=$G(^XTMP(PXRRXTMP,FACILITY,STOIND,"EM",EM))+1
  1. ;Calculate totals by facility for multiple provider encounters.
  1. I MULTPR=1 D
  1. . D FTOT(FACILITY,"&&","CPT")
  1. . D FTOT1(FACILITY,"&&","EM",EM)
  1. Q
  1. ;
  1. ;Totals for multiple provider encounters - used in PXRRWLPR.
  1. FTOT(FL,FLD,FL1) ;
  1. S ^XTMP(PXRRXTMP,FL,FLD,FL1)=$G(^XTMP(PXRRXTMP,FL,FLD,FL1))+1
  1. Q
  1. FTOT1(FL,FLD,FL1,FL2) ;
  1. S ^XTMP(PXRRXTMP,FL,FLD,FL1,FL2)=$G(^XTMP(PXRRXTMP,FL,FLD,FL1,FL2))+1
  1. Q
  1. ;
  1. NF2 ; Migrated from PXRRWLSE
  1. ;Count the total unique patients and visits at the facility.
  1. S TOTUNIQ=0
  1. S TOTVIS=0
  1. S VISITS(0)=0
  1. S VISITS(1)=0
  1. S DFN=0
  1. F S DFN=$O(^TMP(PXRRXTMP,$J,FACILITY,"&","PATIENT",DFN)) Q:DFN="" D
  1. . S TOTUNIQ=TOTUNIQ+1
  1. . S DAY=""
  1. . F S DAY=$O(^TMP(PXRRXTMP,$J,FACILITY,"&","PATIENT",DFN,DAY)) Q:DAY="" D
  1. .. S TOTVIS=TOTVIS+1
  1. .. S INOUT=-1
  1. .. F S INOUT=$O(^TMP(PXRRXTMP,$J,FACILITY,"&","PATIENT",DFN,DAY,INOUT)) Q:INOUT="" D
  1. ... S VISITS(INOUT)=VISITS(INOUT)+1
  1. S ^XTMP(PXRRXTMP,FACILITY,"&","TOTUNIQ")=TOTUNIQ
  1. S ^XTMP(PXRRXTMP,FACILITY,"&","TOTVIS")=TOTVIS
  1. S ^XTMP(PXRRXTMP,FACILITY,"&","TOTINOUT",0)=VISITS(0)
  1. S ^XTMP(PXRRXTMP,FACILITY,"&","TOTINOUT",1)=VISITS(1)
  1. Q
  1. ;
  1. CLOC2 ; Migrated from PXRRWLSE
  1. ;Save this to count the total number of unique patients and
  1. ;the total unique in/out patient encounters.
  1. S ^TMP(PXRRXTMP,$J,FACILITY,"&","PATIENT",DFN,DAY,INOUT)=""
  1. ;
  1. ;Save this to count the unique in/out patient encounters.
  1. S ^TMP(PXRRXTMP,$J,FACILITY,STOIND,"PATIENT",DFN,DAY,INOUT)=""
  1. ;
  1. ;Save this information so we can search for appointments in PXRRWLSA.
  1. S ^XTMP(PXRRXTMP,FACILITY,STOIND,"PATIENT",DFN,DATE,VIEN)=MULTPR
  1. ;
  1. ;Increment the encounter count.
  1. S ^XTMP(PXRRXTMP,FACILITY,STOIND,"TOTENC")=$G(^XTMP(PXRRXTMP,FACILITY,STOIND,"TOTENC"))+1
  1. ;
  1. ;Calculate totals by facility for multiple provider encounters.
  1. I MULTPR=1 D FTOT(FACILITY,"&&","TOTENC")
  1. Q