mirror of
https://github.com/pds-nest/nest.git
synced 2024-11-25 06:24:19 +00:00
🔧 Add new features to RepositoryEditor
This commit is contained in:
parent
1ccff60b3e
commit
eda2ab8c6e
1 changed files with 39 additions and 6 deletions
|
@ -5,6 +5,7 @@ import useArrayState from "../../hooks/useArrayState"
|
||||||
|
|
||||||
export default function RepositoryEditor({
|
export default function RepositoryEditor({
|
||||||
children,
|
children,
|
||||||
|
refresh,
|
||||||
id = null,
|
id = null,
|
||||||
name,
|
name,
|
||||||
is_active: isActive,
|
is_active: isActive,
|
||||||
|
@ -28,10 +29,10 @@ export default function RepositoryEditor({
|
||||||
/** The conditions of the data gathering. */
|
/** The conditions of the data gathering. */
|
||||||
const {
|
const {
|
||||||
value: _conditions,
|
value: _conditions,
|
||||||
setValue: setConditions,
|
setValue: setRawConditions,
|
||||||
appendValue: appendCondition,
|
appendValue: appendRawCondition,
|
||||||
removeValue: removeCondition,
|
removeValue: removeRawCondition,
|
||||||
spliceValue: spliceCondition,
|
spliceValue: spliceRawCondition,
|
||||||
} = useArrayState(conditions)
|
} = useArrayState(conditions)
|
||||||
|
|
||||||
/** The operator the conditions should be evaluated with. */
|
/** The operator the conditions should be evaluated with. */
|
||||||
|
@ -50,6 +51,8 @@ export default function RepositoryEditor({
|
||||||
// PUT
|
// PUT
|
||||||
throw new Error("Not yet implemented")
|
throw new Error("Not yet implemented")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
refresh()
|
||||||
},
|
},
|
||||||
[id]
|
[id]
|
||||||
)
|
)
|
||||||
|
@ -63,12 +66,42 @@ export default function RepositoryEditor({
|
||||||
setActive(isActive)
|
setActive(isActive)
|
||||||
setStart(start)
|
setStart(start)
|
||||||
setEnd(end)
|
setEnd(end)
|
||||||
setConditions(conditions)
|
setRawConditions(conditions)
|
||||||
setEvaluationMode(evaluationMode)
|
setEvaluationMode(evaluationMode)
|
||||||
},
|
},
|
||||||
[name, isActive, start, end, conditions, evaluationMode]
|
[name, isActive, start, end, conditions, evaluationMode]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Try to add a new condition, logging a message to the console if something goes wrong.
|
||||||
|
*/
|
||||||
|
const addCondition = useCallback(
|
||||||
|
(newCond) => {
|
||||||
|
// Check for content
|
||||||
|
if(!newCond.content) {
|
||||||
|
console.debug("Refusing to add ", newCond, ": content is empty.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check for duplicates
|
||||||
|
let duplicate = null;
|
||||||
|
for(const oldCond of _conditions) {
|
||||||
|
if(newCond.type === oldCond.type && newCond.content === oldCond.content) {
|
||||||
|
duplicate = oldCond
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(duplicate) {
|
||||||
|
console.debug("Refusing to add ", newCond, ": ", duplicate, " already exists.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
console.debug("Adding ", newCond, " to the Repository Conditions")
|
||||||
|
appendRawCondition(newCond)
|
||||||
|
},
|
||||||
|
[_conditions]
|
||||||
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ContextRepositoryEditor.Provider value={{
|
<ContextRepositoryEditor.Provider value={{
|
||||||
id,
|
id,
|
||||||
|
@ -76,7 +109,7 @@ export default function RepositoryEditor({
|
||||||
isActive: _isActive, setActive,
|
isActive: _isActive, setActive,
|
||||||
start: _start, setStart,
|
start: _start, setStart,
|
||||||
end: _end, setEnd,
|
end: _end, setEnd,
|
||||||
conditions: _conditions, appendCondition, removeCondition, spliceCondition,
|
conditions: _conditions, addCondition, appendRawCondition, removeRawCondition, spliceRawCondition,
|
||||||
evaluationMode: _evaluationMode, setEvaluationMode,
|
evaluationMode: _evaluationMode, setEvaluationMode,
|
||||||
revert, save,
|
revert, save,
|
||||||
}}>
|
}}>
|
||||||
|
|
Loading…
Reference in a new issue