PHP 8.2.31
Preview: padding.js Size: 2.13 KB
//proc/self/root/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>
	);
}

Directory Contents

Dirs: 0 × Files: 29

Name Size Perms Modified Actions
1.26 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
5.70 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
653 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
4.90 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1000 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.82 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.29 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.53 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
4.01 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
237 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
5.16 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.26 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.32 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
7.39 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.91 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.81 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.96 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.11 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.13 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
771 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
4.20 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.08 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
2.18 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.95 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
1.47 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
846 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
7.21 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download
693 B lrw-r--r-- 2026-04-22 07:17:42
Edit Download
17.44 KB lrw-r--r-- 2026-04-22 07:17:42
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).