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

ORWDBA8.m

Go to the documentation of this file.
  1. ORWDBA8 ; SLC/GDU - Billing Awareness - Phase I [11/16/04 15:39]
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**195**;Dec 17, 1997
  1. ;Clinical Indicator Data Capture By Provider Parameter Management
  1. ;
  1. ;Varaibles
  1. ; CIDC Clinical Indicator Data Capture Parameter, current value
  1. ; CNT Counter, incremented counter variable
  1. ; DIR Input array variable for ^DIR
  1. ; DT Standard Fileman/Kernel variable for current date
  1. ; DT is set, but not newed or killed
  1. ; DTOUT Timeout indicator, output variable of ^DIR
  1. ; DUOUT Up arrow indicator, output variable of ^DIR
  1. ; OREM Error Message, output variable of ^DIC, and ^XPAR
  1. ; FST First, display control varible
  1. ; HC Help Counter, help text line count
  1. ; IEN Internal Entry Number
  1. ; IOF Standard Kernel variable to clear screen
  1. ; NAME Provider Name, parsed from RF output array from FIND^DIC
  1. ; NX0 Next group of providers prompt, used to help build DIR(0)
  1. ; NXC Next group of providers count, used to help build DIR(0)
  1. ; NXH Next group of providers help, used to help build DIR("?"
  1. ; PTD Provider Termination Date, internal value
  1. ; RF Records Found, initial user search results
  1. ; ORSCR Screen, input variable to filter search
  1. ; SP Selected Provider
  1. ; SV Search Value
  1. ; U Standard FileMan, Kernel field delimiter
  1. ; US User Selection
  1. ; WA Work Array, filtered array of providers for user selection
  1. ; X Standard FileMan work varaible
  1. ; Y Processed output of user selection, output variable of ^DIR
  1. ;
  1. ;External References
  1. ; FIND^DIC DBIA 2051, FileMan record(s) finder
  1. ; ^DIR DBIA 10026, FileMan input reader
  1. ; $$GET^XPAR DBIA 2263, Get current value of single parameter
  1. ; ADD^XPAR DBIA 2263, Add new parameter
  1. ; CHG^XPAR DBIA 2263, Change current value of parameter
  1. ; $$DT^XLFDT DBIA 10103, Gets today's date from the system
  1. ;
  1. EN ;Starting point of this program
  1. ;Ask user for provider
  1. N APS,CIDC,CNT,DIR,DTOUT,DUOUT,OREM,FST,HC,IEN,NAME,NX0,NXC,NXH,RF
  1. N ORSCR,PTD,SP,SV,US,VAL,WA,X,Y
  1. S DT=$$DT^XLFDT
  1. S DIR(0)=$P($T(FT0),";",3)
  1. S DIR("A")=$P($T(FA),";",3)
  1. S DIR("?",1)=$P($T(FH1),";",3)
  1. S DIR("?",2)=$P($T(FH2),";",3)
  1. S DIR("?")=$P($T(FH3),";",3)
  1. D SCRHDR W ! D ^DIR S SV=Y K DIR
  1. I SV=""!($D(DTOUT))!($D(DUOUT)) G EXIT
  1. S ORSCR="I $D(^XUSEC(""PROVIDER"",Y))=1"
  1. D FIND^DIC(200,"","@;.01;7;9.2I;9.2","CP",SV,"*","",.ORSCR,"","RF","OREM")
  1. ;Test if no matching records found. If true alert user.
  1. I $P(RF("DILIST",0),U)=0 D G:Y=1 EN G EXIT
  1. . S DIR(0)="E"
  1. . S DIR("A",1)=$P($T(UAA1),";",3)_" "_SV
  1. . S DIR("A")=$P($T(UAA5),";",3)
  1. . D SCRHDR W ! D ^DIR K DIR
  1. S (SP,PTD)=""
  1. ;If search returns only 1 match
  1. I $P(RF("DILIST",0),U)=1 D
  1. . S SP=1,PTD=$P(RF("DILIST",SP,0),U,4)
  1. .;Test if provider is DISUSERED. If true alert user and quit
  1. . I $P(RF("DILIST",SP,0),U,3)="YES" D Q
  1. .. S DIR(0)="E"
  1. .. S DIR("A",1)=$P(RF("DILIST",SP,0),U,2)_" "_$P($T(UAA2),";",3)
  1. .. S DIR("A")=$P($T(UAA5),";",3)
  1. .. D SCRHDR W ! D ^DIR K DIR
  1. .. S SP=$S(Y=1:"",1:"Q")
  1. .;Test if provider is terminated. If true alert user and quit
  1. . I PTD'="",(PTD=DT)!(PTD<DT) D Q
  1. .. S DIR(0)="E"
  1. .. S DIR("A",1)=$P(RF("DILIST",SP,0),U,2)_" "_$P($T(UAA3),";",3)
  1. .. S DIR("A",1)=DIR("A",1)_" "_$P(RF("DILIST",SP,0),U,5)
  1. .. S DIR("A")=$P($T(UAA5),";",3)
  1. .. D SCRHDR W ! D ^DIR K DIR
  1. .. S SP=$S(Y=1:"",1:"Q")
  1. . S IEN=$P(RF("DILIST",1,0),U)
  1. . S NAME=$P(RF("DILIST",1,0),U,2)
  1. I $P(RF("DILIST",0),U)>1 D
  1. . S WA(0)=0
  1. . F X=1:1:$P(RF("DILIST",0),U) D
  1. .. S PTD=$P(RF("DILIST",X,0),U,4)
  1. .. I $P(RF("DILIST",X,0),U,3)="",(PTD="")!(PTD>DT) D
  1. ... S WA(0)=WA(0)+1
  1. ... S WA(WA(0))=RF("DILIST",X,0)
  1. . I WA(0)=0 D
  1. .. ;Alerting the user that this search failed because all providers
  1. .. ;returned are inactive
  1. .. S DIR(0)="E"
  1. .. S DIR("A",1)=$P($T(UAA4),";",3)_" "_SV
  1. .. S DIR("A")=$P($T(UAA5),";",3)
  1. .. D SCRHDR W ! D ^DIR K DIR
  1. .. S SP=$S(Y=1:"",1:"Q")
  1. . I WA(0)=0 Q
  1. . I WA(0)=1 S SP=1 ;Default to the single active provider
  1. . I WA(0)>1 D SPFL ;Additional selection if several active providers
  1. . I SP="Q"!(SP="") Q
  1. . S IEN=$P(WA(SP),U)
  1. . S NAME=$P(WA(SP),U,2)
  1. I SP="Q" G EXIT
  1. I SP="" G EN
  1. D PSP G EN
  1. EXIT ;Exit point for this program
  1. Q
  1. FT0 ;;FO^1:40
  1. FA ;;Select the provider to manage the parameter
  1. FH1 ;;Enter the name/partial name of the provider.
  1. FH2 ;;This is free text, 1 to 40 characters in length.
  1. FH3 ;;This search will only return those with the PROVIDER key.
  1. UAA1 ;;Found no provider records matching the search criteria of
  1. UAA2 ;;is a provider who has been DISUSERED.
  1. UAA3 ;;is an inactive provider with a termination date of
  1. UAA4 ;;Found no active provider records matching the search criteria of
  1. UAA5 ;;Hit enter to continue or "^" to quit
  1. SPFL ;Select Provider From List
  1. I $D(FST)=0 S FST=1
  1. S DIR(0)="SO^"
  1. S DIR("?",1)=$P($T(DH),";",3)
  1. S DIR("?")=$P($T(DHS),";",3)
  1. S DIR("A")=$P($T(DA),";",3)
  1. I WA(0)<10 D
  1. . F X=1:1:WA(0) S DIR(0)=DIR(0)_X_":"_$P(WA(X),U,2)_";"
  1. I WA(0)=10 D
  1. . F X=1:1:10 S DIR(0)=DIR(0)_X_":"_$P(WA(X),U,2)_";"
  1. I WA(0)>10 D
  1. . S CNT=0,HC=1,(NXC,NX0,NXH,SP,X,Y)=""
  1. . F X=FST:1:10+(FST-1) Q:$D(WA(X))=0 D
  1. .. S CNT=CNT+1
  1. .. S DIR(0)=DIR(0)_X_":"_$P(WA(X),U,2)_";"
  1. . S NXC=WA(0)-X,NXC=$S(NXC>10:10,1:NXC)
  1. . S NX0=$P($P($T(D0N),";",3),"|")_NXC_$P($P($T(D0N),";",3),"|",2)
  1. . S NXH=$P($P($T(DHN),";",3),"|")_NXC_$P($P($T(DHN),";",3),"|",2)
  1. . I CNT=10 D
  1. .. S DIR(0)=DIR(0)_";"_NX0
  1. .. S HC=HC+1,DIR("?",HC)=NXH
  1. . I FST>10 D
  1. .. S DIR(0)=DIR(0)_";"_$P($T(D0P),";",3)
  1. .. S HC=HC+1,DIR("?",HC)=$P($T(DHP),";",3)
  1. D SCRHDR,^DIR K DIR
  1. S SP=Y
  1. I SP="" Q
  1. I $D(DTOUT)!($D(DUOUT)) S SP="Q" Q
  1. I SP="N"!(SP="P") S FST=$S(SP="N":FST+10,1:FST-10) G SPFL
  1. I SP=""!(SP="Q") Q
  1. Q
  1. D0N ;;N:Next | provider(s)
  1. D0P ;;P:Previous 10 providers
  1. DH ;;Select the provider for parameter management.
  1. DHN ;;Enter N to get the next | providers.
  1. DHP ;;Enter P to get the previous 10 providers.
  1. DHS ;;Enter "^" to exit or the Enter key to return to provider lookup.
  1. DA ;;Select the provider to assign the parameter
  1. PSP ;Process Selected Provider
  1. S CIDC=$$GET^XPAR(IEN_";VA(200,","OR BILLING AWARENESS BY USER",1,"Q")
  1. I CIDC="" D
  1. . ;Assign the CIDC parameter and enable/disable it
  1. . S DIR(0)="SO^"_$P($T(AE),";",3)_";"_$P($T(AD),";",3)
  1. . S DIR("A")=$P($T(AA),";",3)
  1. . S DIR("?",1)=$P($T(AHE),";",3),DIR("?")=$P($T(AHD),";",3)
  1. . D SCRHDR
  1. . W !,$P($T(ASH1),";",3)," ",NAME,!,$P($T(ASH2),";",3)
  1. . D ^DIR S US=Y K DIR
  1. . I US=""!($D(DTOUT))!($D(DUOUT)) Q
  1. . S VAL=$S(US="E":1,1:0),OREM=""
  1. . D ADD^XPAR(IEN_";VA(200,","OR BILLING AWARENESS BY USER",1,VAL,.OREM)
  1. E D
  1. . ;Edit the CIDC parameter to enable or disable it
  1. . S DIR(0)="Y"
  1. . I CIDC=0 S DIR("A")=$P($T(EEA),";",3),DIR("?",1)=$P($T(EHEY),";",3)
  1. . E S DIR("A")=$P($T(EDA),";",3),DIR("?",1)=$P($T(EHDY),";",3)
  1. . S DIR("B")="YES",DIR("?")=$P($T(EHN),";",3)
  1. . D SCRHDR
  1. . W !,$P($T(ESH),";",3)_" "_NAME
  1. . W:CIDC=0 !,$P($T(EESH),";",3)
  1. . W:CIDC=1 !,$P($T(EDSH),";",3)
  1. . W ! D ^DIR S US=Y K DIR
  1. . I US=""!(US=0)!($D(DTOUT))!($D(DUOUT)) Q
  1. . S OREM="",VAL=$S(CIDC=0:1,1:0)
  1. . D CHG^XPAR(IEN_";VA(200,","OR BILLING AWARENESS BY USER",1,VAL,.OREM)
  1. Q
  1. ASH1 ;;Assign CIDC Functionality Parameter to
  1. ASH2 ;;Enable / Disable CIDC Functionality
  1. AE ;;E:Enable CIDC functionality
  1. AA ;;Assign the parameter and enable / disable CIDC functionality
  1. AHE ;;Enter E to assign the parameter and enable CIDC for this provider.
  1. AHD ;;Enter D to assign the parameter and disable CIDC for this provider
  1. ESH ;;Edit Assigned CIDC Functionality Parameter of
  1. EESH ;;CIDC Functionality for this provider is currently DISABLED
  1. EDSH ;;CIDC Functionality for this provider is currently ENABLED
  1. EEA ;;Enable CIDC Functionality (YES/NO)
  1. EDA ;;Disable CIDC Functionality (YES/NO)
  1. EHEY ;;Enter YES to ENABLE CIDC Functionality
  1. EHDY ;;Enter YES to DISABLE CIDC Functionality
  1. EHN ;;Enter NO to leave CIDC Functionality unchanged
  1. ;
  1. SCRHDR ;Screen Header
  1. W:$D(IOF) @IOF
  1. W !,$P($T(SH1),";",3)
  1. Q
  1. SH1 ;;Clinical Indicator Data Capture By Provider Parameter Management