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

LRCAPPH2.m

Go to the documentation of this file.
  1. LRCAPPH2 ;DALISC/FHS - CREATE OR MODIFY LAB LOCATIONS
  1. ;;5.2;LAB SERVICE;**138**;Sep 27, 1994
  1. EN ;
  1. S LRPKG=$O(^DIC(9.4,"B","LR",0))
  1. I 'LRPKG S LRPKG=$O(^DIC(9.4,"B","LAB SERVICE",0))
  1. I 'LRPKG W !!,$$CJ^XLFSTR("Not able to find 'LAB SERVICE' in your Package (#9.4) file.",80),!,$$CJ^XLFSTR("Contact your IRM Service !!",80),!!,$C(7) H 5 G END
  1. W !!,$$CJ^XLFSTR("List of already defined Laboratory OOS Locations",80),!
  1. S (CNT,I)=0 F S I=$O(^SC(I)) Q:I<1 I $P(^(I,0),U)["LAB DIV " S X=^(0) D
  1. . S CNT=CNT+1 W !,$P(X,U),?32,$P($G(^DIC(4,+$P(X,U,4),99)),U),?40,$P($G(^DIC(40.7,+$P(X,U,7),0)),U,2)
  1. W ! I 'CNT D G END
  1. . W !,$$CJ^XLFSTR("NONE ARE CURRENTLY DEFINED",80)
  1. . W !,$$CJ^XLFSTR("INSTALL PATCH LR*5.2*138",80),!
  1. K DIR S DIR("A")="Would you like a detail display ?",DIR("B")="No",DIR(0)="YAO" D ^DIR
  1. K DIR W !!
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))
  1. I Y=1 D DETAIL G EN
  1. DIV ;
  1. W !,$$CJ^XLFSTR(" You may define a new Laboratory OOS Location ",80),!
  1. K DIR,DIC S DIR(0)="PO^4:AQEZNM",DIR("A")="Enter New Division "
  1. S DIR("S")="I $G(^(99))" D ^DIR
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))
  1. G END:Y<1 S LRDIVN=+Y,LRDIV=$P($G(^DIC(4,+Y,99)),U)
  1. SCODE ;
  1. K DIR S DIR(0)="PO^40.7:AQEZNM",DIR("A")="Select Clinic Stop Code "
  1. S DIR("S")=$$EXEMPT^SCDXUAPI D ^DIR
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))
  1. G END:Y<1 S LRSCODE=$P(Y(0),U,2),LRSCODEN=+Y
  1. DIS ;
  1. S LRNAME="LAB DIV "_LRDIV_" OOS ID "_LRSCODE,LRNAME=$E(LRNAME,1,30)
  1. W !,$$CJ^XLFSTR("ONCE DEFINED - IT CAN NOT BE DELETED",80),!
  1. K DIR S DIR("A")=" ["_LRNAME_"] Is this the correct new name ? "
  1. S DIR("B")="No",DIR(0)="YAO" D ^DIR
  1. CHK ;
  1. K DIR W !!
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))
  1. G DIV:'Y
  1. I $D(^SC("B",LRNAME)) D G EN
  1. . W @IOF,!?20,LRNAME,!?5," This location is already defined ",!,$C(7)
  1. . D END0
  1. W @IOF D LOAD,END0 G DIV
  1. LOADB S LRNAME=$E(LRNAME,1,30) Q:$D(^SC("B",LRNAME))
  1. LOAD ;
  1. S X="SCDXUAPI" X ^%ZOSF("TEST") I '$T W !!,$$CJ^XLFSTR("Load SD*5.3*63 Patch",80),!! Q
  1. S LROK=$$LOC^SCDXUAPI(LRNAME,LRDIVN,LRSCODE,LRPKG,,)
  1. I $G(LRDBUG) W !,"LROK = ",LROK
  1. I LROK<1 W !!?5,$P(LROK,U,2),!,"LOCATION NOT CREATED",!,$C(7) Q
  1. D SHOW
  1. W !!,$$CJ^XLFSTR("LAB Location Added",80),!!
  1. Q:$G(LRDBUG) K DIC,DIE,DA,DIR
  1. Q
  1. SHOW K DA,DIC,DIE S DA=LROK,DIC="^SC(",DR="0:999999" W !! D EN^DIQ Q
  1. END ;
  1. Q:$G(LRDBUG)
  1. END0 K DA,DIC,DIR,DR,LRDIV,LRDIVN,LRNAME,LRSCODE,LRSCODEN,SCERR,S
  1. K LRAA,LRLOC
  1. Q
  1. DETAIL K DIR D 44
  1. G:$G(DTOUT)!($G(DIRUT))!($G(DUOUT)) DEND
  1. I Y>0 S LROK=+Y D SHOW G DETAIL
  1. DEND K DA,DIC,DIR,LROK Q
  1. ACC ;
  1. K DIR S DIR(0)="PO^68:AQEZNM",DIR("A")="Select Accession Area "
  1. D ^DIR
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))!(Y<1)
  1. S LRAA=Y
  1. S LROK=$G(^LRO(68,+LRAA,.8)) I LROK D
  1. . K DIR W @IOF,!,$$CJ^XLFSTR("Current Laboratory OOS Location",80),!
  1. . W $$CJ^XLFSTR("For [ "_$P(Y,U,2)_" ] Accession Area ",80)
  1. . D SHOW
  1. K DIR,LROK S:'$G(^LRO(68,+LRAA,.8)) DIR("B")=$P(^SC(+$G(^LAB(69.9,1,.8)),0),U) S DIR("A")="Select OOS Location for ["_$P(LRAA,U,2)_"] Acc Area " D 44
  1. I Y=-1 W !?10,"NO SELECTION MADE ",!! G ACC
  1. G END:$G(DTOUT)!($G(DIRUT))!($G(DUOUT))!(Y<1)
  1. S LRLOC=+Y
  1. K DIE,DA S DIE="^LRO(68,",DA=+LRAA,DR=".8////"_LRLOC D ^DIE
  1. W !?10,"DONE",! G ACC
  1. Q
  1. 44 ;
  1. K DIC S DIR(0)="PO^44:AQEZNM" S:'$D(DIR("A")) DIR("A")="Select Laboratory OOS Location " S DIR("S")="I $P(^(0),U)[""LAB DIV """
  1. D ^DIR
  1. Q