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

MCARGES.m

Go to the documentation of this file.
  1. MCARGES ;WISC/TJK-SCREEN ENTER/EDIT-ENDOSCOPY,HEMATOLOGY,PACEMAKER ;4/7/97 14:14
  1. ;;2.3;Medicine;**8,15,16**;09/13/1996
  1. START ;
  1. K EXIT,MCDEMO,MCESFL S MCESFL=1
  1. D ENTER I '$D(MCFILE)!('$D(MCARGDA)) D EXIT Q
  1. I '$D(^MCAR(MCFILE,MCARGDA,0)),$D(MCBACK) D BACKSS^MCESEDT K MCBACK S EXIT=1
  1. K:'$D(^MCAR(MCFILE,MCARGDA,0)) MCESFL D EXIT
  1. Q
  1. ENTER ; edit a GI procedure record and display/edit history if selected
  1. D DPT^MCARGE I $D(EXIT) Q
  1. I MCARCODE="G"!(MCARCODE="P") S MCDEMO=1 D DEMO^MCARGE
  1. ;if user wants to edit patient history in patient file
  1. I $D(MCDEMO) D
  1. .S DJSC="MCGDEM",DIC="MCAR(690,",DJDN=DFN,DIC(0)="EQ" D EN^MCARD
  1. .S:$D(DUOUT) EXIT=1
  1. .I '$D(EXIT),$D(^DIC(120.8)) N VADM D EN2^GMRAPEM0
  1. .K MCDEMO
  1. .;restore the procedure record number after patient lookup in 690
  1. .S MCARGDA=+$G(MCARDA)
  1. Q:$D(EXIT) D EDIT Q
  1. EDIT D:MCARCODE="G" SETVAR^MCARGE K DIC
  1. S DJSC=MCEPROC
  1. S DJDN=MCARGDA,DIC="^MCAR("_MCFILE_","
  1. S DIC(0)="EQ"
  1. D IN^MCEO
  1. I $D(DTOUT)!$D(DUOUT) S EXIT=1 Q
  1. D EN^MCARD
  1. I $D(DUOUT) S EXIT=1 Q
  1. I '$D(^MCAR(MCFILE,MCARGDA,0)) S EXIT=1 Q
  1. S MCDFLAG="" I MCARGNAM'="NON-ENDO" D ^MCARGD
  1. D OUT^MCEO
  1. Q
  1. CONSULT ;
  1. K DIC S MCDFLAG="" D CONSULT^MCARGE
  1. G EXIT:$D(DTOUT),EXIT:$D(DUOUT) I $D(Y),Y<0 G EXIT
  1. S DJSC=$S($G(MCBS)=1:"MCCONSULTBR",1:"MCCONSULT")
  1. S DIC="^MCAR(699.5,",DJDN=MCARGDA,DIC(0)="EQ",MCFILE=699.5 D IN^MCEO G EXIT:$D(DTOUT)!$D(DUOUT) D EN^MCARD,OUT^MCEO
  1. EXIT ;
  1. I '$D(DTOUT),'$D(DUOUT),$D(MCESFL),$D(MCFILE),$D(MCARGDA),MCESON D:MCESFL=0 ESRC^MCESSCR(MCFILE,MCARGDA)
  1. K AV,MULTI,EXIT,X,MCPRO,MCEPROC,MCPATNM D EXIT^MCARGE
  1. Q
  1. GENEX(MCARGDA,GENEX) ;Check and resolve non-associated procedures
  1. I ('$P(^MCAR(699.5,MCARGDA,0),U,2)!'$P(^(0),U,6)) S DIK="^MCAR(699.5,",DA=MCARGDA,GENEX=1 D ^DIK Q
  1. Q
  1. GENERIC ;Generic Medicine Enter/Edit
  1. W !,"GENERIC EDIT"
  1. N GENEX S GENEX=0
  1. D MCEPROC^MCARE,^MCAREH
  1. S DIC="^MCAR(699.5,",DIC(0)="AEQLM",(DLAYGO,DIDEL,MCFILE)=699.5,DIC("S")="I '$P(^MCAR(699.5,+Y,0),U,3)"
  1. S DR=".01;.02;.05" D ^DIC G EXIT:Y<0 S MCARGDA=+Y,MCESFL=0
  1. D GENEX(MCARGDA,.GENEX) G:GENEX EXIT
  1. ; allow user to edit .01 field
  1. I MCESON,("125"'[$$ESTONUM^MCESSCR(MCFILE,MCARGDA)) D ESRC^MCESSCR(MCFILE,.MCARGDA) G:$D(MCBACK) SETUP K DIC Q
  1. SUPS S DIE="^MCAR(699.5,",DA=MCARGDA,DR=".01;.02;.05" D ^DIE
  1. I $D(DA) D GENEX(MCARGDA,.GENEX) G:GENEX EXIT
  1. I $D(DTOUT)!$D(DUOUT)!'$D(DA) G EXIT
  1. S MCARGNUM=$P(^MCAR(699.5,MCARGDA,0),U,6),DFN=$P(^(0),U,2)
  1. S DJSC=MCEPROC
  1. S MCARGNAM=$P(^MCAR(699.5,MCARGDA,0),U),DJDN=MCARGDA,DIC="^MCAR(699.5,",DIC(0)="EQ"
  1. S MCHOLD=MCARGDA
  1. ;D IN^MCEO G EXIT:$D(DTOUT)!$D(DUOUT) D EN^MCARD S MCARGDA=MCHOLD D GENEX(MCARGDA,.GENEX) K MCHOLD G:GENEX EXIT
  1. D IN^MCEO G EXIT:$D(DUOUT) D EN^MCARD S MCARGDA=MCHOLD D GENEX(MCARGDA,.GENEX) K MCHOLD ;MC*2.3*8
  1. D OUT^MCEO,QTASK^MCPARAM G EXIT
  1. ;
  1. HEM S DIC="^MCAR(694,",DIC(0)="AEQLM",(DLAYGO,DIDEL,MCFILE)=694 D ^DIC G EXIT:Y<0
  1. S MCARGDA=+Y I $D(DTOUT),('$P(^MCAR(694,+Y,0),U,2))!('$P(^(0),U,3)) S DIK="^MCAR(694,",DA=MCARGDA D ^DIK W "??" G EXIT
  1. S MCARGNUM=$P(^MCAR(694,MCARGDA,0),U,3),DFN=$P(^(0),U,2),DJSC=MCEPROC
  1. S MCARGNAM=$P(^MCAR(697.2,MCARGNUM,0),U),DJDN=MCARGDA,DIC="^MCAR(694,",DIC(0)="EQ"
  1. G EXIT:$D(DTOUT)!$D(DUOUT) D EN^MCARD,QTASK^MCPARAM G EXIT
  1. MULTI K MULTI S MULTI="",MCARGDA=-1 D GEN G EXIT:$D(DTOUT),EXIT:$D(DUOUT),EXIT:'$G(MCARGDA)
  1. S AV=$G(^MCAR(698,MCARGDA,0)),DFN=$P(AV,U,2),AV=$P(AV,U,7) G EXIT:AV=""!("AV"'[AV)
  1. K DIC S DIC("S")="I $P(^(0),U,2)=DFN" D ALEAD:AV["A" G EXIT:$D(DUOUT)!($D(DTOUT))
  1. K DIC S DIC("S")="I $P(^(0),U,2)=DFN" D VLEAD:AV["V" G EXIT
  1. GEN S MCFILE=698
  1. S MCPRO="GEN.IMPL." D MCEPROC^MCARE S MCARGNUM=MCARGNAM,MCARGNAM="GENERATOR IMPLANT" G LOOK
  1. VLEAD S MCFILE=698.1
  1. D:$D(MULTI) LAST^MCARPACE
  1. S MCPRO="V-LEAD IMP" D MCEPROC^MCARE S MCARGNUM=MCARGNAM,MCARGNAM="VENTRICAL LEAD IMPLANT" G LOOK
  1. ALEAD S MCFILE=698.2
  1. D:$D(MULTI) LAST^MCARPACE
  1. S MCPRO="A-LEAD IMP" D MCEPROC^MCARE S MCARGNUM=MCARGNAM,MCARGNAM="ATRIAL LEAD IMPLANT" G LOOK
  1. DEMO ;
  1. W @IOF,!!!,"DEMOGRAPHIC INFORMATION *** SCREEN EDIT ***",!!!
  1. D
  1. .N DLAYGO
  1. .S DLAYGO=690,DIC="^MCAR(690,",DIC(0)="AEQLM",DIC("B")=$G(MCPATNM)
  1. .D ^DIC
  1. .Q
  1. G EXIT:Y<0
  1. S (DJDN,MCARGDA)=+Y,DJSC="MCPACEDEMO",DIC(0)="EQ" D EN^MCARD
  1. ;get new default patient name
  1. S MCX=$$VALUE^MCENDIQ1(690,MCARGDA,.01)
  1. I MCX'="" S MCPATNM=MCX
  1. G EXIT
  1. LOOK ;
  1. W @IOF,!!!,MCARGNAM," PROCEDURES *** SCREEN EDIT ***",!!!
  1. S DIC="^MCAR("_MCFILE_",",DIC(0)="AEQLM"
  1. S DIC("A")="Enter patient name, or date and time: "
  1. ;S DIC("B")=$G(MCPATNM)
  1. S (DLAYGO,DIDEL)=MCFILE D ^DIC G EX:Y<0
  1. ;
  1. ; NOTE: next line must define DFN for Order Entry to work
  1. S MCARGDA=+Y,DFN=$P($G(^MCAR(MCFILE,MCARGDA,0)),U,2) I $D(DTOUT),'DFN S DIK=DIC,DA=MCARGDA D ^DIK G EX
  1. S MCARGNUM=$O(^MCAR(697.2,"BA",MCARGNAM,0))
  1. S DJSC=MCEPROC
  1. S MCARGNAM=$P(^MCAR(697.2,MCARGNUM,0),U),DJDN=MCARGDA,DIC(0)="EQ" D IN^MCEO G EXIT:$D(DTOUT)!$D(DUOUT) D EN^MCARD,OUT^MCEO
  1. ;get new default patient name
  1. S MCX=$$VALUE^MCENDIQ1(MCFILE,MCARGDA,1)
  1. I MCX'="" S MCPATNM=MCX
  1. EX Q:$D(MULTI) G EXIT
  1. SETUP ; If the record is superseded, the user will be allow to edit the superseded record.
  1. S Y=MCY,DA=Y,Y(0)=MCY(0),Y(0,0)=MCY(0,0),MCARGDA=+MCY K MCY,DTOUT,DIROUT,DUOUT,DIC
  1. G SUPS