| 1 | PRSPEAN ;WOIFO/SAB - NEW EXTENDED ABSENCE ;10/20/2004 | 
|---|
| 2 | ;;4.0;PAID;**93**;Sep 21, 1995;Build 7 | 
|---|
| 3 | ;;Per VHA Directive 2004-038, this routine should not be modified. | 
|---|
| 4 | ; Enter New Extended Absence | 
|---|
| 5 | ; | 
|---|
| 6 | N DA,DDSFILE,DDSCHANG,DDSPARM,DIC,DIK,DIR,DIROUT,DIRUT,DO,DR,DTOUT,DUOUT | 
|---|
| 7 | N EAIEN,PRSEANEW,PRSFDT,PRSIEN,PRSX,X,Y | 
|---|
| 8 | ; | 
|---|
| 9 | ; determine Employee IEN | 
|---|
| 10 | S PRSIEN=$$PRSIEN^PRSPUT2(1) | 
|---|
| 11 | I 'PRSIEN G EXIT | 
|---|
| 12 | ; | 
|---|
| 13 | ; verify that user has electronic signature code | 
|---|
| 14 | I '$$ESIGC^PRSPUT2(1) G EXIT | 
|---|
| 15 | ; | 
|---|
| 16 | FDT ; ask new from date | 
|---|
| 17 | S DIR(0)="D^DT:"_$$FMADD^XLFDT(DT,365)_":EX",DIR("A")="FROM DATE" | 
|---|
| 18 | S DIR("?")="Enter the beginning date for a new period of extended absence" | 
|---|
| 19 | D ^DIR K DIR G:$D(DIRUT) EXIT | 
|---|
| 20 | S PRSFDT=$P(Y,U) | 
|---|
| 21 | ; | 
|---|
| 22 | ; If From Date = Today make sure ESR not already posted with RG time. | 
|---|
| 23 | I PRSFDT=DT,$$CHKRG^PRSPEAU(PRSIEN) D  G FDT | 
|---|
| 24 | . W $C(7),!,"From Date can't be Today because RG time already posted on the ESR!" | 
|---|
| 25 | ; | 
|---|
| 26 | ; check for conflicts with from date | 
|---|
| 27 | S PRSX=$$CONFLICT^PRSPEAU(PRSIEN,PRSFDT) | 
|---|
| 28 | I PRSX'="" D RCON^PRSPEAU(PRSX) G FDT | 
|---|
| 29 | ; | 
|---|
| 30 | ; if date changed and new date not under memo then warn user | 
|---|
| 31 | I $$MIEN^PRSPUT1(PRSIEN,PRSFDT)'>0 W $C(7),!!,"Note: From Date is not covered by a memo." S DIR(0)="E" D ^DIR K DIK G:$D(DIRUT) EXIT | 
|---|
| 32 | ; | 
|---|
| 33 | ; create new entry in file | 
|---|
| 34 | K DO S DIC="^PRST(458.4,",DIC(0)="",X=PRSFDT | 
|---|
| 35 | S DIC("DR")="2////^S X=PRSIEN" | 
|---|
| 36 | D FILE^DICN | 
|---|
| 37 | I Y<0 W $C(7),!,"Unable to add an extended absence to the file." G EXIT | 
|---|
| 38 | S EAIEN=+Y | 
|---|
| 39 | ; | 
|---|
| 40 | ; lock record | 
|---|
| 41 | L +^PRST(458.4,EAIEN):2 | 
|---|
| 42 | I '$T D  G EXIT | 
|---|
| 43 | . W $C(7),!,"ERROR: Unable to lock the new entry!" | 
|---|
| 44 | . S DIK="^PRST(458.4,",DA=EAIEN D ^DIK K DIK | 
|---|
| 45 | ; | 
|---|
| 46 | ; call form to edit entry | 
|---|
| 47 | S PRSEANEW=1 | 
|---|
| 48 | S DDSFILE=458.4,DA=EAIEN,DR="[PRSP EXT ABSENCE]",DDSPARM="C" | 
|---|
| 49 | D ^DDS | 
|---|
| 50 | ; | 
|---|
| 51 | ; delete new entry if not saved | 
|---|
| 52 | I $G(DDSCHANG)'=1 S DIK="^PRST(458.4,",DA=EAIEN D ^DIK K DIK | 
|---|
| 53 | ; | 
|---|
| 54 | ; unlock record | 
|---|
| 55 | L -^PRST(458.4,EAIEN) | 
|---|
| 56 | ; | 
|---|
| 57 | EXIT ; exit point | 
|---|
| 58 | Q | 
|---|
| 59 | ; | 
|---|
| 60 | ;PRSPEAN | 
|---|