Your IP : 18.222.161.119


Current Path : /var/softaculous/sitepad/editor/site-data/plugins/pagelayer/js/react/src/components/
Upload File :
Current File : //var/softaculous/sitepad/editor/site-data/plugins/pagelayer/js/react/src/components/padding.js

import { useState, useRef } from '@wordpress/element';
import { LabelControl } from './label';

export const PaddingControl = (props) =>{
		
	const { prop, label, value, setAttributes} = props;
	const { name } = prop['c'];
	
	var values = !pagelayer_empty(value) ? value : ['', '', '', ''];
	
	if(pagelayer_is_string(values)){
		values = values.split(',');
	}

	const [isLinked, setIsLinked] = useState(true);
	const paddingRef = useRef(null);
	
	const handleInputChange = (index, e) => {
		
		const newValue = parseFloat(e.target.value);
		
		let newValues = [...values];
		if (isLinked) {
			newValues = newValues.map(() => newValue);
		} else {
			newValues[index] = newValue;
		}
		
		if(prop?.units){
			newValues = setUnit(newValues);
		}
		
		setAttributes({[name]: newValues});
		
	};
	
	const setUnit = (val) => {
		var unit = paddingRef.current.querySelectorAll('.pagelayer-elp-units .selected')[0].innerHTML;
		
		if(Array.isArray(val)){
			for(var i in val){
				if(val[i].length < 1){
					continue;
				}
				val[i] = parseFloat(val[i])+unit;
			}
		}else{
			val = parseFloat(val)+unit;
		}
		
		return val;
	}

	return (
		<div className="components-base-control pagelayer-base-control" ref={paddingRef}>
			<LabelControl {...props}/>
			<div className="pagelayer-elp-padding-div">
				<input
					type="number"
					className="pagelayer-elp-padding"
					value={parseFloat(values[0])}
					onChange={(e) => handleInputChange(0, e)}
				/>
				<input
					type="number"
					className="pagelayer-elp-padding"
					value={parseFloat(values[1])}
					onChange={(e) => handleInputChange(1, e)}
				/>
				<input
					type="number"
					className="pagelayer-elp-padding"
					value={parseFloat(values[2])}
					onChange={(e) => handleInputChange(2, e)}
				/>
				<input
					type="number"
					className="pagelayer-elp-padding"
					value={parseFloat(values[3])}
					onChange={(e) => handleInputChange(3, e)}
				/>
				<i
				className={`pli pli-link${isLinked ? ' pagelayer-elp-padding-linked' : ''}`}
				onClick={ () => setIsLinked(!isLinked) }
				></i>
			</div>
		</div>
	);
}

?>