User Interface

Hi Everyone, I need to Implement one grid Structure that would be like 

the grid would be dynamic grid, the request Ids may depend on cif number, For Example (CIf-117907 have 5 requests (123456,12456,13456,134566,1244555) like that.

How Would I do that if someone can provide solution that would be more helpful, If more details required please let me know  

Thanks.

  Discussion posts and replies are publicly visible

Parents
  • 0
    Certified Lead Developer

    Can you please elaborate more

  • ok, I need to implement one grid with all request Ids related to the cif. One cif may have one one request,other cif may have multiple request. The grid structure as shown above and dynamic grid. examples( cif-112233 may have 123456,786535 requests and other cif may have cif-345678 ,requests(432167,654328,876543,7655433) like so on



  • a!localVariables(
      local!approvedCAs: rule!CR_QE_getApprovedCAsByFilters(
        cif_int: ri!cif_int,
        requestId_int: ri!requestId_int
      ),
      local!selectedButton: joinarray(
        {
          index(
            ri!crModuleStatus_cdt,
            "requestId_int",
            {}
          ) & if(
            or(
              rule!APN_isBlank(
                index(
                  ri!crModuleStatus_cdt,
                  "versionNo_int",
                  {}
                )
              ),
              rule!APN_isZero(
                index(
                  ri!crModuleStatus_cdt,
                  "versionNo_int",
                  {}
                )
              )
            ),
            "",
            "." & index(
              ri!crModuleStatus_cdt,
              "versionNo_int",
              {}
            )
          ),
          index(
            ri!crModuleStatus_cdt,
            "actionType_txt",
            {}
          ),
          index(
            ri!crModuleStatus_cdt,
            "approvedOn_dt",
            {}
          )
        },
        " - "
      ),
      {
        rule!CR_APP_RT_displayApproverInfoNote(
          message_txt: "Select workflow to see the Request data"
        ),
        a!sideBySideLayout(
          items: {
            a!sideBySideItem(
              item: a!buttonArrayLayout(
                buttons: {
                  a!forEach(
                    items: joinarray(
                      {
                        index(
                          ri!crModuleStatus_cdt,
                          "requestId_int",
                          
                          {}
                        ) & if(
                          or(
                            rule!APN_isBlank(
                              index(
                                ri!crModuleStatus_cdt,
                                "versionNo_int",
                                {}
                              )
                            ),
                            rule!APN_isZero(
                              index(
                                ri!crModuleStatus_cdt,
                                "versionNo_int",
                                {}
                              )
                            )
                          ),
                          "",
                          "." & index(
                            ri!crModuleStatus_cdt,
                            "versionNo_int",
                            {}
                          ),
                          
                        ),
                        index(
                          ri!crModuleStatus_cdt,
                          "actionType_txt",
                          {}
                        ),
                        index(
                          ri!crModuleStatus_cdt,
                          "approvedOn_dt",
                          {}
                        )
                      },
                      " - "
                    ),
                    expression: {
                      a!buttonWidget(
                        label: fv!item,
                        value: fv!item,
                        saveInto: local!selectedButton,
                        size: if(
                          local!selectedButton = fv!item,
                          "STANDARD",
                          "SMALL"
                        ),
                        style: if(
                          local!selectedButton = fv!item,
                          "PRIMARY",
                          "LINK"
                        )
                      )
                    }
                  )
                },
                align: "START",
                showWhen: ri!workFlow_bool
              )
            ),
            a!sideBySideItem(
              item: a!buttonArrayLayout(
                buttons: {
                  a!buttonWidget(
                    label: "Completed Requests",
                    style: "PRIMARY"
                  )
                },
                align: "START",
                
              )
            ),
            
          }
        )
      }
    )

    And the result I am getting as this  But Result should be in seperate button /action ,How would I achieve this?

  • 0
    Certified Lead Developer
    in reply to sid

     
    If you are expecting similar to below grid



    Then refer this code for understanding

    a!localVariables(
      local!data: {
        a!map(
          cif: "cif1",
          request: { "request1", "request2" }
        ),
        a!map(
          cif: "cif2",
          request: { "request3", "request4", "request5" }
        ),
        a!map(cif: "cif3", request: { "request6" })
      },
      {
        a!gridField(
          labelPosition: "ABOVE",
          data: local!data,
          columns: {
            a!gridColumn(label: "CIF", value: fv!row.cif),
            a!gridColumn(
              label: "Requests",
              value: a!buttonArrayLayout(
                buttons: a!forEach(
                  items: fv!row.request,
                  expression: a!buttonWidget(label: fv!item, value: fv!item)
                )
              )
            )
          }
        )
      }
    )

  • a!localVariables(
      local!data: a!map(
        request: rule!CR_QE_getApprovedCAsByFilters(
          requestId_int: ri!requestId_int,
          cif_int: ri!cif_int
        )
      ),
      {
        a!gridField(
          labelPosition: "ABOVE",
          data: local!data,
          columns: {
            a!gridColumn(
              label: "Requests",
              value: a!buttonArrayLayout(
                buttons: a!forEach(
                  items: fv!row.request,
                  expression: a!buttonWidget(label: fv!item, value: fv!item)
                )
              )
            )
          }
        )
      }
    )

    Here is My code, And result I am getting is this,Please correct where I went wrong here And can we make it as side by side instead of Grid Bcoz User wants as side by side tab.

Reply
  • a!localVariables(
      local!data: a!map(
        request: rule!CR_QE_getApprovedCAsByFilters(
          requestId_int: ri!requestId_int,
          cif_int: ri!cif_int
        )
      ),
      {
        a!gridField(
          labelPosition: "ABOVE",
          data: local!data,
          columns: {
            a!gridColumn(
              label: "Requests",
              value: a!buttonArrayLayout(
                buttons: a!forEach(
                  items: fv!row.request,
                  expression: a!buttonWidget(label: fv!item, value: fv!item)
                )
              )
            )
          }
        )
      }
    )

    Here is My code, And result I am getting is this,Please correct where I went wrong here And can we make it as side by side instead of Grid Bcoz User wants as side by side tab.

Children
  • 0
    Certified Lead Developer
    in reply to sid

    Under Request Structure you might need to choose correct column for example under request it should be id_int something else.


    Yes you can change from grid to side by side layout.

    a!localVariables(
      local!data: rule!CR_QE_getApprovedCAsByFilters(
        requestId_int: ri!requestId_int,
        cif_int: ri!cif_int
      ),
      {
        a!buttonArrayLayout(
          buttons: a!forEach(
            items: local!data,
            expression: a!buttonWidget(
              label: fv!item.id_int,
              /*Replace "id_int" with field which you want to display as label.*/
              value: fv!item.id_int/*Replace "id_int" with field which you want to display as label.*/
    
            )
          )
        )
      }
    )




  • a!localVariables(
      local!moduleStatus: a!map(
        request: rule!CR_QE_getApprovedCAsByFilters(
          requestId_int: ri!requestId_int,
          cif_int: ri!cif_int
        )
      ),
      {
        a!gridField(
          labelPosition: "ABOVE",
          data: local!moduleStatus,
          columns: {
            a!gridColumn(
              value: a!buttonArrayLayout(
                buttons: a!forEach(
                  items: fv!row.request,
                  expression: a!buttonWidget(
                    label: joinarray(
                      {fv!item.requestId_int & fv!item.actionType_txt & fv!item.approvedOn_dt},
                      " - "
                    ),
                    value: joinarray(
                      {fv!item.requestId_int & fv!item.actionType_txt & fv!item.approvedOn_dt},
                      " - "
                    ),
                  )
                )
              )
            )
          }
        )
      }
    )

    Ok thanks for your input, Shubham, I have written this code by adding few more things. Can we achieve as a side-by-side buttons by any chance?

    Result I am getting is this

  • 0
    Certified Lead Developer
    in reply to sid

    a!localVariables(
      local!moduleStatus: a!map(
        request: rule!CR_QE_getApprovedCAsByFilters(
          requestId_int: ri!requestId_int,
          cif_int: ri!cif_int
        )
      ),
      {
        a!buttonArrayLayout(
                buttons: a!forEach(
                  items: fv!row.request,
                  expression: a!buttonWidget(
                    label: joinarray(
                      {fv!item.requestId_int & fv!item.actionType_txt & fv!item.approvedOn_dt},
                      " - "
                    ),
                    value: joinarray(
                      {fv!item.requestId_int & fv!item.actionType_txt & fv!item.approvedOn_dt},
                      " - "
                    )
                  )
                )
              )
      }
    )


    Try this once