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

FHWOR3.m

Go to the documentation of this file.
  1. FHWOR3 ; HISC/NCA - HL7 Early/Late Tray ;10/10/00 14:56
  1. ;;5.5;DIETETICS;;Jan 28, 2005
  1. S DATA=X
  1. N BAG,CODE,DATE,DAY,DTE,DP,EL,K,L1,LP,LSTWD,MEAL,PER,PIECE,SERV,SP,W1,WKD,WKDAYS,Y
  1. S:ITVL="" ITVL="ONCE"
  1. I 'SDT S TXT="No Start Date." D ERR^FHWOR Q
  1. S DATE=SDT D CVT^FHWOR S SDT=DATE\1
  1. I EDT S DATE=EDT D CVT^FHWOR S EDT=DATE\1
  1. I 'EDT S:ITVL="ONCE" EDT=SDT I 'EDT S TXT="No Stop Date." D ERR^FHWOR Q
  1. S SERV=$P(DATA,"|",2)
  1. I $P("EARLY",SERV,1)'="",$P("LATE",SERV,1)'="" S TXT="Wrong Type of Tray." D ERR^FHWOR Q
  1. S PER=$P(DATA,"|",3),PER=$E(PER,4,$L(PER)),MEAL=$E(PER,1) I "BNE"'[MEAL S TXT="Wrong Service Period." D ERR^FHWOR Q
  1. I $E(PER,2)'=$E(SERV,1) S TXT="Wrong Service Period." D ERR^FHWOR Q
  1. S PIECE=$E(PER,3) I 'PIECE S TXT="No Time Specified." D ERR^FHWOR Q
  1. S K=$S(MEAL="B":0,MEAL="N":6,1:12)+($E(PER,2)="L"*3)
  1. S W1=$P($G(^FHPT(FHDFN,"A",ADM,0)),"^",8),DP=$P($G(^FH(119.6,+W1,0)),"^",8)
  1. K TM F L1=1:1:3 S TM(L1)=$P($G(^FH(119.73,+DP,1)),"^",K+L1)
  1. S TIM=TM(PIECE) I TIM="" F L1=1:1:3 S:TM(L1)'="" TIM=TM(L1)
  1. I TIM="" S TXT="No Early/Late Time on file." D ERR^FHWOR Q
  1. S BAG="N" I $P(X,"|",4)="bagged" S BAG="Y"
  1. S X=SDT_"@"_TIM,%DT="XT" D ^%DT S (SDT,FHDTIM)=Y,EDT=EDT+(SDT#1)
  1. S (FHV1,FHV2)="" D CUR^FHWOR31(FHDFN,ADM,FHDTIM,.FHV1,.FHV2)
  1. S (WKDAYS,WKD)=""
  1. I SDT=EDT D G:SP ERR G PROC
  1. .S SP="" F K=SDT\1:0 S K=$O(^FHPT(FHDFN,"A",ADM,"EL",K)) Q:K<1!(K\1'=(SDT\1)) I $P(^(K,0),"^",2)=MEAL S SP=K Q
  1. .I SP S TXT="Early/Late Meal Already Ordered for this Date." Q
  1. .Q
  1. F LP=1:1 S CODE=$P(ITVL,"~",LP) Q:CODE="" D Q:TXT'=""
  1. .I CODE="ONCE" S TXT="ONCE is for one Day Only." Q
  1. .I $E(CODE,1)'="Q" S TXT="Wrong Interval specification. Use Only ONCE, QJ#, or Q1J#." Q
  1. .I +$E(CODE,2)>1 S TXT="Wrong interval specification. Use Only ONCE, QJ#, or Q1J#." Q
  1. .S LSTWD=$E(CODE,$L(CODE))
  1. .I LSTWD="J" S DAY=1 S WKD=WKD_$E("MTWRFSX",DAY) Q
  1. .I LSTWD?1N,$E(CODE,$L(CODE)-1)="J" D Q
  1. ..S DAY=LSTWD I DAY<1!(DAY>7) S TXT="Wrong Day Specification." Q
  1. ..S WKD=WKD_$E("MTWRFSX",DAY),WKDAYS=WKDAYS_DAY Q
  1. .S TXT="Wrong interval specification. Use Only ONCE, QJ#, or Q1J#."
  1. .Q
  1. I TXT'="" D ERR^FHWOR Q
  1. PROC ; Process Add E/L Trays
  1. D PROC^FHWOR31
  1. EXIT ; Exit Process Kill.
  1. K %,%H,%I,%DT,BAG,CODE,DATE,DAY,DTE,DP,EL,FHDAY,FHDTIM,FHV1,FHV2,K,L1,LP,LSTWD,MEAL,PER,PIECE,SERV,SP,W1,WKD,WKDAYS,X,Y Q
  1. ERR ; Send Error Message
  1. D ERR^FHWOR Q
  1. CAN ; Process Cancel/Discontinue from OE/RR
  1. D NOW^%DTC S NOW=%,CT=0
  1. D GADM^FHWORR
  1. F EL=%:0 S EL=$O(^FHPT(FHDFN,"A",+ADM,"EL",EL)) Q:EL<1!(EL>$P(FILL,";",5)) S X=$G(^(EL,0)) I $P(X,"^",7)=+FHORN K ^FHPT(FHDFN,"A",ADM,"EL",EL),^FHPT("ADLT",EL,FHDFN) S CT=CT+1
  1. S %=$S($D(^FHPT(FHDFN,"A",ADM,"EL",0)):$P(^(0),"^",4),1:0)-CT S:%'<0 $P(^(0),"^",4)=%
  1. K %,%H,%I,CT,EL D CSEND^FHWOR Q
  1. EL ; Code Early Late Tray
  1. K MSG S WKDAYS=""
  1. I SDT=EDT S ITVL="ONCE" G EL1
  1. S ITVL="" F K=1:1 S Z=$E(WKD,K) Q:Z="" S DAY=$F("MTWRFSX",Z),DAY=DAY-1 S:ITVL'="" ITVL=ITVL_"~" S ITVL=ITVL_"QJ"_DAY,WKDAYS=WKDAYS_DAY
  1. EL1 S FILL="E"_";"_ADM_";;"_SDT_";"_EDT_";"_WKD_";"_MEAL_";"_TIM_";"_BAG
  1. D SET
  1. ; Code MSH, PID, and PV1
  1. D MSH^FHWOR
  1. ; code ORC
  1. S MSG(4)="ORC|SN||"_FILL_"^FH||||^"_ITVL_"^^"_SDT_"^"_EDT_"|||"_DUZ_"||"_DUZ_"|||"_NOW
  1. ; code ODT
  1. S MSG(5)="ODT|"_$S(SERV="E":"EARLY",1:"LATE")_"|^^^"_MEAL_SERV_NUM_"^^99FHS|"_$S(BAG="Y":"bagged",1:"")
  1. K FHWARD,FILL,HOSP,ITVL,FHORN,RM,SITE,WARD,WKDAYS,Z Q
  1. CODE ; Code Cancel/Discontinue Early Late Tray
  1. K MSG S ACT="OC",WKD="",CTR=0 D SITE^FH
  1. S EDT="" F SK=0:0 S SK=$O(NN(FHORN,SK)) Q:SK<1 S CTR=CTR+1 S:CTR=1 SDT=SK S EDT=SK D WKD
  1. S STR=$G(^FHPT(FHDFN,"A",ADM,"EL",EDT,0))
  1. S FILL="E"_";"_ADM_";;"_SDT_";"_EDT_";"_WKD_";"_$P(STR,"^",2)_";"_$P(STR,"^",3)_";"_$P(STR,"^",4)
  1. ; code MSH
  1. S MSG(1)="MSH|^~\&|DIETETICS|"_SITE(1)_"|||||ORM"
  1. ; code PID
  1. S MSG(2)="PID|||"_DFN_"||"_$P($G(^DPT(DFN,0)),"^",1)
  1. ; code ORC
  1. S DATE=$$FMTHL7^XLFDT(NOW)
  1. S MSG(3)="ORC|"_ACT_"|"_FHORN_"^OR|"_FILL_"^FH|||||||||"_FHPV_"|||"_DATE_"|Dietetics Canceled Early/Late Tray order."
  1. K %,%Y,ACT,DATE,EDT,FILL,FHORN,SDT,SK,SITE,STR,WKD Q
  1. WKD ; Get week days
  1. D WKD^FHWOR31
  1. Q
  1. SET ; Set Date/Time in HL7 format
  1. D SET^FHWOR31
  1. Q
  1. NA ; OE/RR Number Assign
  1. S SDT=$P(FILL,";",4),EDT=$P(FILL,";",5),WKD=$P(FILL,";",6),MEAL=$P(FILL,";",7),TIM=$P(FILL,";",8),DTE=SDT
  1. G:'+FHORN KIL
  1. G:'$D(^FHPT(FHDFN,"A",ADM,"EL",SDT,0)) KIL
  1. I WKD="" S $P(^FHPT(FHDFN,"A",ADM,"EL",SDT,0),"^",7)=+FHORN G KIL
  1. F EL=SDT\1:0 S EL=$O(^FHPT(FHDFN,"A",ADM,"EL",EL)) Q:EL<1!(EL>EDT) D
  1. .Q:$P(^FHPT(FHDFN,"A",ADM,"EL",EL,0),"^",7)
  1. .Q:$P(^FHPT(FHDFN,"A",ADM,"EL",EL,0),"^",2)'=MEAL
  1. .Q:$P(^FHPT(FHDFN,"A",ADM,"EL",EL,0),"^",3)'=TIM
  1. .S X=EL D H^%DTC S:%Y=0 %Y=7 Q:%Y<0
  1. .S WKDAYS=$E("MTWRFSX",%Y) Q:WKDAYS=""
  1. .S:"MTWRFSX"[WKDAYS $P(^FHPT(FHDFN,"A",ADM,"EL",EL,0),"^",7)=+FHORN
  1. .Q
  1. KIL K %Y,DTE,EDT,EL,NUM,MEAL,MSG,FHORN,SDT,TIM,WKDAYS,WKD Q