Learn more  » Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

jsarnowski / jsarnowski/jet-blocks   php

Repository URL to install this package:

Version: 1.2.8 

/ modules / vue-ui / assets / src / js / components / form / dimensions.js

import { oneOf } from '../../utils/assist';
import { checkConditions } from '../../mixins/check-conditions';

const Dimensions = {

	name: 'cx-vui-dimensions',
	template: '#cx-vui-dimensions',
	mixins: [ checkConditions ],
	props: {
		value: {
			type: Object,
			default: {
				'top': '',
				'right': '',
				'bottom': '',
				'left': '',
				'is_linked': true,
				'units': 'px'
			}
		},
		units: {
			type: Array,
			default() {
				return [
					{
						unit: 'px',
						min: -1000,
						max: 1000,
						step: 1
					},
					{
						unit: 'em',
						min: 0,
						max: 10,
						step: 0.1
					},
					{
						unit: '%',
						min: 0,
						max: 100,
						step: 1
					}
				];
			}
		},
		size: {
			validator ( value ) {
				return oneOf( value, [ 'fullwidth', 'default' ] );
			},
			default: 'default'
		},
		disabled: {
			type: Boolean,
			default: false
		},
		name: {
			type: String
		},
		elementId: {
			type: String
		},
		conditions: {
			type: Array,
			default() {
				return [];
			}
		},
		// Wrapper related props (should be passed into wrapper component)
		preventWrap: {
			type: Boolean,
			default: false
		},
		label: {
			type: String
		},
		description: {
			type: String
		},
		wrapperCss: {
			type: Array,
			default: function() {
				return [];
			}
		},
	},
	mounted() {
		if ( ! this.currentId && this.name ) {
			this.currentId = 'cx_' + this.name;
		}
	},
	data() {
		return {
			currentValue: this.value,
			currentId: this.elementId,
			isLink: this.value['is_linked'] ? true : false,
		};
	},
	computed: {
		controlClasses: function() {
			let classesList = [ 'cx-vui-dimensions' ];

			classesList.push( 'size-' + this.size );

			return classesList;
		},

		sanitizeValue: function() {

			return {
				top: this.currentValue.top || '',
				right: this.currentValue.right || '',
				bottom: this.currentValue.bottom || '',
				left: this.currentValue.left || '',
				is_linked: this.isLink ? '1' : '0',
				units: this.currentValue.units || 'px'
			}
		},

		min: function() {
			let unitData = this.units.filter( ( obj ) => {
				return obj.unit === this.currentValue.units;
			} );

			if ( 0 === unitData.length ) {
				return false;
			}

			return unitData[0]['min'];
		},

		max: function() {
			let unitData = this.units.filter( ( obj ) => {
				return obj.unit === this.currentValue.units;
			} );

			if ( 0 === unitData.length ) {
				return false;
			}

			return unitData[0]['max'];
		},

		step: function() {
			let unitData = this.units.filter( ( obj ) => {
				return obj.unit === this.currentValue.units;
			} );

			if ( 0 === unitData.length ) {
				return false;
			}

			return unitData[0]['step'];
		}
	},
	methods: {
		handleInput( value ) {

			if ( this.isLink ) {
				this.currentValue.top = value;
				this.currentValue.right = value;
				this.currentValue.bottom = value;
				this.currentValue.left = value;
			}

			this.$emit( 'input', this.sanitizeValue );
		},

		handleChange( event ) {
			let value = event.target.value;

			if ( this.isLink ) {
				this.currentValue.top = value;
				this.currentValue.right = value;
				this.currentValue.bottom = value;
				this.currentValue.left = value;
			}

			this.$emit( 'on-change', this.sanitizeValue );
		},

		unitHandler( unit ) {
			this.currentValue.units = unit;

			this.$emit( 'input', this.sanitizeValue );
			this.$emit( 'on-change', this.sanitizeValue );
			this.$emit( 'on-unit-updated', unit );
		},

		linkHandler() {
			this.isLink = ! this.isLink;
			this.currentValue['is_linked'] = this.isLink ? '1' : '0';

			this.$emit( 'input', this.sanitizeValue );
			this.$emit( 'on-change', this.sanitizeValue );
			this.$emit( 'on-link-updated' );
		}
	},
};

export default Dimensions;