1 | GMPLX ; SLC/MKB/AJB -- Problem List Problem Utilities ; 02/27/2004
|
---|
2 | ;;2.0;Problem List;**7,23,26,28,27**;Aug 25, 1994
|
---|
3 | ;
|
---|
4 | ; External References
|
---|
5 | ; DBIA 446 ^AUTNPOV(
|
---|
6 | ; DBIA 10082 ^ICD9("BA"
|
---|
7 | ; DBIA 10060 ^VA(200
|
---|
8 | ; DBIA 10006 ^DIC
|
---|
9 | ; DBIA 10009 FILE^DICN
|
---|
10 | ; DBIA 10013 EN^DIK
|
---|
11 | ; DBIA 10013 IX1^DIK
|
---|
12 | ; DBIA 10026 ^DIR
|
---|
13 | ; DBIA 1609 CONFIG^LEXSET
|
---|
14 | ; DBIA 10103 $$FMTE^XLFDT
|
---|
15 | ; DBIA 10104 $$UP^XLFSTR
|
---|
16 | ; DBIA 2742 GMPLX
|
---|
17 | ; DBIA 3991 $$STATCHK^ICDAPIU
|
---|
18 | ;
|
---|
19 | SEARCH(X,Y,PROMPT,UNRES,VIEW) ; Search Lexicon for Problem X
|
---|
20 | N DIC S:'$L($G(VIEW)) VIEW="PL1" D CONFIG^LEXSET("GMPL",VIEW,DT)
|
---|
21 | S DIC("A")=$S($L($G(PROMPT)):PROMPT,1:"Select PROBLEM: ")
|
---|
22 | S DIC="^LEX(757.01,",DIC(0)=$S('$L($G(X)):"A",1:"")_"EQM"
|
---|
23 | S:'$G(UNRES) LEXUN=0 D ^DIC S:+Y>1 X=$P(Y,U,2)
|
---|
24 | Q
|
---|
25 | ;
|
---|
26 | PROVNARR(X,CL) ; Returns IFN ^ Text of Narrative (#9999999.27)
|
---|
27 | N DIC,Y,DLAYGO,DD,DO,DA S:$L(X)>80 X=$E(X,1,80)
|
---|
28 | S DIC="^AUTNPOV(",DIC(0)="L",DLAYGO=9999999.27,(DA,Y)=0
|
---|
29 | F S DA=$O(^AUTNPOV("B",$E(X,1,30),DA)) Q:DA'>0 I $P(^AUTNPOV(DA,0),U)=X S Y=DA_U_X Q
|
---|
30 | I '(+Y) K DA,Y D FILE^DICN S:Y'>0 Y=U_X I Y>0,CL>1 S ^AUTNPOV(+Y,757)=CL
|
---|
31 | Q $P(Y,U,1,2)
|
---|
32 | ;
|
---|
33 | PROBTEXT(IFN) ; Returns Display Text
|
---|
34 | N X,Y,GMPLEXP,GMPLPOV,GMPLSO,GMPLTXT
|
---|
35 | S Y=$P($G(^AUPNPROB(+IFN,0)),U,5),X=$P($G(^AUTNPOV(+Y,0)),U)
|
---|
36 | S GMPLEXP=$$EP(IFN),GMPLSO=$$CS(X),GMPLPOV=$$PT(X,GMPLSO)
|
---|
37 | S GMPLTXT=GMPLPOV S:$L(GMPLEXP) GMPLTXT=GMPLTXT_" ("_GMPLEXP_")"
|
---|
38 | S:$L(GMPLSO) GMPLTXT=GMPLTXT_" "_GMPLSO
|
---|
39 | S:GMPLTXT["*" GMPLTXT=$TR(GMPLTXT,"*","")
|
---|
40 | ;S:$L(GMPLTXT) GMPLTXT=GMPLTXT_" ("_$$HFP^GMPLUTL4_","_$$PTR^GMPLUTL4_")"
|
---|
41 | S:$L(GMPLTXT) X=GMPLTXT Q X
|
---|
42 | PROBNARR(IFN) ; Returns Provider Narrative
|
---|
43 | N X,Y S Y=$P($G(^AUPNPROB(+IFN,0)),U,5),X=$P($G(^AUTNPOV(+Y,0)),U)
|
---|
44 | Q X
|
---|
45 | CS(X) ; Problem Codes
|
---|
46 | N GMPLSAB,GMPLSO S GMPLSO="" S X=$G(X) Q:X'["(" ""
|
---|
47 | F GMPLSAB="ICD-","CPT-","DSM-","HCPCS","NANDA","NIC","NOC","LOINC","SNOMED","OMAHA" S:$G(X)[("("_GMPLSAB) GMPLSO="("_GMPLSAB_$P(X,("("_GMPLSAB),2,299) Q:$L(GMPLSO)
|
---|
48 | I $L(GMPLSO) S X=GMPLSO Q X
|
---|
49 | F GMPLSAB="ACR","AI/RHEUM","CONGRESS","COSTAR","COSTART","CRISP","DODFAC" S:$G(X)[("("_GMPLSAB) GMPLSO="("_GMPLSAB_$P(X,("("_GMPLSAB),2,299) Q:$L(GMPLSO)
|
---|
50 | I $L(GMPLSO) S X=GMPLSO Q X
|
---|
51 | F GMPLSAB="DORLAND","DXPLAIN","HHCC","MCMASTER","META","MTF","MeSH","RVC","TITLE 38","UMDNS","UWA" S:$G(X)[("("_GMPLSAB) GMPLSO="("_GMPLSAB_$P(X,("("_GMPLSAB),2,299) Q:$L(GMPLSO)
|
---|
52 | I $L(GMPLSO) S X=GMPLSO Q X
|
---|
53 | Q ""
|
---|
54 | EP(X) ; Exposures
|
---|
55 | N GMPLSC S X=+($G(X)) D SCS^GMPLX1(+X,.GMPLSC) S X=$G(GMPLSC(1)) Q X
|
---|
56 | PT(X,C) ; Problem Text (only)
|
---|
57 | N GMPLTERM,GMPLSO S GMPLTERM=$G(X),GMPLSO=$G(C)
|
---|
58 | S:$L(GMPLSO)&(GMPLTERM[GMPLSO) GMPLTERM=$P(GMPLTERM,GMPLSO,1) S GMPLTERM=$$TRIM(GMPLTERM)
|
---|
59 | S:$L(GMPLTERM) X=GMPLTERM Q X
|
---|
60 | TRIM(X) ; Trim Spaces and "*"
|
---|
61 | S X=$G(X) F Q:$E(X,$L(X))'=" " S X=$E(X,1,($L(X)-1))
|
---|
62 | F Q:$E(X,$L(X))'="*" S X=$E(X,1,($L(X)-1))
|
---|
63 | F Q:$E(X,$L(X))'=" " S X=$E(X,1,($L(X)-1))
|
---|
64 | F Q:$E(X,1)'=" " S X=$E(X,2,$L(X))
|
---|
65 | Q X
|
---|
66 | WRAP(PROB,MAX,TEXT) ; Splits Text into TEXT array
|
---|
67 | N I,J S J=0 K TEXT I $L(PROB)'>MAX S J=J+1,TEXT(J)=PROB G WRQ
|
---|
68 | WR0 ; Loop for Remaining Text
|
---|
69 | S I=$F(PROB," ") I ('I)!(I>(MAX+2)) S J=J+1,TEXT(J)=$E(PROB,1,MAX),PROB=$E(PROB,MAX+1,999)
|
---|
70 | I $L(PROB)>MAX F I=(MAX+1):-1:1 I $E(PROB,I)=" " S J=J+1,TEXT(J)=$E(PROB,1,I-1),PROB=$E(PROB,I+1,999) Q
|
---|
71 | G:$L(PROB)>MAX WR0
|
---|
72 | S:$L(PROB) J=J+1,TEXT(J)=PROB
|
---|
73 | WRQ ; Quit Wrap
|
---|
74 | S TEXT=J
|
---|
75 | Q
|
---|
76 | ;
|
---|
77 | NOS() ; Return PTR ^ 799.9 ICD code
|
---|
78 | N X S X=$O(^ICD9("BA",799.9,0)) Q (+X_"^799.9")
|
---|
79 | ;
|
---|
80 | SEL(HELP) ; Select List of Problems
|
---|
81 | N X,Y,DIR,MAX S MAX=+$G(^TMP("GMPL",$J,0)) I MAX'>0 Q "^"
|
---|
82 | S DIR(0)="LAO^1:"_MAX,DIR("A")="Select Problem(s)"
|
---|
83 | S:MAX>1 DIR("A")=DIR("A")_" (1-"_MAX_"): "
|
---|
84 | S:MAX'>1 DIR("A")=DIR("A")_": ",DIR("B")=1
|
---|
85 | S DIR("?")="Enter the problems you wish to "
|
---|
86 | S DIR("?")=DIR("?")_$S($L(HELP):HELP,1:"act on")_", as a range or list of numbers"
|
---|
87 | D ^DIR I $D(DTOUT)!(X="") S Y="^"
|
---|
88 | Q Y
|
---|
89 | ;
|
---|
90 | SEL1(HELP) ; Select 1 Problem
|
---|
91 | N X,Y,DIR,MAX S MAX=+$G(^TMP("GMPL",$J,0)) I MAX'>0 Q "^"
|
---|
92 | S DIR(0)="NAO^1:"_MAX_":0",DIR("A")="Select Problem"
|
---|
93 | S:MAX>1 DIR("A")=DIR("A")_" (1-"_MAX_"): "
|
---|
94 | S:MAX'>1 DIR("A")=DIR("A")_": ",DIR("B")=1
|
---|
95 | S DIR("?")="Enter the number of the problem you wish to "
|
---|
96 | S DIR("?")=DIR("?")_$S($L(HELP):HELP,1:"act on")
|
---|
97 | D ^DIR I $D(DTOUT)!(X="") S Y="^"
|
---|
98 | Q Y
|
---|
99 | ;
|
---|
100 | DUPL(DFN,TERM,TEXT) ; Check's for Duplicate Entries
|
---|
101 | N DA,IFN,NODE0,NODE1 S DA=0,TEXT=$$UP^XLFSTR(TEXT)
|
---|
102 | I '$D(^AUPNPROB("C",TERM))!('$D(^AUPNPROB("AC",DFN))) Q DA
|
---|
103 | F IFN=0:0 S IFN=$O(^AUPNPROB("AC",DFN,IFN)) Q:IFN'>0 D Q:DA>0
|
---|
104 | . S NODE0=$G(^AUPNPROB(IFN,0)),NODE1=$G(^(1)) Q:$P(NODE1,U,2)="H"
|
---|
105 | . I TERM>1 S:+NODE1=TERM DA=IFN Q
|
---|
106 | . S:TEXT=$$UP^XLFSTR($P(^AUTNPOV($P(NODE0,U,5),0),U)) DA=IFN
|
---|
107 | Q DA
|
---|
108 | ;
|
---|
109 | DUPLOK(IFN) ; Ask to Duplicate Problem
|
---|
110 | N DIR,X,Y,GMPL0,GMPL1,DATE,PROV S DIR(0)="YA",GMPL0=$G(^AUPNPROB(IFN,0)),GMPL1=$G(^(1))
|
---|
111 | S DIR("A")="Are you sure you want to continue? ",DIR("B")="NO"
|
---|
112 | S DIR("?",1)="Enter YES if you want to duplicate this problem on this patient's list;",DIR("?")="press <return> to re-enter the problem name."
|
---|
113 | W $C(7),!!,">>> "_$$PROBTEXT(IFN),!?5,"is already an "
|
---|
114 | W $S($P(GMPL0,U,12)="I":"IN",1:"")_"ACTIVE problem on this patient's list!",!
|
---|
115 | S PROV=+$P(GMPL1,U,5) W:PROV !?5,"Provider: "_$P($G(^VA(200,PROV,0)),U)_" ("_$P($$SERVICE^GMPLX1(PROV),U,2)_")"
|
---|
116 | I $P(GMPL0,U,12)="A" W !?8,"Onset: " S DATE=$P(GMPL0,U,13)
|
---|
117 | I $P(GMPL0,U,12)="I" W !?5,"Resolved: " S DATE=$P(GMPL1,U,7)
|
---|
118 | W $S(DATE>0:$$FMTE^XLFDT(DATE),1:"unspecified"),!
|
---|
119 | D ^DIR W !
|
---|
120 | Q +Y
|
---|
121 | ;
|
---|
122 | LOCKED() ; Returns Message that Problem is Locked
|
---|
123 | Q "This problem is currently being edited by another user!"
|
---|
124 | ;
|
---|
125 | SURE() ; Ask to Delete
|
---|
126 | ; Returns 1 if YES, else 0
|
---|
127 | N DIR,X,Y S DIR(0)="YA",DIR("B")="NO"
|
---|
128 | S DIR("?")="Enter YES to remove this value or NO to leave it unchanged."
|
---|
129 | S DIR("A")="Are you sure you want to remove this value? " D ^DIR
|
---|
130 | Q +Y
|
---|
131 | ;
|
---|
132 | EXTDT(DATE) ; Formats Date into MM/DD/YY
|
---|
133 | N X,MM,DD,YY,YYY S X="",DATE=$P(DATE,".") Q:'DATE ""
|
---|
134 | S MM=+$E(DATE,4,5),DD=+$E(DATE,6,7),YY=$E(DATE,2,3),YYY=$E(DATE,1,3)
|
---|
135 | S:MM X=MM_"/" S:DD X=X_DD_"/" S X=$S($L(X):X_YY,1:1700+YYY)
|
---|
136 | Q X
|
---|
137 | ;
|
---|
138 | AUDIT(DATA,OLD) ; Makes Entry in Audit File
|
---|
139 | ; DATA = string for 0-node
|
---|
140 | ; OLD = string for 1-node
|
---|
141 | ; = 0-node from reform/react problem
|
---|
142 | N DA,DD,DO,DIC,X,Y,DIK,DLAYGO
|
---|
143 | S DIC="^GMPL(125.8,",DIC(0)="L",X=$P(DATA,U),DLAYGO=125.8
|
---|
144 | D FILE^DICN Q:+Y'>0 S DA=+Y,DIK="^GMPL(125.8,"
|
---|
145 | S ^GMPL(125.8,DA,0)=DATA D IX1^DIK
|
---|
146 | S:$L(OLD) ^GMPL(125.8,DA,1)=OLD
|
---|
147 | Q
|
---|
148 | ;
|
---|
149 | DTMOD(DA) ; Update Date Last Modified
|
---|
150 | N DIE,DR
|
---|
151 | S DR=".03///TODAY",DIE="^AUPNPROB("
|
---|
152 | D ^DIE
|
---|
153 | Q
|
---|
154 | ;
|
---|
155 | MSG() ; List Manager Message Bar
|
---|
156 | Q "+ Next Screen - Prev Screen ?? More actions"
|
---|
157 | ;
|
---|
158 | KILL ; Clean-Up Variables
|
---|
159 | K X,Y,DIC,DIE,DR,DA,DUOUT,DTOUT,GMPQUIT,GMPRT,GMPSAVED,GMPIFN,GMPLNO,GMPLNUM,GMPLSEL,GMPREBLD,GMPI,GMPLSLST,GMPLJUMP
|
---|
160 | Q
|
---|
161 | ;
|
---|
162 | CODESTS(PROB,ADATE) ;check status of code associated with a problem
|
---|
163 | ; Input:
|
---|
164 | ; PROB = pointer to the PROBLEM (#9000011) file
|
---|
165 | ; ADATE = FM date on which to check the status of ICD9 code (opt.)
|
---|
166 | ;
|
---|
167 | ; Output:
|
---|
168 | ; 1 = ACTIVE on the date passed or current date if not passed
|
---|
169 | ; 0 = INACTIVE on the date passed or current date if not passed
|
---|
170 | ;
|
---|
171 | I '$G(ADATE) S ADATE=DT
|
---|
172 | I '$D(^AUPNPROB(PROB,0)) Q 0
|
---|
173 | S PROB=$P(^AUPNPROB(PROB,0),U)
|
---|
174 | Q +($$STATCHK^ICDAPIU($$CODEC^ICDCODE(+(PROB)),ADATE))
|
---|