Tech Articles


Grid datawindow object with variable number of columns


Here is a way to build a grid datawindow which contains columns corresponding to an unknown number of data elements. You could use this approach in creating a project schedule, inventory location system, baseball box score, or any number of other examples. My example assumes the minimum number of columns to be four.

This create grid event returns a string.

long    ll_columns, ll_count, ll_pos
string ls_errors, ls_sql, ls_dw_presentation, ls_dw_syntax, ls_find, ls_name, ls_mod_string
// base presentation information
ls_dw_presentation =    "style( type=Grid                          &
            Horizontal_spread = 25 )            &
     datawindow( units=1                       &
             Color= 16777215)              &
     column( Font.Face='Arial'         &
         Font.Height=-9                    &
         Font.Weight=400)                  &
         text(   Font.Face='Arial' &
         Font.Height=-9                    &
         Font.Weight=400                   &
             Border=6)"

// set initial grid to 4 columns (plus time_of_day and last_col columns)
ls_sql = "SELECT space(10) as time_of_day, space(40) as col1, space(40) as col2, space(40) as col3, space(40) as col4,"

ll_count = 5 // next column to add would be 5

// this is the variable number of data elements
ll_columns = ids_trains.rowcount()

// add any additional columns past 4
DO WHILE ll_count <= ll_columns
    ls_sql += " space(40) as col" + string(ll_count) + ","
    ll_count++
LOOP

ls_sql += " '' as last_col"
ls_sql += " FROM dbo.TRAINS WITH (NOLOCK) WHERE 1 = 2"
// build the datawindow syntax from the presentation and sql statement
ls_dw_syntax = SQLCA.Syntaxfromsql( ls_sql, ls_dw_presentation, ls_errors)
IF Len(ls_errors) = 0 THEN
    // widen the header band a bit
    ls_dw_syntax = Replace(ls_dw_syntax, Pos(ls_dw_syntax,"header(height=19)"), Len("header(height=19)"), "header(height=23)")
    // create dwo and assign to grid
    dw_grid.create(ls_dw_syntax,ls_errors)
END IF
// appearance modifies
dw_grid.modify("last_col.visible=FALSE")

FOR ll_count = 1 TO Long(dw_grid.Object.DataWindow.Column.Count)
    IF dw_grid.Describe("#" + String(ll_count) + ".Visible") = "1" Then
        ls_name = dw_grid.Describe("#" + String(ll_count) + ".Name") 
        ls_mod_string = ls_name + "_t.background.mode=0" // must set to opaque or color does not show
        ls_errors = dw_grid.modify(ls_mod_string)
        // set the column heading color
        ls_mod_string = ls_name + "_t.background.color=12632256"
        ls_errors = dw_grid.modify(ls_mod_string)
        IF POS(ls_name ,'time_of_day') = 0 THEN
            ls_mod_string = ls_name + "_t.Alignment=0" //left
            ls_errors = dw_grid.modify(ls_mod_string)
        END IF
        ls_mod_string = ls_name + "_t.Height=18"
        ls_errors = dw_grid.modify(ls_mod_string)
        ls_mod_string = ls_name + "_t.tooltip.enabled=1"
        ls_errors = dw_grid.modify(ls_mod_string)
    END IF
NEXT
RETURN ls_errors


Now I know you can do several modifies with a single statement but it is much easier to debug if you do a single attribute at a time.

Once you have the grid set up you can call subsequent methods to populate it (and make columns invisible if needed), resize the width of the columns, etc.

Example schedule grid datawindow


Example grid for a time schedule with fifteen minute increments.

Comments (0)
There are no comments posted here yet

Find Articles by Tag

REST Debugger DataType Text Database Connection CoderObject Trial Icon OAuth 2.0 Automated Testing TLS/SSL PowerBuilder (Appeon) Error WinAPI Debugging Import JSON NativePDF DataWindow JSON Deployment Git Database PowerServer Mobile Design Bug HTTPClient RibbonBar Builder API .NET Std Framework UI Themes iOS DragDrop C# DataWindow Linux OS SQL Server DevOps PFC Transaction Filter UI Modernization Export JSON Database Table Configuration Web Service Proxy WebBrowser PDFlib Window PostgreSQL SOAP Interface Jenkins SqlExecutor PDF SQL .NET Assembly SqlModelMapper Graph PowerServer Web PBDOM Messagging OrcaScript RESTClient Oracle Source Control Event Handler ActiveX Variable Service InfoMaker Excel JSONParser ODBC Charts RichTextEdit Control 32-bit Visual Studio Sort Mobile Testing TreeView GhostScript PowerBuilder Windows 10 Icons Outlook Menu SDK Windows OS Migration SVN Expression SnapObjects Azure Authentication PBVM Branch & Merge Application File Web API Model Class JSONGenerator Database Painter External Functions Import Database Profile Elevate Conference Encryption BLOB TFS XML OAuth Encoding PostgreSQL ODBC driver Installation Event Handling Syntax PowerBuilder Compiler UI TortoiseGit IDE Database Object Debug Validation CrypterObject CI/CD PowerScript (PS) License Authorization PBNI Event SnapDevelop OLE Resize Database Table Data JSON Array Stored Procedure Open Source Export Script COM Platform MessageBox Android .NET DataStore 64-bit Source Code Database Table Schema DLL RibbonBar Performance Data Repository