Skip to main content
Version: Next

Tables

Tables are created using tanstack table.

tables.json

Create a src/vision/layouts/tables.json file (case-sensitive)

The src/vision/layouts/tables.json file is responsible for:

  • Defining what OML Vision Tables can render
    • Name of the Table
    • Commands that can be executed from the Table
    • Name of the columns for the Table
    • Queries that the Table's content needs
    • How to map Table queries to columns

It is formatted as a JSON data structure.

An example of what this looks like is seen below with the source code found here

{
"objectives": {
"name": "Objectives",
"diagrams": {
"all-rows": "objectives-diagram"
},
"columnNames": {
"o1_id": "Objective 1 ID",
"o1_name": "Objective 1 Name",
"o2_id": "Objective 2 ID",
"o2_name": "Objective 2 Name"
},
"queries": {
"o1_id": "objectives.sparql",
"o1_name": "objectives.sparql",
"o2_id": "objectives.sparql",
"o2_name": "objectives.sparql"
},
"rowMapping": {
"id": "o1_id",
"name": "Objectives",
"labelFormat": "Objective"
}
},
"connections": {
"name": "Connections",
"diagrams": {
"all-rows": "connections-diagram"
},
"columnNames": {
"c1_name": "Connection 1 Name",
"c2_name": "Connection 2 Name"
},
"queries": {
"c1_name": "connections.sparql",
"c2_name": "connections.sparql"
},
"rowMapping": {
"id": "c1_name",
"name": "Connections",
"labelFormat": "Connection"
}
}
}

Defining Table

A table must be properly defined in order to be rendered by OML Vision

path

REQUIRED
path: string

This string defines the path of the Table.

USER INTERFACE

The name of the path is the same path that was defined in the pages.json.

Table Path

name

OPTIONAL
name: string

This string gives a name to the table in the tableLayouts.json file.

diagrams

OPTIONAL
diagrams: {
all-rows: string
}

The diagrams object defines the commands that the Table is able to execute.

USER INTERFACE

The diagrams correspond to the commands that appear when a user right clicks a row in the Table.

Table Commands

all-rows

REQUIRED
all-rows: string

This string defines that all rows have the commands defined available for them to execute. The name of the string is arbitrary, but a good name for all-rows is "all-rows".

columnNames

REQUIRED
columnNames: {}

This object contains the columns that will render on the Table.

USER INTERFACE

The columnNames are rendered in the headers of the Table shown in the red boxes.

Table Column Names

queries

REQUIRED
queries: {}

This object contains the queries that will query the RDF Triplestore for the content that will populate in the Table.

Look at the sparql docs for more info found here

FUSEKI

You can test queries by going to localhost:3030 which is created once data is loaded into the Fuseki DB. You can watch more info about testing queries with Fuseki by going here

The AI & DS Channel (2021, February 18). SPARQL Query [Video]. YouTube. https://www.youtube.com/watch?v=w_pJ3XiBWeM&t=621s

rowMapping

REQUIRED
rowMapping: {}

This object defines how the queries map to the columnNames

id

REQUIRED
id: string

This string the id for the rowMapping.

USER INTERFACE

The id correspond to one of the columnNames.

Table Row Mapping Id

name

OPTIONAL
name: string

This string gives a name to the rowMapping.

labelFormat

REQUIRED
labelFormat: string

This string contains the label of the row for the rowMapping.

USER INTERFACE

The labelFormat is rendered in the rows of the Table shown in the red boxes.

Table Column Names

STRING INTERPOLATION

OML Vision supports string interpolation with the queries that were formatted. The format is "{string}"

An example is found here

Table String Interpolation

subRowMappings

OPTIONAL
subRowMappings: {
id: string
name: string
labelFormat: string
}[]

This subRowMappings array of objects defines the id, name, and labelFormat for the subrows of the Table.

The id, name, and labelFormat have the same data structure as rowMapping