__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
import { createElement, useState, useCallback } from '@wordpress/element'
import OptionsPanel from '../OptionsPanel'
import classnames from 'classnames'
const Accordion = (props) => {
const [currentItems, setCurrentItems] = useState([])
const handleVisibility = useCallback(
(id) => {
if (currentItems.includes(id)) {
setCurrentItems(currentItems.filter((item) => item !== id))
} else {
setCurrentItems([...currentItems, id])
}
},
[currentItems]
)
return (
<div className="ct-option-accordion">
{props.renderingChunk.map((singleItem) => {
const isActive = currentItems.includes(singleItem.id)
return (
<div
key={singleItem.id}
className={classnames('ct-accordion-item', {
active: isActive,
})}>
<h3
className="ct-accordion-heading"
onClick={(e) => {
if (e.target.tagName === 'SELECT') {
return
}
handleVisibility(singleItem.id)
}}>
{singleItem.title
? singleItem.title
: singleItem.id}
<span className="ct-accordion-item-controls">
{singleItem.afterHeading
? singleItem.afterHeading(singleItem)
: null}
<svg
width="8"
height="8"
fill="currentColor"
viewBox="0 0 20 15">
<path d="M20 0 9.92 15 0 0h20Z" />
</svg>
</span>
</h3>
<div className="ct-accordion-item-content">
<div className="ct-accordion-options-container">
<OptionsPanel
purpose={props.purpose}
onChange={(key, val) =>
props.onChange(key, val)
}
options={singleItem.options}
value={props.value}
/>
</div>
</div>
</div>
)
})}
</div>
)
}
export default Accordion
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| Accordion.js | File | 1.76 KB | 0640 |
|
| Condition.js | File | 5.72 KB | 0640 |
|
| Group.js | File | 2.81 KB | 0640 |
|
| LabeledGroup.js | File | 4.35 KB | 0640 |
|
| MigrateValues.js | File | 2.26 KB | 0640 |
|
| Tabs.js | File | 1.8 KB | 0640 |
|
| ct-has-meta-category-button.js | File | 1.17 KB | 0640 |
|
| use-force-update.js | File | 325 B | 0640 |
|