| 1 | SCCVCST3 ;ALB/TMP - Scheduling Conversion Template Utilities - CST; APR 20, 1998
 | 
|---|
| 2 |  ;;5.3;Scheduling;**211**;Aug 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | ONE ; -- Select/Convert one pt's encounter episode - no CST needed
 | 
|---|
| 5 |  D FULL^VALM1
 | 
|---|
| 6 |  ; -- is conversion enabled
 | 
|---|
| 7 |  IF '$$OK^SCCVU(1) G ONEQ
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 |  F  W !! Q:$$SEL1()
 | 
|---|
| 10 |  ;
 | 
|---|
| 11 | ONEQ S VALMBCK="R"
 | 
|---|
| 12 |  Q
 | 
|---|
| 13 |  ;
 | 
|---|
| 14 | SEL1() ; Select an entry, convert
 | 
|---|
| 15 |  N DIR,X,Y,SCFILE,SCFILE1,SCCVDFN,SCCVTYP,SCCVDA,SCCVCOD,SCQUIT,DA,DIC,DIQ,SCSTOP,SCCVEVT,SCPREF,Z,SCCVACRP,SCCV900,SCCVDIS
 | 
|---|
| 16 |  S SCCVACRP=$$ENDDATE^SCCVU()
 | 
|---|
| 17 |  S SCCV900=+$O(^DIC(40.7,"C",900,0))
 | 
|---|
| 18 |  S SCSTOP=0
 | 
|---|
| 19 |  S DIR(0)="SAMB^C:Convert;R:Reconvert",DIR("A")="(C)onvert/(R)econvert: ",DIR("B")="Convert"
 | 
|---|
| 20 |  D ^DIR K DIR
 | 
|---|
| 21 |  I Y["^" S SCSTOP=1 G SEL1Q
 | 
|---|
| 22 |  S SCCVEVT=$S(Y="C":1,1:2),SCPREF=$S(SCCVEVT=1:"",1:"re")
 | 
|---|
| 23 |  ;
 | 
|---|
| 24 |  S DIR(0)="SABM^E:Encounter;D:Disposition;A:Appointment;S:Standalone Add/Edit",SCCVCOD=$P(DIR(0),U,2)
 | 
|---|
| 25 |  S DIR("A")="TYPE OF ENTRY TO "_$S(SCCVEVT=1:"",1:"RE")_"CONVERT: ",DIR("?")="Select the type of entry you want to "_SCPREF_"convert from the list"
 | 
|---|
| 26 |  D ^DIR K DIR
 | 
|---|
| 27 |  I "EDAS"'[Y S SCSTOP=1 G SEL1Q
 | 
|---|
| 28 |  S SCCVTYP=Y,SCCVTYPN=$P($P(SCCVCOD,SCCVTYP_":",2),";")
 | 
|---|
| 29 |  ;
 | 
|---|
| 30 |  S DIC="^DPT(",DIC(0)="AEMQ" D ^DIC ;Select patient
 | 
|---|
| 31 |  G:Y'>0 SEL1Q
 | 
|---|
| 32 |  S SCCVDFN=+Y
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  S SCFILE=$$SETFL($S(SCCVTYP="E":0,SCCVTYP="D":3,SCCVTYP="A":1,1:2),SCCVDFN)
 | 
|---|
| 35 |  S SCFILE1=$S(SCFILE["SCE"!(SCFILE["SDV"):SCFILE_"("_$S(SCFILE["SCE":"""ADFN"","_SCCVDFN_",",1:""),1:$P(SCFILE,")")_",") ;Indirection format
 | 
|---|
| 36 |  ;
 | 
|---|
| 37 |  ; Select a specific entry
 | 
|---|
| 38 |  S SCQUIT=0
 | 
|---|
| 39 |  W !
 | 
|---|
| 40 |  S DIR(0)=$S(SCFILE["SCE":"NAO^^I $P($G(^SCE(X,0)),U,2)'=SCCVDFN K X",SCFILE["SDV":"FAO^^D DTCNVT^SCCVCST3(.X)",1:"DAO^:"_SCCVACRP_":RXP")
 | 
|---|
| 41 |  S DIR("A")="ENTER THE "_$S(SCFILE["SDV":"SCHEDULING VISIT ENTRY #",SCFILE["SCE":"ENCOUNTER ENTRY #",SCFILE["""DIS""":"DISPOSITION DATE/TIME",1:"APPOINTMENT DATE/TIME")_", IF KNOWN: "
 | 
|---|
| 42 |  S DIR("?",1)="Enter the "_$S(SCFILE["SCE":"internal entry number",1:"date/time")_" of the "_SCCVTYPN_" to "_SCPREF_"convert, if you know it"
 | 
|---|
| 43 |  S Z=2
 | 
|---|
| 44 |  I SCFILE["SDV" S DIR("?",2)="Date may be entered in internal or external format",Z=Z+1
 | 
|---|
| 45 |  S DIR("?",Z)="Must be a valid "_SCCVTYPN_$S(SCFILE'["SCE":" date/time",1:"")_" for the patient"_$S(SCFILE'["SCE":", on or before "_$$FMTE^XLFDT(SCCVACRP,"1D"),1:"")
 | 
|---|
| 46 |  S DIR("?")="If not known, Press RETURN to review the "_SCCVTYPN_"s on a specific date"
 | 
|---|
| 47 |  D ^DIR K DIR
 | 
|---|
| 48 |  W !!
 | 
|---|
| 49 |  ;
 | 
|---|
| 50 |  S SCCVDA=$S(Y'>0:0,SCFILE'["""DIS""":+Y,1:9999999-Y)
 | 
|---|
| 51 |  I SCCVDA D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,$S(SCFILE'["SCE":+Y,1:+$G(^SCE(SCCVDA,0))),SCCVDA,0,.SCQUIT,.SCONE) ;Specific entry selected
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 |  G:SCQUIT SEL1Q
 | 
|---|
| 54 |  ;
 | 
|---|
| 55 |  ; Select entry by date or date/time
 | 
|---|
| 56 |  S DIR(0)="DAO^:"_SCCVACRP_":PTSX"
 | 
|---|
| 57 |  S DIR("A")="DATE: "
 | 
|---|
| 58 |  S DIR("?",1)="Enter a valid date or date and time of the patient's "_SCCVTYPN_" to "_SCPREF_"convert."
 | 
|---|
| 59 |  S DIR("?",2)=" The date must be on or before "_$$FMTE^XLFDT(SCCVACRP,1)_".",DIR("?",3)=" "
 | 
|---|
| 60 |  S DIR("?",4)="If you enter only a date, all the patient's "_SCCVTYPN_"s on that date will be",DIR("?",5)=" presented one at a time.  If the entry displayed is the correct one,"
 | 
|---|
| 61 |  S DIR("?")=" you may request it be "_SCPREF_"converted or if not the correct one, reject it."
 | 
|---|
| 62 |  D ^DIR K DIR
 | 
|---|
| 63 |  G:'Y SEL1Q
 | 
|---|
| 64 |  S SCDTM=+Y,SCQUIT=0
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 |  I SCDTM'["." D  G:SCQUIT SEL1Q ; Date only entered
 | 
|---|
| 67 |  . ; SCQUIT is set to 1 when an entry is selected for conversion
 | 
|---|
| 68 |  . ; SCONE is set to 1 if at least one valid entry is found
 | 
|---|
| 69 |  . ;
 | 
|---|
| 70 |  . N SCONE,SC,SCV,SCF,SCD
 | 
|---|
| 71 |  . S SCF=$S(SCFILE["SCE":"^SCE(""ADFN"","_SCCVDFN_")",SCFILE["SDV":"^SDV(""ADT"","_SCCVDFN_")",1:SCFILE)
 | 
|---|
| 72 |  . S SCONE=$S(SCF["SCE":$O(@SCF@(SCDTM)),SCF["""S""":$O(@SCF@(SCDTM)),SCF["""DIS""":9999999-$O(@SCF@(9999999-SCDTM),-1),1:$O(@SCF@(SCDTM-1)))
 | 
|---|
| 73 |  . S SCONE=(SCONE\1=SCDTM)
 | 
|---|
| 74 |  . I '$G(SCONE) D NOENT^SCCVCST4(SCCVTYPN,SCCVDFN,SCDTM) S SCQUIT=1 Q  ;No valid entry found
 | 
|---|
| 75 |  . I SCCVEVT=2 S SCONE=0
 | 
|---|
| 76 |  . ;
 | 
|---|
| 77 |  . I SCFILE["SCE"!(SCFILE["""S""") D  ; Encounters and Appts
 | 
|---|
| 78 |  .. S SC=SCDTM,SCONE=0
 | 
|---|
| 79 |  .. F  S SC=$O(@SCF@(SC)) Q:'SC!((SC\1)'=SCDTM)  D  Q:SCQUIT
 | 
|---|
| 80 |  ... I SCF["SCE" D  ; Encounters
 | 
|---|
| 81 |  .... S SCD=0 F  S SCD=$O(@SCF@(SC,SCD)) Q:'SCD  W "." I '$P($G(^SCE(SCD,0)),U,6) D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,+$G(^SCE(SCD,0)),SCD,1,.SCQUIT,.SCONE) Q:SCQUIT
 | 
|---|
| 82 |  ... ;
 | 
|---|
| 83 |  ... I SCF["""S""" D  ; Appts
 | 
|---|
| 84 |  .... D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,SC,SC,1,.SCQUIT,.SCONE)
 | 
|---|
| 85 |  . ;
 | 
|---|
| 86 |  . I SCFILE["""DIS""" D  ; Dispositions
 | 
|---|
| 87 |  .. S SCDTM=9999999-SCDTM-1,SC=SCDTM+1,SCONE=0
 | 
|---|
| 88 |  .. F  S SC=$O(@SCF@(SC),-1) Q:'SC!((SC\1)'=SCDTM)  W "." D  Q:SCQUIT
 | 
|---|
| 89 |  ... D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,9999999-SC,SC,1,.SCQUIT,.SCONE)
 | 
|---|
| 90 |  . I SCFILE["SDV" D  ; Add/edits
 | 
|---|
| 91 |  .. S SCONE=0,SC=$G(@SCF@(SCDTM))
 | 
|---|
| 92 |  .. Q:SC=""
 | 
|---|
| 93 |  .. D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,SC,SC,1,.SCQUIT,.SCONE)
 | 
|---|
| 94 |  . ;
 | 
|---|
| 95 |  . I 'SCONE S SCQUIT=1 D NOENT^SCCVCST4(SCCVTYPN,SCCVDFN,SCDTM) Q
 | 
|---|
| 96 |  . ;
 | 
|---|
| 97 |  . I 'SCQUIT,SCONE S DIR(0)="EA",DIR("A",1)="NO ENTRY SELECTED",DIR("A")="PRESS RETURN " D ^DIR K DIR
 | 
|---|
| 98 |  ;
 | 
|---|
| 99 |  I SCDTM["." D  ; Date and time entered
 | 
|---|
| 100 |  . I SCFILE["SCE" D  ; Encounter
 | 
|---|
| 101 |  .. S SCCVDA=0 F  S SCCVDA=$O(^SCE("ADFN",SCCVDFN,SCDTM,SCCVDA)) W "." Q:'SCCVDA  D
 | 
|---|
| 102 |  ... D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,SCDTM,SCCVDA,1,.SCQUIT,.SCONE)
 | 
|---|
| 103 |  . ;
 | 
|---|
| 104 |  . I SCFILE'["SCE" D  ; Non-encounter
 | 
|---|
| 105 |  .. S SCCVDA=$S(SCFILE'["""DIS""":SCDTM,1:9999999-SCDTM)
 | 
|---|
| 106 |  .. D CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,SCDTM,SCCVDA,0,.SCQUIT,.SCONE)
 | 
|---|
| 107 | SEL1Q Q SCSTOP
 | 
|---|
| 108 |  ;
 | 
|---|
| 109 | SETFL(SCCVTYP,SCCVDFN) ;Set the lookup format of the file
 | 
|---|
| 110 |  ; INPUT: SCCVTYP, SCCVDFN
 | 
|---|
| 111 |  ; FUNCTION OUTPUT: Lookup format of filename for type/patient
 | 
|---|
| 112 |  ;
 | 
|---|
| 113 |  Q $S(SCCVTYP=0:"^SCE",SCCVTYP=3:"^DPT("_SCCVDFN_",""DIS"")",SCCVTYP=1:"^DPT("_SCCVDFN_",""S"")",SCCVTYP=2:"^SDV",1:"")
 | 
|---|
| 114 |  ;
 | 
|---|
| 115 | CHK(SCCVEVT,SCCVTYPN,SCFILE,SCFILE1,SCDTM,SC,SCMULT,SCQUIT,SCONE) ;
 | 
|---|
| 116 |  ; Check for validity for convert, display entry, convert if confirmed
 | 
|---|
| 117 |  N SCV,DIR,Y
 | 
|---|
| 118 |  I $$VAL1^SCCVCST5(SCCVEVT,SCFILE,SC,SCMULT) D
 | 
|---|
| 119 |  .S SCONE=1
 | 
|---|
| 120 |  .W ! S SCV=$$DISP1^SCCVCST4(SCCVTYPN,SCFILE1,SC)
 | 
|---|
| 121 |  .I 'SCV S:SCV="^" SCQUIT=1 Q
 | 
|---|
| 122 |  .S SCQUIT=1 D CONV1^SCCVCST4(SCCVEVT,SCFILE,SCCVDFN,SCDTM,SC)
 | 
|---|
| 123 |  Q
 | 
|---|
| 124 |  ;
 | 
|---|
| 125 | DTCNVT(X) ; Convert date/time for disposition
 | 
|---|
| 126 |  N SCZ,SCX,Y,Z,%DT
 | 
|---|
| 127 |  S %DT="RXPT"
 | 
|---|
| 128 |  I X["@"!(X'[".") D
 | 
|---|
| 129 |  . S SCX=$P(X,"@",2)
 | 
|---|
| 130 |  . S SCZ=$TR(SCX,"APMapm"),Z=$L(SCZ) ;strip AM/PM from time
 | 
|---|
| 131 |  . I Z>4 S %DT=%DT_"S" S:Z=5 X=$P(X,"@")_"@"_SCZ_"0"
 | 
|---|
| 132 |  D ^%DT S X=Y
 | 
|---|
| 133 |  K:Y<0 X
 | 
|---|
| 134 |  Q
 | 
|---|
| 135 |  ;
 | 
|---|