diff options
Diffstat (limited to 'web/source/settings/lib/form')
| -rw-r--r-- | web/source/settings/lib/form/context.jsx | 33 | ||||
| -rw-r--r-- | web/source/settings/lib/form/field-array.jsx | 65 | ||||
| -rw-r--r-- | web/source/settings/lib/form/get-form-mutations.js | 47 | ||||
| -rw-r--r-- | web/source/settings/lib/form/index.js | 1 | ||||
| -rw-r--r-- | web/source/settings/lib/form/submit.js | 27 | 
5 files changed, 153 insertions, 20 deletions
| diff --git a/web/source/settings/lib/form/context.jsx b/web/source/settings/lib/form/context.jsx new file mode 100644 index 000000000..b25bb11b7 --- /dev/null +++ b/web/source/settings/lib/form/context.jsx @@ -0,0 +1,33 @@ +/* +	GoToSocial +	Copyright (C) GoToSocial Authors admin@gotosocial.org +	SPDX-License-Identifier: AGPL-3.0-or-later + +	This program is free software: you can redistribute it and/or modify +	it under the terms of the GNU Affero General Public License as published by +	the Free Software Foundation, either version 3 of the License, or +	(at your option) any later version. + +	This program is distributed in the hope that it will be useful, +	but WITHOUT ANY WARRANTY; without even the implied warranty of +	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +	GNU Affero General Public License for more details. + +	You should have received a copy of the GNU Affero General Public License +	along with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +"use strict"; + +const React = require("react"); + +const FormContext = React.createContext({}); + +module.exports = { +	FormContext, +	useWithFormContext(index, form) { +		const formContainer = React.useContext(FormContext); +		formContainer[index] = form; +		return form; +	} +};
\ No newline at end of file diff --git a/web/source/settings/lib/form/field-array.jsx b/web/source/settings/lib/form/field-array.jsx new file mode 100644 index 000000000..beea0bc9b --- /dev/null +++ b/web/source/settings/lib/form/field-array.jsx @@ -0,0 +1,65 @@ +/* +	GoToSocial +	Copyright (C) GoToSocial Authors admin@gotosocial.org +	SPDX-License-Identifier: AGPL-3.0-or-later + +	This program is free software: you can redistribute it and/or modify +	it under the terms of the GNU Affero General Public License as published by +	the Free Software Foundation, either version 3 of the License, or +	(at your option) any later version. + +	This program is distributed in the hope that it will be useful, +	but WITHOUT ANY WARRANTY; without even the implied warranty of +	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +	GNU Affero General Public License for more details. + +	You should have received a copy of the GNU Affero General Public License +	along with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +"use strict"; + +const React = require("react"); + +const getFormMutations = require("./get-form-mutations"); + +function parseFields(entries, length) { +	const fields = []; + +	for (let i = 0; i < length; i++) { +		if (entries[i] != undefined) { +			fields[i] = Object.assign({}, entries[i]); +		} else { +			fields[i] = {}; +		} +	} + +	return fields; +} + +module.exports = function useArrayInput({ name, _Name }, { initialValue, length = 0 }) { +	const fields = React.useRef({}); + +	const value = React.useMemo(() => parseFields(initialValue, length), [initialValue, length]); + +	return { +		name, +		value, +		ctx: fields.current, +		maxLength: length, +		selectedValues() { +			// if any form field changed, we need to re-send everything +			const hasUpdate = Object.values(fields.current).some((fieldSet) => { +				const { updatedFields } = getFormMutations(fieldSet, { changedOnly: true }); +				return updatedFields.length > 0; +			}); +			if (hasUpdate) { +				return Object.values(fields.current).map((fieldSet) => { +					return getFormMutations(fieldSet, { changedOnly: false }).mutationData; +				}); +			} else { +				return []; +			} +		} +	}; +};
\ No newline at end of file diff --git a/web/source/settings/lib/form/get-form-mutations.js b/web/source/settings/lib/form/get-form-mutations.js new file mode 100644 index 000000000..6bdc3e4cd --- /dev/null +++ b/web/source/settings/lib/form/get-form-mutations.js @@ -0,0 +1,47 @@ +/* +	GoToSocial +	Copyright (C) GoToSocial Authors admin@gotosocial.org +	SPDX-License-Identifier: AGPL-3.0-or-later + +	This program is free software: you can redistribute it and/or modify +	it under the terms of the GNU Affero General Public License as published by +	the Free Software Foundation, either version 3 of the License, or +	(at your option) any later version. + +	This program is distributed in the hope that it will be useful, +	but WITHOUT ANY WARRANTY; without even the implied warranty of +	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +	GNU Affero General Public License for more details. + +	You should have received a copy of the GNU Affero General Public License +	along with this program.  If not, see <http://www.gnu.org/licenses/>. +*/ + +"use strict"; + +const syncpipe = require("syncpipe"); + +module.exports = function getFormMutations(form, { changedOnly }) { +	let updatedFields = []; +	return { +		updatedFields, +		mutationData: syncpipe(form, [ +			(_) => Object.values(_), +			(_) => _.map((field) => { +				if (field.selectedValues != undefined) { +					let selected = field.selectedValues(); +					if (!changedOnly || selected.length > 0) { +						updatedFields.push(field); +						return [field.name, selected]; +					} +				} else if (!changedOnly || field.hasChanged()) { +					updatedFields.push(field); +					return [field.name, field.value]; +				} +				return null; +			}), +			(_) => _.filter((value) => value != null), +			(_) => Object.fromEntries(_) +		]) +	}; +};
\ No newline at end of file diff --git a/web/source/settings/lib/form/index.js b/web/source/settings/lib/form/index.js index 1bdb2a6d4..3d5f5238b 100644 --- a/web/source/settings/lib/form/index.js +++ b/web/source/settings/lib/form/index.js @@ -74,6 +74,7 @@ module.exports = {  	useRadioInput: makeHook(require("./radio")),  	useComboBoxInput: makeHook(require("./combo-box")),  	useCheckListInput: makeHook(require("./check-list")), +	useFieldArrayInput: makeHook(require("./field-array")),  	useValue: function (name, value) {  		return {  			name, diff --git a/web/source/settings/lib/form/submit.js b/web/source/settings/lib/form/submit.js index ee30df8a2..2d1d42b3a 100644 --- a/web/source/settings/lib/form/submit.js +++ b/web/source/settings/lib/form/submit.js @@ -21,7 +21,7 @@  const Promise = require("bluebird");  const React = require("react"); -const syncpipe = require("syncpipe"); +const getFormMutations = require("./get-form-mutations");  module.exports = function useFormSubmit(form, mutationQuery, { changedOnly = true, onFinish } = {}) {  	if (!Array.isArray(mutationQuery)) { @@ -44,25 +44,12 @@ module.exports = function useFormSubmit(form, mutationQuery, { changedOnly = tru  			}  			usedAction.current = action;  			// transform the field definitions into an object with just their values  -			let updatedFields = []; -			const mutationData = syncpipe(form, [ -				(_) => Object.values(_), -				(_) => _.map((field) => { -					if (field.selectedValues != undefined) { -						let selected = field.selectedValues(); -						if (!changedOnly || selected.length > 0) { -							updatedFields.push(field); -							return [field.name, selected]; -						} -					} else if (!changedOnly || field.hasChanged()) { -						updatedFields.push(field); -						return [field.name, field.value]; -					} -					return null; -				}), -				(_) => _.filter((value) => value != null), -				(_) => Object.fromEntries(_) -			]); + +			const { mutationData, updatedFields } = getFormMutations(form, { changedOnly }); + +			if (updatedFields.length == 0) { +				return; +			}  			mutationData.action = action; | 
