Skip to content

Commit

Permalink
fix conditional field bug
Browse files Browse the repository at this point in the history
wp 6.2 compatibility
  • Loading branch information
michelegiorgi committed Feb 28, 2023
1 parent c2d8365 commit 649208d
Show file tree
Hide file tree
Showing 10 changed files with 45 additions and 26 deletions.
2 changes: 1 addition & 1 deletion LICENSE.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
Copyright (C) 2018-2022, Michele Giorgi
Copyright (C) 2018-2023, Michele Giorgi

GNU GENERAL PUBLIC LICENSE
Version 3, 29 June 2007
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ If you are not a developer, please download the latest release of the Formality

## Requirements

* [WordPress](https://wordpress.org/) >= 6.0
* [WordPress](https://wordpress.org/) >= 6.1

## Plugin setup

Expand Down Expand Up @@ -54,4 +54,4 @@ Contributions are welcome from everyone.

## License

GPL-3.0 - Copyright (c) 2018-2022 Michele Giorgi
GPL-3.0 - Copyright (c) 2018-2023 Michele Giorgi
35 changes: 22 additions & 13 deletions assets/scripts/public/modules/conditional.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ export let initConditionalField = (form, field) => {
if(!field.hasAttribute('data-conditional')) return
let query = ''
const rule = JSON.parse(field.getAttribute('data-conditional'))
for (const index in rule) { query += ( index == 0 ? '' : ', ' ) + '[name="' + rule[index].field + '"]' }
for(const index in rule) { query += ( index == 0 ? '' : ', ' ) + '[name="' + rule[index].field + '"]' }
if(query) {
checkCondition(form, field, rule)
const inputs = form.querySelectorAll(query)
Expand All @@ -23,13 +23,19 @@ export let checkCondition = (form, field, rule, auto=true) => {
if(inputs.length) {
let check = false
let inputValue = ''
inputs.forEach((input)=> {
inputs.forEach((input) => {
const type = input.getAttribute('type')
switch(type) {
case 'radio' : inputValue = input.checked ? input.value : '' ; break;
case 'checkbox' : inputValue = input.checked ? input.value : ''; break;
case 'file' : inputValue = input.hasAttribute('data-file') ? input.getAttribute('data-file') : ''; break;
default : inputValue = input.value; break;
case 'radio':
case 'checkbox':
if(input.checked) { inputValue = input.value }
break
case 'file':
inputValue = input.hasAttribute('data-file') ? input.getAttribute('data-file') : ''
break
default:
inputValue = input.value
break
}
})
const ruleValue = ('value' in rule[index]) ? rule[index].value : '';
Expand Down Expand Up @@ -69,27 +75,30 @@ export let toggleConditionalField = (field, show) => {
if(show && disabled) {
field.classList.remove(el('field', '', 'disabled'))
toggleConditionalValidation(field, false)
toggleConditionalNavbar(field, true)
} else if(!show && !disabled) {
field.classList.add(el('field', '', 'disabled'))
toggleConditionalValidation(field, true)
toggleConditionalNavbar(field, false)
}
if(video) {
video.style.display = 'none'
video.style.display = 'block'
}
}

export let toggleConditionalNavbar = (field, show) => {
const input = field.querySelector('input, select, textarea')
if(input) {
const navItem = document.querySelector(cl('nav', 'list li[data-name="' + input.name + '"]'))
if(navItem) { navItem.classList.toggle('disabled', !show) }
}
}

export let toggleConditionalValidation = (field, disable=true) => {
const input = field.querySelector('[required]')
if(disable) {
field.setAttribute('data-excluded','')
} else {
field.removeAttribute('data-excluded')
}
if(input) {
const navItem = document.querySelector(cl('nav', 'list li[data-name="' + input.name + '"]'))
if(navItem) {
navItem.classList.toggle('disabled', disable)
}
}
}
3 changes: 2 additions & 1 deletion assets/scripts/public/modules/navigation.js
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,8 @@ export let conversationalNavbar = (form, section) => {
if(navItem.classList.contains(el('field'))) {
const input = getInput(navItem)
const label = navItem.querySelector(cl('label'))
listHtml += `<li data-name="${ input.id }"><a href="#${ navItemId }">${ label.innerText }</a></li>`
const disabled = navItem.classList.contains(el('field', '', 'disabled'))
listHtml += `<li class="${ disabled ? 'disabled' : '' }" data-name="${ input.name }"><a href="#${ navItemId }">${ label.innerText }</a></li>`
} else if(navItem.classList.contains(el('section', 'header'))) {
const title = navItem.querySelector('h4')
listHtml += `</ul></li><li class="${ el('nav', 'anchor') }"><a href="#${ navItemId }">${ title.innerText }</a><ul>`
Expand Down
1 change: 1 addition & 0 deletions assets/styles/admin/layouts/sidebar_form.scss
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@
border-radius: 50%;
box-sizing: content-box;
margin: 0;
padding: 0;
* {
box-sizing: border-box;
}
Expand Down
6 changes: 3 additions & 3 deletions formality.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,13 @@
* @link https://formality.dev
* @since 1.0
* @package Formality
* @copyright Copyright (C) 2018-2022, Michele Giorgi
* @copyright Copyright (C) 2018-2023, Michele Giorgi
*
* @wordpress-plugin
* Plugin Name: Formality
* Plugin URI: https://formality.dev
* Description: Forms made simple (and cute). Designless, multistep, conversational, secure, all-in-one WordPress forms plugin.
* Version: 1.5.6
* Version: 1.5.7
* Author: Michele Giorgi
* Author URI: https://giorgi.io
* License: GPLv3
Expand Down Expand Up @@ -47,7 +47,7 @@
/**
* Currently plugin version.
*/
define('FORMALITY_VERSION', '1.5.6');
define('FORMALITY_VERSION', '1.5.7');
define('FORMALITY_PATH', plugin_dir_path( __FILE__ ));

/**
Expand Down
2 changes: 1 addition & 1 deletion includes/class-formality.php
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ class Formality {
*/
public function __construct() {

$this->version = defined( 'FORMALITY_VERSION' ) ? FORMALITY_VERSION : '1.5.6';
$this->version = defined( 'FORMALITY_VERSION' ) ? FORMALITY_VERSION : '1.5.7';
$this->formality = 'formality';

$this->load_dependencies();
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "Formality",
"version": "1.5.6",
"version": "1.5.7",
"author": "Michele Giorgi <[email protected]>",
"homepage": "https://giorgi.io",
"private": true,
Expand Down
14 changes: 11 additions & 3 deletions readme.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
Contributors: michelegiorgi
Donate link: https://www.paypal.me/michelegiorgi/
Tags: form, conversational, multistep, design form, gutenberg, block editor
Requires at least: 6.0
Tested up to: 6.1
Stable tag: 1.5.6
Requires at least: 6.1
Tested up to: 6.2
Stable tag: 1.5.7
Requires PHP: 7.2
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.txt
Expand Down Expand Up @@ -61,6 +61,14 @@ You will find **Formality** menu in your WordPress admin screen.

== Changelog ==

= 1.5.7 =
Release Date: February 28th, 2023

* Fix conditional validation on radio/checkbox input¹
* WordPress 6.2 compatibility

<small>¹ Thanks to @julien2400056, @anagaaco, @rizoma for bug report</small>

= 1.5.6 =
Release Date: October 31th, 2022

Expand Down
2 changes: 1 addition & 1 deletion webpack.mix.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ mix
.js('assets/scripts/public/index.js', 'scripts/formality-public.js')
.js('assets/scripts/editor/index.js', 'scripts/formality-editor.js')
.js('assets/scripts/admin/index.js', 'scripts/formality-admin.js')
.banner({ banner: 'Formality v1.5.6' });
.banner({ banner: 'Formality v1.5.7' });

mix
.copyWatched('assets/images/admin/**', 'dist/images/admin')
Expand Down

0 comments on commit 649208d

Please sign in to comment.