| 1 | RMPORPT ;(NG)/DG/CAP /HINES CIOFO/HNC - Home Oxygen Primary Item Report ;7/24/98
|
---|
| 2 | ;;3.0;PROSTHETICS;**29,46**;Feb 09, 1996
|
---|
| 3 | SITE ;Set up site variables.
|
---|
| 4 | D HOSITE^RMPOUTL0 I '$D(RMPOXITE) Q
|
---|
| 5 | ;
|
---|
| 6 | LI ;List the sought patient.
|
---|
| 7 | N PBREAK,NBREAK S (PBREAK,NBREAK)=""
|
---|
| 8 | S DIC="^RMPR(665,"
|
---|
| 9 | S BY(0)="^TMP($J,",L(0)=3
|
---|
| 10 | S DIS(0)="I $P($G(^RMPR(665,D0,""RMPOA"")),U,7)=RMPOXITE,$P($G(^RMPR(665,D0,""RMPOA"")),U,2)'="""",$P($G(^RMPR(665,D0,""RMPOA"")),U,3)="""""
|
---|
| 11 | S L=0,FR="",(PAGE,RMEND,RMPORPT)=0
|
---|
| 12 | S $P(SPACE," ",80)="",COUNT=0
|
---|
| 13 | D NOW^%DTC
|
---|
| 14 | S Y=% X ^DD("DD") S RPTDT=$P(Y,"@",1)_" "_$P($P(Y,"@",2),":",1,2)
|
---|
| 15 | S DHD="W ?0 D RPTHDR^RMPORPT"
|
---|
| 16 | S DIOEND="I $G(Y)'[U S COUNT=$E("" "",1,(6-$L(COUNT)))_COUNT W !!,?50,""Total Patients: "",COUNT S RMEND=1 S:IOST[""P-"" RMPORPT=1"
|
---|
| 17 | ;S DIOEND="S:$G(Y)[U RMEND=1 I '$G(RMEND) S COUNT=$E("" "",1,(6-$L(COUNT)))_COUNT W !!,?50,""Total Patients: "",COUNT"
|
---|
| 18 | S FLDS="D PBREAK^RMPORPT,.01;C1;L18;""PATIENT"",D SSN^RMPORPT W X;C20;R4;""SSN"",D IT^RMPORPT W X;C27;L30;"""""
|
---|
| 19 | S FLDS(1)="D QTY^RMPORPT W X;C60;L2;""QTY"",D UCOST^RMPORPT W X;C63;""UNIT COST"",D TCOST^RMPORPT W X;C72;""TOTAL COST"""
|
---|
| 20 | D SORT
|
---|
| 21 | D EN1^DIP
|
---|
| 22 | I RMPORPT=0,$G(RMEND) K DIR S DIR(0)="E" D ^DIR
|
---|
| 23 | EXIT ;
|
---|
| 24 | ;K SPACE,RB,COUNT,PAGE,RMPOF,RPTDT,^TMP($J,"RMPORPT")
|
---|
| 25 | ;K FRMDT,TODT,Y,VA,VADM,DFN,RCOST,RNAM,XIOSL,UCOST
|
---|
| 26 | K ^TMP($J) N RMPR,RMPRSITE D KILL^XUSCLEAN
|
---|
| 27 | Q
|
---|
| 28 | CNT ;COUNT NAMES
|
---|
| 29 | I X'="" S COUNT=COUNT+1
|
---|
| 30 | Q
|
---|
| 31 | PBREAK ;Print the break of primary items.
|
---|
| 32 | D IT^RMPORPT
|
---|
| 33 | I PBREAK'=NBREAK W !,"Primary Item: ",PBREAK,! S NBREAK=PBREAK
|
---|
| 34 | Q
|
---|
| 35 | ;
|
---|
| 36 | SSN ;GET SSN
|
---|
| 37 | S X=""
|
---|
| 38 | K VA,VADM S DFN=D0 D ^VADPT
|
---|
| 39 | S RNAM=$E(VADM(1),1,22)_"^"_$P(VA("PID"),"-",3)
|
---|
| 40 | S X=$P(VA("PID"),"-",3)
|
---|
| 41 | D CNT
|
---|
| 42 | Q
|
---|
| 43 | IT ;Get the primary Item.
|
---|
| 44 | S (X,UCOST,QTY)="" N RR,RA S (RR,RA)=0
|
---|
| 45 | F S RA=$O(^RMPR(665,D0,"RMPOC",RA)) Q:RA="" I $P($G(^RMPR(665,D0,"RMPOC",RA,0)),U,11)="Y" D Q
|
---|
| 46 | . ; PROSTHETICS PATIENT FILE
|
---|
| 47 | . S RR=$P(^RMPR(665,D0,"RMPOC",RA,0),U)
|
---|
| 48 | . S UCOST=$P(^RMPR(665,D0,"RMPOC",RA,0),U,4)
|
---|
| 49 | . S QTY=$P(^RMPR(665,D0,"RMPOC",RA,0),U,3)
|
---|
| 50 | . ;PROS ITEM FILE
|
---|
| 51 | . S RR=$P(^RMPR(661,RR,0),U)
|
---|
| 52 | . ; ITEM MASTER FILE
|
---|
| 53 | . S RR=$P(^PRC(441,RR,0),"^",2)
|
---|
| 54 | . S X=$E(RR,1,30)
|
---|
| 55 | . S PBREAK=X
|
---|
| 56 | Q
|
---|
| 57 | ;
|
---|
| 58 | QTY ;Get the quntity of the primary item.
|
---|
| 59 | S X=""
|
---|
| 60 | S X=QTY
|
---|
| 61 | Q
|
---|
| 62 | ;
|
---|
| 63 | UCOST ;Get the unit cost of the primary item.
|
---|
| 64 | S X=""
|
---|
| 65 | S X=$J(UCOST,7,2)
|
---|
| 66 | Q
|
---|
| 67 | ;
|
---|
| 68 | TCOST ;Calculate the total cost of the primary item.
|
---|
| 69 | S X=""
|
---|
| 70 | S X=QTY*UCOST,X=$J(X,8,2)
|
---|
| 71 | Q
|
---|
| 72 | ;
|
---|
| 73 | ZPAGE(RY) ;Print page.
|
---|
| 74 | I ($Y+RY)<IOSL Q
|
---|
| 75 | S RKO="ZL DIO2 X ^TMP($J,1) ZL RMPORPT" X RKO K RKO
|
---|
| 76 | Q
|
---|
| 77 | ;
|
---|
| 78 | RPTHDR ;Report header.
|
---|
| 79 | N RA S RA=RMPO("NAME"),PAGE=PAGE+1
|
---|
| 80 | W RPTDT,?(40-($L(RA)/2)),RA,?72,"Page: "_PAGE
|
---|
| 81 | W !?23,"Primary Item Report",!
|
---|
| 82 | W !?64,"Unit",?73,"Total"
|
---|
| 83 | W !,"Patient",?20,"SSN",?26,"Primary Item",?58,"Qty"
|
---|
| 84 | W ?64,"Cost",?74,"Cost"
|
---|
| 85 | W !,"=================",?19,"====",?26,"=============================="
|
---|
| 86 | W ?58,"===",?64,"======",?73,"======"
|
---|
| 87 | W !
|
---|
| 88 | Q
|
---|
| 89 | ;
|
---|
| 90 | SORT ;Sort patient by primary item and patient name.
|
---|
| 91 | N D0,X,Y,UCOST,QTY,PBREAK
|
---|
| 92 | S (X,Y,UCOST,QTY,PBREAK)=""
|
---|
| 93 | S D2=0
|
---|
| 94 | ST F S D2=$O(^RMPR(665,"AHO",D2)) Q:D2="" D
|
---|
| 95 | .S D0="" F S D0=$O(^RMPR(665,"AHO",D2,D0)) Q:D0="" D
|
---|
| 96 | ..S DFN=$P($G(^RMPR(665,D0,0)),U,1)
|
---|
| 97 | ..K VADM D ^VADPT S Y=VADM(1)
|
---|
| 98 | ..D IT S:X'="" ^TMP($J,X,Y,D0)=""
|
---|
| 99 | Q
|
---|
| 100 | ;
|
---|