feature: create debounce input

This commit is contained in:
RouxAntoine 2023-07-24 19:21:09 +02:00
parent 0c4e87d1ab
commit eaf5412149
Signed by: antoine
GPG Key ID: 098FB66FC0475E70
5 changed files with 28 additions and 9 deletions

View File

@ -1,4 +1,5 @@
backoffice.configuration.kubernetes.api.kubeconfig=/Users/antoine/.kube/config.kubeconfig backoffice.configuration.kubernetes.api.kubeconfig=/Users/antoine/.kube/config.kubeconfig
backoffice.configuration.kubernetes.api.context=admin@kubernetes
#backoffice.configuration.kubernetes.api.url=https://kubernetes.localdomain:6443 #backoffice.configuration.kubernetes.api.url=https://kubernetes.localdomain:6443
#backoffice.configuration.kubernetes.api.ca-cert=/Users/antoine/Documents/virtualization/kubeadm/ca.crt #backoffice.configuration.kubernetes.api.ca-cert=/Users/antoine/Documents/virtualization/kubeadm/ca.crt

View File

@ -18,6 +18,7 @@
<!-- Load our React component. --> <!-- Load our React component. -->
<script src="http://localhost:35729/livereload.js"></script> <script src="http://localhost:35729/livereload.js"></script>
<script type="text/babel" src="src/RootHeader.js" data-presets="es2015,react"></script> <script type="text/babel" src="src/RootHeader.js" data-presets="es2015,react"></script>
<script type="text/babel" src="src/InputWithDebounce.js" data-presets="es2015,react"></script>
<script type="text/babel" src="src/ListData.js" data-presets="es2015,react"></script> <script type="text/babel" src="src/ListData.js" data-presets="es2015,react"></script>
<script type="text/babel" src="src/NodesComponent.js" data-presets="es2015,react"></script> <script type="text/babel" src="src/NodesComponent.js" data-presets="es2015,react"></script>
<script type="text/babel" src="src/RootBody.js" data-presets="es2015,react"></script> <script type="text/babel" src="src/RootBody.js" data-presets="es2015,react"></script>

View File

@ -0,0 +1,20 @@
function InputWithDebounce({value, setValue, debounce = 500}) {
const [directValue, setDirectValue] = React.useState(value);
React.useEffect(() => {
const timeoutId = setTimeout(() => {
setValue(directValue)
}, debounce);
return () => clearTimeout(timeoutId);
}, [directValue, debounce]);
return (
<MaterialUI.TextField
label="filter criteria"
value={directValue}
onChange={event => {
setDirectValue(event.target.value);
}}
/>
)
}

View File

@ -9,6 +9,10 @@ function Nodes({criteria}) {
.then(value => setNodes(value)); .then(value => setNodes(value));
}, []); }, []);
React.useEffect(() => {
console.log(criteria);
}, [criteria]);
return ( return (
<div> <div>
<div>nodes</div> <div>nodes</div>

View File

@ -1,20 +1,13 @@
'use strict'; 'use strict';
function FilterInput({onChange}) {
return (
<input
onChange={onChange}
/>
)
}
function RootBody() { function RootBody() {
const [criteria, setCriteria] = React.useState("") const [criteria, setCriteria] = React.useState("")
return ( return (
<div> <div>
<Nodes criteria={criteria}/> <Nodes criteria={criteria}/>
<FilterInput onChange={e => setCriteria(e.target.value)}/> <br/>
<InputWithDebounce value={criteria} setValue={setCriteria}/>
</div> </div>
); );
} }