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

SDWLBACC.m

Go to the documentation of this file.
SDWLBACC ;;IOFO BAY PINES/OG - BATCH CHANGE EWL CLINIC  ; Compiled August 14, 2007 11:20:57
 ;;5.3;scheduling;**446,1015**;AUG 13 1993;Build 21
 ;
 ;  ******************************************************************
 ;  CHANGE LOG
 ;       
 ;   DATE         PATCH    DESCRIPTION
 ;   ----         -----    -----------
 ;   
 ;
 N SDWLERR,SDWLOPT,SDWLSCL,SDWLHD,SDWLIN1,SDWLIN2,SDWLCL0,SDWLCL1,SDWLCL2,SDWLCSC1,SDWLCSC2,SDWLCM
 S SDWLHD="Scheduling/PCMM Batch Change EWL Clinic"
 W:$D(IOF) @IOF W !?80-$L(SDWLHD)\2,SDWLHD,!
 S SDWLERR=0,SDWLOPT=1,(SDWLIN2,SDWLCL1,SDWLCL2,SDWLCM)="",SDWLIN1=+$$SITE^VASITE()
 F  D @("P"_SDWLOPT) Q:'SDWLOPT
 Q
P1 ; Source Institution
 S DIR(0)="PAO^DIC(4,:EMNZ"
 S DIR("A")="Select Source Institution: "
 I SDWLIN1'="" S DIR("B")=$$GET1^DIQ(4,SDWLIN1,.01)
 S DIR("S")="I $E($$GET1^DIQ(4,+Y,99),1,3)=$E(+$P($$SITE^VASITE(),U,3),1,3)"
 D ^DIR
 I Y<1 S SDWLOPT=0 Q
 S (SDWLIN1,SDWLIN2)=+Y,SDWLOPT=SDWLOPT+1
 Q
P2 ; Source Clinic
 N DIR,SDWLSC
 S DIR(0)="PAO^SDWL(409.32,:EMNZ"
 S DIR("A")="Select Source Clinic: "
 I SDWLCL1'="" S DIR("B")=$$GET1^DIQ(409.32,SDWLCL1,.01)
 S DIR("S")="S X=$$GET1^DIQ(409.32,+Y,.01,""I"") I $P($$CLIN^SDWLBACC(X),U)=SDWLIN1"
 D ^DIR
 I Y="^" S SDWLOPT=0 Q
 I Y<1 S SDWLOPT=SDWLOPT-1 Q
 S SDWLCL0=+Y  ; Wait list specific clinic
 S SDWLCL1=$P(Y,U,2)  ; pointer to HOSPITAL LOCATION file
 S SDWLCSC1=$$GET1^DIQ(44,SDWLCL1,8,"I")_U_$$GET1^DIQ(44,SDWLCL1,8) ; Clinic stop code
 S SDWLOPT=SDWLOPT+1
 Q
P3 ; Destination Institution
 S DIR(0)="PAO^DIC(4,:EMNZ"
 S DIR("A")="Select Destination Institution: "
 I SDWLIN1'="" S DIR("B")=$$GET1^DIQ(4,SDWLIN2,.01)
 S DIR("S")="I $E($$GET1^DIQ(4,+Y,99),1,3)=$E(+$P($$SITE^VASITE(),U,3),1,3)"
 D ^DIR
 I Y="^" S SDWLOPT=0 Q
 I Y<1 S SDWLOPT=SDWLOPT-1 Q
 S SDWLIN2=+Y,SDWLOPT=SDWLOPT+1
 Q
P4 ; Destination Clinic
 N DIR,SDWLSC,SDWLY
 S DIR(0)="PAO^SDWL(409.32,:EMNZ"
 S DIR("A")="Select Destination Clinic: "
 I SDWLCL2'="" S DIR("B")=$$GET1^DIQ(409.32,SDWLCL2,.01)
 S DIR("S")="S X=$$GET1^DIQ(409.32,+Y,.01,""I"") I $P($$CLIN^SDWLBACC(X),U)=SDWLIN2,+Y'=SDWLCL0"
 D ^DIR
 I Y="^" S SDWLOPT=0 Q
 I Y<1 S SDWLOPT=SDWLOPT-1 Q
 S SDWLY=+Y,SDWLSC=$P(Y,U,2)  ; pointer to HOSPITAL LOCATION file
 ; get clinic's stop code. warn if different.
 S SDWLCSC2=$$GET1^DIQ(44,SDWLSC,8,"I")_U_$$GET1^DIQ(44,SDWLSC,8)  ; Clinic's stop code
 I +SDWLCSC1'=+SDWLCSC2 D  Q:'Y
 .S DIR(0)="Y"
 .S DIR("A")="The clinics' stop codes are different, continue"
 .S DIR("A",1)=$$GET1^DIQ(409.32,SDWLCL1,.01)_": "_$P(SDWLCSC1,U,2)_" ("_+SDWLCSC1_")"
 .S DIR("A",2)=$$GET1^DIQ(409.32,+Y,.01)_": "_$P(SDWLCSC2,U,2)_" ("_+SDWLCSC2_")"
 .S DIR("B")="YES"
 .D ^DIR
 .S:Y="^" SDWLOPT=0
 .Q
 S SDWLSCL=SDWLY,SDWLOPT=SDWLOPT+1
 Q
P5 ; Comment
 D P4^SDWLE6
 Q
P6 ; Confirmation and processing
 N DIR,Y
 S DIR(0)="Y"
 S DIR("A")="Proceed with batch clinic change"
 S DIR("B")="YES"
 D ^DIR
 D:Y CHNGCL
 S SDWLOPT=0
 Q
CHNGCL ;
 N DIR,SDWLDA,SDWLCNT
 S SDWLDA="",SDWLCNT=0
 F  S SDWLDA=$O(^SDWL(409.3,"SC",SDWLCL1,SDWLDA)) Q:'SDWLDA  D
 .N DA,DIE,DIR,DR,SDWLDFN,SDWLIN,SDWLTMP,SDWLORDT,SDWLSCPG,SDWLSCPR,SDWLCL1,SDWLDDT,SDWLEEST,Y
 .D GETS^DIQ(409.3,SDWLDA_",","1;14;15;22;23;27","I","SDWLTMP")
 .Q:SDWLTMP(409.3,SDWLDA_",",23,"I")="C"  ; Only open entries.
 .S SDWLDFN=$$GET1^DIQ(409.3,SDWLDA,.01,"I")
 .S SDWLORDT=SDWLTMP(409.3,SDWLDA_",",1,"I")
 .S SDWLSCPG=SDWLTMP(409.3,SDWLDA_",",14,"I")
 .S SDWLSCPR=SDWLTMP(409.3,SDWLDA_",",15,"I")
 .S SDWLDDT=SDWLTMP(409.3,SDWLDA_",",22,"I")
 .S SDWLEEST=SDWLTMP(409.3,SDWLDA_",",27,"I")
 .Q:'$$UPDATE^SDWLE7(SDWLDFN,SDWLORDT,SDWLIN2,SDWLSCL,SDWLSCPG,SDWLSCPR,SDWLDDT,SDWLCM,SDWLEEST,SDWLDA)
 .; disposition old entry
 .S DIE="^SDWL(409.3,",DA=SDWLDA,DR="19////^S X=DT;20////^S X=DUZ;21////^S X=""CL"";23////^S X=""C"""
 .D ^DIE
 .S SDWLCNT=SDWLCNT+1
 .Q
 W ! W:SDWLCNT "Clinics changed. " W SDWLCNT," entries processed."
 S DIR(0)="E" D ^DIR
 Q
CLIN(CL) ;identify clinic institution through DIVISON ----> INSTITUTION path.
 ; function to return: 
 ;        - Institution pointer to ^DIC(4 _U_ STATION number (# 99) _U_ Inst Name _U_ Div Pointer to ^DG(40.8 _U_N/L_U_Message
 ;           ( INST^STA NUM^SNAM^DIV^N/L^MESS )
 ;           N/L - N -National/L -Local
 ;           with Message:
 ;           - if STA="" INST^^SNAM^DIV^^N/L^' - No Station Number on file'
 ;          or
 ;        -  0^^^DIV^^' - No Institution has been identified'
 ;        -  0^^^-1^^'  - no Division has been identified'
 ;        - -1 no clinic on file'
 I '$D(^SC(+CL)) Q -1_"^^^^^no clinic on file"
 N SDWMES,STN,DIV,INS,SNL,STR,SNAM S SDWMES="",STN=""
 S DIV=+$$GET1^DIQ(44,CL_",",3.5,"I")
 I DIV=0 S SDWMES="no Division has been identified" Q 0_"^^^"_-1_"^^"_SDWMES
 S INS=+$$GET1^DIQ(40.8,DIV_",",.07,"I")
 I INS=0 S SDWMES="No Institution has been identified" Q 0_"^^^"_DIV_"^"_SDWMES
 E  S STR=$$NS^XUAF4(INS),STN=$P(STR,U,2),SNAM=$P(STR,U) ;station number and name
 I STN="" S SDWMES="No Station Number on file"
 I '$$TF^XUAF4(INS) S SDWMES="Inactive treating medical facility"
 S SNL=$$GET1^DIQ(4,INS_",",11,"I")
 Q INS_U_STN_U_SNAM_U_DIV_U_SNL_U_SDWMES