Skip to content
This repository has been archived by the owner on Apr 12, 2024. It is now read-only.
/ metaExplorer Public archive

Open source UI toolset for linking graph data in json-ld documents, based on Web technologies

License

Notifications You must be signed in to change notification settings

shnydercom/metaExplorer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 

Repository files navigation

Introduction-Video

https://youtu.be/iJUnQRw52Ds

...and here you can build your own App with the POC:

metaExplorer starter template

Vision

MetaExplorer aims to build user interfaces that adapt to different people and circumstances. These people can be the end-users or your team members, who solve a user's problem. MetaExplorer aims to build a general human-machine interface that can interact with different devices, operating systems and individual needs of a person.

It is inspired by the communities who share and combine complex technical work. Namely blender3D, node-red, the numerous 3D printing communities and creators of many software development frameworks.

How does it work?

  • every re-usable part gets a URL, based on schema.org
  • type-checks happen with URLs as types
  • synchronous state is modeled as a Directed Acyclic Graph, asynchronous state updates (side effects) can be any graph
  • data is modeled in 'any graph', described in JSON-LD
  • existing JSON doesn't have to change, with JSON-LD's @context, variables can migrate their full domain (so a Button becomes a mydomain.com/Button and can change into an example.com/Button or a localhost/Button)
  • if it's clear which Button-type is meant, a UI component or other code can be run after getting it from a Retriever
  • if there is more than one possible option, or to change the UI after the @context has changed, a Matcher can choose from multiple Retrievers

And that's about it. This approach is independent of UI frameworks, since it works on data and the descriptive names we give to parts of that data. The names go into a generalized vocabulary, but stay locally modifyable. Unlike most content management systems and nocode-tools, the UI data can be saved both in git or in a database.

Proof of Concept

The proof of concept was started as UI tech for hydra APIs. Slowly GraphQL has taken over, and now that I've worked with REST, GraphQL and websockets I want something that's independent of that to the backend, and similarly independent to the frontend. The POC contains a node-editor similarly to blender's, but you can crash it by creating a cyclic graph. It updates everything asynchronously, which puts a limit to performance. The page at metaexplorer.io was created with the POC, and so you can try out the performance of that approach.

License

This project was started in Europe, therefore we chose the EUPL license. It's compatible with a lot of other Open Source licenses and fit for commercial use. More info:

Why this license?

Which license(s) you choose for add-ons to MetaExplorer under your domain should be up to you. It's only important for open source projects that overall improvements to the core technology stay open.