| 1 | SCCVPAR ;ALB/TMP - SCHED VISITS CONVERSION PARAMETERS; [ 03/02/98  10:47 AM ]
 | 
|---|
| 2 |  ;;5.3;Scheduling;**211**;Aug 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | PARAM ; Main entry point - display scheduling conversion parameters
 | 
|---|
| 5 |  D EN^VALM("SCCV CONV PARAM MENU")
 | 
|---|
| 6 |  D REFRESH^SCCVCDSP
 | 
|---|
| 7 |  Q
 | 
|---|
| 8 |  ;
 | 
|---|
| 9 | INIT ; -- set up initial variables
 | 
|---|
| 10 |  D FNL
 | 
|---|
| 11 |  S U="^",VALMCNT=0,VALMBG=1
 | 
|---|
| 12 |  D BLD
 | 
|---|
| 13 |  Q
 | 
|---|
| 14 |  ;
 | 
|---|
| 15 | HDR ;
 | 
|---|
| 16 |  S VALMHDR(1)=""
 | 
|---|
| 17 |  Q
 | 
|---|
| 18 |  ;
 | 
|---|
| 19 | FNL ; Clean up
 | 
|---|
| 20 |  K ^TMP("SCCV.PARAM",$J),^TMP("SCCV.PARAM.DX",$J)
 | 
|---|
| 21 |  Q
 | 
|---|
| 22 |  ;
 | 
|---|
| 23 | BLD ;Build parameter display
 | 
|---|
| 24 |  N SCCVCNV
 | 
|---|
| 25 |  S VALMBG=1
 | 
|---|
| 26 |  K ^TMP("SCCV.PARAM",$J)
 | 
|---|
| 27 |  S VALMCNT=0
 | 
|---|
| 28 |  S SCCVCNV=$G(^SD(404.91,1,"CNV"))
 | 
|---|
| 29 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 30 |  D SET^VALM10(VALMCNT," ")
 | 
|---|
| 31 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 32 |  D SET^VALM10(VALMCNT,"Earliest encounter date to be converted: "_$S(+SCCVCNV:$$FMTE^XLFDT(+SCCVCNV,"1D"),1:"<Not Specified>"))
 | 
|---|
| 33 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 34 |  D SET^VALM10(VALMCNT,"Limit CST date range to 1 year or less?: "_$$EXPAND^SCCVDSP2(404.91,905,+$P(SCCVCNV,U,5)))
 | 
|---|
| 35 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 36 |  D SET^VALM10(VALMCNT,"             Default Disposition Clinic: "_$$NONE^SCCVDSP2(404.91,902,$P(SCCVCNV,U,2),"<Not Specified>"))
 | 
|---|
| 37 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 38 |  D SET^VALM10(VALMCNT,"                 Maximum Errors Allowed: "_$$EXPAND^SCCVDSP2(404.91,907,$S($P(SCCVCNV,U,7):$P(SCCVCNV,U,7),1:1000)))
 | 
|---|
| 39 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 40 |  D SET^VALM10(VALMCNT,"            Display Cancelled Templates: "_$$EXPAND^SCCVDSP2(404.91,909,+$P(SCCVCNV,U,9)))
 | 
|---|
| 41 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 42 |  D SET^VALM10(VALMCNT," ")
 | 
|---|
| 43 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 44 |  D SET^VALM10(VALMCNT,"Date Conversion Completed: "_$S('$$COMPL():"* UNEDITABLE - CST entry(s) missing or incomplete *",1:$$FMTE^XLFDT($P(SCCVCNV,U,4),"1D")))
 | 
|---|
| 45 |  S VALMCNT=VALMCNT+1
 | 
|---|
| 46 |  D SET^VALM10(VALMCNT,"Date Deletion   Completed: "_$S('$$COMPL():"* UNEDITABLE - CST entry(s) missing or incomplete *",1:$$FMTE^XLFDT($P(SCCVCNV,U,3),"1D")))
 | 
|---|
| 47 |  Q
 | 
|---|
| 48 |  ;
 | 
|---|
| 49 | EDIT ; Edit scheduling conversion parameters
 | 
|---|
| 50 |  N SCDT1
 | 
|---|
| 51 |  S SCDT1=$P($G(^SD(404.91,1,"CNV")),U,4)
 | 
|---|
| 52 |  D FULL^VALM1
 | 
|---|
| 53 |  S DIE="^SD(404.91,",DA=1,DR="[SCCV CONV EDIT SITE PARAMS]"
 | 
|---|
| 54 |  D ^DIE
 | 
|---|
| 55 |  I 'SCDT1,$P($G(^SD(404.91,1,"CNV")),U,4) D
 | 
|---|
| 56 |  . S DIR(0)="YA",DIR("A")="Do you want to delete the old scheduling files now? ",DIR("B")="NO" D ^DIR K DIR
 | 
|---|
| 57 |  . I Y=1 D
 | 
|---|
| 58 |  .. D EN^SCCVDEL
 | 
|---|
| 59 |  D BLD
 | 
|---|
| 60 |  S VALMBCK="R"
 | 
|---|
| 61 |  Q
 | 
|---|
| 62 |  ;
 | 
|---|
| 63 | 903(SKIPTO) ;
 | 
|---|
| 64 |  N DIR,Y
 | 
|---|
| 65 |  ;
 | 
|---|
| 66 |  Q:'$P($G(^SD(404.91,1,"CNV")),U,3)!($G(SCCVX(903)))
 | 
|---|
| 67 |  ;
 | 
|---|
| 68 |  I '$P($G(^SD(404.91,1,"CNV")),U,4) D  G Q903
 | 
|---|
| 69 |  .S DIR(0)="EA"
 | 
|---|
| 70 |  .S DIR("A",1)="DATE CONVERSION COMPLETED must be entered before you can enter this date",DIR("A")="Press RETURN to continue"
 | 
|---|
| 71 |  .D ^DIR K DIR
 | 
|---|
| 72 |  .S SKIPTO="@30"
 | 
|---|
| 73 |  ;
 | 
|---|
| 74 |  S DIR(0)="YA",DIR("B")="NO"
 | 
|---|
| 75 |  S DIR("A",1)="Entering this date indicates that your site is finished",DIR("A",2)="deleting any old encounter files that can be deleted.",DIR("A",3)=" ",DIR("A")="Are you sure you want to do this?: "
 | 
|---|
| 76 |  D ^DIR K DIR
 | 
|---|
| 77 |  I Y'=1 S SKIPTO="@30"
 | 
|---|
| 78 |  ;
 | 
|---|
| 79 | Q903 Q
 | 
|---|
| 80 |  ;
 | 
|---|
| 81 | 904(SKIPTO) ;
 | 
|---|
| 82 |  N DIR,SC0,SCLACT,SCLEVT,SCOK,Y,Z
 | 
|---|
| 83 |  ;
 | 
|---|
| 84 |  G:'$P($G(^SD(404.91,1,"CNV")),U,4)!($G(SCCVX(904))) Q904
 | 
|---|
| 85 |  ;
 | 
|---|
| 86 |  ; All CST's must be canceled or completed before date can be entered
 | 
|---|
| 87 |  I '$$COMPL() D  S SKIPTO="@20" G Q904
 | 
|---|
| 88 |  . W !
 | 
|---|
| 89 |  . S DIR(0)="EA"
 | 
|---|
| 90 |  .S DIR("A",1)="You must complete or cancel each CST before you may enter this date",DIR("A",2)="At least one CST was found to be missing or incomplete",DIR("A")="Press RETURN to continue "
 | 
|---|
| 91 |  . D ^DIR K DIR
 | 
|---|
| 92 |  . W !
 | 
|---|
| 93 |  ;
 | 
|---|
| 94 |  I $$SEQGAP() D  S SKIPTO="@20" G Q904 ; Check for gaps in the dt range
 | 
|---|
| 95 |  . N DIR,Y,SCDT1
 | 
|---|
| 96 |  . S SCDT1=$P($G(^SD(404.91,1,"CNV")),U)
 | 
|---|
| 97 |  . S:SCDT1 SCDT1=$$FMTE^XLFDT(SCDT1,2)
 | 
|---|
| 98 |  . W !
 | 
|---|
| 99 |  . S DIR(0)="EA"
 | 
|---|
| 100 |  . S DIR("A",1)="You have one or more gaps in conversion dates from your earliest date to",DIR("A",2)=" convert ("_$S(SCDT1'="":SCDT1,1:"NOT ENTERED")_") to 9-30-96"
 | 
|---|
| 101 |  . S DIR("A",3)="You must finish converting before you can enter the conversion completed date",DIR("A")="Press RETURN to continue "
 | 
|---|
| 102 |  . D ^DIR K DIR
 | 
|---|
| 103 |  . W !
 | 
|---|
| 104 |  ;
 | 
|---|
| 105 |  S DIR(0)="YA",DIR("B")="NO"
 | 
|---|
| 106 |  S DIR("A",1)="Entering this date prevents you from converting any more data from the old",DIR("A",2)=" Scheduling files to the PCE V-files",DIR("A",3)=" ",DIR("A")="Are you sure you want to do this?: "
 | 
|---|
| 107 |  D ^DIR K DIR
 | 
|---|
| 108 |  I Y'=1 S SKIPTO="@20"
 | 
|---|
| 109 |  ;
 | 
|---|
| 110 | Q904 Q
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 | COMPL(ANY) ; Check if all/any CST's are complete or canceled
 | 
|---|
| 113 |  ; Returns 0 if function fails, 1 if function succeeds
 | 
|---|
| 114 |  ; ANY = 1: just check for ANY completed
 | 
|---|
| 115 |  ;
 | 
|---|
| 116 |  N Z,SC0,SCOK,SCLACT,SCLEVT,SCANY
 | 
|---|
| 117 |  ;
 | 
|---|
| 118 |  I '$G(ANY) S SCOK='$$SEQGAP() G COMPLQ  ;Check all for full range
 | 
|---|
| 119 |  ;
 | 
|---|
| 120 |  S Z=0,SCANY=0
 | 
|---|
| 121 |  F  S Z=$O(^SD(404.98,Z)) Q:'Z  S SC0=$G(^(Z,0)) D  Q:SCANY
 | 
|---|
| 122 |  . Q:$P(SC0,U,9)  ; CST canceled
 | 
|---|
| 123 |  . S SCLACT=+$$LSTACT^SCCVLOG(Z),SCLEVT=+$$LSTEVT^SCCVLOG(Z)
 | 
|---|
| 124 |  . I $S(SCLACT'=5:0,1:"12"[SCLEVT) S SCANY=1 Q  ; Last actn (cnvrt/recnvrt) completed
 | 
|---|
| 125 |  ;
 | 
|---|
| 126 | COMPLQ Q $S($G(ANY):SCANY,1:SCOK)
 | 
|---|
| 127 |  ;
 | 
|---|
| 128 | SEQGAP() ; Checks entire date range from start to 9-30-96 has been converted 
 | 
|---|
| 129 |  ; Returns 0 if no gap found from earliest date to convert to 09/30/96
 | 
|---|
| 130 |  ;         1 if gap found
 | 
|---|
| 131 |  N Z,Z0,SC0,SCLACT,SCLEVT,SCGAP,SCDT1,SCDT2
 | 
|---|
| 132 |  ;
 | 
|---|
| 133 |  S Z=0,SCGAP=0
 | 
|---|
| 134 |  F  S Z=$O(^SD(404.98,Z)) Q:'Z  S SC0=$G(^(Z,0)) D
 | 
|---|
| 135 |  . Q:$P(SC0,U,9)  ; CST canceled
 | 
|---|
| 136 |  . S SCLACT=+$$LSTACT^SCCVLOG(Z),SCLEVT=+$$LSTEVT^SCCVLOG(Z)
 | 
|---|
| 137 |  . I $S(SCLACT'=5:0,1:"12"[SCLEVT) D  ; Last actn (cnvrt/recnvrt) completed
 | 
|---|
| 138 |  .. S SCGAP(+$$FMTH^XLFDT($P(SC0,U,3),1))=+$$FMTH^XLFDT($P(SC0,U,4),1)
 | 
|---|
| 139 |  ;
 | 
|---|
| 140 |  S SCDT1=+$$FMTH^XLFDT(+$G(^SD(404.91,1,"CNV"),2801001),1) ; start date
 | 
|---|
| 141 |  S SCDT2=+$$FMTH^XLFDT($$ENDDATE^SCCVU(),1)                          ; end date
 | 
|---|
| 142 |  S SCGAP=0,Z=SCDT1
 | 
|---|
| 143 |  F  S Z0=$G(SCGAP(Z)) D  Q:SCGAP!(Z0=SCDT2)  ;Check ranges for gaps
 | 
|---|
| 144 |  . I Z0=SCDT2 Q                              ; No gaps found
 | 
|---|
| 145 |  . I Z0="" S SCGAP=1 Q                       ; Gap found...S/B an entry at Z
 | 
|---|
| 146 |  . I Z=SCDT1 S Z=Z0+1 Q                      ; First date range
 | 
|---|
| 147 |  . S Z=Z0+1
 | 
|---|
| 148 |  ;
 | 
|---|
| 149 |  Q SCGAP
 | 
|---|
| 150 |  ;
 | 
|---|