home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Monster Media 1993 #2
/
Image.iso
/
clipper
/
cuaclip.zip
/
EX1.PRG
< prev
next >
Wrap
Text File
|
1993-06-01
|
4KB
|
182 lines
/*********************************************************************
EX1.PRG - CUA-Clip Library examples.
This file contains sample code illustrating the GET system.
NOTES:
1) This example will create the files Printer.DBF and Printer.NTX.
2) Also contains samples of:
- DBNetUse/DBNetClose
- ShadowBox
- Alert
- SetMessColor
- SetListKey
- ValidGets
Author: Dave Rooney
Date : Feb. 22, 1993
*********************************************************************/
#include "Demo.CH"
//
// Example 1 - Standard GETs & Buttons
//
FUNCTION GET_Examples
LOCAL cScreen, ; // Screen behind the dialog box
cOldColor, ; // Colour on entry
GetList, ; // Local GetList array
cPrinter, ; // Name of the printer
nPort, ; // Printer port selected
lPostScript, ; // .T. if the printer is PostScript
aPrinters, ; // DBLIST array for the Printer lookup
aPorts, ; // Radio button array for the Printer port
lProceed, ; // .T. if proceeding with the update
cMsgText, ; // Text for the ALERT message
aOptions, ; // Options array for the ALERT
nChoice, ; // Selection from the ALERT
lExit // Loop control flag
//
// Initialize the variables...
//
cOldColor := SETCOLOR()
GetList := {}
cPrinter := SPACE(30)
nPort := 1
lPostScript := .F.
lProceed := .F.
lExit := .F.
//
// Ensure Printer.DBF/.NTX are there. If not, make 'em!
//
IF !( FILE( "Printer.DBF" ) .AND. FILE( "Printer.NTX" ))
_BuildPrinter()
ENDIF
//
// Radio button array for the printer port...
//
aPorts := { { { 1, "LPT1" }, { 2, "LPT2" }, { 3, "LPT3" } } }
//
// List of available printers:
//
// Table Index Display Exp. Search Exp.
// v v v v
//
aPrinters := { "Printer", "Printer",, {|| FIELD->PrnName },, {|x| UPPER(x) } }
//
// Open the printer file.
//
IF DBNetUse( .T., "DBFNTX", "Printer" )
DBSETINDEX( "Printer" )
ELSE
SETCOLOR( cOldColor )
RETURN NIL
ENDIF
//
// Display the dialog box
//
cScreen := ShadowBox( 2, 12, 12, 64, 2, "GR+/B" )
SETCOLOR( "W+/B" )
@ 2,13 SAY "[ CUA-Clip Interface Library - GET System Examples ]"
SETCOLOR( "BG+/B" )
@ 4,15 SAY " Printer:"
@ 4,59 SAY "<F2>"
@ 6,15 SAY " Port:"
@ 8,15 SAY "PostScript:"
//
// Standard GET with a database list. Note the use of Monitor() to
// refresh all of the GETs after a printer name has been entered.
// This will change the colour of the radio buttons and check box
// from dimmed to normal.
//
@ 4,27 GET cPrinter PICTURE "@!" ;
VALID Printer->( DBSEEK( UPPER( cPrinter ), .F. )) .AND. Monitor() ;
DBLIST aPrinters ;
COLOR "W+/N, W+/R, W/N" ;
MESSAGE "Enter the name of the printer"
//
// Radio buttons - nothing too fancy here!
//
@ 6,27 GET nPort USING RADIO WITH aPorts ;
WHEN !EMPTY( cPrinter ) ;
VALID ( nPort > 0 ) ;
COLOR "W+/B, W+/R, W/B" ;
MESSAGE "Select the port for the printer"
//
// Check box - piece of cake!
//
@ 8,27 GET lPostScript USING CHECK ;
WHEN !EMPTY( cPrinter ) ;
COLOR "W+/B, W+/R, W/B" ;
MESSAGE "Is it a PostScript printer?"
//
// Push buttons - code 'em in your sleep! Note that the ACTION expression
// returns a logical value: .T. means end the READ, .F. means continue.
//
@ 10,25 BUTTON " ~OK " ;
ACTION lProceed := ( ValidGets() == 0 ) ;
COLOR "W+/BG, W+/R, N/BG, R/BG, N/BG"
@ 10,43 BUTTON " E~xit " ;
ACTION !( lProceed := .F. ) ;
COLOR "W+/BG, W+/R, N/BG, R/BG, N/BG"
DO WHILE !lExit
READ SAVE // Use "SAVE" so that the GETs aren't cleared!
IF lProceed
cMsgText := "You selected: " + ALLTRIM( cPrinter ) + ;
IF( lPostScript, " (PostScript) ", " " ) + ;
"on LPT" + ALLTRIM( STR( nPort ))
aOptions := { "Continue", "Exit" }
// Message Options Colours Beep Shadow
// v v v v v
nChoice := ALERT( cMsgText, aOptions, "W+/BG, W+/R, W+/B", .F., .T. )
lExit := ( nChoice == 2 )
ELSE
lExit := .T.
ENDIF
ENDDO
//
// Get rid of the dialog box...
//
KillBox( cScreen )
//
// Close the printer file...
//
DBNetClose( "Printer" )
SETCOLOR( cOldColor )
RETURN NIL
//
// That's all folks!
//