source: FOIAVistA/trunk/r/INPATIENT_MEDICATIONS-PSJ-PSIV-PSG--PSGW/PSJ200.m@ 1608

Last change on this file since 1608 was 628, checked in by George Lilly, 15 years ago

initial load of FOIAVistA 6/30/08 version

File size: 4.2 KB
Line 
1PSJ200 ;BIR/RSB-UTILITY TO CORRECT CHANGED USER NAMES IN IV'S ;30 APR 97 / 8:39 AM
2 ;;5.0; INPATIENT MEDICATIONS ;;16 DEC 97
3 ; DO NOT DELETE THIS ROUTINE, IT IS CALLED BY MANY PROTOCOL
4 ; ENTRY ACTIONS TO CHANGE THE SCREEN LENGTH IN LISTMAN!
5 ;
6 I '$L($O(^XTMP("PSJ NEW PERSON",0))) D Q
7 .W !!," This option doesn't need to be run. All changed names in IVs have "
8 .W !," been corrected. Please have IRM remove this option from your menu."
9 I '$$PRIV Q
10 K PSJL,PSJPT,DUOUT,DTOUT
11 W @IOF,!," The following user names were found in IV orders. These names have either",!," been deleted, changed, or are duplicates in the NEW PERSON file.",!
12 S PSJL=0 F S PSJL=$O(^XTMP("PSJ NEW PERSON",PSJL)) Q:PSJL="" D
13 .W !?2,PSJL
14 W !!," Please do one of the following:"
15 W !," a. If the name has changed, pick the correct name from the NEW PERSON file."
16 W !," b. If the person has been deleted from the file, please see the appropriate",!?3," person to get this named added back into the NEW PERSON file and rerun this",!?3," option."
17 W !! S PSJL=0 F S PSJL=$O(^XTMP("PSJ NEW PERSON",PSJL)) Q:PSJL=""!($G(DUOUT)) D
18 .K PSJPT S PSJPT=$$200
19 .S:PSJPT=-1 PSJB=1 I PSJPT'=-1 S ^XTMP("PSJ NEW1",PSJL)=PSJPT
20 I '$D(PSJB) W !!," Finished. Please have IRM remove this option"
21 I W " (PSJI 200) from",!," your menu, as it is no longer needed."
22 E W !!,"Not all names have been corrected, PLEASE RERUN THIS OPTION!"
23 K PSJB,PSJC,PSJL,PSJPT,PSJDFN,PSJORD,PSJ1,PSJ2,PSJ3,PSJ4,PSJNUM
24 S ZTIO="",ZTRTN="SEARCH^PSJ200",ZTDESC="Correct names in IV orders"
25 S ZTDTH=$H D ^%ZTLOAD
26 Q
27200() ;
28201 K DUOUT,DTOUT W ! K DIC S DIC="^VA(200,",DIC(0)="AEMQ"
29 S DIC("A")=" Please select the correct name to replace "_PSJL_" : "
30 D ^DIC K DIC S PSJPT=Y
31 I +PSJPT'=-1 S DIR(0)="Y",DIR("A")="Are you sure "_$P(^VA(200,+Y,0),"^")_" is the correct choice" D ^DIR I Y=0 G 201
32 Q +PSJPT
33 ;
34PRIV() ;
35 I $D(^XUSEC("PSJI MGR",DUZ))
36 E W !," You must hold the PSJI MGR security to run this routine"
37 Q $T
38 ;
39SEARCH ;
40 F PSJ1=0 F S PSJ1=$O(^XTMP("PSJ NEW1",PSJ1)) Q:PSJ1="" D
41 .F PSJ2=0:0 S PSJ2=$O(^XTMP("PSJ NEW PERSON",PSJ1,PSJ2)) Q:'PSJ2 D
42 ..D CONVERT(PSJ2,0)
43 ..F PSJ3=0:0 S PSJ3=$O(^XTMP("PSJ NEW PERSON",PSJ1,PSJ2,PSJ3)) Q:'PSJ3 D
44 ...K DA,DIE S DIE="^PS(55,"_PSJ2_",""IV"",",DA(1)=PSJ2,DA=PSJ3
45 ...S DR="135////"_^XTMP("PSJ NEW1",PSJ1) D ^DIE K DIE,DA
46 ...S X=$P($G(^PS(55,PSJ2,"IV",PSJ3,0)),"^",21),PSOC=$S(X=0:"SN",X]"":"ZC",1:"SN") D EN1^PSJHL2(PSJ2,PSOC,PSJ3_"V")
47 ...K ^XTMP("PSJ NEW PERSON",PSJ1,PSJ2,PSJ3)
48 ...S PSJC=$S('$D(PSJC):1,1:PSJC+1) ;W:((PSJC#25)=0) "."
49 .K ^XTMP("PSJ NEW1",PSJ1)
50 D M S ZTIO="@" Q
51CONVERT(DFN,TYPE) ;
52 ; Convert existing UD orders to new format. Only run once/patient, and
53 ; only converts orders with a stop date<(5.0 Install date-365)
54 ; DFN = Patient IEN
55 ; TYPE = Background or Interactive mode
56 ;
57 I '$D(^PS(55,DFN,0)) Q
58 N ADS,ADS1,DDRG,ND,ON,ON1,PSOC,PSGDT,STAT,STPDT,STS,X,XX,X1,X2
59 D NOW^%DTC S X1=$P(%,"."),X2=-365 D C^%DTC S PSGDT=X
60 ;Convert and Backfill IV orders.
61 F STPDT=PSGDT:0 S STPDT=$O(^PS(55,DFN,"IV","AIS",STPDT)) Q:'STPDT F ON=0:0 S ON=$O(^PS(55,DFN,"IV","AIS",STPDT,ON)) Q:'ON I '$G(^PS(55,DFN,"IV",ON,.2)) D
62 .S ND=$G(^PS(55,DFN,"IV",ON,6)) F ADS="AD","SOL" S ADS1=$O(^PS(55,DFN,"IV",ON,ADS)) F ON1=0:0 S ON1=$O(^PS(55,DFN,"IV",ON,ADS,ON1)) Q:'ON1 Q:$G(^PS(55,DFN,"IV",ON,.2)) S XX=+$G(^PS(55,DFN,"IV",ON,ADS,ON1,0)) D
63 ..S:XX XX=$S(ADS="AD":$P($G(^PS(52.6,XX,0)),U,11),1:$P($G(^PS(52.7,XX,0)),U,11)) I XX I $P(^PS(50.7,XX,0),U,3)=1 S ^PS(55,DFN,"IV",ON,.2)=XX_U_$P(ND,U,2,3) W:TYPE "."
64 Q
65 ;
66M ; sends mail message when complete
67 I $L($O(^XTMP("PSJ NEW PERSON",0))) Q
68 K XMY S XMSUB="Changed names in IV orders",XMTEXT="PSJ1(",XMY(DUZ)=""
69 S XMDUZ="Inpatient Medications Version 5.0 install",PSJ1(1)=""
70 S PSJ1(2)="The process that has replaced the changed names in the IV orders has finished.",PSJ1(3)=""
71 S PSJ1(4)="Please have IRM remove this option (PSJI 200) from your menu, as it is no"
72 S PSJ1(5)="longer needed." D ^XMD K XMSUB,XMDUZ,XMTEXT,PSJ1 Q
73 ;
74A(LONG,SHORT,SHRINK) ; Resizes list area
75 ; copied this from TIU RESIZE^TIULM
76 N PSJBM S PSJBM=$S(VALMMENU:SHORT,+$G(SHRINK):SHORT,1:LONG)
77 I VALM("BM")'=PSJBM S VALMBCK="R" D
78 .S VALM("BM")=PSJBM,VALM("LINES")=(PSJBM-VALM("TM"))+1
79 .I +$G(VALMCC) D RESET^VALM4
80 Q
Note: See TracBrowser for help on using the repository browser.