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

RMPR9CA.m

Go to the documentation of this file.
  1. RMPR9CA ;OI-HINES/HNC -SUSPENSE RPC;12/27/2004
  1. ;;3.0;PROSTHETICS;**90,135,141,146**;Feb 09, 1996;Build 4
  1. A1 ;roll and scroll entry point
  1. G A2
  1. EN(RESULTS,RMIE68,RMPRDUZ,RMSUSTAT,RMPR664,RMPRTXT) ;RPC entry point
  1. A2 ;
  1. S RESULTS(0)="",STP=0
  1. K ^TMP($J)
  1. ;
  1. CONT ;RMSUSTAT is status 1=complete or 0=incomplete or 2=pending (incomplete)
  1. ;
  1. S RMIE=0
  1. F S RMIE=$O(^RMPR(664,RMPR664,1,RMIE)) Q:RMIE'>0 D Q:STP=1
  1. .S RMIE60=$P(^RMPR(664,RMPR664,1,RMIE,0),U,13) Q:'RMIE60
  1. .S ^TMP($J,RMIE60)=""
  1. .D FD Q:STP=1
  1. .D UPD
  1. I STP=1 G EXIT
  1. I RMSUSTAT=1 D CNOTE,FD
  1. I RMSUSTAT=0 D INOTE,FD
  1. I RMSUSTAT=2 D ONOTE,FD
  1. ;set status
  1. Q
  1. CNOTE ;(#12) COMPLETION NOTE
  1. ;set file 668
  1. ;^RMPR(668,D0,4,0)=^668.012^^
  1. ;if status is close, or 1
  1. ;RMPRTXT ;load into field #12
  1. ;^RMPR(668,D0,4,D1,0)
  1. ;
  1. I $P(^RMPR(668,RMIE68,0),U,10)="C" S RESULTS(0)="0^This Suspense has already been Closed!"
  1. S DA=RMIE68
  1. D NOW^%DTC S RMPREODT=%,GMRCAD=%
  1. S DIE="^RMPR(668,"
  1. S DR="5////^S X=RMPREODT;6////^S X=DUZ;14///^S X=""C""" D ^DIE
  1. N RMPRC
  1. S L="",LN=0
  1. F S L=$O(RMPRTXT(L)) Q:L="" D
  1. . I 'LN D Q:RMPRC="" ;strip leading space from 1st line, ignore blank line
  1. .. S RMPRC=$E($TR(RMPRTXT(L)," ","")) ;1st non space char
  1. .. S:RMPRC'="" RMPRTXT(L)=$E(RMPRTXT(L),$F(RMPRTXT(L),RMPRC)-1,$L(RMPRTXT(L))) ;extract from 1st non space char to end of line
  1. .. Q
  1. . S LN=LN+1,^RMPR(668,RMIE68,4,LN,0)=RMPRTXT(L)
  1. . Q
  1. S $P(^RMPR(668,RMIE68,4,0),"^",3)=LN
  1. K L,LN
  1. ;S DA=RMIE68,DIK="^RMPR(668," D IX1^DIK
  1. I '$P(^RMPR(668,DA,0),U,9) D
  1. .S DIE="^RMPR(668,"
  1. .S DR="7///^S X=""See Completion Note for Initial Action Taken."""
  1. .D ^DIE
  1. .S DR="10////^S X=RMPREODT;16////^S X=DUZ" D ^DIE
  1. K RMPREODT
  1. S GMRCO=$P(^RMPR(668,RMIE68,0),U,15)
  1. I GMRCO="" S RESULTS(0)="0^Completed Manual Suspense Action. Suspense status has been updated to CLOSED." Q
  1. S RMPRCOM=0
  1. F S RMPRCOM=$O(^RMPR(668,RMIE68,4,RMPRCOM)) Q:RMPRCOM="" D
  1. .S GMRCOM(RMPRCOM)=^RMPR(668,RMIE68,4,RMPRCOM,0)
  1. I $G(GMRCOM)="" S GMRCOM="Not Noted"
  1. S GMRCSF="U"
  1. S GMRCA=10
  1. S GMRCALF="N"
  1. S GMRCATO=""
  1. S (GMRCORNP,GMRCDUZ)=DUZ
  1. S BDC=$$SFILE^GMRCGUIB(.GMRCO,.GMRCA,.GMRCSF,.GMRCORNP,.GMRCDUZ,.GMRCOM,.GMRCALF,.GMRCATO,.GMRCAD)
  1. I +BDC=1 S RESULTS(0)=1_"^"_$P(BDC,U,2)
  1. K GMRCO,GMRCA,GMRCSF,GMRCORNP,GMRCDUZ,GMRCOM,GMRCALF,GMRCATO,GMRCAD
  1. I RESULTS(0)="" S RESULTS(0)="0^Completed Suspense Action, and Posted note to CPRS Consult. Suspense status has been updated to CLOSED."
  1. Q
  1. ONOTE ;Other note
  1. ;set file 668
  1. ;^RMPR(668,D0,4,0)=^668.012^^
  1. ;if status is pending, and already initial action note or 0
  1. ;^RMPR(668,D0,1,D1,0)= (#.01) ACTION DATE [1D]
  1. ;RMPRTXT ;load into field #11, #1
  1. ;^RMPR(668,D0,1,D1,1,0)=^668.111^^
  1. ;
  1. S RMPRDA1=RMIE68,DA(1)=RMIE68,DA=RMIE68
  1. D NOW^%DTC S X=%,GMRCWHN=%
  1. S DIC="^RMPR(668,"_RMIE68_",1,"
  1. S DIC(0)="CQL"
  1. S DIC("P")="668.011DA"
  1. S DLAYGO=668
  1. D ^DIC
  1. I Y=-1 S RESULTS(0)="1^Error Modifying Record!" Q
  1. ;S DIE=DIC K DIC
  1. S (DA,RMPRDA2)=+Y
  1. ;S DR="1" D ^DIE
  1. K DIE,DR,Y
  1. ;S ^RMPR(668,RMIE68,1,0)="^668.011DA^1^1"
  1. N RMPRC
  1. S L="",LN=0
  1. F S L=$O(RMPRTXT(L)) Q:L="" D
  1. . I 'LN D Q:RMPRC="" ;strip leading space from 1st line, ignore blank line
  1. .. S RMPRC=$E($TR(RMPRTXT(L)," ","")) ;1st non space char
  1. .. S:RMPRC'="" RMPRTXT(L)=$E(RMPRTXT(L),$F(RMPRTXT(L),RMPRC)-1,$L(RMPRTXT(L))) ;extract from 1st non space char to end of line
  1. .. Q
  1. . S LN=LN+1,^RMPR(668,RMIE68,1,RMPRDA2,1,LN,0)=RMPRTXT(L)
  1. . Q
  1. S $P(^RMPR(668,RMIE68,1,RMPRDA2,1,0),"^",3)=LN
  1. K L,LN
  1. S GMRCO=$P(^RMPR(668,RMIE68,0),U,15)
  1. I GMRCO="" S RESULTS(0)="0^Completed Manual Suspense Action. Suspense status has not changed." Q
  1. S RMPRCOM=0
  1. F S RMPRCOM=$O(^RMPR(668,RMIE68,1,RMPRDA2,1,RMPRCOM)) Q:RMPRCOM="" D
  1. .S GMRCOM(RMPRCOM)=^RMPR(668,RMIE68,1,RMPRDA2,1,RMPRCOM,0)
  1. D CMT^GMRCGUIB(.GMRCO,.GMRCOM,"",GMRCWHN,DUZ)
  1. K DA,RMPRDA1,RMPRDA2,RMPRCOM,GMRCOM,GMRCO,GMRCWHN
  1. S RESULTS(0)="0^Completed Suspense Action, and Posted note to CPRS Consult. Suspense status has not changed."
  1. Q
  1. INOTE ;initial action note
  1. ;set file 668
  1. ;^RMPR(668,D0,3,0)=^668.07^^
  1. ;if status is pending, or 0
  1. ;RMPRTXT ;load into field #7
  1. ;^RMPR(668,D0,3,0)=^668.07^^
  1. ;
  1. I $D(^RMPR(668,RMIE68,3,1,0)) S RESULTS(0)="1^Initial Action Note Already Posted!" Q
  1. D NOW^%DTC S RMPREODT=%
  1. N RMPRC
  1. S ^RMPR(668,RMIE68,3,0)="^^^"_DT_"^"
  1. S L="",LN=0
  1. F S L=$O(RMPRTXT(L)) Q:L="" D
  1. . I 'LN D Q:RMPRC="" ;strip leading space from 1st line, ignore blank line
  1. .. S RMPRC=$E($TR(RMPRTXT(L)," ","")) ;1st non space char
  1. .. S:RMPRC'="" RMPRTXT(L)=$E(RMPRTXT(L),$F(RMPRTXT(L),RMPRC)-1,$L(RMPRTXT(L))) ;extract from 1st non space char to end of line
  1. .. Q
  1. . S LN=LN+1,^RMPR(668,RMIE68,3,LN,0)=RMPRTXT(L)
  1. . Q
  1. S $P(^RMPR(668,RMIE68,3,0),"^",3)=LN
  1. K L,LN
  1. S DIE="^RMPR(668,"
  1. S DA=RMIE68
  1. S DR="10////^S X=RMPREODT;16////^S X=DUZ;14///^S X=""P"""
  1. D ^DIE
  1. S GMRCO=$P(^RMPR(668,RMIE68,0),U,15)
  1. I GMRCO="" S RESULTS(0)="0^Completed Manual Suspense Action. Suspense status has been updated to PENDING" Q
  1. S RMPRCMT=0
  1. F S RMPRCMT=$O(^RMPR(668,RMIE68,3,RMPRCMT)) Q:RMPRCMT="" D
  1. .S GMRCMT(RMPRCMT)=^RMPR(668,RMIE68,3,RMPRCMT,0)
  1. D CMT^GMRCGUIB(GMRCO,.GMRCMT,DUZ,RMPREODT,DUZ)
  1. K RMPREODT,GMRCO,RMGMRCO,GMRCMT,RMPRCMT
  1. S RESULTS(0)="0^Completed Suspense Action, and Posted note to CPRS Consult. Suspense status has changed to PENDING."
  1. Q
  1. ;
  1. FD ;file date
  1. N DIE,DIC,I,J,Y,RMDFN,RMI,RMDATE,RM680,RM6810,RMERROR,RM60L,RC
  1. N RMERR,RMCHK,DLAYGO,X,DR,RM668,RM60DAT,RMSTATUS
  1. N RM68CNT,RM60CNT,RMSI,RMSAMIS,RM68IEN,RM60IEN,RMSUS60,RMSUS68,RMD
  1. N RM68DATA,RM60TYP,RM68D,RM68TRAN,RMPRPRC,RM60IT,RMENTSUS,RMQUIT
  1. ;
  1. S RMERR=0
  1. S:RMSUSTAT="" RMSUSTAT=0
  1. L +^RMPR(660,RMIE60):2
  1. I $T=0 S RESULTS(0)="1^Someone else is Editing this entry!" S STP=1 Q
  1. S RM680=$G(^RMPR(668,RMIE68,0))
  1. S RM688=$G(^RMPR(668,RMIE68,8))
  1. S RM6810=$G(^RMPR(668,RMIE68,10))
  1. S RMAMIS=$P($G(^RMPR(660,RMIE60,"AMS")),U,1)
  1. ;code here for 668 fields
  1. S RMDATE=$P(RM680,U,1)
  1. S RMCODT=$P(RM680,U,5)
  1. S RMINDT=$P(RM680,U,9)
  1. S RMPRCO=$P(RM680,U,15)
  1. S RMDWRT=$P(RM680,U,16)
  1. S RMSTAT=$P(RM680,U,7)
  1. S RMTRES=$P(RM680,U,8)
  1. S RMTYRE=$S(RMTRES=1:"ROUTINE",RMTRES=2:"EYEGLASS",RMTRES=3:"CONTACT LENS",RMTRES=4:"OXYGEN",RMTRES=5:"MANUAL",1:"")
  1. S RMREQU=$P(RM680,U,11)
  1. S RMSERV=""
  1. I $G(RMREQU) D GETS^DIQ(200,RMREQU,"29","E","RMAA") S RMSERV=RMAA(200,RMREQU_",",29,"E")
  1. S RMPRDI=$E($P(RM688,U,2),1,16)
  1. S RMICD9=$P(RM688,U,3)
  1. ;
  1. S RMDAT(660,RMIE60_",",8.1)=RMDATE
  1. S RMDAT(660,RMIE60_",",8.2)=RMDWRT
  1. S RMDAT(660,RMIE60_",",8.3)=RMINDT
  1. S RMDAT(660,RMIE60_",",8.4)=RMCODT
  1. S RMDAT(660,RMIE60_",",8.5)=RMTYRE
  1. S RMDAT(660,RMIE60_",",8.6)=RMREQU
  1. S RMDAT(660,RMIE60_",",8.61)=RMSERV
  1. S RMDAT(660,RMIE60_",",8.7)=RMPRDI
  1. S RMDAT(660,RMIE60_",",8.8)=RMICD9
  1. S RMDAT(660,RMIE60_",",8.9)=RMPRCO
  1. S RMDAT(660,RMIE60_",",8.11)=RMSTAT
  1. I RMSUSTAT=2 S RMDAT(660,RMIE60_",",8.14)=0
  1. I RMSUSTAT'=2 S RMDAT(660,RMIE60_",",8.14)=RMSUSTAT
  1. D FILE^DIE("","RMDAT","RMERROR")
  1. I $D(RMERROR) S RMERR=1 S STP=1
  1. ;
  1. L -^RMPR(660,RMIE60)
  1. Q
  1. UPD ;update file 668 with 2319 records
  1. S DA(1)=RMIE68 K DD,DO,DIC
  1. S DIC="^RMPR(668,"_DA(1)_","_"10,"
  1. S DIC(0)="L",DLAYGO=668,X=RMIE60
  1. D FILE^DICN
  1. K X,DD,DO,DIC
  1. S DA(1)=RMIE68,DIC(0)="L",DLAYGO=668
  1. S DIC="^RMPR(668,"_DA(1)_","_"11,"
  1. S X=RMAMIS
  1. D FILE^DICN
  1. K DIC,X,DLAYGO,DD,DO
  1. Q
  1. A3 G A4
  1. EN1(RESULTS,DA) ;Broker entry to kill PO
  1. ;DA is passed
  1. S DIK="^RMPR(664," D ^DIK
  1. K DIK
  1. A4 ;
  1. Q
  1. ERR ;exit on error
  1. EXIT ;
  1. K RMTYRE,RMTRES,RMSUSTAT,RMSTAT,RMSERV,RMEQU,RMPRTST,RMPRDUZ,RMPRDI,RMPRCO,RMPR664,RMIE68
  1. K RMIE60,RMIE,RMICD9,RMDWRT,RMDAT,RMCODT,RMAMIS,RMAA,RM688,RMPRTXT
  1. K BDC,BAD,%,RMINDT,RMPREQU,STP
  1. Q