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

AMHLEA1.m

Go to the documentation of this file.
  1. AMHLEA1 ; IHS/CMI/LAB - ADD NEW CHR ACTIVITY RECORDS ;
  1. ;;4.0;IHS BEHAVIORAL HEALTH;;MAY 14, 2010
  1. ;
  1. ;add new records
  1. ;get all items for a record, check record, file record
  1. ;if not complete record, issue warning and delete record
  1. BEGIN ;add adm record
  1. D GETTYPE
  1. I AMHPTYPE="" D EXIT Q
  1. D GETDATE
  1. I AMHDATE="" D EXIT Q
  1. D CREATE
  1. D EXIT
  1. Q
  1. GETTYPE ;EP
  1. S AMHPTYPE=""
  1. S DIR(0)="S^M:MENTAL HEALTH DEFAULTS;S:SOCIAL SERVICES DEFAULTS;C:CHEMICAL DEPENDENCY or ALCOHOL/SUBSTANCE ABUSE;O:OTHER",DIR("A")="Which set of defaults do you want to use in Data Entry" K DA D ^DIR K DIR
  1. Q:$D(DIRUT)
  1. S AMHPTYPE=Y
  1. Q
  1. GETDATE ;EP - GET DATE OF ENCOUNTER
  1. W !!
  1. S AMHDATE="",DIR(0)="DO^:"_DT_":EPTX",DIR("A")="Enter ENCOUNTER DATE" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. Q:$D(DIRUT)
  1. S AMHDATE=Y
  1. Q
  1. CREATE ;EP
  1. S AMHACTN=1
  1. S APCDOVRR=""
  1. K DD,D0,DO,DINUM,DIC,DA,DR S DIC(0)="EL",DIC="^AMHREC(",DLAYGO=9002011,DIADD=1,X=AMHDATE D FILE^DICN K DIC,DR,DIE,DIADD,DLAYGO,X,D0
  1. I Y=-1 W !!,$C(7),$C(7),"Behavioral Health Record is NOT complete!! Deleting Record.",! D PAUSE Q
  1. S AMHR=+Y,DIE="^AMHREC(",DA=AMHR,DR="5100///NOW",DR(2,9002011.5101)=".02////^S X=DUZ" D ^DIE K DIE,DA,DR
  1. D GETPROV
  1. S DA=AMHR,DIE="^AMHREC(",DR="[AMH ADD ADM RECORD]" D CALLDIE^AMHLEIN
  1. I $D(Y)!('$D(^AMHRPROV("AD",AMHR))) W !!,"Incomplete record!! Deleting record!!" D DEL G EXIT
  1. D GETPOV
  1. I '$D(^AMHRPRO("AD",AMHR))!('$D(^AMHRPROV("AD",AMHR))) W !!,"Incomplete record!! Deleting record!!" D DEL G EXIT
  1. S AMHOKAY=0 D RECCHECK^AMHLE2 I AMHOKAY W !,"Incomplete record!! Deleting record!!" D DEL G EXIT
  1. W ! S DIE="^AMHREC(",DR="8101",DA=AMHR D CALLDIE^AMHLEIN
  1. ;S X=$$ESIG^AMHESIG(AMHR)
  1. ;I X D ESIGGFI^AMHESIG
  1. D EXIT
  1. Q
  1. EXIT ;
  1. D ^XBFMK
  1. D EN^XBVK("AMH")
  1. Q
  1. DEL ;EP
  1. I $$IINTAKE^AMHLEDEL(AMHR) W !!,"This visit has an Initial Intake with Updates, it can not be deleted",!,"until the update documents have been deleted." D PAUSE Q
  1. S AMHVDLT=$P(^AMHREC(AMHR,0),U,16)
  1. S AMHRDEL=AMHR
  1. D EN^AMHLEDEL
  1. W !,"Record deleted." D PAUSE
  1. Q
  1. PAUSE ;EP
  1. S DIR(0)="EO",DIR("A")="Press enter to continue...." D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. Q
  1. GETPROV ;get providers
  1. K DIR,DIC,DA,DTOUT,DIRUT,DUOUT,DIC,X,Y S DIR("B")=$P(^VA(200,DUZ,0),U),DIR(0)="9002011.02,.01O",DIR("A")="Enter PRIMARY PROVIDER" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. Q:$D(DIRUT)
  1. Q:Y=""
  1. S X=+Y,DIC("DR")=".02////"_$G(AMHPAT)_";.03////"_AMHR_";.04///PRIMARY",DIC="^AMHRPROV(",DIC(0)="MLQ",DIADD=1,DLAYGO=9002011.02 K DD,DO D FILE^DICN K DIC,DA,DO,DD,D0,DG,DH,DI,DIW,DIU,DIADD,DIE,DQ,DLAYGO
  1. I Y=-1 W !!,"Creating Primary Provider entry failed!!!",$C(7),$C(7) H 2
  1. Q
  1. GETPOV ;
  1. D EN^XBNEW("EP^AMHLEA1","AMH*")
  1. Q
  1. EP ;EP - ask for POV and file each
  1. I 'AMHR W !!,"NO RECORD DEFINED!!" Q
  1. I '$D(^AMHREC(AMHR)) W !!,"NO RECORD!!" Q
  1. S APCDOVRR=""
  1. D POV
  1. D CHK
  1. Q
  1. CHK ;
  1. Q:$D(^AMHRPRO("AD",AMHR))
  1. W !!,$C(7),$C(7),"At least ONE POV is REQUIRED!!"
  1. S DIR(0)="Y",DIR("A")="Do you wish to exit and delete this record",DIR("B")="N" D ^DIR K DIR S:$D(DUOUT) DIRUT=1
  1. I $G(Y)=0 G EP
  1. Q
  1. POV ;
  1. S DIC("A")=$S($G(AMHGROUP):"Enter another Problem (POV): ",'$D(^AMHRPRO("AD",AMHR)):"Enter PRIMARY Problem-POV: ",1:"Enter ANOTHER Problem-POV: "),DIC("S")="I '$P(^(0),U,13)",DIC="^AMHPROB(",DIC(0)="AEMQ",DIC("B")=99
  1. W ! D ^DIC
  1. I Y=-1 D ^XBFMK Q
  1. S AMHPOV=$P(Y,U,2),AMHPOVP=+Y
  1. ;call FILE^DICN to file this POV
  1. FILE ;
  1. D ^XBFMK
  1. K DD,D0,DO,DINUM,DIC,DA,DR S DIC(0)="EL",DIC="^AMHRPRO(",DLAYGO=9002011.01,DIADD=1,X=AMHPOVP,DIC("DR")="" D FILE^DICN K DIC,DR,DIE,DIADD,DLAYGO,X,D0
  1. I Y=-1 D ^XBFMK W !!,$C(7),$C(7),"Behavioral Health POV failed!! Notify Site Manager." Q
  1. S AMHRPRO=+Y,AMHPOVR=^AMHRPRO(AMHRPRO,0)
  1. D ^XBFMK
  1. S DIE("NO^")="",DA=AMHRPRO,DIE="^AMHRPRO(",DR=".02////"_$G(AMHPAT)_";.03////"_AMHR_";.04 Provider Narrative.....:" S DIE("NO^")="" D CALLDIE^AMHLEIN
  1. S AMHPOVR=^AMHRPRO(AMHRPRO,0)
  1. I $P(AMHPOVR,U,4)="" S X=$E($P(^AMHPROB($P(AMHPOVR,U),0),U,2),1,79),X=$TR(X,";"," "),DIE="^AMHRPRO(",DR=".04///"_X,DA=AMHRPRO S DIE("NO^")="" D CALLDIE^AMHLEIN
  1. I $D(Y) D ^XBFMK W !!,$C(7),$C(7),"DIE failed when updating POV" D PAUSE^AMHLEA Q
  1. Q