Info | ||
---|---|---|
|
We at Vertuna LLC, live, eat and breath data entry forms, we just love to build forms to quickly collect user opinions and feedback. And we love Atlassian products, so we have built, and continue to build, the best forms add-on for app for Confluence available on Atlassian Marketplace called - ConfiForms, Data entry forms and workflows.
...
And the choice field configured as something like this
ConfiForms Form Definition | ||||||
---|---|---|---|---|---|---|
| ||||||
...
We can add a default FormView, but it is rather boring, as you can see below
...
We want something more sexy and user engaging. So, we will build a user macro with icons and a little bit of scripting to glue the things together.
Quickfeedback | ||||||
---|---|---|---|---|---|---|
|
When a form is used by an authenticated user then this information is stored in the createdBy field, as ConfiForms has some metadata fields stored with each record (even when you have defined just one field, as we did in this example)
When a form is used by anonymous users the createdBy field is left blank
Each image has a custom "onClick" handler and invokes ConfiForms REST API to create new record in the form
The code, the handler invokes, looks something like this:
Code Block |
---|
// mychoice is the value (ID) for each option in "choice" field
function leaveFeedback(mychoice) {
AJS.$.ajax({
url: 'https://wiki.vertuna.com/ajax/confiforms/rest/save.action?pageId=16646199&f=f&choice=' + mychoice,
type: "GET",
success: function (data) {
// here we need to tell we received the feedback
}
});
}
|
See more complete example on how to setup the handlers with scripting here: Custom feedback form with ConfiForms and some JavaScript
You can also see the form in action and user macro created for you
Children Display |
---|
What is good about ConfiForms is that you can use and re-use the defined form on multiple pages, as well as build the "views" around the stored data where you want. Let's build the table over the stored data, we will show the metadata field created with the feedback given
...
formName | f |
---|
...
This is as simple as this, thanks to ConfiForms TableView macro
And the result would be something like this
Created | User feedback |
---|---|
Oct 06, 2017 16:06 | Awesome |
Oct 06, 2017 16:06 | Could be better |
Oct 06, 2017 16:06 | WTF!? |
Oct 06, 2017 16:06 | Good |
Oct 06, 2017 16:06 | Awesome |
Oct 06, 2017 16:06 | Could be better |
Oct 06, 2017 16:06 | Awesome |
Of course we can add some styling to the table, and can show other fields stored (like the mentuioned earlier createdBy metadata field) or with modifying the form definition a little bit further we can collect some system environment data, see notes on the bottom of this page.
Also, to have a good overview of the data stored we will make a simple report using Confluence built in chart macro and will group the choices made by our users and present the aggregated data as a pie chart
...
Awesome |
---|
...
Good |
---|
...
Could be better |
---|
...
WTF |
---|
...
...
3 |
...
1 |
...
...
2 |
...
1 |
All in real time, rendering the chart based on the data stored, by using ConfiForms Table View Merger macro together with Confluence Chart macro
...
dataDisplay | before |
---|---|
columns | 1,2,3,4 |
dataOrientation | horizontal |
...
Awesome
...
Good
...
Could be better
...
WTF!?
...
We can add some invisible to user feature that will helps us to understand more about the users and where the feedback has been actually given.
...