VistA-FOIAVistA/r/CLINICAL_MONITORING_SYSTEM-QAM/QAMC7.m

31 lines
2.2 KiB
Mathematica

QAMC7 ;HISC/DAD-CONDITION: LENGTH OF STAY IN A TREATING SPECIALTY ;2/10/92 07:33
;;1.0;Clinical Monitoring System;;09/13/1993
EN1 ; *** CONDITION CODE
S LOS=$S($D(^QA(743,QAMD0,"COND",QAMD1,"P1"))#2:+^("P1"),1:0)
S TXSPGRP=$S($D(^QA(743,QAMD0,"COND",QAMD1,"P2"))#2:+^("P2"),1:0)
S X1=QAMTODAY,X2=-LOS D C^%DTC S (X1,START)=X,X2=1 D C^%DTC S END=X,START=START-.0000001 K ^UTILITY($J,"QAM TEMP")
F TXSPDT=START:0 S TXSPDT=$O(^DGPM("AMV6",TXSPDT)) Q:(TXSPDT'>0)!(TXSPDT'<END)!(TXSPDT\1'?7N) F QAMDFN=0:0 S QAMDFN=$O(^DGPM("AMV6",TXSPDT,QAMDFN)) Q:QAMDFN'>0 D LOOP0
F QAMDFN=0:0 S QAMDFN=$O(^UTILITY($J,"QAM TEMP",QAMDFN)) Q:QAMDFN'>0 F TXSPDT=0:0 S TXSPDT=$O(^UTILITY($J,"QAM TEMP",QAMDFN,TXSPDT)) Q:TXSPDT'>0 D LOOP2
K ^UTILITY($J,"QAM TEMP"),LOS,TXSPGRP,X1,X2,END,START,TXSPDT,TXSP,IEN,X
Q
LOOP0 F IEN=0:0 S IEN=$O(^DGPM("AMV6",TXSPDT,QAMDFN,IEN)) Q:IEN'>0 D LOOP1
Q
LOOP1 I TXSPGRP S TXSP=+$S($D(^DGPM(IEN,0))#2:$P(^(0),"^",9),1:0) Q:$O(^QA(743.5,TXSPGRP,"GRP","AB",TXSP,0))'>0
K ^UTILITY($J,"QAM TEMP",QAMDFN) S ^UTILITY($J,"QAM TEMP",QAMDFN,TXSPDT)=IEN
Q
LOOP2 S X=$O(^DGPM("APTT3",QAMDFN,TXSPDT)) Q:(X'>QAMTODAY)&X S X=$O(^DGPM("APTT6",QAMDFN,TXSPDT)) Q:(X'>QAMTODAY)&X
S ^UTILITY($J,"QAM CONDITION",QAMD1,QAMDFN)="",^UTILITY($J,"QAM CONDITION",QAMD1,QAMDFN,QAMTODAY)=^UTILITY($J,"QAM TEMP",QAMDFN,TXSPDT)
Q
EN2 ; *** PARAMETER CODE
K DIR,DIRUT S DIR(0)="NO^1:365:0",DIR("A")="LENGTH OF STAY",DIR("B")=$S($D(^QA(743,QAMD0,"COND",QAMD1,"P1"))#2:^("P1"),1:"") K:DIR("B")="" DIR("B")
S DIR("?",1)="Enter the LOS from the date of the patient's transfer into",DIR("?",2)="a treating specialty.",DIR("?")="Enter the treating specialty length of stay from 1-365 days."
S QAMPARAM="P1" D EN3^QAMUTL1 I $D(DIRUT) S Y=-1 G Y
S:Y]"" ^QA(743,QAMD0,"COND",QAMD1,"P1")=Y
2 K DIC,DIR,DIRUT S DIC=743.5,DIC(0)="EMNQZ",DIC("S")="I $P(^(0),""^"",2)=45.7",DIC("A")="TREATING SPECIALTY GROUP: ",DIC("B")=$S($D(^QA(743,QAMD0,"COND",QAMD1,"P2"))#2:$P(^("P2"),"^",2),1:"") K:DIC("B")="" DIC("B")
S DIR("?",1)="Enter a GROUP name that contains MAS treating specialties.",DIR("?")="press 'RETURN' for all treating specialties."
S QAMPARAM="P2" D EN2^QAMUTL1 I $D(DIRUT) S Y=-1 G Y
S:Y]"" ^QA(743,QAMD0,"COND",QAMD1,"P2")=+Y_"^"_Y(0,0)
EXIT K Y
K QAMPARAM
Y Q