%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/tradesc/www/relax/wp-content/plugins/wpforms-lite/assets/js/admin/builder/
Upload File :
Create Path :
Current File : /home/tradesc/www/relax/wp-content/plugins/wpforms-lite/assets/js/admin/builder/search-fields.js

/**
 * WPForms Builder Search module.
 *
 * @since 1.8.3
 */

'use strict';

var WPForms = window.WPForms || {};

WPForms.Admin = WPForms.Admin || {};
WPForms.Admin.Builder = WPForms.Admin.Builder || {};

WPForms.Admin.Builder.Search = WPForms.Admin.Builder.Search || ( function( document, window, $ ) {

	/**
	 * Elements holder.
	 *
	 * @since 1.8.3
	 *
	 * @type {object}
	 */
	const el = {};

	/**
	 * Public functions and properties.
	 *
	 * @since 1.8.3
	 *
	 * @type {object}
	 */
	const app = {

		/**
		 * Start the engine. DOM is not ready yet, use only to init something.
		 *
		 * @since 1.8.3
		 */
		init: function() {

			$( app.ready );
		},

		/**
		 * DOM is fully loaded.
		 *
		 * @since 1.8.3
		 */
		ready: function() {

			app.setup();
			app.events();
			app.scrollSidebar();
		},

		/**
		 * Scroll the sidebar to the height of the search.
		 *
		 * @since 1.8.3
		 */
		scrollSidebar: function() {

			el.$sidebar.scrollTop( el.$searchWrapper.height() + 20 );
		},

		/**
		 * Setup. Prepare some variables.
		 *
		 * @since 1.8.3
		 */
		setup: function() {

			// Cache DOM elements
			el.$document            = $( document );
			el.$builder             = $( '#wpforms-builder' );
			el.$searchInput         = $( '#wpforms-search-fields-input' );
			el.$searchInputCloseBtn = $( '.wpforms-search-fields-input-close' );
			el.$searchWrapper       = $( '.wpforms-search-fields-wrapper' );
			el.$noResults           = $( '.wpforms-search-fields-no-results' );
			el.$listWrapper         = $( '.wpforms-search-fields-list' );
			el.$list                = $( '.wpforms-search-fields-list .wpforms-add-fields-buttons' );
			el.$groups              = $( '.wpforms-tab-content > .wpforms-add-fields-group' );
			el.$sidebar             = $( '#wpforms-panel-fields .wpforms-add-fields' );
		},

		/**
		 * Bind events.
		 *
		 * @since 1.8.3
		 */
		events: function() {

			el.$searchInput.on( 'keyup', app.searchAction );
			el.$searchInputCloseBtn.on( 'click', app.clearSearch );
			el.$document.on( 'wpformsFieldAdd', app.clearSearch );
			el.$document.on( 'wpformsFieldDelete', app.refreshSearchResults );
		},

		/**
		 * Search action.
		 *
		 * @since 1.8.3
		 */
		searchAction: function() {

			const $fields = el.$builder.find( '.wpforms-tab-content > .wpforms-add-fields-group .wpforms-add-fields-button' );
			const searchValue = el.$searchInput.val().toLowerCase();

			el.$list.empty();

			if ( searchValue ) {
				el.$groups.hide();
				el.$listWrapper.show();
				el.$searchInputCloseBtn.addClass( 'active' );

				$fields.each( function() {

					const $item     = $( this );
					const titleText = $item.text().toLowerCase();
					const keywords  = $item.data( 'field-keywords' ) ? $item.data( 'field-keywords' ).toLowerCase() : '';

					if ( titleText.indexOf( searchValue ) >= 0 || ( keywords && keywords.indexOf( searchValue ) >= 0 ) ) {
						const $clone = $item.clone();

						$clone.attr( 'data-target', $clone.attr( 'id' ) );
						$clone.removeAttr( 'id' );
						$clone.addClass( 'wpforms-add-fields-button-clone' );

						el.$list.append( $clone );
					}
				} );

				const $matchingItems = el.$list.find( '.wpforms-add-fields-button' );
				const hasMatchingItems = $matchingItems.length > 0;

				if ( hasMatchingItems ) {
					el.$noResults.hide();
				} else {
					el.$noResults.show();
					el.$listWrapper.hide();
				}
			} else {
				el.$groups.show();
				el.$listWrapper.hide();
				el.$noResults.hide();
				el.$searchInputCloseBtn.removeClass( 'active' );
			}

			WPForms.Admin.Builder.DragFields.setup();
			WPForms.Admin.Builder.DragFields.initSortableFields();
			app.cloneClickAction();
		},

		/**
		 * Clear search.
		 *
		 * @since 1.8.3
		 */
		clearSearch: function() {

			if ( ! el.$searchInput.val() ) {
				return;
			}

			el.$list.empty();
			el.$listWrapper.hide();
			el.$groups.show();
			el.$noResults.hide();
			el.$searchInput.val( '' ).focus();
			el.$searchInputCloseBtn.removeClass( 'active' );
		},

		/**
		 * Refresh search results.
		 *
		 * @since 1.8.3
		 */
		refreshSearchResults: function() {

			// We need to wait for the original field to be unlocked.
			setTimeout( app.searchAction, 0 );
		},

		/**
		 * Clone click action.
		 *
		 * @since 1.8.3
		 */
		cloneClickAction() {
			$( '.wpforms-add-fields-button-clone' ).on( 'click', function( e ) {
				e.preventDefault();
				e.stopPropagation();

				const target = $( this ).attr( 'data-target' );

				$( '#' + target ).trigger( 'click' );
			} );
		},
	};

	// Provide access to public functions/properties.
	return app;

}( document, window, jQuery ) );

// Initialize.
WPForms.Admin.Builder.Search.init();

Zerion Mini Shell 1.0