Home > Widgets

Sparnatural widgets

This is a reference documentation for Sparnatural widgets.


List widget

Appearance

Example Description
Typical appearance of a list widget, allowing to select a URI value, shown with a label and number of occurrences, ordered by decreasing number of occurrences
Showing literal values only (EDM Type is a literal value)
Showing a mix of literal values and URIs
Listing URI values with a label listed alphabetically
Listing values using optgroup

Description

List widgets allow to select a value from a dropdown list. They are suitable if the list of distinct values is limited in size (typically less than 500 items). The widget provides a dropdown list combined with a filtering/search input to search within the list content. The input field to search within the list does not appear if the list is very small, under 20 items. List widget is implemented using the select2 JQuery component.

List widgets can work both with URIs + labels, or with literal values. It can even mix URIs and literals in the same list.

The sort order of the elements in the list, as well as their precise labels, depends on the underlying SPARQL query that populates the list. Sparnatural provides default datasources that can be ordered alphabetically, alphabetically showing the number of occurrences in parenthesis, or ordered by decreasing number of occurrences.

List widgets supports optgroup to group values into sections. The grouping is also provided by the SPARQL query, and is used in particular when querying multiple endpoints.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:ListProperty.

Default configuration

By default, list widgets are used if the statistics are available to the configuration and if the number of distinct objects for the property is less than 500.

Datasources

The list of URI as well as their labels needs to be configured using a SPARQL datasource.

The default datasource used is datasources:list_URI_or_literal_count, itself relying on the SPARQL query datasources:query_list_URI_or_literal_count

SPARQL generation

If a single value is selected, the value is inserted directly as the triple object:

  ?Museum_1 <http://dbpedia.org/ontology/country> <http://fr.dbpedia.org/resource/France>.

If more than one value is selected, or if the corresponding variable is selected for inclusion in the result set, then a VALUES keyword is used:

With more than one values:

  ?Museum_1 <http://dbpedia.org/ontology/country> ?Country_2.
  VALUES ?Country_2 {
    <http://fr.dbpedia.org/resource/France>
    <http://fr.dbpedia.org/resource/Italie>
  }
}

or with the variable selected:

SELECT DISTINCT ?Museum_1 ?Country_2 WHERE {
  ?Museum_1 <http://dbpedia.org/ontology/country> ?Country_2.
  VALUES ?Country_2 {
    <http://fr.dbpedia.org/resource/France>
  }
}

Autocomplete widget

Appearance

Description

The autocomplete widget allows to select a URI by typing a few letters, and selecting a value from a list of proposals. The search is triggered when 3 characters at least have been entered. The search is done on one or more properties configured in the widget datasource (it can be configured to search on preferred label as well as synonyms, acronyms, identifiers, etc.). Autocompletion also works for searching on literal values. Autocomplete widget is implemented based on awesomeplete library.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:AutocompleteProperty.

Default configuration

By default, autocomplete widgets are used if none of the other widget matched.

Datasources

The list of proposals displayed to the user needs to be configured using a SPARQL datasource. The default datasource used is datasources:search_URI_contains, itself relying on the SPARQL query datasources:query_search_URI_contains. If the range is a literal, the default datasource is datasources:search_literal_contains, itself relying on the SPARQL query datasources:query_search_literal_contains

SPARQL clause

The SPARQL query generation logic is identical to the ListWidget (see above).


Tree widget

Appearance

Description

The tree widget allows to select entities from a tree of values, typically a SKOS ConceptScheme. A maximum of 3 values can be selected. The typical behavior is that the complete tree is always shown, even with the values that are never used, which will appear disabled and can’t be selected. Tree widget is implemented using the JS tree library.

Configuration

In SHACL configuration, add a dash:searchWidget annotation with the value config-core:TreeProperty.

Default configuration

The tree widget does not have a default behavior, it needs to be declared explicitely in the configuration.

Datasources

A tree widget requires 2 datasources:

  • One to list the root nodes to be displayed (at the first level).
  • One to list the children of a node, when a node is clicked.

The root datasource is configured using the datasources:treeRootsDatasource annotation. The default datasource used if none is indicated is [datasources:tree_root_skostopconcept]. The children datasource is configured using the datasources:treeChildrenDatasource annotation. The default datasource used if none is indicated is datasources:tree_children_skosnarrower.

SPARQL clause

The SPARQL query generation logic is identical to the ListWidget (see above). However please note that it is expected that Tree widgets are configured on properties that use a “*” SPARQL property path, indicating that the search is made recursively on the selected node but also all its children. A typical SPARQL property path configured on a property associated to a tree widget is <http://purl.org/dc/terms/subject>/(<http://www.w3.org/2004/02/skos/core#broader>|^<http://www.w3.org/2004/02/skos/core#narrower>)* : note how it searches for a connection using the dcterms:subject predicate, extended to either a skos:broader or inverse of skos:narrower up to the selected node in the tree.

String search widget

Appearance

Description

The search widget simply allows to enter some characters that will be searched for, using different techniques (see below), either using a regex or custom proprietary full-text search functions.

Configuration

In SHACL configuration, add a dash:searchWidget annotation with the value config-core:SearchProperty or one of its sub-properties, which will influence the SPARQL generation logic (see below).

Default configuration

String search widget is used by default if the sh:nodeKind is sh:Literal and if there is either no statistics available or a number of distinct values greater than 500.

Datasources

No datasource required.

SPARQL clause

The generated SPARQL clause depends on the exact super-property used when configuring the property:

SearchProperty

The string will be searched using a regex function.

FILTER(REGEX(STR(?Text_6), "picasso", "i"))

StringEqualsProperty

The string will be searched in an exact way, case-insensitive. This is useful when searching for exact identifiers.

FILTER((LCASE(?Cote_1)) = (LCASE("ABC")))

GraphDBSearchProperty

The string will be searched using GraphDB proprietary Lucene connector. Make sure you follow the additional documentation provided for this, as this imposes some naming convention on the URI of the range class and the property.

VirtuosoSearchProperty

The string will be searched using Virtuoso proprietary bif:contains operator.


Date range widget

Appearance

Description

Allows to express a date range to search on, using a begin date and end date selected from calendars. Open ranges are allowed (only the start date or only the end date). Date range widget is implemented using @chenfengyuan/datepicker.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:TimeProperty-Date.

In addition, if the entities in the knowledge graph are associated to a date range and possibly an exact date, and you want to test if the searche date range overlaps with the entities date range, you can use the annotations config-core:beginDateProperty, config-core:endDateProperty and optionnaly config-core:exactDateProperty to indicate respectively the URIs used to express the begin date, end date and exact date on the entities. More details can be found in the detailled documentation of the date-range query feature.

Default configuration

Date range widget is used by default if the sh:datatype is xsd:date or xsd:dateTime.

Datasources

No datasource required.

SPARQL clause

FILTER(((xsd:dateTime(?Date_2)) >= "1948-06-12T23:00:00Z"^^xsd:dateTime) && ((xsd:dateTime(?Date_2)) <= "1948-12-31T22:59:59Z"^^xsd:dateTime))

For advanced date-range querying, see the detailled documentation.


Year range widget

Appearance

Description

Allows to express a year range to search on, using a begin year and end year. Open ranges are allowed (only the start year or only the end year). Year range widget is implemented using @chenfengyuan/datepicker, configured to use only years.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:TimeProperty-Year.

Default configuration

Year range widget is used by default if the sh:datatype is xsd:gYear.

Datasources

No datasource required.

SPARQL clause

FILTER((xsd:dateTime(?Date_2)) >= "2017-12-31T23:00:01Z"^^xsd:dateTime)

(here with only a start year). Note how the values is cast to an xsd:dateTime explicitely.


Number widget

Appearance

Description

Allows to select a number range, with a lower bound and upper bound. Can limit the range of input fields based on the datatype indicated in the SHACL config (e.g. xsd:byte will be limited betwen -127 and 128)

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:NumberProperty.

Datasources

No datasource required.

Default configuration

Numeric range widget is used by default if the sh:datatype is this list : xsd:byte,xsd:decimal,xsd:double,xsd:float,xsd:int,xsd:integer,xsd:long,xsd:nonNegativeInteger,xsd:short,xsd:unsignedByte,xsd:unsignedInt,xsd:unsignedLong,xsd:unsignedShort.

SPARQL clause

Either with a lower and upper bound:

  FILTER((?Number_2 >= "1"^^xsd:decimal) && (?Number_2 <= "1000"^^xsd:decimal))

With only lower bound:

   FILTER(?Number_2 >= "11"^^xsd:decimal)

With only upper bound:

   FILTER(?Number_2 <= "11"^^xsd:decimal)

Boolean widget

Appearance

Description

Allows to select either a boolean value “true” or “false”.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:NumberProperty.

Default configuration

Boolean widget is used by default if the sh:datatype is xsd:boolean.

Datasources

No datasource required.

SPARQL clause

   ?Person_1 ex:isAlive true .

Map widget

Appearance

Description

Allows to select a rectangle on a map, and generates a corresponding GeoSPARQL query, using a geof:sfWithin function. This implies that the data in the triplestore must be encoded with literal values using the <http://www.opengis.net/ont/geosparql#wktLiteral> datatype, such as in this example (this is a tiny extract from Wikidata, of course you can use different predicates, the important thing is the use of ^^geo:wktLiteral :

@prefix geo: <http://www.opengis.net/ont/geosparql#> .
@prefix wd: <http://www.wikidata.org/entity/> .
@prefix wdt: <http://www.wikidata.org/prop/direct/> .

wd:Q16214 wdt:P31 wd:Q484170 ;
  wdt:P625 "Point(4.613611111 47.098055555)"^^geo:wktLiteral ;
  wdt:P1448 "Bessey-la-Fontaine"@fr .

wd:Q16233 wdt:P31 wd:Q484170 ;
  wdt:P625 "Point(4.673611111 47.091111111)"^^geo:wktLiteral ;
  wdt:P1448 "Lusigny-sur-Ouche"@fr .

wd:Q16213 wdt:P31 wd:Q484170 ;
  wdt:P625 "Point(4.624444444 47.123611111)"^^geo:wktLiteral ;
  wdt:P1448 "Auxant"@fr .

WKT literals can be used to encode points or polygons. WKT literals can also include an optional IRI before the geometry to indicate the reference system (see the example from the spec : "<http://www.opengis.net/def/crs/EPSG/0/4326> Point(33.95 -83.38)"^^<http://www.opengis.net/ont/geosparql#wktLiteral>)

For more information on WKT literals, see the Wikipedia page, and the GeoSPARQL spec.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:MapProperty.

Default configuration

Boolean widget is used by default if the sh:datatype is geo:wktLiteral.

Datasources

No datasource required.

SPARQL clause

    ?MuseumWikidata_2 <http://www.wikidata.org/prop/direct/P625> ?Map_4.
    FILTER(<http://www.opengis.net/def/function/geosparql/sfWithin>(?Map_4, "Polygon((6.113179202657193 46.196063994634265, 6.113179202657193 46.21649770912313, 6.149914737325163 46.21649770912313, 6.149914737325163 46.196063994634265, 6.113179202657193 46.196063994634265))"^^<http://www.opengis.net/ont/geosparql#wktLiteral>))

No selection widget

Appearance

Description

Completely disables the possibility for the user to select a value. Only the “where” option is active in order to “traverse” this entity. This is useful to show intermediate nodes to the user without allowing for a selection on a label, but only on other properties attached to that node. This is typically useful for event-based models like the CIDOC-CRM where events are usually not selectables by themselves but serves to connect other properties.

Configuration

In your SHACL configuration, add a dash:searchWidget annotation with the value config-core:NonSelectableProperty.

Datasources

No datasource required.

Default configuration

There is no default behavior for this widhet, it needs to be configured explicitely.

SPARQL clause

No SPARQL generated.