Form Editor polishing - convert checkbox to toggle & notification as modal (#32)
This commit is contained in:
parent
9dd6bbe5ae
commit
f142a0e799
|
@ -103,7 +103,7 @@
|
||||||
</template>
|
</template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
<pro-tag class="float-right"/>
|
<pro-tag class="float-right"/>
|
||||||
<checkbox-input name="re_fillable" :form="form" class="mt-4"
|
<toggle-switch-input name="re_fillable" :form="form" class="mt-4"
|
||||||
label="Allow users to fill the form again"
|
label="Allow users to fill the form again"
|
||||||
/>
|
/>
|
||||||
<text-input v-if="form.re_fillable" name="re_fill_button_text"
|
<text-input v-if="form.re_fillable" name="re_fill_button_text"
|
||||||
|
|
|
@ -59,16 +59,16 @@
|
||||||
:form="form"
|
:form="form"
|
||||||
label="Color (for buttons & inputs border)"
|
label="Color (for buttons & inputs border)"
|
||||||
/>
|
/>
|
||||||
<checkbox-input name="hide_title" :form="form" class="mt-4"
|
<toggle-switch-input name="hide_title" :form="form" class="mt-4"
|
||||||
label="Hide Title"
|
label="Hide Title"
|
||||||
/>
|
/>
|
||||||
<checkbox-input name="no_branding" :form="form" class="mt-4"
|
<toggle-switch-input name="no_branding" :form="form" class="mt-4"
|
||||||
label="Remove OpnForm Branding"
|
label="Remove OpnForm Branding"
|
||||||
/>
|
/>
|
||||||
<checkbox-input name="uppercase_labels" :form="form" class="mt-4"
|
<toggle-switch-input name="uppercase_labels" :form="form" class="mt-4"
|
||||||
label="Uppercase Input Labels"
|
label="Uppercase Input Labels"
|
||||||
/>
|
/>
|
||||||
<checkbox-input name="transparent_background" :form="form" class="mt-4"
|
<toggle-switch-input name="transparent_background" :form="form" class="mt-4"
|
||||||
label="Transparent Background" help="Only applies when form is embedded"
|
label="Transparent Background" help="Only applies when form is embedded"
|
||||||
/>
|
/>
|
||||||
</collapse>
|
</collapse>
|
||||||
|
|
|
@ -11,52 +11,23 @@
|
||||||
<pro-tag />
|
<pro-tag />
|
||||||
</h3>
|
</h3>
|
||||||
</template>
|
</template>
|
||||||
<checkbox-input name="notifies" :form="form" class="mt-4"
|
|
||||||
label="Receive email notifications on submission"
|
<form-notifications-option />
|
||||||
/>
|
<form-notifications-slack />
|
||||||
<text-area-input v-if="form.notifies" name="notification_emails" :form="form" class="mt-4"
|
<form-notifications-submission-confirmation />
|
||||||
label="Notification Emails" help="Add one email per line"
|
|
||||||
/>
|
|
||||||
<checkbox-input name="notifies_slack" :form="form" class="mt-4"
|
|
||||||
label="Receive a Slack notification on submission"
|
|
||||||
/>
|
|
||||||
<text-input v-if="form.notifies_slack" name="slack_webhook_url" :form="form" class="mt-4"
|
|
||||||
label="Slack webhook url" help="help"
|
|
||||||
>
|
|
||||||
<template #help>
|
|
||||||
Receive slack message on each form submission. <a href="https://api.slack.com/messaging/webhooks" target="_blank">Click here</a> to learn how to get a slack webhook url
|
|
||||||
</template>
|
|
||||||
</text-input>
|
|
||||||
|
|
||||||
<checkbox-input :disabled="emailSubmissionConfirmationField===null" name="send_submission_confirmation"
|
|
||||||
:form="form" class="mt-4"
|
|
||||||
label="Send submission confirmation" :help="emailSubmissionConfirmationHelp"
|
|
||||||
/>
|
|
||||||
<text-input v-if="form.send_submission_confirmation" name="notification_sender"
|
|
||||||
:form="form" class="mt-4"
|
|
||||||
label="Confirmation Email Sender Name" help="Emails will be sent from our email address but you can customize the name of the Sender"
|
|
||||||
/>
|
|
||||||
<text-input v-if="form.send_submission_confirmation" name="notification_subject"
|
|
||||||
:form="form" class="mt-4"
|
|
||||||
label="Confirmation email subject" help="Subject of the confirmation email that will be sent"
|
|
||||||
/>
|
|
||||||
<rich-text-area-input v-if="form.send_submission_confirmation" name="notification_body"
|
|
||||||
:form="form" class="mt-4"
|
|
||||||
label="Confirmation email content" help="Content of the confirmation email that will be sent"
|
|
||||||
/>
|
|
||||||
<checkbox-input v-if="form.send_submission_confirmation" name="notifications_include_submission"
|
|
||||||
:form="form" class="mt-4"
|
|
||||||
label="Include submission data" help="If enabled the confirmation email will contain form submission answers"
|
|
||||||
/>
|
|
||||||
</collapse>
|
</collapse>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import Collapse from '../../../../common/Collapse'
|
import Collapse from '../../../../common/Collapse'
|
||||||
import ProTag from '../../../../common/ProTag'
|
import ProTag from '../../../../common/ProTag'
|
||||||
|
import FormNotificationsOption from './components/FormNotificationsOption'
|
||||||
|
import FormNotificationsSlack from './components/FormNotificationsSlack'
|
||||||
|
import FormNotificationsSubmissionConfirmation from './components/FormNotificationsSubmissionConfirmation'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: { Collapse, ProTag },
|
components: { FormNotificationsSubmissionConfirmation, FormNotificationsSlack, FormNotificationsOption, Collapse, ProTag },
|
||||||
props: {
|
props: {
|
||||||
},
|
},
|
||||||
data () {
|
data () {
|
||||||
|
@ -74,28 +45,10 @@ export default {
|
||||||
set (value) {
|
set (value) {
|
||||||
this.$store.commit('open/working_form/set', value)
|
this.$store.commit('open/working_form/set', value)
|
||||||
}
|
}
|
||||||
},
|
|
||||||
emailSubmissionConfirmationField () {
|
|
||||||
const emailFields = this.form.properties.filter((field) => {
|
|
||||||
return field.type === 'email' && !field.hidden
|
|
||||||
})
|
|
||||||
if (emailFields.length === 1) return emailFields[0]
|
|
||||||
return null
|
|
||||||
},
|
|
||||||
emailSubmissionConfirmationHelp () {
|
|
||||||
if (this.emailSubmissionConfirmationField) {
|
|
||||||
return 'Confirmation will be sent to the email in the "' + this.emailSubmissionConfirmationField.name + '" field.'
|
|
||||||
}
|
|
||||||
return 'Only available if your form contains 1 email field.'
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
watch: {
|
watch: {
|
||||||
emailSubmissionConfirmationField (val) {
|
|
||||||
if (val === null) {
|
|
||||||
this.$set(this.form, 'send_submission_confirmation', false)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
mounted () {
|
mounted () {
|
||||||
|
|
|
@ -9,11 +9,11 @@
|
||||||
</svg> Security & Privacy
|
</svg> Security & Privacy
|
||||||
</h3>
|
</h3>
|
||||||
</template>
|
</template>
|
||||||
<checkbox-input name="can_be_indexed" :form="form" class="mt-4"
|
<toggle-switch-input name="can_be_indexed" :form="form" class="mt-4"
|
||||||
label="Indexable by Google"
|
label="Indexable by Google"
|
||||||
help="If enabled, your form can appear in the search results of Google"
|
help="If enabled, your form can appear in the search results of Google"
|
||||||
/>
|
/>
|
||||||
<checkbox-input name="use_captcha" :form="form" class="mt-4"
|
<toggle-switch-input name="use_captcha" :form="form" class="mt-4"
|
||||||
label="Protect your form with a Captcha"
|
label="Protect your form with a Captcha"
|
||||||
help="If enabled we will make sure respondant is a human"
|
help="If enabled we will make sure respondant is a human"
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -0,0 +1,75 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<button
|
||||||
|
class="flex items-center mt-3 cursor-pointer relative w-full rounded-lg flex-1 appearance-none border border-gray-300 dark:border-gray-600 w-full py-2 px-4 bg-white text-gray-700 dark:bg-notion-dark-light dark:text-gray-300 dark:placeholder-gray-500 placeholder-gray-400 shadow-sm text-base focus:outline-none focus:ring-2 focus:border-transparent focus:ring-opacity-100"
|
||||||
|
@click.prevent="showModal=true"
|
||||||
|
>
|
||||||
|
<div class="flex-grow flex items-center">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor"
|
||||||
|
class="w-5 h-5 inline"
|
||||||
|
>
|
||||||
|
<path stroke-linecap="round" stroke-linejoin="round"
|
||||||
|
d="M21.75 6.75v10.5a2.25 2.25 0 01-2.25 2.25h-15a2.25 2.25 0 01-2.25-2.25V6.75m19.5 0A2.25 2.25 0 0019.5 4.5h-15a2.25 2.25 0 00-2.25 2.25m19.5 0v.243a2.25 2.25 0 01-1.07 1.916l-7.5 4.615a2.25 2.25 0 01-2.36 0L3.32 8.91a2.25 2.25 0 01-1.07-1.916V6.75"
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
<p class="flex-grow text-center">
|
||||||
|
Email Notifications
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div v-if="form.notifies">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor"
|
||||||
|
class="w-5 h-5 text-nt-blue"
|
||||||
|
>
|
||||||
|
<path stroke-linecap="round" stroke-linejoin="round"
|
||||||
|
d="M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z"
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
<modal :show="showModal" @close="showModal=false">
|
||||||
|
<h2 class="text-2xl font-bold z-10 truncate mb-5 text-nt-blue">
|
||||||
|
Form Notifications
|
||||||
|
<pro-tag />
|
||||||
|
</h2>
|
||||||
|
<toggle-switch-input name="notifies" :form="form" class="mt-4"
|
||||||
|
label="Receive email notifications on submission"
|
||||||
|
/>
|
||||||
|
<text-area-input v-if="form.notifies" name="notification_emails" :form="form" class="mt-4"
|
||||||
|
label="Notification Emails" help="Add one email per line"
|
||||||
|
/>
|
||||||
|
</modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import ProTag from '../../../../../common/ProTag'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: { ProTag },
|
||||||
|
props: {},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
showModal: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
computed: {
|
||||||
|
form: {
|
||||||
|
get () {
|
||||||
|
return this.$store.state['open/working_form'].content
|
||||||
|
},
|
||||||
|
/* We add a setter */
|
||||||
|
set (value) {
|
||||||
|
this.$store.commit('open/working_form/set', value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
watch: {},
|
||||||
|
|
||||||
|
mounted () {
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {}
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -0,0 +1,73 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<button
|
||||||
|
class="flex items-center mt-3 cursor-pointer relative w-full rounded-lg flex-1 appearance-none border border-gray-300 dark:border-gray-600 w-full py-2 px-4 bg-white text-gray-700 dark:bg-notion-dark-light dark:text-gray-300 dark:placeholder-gray-500 placeholder-gray-400 shadow-sm text-base focus:outline-none focus:ring-2 focus:border-transparent focus:ring-opacity-100"
|
||||||
|
@click.prevent="showModal=true"
|
||||||
|
>
|
||||||
|
<div class="flex-grow flex items-center">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" class="w-5 h-5 inline" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M14.5 10c-.83 0-1.5-.67-1.5-1.5v-5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5v5c0 .83-.67 1.5-1.5 1.5z" /><path d="M20.5 10H19V8.5c0-.83.67-1.5 1.5-1.5s1.5.67 1.5 1.5-.67 1.5-1.5 1.5z" /><path d="M9.5 14c.83 0 1.5.67 1.5 1.5v5c0 .83-.67 1.5-1.5 1.5S8 21.33 8 20.5v-5c0-.83.67-1.5 1.5-1.5z" /><path d="M3.5 14H5v1.5c0 .83-.67 1.5-1.5 1.5S2 16.33 2 15.5 2.67 14 3.5 14z" /><path d="M14 14.5c0-.83.67-1.5 1.5-1.5h5c.83 0 1.5.67 1.5 1.5s-.67 1.5-1.5 1.5h-5c-.83 0-1.5-.67-1.5-1.5z" /><path d="M15.5 19H14v1.5c0 .83.67 1.5 1.5 1.5s1.5-.67 1.5-1.5-.67-1.5-1.5-1.5z" /><path d="M10 9.5C10 8.67 9.33 8 8.5 8h-5C2.67 8 2 8.67 2 9.5S2.67 11 3.5 11h5c.83 0 1.5-.67 1.5-1.5z" /><path d="M8.5 5H10V3.5C10 2.67 9.33 2 8.5 2S7 2.67 7 3.5 7.67 5 8.5 5z" /></svg>
|
||||||
|
<p class="flex-grow text-center">
|
||||||
|
Slack Notifications
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div v-if="form.notifies_slack">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor"
|
||||||
|
class="w-5 h-5 text-nt-blue"
|
||||||
|
>
|
||||||
|
<path stroke-linecap="round" stroke-linejoin="round"
|
||||||
|
d="M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z"
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
<modal :show="showModal" @close="showModal=false">
|
||||||
|
<h2 class="text-2xl font-bold z-10 truncate mb-5 text-nt-blue">
|
||||||
|
Slack Notifications
|
||||||
|
<pro-tag />
|
||||||
|
</h2>
|
||||||
|
<toggle-switch-input name="notifies_slack" :form="form" class="mt-4"
|
||||||
|
label="Receive a Slack notification on submission"
|
||||||
|
/>
|
||||||
|
<text-input v-if="form.notifies_slack" name="slack_webhook_url" :form="form" class="mt-4"
|
||||||
|
label="Slack webhook url" help="help"
|
||||||
|
>
|
||||||
|
<template #help>
|
||||||
|
Receive slack message on each form submission. <a href="https://api.slack.com/messaging/webhooks" target="_blank">Click here</a> to learn how to get a slack webhook url
|
||||||
|
</template>
|
||||||
|
</text-input>
|
||||||
|
</modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import ProTag from '../../../../../common/ProTag'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: { ProTag },
|
||||||
|
props: {},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
showModal: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
computed: {
|
||||||
|
form: {
|
||||||
|
get () {
|
||||||
|
return this.$store.state['open/working_form'].content
|
||||||
|
},
|
||||||
|
/* We add a setter */
|
||||||
|
set (value) {
|
||||||
|
this.$store.commit('open/working_form/set', value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
watch: {},
|
||||||
|
|
||||||
|
mounted () {
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {}
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -0,0 +1,104 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<button
|
||||||
|
class="flex items-center mt-3 cursor-pointer relative w-full rounded-lg flex-1 appearance-none border border-gray-300 dark:border-gray-600 w-full py-2 px-4 bg-white text-gray-700 dark:bg-notion-dark-light dark:text-gray-300 dark:placeholder-gray-500 placeholder-gray-400 shadow-sm text-base focus:outline-none focus:ring-2 focus:border-transparent focus:ring-opacity-100"
|
||||||
|
@click.prevent="showModal=true"
|
||||||
|
>
|
||||||
|
<div class="flex-grow flex items-center">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor" class="w-5 h-5">
|
||||||
|
<path stroke-linecap="round" stroke-linejoin="round" d="M6 12L3.269 3.126A59.768 59.768 0 0121.485 12 59.77 59.77 0 013.27 20.876L5.999 12zm0 0h7.5" />
|
||||||
|
</svg>
|
||||||
|
<p class="flex-grow text-center">
|
||||||
|
Send submission confirmation
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div v-if="form.send_submission_confirmation">
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor"
|
||||||
|
class="w-5 h-5 text-nt-blue"
|
||||||
|
>
|
||||||
|
<path stroke-linecap="round" stroke-linejoin="round"
|
||||||
|
d="M9 12.75L11.25 15 15 9.75M21 12a9 9 0 11-18 0 9 9 0 0118 0z"
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
<modal :show="showModal" @close="showModal=false">
|
||||||
|
<h2 class="text-2xl font-bold z-10 truncate mb-5 text-nt-blue">
|
||||||
|
Submission confirmation
|
||||||
|
<pro-tag />
|
||||||
|
</h2>
|
||||||
|
<toggle-switch-input :disabled="emailSubmissionConfirmationField===null" name="send_submission_confirmation"
|
||||||
|
:form="form" class="mt-4"
|
||||||
|
label="Send submission confirmation" :help="emailSubmissionConfirmationHelp"
|
||||||
|
/>
|
||||||
|
<text-input v-if="form.send_submission_confirmation" name="notification_sender"
|
||||||
|
:form="form" class="mt-4"
|
||||||
|
label="Confirmation Email Sender Name" help="Emails will be sent from our email address but you can customize the name of the Sender"
|
||||||
|
/>
|
||||||
|
<text-input v-if="form.send_submission_confirmation" name="notification_subject"
|
||||||
|
:form="form" class="mt-4"
|
||||||
|
label="Confirmation email subject" help="Subject of the confirmation email that will be sent"
|
||||||
|
/>
|
||||||
|
<rich-text-area-input v-if="form.send_submission_confirmation" name="notification_body"
|
||||||
|
:form="form" class="mt-4"
|
||||||
|
label="Confirmation email content" help="Content of the confirmation email that will be sent"
|
||||||
|
/>
|
||||||
|
<toggle-switch-input v-if="form.send_submission_confirmation" name="notifications_include_submission"
|
||||||
|
:form="form" class="mt-4"
|
||||||
|
label="Include submission data" help="If enabled the confirmation email will contain form submission answers"
|
||||||
|
/>
|
||||||
|
</modal>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import ProTag from '../../../../../common/ProTag'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
components: { ProTag },
|
||||||
|
props: {},
|
||||||
|
data () {
|
||||||
|
return {
|
||||||
|
showModal: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
computed: {
|
||||||
|
form: {
|
||||||
|
get () {
|
||||||
|
return this.$store.state['open/working_form'].content
|
||||||
|
},
|
||||||
|
/* We add a setter */
|
||||||
|
set (value) {
|
||||||
|
this.$store.commit('open/working_form/set', value)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
emailSubmissionConfirmationField () {
|
||||||
|
const emailFields = this.form.properties.filter((field) => {
|
||||||
|
return field.type === 'email' && !field.hidden
|
||||||
|
})
|
||||||
|
if (emailFields.length === 1) return emailFields[0]
|
||||||
|
return null
|
||||||
|
},
|
||||||
|
emailSubmissionConfirmationHelp () {
|
||||||
|
if (this.emailSubmissionConfirmationField) {
|
||||||
|
return 'Confirmation will be sent to the email in the "' + this.emailSubmissionConfirmationField.name + '" field.'
|
||||||
|
}
|
||||||
|
return 'Only available if your form contains 1 email field.'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
watch: {
|
||||||
|
emailSubmissionConfirmationField (val) {
|
||||||
|
if (val === null) {
|
||||||
|
this.$set(this.form, 'send_submission_confirmation', false)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
mounted () {
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {}
|
||||||
|
}
|
||||||
|
</script>
|
Loading…
Reference in New Issue