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

QAOSCKEY.m

Go to the documentation of this file.
  1. QAOSCKEY ;HISC/DAD-ALLOCATE/DEALLOCATE CLINICAL REVIEWER KEY ;11/9/92 10:38
  1. ;;3.0;Occurrence Screen;;09/14/1993
  1. S QAOSCLIN(0)="QAOSCLIN",QAOSCLIN=+$O(^DIC(19.1,"B",QAOSCLIN(0),0))
  1. I $P($G(^DIC(19.1,QAOSCLIN,0)),"^")'=QAOSCLIN(0) D G EXIT
  1. . W !!?5,"*** The Clinical Reviewer key was not found !! ***",*7
  1. . Q
  1. K ^TMP($J,"QAOSCLIN ADD"),^TMP($J,"QAOSCLIN DEL") S QAOCOUNT=0
  1. W !!,"Checking for current holders of the Clinical Reviewer key"
  1. F QAOSDUZ=0:0 S QAOSDUZ=$O(^XUSEC(QAOSCLIN(0),QAOSDUZ)) Q:QAOSDUZ'>0 D
  1. . W "." S X=$G(^VA(200,QAOSDUZ,0))
  1. . I $P(X,"^")]"" D
  1. .. S ^TMP($J,"QAOSCLIN ADD",$P(X,"^"),QAOSDUZ)=""
  1. .. S QAOCOUNT=QAOCOUNT+1
  1. .. Q
  1. . Q
  1. W !,QAOCOUNT," found. " W:QAOCOUNT "Type a '?' to list their names."
  1. ASK ;
  1. R !!,"Select CLINICAL REVIEWER: ",X:DTIME S:'$T X="^"
  1. G EXIT:$E(X)="^",OK:X=""
  1. S QADELETE=($E(X)="-"),X=$S(QADELETE:$E(X,2,999),1:X)
  1. I $E(X)="?" D HELP G ASK
  1. S DIC="^VA(200,",DIC(0)="EMNQZ" D ^DIC K DIC G:Y'>0 ASK
  1. S QAOSDUZ=+Y,QAOSDUZ(0)=$P(Y(0),"^")
  1. I QAOSDUZ(0)="" W " ??",*7 G ASK
  1. I QADELETE D
  1. . I $D(^TMP($J,"QAOSCLIN ADD",QAOSDUZ(0),QAOSDUZ))[0 W " ??",*7 Q
  1. . S ^TMP($J,"QAOSCLIN DEL",QAOSDUZ(0),QAOSDUZ)=""
  1. . K ^TMP($J,"QAOSCLIN ADD",QAOSDUZ(0),QAOSDUZ)
  1. . Q
  1. E D
  1. . S ^TMP($J,"QAOSCLIN ADD",QAOSDUZ(0),QAOSDUZ)=""
  1. . K ^TMP($J,"QAOSCLIN DEL",QAOSDUZ(0),QAOSDUZ)
  1. . Q
  1. G ASK
  1. OK ;
  1. I $O(^TMP($J,"QAOSCLIN ADD",""))="",$O(^TMP($J,"QAOSCLIN DEL",""))="" W !!?3,"*** No Clinical Reviewers selected !! ***",*7 G EXIT
  1. ASKOK W !!,"Allocate / Deallocate Clinical Reviewer key"
  1. S %=2 D YN^DICN G:(%=-1)!(%=2) EXIT
  1. I '% W !!?5,"Please answer Y(es) or N(o)" G ASKOK
  1. DOIT ; Entry point from postinit: convert file #741.3
  1. W !!,"Allocating key:"
  1. I $O(^TMP($J,"QAOSCLIN ADD",""))]"" D
  1. . S QAOSDUZ(0)=""
  1. . F S QAOSDUZ(0)=$O(^TMP($J,"QAOSCLIN ADD",QAOSDUZ(0))) Q:QAOSDUZ(0)="" F QAOSDUZ=0:0 S QAOSDUZ=$O(^TMP($J,"QAOSCLIN ADD",QAOSDUZ(0),QAOSDUZ)) Q:QAOSDUZ'>0 D
  1. .. K DD,DIC,DINUM,DO
  1. .. S:$D(^VA(200,QAOSDUZ,51,0))[0 ^(0)="^200.051PA^^"
  1. .. S DA(1)=QAOSDUZ,DIC="^VA(200,"_QAOSDUZ_",51,"
  1. .. S DIC(0)="LM",DLAYGO=200,(X,DINUM)=QAOSCLIN
  1. .. D:$O(^VA(200,QAOSDUZ,51,"B",QAOSCLIN,0))'>0 FILE^DICN
  1. .. W !?3,QAOSDUZ(0)
  1. .. Q
  1. . Q
  1. E W !?3,"*** None ***"
  1. W !!,"Deallocating key:"
  1. I $O(^TMP($J,"QAOSCLIN DEL",""))]"" D
  1. . S QAOSDUZ(0)=""
  1. . F S QAOSDUZ(0)=$O(^TMP($J,"QAOSCLIN DEL",QAOSDUZ(0))) Q:QAOSDUZ(0)="" F QAOSDUZ=0:0 S QAOSDUZ=$O(^TMP($J,"QAOSCLIN DEL",QAOSDUZ(0),QAOSDUZ)) Q:QAOSDUZ'>0 D
  1. .. F QAOSD1=0:0 S QAOSD1=$O(^VA(200,QAOSDUZ,51,"B",QAOSCLIN,QAOSD1)) Q:QAOSD1'>0 D
  1. ... S DA(1)=QAOSDUZ,DA=QAOSD1,DIDEL=200
  1. ... S DIK="^VA(200,"_QAOSDUZ_",51,"
  1. ... D ^DIK
  1. ... Q
  1. .. W !?3,QAOSDUZ(0)
  1. .. Q
  1. . Q
  1. E W !?3,"*** None ***"
  1. EXIT ;
  1. K %,D,DA,DD,DIC,DIDEL,DIK,DINUM,DIR,DLAYGO,DO,DZ,QADELETE
  1. K QAOCOUNT,QAOSCLIN,QAOSD1,QAOSDUZ,QAOSLINE,QAOSLIST,X,Y
  1. K ^TMP($J,"QAOSCLIN ADD"),^TMP($J,"QAOSCLIN DEL")
  1. Q
  1. HELP ;
  1. W !!," Enter the name of a Clinical Reviewer to add to the list."
  1. W !," Enter a minus (-) Clinical Reviewer name to remove a name"
  1. W " from the list."
  1. W !!,"Clinical Reviewers selected for key ALLOCATION:" D HLP("ADD")
  1. W !!,"Clinical Reviewers selected for key DEALLOCATION:" D HLP("DEL")
  1. Q:X'?1"??".E
  1. K DIR S DIR(0)="E" W ! D ^DIR K DIR Q:Y'>0
  1. S DIC="^VA(200,",DIC(0)="AEMNQ",D="B",DZ="??" D DQ^DICQ
  1. Q
  1. HLP(QAOSLIST) ; DISPLAY CLINICAL REVIEWERS
  1. N DIR,QAOSLINE,QAOSDUZ,X,Y
  1. S QAOSLIST="QAOSCLIN "_QAOSLIST
  1. I $O(^TMP($J,QAOSLIST,""))]"" D
  1. . S QAOSLINE=$Y,Y=1,QAOSDUZ(0)=""
  1. . F S QAOSDUZ(0)=$O(^TMP($J,QAOSLIST,QAOSDUZ(0))) Q:(QAOSDUZ(0)="")!(Y'>0) F QAOSDUZ=0:0 S QAOSDUZ=$O(^TMP($J,QAOSLIST,QAOSDUZ(0),QAOSDUZ)) Q:(QAOSDUZ'>0)!(Y'>0) D
  1. .. W !?3,QAOSDUZ(0)
  1. .. I $Y>(IOSL+QAOSLINE-3),(($O(^TMP($J,QAOSLIST,QAOSDUZ(0)))]"")!($O(^TMP($J,QAOSLIST,QAOSDUZ(0),QAOSDUZ)))) K DIR S DIR(0)="E",QAOSLINE=$Y D ^DIR K DIR
  1. .. Q
  1. . Q
  1. E W !?3,"*** None ***"
  1. Q