Why Gemfury? 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-engine   php

Repository URL to install this package:

Version: 2.7.7 

/ js / admin / dashboard / data-stores.js

(function( $, dataStoresConfig ) {

	'use strict';

	Vue.component( 'jet-engine-data-stores', {
		template: '#jet_engine_data_stores',
		data: function() {
			return {
				dataStores: dataStoresConfig.items,
				storeTypes: dataStoresConfig.types,
				postTypes: dataStoresConfig.post_types,
				canCount: dataStoresConfig.can_posts_counts,
				nonce: dataStoresConfig._nonce,
				saving: false,
			};
		},
		methods: {
			sanitizeStoreSlug: function( value ) {
				var regex = /\s+/g;
				value = value.toLowerCase().replace( regex, '-' );
				value = window.JetEngineTools.maybeCyrToLatin( value );

				return value;
			},
			addNewRepeaterItem: function( item ) {
				this.dataStores.push( item );
			},
			cloneItem: function( index, keys ) {
				var item    = JSON.parse( JSON.stringify( this.dataStores[ index ] ) ),
					newItem = {};

				// for ( var i = 0; i < keys.length; i++ ) {
				// 	newItem[ keys[ i ] ] = item[ keys[ i ] ];
				// };

				newItem = item;

				if ( newItem.id ) {
					delete newItem.id;
				}

				newItem.name = newItem.name + ' (Copy)';
				newItem.slug = newItem.slug + '_copy';

				this.dataStores.push( newItem );

			},
			deleteItem: function( index ) {
				this.dataStores.splice( index, 1 );
			},
			setProp: function( index, key, value ) {

				var item = this.dataStores[ index ];

				item[ key ] = value;

				if ( 'slug' === key && ! item.slug ) {
					item.slug = this.sanitizeStoreSlug( value );
				}

				this.dataStores.splice( index, 1, item );
			},
			preSetSlug: function( index ) {

				var item = this.dataStores[ index ];

				if ( ! item.slug ) {
					this.setProp( index, 'slug', this.sanitizeStoreSlug( item.name ) );
				}

			},
			isCollapsed: function( object ) {

				if ( undefined === object.collapsed || true === object.collapsed ) {
					return true;
				} else {
					return false;
				}

			},
			saveStores: function() {

				var self = this;

				self.saving = true;

				jQuery.ajax({
					url: window.ajaxurl,
					type: 'POST',
					dataType: 'json',
					data: {
						action: 'jet_engine_data_stores_save',
						nonce: self.nonce,
						items: self.dataStores,
					},
				}).done( function( response ) {
					if ( response.success ) {
						self.$CXNotice.add( {
							message: response.data.message,
							type: 'success',
							duration: 7000,
						} );
					} else {
						self.$CXNotice.add( {
							message: response.data.message,
							type: 'error',
							duration: 15000,
						} );
					}

					self.saving = false;

				} ).fail( function( jqXHR, textStatus, errorThrown ) {

					self.$CXNotice.add( {
						message: errorThrown,
						type: 'error',
						duration: 15000,
					} );

					self.saving = false;

				} );
			}
		}
	} );

})( jQuery, window.JetEngineDataStores );