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