How to create custom grid

Hi,

I have a requirement to create a grid something like the one below :

first row first column has one cell, first row second column has two cells and first row third column has two cells.

Date

Name

Code

Monday September 20, 2021

Dave

1122

Frank

1133

Tuesday September 21, 2021

Maria

3322

John

1324

Joe

3444

Thursday September 23, 2021

Adam

3432

Please suggest

  Discussion posts and replies are publicly visible

Parents
  • 0
    Certified Lead Developer

    There's no exact solution for this available in base Appian.  My first approach would be to build a Read-Only Grid where the Name and Code column values are Rich Text, and iterate over all the values that belong in that primary row, separating them with line returns.  There are other possible "approximate" approaches too, like perhaps building a quasi-grid using stacked Cards, etc.

    Here's a "portable" example of my primary suggestion above, using your example data structure:

    Fullscreen
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    a!localVariables(
    local!array: {
    a!map(
    date: today() - 5,
    people: {
    a!map(name: "Dave", code: 1122),
    a!map(name: "Frank", code: 1133)
    }
    ),
    a!map(
    date: today() - 4,
    people: {
    a!map(name: "Maria", code: 3322),
    a!map(name: "John", code: 1324),
    a!map(name: "Joe", code: 3444)
    }
    ),
    a!map(
    date: today() - 3,
    people: { a!map(name: "Adam", code: 3432) }
    )
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Reply
  • 0
    Certified Lead Developer

    There's no exact solution for this available in base Appian.  My first approach would be to build a Read-Only Grid where the Name and Code column values are Rich Text, and iterate over all the values that belong in that primary row, separating them with line returns.  There are other possible "approximate" approaches too, like perhaps building a quasi-grid using stacked Cards, etc.

    Here's a "portable" example of my primary suggestion above, using your example data structure:

    Fullscreen
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    a!localVariables(
    local!array: {
    a!map(
    date: today() - 5,
    people: {
    a!map(name: "Dave", code: 1122),
    a!map(name: "Frank", code: 1133)
    }
    ),
    a!map(
    date: today() - 4,
    people: {
    a!map(name: "Maria", code: 3322),
    a!map(name: "John", code: 1324),
    a!map(name: "Joe", code: 3444)
    }
    ),
    a!map(
    date: today() - 3,
    people: { a!map(name: "Adam", code: 3432) }
    )
    XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Children
  • Hi Mike, 

    Thank you for the explanation. But my data is coming from database view insted of local array. However I tried to use the above code but it does not seem to work in grid. Could you please suggest on this.

  • 0
    Certified Lead Developer
    in reply to shubhamy0001

    The primary reason for using local data in the above sample code is for ease of portability (i.e. anyone here can copy/paste that into their interface designer and see what i did, as long as they have a reasonably modern version of Appian).  In a normal use case data would be coming from the database, but the above example would still work pending adjustments to account for the particular configuration of your data.