- ORS100A ;SLC/RAF - Continuation of ORS100 ;10/20/00 14:47
- ;;3.0;ORDER ENTRY/RESULTS REPORTING;**50**;Dec 17, 1997
- ;
- LOOP ;called from ORS100
- ;goes thru the "AS" xref in 100 for order dates - called from ORS100
- S RPDT="""Report Date: "",$$FMTE^XLFDT($$NOW^XLFDT),"" Sort Range From: "",SDT,"" To: "",EDT",STOP=0
- S PAT="" F S PAT=$O(^OR(100,"AS",PAT)) Q:'PAT!STOP D
- .Q:$P(^DPT(+PAT,0),U,21) ;Quit if test patient
- .S DATE=0 F S DATE=$O(^OR(100,"AS",PAT,DATE)) Q:'DATE!STOP I DATE>SDATE,DATE<EDATE D
- ..S IEN=0 F S IEN=$O(^OR(100,"AS",PAT,DATE,IEN)) Q:'IEN!STOP D
- ...S SUB=0 F S SUB=$O(^OR(100,"AS",PAT,DATE,IEN,SUB)) Q:'SUB!STOP D
- ....I $D(^OR(100,IEN,8,SUB,0)),'$L($P(^(0),"^",6)) D
- .....I TYPE=1 Q:+$P(^(0),U,15)=11
- .....I TYPE=3 Q:+$P(^(0),U,15)'=11
- .....S (LOC,DIV)="**DELAYED ORDER/NOT ENTERED" ;Reset values as delayed orders may not have these values yet
- .....I $D(^VA(200,+$P(^OR(100,IEN,8,SUB,0),U,3),0)) S PROV=$$USER^ORS100(+$P(^OR(100,IEN,8,SUB,0),U,3))
- .....I $D(^VA(200,+$P(^OR(100,IEN,8,SUB,0),U,3),5)),$L($P(^(5),U)) S SER=$$SER^ORS100(+$P(^VA(200,+$P(^OR(100,IEN,8,SUB,0),U,3),5),U))
- .....E S SER="MISSING from file 200"
- .....I $D(^VA(200,+$P(^OR(100,IEN,8,SUB,0),U,13))) S WHO=$$USER^ORS100(+$P(^OR(100,IEN,8,SUB,0),U,13))
- .....I $G(^OR(100,IEN,6)) I $P(^(6),U)=9&($P(^(6),U,5)="AUTO DC") S WHO=$$USER^ORS100(+$P(^OR(100,IEN,8,1,0),U,13)) ;If DCd nature is auto and text is auto dc set entered by to original entry person
- .....S DFN=+$P(^OR(100,IEN,0),U,2) D DEM^VADPT S SSN=VA("BID"),PNM=$E(VADM(1),1,24)
- .....I $D(^OR(100,IEN,3)),$P(^(3),U,3) S STATUS=$$STAT^ORS100(+$P(^(3),U,3))
- .....I $D(^OR(100,IEN,0)),$P(^(0),U,10) S LOC=$$LOC^ORS100(+$P(^(0),U,10))
- .....I $D(^OR(100,IEN,0)),$P(^(0),U,10) S DIV=$$DIV^ORS100(+$P(^(0),U,10))
- .....I $D(^OR(100,IEN,8,SUB,0)),$P(^(0),U) S WHEN=$$FMTE^XLFDT($P($P(^(0),U),"."))
- .....I SORT=1 S ^TMP("ORUNS",$J,SER,PROV,IEN)=SER_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- .....I SORT=2 S ^TMP("ORUNS",$J,PROV,PNM,IEN)=PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- .....I SORT=3 S ^TMP("ORUNS",$J,PNM,PROV,IEN)=PNM_U_SSN_U_PROV_U_WHO_U_STATUS_U_IEN_U_WHEN
- .....I SORT=4 S ^TMP("ORUNS",$J,LOC,PROV,IEN)=LOC_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- .....I SORT=5 S ^TMP("ORUNS",$J,WHO,PNM,IEN)=WHO_U_PROV_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- .....I SORT=6 S ^TMP("ORUNS",$J,DIV,LOC,PROV,IEN)=DIV_U_LOC_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- PROV ;loops thru the TMP global for output sort by provider
- I SORT=2&('$D(LONER)) D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders by PROVIDER"""
- .I TYPE=2 S HDR="!!?40,""List of UNSIGNED orders by PROVIDER"""
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by PROVIDER"""
- .S HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .S PAGE=0 D HDR^ORS100
- .I '$D(^TMP("ORUNS",$J)) W !,"No unsigned orders found" Q
- .S PROV="" F S PROV=$O(^TMP("ORUNS",$J,PROV)) Q:PROV=""!STOP D
- ..S PNM="" F S PNM=$O(^TMP("ORUNS",$J,PROV,PNM)) S CNT=0 Q:PNM=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,PROV,PNM,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^(IEN),U),?25,$P(^(IEN),U,2),?50,$P(^(IEN),U,3),?75,$P(^(IEN),U,4),?81,$P(^(IEN),U,5),?95,$P(^(IEN),U,6),?110,$P(^(IEN),U,7),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,PROV,PNM)=CNT
- SPROV ;sorts for a single provider
- I SORT=2&($D(LONER)) S LONER="",PAGE=0 F S LONER=$O(LONER(LONER)) Q:LONER=""!STOP D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- .I TYPE=2 S HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- .S HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .D HDR^ORS100
- .S PROV=LONER I $D(^TMP("ORUNS",$J,PROV)) D
- ..S PNM="" F S PNM=$O(^TMP("ORUNS",$J,PROV,PNM)) S CNT=0 Q:PNM=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,PROV,PNM,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^(IEN),U),?25,$P(^(IEN),U,2),?50,$P(^(IEN),U,3),?75,$P(^(IEN),U,4),?81,$P(^(IEN),U,5),?95,$P(^(IEN),U,6),?110,$P(^(IEN),U,7),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,PROV,PNM)=CNT
- .I '$D(^TMP("ORUNS",$J,PROV)) W !!,"No unsigned orders found for "_LONER
- PAT ;loops thru the TMP global for output sort by patient
- I SORT=3&('$D(LONER)) D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders by PATIENT"""
- .I TYPE=2 S HDR="!!?40,""List of UNSIGNED orders by PATIENT"""
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by PATIENT"""
- .S HDR1="!!,""PATIENT"",?25,""SSN"",?30,""PROVIDER"",?55,""ENTERED BY"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .S PAGE=0 D HDR^ORS100
- .I '$D(^TMP("ORUNS",$J)) W !,"No unsigned orders found" Q
- .S PNM="" F S PNM=$O(^TMP("ORUNS",$J,PNM)) Q:PNM=""!STOP D
- ..S PROV="" F S PROV=$O(^TMP("ORUNS",$J,PNM,PROV)) S CNT=0 Q:PROV=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,PNM,PROV,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^(IEN),U),?25,$P(^(IEN),U,2),?30,$P(^(IEN),U,3),?55,$P(^(IEN),U,4),?81,$P(^(IEN),U,5),?95,$P(^(IEN),U,6),?110,$P(^(IEN),U,7),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,PNM,PROV)=CNT
- ....;I $E(IOST)="E",$Y>(IOSL-105) W @IOF,@HDR
- SPAT ;sorts for a single patient
- I SORT=3&($D(LONER)) S LONER="",PAGE=0 F S LONER=$O(LONER(LONER)) Q:LONER=""!STOP D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- .I TYPE=2 S HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- .S HDR1="!!,""PATIENT"",?25,""SSN"",?30,""PROVIDER"",?55,""ENTERED BY"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .D HDR^ORS100
- .S PNM=LONER I $D(^TMP("ORUNS",$J,PNM)) D
- ..S PROV="" F S PROV=$O(^TMP("ORUNS",$J,PNM,PROV)) S CNT=0 Q:PROV=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,PNM,PROV,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^(IEN),U),?25,$P(^(IEN),U,2),?30,$P(^(IEN),U,3),?55,$P(^(IEN),U,4),?81,$P(^(IEN),U,5),?95,$P(^(IEN),U,6),?110,$P(^(IEN),U,7),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,PNM,PROV)=CNT
- .I '$D(^TMP("ORUNS",$J,PNM)) W !!,"No unsigned orders found for "_LONER
- WARD ;loops thru the TMP global for output sort by location
- I SORT=4&('$D(LONER)) D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders by LOCATION"""
- .I TYPE=2 S HDR="!!?30,""List of UNSIGNED orders by LOCATION"""
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by LOCATION"""
- .S HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .S PAGE=0 D HDR^ORS100
- .I '$D(^TMP("ORUNS",$J)) W !,"No unsigned orders found" Q
- .S LOC="" F S LOC=$O(^TMP("ORUNS",$J,LOC)) Q:LOC=""!STOP W:'SUMONLY "Location: ",LOC,! D
- ..S PROV="" F S PROV=$O(^TMP("ORUNS",$J,LOC,PROV)) S CNT=0 Q:PROV=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,LOC,PROV,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^TMP("ORUNS",$J,LOC,PROV,IEN),U,2),?25,$P(^(IEN),U,3),?50,$P(^(IEN),U,4),?75,$P(^(IEN),U,5),?81,$P(^(IEN),U,6),?95,$P(^(IEN),U,7),?110,$P(^(IEN),U,8),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,LOC,PROV)=CNT
- ..W !
- ;
- SWARD ;sorts for a single location
- I SORT=4&($D(LONER)) S LONER="",PAGE=0 F S LONER=$O(LONER(LONER)) Q:LONER=""!STOP D
- .I TYPE=1 S HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- .I TYPE=2 S HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- .I TYPE=3 S HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- .S HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- .D HDR^ORS100
- .S LOC=LONER I $D(^TMP("ORUNS",$J,LOC)) D
- ..S PROV="" F S PROV=$O(^TMP("ORUNS",$J,LOC,PROV)) S CNT=0 Q:PROV=""!STOP D
- ...S IEN=0 F S IEN=$O(^TMP("ORUNS",$J,LOC,PROV,IEN)) S CNT=CNT+1 Q:'IEN!STOP D
- ....I 'SUMONLY W $P(^TMP("ORUNS",$J,LOC,PROV,IEN),U,2),?25,$P(^(IEN),U,3),?50,$P(^(IEN),U,4),?75,$P(^(IEN),U,5),?81,$P(^(IEN),U,6),?95,$P(^(IEN),U,7),?110,$P(^(IEN),U,8),! D:$Y>(IOSL-4) HDR^ORS100 Q:STOP
- ....S ^TMP("ORSTATS",$J,LOC,PROV)=CNT
- .I '$D(^TMP("ORUNS",$J,LOC)) W !!,"No unsigned orders found for "_LONER
- I SORT=1 D SERV^ORS100B
- I SORT=5 D WHO^ORS100B
- I SORT=6 D DIV^ORS100B
- I 'STOP D STATS^ORS100
- EXIT K ^TMP("ORUNS",$J),^TMP("ORSTATS",$J)
- D ^%ZISC
- Q
- --- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HORS100A 8633 printed Apr 23, 2025@18:48:39 Page 2
- ORS100A ;SLC/RAF - Continuation of ORS100 ;10/20/00 14:47
- +1 ;;3.0;ORDER ENTRY/RESULTS REPORTING;**50**;Dec 17, 1997
- +2 ;
- LOOP ;called from ORS100
- +1 ;goes thru the "AS" xref in 100 for order dates - called from ORS100
- +2 SET RPDT="""Report Date: "",$$FMTE^XLFDT($$NOW^XLFDT),"" Sort Range From: "",SDT,"" To: "",EDT"
- SET STOP=0
- +3 SET PAT=""
- FOR
- SET PAT=$ORDER(^OR(100,"AS",PAT))
- if 'PAT!STOP
- QUIT
- Begin DoDot:1
- +4 ;Quit if test patient
- if $PIECE(^DPT(+PAT,0),U,21)
- QUIT
- +5 SET DATE=0
- FOR
- SET DATE=$ORDER(^OR(100,"AS",PAT,DATE))
- if 'DATE!STOP
- QUIT
- IF DATE>SDATE
- IF DATE<EDATE
- Begin DoDot:2
- +6 SET IEN=0
- FOR
- SET IEN=$ORDER(^OR(100,"AS",PAT,DATE,IEN))
- if 'IEN!STOP
- QUIT
- Begin DoDot:3
- +7 SET SUB=0
- FOR
- SET SUB=$ORDER(^OR(100,"AS",PAT,DATE,IEN,SUB))
- if 'SUB!STOP
- QUIT
- Begin DoDot:4
- +8 IF $DATA(^OR(100,IEN,8,SUB,0))
- IF '$LENGTH($PIECE(^(0),"^",6))
- Begin DoDot:5
- +9 IF TYPE=1
- if +$PIECE(^(0),U,15)=11
- QUIT
- +10 IF TYPE=3
- if +$PIECE(^(0),U,15)'=11
- QUIT
- +11 ;Reset values as delayed orders may not have these values yet
- SET (LOC,DIV)="**DELAYED ORDER/NOT ENTERED"
- +12 IF $DATA(^VA(200,+$PIECE(^OR(100,IEN,8,SUB,0),U,3),0))
- SET PROV=$$USER^ORS100(+$PIECE(^OR(100,IEN,8,SUB,0),U,3))
- +13 IF $DATA(^VA(200,+$PIECE(^OR(100,IEN,8,SUB,0),U,3),5))
- IF $LENGTH($PIECE(^(5),U))
- SET SER=$$SER^ORS100(+$PIECE(^VA(200,+$PIECE(^OR(100,IEN,8,SUB,0),U,3),5),U))
- +14 IF '$TEST
- SET SER="MISSING from file 200"
- +15 IF $DATA(^VA(200,+$PIECE(^OR(100,IEN,8,SUB,0),U,13)))
- SET WHO=$$USER^ORS100(+$PIECE(^OR(100,IEN,8,SUB,0),U,13))
- +16 ;If DCd nature is auto and text is auto dc set entered by to original entry person
- IF $GET(^OR(100,IEN,6))
- IF $PIECE(^(6),U)=9&($PIECE(^(6),U,5)="AUTO DC")
- SET WHO=$$USER^ORS100(+$PIECE(^OR(100,IEN,8,1,0),U,13))
- +17 SET DFN=+$PIECE(^OR(100,IEN,0),U,2)
- DO DEM^VADPT
- SET SSN=VA("BID")
- SET PNM=$EXTRACT(VADM(1),1,24)
- +18 IF $DATA(^OR(100,IEN,3))
- IF $PIECE(^(3),U,3)
- SET STATUS=$$STAT^ORS100(+$PIECE(^(3),U,3))
- +19 IF $DATA(^OR(100,IEN,0))
- IF $PIECE(^(0),U,10)
- SET LOC=$$LOC^ORS100(+$PIECE(^(0),U,10))
- +20 IF $DATA(^OR(100,IEN,0))
- IF $PIECE(^(0),U,10)
- SET DIV=$$DIV^ORS100(+$PIECE(^(0),U,10))
- +21 IF $DATA(^OR(100,IEN,8,SUB,0))
- IF $PIECE(^(0),U)
- SET WHEN=$$FMTE^XLFDT($PIECE($PIECE(^(0),U),"."))
- +22 IF SORT=1
- SET ^TMP("ORUNS",$JOB,SER,PROV,IEN)=SER_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- +23 IF SORT=2
- SET ^TMP("ORUNS",$JOB,PROV,PNM,IEN)=PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- +24 IF SORT=3
- SET ^TMP("ORUNS",$JOB,PNM,PROV,IEN)=PNM_U_SSN_U_PROV_U_WHO_U_STATUS_U_IEN_U_WHEN
- +25 IF SORT=4
- SET ^TMP("ORUNS",$JOB,LOC,PROV,IEN)=LOC_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- +26 IF SORT=5
- SET ^TMP("ORUNS",$JOB,WHO,PNM,IEN)=WHO_U_PROV_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- +27 IF SORT=6
- SET ^TMP("ORUNS",$JOB,DIV,LOC,PROV,IEN)=DIV_U_LOC_U_PROV_U_WHO_U_PNM_U_SSN_U_STATUS_U_IEN_U_WHEN
- End DoDot:5
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- PROV ;loops thru the TMP global for output sort by provider
- +1 IF SORT=2&('$DATA(LONER))
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders by PROVIDER"""
- +3 IF TYPE=2
- SET HDR="!!?40,""List of UNSIGNED orders by PROVIDER"""
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by PROVIDER"""
- +5 SET HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 SET PAGE=0
- DO HDR^ORS100
- +7 IF '$DATA(^TMP("ORUNS",$JOB))
- WRITE !,"No unsigned orders found"
- QUIT
- +8 SET PROV=""
- FOR
- SET PROV=$ORDER(^TMP("ORUNS",$JOB,PROV))
- if PROV=""!STOP
- QUIT
- Begin DoDot:2
- +9 SET PNM=""
- FOR
- SET PNM=$ORDER(^TMP("ORUNS",$JOB,PROV,PNM))
- SET CNT=0
- if PNM=""!STOP
- QUIT
- Begin DoDot:3
- +10 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,PROV,PNM,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +11 IF 'SUMONLY
- WRITE $PIECE(^(IEN),U),?25,$PIECE(^(IEN),U,2),?50,$PIECE(^(IEN),U,3),?75,$PIECE(^(IEN),U,4),?81,$PIECE(^(IEN),U,5),?95,$PIECE(^(IEN),U,6),?110,$PIECE(^(IEN),U,7),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +12 SET ^TMP("ORSTATS",$JOB,PROV,PNM)=CNT
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- SPROV ;sorts for a single provider
- +1 IF SORT=2&($DATA(LONER))
- SET LONER=""
- SET PAGE=0
- FOR
- SET LONER=$ORDER(LONER(LONER))
- if LONER=""!STOP
- QUIT
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- +3 IF TYPE=2
- SET HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- +5 SET HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 DO HDR^ORS100
- +7 SET PROV=LONER
- IF $DATA(^TMP("ORUNS",$JOB,PROV))
- Begin DoDot:2
- +8 SET PNM=""
- FOR
- SET PNM=$ORDER(^TMP("ORUNS",$JOB,PROV,PNM))
- SET CNT=0
- if PNM=""!STOP
- QUIT
- Begin DoDot:3
- +9 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,PROV,PNM,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +10 IF 'SUMONLY
- WRITE $PIECE(^(IEN),U),?25,$PIECE(^(IEN),U,2),?50,$PIECE(^(IEN),U,3),?75,$PIECE(^(IEN),U,4),?81,$PIECE(^(IEN),U,5),?95,$PIECE(^(IEN),U,6),?110,$PIECE(^(IEN),U,7),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +11 SET ^TMP("ORSTATS",$JOB,PROV,PNM)=CNT
- End DoDot:4
- End DoDot:3
- End DoDot:2
- +12 IF '$DATA(^TMP("ORUNS",$JOB,PROV))
- WRITE !!,"No unsigned orders found for "_LONER
- End DoDot:1
- PAT ;loops thru the TMP global for output sort by patient
- +1 IF SORT=3&('$DATA(LONER))
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders by PATIENT"""
- +3 IF TYPE=2
- SET HDR="!!?40,""List of UNSIGNED orders by PATIENT"""
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by PATIENT"""
- +5 SET HDR1="!!,""PATIENT"",?25,""SSN"",?30,""PROVIDER"",?55,""ENTERED BY"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 SET PAGE=0
- DO HDR^ORS100
- +7 IF '$DATA(^TMP("ORUNS",$JOB))
- WRITE !,"No unsigned orders found"
- QUIT
- +8 SET PNM=""
- FOR
- SET PNM=$ORDER(^TMP("ORUNS",$JOB,PNM))
- if PNM=""!STOP
- QUIT
- Begin DoDot:2
- +9 SET PROV=""
- FOR
- SET PROV=$ORDER(^TMP("ORUNS",$JOB,PNM,PROV))
- SET CNT=0
- if PROV=""!STOP
- QUIT
- Begin DoDot:3
- +10 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,PNM,PROV,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +11 IF 'SUMONLY
- WRITE $PIECE(^(IEN),U),?25,$PIECE(^(IEN),U,2),?30,$PIECE(^(IEN),U,3),?55,$PIECE(^(IEN),U,4),?81,$PIECE(^(IEN),U,5),?95,$PIECE(^(IEN),U,6),?110,$PIECE(^(IEN),U,7),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +12 SET ^TMP("ORSTATS",$JOB,PNM,PROV)=CNT
- +13 ;I $E(IOST)="E",$Y>(IOSL-105) W @IOF,@HDR
- End DoDot:4
- End DoDot:3
- End DoDot:2
- End DoDot:1
- SPAT ;sorts for a single patient
- +1 IF SORT=3&($DATA(LONER))
- SET LONER=""
- SET PAGE=0
- FOR
- SET LONER=$ORDER(LONER(LONER))
- if LONER=""!STOP
- QUIT
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- +3 IF TYPE=2
- SET HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- +5 SET HDR1="!!,""PATIENT"",?25,""SSN"",?30,""PROVIDER"",?55,""ENTERED BY"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 DO HDR^ORS100
- +7 SET PNM=LONER
- IF $DATA(^TMP("ORUNS",$JOB,PNM))
- Begin DoDot:2
- +8 SET PROV=""
- FOR
- SET PROV=$ORDER(^TMP("ORUNS",$JOB,PNM,PROV))
- SET CNT=0
- if PROV=""!STOP
- QUIT
- Begin DoDot:3
- +9 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,PNM,PROV,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +10 IF 'SUMONLY
- WRITE $PIECE(^(IEN),U),?25,$PIECE(^(IEN),U,2),?30,$PIECE(^(IEN),U,3),?55,$PIECE(^(IEN),U,4),?81,$PIECE(^(IEN),U,5),?95,$PIECE(^(IEN),U,6),?110,$PIECE(^(IEN),U,7),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +11 SET ^TMP("ORSTATS",$JOB,PNM,PROV)=CNT
- End DoDot:4
- End DoDot:3
- End DoDot:2
- +12 IF '$DATA(^TMP("ORUNS",$JOB,PNM))
- WRITE !!,"No unsigned orders found for "_LONER
- End DoDot:1
- WARD ;loops thru the TMP global for output sort by location
- +1 IF SORT=4&('$DATA(LONER))
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders by LOCATION"""
- +3 IF TYPE=2
- SET HDR="!!?30,""List of UNSIGNED orders by LOCATION"""
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders by LOCATION"""
- +5 SET HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 SET PAGE=0
- DO HDR^ORS100
- +7 IF '$DATA(^TMP("ORUNS",$JOB))
- WRITE !,"No unsigned orders found"
- QUIT
- +8 SET LOC=""
- FOR
- SET LOC=$ORDER(^TMP("ORUNS",$JOB,LOC))
- if LOC=""!STOP
- QUIT
- if 'SUMONLY
- WRITE "Location: ",LOC,!
- Begin DoDot:2
- +9 SET PROV=""
- FOR
- SET PROV=$ORDER(^TMP("ORUNS",$JOB,LOC,PROV))
- SET CNT=0
- if PROV=""!STOP
- QUIT
- Begin DoDot:3
- +10 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,LOC,PROV,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +11 IF 'SUMONLY
- WRITE $PIECE(^TMP("ORUNS",$JOB,LOC,PROV,IEN),U,2),?25,$PIECE(^(IEN),U,3),?50,$PIECE(^(IEN),U,4),?75,$PIECE(^(IEN),U,5),?81,$PIECE(^(IEN),U,6),?95,$PIECE(^(IEN),U,7),?110,$PIECE(^(IEN),U,8),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +12 SET ^TMP("ORSTATS",$JOB,LOC,PROV)=CNT
- End DoDot:4
- End DoDot:3
- +13 WRITE !
- End DoDot:2
- End DoDot:1
- +14 ;
- SWARD ;sorts for a single location
- +1 IF SORT=4&($DATA(LONER))
- SET LONER=""
- SET PAGE=0
- FOR
- SET LONER=$ORDER(LONER(LONER))
- if LONER=""!STOP
- QUIT
- Begin DoDot:1
- +2 IF TYPE=1
- SET HDR="!!?30,""List of RELEASED but UNSIGNED orders for "",LONER"
- +3 IF TYPE=2
- SET HDR="!!?30,""List of UNSIGNED orders for "",LONER"
- +4 IF TYPE=3
- SET HDR="!!?30,""List of UNSIGNED/UNRELEASED orders for "",LONER"
- +5 SET HDR1="!!,""PROVIDER"",?25,""ENTERED BY"",?50,""PATIENT"",?75,""SSN"",?81,""STATUS"",?95,""ORDER #"",?110,""ORDER DATE"""
- +6 DO HDR^ORS100
- +7 SET LOC=LONER
- IF $DATA(^TMP("ORUNS",$JOB,LOC))
- Begin DoDot:2
- +8 SET PROV=""
- FOR
- SET PROV=$ORDER(^TMP("ORUNS",$JOB,LOC,PROV))
- SET CNT=0
- if PROV=""!STOP
- QUIT
- Begin DoDot:3
- +9 SET IEN=0
- FOR
- SET IEN=$ORDER(^TMP("ORUNS",$JOB,LOC,PROV,IEN))
- SET CNT=CNT+1
- if 'IEN!STOP
- QUIT
- Begin DoDot:4
- +10 IF 'SUMONLY
- WRITE $PIECE(^TMP("ORUNS",$JOB,LOC,PROV,IEN),U,2),?25,$PIECE(^(IEN),U,3),?50,$PIECE(^(IEN),U,4),?75,$PIECE(^(IEN),U,5),?81,$PIECE(^(IEN),U,6),?95,$PIECE(^(IEN),U,7),?110,$PIECE(^(IEN),U,8),!
- if $Y>(IOSL-4)
- DO HDR^ORS100
- if STOP
- QUIT
- +11 SET ^TMP("ORSTATS",$JOB,LOC,PROV)=CNT
- End DoDot:4
- End DoDot:3
- End DoDot:2
- +12 IF '$DATA(^TMP("ORUNS",$JOB,LOC))
- WRITE !!,"No unsigned orders found for "_LONER
- End DoDot:1
- +13 IF SORT=1
- DO SERV^ORS100B
- +14 IF SORT=5
- DO WHO^ORS100B
- +15 IF SORT=6
- DO DIV^ORS100B
- +16 IF 'STOP
- DO STATS^ORS100
- EXIT KILL ^TMP("ORUNS",$JOB),^TMP("ORSTATS",$JOB)
- +1 DO ^%ZISC
- +2 QUIT