HEX
Server: Apache
System: Linux cpanelx.inxs.ro 4.18.0-477.27.2.lve.el8.x86_64 #1 SMP Wed Oct 11 12:32:56 UTC 2023 x86_64
User: crowdandsafety (1041)
PHP: 8.1.34
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //proc/self/cwd/wp-content/plugins/convertplug/framework/lib/fields/border/js/borderRadius.js
/* eslint-env jquery */
$ = jQuery;
let smile_panel_id = '';
jQuery(document).ready(function () {
	jQuery(document).on('smile_panel_loaded', function () {
		const smile_panel = jQuery('.customize').data('style');
		smile_panel_id = smile_panel;
		function Border(options) {
			this.htmlElement =
				options.htmlElement ||
				jQuery(
					'#accordion-' + smile_panel_id + ' #border-radius-panel'
				);
			this.htmlCode = jQuery(
				'#accordion-' + smile_panel_id + ' #border-code'
			);
			this.br_all =
				typeof options.br_all !== 'undefined' ? options.br_all : 10;
			this.br_tl =
				typeof options.br_tl !== 'undefined' ? options.br_tl : 10;
			this.br_tr =
				typeof options.br_tr !== 'undefined' ? options.br_tr : 10;
			this.br_bl =
				typeof options.br_bl !== 'undefined' ? options.br_bl : 10;
			this.br_br =
				typeof options.br_br !== 'undefined' ? options.br_br : 10;
			this.style = options.style || 'none';
			this.color = options.color || '#000000';
			this.br_type = options.br_type || 0;
			this.bw_type = options.bw_type || 0;
			this.bw_all =
				typeof options.bw_all !== 'undefined' ? options.bw_all : 10;
			this.bw_t = typeof options.bw_t !== 'undefined' ? options.bw_t : 10;
			this.bw_l = typeof options.bw_l !== 'undefined' ? options.bw_l : 10;
			this.bw_r = typeof options.bw_r !== 'undefined' ? options.bw_r : 10;
			this.bw_b = typeof options.bw_b !== 'undefined' ? options.bw_b : 10;
			return this;
		}

		Border.prototype.refresh = function () {
			let inputCode = 'br_type:' + this.br_type + '|';
			inputCode += 'br_all:' + this.br_all + '|';
			inputCode += 'br_tl:' + this.br_tl + '|';
			inputCode += 'br_tr:' + this.br_tr + '|';
			inputCode += 'br_br:' + this.br_br + '|';
			inputCode += 'br_bl:' + this.br_bl + '|';
			inputCode += 'style:' + this.style + '|';
			inputCode += 'color:' + this.color + '|';
			inputCode += 'bw_type:' + this.bw_type + '|';
			inputCode += 'bw_all:' + this.bw_all + '|';
			inputCode += 'bw_t:' + this.bw_t + '|';
			inputCode += 'bw_l:' + this.bw_l + '|';
			inputCode += 'bw_r:' + this.bw_r + '|';
			inputCode += 'bw_b:' + this.bw_b;

			this.htmlCode.html(inputCode);
		};

		Border.prototype.setAllCorners = function (border) {
			this.br_all = border;
			this.br_tl = border;
			this.br_tr = border;
			this.br_bl = border;
			this.br_br = border;
		};

		Border.prototype.setAllSides = function (width) {
			this.bw_all = width;
			this.bw_t = width;
			this.bw_l = width;
			this.bw_r = width;
			this.bw_b = width;
		};

		function _getAllValuesFromPanelBorder() {
			const options = {};
			options.br_all = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #all-corners').val()
			);
			options.br_tl = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #top-left').val()
			);
			options.br_tr = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #top-right').val()
			);
			options.br_bl = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #bottom-left').val()
			);
			options.br_br = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #bottom-right').val()
			);
			options.style = jQuery(
				'#accordion-' + smile_panel_id + ' #select-border :selected'
			).val();
			options.color = jQuery(
				'#accordion-' + smile_panel_id + ' #br-color'
			).val();
			options.br_type = jQuery(
				'#accordion-' + smile_panel_id + ' #smile_adv_border_opt'
			).val();
			options.bw_all = parseFloat(
				jQuery(
					'#accordion-' + smile_panel_id + ' #width-allsides'
				).val()
			);
			options.bw_t = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #width-top').val()
			);
			options.bw_l = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #width-left').val()
			);
			options.bw_r = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #width-right').val()
			);
			options.bw_b = parseFloat(
				jQuery('#accordion-' + smile_panel_id + ' #width-bottom').val()
			);
			options.bw_type = jQuery(
				'#accordion-' + smile_panel_id + ' #smile_adv_borderwidth_opt'
			).val();
			return options;
		}

		function _getFromFieldBorder(value, min, max, elem) {
			let val = parseFloat(value);
			if (isNaN(val) || val < min) {
				val = 0;
			} else if (val > max) {
				val = max;
			}

			if (elem) elem.val(val);

			return val;
		}

		const opts = _getAllValuesFromPanelBorder();
		const border = new Border(opts);

		/* Border Type */
		jQuery('#accordion-' + smile_panel + ' #smile_adv_border_opt').on(
			'change',
			function () {
				const all_radius = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #all-corners'
					).val()
				);
				const top_left = parseFloat(
					jQuery('#accordion-' + smile_panel_id + ' #top-left').val()
				);
				const top_right = parseFloat(
					jQuery('#accordion-' + smile_panel_id + ' #top-right').val()
				);
				const bottom_left = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #bottom-left'
					).val()
				);
				const bottom_right = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #bottom-right'
					).val()
				);

				const val = jQuery(this).val();
				if (val === '0') {
					jQuery('.border-container.param-advanced-block').slideUp();
					jQuery('.border-container.param-basic-block').slideDown();
					partial_refresh_border('border-radius', all_radius);
				} else {
					jQuery('.border-container.param-basic-block').slideUp();
					jQuery(
						'.border-container.param-advanced-block'
					).slideDown();

					partial_refresh_border('border-top-left-radius', top_left);
					partial_refresh_border(
						'border-top-right-radius',
						top_right
					);
					partial_refresh_border(
						'border-bottom-left-radius',
						bottom_left
					);
					partial_refresh_border(
						'border-bottom-right-radius',
						bottom_right
					);
				}
			}
		);

		/* Border Width - Switch ( basic / advanced ) */
		jQuery('#accordion-' + smile_panel + ' #smile_adv_borderwidth_opt').on(
			'change',
			function () {
				const all_widths = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #width-allsides'
					).val()
				);
				const top = parseFloat(
					jQuery('#accordion-' + smile_panel_id + ' #width-top').val()
				);
				const left = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #width-left'
					).val()
				);
				const right = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #width-right'
					).val()
				);
				const bottom = parseFloat(
					jQuery(
						'#accordion-' + smile_panel_id + ' #width-bottom'
					).val()
				);

				const val = jQuery(this).val();
				if (val === '0') {
					jQuery(
						'.borderwidth-container.param-advanced-block'
					).slideUp();
					jQuery(
						'.borderwidth-container.param-basic-block'
					).slideDown();
					partial_refresh_border('border-width', all_widths);
				} else {
					jQuery(
						'.borderwidth-container.param-basic-block'
					).slideUp();
					jQuery(
						'.borderwidth-container.param-advanced-block'
					).slideDown();

					partial_refresh_border('border-top-width', top);
					partial_refresh_border('border-left-width', left);
					partial_refresh_border('border-right-width', right);
					partial_refresh_border('border-bottom-width', bottom);
				}
			}
		);

		/* Border Style */
		jQuery('#accordion-' + smile_panel + ' #select-border').on(
			'change',
			function () {
				const val = jQuery(this).val();

				//	Partial refresh - Apply to [border-style]
				partial_refresh_border('border-style', val);

				if (val === 'none') {
					jQuery('.borderwidth-block')
						.closest('.setting-block')
						.slideUp();
					jQuery('.bordercolor-block')
						.closest('.setting-block')
						.slideUp();
				} else {
					jQuery('.borderwidth-block')
						.closest('.setting-block')
						.slideDown();
					jQuery('.bordercolor-block')
						.closest('.setting-block')
						.slideDown();
				}
			}
		);

		/* Border Radius - Slider */
		jQuery('#accordion-' + smile_panel + ' #slider-all-corners').slider({
			value: jQuery('#accordion-' + smile_panel + ' #all-corners').val(),
			min: 0,
			max: 500,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(ui.value, 0, 500);
				//  Partial Refresh - Apply [border-radius]
				partial_refresh_border('border-radius', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');

				jQuery('#accordion-' + smile_panel + ' #all-corners').val(val);
				jQuery('#accordion-' + smile_panel + ' #top-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #top-right').val(val);
				jQuery('#accordion-' + smile_panel + ' #bottom-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #bottom-right').val(val);

				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-top-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-top-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			stop() {
				border.refresh();
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-top-left').slider({
			value: jQuery('#accordion-' + smile_panel + ' #top-left').val(),
			min: 0,
			max: 500,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #top-left')
				);

				//	Partial refresh - Apply to [border-top-left-radius]
				partial_refresh_border('border-top-left-radius', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-top-right').slider({
			value: jQuery('#accordion-' + smile_panel + ' #top-right').val(),
			min: 0,
			max: 500,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #top-right').val(val)
				);

				// Partial refresh - Apply to [border-top-right-radius]
				partial_refresh_border('border-top-right-radius', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-bottom-left').slider({
			value: jQuery('#accordion-' + smile_panel + ' #bottom-left').val(),
			min: 0,
			max: 500,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #bottom-left')
				);

				// Partial refresh - Apply to [border-bottom-left-radius]
				partial_refresh_border('border-bottom-left-radius', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-bottom-right').slider({
			value: jQuery('#accordion-' + smile_panel + ' #bottom-right').val(),
			min: 0,
			max: 500,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #bottom-right')
				);

				// Partial refresh - Apply to [border-bottom-right-radius]
				partial_refresh_border('border-bottom-right-radius', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});

		/* Border Radius - Input */
		jQuery('#accordion-' + smile_panel + ' #all-corners').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #all-corners')
				);

				//	Partial refresh - Apply [border-radius]
				partial_refresh_border('border-radius', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-all-corners'
				).slider('value', val);
				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-all-corners'
				)
					.find('.ui-slider-handle')
					.css('left');

				jQuery('#accordion-' + smile_panel + ' #slider-all-corners')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #top-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #top-right').val(val);
				jQuery('#accordion-' + smile_panel + ' #bottom-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #bottom-right').val(val);
				jQuery('#accordion-' + smile_panel + ' #slider-top-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-top-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#top-left').on('keyup change', function () {
			const val = _getFromFieldBorder(
				jQuery(this).val(),
				0,
				500,
				jQuery('#accordion-' + smile_panel + ' #top-left')
			);

			//	Partial refresh - Apply [border-top-left-radius]
			partial_refresh_border('border-top-left-radius', val);

			jQuery('#accordion-' + smile_panel + ' #slider-top-left').slider(
				'value',
				val
			);
			const leftMarginToSlider = jQuery(
				'#accordion-' + smile_panel + ' #slider-top-left'
			)
				.find('.ui-slider-handle')
				.css('left');
			jQuery('#accordion-' + smile_panel + ' #slider-top-left')
				.find('.range-quantity')
				.css('width', leftMarginToSlider);
		});
		jQuery('#accordion-' + smile_panel + ' #top-right').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #top-right')
				);

				//	Partial refresh - Apply [border-top-right-radius]
				partial_refresh_border('border-top-right-radius', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-top-right'
				).slider('value', val);
				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-top-right'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-top-right')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#accordion-' + smile_panel + ' #bottom-left').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #bottom-left')
				);

				//	Partial refresh - Apply [border-bottom-left-radius]
				partial_refresh_border('border-bottom-left-radius', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-bottom-left'
				).slider('value', val);
				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-bottom-left'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-left')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#accordion-' + smile_panel + ' #bottom-right').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #bottom-right')
				);

				//	Partial refresh - Apply [border-bottom-right-radius]
				partial_refresh_border('border-bottom-right-radius', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-bottom-right'
				).slider('value', val);
				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-bottom-right'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-bottom-right')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);

		/* Color (Border and background) */
		jQuery('#accordion-' + smile_panel + ' #br-color').on(
			'change',
			function () {
				const v = jQuery(this).val();
				jQuery('#accordion-' + smile_panel + ' #br-color-button').css(
					'background-color',
					'#' + v
				);

				//  Partial Refresh - Apply [border-color]
				partial_refresh_border('border-color', v);
			}
		);

		/* Border Width - Slider */
		jQuery('#accordion-' + smile_panel + ' #slider-width-allsides').slider({
			value: jQuery(
				'#accordion-' + smile_panel + ' #width-allsides'
			).val(),
			min: 0,
			max: 50,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(ui.value, 0, 500);

				//  Partial Refresh - Apply [border-color]
				partial_refresh_border('border-width', val);

				jQuery('#accordion-' + smile_panel + ' #width-allsides').val(
					val
				);
				jQuery('#accordion-' + smile_panel + ' #width-top').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-right').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-bottom').val(val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-allsides')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-top')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-bottom')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			stop() {
				border.refresh();
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-width-top').slider({
			value: jQuery('#accordion-' + smile_panel + ' #width-top').val(),
			min: 0,
			max: 50,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-top')
				);

				//  Partial Refresh - Apply [border-top-width]
				partial_refresh_border('border-top-width', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-width-left').slider({
			value: jQuery('#accordion-' + smile_panel + ' #width-left').val(),
			min: 0,
			max: 50,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-left')
				);

				//  Partial Refresh - Apply [border-left-width]
				partial_refresh_border('border-left-width', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-width-right').slider({
			value: jQuery('#accordion-' + smile_panel + ' #width-right').val(),
			min: 0,
			max: 50,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-right')
				);

				//  Partial Refresh - Apply [border-right-width]
				partial_refresh_border('border-right-width', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});
		jQuery('#accordion-' + smile_panel + ' #slider-width-bottom').slider({
			value: jQuery('#accordion-' + smile_panel + ' #width-bottom').val(),
			min: 0,
			max: 50,
			step: 1,
			slide(event, ui) {
				const val = _getFromFieldBorder(
					ui.value,
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-bottom')
				);

				//  Partial Refresh - Apply [border-bottom-width]
				partial_refresh_border('border-bottom-width', val);

				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
			create() {
				const leftMarginToSlider = jQuery(this)
					.find('.ui-slider-handle')
					.css('left');
				jQuery(this)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			},
		});

		/* Border Width - Input */
		jQuery('#accordion-' + smile_panel + ' #width-allsides').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #all-sides')
				);

				//  Partial Refresh - Apply [border-width]
				partial_refresh_border('border-width', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-width-allsides'
				).slider('value', val);
				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-width-allsides'
				)
					.find('.ui-slider-handle')
					.css('left');

				jQuery('#accordion-' + smile_panel + ' #slider-width-allsides')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #width-top').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-left').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-right').val(val);
				jQuery('#accordion-' + smile_panel + ' #width-bottom').val(val);

				jQuery('#accordion-' + smile_panel + ' #slider-width-allsides')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-top')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-left')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-right')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
				jQuery('#accordion-' + smile_panel + ' #slider-width-bottom')
					.slider('value', val)
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#width-top').on('keyup change', function () {
			const val = _getFromFieldBorder(
				jQuery(this).val(),
				0,
				500,
				jQuery('#accordion-' + smile_panel + ' #width-top')
			);

			//  Partial Refresh - Apply [border-top-width]
			partial_refresh_border('border-top-width', val);

			jQuery('#accordion-' + smile_panel + ' #slider-width-top').slider(
				'value',
				val
			);

			const leftMarginToSlider = jQuery(
				'#accordion-' + smile_panel + ' #slider-width-top'
			)
				.find('.ui-slider-handle')
				.css('left');
			jQuery('#accordion-' + smile_panel + ' #slider-width-top')
				.find('.range-quantity')
				.css('width', leftMarginToSlider);
		});
		jQuery('#accordion-' + smile_panel + ' #width-left').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-left')
				);
				//  Partial Refresh - Apply [border-left-width]
				partial_refresh_border('border-left-width', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-width-left'
				).slider('value', val);

				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-width-left'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-width-left')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#accordion-' + smile_panel + ' #width-right').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-right')
				);

				//  Partial Refresh - Apply [border-right-width]
				partial_refresh_border('border-right-width', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-width-right'
				).slider('value', val);

				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-width-right'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-width-right')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);
		jQuery('#accordion-' + smile_panel + ' #width-bottom').on(
			'keyup change',
			function () {
				const val = _getFromFieldBorder(
					jQuery(this).val(),
					0,
					500,
					jQuery('#accordion-' + smile_panel + ' #width-bottom')
				);

				//  Partial Refresh - Apply [border-bottom-width]
				partial_refresh_border('border-bottom-width', val);

				jQuery(
					'#accordion-' + smile_panel + ' #slider-width-bottom'
				).slider('value', val);

				const leftMarginToSlider = jQuery(
					'#accordion-' + smile_panel + ' #slider-width-bottom'
				)
					.find('.ui-slider-handle')
					.css('left');
				jQuery('#accordion-' + smile_panel + ' #slider-width-bottom')
					.find('.range-quantity')
					.css('width', leftMarginToSlider);
			}
		);

		//	Generate CSS
		const a = jQuery('#accordion-' + smile_panel_id + ' #border-code');
		const css_preview = a.attr('data-css-preview') || '';
		const selector = a.attr('data-css-selector') || '';
		const unit = a.attr('data-unit') || 'px';
		function partial_refresh_border(property, value) {
			//  apply css by - inline
			if (
				css_preview !== 1 ||
				null === css_preview ||
				'undefined' === css_preview
			) {
				jQuery('#smile_design_iframe')
					.contents()
					.find(selector)
					.css(property, value);
			}
			a.trigger('change');

			//  apply css by - after css generation
			jQuery(document).trigger('updated', [
				css_preview,
				selector,
				property,
				value,
				unit,
			]);
		}

		//	Generate - Border hidden value with ConCat
		jQuery('#button-save-' + smile_panel + ' > span').trigger('click');
		jQuery('#button-save-' + smile_panel).on('click', function () {
			const panel_opts = _getAllValuesFromPanelBorder();
			const panel_border = new Border(panel_opts);
			panel_border.refresh();
		});
	});
});