home *** CD-ROM | disk | FTP | other *** search
- // Tbex13.prg
- //
- // DbLookup function, where programmer passes an array containing
- // the names of fields to display
-
- #include "Inkey.ch"
-
- // Default column separator
- #define DEF_CSEP " " + chr(179) + " "
-
- // Default heading separator
- #define DEF_HSEP chr(205) + chr(209) + chr(205)
-
- // Default footing separator
- #define DEF_FSEP chr(205) + chr(207) + chr(205)
-
- FUNCTION Tbex13
-
- CLEAR SCREEN
- DbLookup("tbdbf1", {"Lname", "Fname", "Acbal"})
- ? Recno()
-
- RETURN NIL
-
-
- FUNCTION DbLookup(cDbfName, aFieldNames)
-
- LOCAL nSaveSel := Select()
- LOCAL oTbr := TBrowseDB(11, 11, 19, 69)
- LOCAL cSaveScr := SaveScreen(10, 10, 20, 70)
- LOCAL nField
- LOCAL oTbcTemp
- LOCAL lExitRequested := .F.
- LOCAL nKey
-
- oTbr:headSep := DEF_HSEP
- oTbr:footSep := DEF_FSEP
- oTbr:colSep := DEF_CSEP
-
- @ 10, 10 TO 20, 70
- USE (cDbfName) NEW
-
- // Create and add a TBColumn object for each database field in
- // the aFieldNames array
- FOR nField := 1 TO Len(aFieldNames)
- oTbcTemp := TBColumnNew(aFieldNames[nField], ;
- FieldBlock(aFieldNames[nField]))
- oTbr:addColumn(oTbcTemp)
- NEXT
-
- DO WHILE !lExitRequested
- DO WHILE !oTbr:stabilize()
- ENDDO
- nKey := InKey(0)
- IF !StdMeth(nKey, oTbr)
- DO CASE
- CASE nKey == K_ESC .OR. nKey == K_ENTER
- lExitRequested := .T.
- ENDCASE
- ENDIF
- ENDDO
-
- SELECT (nSaveSel)
- RestScreen(10, 10, 20, 70, cSaveScr)
-
- RETURN NIL
-
-
- FUNCTION StdMeth(nKey, oTbr)
-
- LOCAL lKeyHandled := .T.
-
- DO CASE
- CASE nKey == K_DOWN; oTbr:down()
- CASE nKey == K_UP; oTbr:up()
- CASE nKey == K_PGDN; oTbr:pageDown()
- CASE nKey == K_PGUP; oTbr:pageUp()
- CASE nKey == K_CTRL_PGUP; oTbr:goTop()
- CASE nKey == K_CTRL_PGDN; oTbr:goBottom()
- CASE nKey == K_RIGHT; oTbr:right()
- CASE nKey == K_LEFT; oTbr:left()
- CASE nKey == K_HOME; oTbr:home()
- CASE nKey == K_END; oTbr:end()
- CASE nKey == K_CTRL_LEFT; oTbr:panLeft()
- CASE nKey == K_CTRL_RIGHT; oTbr:panRight()
- CASE nKey == K_CTRL_HOME; oTbr:panHome()
- CASE nKey == K_CTRL_END; oTbr:panEnd()
- OTHERWISE; lKeyHandled := .F.
- ENDCASE
-
- RETURN lKeyHandled
-