Demo VisualData 1.0

From Wikisphere
Demo VisualData
Jump to navigation Jump to search
No edit summary
No edit summary
 
(78 intermediate revisions by 2 users not shown)
Line 1: Line 1:
{{#pagepropertiesprint: {{FULLPAGENAME}}
{{#visualdataprint: {{FULLPAGENAME}}|schema=Book|template=Book|template?authors=Book authors|format=template}}  
|?cover
|?title
|?authors/name
|?authors/email
|schema=Book
|template=Book
|template?authors=Book authors
|format=template
}}
This is a page with an infobox that demonstrates the use of PageProperties ([https://gerrit.wikimedia.org/r/c/mediawiki/extensions/PageProperties/+/968230 latest version]) used as a [https://en.wikipedia.org/wiki/Create,_read,_update_and_delete CRUD]


Click the button below to edit the article's metadata through a popup or the tab "Edit semantic" among the article's actions.
This is a page with an infobox that demonstrates the use of VisualData ([https://gerrit.wikimedia.org/r/c/mediawiki/extensions/VisualData/+/968230 latest version]) used as a [[wikipedia:Create,_read,_update_and_delete|CRUD]]


Click the button below to edit the article's metadata through a popup or the tab "Edit semantic" among the article's actions.


{{#pagepropertiesform: Book
{{#visualdataform: Book|title=edit infobox and page|action=edit|edit-page={{FULLPAGENAME}}|return-page=|view=popup|popup-size=medium|css-class=|pagename-formula=|edit-freetext=true|edit-categories=false|edit-content-model=false|default-categories=|default-content-model=wikitext|layout-align=top|popup-help=false|submit-button-text=|layout=tabs|validate-button-text=}}
|title = edit infobox and page
|action = edit
|edit-page = {{FULLPAGENAME}}
|return-page =  
|view = popup
|popup-size = medium
|css-class =
|pagename-formula =
|edit-freetext = true
|edit-categories = false
|edit-content-model = false
|default-categories =  
|default-content-model = wikitext
|layout-align = top
|popup-help = true
|submit-button-text =
|layout = tabs
|submit-button-text =
|validate-button-text =
}}




Line 41: Line 12:


<pre>
<pre>
{{#pagepropertiesform: Book
{{#visualdataform: Book
|title = edit infobox and page
|title = edit infobox and page
|action = edit
|action = edit
Line 53: Line 24:
|edit-categories = false
|edit-categories = false
|edit-content-model = false
|edit-content-model = false
|edit-target-slot = false
|target-slot = jsondata
|default-categories =  
|default-categories =  
|default-content-model = wikitext
|default-content-model = wikitext
|preload=
|preload-data=
|layout-align = top
|layout-align = top
|popup-help = true
|popup-help = false
|submit-button-text =
|submit-button-text =
|layout = tabs
|layout = tabs
Line 65: Line 40:
</pre>
</pre>
   
   
A Pageproperties' form can edit whatever page (through the parameter <code>edit-page</code>, and create new pages with user-defined title or using a pagename formula. It is [https://json-schema.org/ json/schema] compliant<ref>It does not yet support allOf, anyOf, oneOf, and $refs both in the editor and in the viewer</ref>  and can handle subitems, multiple fields and multiple sub items. It is deeply integrated with the Mediawiki's [https://doc.wikimedia.org/oojs-ui/master/demos/ OOUI library] and uses a lot or most of its features.
A VisualData' form can edit whatever page (through the parameter <code>edit-page</code>, and create new pages with user-defined title or using a pagename formula. It is [https://json-schema.org/ json/schema] compliant<ref>It does not yet support allOf, anyOf, oneOf, and $refs both in the editor and in the viewer</ref>  and can handle subitems, multiple fields and multiple sub items. It is deeply integrated with the Mediawiki's [https://doc.wikimedia.org/oojs-ui/master/demos/ OOUI library] and uses a lot or most of its features.
'''In the latest version can query properties and nested properties, as well as render them using templates and nested templates and does not rely on [https://www.semantic-mediawiki.org/wiki/Semantic_MediaWiki SemanticMediawiki]'''.  
'''In the latest version can query properties and nested properties, as well as render them using templates and nested templates and does not rely on [https://www.semantic-mediawiki.org/wiki/Semantic_MediaWiki SemanticMediawiki]'''.  


Line 73: Line 48:


<pre>
<pre>
{{#pagepropertiesprint: {{FULLPAGENAME}}
{{#visualdataprint: {{FULLPAGENAME}}
|?cover
|?cover
|?title
|?title
Line 87: Line 62:




This is a SemanticMediawiki-like parser function that can be used as a shorthand to invoke the more complex <code> {{#pagepropertiesquery }} </code> parser function that can handle multi-page results and provides a basic query language. (more about this on the official page of the extension to be updated soon)
This is a SemanticMediawiki-like parser function that can be used as a shorthand to invoke the more complex <code> {{#visualdataquery}} </code> parser function that can handle multi-page results and provides a basic query language. (more about this on the official page of the extension to be updated soon)


The results are rendered on the page using 2 templates, [[Template:Book]] and [[Template:Book authors]]. The second is used as a nested template rendered inside the parent template ([[Template:Book]]) entitled to render the properties with path <code>authors</code>. ''' Note that the parent template must include a reference to the name of the child template since both values and template's containers are passed as named parameters.'''
The results are rendered on the page using 2 templates, [[Template:Book]] and [[Template:Book authors]]. The second is used as a nested template rendered inside the parent template ([[Template:Book]]) entitled to render the properties with path <code>authors</code>. ''' Note that the parent template must include a reference to the name of the child template since both values and template's containers are passed as named parameters.'''




The form's schema(s) (a form can contain an arbitrary number of schemas, and a schema an arbitrary number of items and subitems) can be edited using this [[Special:ManageSchemas|Special page]] or [https://wikisphere.org/w/index.php?title=Test_pageproperties_2.0&action=editsemantic this interface] (tab Edit semantic, edit icon on the right and then "Manage schemas")
{{notice|1=Since version 1.0.9 all the parameters passed to a template by the visualdataquery parser function are visible using the parameters <nowiki>{{{params}}}</nowiki> or <nowiki>{{{_params}}}</nowiki> -- so that editors know which parameters are passed to the template and can use them properly }}
 
 
The form's schema(s) (a form can contain an arbitrary number of schemas, and a schema an arbitrary number of items and subitems) can be edited using this [[Special:ManageSchemas|Special page]] or [https://wikisphere.org/w/index.php?title=Test_visualdata_2.0&action=editsemantic this interface] (tab Edit semantic, edit icon on the right and then "Manage schemas")


The related [[PagePropertiesSchema:Book|schema]] created by the UI contains an hidden property "name" that is filled-in with the compounded value of the fields <code>first_name</code> and <code>last_name</code>.
The related [[VisualDataSchema:Book|schema]] created by the UI contains an hidden property "name" that is filled-in with the compounded value of the fields <code>first_name</code> and <code>last_name</code>.
Also, the cover file name contains a value-formula, that allows the file to be saved with the article-id as prefix (also for new articles) which is useful to easily upload on the wiki files with similar names.
Also, the cover file name contains a value-formula, that allows the file to be saved with the article-id as prefix (also for new articles) which is useful to easily upload on the wiki files with similar names.


Line 101: Line 79:




== See also ==


== Additional examples ==
{{Demo VisualData footer}}


* [[New task]]
<!--
* [[Page upload]]
== Download ==
* [[Test pageproperties_2.0 - Result formats]]


[[mediawikiwiki:Special:ExtensionDistributor/VisualData|'''Latest version!''']]
-->
<!--
<!--
For custom development requests use this form https://wikisphere.org/wiki/Contact_form
For custom development requests use this form https://wikisphere.org/wiki/Contact_form
-->
-->
<references />
jsondata
Line 1: Line 1:
{}
{
"schemas": {
"Book": {
"title": "The first men in the moon",
"authors": [
{
"first_name": "Herbert ",
"last_name": "Wells",
"email": null,
"name": "Herbert  Wells"
},
{
"first_name": "George",
"last_name": "Wells",
"email": null,
"name": "George Wells"
}
],
"cover": "File:First_Men_in_the_Moon_(1901)_frontispiece.jpg"
}
},
"schemas-data": {
"untransformed": {
"Book/authors/0/name": "Herbert  Wells",
"Book/authors/1/name": "George Wells",
"Book/cover": "First_Men_in_the_Moon_(1901)_frontispiece.jpg"
}
}
}
pageproperties
Line 1: Line 1:
{
{}
    "schemas-data": {
        "untransformed": {
            "Book/authors/0/name": "",
            "Book/authors/1/name": "",
            "Book/cover": "First_Men_in_the_Moon_(1901)_frontispiece.jpg"
        }
    },
    "schemas": {
        "Book": {
            "title": "The first men in the moon",
            "authors": [
                {
                    "first_name": "Herbert ",
                    "last_name": "Wells",
                    "email": "",
                    "name": "Herbert  Wells"
                },
                {
                    "first_name": "George",
                    "last_name": "Wells",
                    "email": "",
                    "name": "George Wells"
                }
            ],
            "cover": "File:First_Men_in_the_Moon_(1901)_frontispiece.jpg"
        }
    }
}

Latest revision as of 11:31, 1 September 2025


This is a page with an infobox that demonstrates the use of VisualData (latest version) used as a CRUD

Click the button below to edit the article's metadata through a popup or the tab "Edit semantic" among the article's actions.


Form is loading...


The popup is rendered using the following code

{{#visualdataform: Book
|title = edit infobox and page
|action = edit
|edit-page = {{FULLPAGENAME}}
|return-page = 
|view = popup
|popup-size = medium
|css-class =
|pagename-formula =
|edit-freetext = true	
|edit-categories = false
|edit-content-model = false
|edit-target-slot = false
|target-slot = jsondata
|default-categories = 
|default-content-model = wikitext
|preload=
|preload-data=
|layout-align = top
|popup-help = false 
|submit-button-text =
|layout = tabs
|submit-button-text =
|validate-button-text =
}}

A VisualData' form can edit whatever page (through the parameter edit-page, and create new pages with user-defined title or using a pagename formula. It is json/schema compliant[1] and can handle subitems, multiple fields and multiple sub items. It is deeply integrated with the Mediawiki's OOUI library and uses a lot or most of its features. In the latest version can query properties and nested properties, as well as render them using templates and nested templates and does not rely on SemanticMediawiki.


The infobox is rendered through the following code:

{{#visualdataprint: {{FULLPAGENAME}}
|?cover
|?title
|?authors/name
|?authors/email
|schema=Book
|template=Book
|template?authors=Book authors
|format=template
}}


This is a SemanticMediawiki-like parser function that can be used as a shorthand to invoke the more complex {{#visualdataquery}} parser function that can handle multi-page results and provides a basic query language. (more about this on the official page of the extension to be updated soon)

The results are rendered on the page using 2 templates, Template:Book and Template:Book authors. The second is used as a nested template rendered inside the parent template (Template:Book) entitled to render the properties with path authors. Note that the parent template must include a reference to the name of the child template since both values and template's containers are passed as named parameters.



The form's schema(s) (a form can contain an arbitrary number of schemas, and a schema an arbitrary number of items and subitems) can be edited using this Special page or this interface (tab Edit semantic, edit icon on the right and then "Manage schemas")

The related schema created by the UI contains an hidden property "name" that is filled-in with the compounded value of the fields first_name and last_name. Also, the cover file name contains a value-formula, that allows the file to be saved with the article-id as prefix (also for new articles) which is useful to easily upload on the wiki files with similar names.


Have fun with this extension !!


See also


support & questions: support at topway.it

Download the latest version!

  1. It does not yet support allOf, anyOf, oneOf, and $refs both in the editor and in the viewer