The ResearchSpace codebase has been growing and changing for more than a decade, bringing together work from various projects in different development environments. This distributed work needed consolidation and was the main motivation for the work carried out in this release, which incorporates the most relevant pull requests from various branches, issues fixes, and a new default user interface directly supporting and mirroring the CIDOC CRM ontologies. Overall, it provides an accessible non-technical starting point for a ResearchSpace project, with mechanisms to record primary sources, add interpretations, annotate, build visual arguments or synthesise.
Previously, the platform was available with just a small number of example templates, not designed to work together and difficult to reuse. This meant a lot of time and effort was expended by each new project to repeatedly set up the same types of templates for viewing, editing or searching through data. In contrast to this, in this release we reviewed the process of building on ResearchSpace as a platform and we added a large number of templates and customisations coherently connected that showcase good practices when creating ResearchSpace-based projects. This will enable quick prototyping and experimentation with data that can be engaging for researchers early on.
The current release offers a unique way of recording data with semantics based on an exhaustive collection of interconnected resource templates, allowing one to start by adding any new resource based on CIDOC CRM ontology. For example, one can start by selecting new Human-Made Object and progressively adding more details such as who created it, when was it produced, and any other relevant information. The form's inputs reflect all applicable relationships (properties) from the CIDOC CRM ontology. Thus, through the UI a wide range of entities can be described, combining data input with modelling and creating complex semantic data networks. Work by Giovanna Garzoni, data visualisation in the Knowledge Map
Setting up a system using the ResearchSpace platform is a process of generating or importing semantic data modelled using a set of ontologies , producing knowledge patterns for creating or visualising linked data connections, defining templates (application and resource templates) and customising components for constructing specific user interfaces based on one's project requirements (more details in ResearchSpace documentation). So far, the platform has been available without a default UI, which made it difficult for users and developers alike to see its potential for specific projects, and meant significant time was needed in each instance to put together an application. The revisions aim to make it easier to setup the key parts of a project, with better mechanisms of managing ontologies and knowledge patterns, as well as a new way of explicitly configuring how particular entity types (e.g. all E21 Person or all E22 Human-Made Objects in a system) are managed from authoring to visualisations in different parts of the default user interface.
In previous versions, the platform was available with just a small number of example templates and a set of dependant knowledge patterns; This was problematic to maintain; they resided in a separate repositories and often missed as a prerequisite when preparing a new ResearchSpace instance; also, no clear UI based way for the categorisation of the knowledge patterns was in place. Hence, the following have been introduced:
-
A new way of categorising the knowledge pattern when created, with categories visible in the KPs catalogue in the Admin section.
-
There are three main groups of knowledge patterns in any instance:
- system patterns which cannot be edited and are used by the default UI
- ontology patterns which are auto-generated from the ontologies and also read only auto-generated KPs for the uploaded ontologies
- custom knowledge patterns created for the current application; they can also be generated based on system or patterns using the
Duplicate
functionality
Ontology management has been improved. The codebase now contains revised files for the following ontologies:
- CIDOC 7.3.1 (including CRMpc 1.2)
- CRMArcheo 1.4
- CRMba 1.4
- CRMdig 3.2.1
- CRMgeo 1.2
- Influence
- CRMsci
- FRBRoo
- skos
Note, these are loaded only when loadDefaultConfig
in the global.prop is set to 1 (see section How to enable/disable the default UI for more details)
The system now supports:
- Automatic generation and tagging of knowledge patterns when an ontology is uploaded
- Delete of all the associated knowledge patterns when an ontology is removed from the system
- Ontology properties search with inference across the ontologies available in a running system and ontologies elements search
- Support for upload of ontologies in either owl and rdfs formats
The default UI relies on a set of vocabularies, which can be edited:
- System authority documents
- Other authority documents required by KPs or default templates
A resource is a ResearchSpace encoding of a real world entity and is used to support the authoring of all instances of that entity. For example Giovanna Garzoni modelled as an instance of an ontology class such as E21 Person and further specialised as an artist by using the P2 has type relationship.
Resources is a new area in the Admin interface where resource configurations are defined. A configuration groups together information about how an instance of that resource is identified, how it is discovered, how the resource is represented in the interface, and its template for data input. Overall, these additions make it easier to customize the default UI depending on a project's data.
For example, in a New Person configuration it is required to specify the ontology class (E21 Person), and additionaly state the semantic form used for editing an instance of a Person, or describe the structure of authority documents based on that resource type, as well as describe its visual representations through icons or labels in the system.
The codebase includes a selection of 90+ configurations that can be customised further:
- System Resources Configurations: Knowledge Pattern Category, Chart, Timeline, Image Annotation, Knowledge Map, Semantic Narrative, Set, Set Item, User
- CIDOC CRM Classes Resource Configurations Acquisition, Activity, Actor, Appellation, Attribute assignment, Audio, Authority document, Beginning of existence, Biological object, Birth, Conceptual object, Condition assessment, Condition state, Creation, Curated collection, Curation activity, Currency, Death, Design or procedure, Destruction, Dimension, Dissolution, Document, End of existence, Entity, Event, Exhibition, Formation, Group, Human-made feature, Human-made object, Human-made thing, Identifier, Identifier assignment, Image, Information object, Inscription, Joining, Language, Leaving, Legal object, Linguistic object, Mark, Material, Measurement, Measurement unit, Model 3D, Modification, Monetary amount, Move, Organisation, Part addition, Part removal, Period, Persistent item, Person, Physical feature, Physical Human-made thing, Physical object, Physical thing, Place, Product type, Production, Project, Propositional object, Publication, Purchase, Research question, Right, Series, Site, Symbolic object, Term, Thing, Timespan, Title, Transfer of custody, Transformation, Type, Type assignment, Type creation, Video, Visual item
IMPORTANT Existing configurations can be modified and new configuration are only necessary for resources that have an ontology class not covered by the default configurations or if the representation is more specific. In our running example, there exists a configuration for Person
, but if needed a custom configuration can be created for Artist
(a type of Person) by adding a E21 Person as ontology class and artist
E55 Type as the Type of the configuration. This will allow the system to differentiate when to use the Person configuration
or the custom Artist configuration
.
IMPORTANT The resource configurations are intended to make it explicit what templates are being used for a new instance of that resource.
The existing resource templating mechanism can still be used for visualising resources, by customising the templateIncludeQuery
in the Admin/UI, Environment, Global & Data Quality section. The default UI templates do not rely on this UI setting.
There are four new repositories: configurations
, system
, ontologies
, and authorities
. These contain information that supports the default UI. For a new installation of the system these will be loaded and reloaded on start when the setting loadDefaultConfig
is 1 in the runtime-data/config/global.prop or in the your-custom-app/config/global.prop. In developer mode, just add "-Dconfig.global.loadDefaultConfig=1" to build.gradle script.
-
The
configurations
repository is a group of named graphs each containing a resource configuration -
The
system
repository is a set of knowledge patterns that cannot be edited by the users of the system and are a prerequisite for the functioning of the default templates. -
The
authorities
repository is a set of crm:E32 Authority Documents created using RS that are referred to by the system knowledge patterns and default templates. -
The
ontologies
repository is a set of ontologies: CIDOC 7.3.1 (including CRMpc 1.2), CRMArcheo 1.4, CRMba 1.4, CRMdig 3.2.1, CRMgeo 1.2, Influence, CRMsci, FRBRoo, skos (not an ontology).The current implementation covers the following scenarios:
-
For a new RS system setup with an empty graph-database all repositories above are loaded for the first time, if the
loadDefaultConfig
was not set; if you want your system to load future updates the flag needs to be set explicitly to 1. -
For an existing system with content in its graph-database, the loading process will check if the
loadDefaultConfig
is set to 1. If true,configurations
andauthorities
are loaded, and can be edited by the user. Thesystem
repository is also loaded. And finally theontologies
are loaded only if no other ontologies already exist. A user can work with their own choice of ontologies, but note that the templates provided have been customised based on CIDOC CRM 7.3.1.
-
IMPORTANT Setting the flag to 0 will not load any of the repositories above and the Resources and Ontologies sections in the Admin section will be broken. For existing systems, the default UI should not create any conflicts with the existing setups, but do investigate your logs which will reflect if such conflicts occur.
We designed and integrated a simple import workflow part of the process of creating a New Resource for relevant entities like Biological object, Curated collection, Human-made feature, Human-made object, Physical feature, Physical human-made thing, Physical object, Series, Site, Place, Organisation, Actor, Group, and Person. By importing from external resources a quick scaffolding of semantic data with provenance is built.
For example, when adding a New Person, click import from External Resource and Search on wikidata for Artemisia Gentileschi, add an image and the imported data from Wikidata is now part of the system. This functionality is only saving a small set of properties available via the APIs, more can be added by extending the existing templates.
Similarly, other external sources can be selected: Search and Import from the V&A, Search and Import from TNA
SQL Integration #320 (see more details)
Feature | Description |
---|---|
Frames | The frame system allows a layout where multiple windows are opened, displayed and placed in tabs, allowing an arrangement of different views, exchanges of information between them, and in many cases a refresh of information when frames hold the same or connected information. The component is based on the FlexLayout layout manager |
Finder | This is a configurable tab, an entrypoint for browsing resources. It is configured under Resource configuration of a particular resource. As part of the properties one can specify whether the resource is listed in finder and choose an icon for it. Finder organises entities in user defined hierarchies grouped under three headings: Favorites, Libraries, and System |
Resource Searches | All configured resources have a section for describing their search page that can be accessed through Finder. It is possible to select dynamically which views will be available for search pages: List, Grid, Chart, or Timeline; for the list view, one can specify the sparql query used for each column, presenting either a description, or other data in the results listing; additionally, the search page will also provide facets based on the knowledge patterns category selected in this section. Apart from individual resource search pages, a Search All Resources is also available: |
Contextual Drop-Down Menu | Through the current UI three vertical dots indicate the presence of a contextual menu with triggers for actions available depending on the nature of the resource or the application templates. Here are some examples of context menus for: Places, Timelines, Search Results, Objects, etc. Across resources a few functionalities are always present: Copy IRI , Copy to clipboard , Open in Knowledge Map , Edit , and custom Preview . IMPORTANT In the contextual menu the Share edit or Share Image Annotation , etc. will generate a URL that can be used as a way of directly viewing a resource in a particular view (i.e. in a form or an image annotation frame in this example) |
Clipboard | It is an individual space where a user places relevant resources. Copy to clipboard is now an action available from the contextual menu of all resources. |
Sets | Sets in previous versions were created in the clipboard or saved to the clipboard from the results list of a search. Sets were only visible in the Clipboard. Now, a set has its own search page and it can be added or removed from clipboard as needed. Sets are D1 Digital Object and have an extended form allowing a user to specify information about the set using CIDOC CRM relations |
Charts | A chart is created through any of the search pages, by selecting Chart view and a visualisation context. It can then be saved and it becomes a system resource that changes depending on the data in the system: Object categorisation by type chart in Multiple Views. Charts are modelled as D1 Digital Objects, enabling us to add further context to them. |
Knowledge Maps | Updated elements in the Toolbar of the KMs adding refresh and contextual menu buttons; Separated Save data and Save map functionality, and enabled an extended context form: |
Maps | Added visualisations within relevant resources when coordinate data is available: Frankfurt edit view |
Semantic Narratives | Updated elements in the Toolbar of the SN adding refresh and contextual menu buttons; Enabled visualising on a separate page all related resources for a narrative: |
Timelines | A timeline is created through any of the search pages, by selecting Timeline view. In this example, the timeline reflects the existing data for persons Seventeenth Century Contemporaries. Similarly to charts, timelines are modelled as Digital Objects and further context can be added through a form: |
Image Annotation | This functionality was possible only for Images and has been extended for any entity that has an image or images as representations. Annotations are resources (Digital Image Region) for which we can further state what they depict, similarities, and other properties inherited from the CIDOC CRM for a resource of this class: In this example a set of human made objects: |
Images Overlay | This functionality can be initiated from the search page for images for any two images in the list and a new image can be generated The new overlay image can be further annotated visually or with semantic data in a form: |
Events and Notifications | Using the existing event system, communication and exchange of information across frames has been improved with automatic refreshes of search pages when a new resource is created, modified or deleted. Notifications of the results of ones actions via the UI have clear feedback ('Resource created', 'Success', 'Warning', etc.) |
System Activities | A section in the UI that reflects when resources are created or modified, providing a sense of the history and provenance of the data System Activities. This is a first iteration in recording in the data when resources are created or edited. It isn't setup currently to record with fine granularity when each aspect of resource is being changed. |
User Profile | Enable a logged in user either Person or Organisation or Group to record further details about themselves; this together with the System Activities are the first iteration in adding more visibility across the platform to who created or edited information |
- resource card redesign to include the contextual menu instead of previous hover effect
- responsive templates implementation inside frames using container queries
- addition and consistent use of Google Material symbols for all icons in the UI
- helper page for ResearchSpace UI Design Elements
- reinstating linked views functionality (image graph annotation functionality has been fixed)
- frames tab labelling
- customLabel prop
- renaming of tabs when new resources are created (new Knowledge Map, new Resource of any type)
- support for FlexLayout event addTabWithDragAndDrop
Replaced the nested-form-template
with nested-form-templates
. This provides a user further options for choosing an appropriate type for the New resource to be created.
<semantic-form-autocomplete-input
for="actor_current_owner_of"
label="Current owner of"
placeholder="Select thing/object of which the user is legal owner"
nested-form-templates='[
{
"label": "Biological object",
"nestedForm": "{{{{raw}}}}{{> \"http://www.researchspace.org/resource/system/forms/BiologicalObject\" nested=true editable=true mode=\"new\" }}{{{{/raw}}}}"
},
{
"label": "Curated collection",
"nestedForm": "{{{{raw}}}}{{> \"http://www.researchspace.org/resource/system/forms/Collection\" nested=true editable=true mode=\"new\" }}{{{{/raw}}}}"
},
{
"label": "Human-made feature",
"nestedForm": "{{{{raw}}}}{{> \"http://www.researchspace.org/resource/system/forms/HumanMadeFeature\" nested=true editable=true mode=\"new\" }}{{{{/raw}}}}"
},...']>
</semantic-form-autocomplete-input>
Node 20, Webpack 5
Updated all major dev dependencies to node 20 like webpack, typescript and sass: more details here
-
researchspace-instance-configurations
github repo dependant knowledge patterns no longer required