Server IP : 192.158.238.246 / Your IP : 3.139.240.192 Web Server : LiteSpeed System : Linux uniform.iwebfusion.net 4.18.0-553.27.1.lve.1.el8.x86_64 #1 SMP Wed Nov 20 15:58:00 UTC 2024 x86_64 User : jenniferflocom ( 1321) PHP Version : 8.1.32 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/7779/task/7779/cwd/plugins/give/src/Views/Components/ListTable/Filters/ |
Upload File : |
import {FormSelect} from '@givewp/components/ListTable/FormSelect'; import Select from '@givewp/components/ListTable/Select'; import Input from '@givewp/components/ListTable/Input'; export const Filter = ({filter, value = null, onChange, debouncedOnChange}) => { switch (filter.type) { case 'select': return ( <Select name={filter.name} aria-label={filter?.ariaLabel} onChange={(event) => onChange(event.target.name, event.target.value)} style={{inlineSize: filter?.inlineSize}} defaultValue={value} > {filter.options.map(({value, text}) => ( <option key={value} value={value}> {text} </option> ))} </Select> ); case 'formselect': return ( <FormSelect name={filter.name} options={filter.options} aria-label={filter?.ariaLabel} placeholder={filter?.text} onChange={onChange} style={{inlineSize: filter?.inlineSize}} defaultValue={value} /> ); case 'search': return ( <Input type="search" name={filter.name} aria-label={filter?.ariaLabel} placeholder={filter?.text} onChange={(event) => debouncedOnChange(event.target.name, event.target.value)} style={{inlineSize: filter?.inlineSize}} defaultValue={value} /> ); default: return null; break; } }; // figure out what the initial filter state should be based on the filter configuration export const getInitialFilterState = (filters) => { const state = {}; const urlParams = new URLSearchParams(window.location.search); filters.map((filter) => { // if the search parameters contained a value for the filter, use that const filterQuery = decodeURI(urlParams.get(filter.name)); // only accept a string or number, we don't want any surprises if (urlParams.has(filter.name) && (typeof filterQuery == 'string' || typeof filterQuery == 'number')) { state[filter.name] = filterQuery; } // otherwise, use the default value for the filter type else { switch (filter.type) { case 'select': state[filter.name] = filter.options?.[0].value; break; case 'search': case 'formselect': default: state[filter.name] = ''; break; } } }); return state; };