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

RMPFET8.m

Go to the documentation of this file.
  1. RMPFET8 ;DDC/KAW-ADJUST AN ORDER [ 06/16/95 3:06 PM ]
  1. ;;2.0;REMOTE ORDER/ENTRY SYSTEM;**17**;06/06/01
  1. ;;input : RMPFX,DFN,RMPFTYP,RMPFHAT,RMPFTP
  1. ;;output: None
  1. Q:'$D(RMPFX) Q:'$D(DFN) Q:'DFN
  1. W @IOF,!!,"ORDER ADJUSTMENTS"
  1. W !!?32,"*** WARNING ***"
  1. W !!,"This module is used to make adjustments to an order that has already been"
  1. W !!,"sent to the DDC. Orders may be adjusted up to 60 working days after aids"
  1. W !!,"are issued. If an adjustment is made after issue, the DDC will update the"
  1. W !!,"the order with the status 'CERTIFICATION PENDING'. Certification will again"
  1. W !!,"be required before the vendor will be paid."
  1. D CONT^RMPFET G END:$D(RMPFOUT)
  1. EN1 S S0=^RMPF(791810,RMPFX,0) K RMPFADJ
  1. I RMPFTYP,$D(^RMPF(791810.1,RMPFTYP,0)) S RMPFTYPP=$P(^(0),U,1)
  1. I RMPFTYP=""!(RMPFHAT="") W $C(7),!!,"ERROR IN ORDER TYPE" G END
  1. K RMPFSEL1
  1. EDIT D PAT^RMPFUTL,HEAD,^RMPFDT2
  1. S (X,CT)=0 F I=1:1 S X=$O(RMPFO(X)) Q:'X S CT=CT+1
  1. D SEL G END:$D(RMPFOUT),EDIT:$D(RMPFQUT),END:RMPFSEL1="",EDIT
  1. END K RMPFTYPP,CT,X,RMPFOUT,RMPFQUT,RMPFSEL1,RMPFADJ,RMPFDOD
  1. K RMPFDOB,RMPFNAM,RMPFMD,RMPFO,RMPFSSN,CM,CX,DI,DIC,I,Y,RMPFRE Q
  1. SEL ;;Select adjustment action
  1. ;; input: RMPFX,CT,RMPFMD
  1. ;;output: RMPFSEL1
  1. S RMPFODAT=$P(^RMPF(791810,RMPFX,0),"^",9)
  1. I RMPFODAT>3010630 D
  1. .W !!!,"Enter <C>hange Model, <H>istory or <RETURN> to continue: " D READ
  1. I RMPFODAT<3010701 D
  1. .W !!!,"Enter <C>hange Model, <R>emove Component, <A>dd Component,"
  1. .W " <H>istory or <RETURN> to continue: " D READ
  1. G SELE:$D(RMPFOUT)
  1. SEL1 I $D(RMPFQUT) D MSG G SELE:$D(RMPFOUT) S RMPFQUT="" G SELE
  1. S RMPFSEL1=$E(Y,1) G SELE:RMPFSEL1=""
  1. I RMPFODAT>3010630 I "CcHh"'[RMPFSEL1 S RMPFQUT="" G SEL1
  1. I RMPFODAT<3010701 I "CcRrAaHh"'[RMPFSEL1 S RMPFQUT="" G SEL1
  1. I "Hh"[RMPFSEL1 D ^RMPFDT7 G SELE
  1. I CT=1,$P(^RMPF(791810,RMPFX,101,RMPFMD(1),0),U,15)'="C" S RMPFY=RMPFMD(1) G DO
  1. NUM S Z=$E(Y,2,99) G ITEM:'Z
  1. I $D(RMPFMD(Z)),$P(^RMPF(791810,RMPFX,101,RMPFMD(Z),0),U,15)'="C" S RMPFY=RMPFMD(Z) G DO
  1. ITEM W !!,"Select number of item to adjust: " D READ G SELE:$D(RMPFOUT)
  1. ITEM1 I $D(RMPFQUT) W !!,"Enter the number to the left of the item that you wish to adjust." G ITEM
  1. G SELE:Y="" I '$D(RMPFMD(Y)) S RMPFQUT="" G ITEM1
  1. S RMPFY=RMPFMD(Y)
  1. I $P(^RMPF(791810,RMPFX,101,RMPFY,0),U,15)="C" W $C(7),!!,"*** THIS ORDER HAS BEEN CANCELED ***" S RMPFQUT="" G ITEM1
  1. DO S X=$P(^RMPF(791810,RMPFX,101,RMPFY,0),U,18) G SELE:'X,SELE:'$D(^RMPF(791810.2,X,0)) S X=$P(^(0),U,2) G SELE:X="" I "SECF"'[X W !!,$C(7),"*** LINE ITEMS WITH THIS STATUS CANNOT BE ADJUSTED ***" H 2 G SELE
  1. I "Cc"[RMPFSEL1 D CHANGEM^RMPFET81 G END:$D(RMPFOUT)!'$D(RMPFY) D CERTIFY G END:$D(RMPFOUT),SELE
  1. I RMPFODAT<3010701 I "Rr"[RMPFSEL1 D REMOVEC^RMPFET81 G END:$D(RMPFOUT)!'$D(RMPFY) D CERTIFY G END:$D(RMPFOUT),SELE
  1. I RMPFODAT<3010701 I "Aa"[RMPFSEL1 D ADDC^RMPFET81 G END:$D(RMPFOUT)!'$D(RMPFY) D CERTIFY G END:$D(RMPFOUT),SELE
  1. SELE K X,Y,Z,RMPFMD,RMPFY Q
  1. READ K RMPFOUT,RMPFQUT
  1. R Y:DTIME I '$T W $C(7) R Y:5 G READ:Y="." S:'$T Y=U
  1. I Y?1"^".E S (RMPFOUT,Y)="" Q
  1. S:Y?1"?".E (RMPFQUT,Y)=""
  1. Q
  1. W !,"Station: ",RMPFSTAP,?68,RMPFDAT
  1. W !,"Patient: ",$E(RMPFNAM,1,25),?40,"SSN: ",RMPFSSN,?62,"DOB: ",RMPFDOB
  1. W ! F I=1:1:80 W "-"
  1. Q
  1. CERTIFY S S0=^RMPF(791810,RMPFX,101,RMPFY,0)
  1. Q:'$P(S0,U,20) Q:$P(S0,U,19)'["A"
  1. Q:'$D(^RMPF(791810,RMPFX,101,RMPFY,90)) F I=8:1:11 S $P(^(90),U,I)=""
  1. W !!,"*** THIS LINE ITEM MUST BE CERTIFIED ***"
  1. S BX=1 D ^RMPFET85
  1. Q
  1. MSG W !!,"Enter <C> to change a hearing aid model"
  1. W:RMPFODAT<3010701 !?6,"<R> to remove a component from the order"
  1. W:RMPFODAT<3010701 !?6,"<A> to add a component to the order"
  1. W !?6,"<H> to view the history of the order actions"
  1. W !?6,"<RETURN> to continue."
  1. W !!,"If the order consists of more than one model, the number of the model needing to",!,"be adjusted may be entered after the letter from the command line (i.g., 'C2')."
  1. W !!,"Enter <RETURN> to continue." D READ Q
  1. DELETE ;;Delete old model when changing models
  1. ;; input: RMPFX,RMPFY,RMPFRE,RMPFMSG,RMPFY1
  1. ;;output: None
  1. S S0=^RMPF(791810,RMPFX,101,RMPFY1,0),IT=$P(S0,U,1)
  1. S LR=$P(S0,U,4),CX=$P(S0,U,14),X="NOW",%DT="T" D ^%DT S TD=Y
  1. S DIC="^RMPF(791810,"_RMPFX_",101,",DA(1)=RMPFX,DLAYGO=791810
  1. S DIC(0)="L",X=""_IT_""
  1. S DIC("DR")=".04////"_LR_";.14////"_CX_";.15////DC;.16////"_RMPFY1_";.18///APPROVED;90.01////"_DUZ_";90.02////"_TD_";90.03////"_RMPFRE_";90.04////"_RMPFMESG W "."
  1. K DD,DO D FILE^DICN S RMPFY3=+Y
  1. I Y=-1 W $C(7),!!,"*** MODEL NOT DELETED ***" H 2 Q
  1. S RMPFY=RMPFY1 D ARRAY2^RMPFDT2
  1. S RMPFZ=0 F IX=1:1 S RMPFZ=$O(RMPFC(RMPFZ)) Q:'RMPFZ W "." D
  1. .S IT=$P(RMPFC(RMPFZ),U,1),CX=$P(RMPFC(RMPFZ),U,2)
  1. .I '$D(^RMPF(791810,RMPFX,101,RMPFY3,102,0)) S ^RMPF(791810,RMPFX,101,RMPFY3,102,0)="^791810.101102P"
  1. .S DIC="^RMPF(791810,"_RMPFX_",101,"_RMPFY3_",102,",X=""_IT_""
  1. .S DA(2)=RMPFX,DA(1)=RMPFY3,DLAYGO=791810,DIC(0)="L"
  1. .S DIC("DR")=".03////D;.05////"_DUZ_";.06////"_TD_";.07////"_RMPFRE
  1. .K DO,DD D FILE^DICN I Y=-1 W $C(7),!!,"*** COMPONENT NOT DELETED ***" Q
  1. .S $P(^RMPF(791810,RMPFX,101,RMPFY3,102,+Y,0),U,4)=+Y,$P(^(0),U,2)=CX Q
  1. K X,Y,RMPFOUT,RMPFQUT,DIC,RMPFZ,RMPFC,IT,CX,DA,ZZ,ZY,RMPFRE,RMPFY3,TD
  1. K LR,IX,%,%DT,D0,DI,DIE,DLAYGO,DQ,DR Q