home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
World of Shareware - Software Farm 2
/
wosw_2.zip
/
wosw_2
/
QBAS
/
WNDTOOL5.ZIP
/
KEYCAL.SUB
< prev
next >
Wrap
Text File
|
1989-04-26
|
5KB
|
117 lines
'
'$PAGE
'
'******************************************************************************
' Function : *
' *
' Purpose: *
' *
' *
' Results: *
' *
' Usage : *
' *
' *
' Date Written : 01/01/89 - Date Tested: 01/01/89 - Author: James P Morgan *
' Date Modified: - : - : *
'-----------------------------------------------------------------------------*
' NOTE: *
'******************************************************************************
' *
' SUB PROGRAM NAME (PARAMETERS) STATIC/RECURSIVE *
'-----------------------------------------------------------------------------*
' *
'============================================================================
'
SUB KEYCAL(MONTH%,YEAR%,QUADRANT$,FORE%,BACK%,SHADOW%) STATIC
DEFINT A-Z 'make all short intergers by default
IF (MONTH%<1) OR (MONTH%>12) THEN 'edit month for validity
GOTO KEYCAL.DONE
ENDIF
IF YEAR%<0 THEN 'edit year for validity
GOTO KEYCAL.DONE
ENDIF
GOSUB KEYCAL.DISPCAL 'display the calendar for this month/year
KEYCAL.TESTKEYS:
Q$=INKEY$ 'wait for user to press a key
IF Q$="" THEN
GOTO KEYCAL.TESTKEYS
ENDIF
IF (Q$=CHR$(13)) OR (Q$=CHR$(27)) THEN 'an Enter or ESC key pressed?
EXIT SUB 'Yes, then return to caller
ENDIF
IF LEN(Q$)=1 THEN 'only an extended function key allowed
GOSUB KEYCAL.SOUNDOFF
GOTO KEYCAL.TESTKEYS
ENDIF
KEY.VAL=ASC(RIGHT$(Q$,1)) 'strip out the extended key code
IF KEY.VAL=77 THEN 'cursor right key pressed?
MONTH%=MONTH%+1 'we want the next month
IF MONTH%=13 THEN 'did the month roll over?
MONTH%=1
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ELSE
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ENDIF
ENDIF
IF KEY.VAL=75 THEN 'cursor left key pressed?
MONTH%=MONTH%-1 'we want the previous month
IF MONTH%=0 THEN 'did the monthy roll back?
MONTH%=12
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ELSE
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ENDIF
ENDIF
IF KEY.VAL=80 THEN 'cursor down key pressed?
YEAR%=YEAR%-1 'we want the previous year, same month
IF YEAR%>=0 THEN
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ELSE
GOSUB KEYCAL.SOUNDOFF 'year would be invalid
GOTO KEYCAL.TESTKEYS
ENDIF
ENDIF
IF KEY.VAL=72 THEN 'cursor up key pressed?
YEAR%=YEAR%+1 'we want the next year, same month
GOSUB KEYCAL.DISPCAL 'display the calendar
GOTO KEYCAL.TESTKEYS
ENDIF
GOSUB KEYCAL.SOUNDOFF 'invalid extended key pressed
GOTO KEYCAL.TESTKEYS
'
KEYCAL.DISPCAL:
CALL CALENDAR(MONTH%,YEAR%,QUADRANT$,FORE%,BACK%,SHADOW%)
RETURN
'
KEYCAL.SOUNDOFF:
SOUND 1000,1 'alter user to problem/error
SOUND 1500,2
SOUND 500,1
RETURN
'
KEYCAL.DONE:
EXIT SUB 'return to caller
END SUB