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

IBDFDE22.m

Go to the documentation of this file.
  1. IBDFDE22 ;ALB/AAS - AICS Data Entry, check selection rules ; 24-FEB-96
  1. ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997
  1. ;
  1. % G ^IBDFDE
  1. ;
  1. CHK ; -- see if rules allow for more or less than one
  1. ; rules 0 := select any number
  1. ; 1 := exactly 1
  1. ; 2 := at most 1
  1. ; 3 := at least 1 (1 or more)
  1. N I,IBDY,MATCH,OVERSAV
  1. S (MATCH,OVER,OVERSAV,ASKOTHER)=0
  1. ;
  1. ; -- check all rules for list and enforce
  1. S I=0 F S I=$O(RULE(I)) Q:I="" D I OVER S:OVER>OVERSAV OVERSAV=OVER
  1. .;
  1. .; -- find all matches for list, and qualifier
  1. .S MATCH=0
  1. .S IBDY=0 F S IBDY=$O(IBDPI(IBDF("PI"),IBDY)) Q:'IBDY I $P(IBDPI(IBDF("PI"),IBDY),"^",6)=QLFR(I) S MATCH=MATCH+1
  1. .;
  1. .; -- any number allowed
  1. .I $G(RULE(+I))=0 D Q
  1. ..I ANS="" S OVER=0 Q ;nothing selected, don't reask
  1. ..I ANS'="" S OVER=1 Q ;something selected, reask
  1. .;
  1. .; -- exactly one required
  1. .I $G(RULE(+I))=1 D Q
  1. ..I MATCH>1 S OVER=2 W:'$G(IBDREDIT) !,"More than one selected, you must delete one" Q
  1. ..I MATCH=1 S OVER=0 D DELQLF Q ;exactly one selected
  1. ..I MATCH<1 S OVER=1 W:'$G(IBDREDIT) !!,"A ",IOINHI,IBDASK,IOINORM," selection is required"_$S(QLFR(I)="":"",1:" for "_IOINHI_QLFR(I)_IOINORM),".",! Q
  1. .;
  1. .; -- at most one required
  1. .I $G(RULE(+I))=2 D Q
  1. ..I MATCH>1 S OVER=2 W:'$G(IBDREDIT) !,"More than one selected, you must delete one" Q
  1. ..I MATCH=1 S OVER=0 D DELQLF Q ;exactly one selected
  1. ..I ANS'="",MATCH<1 S OVER=1 ;if match = 0 thats okay but ask
  1. .;
  1. .; -- at least one required
  1. .I $G(RULE(+I))=3 D Q
  1. ..S OVER=1
  1. ..I MATCH<1 S OVER=1 W:'$G(IBDREDIT) !!,"A ",IOINHI,IBDASK,IOINORM," selection is required"_$S(QLFR(I)="":"",1:" for "_IOINHI_QLFR(I)_IOINORM),".",! Q
  1. ..I MATCH>1,ANS="" S OVER=0 Q ;more than one selected
  1. ..I MATCH=1,ANS="" S OVER=0 Q ;exactly one selected
  1. ;
  1. S OVER=OVERSAV
  1. I OVER=2 D DEL^IBDFDE1
  1. CHKQ Q
  1. ;
  1. DELQLF ; -- delete rule, qualifier
  1. Q:RULE<2 ;must leave the last or only rule
  1. I MATCH=1 S OVER=0 K RULE(I),QLFR(I) S RULE=RULE-1
  1. Q
  1. ;
  1. RULES ; -- look at zero node, find qualifiers and selection rule
  1. N Q,R,CNT
  1. S RULE=$P($$CHOICE^IBDFDE2(0),"^",3),QLFR="",CNT=0
  1. ;
  1. ; -- go thru rules, if primary then make #1
  1. F IBD=1:1 S ROW=$P(RULE,"::",IBD) Q:ROW="" D
  1. .S Q(IBD)=$P(ROW,";;",1),R(IBD)=$P(ROW,";;",2)
  1. .I Q(IBD)="PRIMARY" D
  1. ..S R(IBD)=$S(R(IBD)=3:1,R(IBD)=0:2,1:R(IBD))
  1. ..S RULE(1)=R(IBD),QLFR(1)=Q(IBD),CNT=CNT+1 K R(IBD),Q(IBD)
  1. S RULE=IBD-1
  1. ;
  1. ; -- make secondary #2 if primary exists, else #1
  1. S IBD="" F S IBD=$O(R(IBD)) Q:'IBD I Q(IBD)="SECONDARY" S CNT=CNT+1,RULE(CNT)=R(IBD),QLFR(CNT)=Q(IBD) K R(IBD),Q(IBD) Q
  1. ;
  1. ; -- take the rest as they come
  1. S IBD="" F S IBD=$O(R(IBD)) Q:'IBD S CNT=CNT+1,RULE(CNT)=R(IBD),QLFR(CNT)=Q(IBD)
  1. ;
  1. ;F IBD=1:1 S ROW=$P(RULE,"::",IBD) Q:ROW="" S QLFR(IBD)=$P(ROW,";;",1),RULE(IBD)=$P(ROW,";;",2) I QLFR(IBD)="PRIMARY" D
  1. ;.S RULE(IBD)=$S(RULE(IBD)=3:1,RULE(IBD)=0:2,1:RULE(IBD))
  1. ;S RULE=IBD-1
  1. Q