__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
import {
createElement,
Component,
useState,
useRef,
useContext,
Fragment,
} from '@wordpress/element'
import OutsideClickHandler from './react-outside-click-handler'
import classnames from 'classnames'
import ColorPicker from './ct-color-picker'
import { __ } from 'ct-i18n'
const clamp = (min, max, value) => Math.max(min, Math.min(max, value))
const Border = ({ value, option, onChange }) => {
const [isOpen, setIsOpen] = useState(false)
return (
<div className={classnames('ct-option-border')}>
<div
className={classnames('ct-value-changer', {
['active']: isOpen,
})}>
{value.style !== 'none' && !value.inherit && (
<input
type="number"
value={value.width}
// disabled={value.style === 'none'}
onChange={({ target: { value: width } }) =>
onChange({
...value,
width: clamp(1, 5, parseInt(width, 10) || 1),
})
}
/>
)}
<span
className="ct-current-value"
data-style={value.inherit ? 'none' : value.style}
onClick={() => setIsOpen(!isOpen)}>
{value.inherit
? __('Inherit', 'blocksy')
: value.style === 'none'
? __('none', 'blocksy')
: null}
</span>
<OutsideClickHandler
className="ct-units-list"
disabled={!isOpen}
onOutsideClick={() => {
if (!isOpen) return
setIsOpen(false)
}}>
{['solid', 'dashed', 'dotted', 'none'].map((style) => (
<span
key={style}
onClick={() => {
onChange({
...value,
style,
...(Object.keys(option.value).indexOf(
'inherit'
) > -1
? {
inherit: false,
}
: {}),
})
setIsOpen(false)
}}
data-style={style}>
{style === 'none' ? __('None', 'blocksy') : null}
</span>
))}
</OutsideClickHandler>
</div>
{value.style !== 'none' && !value.inherit && (
<Fragment>
<ColorPicker
onChange={(colorValue) =>
onChange({
...value,
color: colorValue.default,
})
}
option={{
pickers: [
{
id: 'default',
title: __('Initial', 'blocksy'),
},
],
}}
value={{
default: value.color,
}}
/>
{option.secondColor && (
<ColorPicker
onChange={(colorValue) =>
onChange({
...value,
secondColor: colorValue.default,
})
}
option={{
pickers: [
{
id: 'default',
title: __('Hover', 'blocksy'),
},
],
}}
value={{
default:
value.secondColor ||
option.value.secondColor,
}}
/>
)}
</Fragment>
)}
</div>
)
}
export default Border
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| background | Folder | 0750 |
|
|
| box-shadow | Folder | 0750 |
|
|
| color-palettes | Folder | 0750 |
|
|
| color-picker | Folder | 0750 |
|
|
| ct-addable-box | Folder | 0750 |
|
|
| ct-layers | Folder | 0750 |
|
|
| ct-number | Folder | 0750 |
|
|
| ct-radio | Folder | 0750 |
|
|
| ct-select | Folder | 0750 |
|
|
| ct-slider | Folder | 0750 |
|
|
| ct-spacing | Folder | 0750 |
|
|
| ct-switch | Folder | 0750 |
|
|
| ratio | Folder | 0750 |
|
|
| text | Folder | 0750 |
|
|
| typography | Folder | 0750 |
|
|
| ct-addable-box.js | File | 6.16 KB | 0640 |
|
| ct-background.js | File | 5.46 KB | 0640 |
|
| ct-border.js | File | 2.75 KB | 0640 |
|
| ct-box-shadow.js | File | 2.64 KB | 0640 |
|
| ct-button.js | File | 456 B | 0640 |
|
| ct-checkboxes.js | File | 1.91 KB | 0640 |
|
| ct-color-palettes-mirror.js | File | 1000 B | 0640 |
|
| ct-color-palettes-picker.js | File | 6.71 KB | 0640 |
|
| ct-color-picker.js | File | 2.71 KB | 0640 |
|
| ct-customize-section-title-actions.js | File | 6.74 KB | 0640 |
|
| ct-customizer-reset-options.js | File | 1.83 KB | 0640 |
|
| ct-divider.js | File | 328 B | 0640 |
|
| ct-entity-picker.js | File | 2.38 KB | 0640 |
|
| ct-file-uploader.js | File | 2 KB | 0640 |
|
| ct-footer-builder.js | File | 5.96 KB | 0640 |
|
| ct-header-builder.js | File | 272 B | 0640 |
|
| ct-image-picker.js | File | 1.81 KB | 0640 |
|
| ct-image-uploader.js | File | 10.12 KB | 0640 |
|
| ct-layers-combined.js | File | 2.22 KB | 0640 |
|
| ct-layers-mirror.js | File | 1.15 KB | 0640 |
|
| ct-layers.js | File | 5.39 KB | 0640 |
|
| ct-multi-image-uploader.js | File | 3.14 KB | 0640 |
|
| ct-notification.js | File | 378 B | 0640 |
|
| ct-number.js | File | 454 B | 0640 |
|
| ct-panel.js | File | 8.88 KB | 0640 |
|
| ct-radio.js | File | 401 B | 0640 |
|
| ct-ratio.js | File | 6.87 KB | 0640 |
|
| ct-select.js | File | 669 B | 0640 |
|
| ct-slider.js | File | 14.14 KB | 0640 |
|
| ct-spacer.js | File | 386 B | 0640 |
|
| ct-spacing.js | File | 5.09 KB | 0640 |
|
| ct-switch.js | File | 508 B | 0640 |
|
| ct-timer.js | File | 3.27 KB | 0640 |
|
| ct-title.js | File | 562 B | 0640 |
|
| ct-typography.js | File | 7.35 KB | 0640 |
|
| ct-visibility.js | File | 4.76 KB | 0640 |
|
| ct-woocommerce-columns-and-rows.js | File | 3 KB | 0640 |
|
| ct-woocommerce-ratio.js | File | 1.66 KB | 0640 |
|
| date-time-picker.js | File | 811 B | 0640 |
|
| hidden.js | File | 243 B | 0640 |
|
| html.js | File | 264 B | 0640 |
|
| jsx.js | File | 237 B | 0640 |
|
| react-outside-click-handler.js | File | 3.17 KB | 0640 |
|
| text.js | File | 384 B | 0640 |
|
| textarea.js | File | 518 B | 0640 |
|
| wp-editor.js | File | 3.67 KB | 0640 |
|