OOPSGUID ;WIOFO/LLH-RPC routine for GET/SET CA7 ;04/29/04
 ;;2.0;ASISTS;**8**;Jun 03, 2002
 ;
SAVECA7 ; saves CA7 data to database
 S (RESULTS,RESULTS(1),RESULTS(2))=""
 I $G(IEN)="NEW" D NEWCA7 I $P(RESULTS(2),U,2)'="CA7 Created" Q
 ;
 S RESULTS(1)=IEN_U_"UPDATE FAILED"
 K DR S DIE="^OOPS(2264,",DA=IEN,DR=""
 S DR(1,2264,1)="1///^S X=ARR(6)"
 S DR(1,2264,2)="2////^S X=ARR(7)"
 S DR(1,2264,3)="3///^S X=ARR(8)"
 S DR(1,2264,4)="4///^S X=ARR(9)"
 S DR(1,2264,5)="5////^S X=ARR(10)"
 S DR(1,2264,6)="6///^S X=ARR(11)"
 S DR(1,2264,7)="7///^S X=ARR(12)"
 S DR(1,2264,8)="8///^S X=ARR(13)"
 S DR(1,2264,11)="9///^S X=ARR(14)"
 S DR(1,2264,12)="10///^S X=ARR(15)"
 S DR(1,2264,13)="11///^S X=ARR(16)"
 S DR(1,2264,14)="12///^S X=ARR(17)"
 S DR(1,2264,15)="13///^S X=ARR(18)"
 S DR(1,2264,16)="14///^S X=ARR(19)"
 S DR(1,2264,17)="15///^S X=ARR(20)"
 S DR(1,2264,18)="16///^S X=ARR(21)"
 S DR(1,2264,19)="17///^S X=ARR(22)"
 S DR(1,2264,20)="18///^S X=ARR(23)"
 S DR(1,2264,21)="19///^S X=ARR(24)"
 S DR(1,2264,22)="20///^S X=ARR(25)"
 S DR(1,2264,24)="21///^S X=ARR(26)"
 S DR(1,2264,25)="22///^S X=ARR(27)"
 S DR(1,2264,26)="23///^S X=ARR(28)"
 S DR(1,2264,27)="24///^S X=ARR(29)"
 S DR(1,2264,28)="25///^S X=ARR(30)"
 S DR(1,2264,29)="27///^S X=ARR(31)"
 S DR(1,2264,30)="28///^S X=ARR(32)"
 S DR(1,2264,31)="29///^S X=ARR(33)"
 S DR(1,2264,32)="30///^S X=ARR(34)"
 S DR(1,2264,33)="31///^S X=ARR(35)"
 S DR(1,2264,34)="32///^S X=ARR(36)"
 S DR(1,2264,35)="33///^S X=ARR(37)"
 S DR(1,2264,36)="34///^S X=ARR(38)"
 S DR(1,2264,37)="35///^S X=ARR(39)"
 S DR(1,2264,38)="36///^S X=ARR(40)"
 S DR(1,2264,39)="37///^S X=ARR(41)"
 S DR(1,2264,40)="38///^S X=ARR(42)"
 S DR(1,2264,41)="39///^S X=ARR(43)"
 S DR(1,2264,42)="40///^S X=ARR(44)"
 S DR(1,2264,43)="41///^S X=ARR(45)"
 S DR(1,2264,44)="41.3///^S X=ARR(46)"
 S DR(1,2264,45)="41.6///^S X=ARR(47)"
 S DR(1,2264,46)="42///^S X=ARR(48)"
 S DR(1,2264,47)="43///^S X=ARR(49)"
 S DR(1,2264,48)="44///^S X=ARR(50)"
 S DR(1,2264,49)="45///^S X=ARR(51)"
 S DR(1,2264,50)="46///^S X=ARR(52)"
 S DR(1,2264,51)="47///^S X=ARR(53)"
 S DR(1,2264,52)="48///^S X=ARR(54)"
 S DR(1,2264,53)="49///^S X=ARR(55)"
 S DR(1,2264,54)="50///^S X=ARR(56)"
 S DR(1,2264,55)="51///^S X=ARR(57)"
 D ^DIE
 I '($D(Y)=0) Q
 K DR S DIE="^OOPS(2264,",DA=IEN,DR=""
 S DR(1,2264,56)="52///^S X=ARR(58)"
 S DR(1,2264,57)="53///^S X=ARR(59)"
 S DR(1,2264,58)="54///^S X=ARR(60)"
 S DR(1,2264,59)="56///^S X=ARR(61)"
 S DR(1,2264,60)="57///^S X=ARR(62)"
 S DR(1,2264,61)="58///^S X=ARR(63)"
 S DR(1,2264,62)="59///^S X=ARR(64)"
 S DR(1,2264,63)="60///^S X=ARR(65)"
 S DR(1,2264,64)="62///^S X=ARR(66)"
 S DR(1,2264,65)="63///^S X=ARR(67)"
 S DR(1,2264,66)="64///^S X=ARR(68)"
 S DR(1,2264,67)="65///^S X=ARR(69)"
 S DR(1,2264,68)="67///^S X=ARR(70)"
 S DR(1,2264,69)="68///^S X=ARR(71)"
 S DR(1,2264,70)="69///^S X=ARR(72)"
 S DR(1,2264,71)="70///^S X=ARR(73)"
 S DR(1,2264,72)="71///^S X=ARR(74)"
 S DR(1,2264,73)="72///^S X=ARR(75)"
 S DR(1,2264,74)="73///^S X=ARR(76)"
 S DR(1,2264,75)="74///^S X=ARR(77)"
 S DR(1,2264,76)="75///^S X=ARR(78)"
 S DR(1,2264,77)="76///^S X=ARR(79)"
 S DR(1,2264,78)="78///^S X=ARR(80)"
 S DR(1,2264,79)="79///^S X=ARR(81)"
 S DR(1,2264,80)="80///^S X=ARR(82)"
 S DR(1,2264,81)="81///^S X=ARR(83)"
 S DR(1,2264,82)="82///^S X=ARR(84)"
 S DR(1,2264,83)="83///^S X=ARR(85)"
 S DR(1,2264,84)="84///^S X=ARR(86)"
 S DR(1,2264,85)="85///^S X=ARR(87)"
 S DR(1,2264,86)="86///^S X=ARR(88)"
 S DR(1,2264,87)="87///^S X=ARR(89)"
 S DR(1,2264,88)="88///^S X=ARR(90)"
 S DR(1,2264,89)="89///^S X=ARR(91)"
 S DR(1,2264,90)="90///^S X=ARR(92)"
 S DR(1,2264,91)="91///^S X=ARR(93)"
 S DR(1,2264,92)="92///^S X=ARR(94)"
 S DR(1,2264,93)="93///^S X=ARR(95)"
 S DR(1,2264,94)="94///^S X=ARR(96)"
 D ^DIE
 ;Check the return of ^DIE
 I $D(Y)=0 S RESULTS(1)=IEN_U_ARR(0)_U_"UPDATE COMPLETED"
 Q
NEWCA7 ; need to file the CA7 first, then file the remaining data
 N ACLAIM,CA7,DLAYGO,DR,DIC,I,X
 S CA7=""
 I '$G(ARR(3)) S (RESULTS,RESULTS(1))="No ASISTS IEN, cannot file" Q
 I '$D(^OOPS(2260,ARR(3),0)) D  Q
 . S (RESULTS,RESULTS(1))="ASISTS claim not on file, cannot continue"
 S ACLAIM=$$GET1^DIQ(2260,ARR(3),.01)
 I $G(ACLAIM)="" D  Q
 . S (RESULTS,RESULTS(1))="No ASISTS claim number, cannot continue"
 S ARR(0)=$$CA7NUM()
 I $G(ARR(0))="" D  Q
 . S (RESULTS,RESULTS(1))="Could not build CA7 Number, cannot continue"
 S ARR(1)=$$NOW()
 K DD,DO S DLAYGO=2264,DIC="^OOPS(2264,",DIC(0)="L",X=ARR(0)
 S DIC("DR")=".3////^S X=ARR(1);.5////^S X=DUZ;.7////^S X=ARR(3);.8////^S X=ARR(4);.9////^S X=ARR(5)"
 D FILE^DICN I +Y>0 D
 . S (RESULTS,RESULTS(2))=IEN_U_"CA7 Created"
 . S IEN=+Y
 Q
CA7NUM() ; gets next CA-7 number
 N CASE,NUM,CA7TEST
 S CA7TEST=ACLAIM_"-CA7"
 S CASE="^OOPS(2264,"_"""B"""_","""_CA7TEST_""")"
 F  S CASE=$Q(@CASE) Q:$P(CASE,",",3)'[ACLAIM  S CA7=$P(CASE,",",3)
 S NUM=$P(CA7,"-",4)+1,NUM=$E("000",1,3-$L(NUM))_NUM
 Q $P(CA7TEST,"-",1,3)_"-"_NUM
 ;
NOW() ; returns current date and time
 N %,%I,%H,X
 D NOW^%DTC
 Q %
DUAL(RESULTS,INPUT,DATA) ; new sub for filing DUAL node fields - 
 ;                         need to add parameters back
 ; for the Dual Benefit form answered from the CA1 or CA2
 ;
 ; Input:  INPUT - IEN^FORM; first piece is the record identifier
 ;                           2nd piece is the form, CA1 or CA2
 ;          DATA - data string, p1=fld 303, p2=304, p3=305, p4=306
 ;                 p5=307, p6=308
 ;                 data does not include electronic signature fields
 ;                 for the node 
 ;
 N ARR,CN,DA,DIE,DR,LP,IEN
 S RESULTS="No Changes Filed"
 S IEN=$P($G(INPUT),U)
 I '$G(IEN) S RESULTS="No IEN passed in - save failed" Q
 K DR S DIE="^OOPS(2260,",DA=IEN,DR=""
 I '$L($TR(DATA,"^","")) S RESULTS="No data to save" Q
 F LP=1:1:6 S ARR(LP)=$P($G(DATA),U,LP)
 S DR(1,2260,1)="303///^S X=ARR(1)"
 S DR(1,2260,2)="304///^S X=ARR(2)"
 S DR(1,2260,3)="305///^S X=ARR(3)"
 S DR(1,2260,4)="306///^S X=ARR(4)"
 S DR(1,2260,5)="307///^S X=ARR(5)"
 S DR(1,2260,6)="308///^S X=ARR(6)"
 D ^DIE
 I $D(Y)=0 S RESULTS="UPDATE COMPLETED"
 Q
