The corresponding challenge is #64.
Create a drag & drop form builder that combines HTML form input fields, and generates an RDF form definition of the created form. This RDF form definition should be stored in a preferred Solid location.
The basic idea is to start with a Google Forms-like interface but for the generation of RDF data. This application is one application that can be used in an environment in which:
- Form builders can generate an RDF form definition.
- Form renders that can render an RDF form for end users (e.g. as HTML or as a text menu).
- Form viewers that can view the generated RDF in a human friendly way.
These three components can work together, for example, so that
- a form builder creates a Doodle form,
- a form renderer makes a HTML version to input the data, and
- a form viewer generates a nice read-only view.
See also the report "Form renderer that to view RDF form and store filled-in data in pod".
We developed a Web app that allows users to create form definitions and share them with other users. The generated form definition is stored in a user's pod as RDF and can then be used together with a form renderer to input data.
Below you find a screenshot where a form is defined with the following fields:
- Title: a text field which binds to
dc:title
- Author: a text field which binds to
dc:author
- Rating: a dropdown field for which binds to ex:rating. The dropdown should contain these options:
- "★ - I don't like it" binding to
ex:NotLikeIt
- "★★ - It was ok" binding to
ex:ItWasOk
- "★★★ - I liked it" binding to
ex:LikedIt
- "★★★★ - I really liked it" binding to
ex:ReallyLikedIt
- "★ - I don't like it" binding to
- Review: a text field which binds to
dc:description
- Form generator Web app
- User of the Web app
- The user has a WebID.
- The user opens the Web app.
- The user logs in with their WebID.
- The user drags fields from the panel on the left side to the panel on the right.
- The user fills in the details of the fields. See the example form in the "Approved solution" section.
- The user click on the button "Save".
- The app shows a notification confirming that the data is saved at the resource mentioned at the top.
- The form is stored in the user's pod at the resource mentioned at the top.
None.
None.