b0y-101 Mini Shell


Current Path : E:/www3/chiangrai/wp-content/plugins/so-widgets-bundle/base/inc/fields/js/
File Upload :
Current File : E:/www3/chiangrai/wp-content/plugins/so-widgets-bundle/base/inc/fields/js/autocomplete-field.js

/* global jQuery, soWidgets */

( function( $ ) {

	$( document ).on( 'sowsetupformfield', '.siteorigin-widget-field-type-autocomplete', function( e ) {
		var $$ = $( this );
		var $contentSelector = $$.find(' .existing-content-selector' );

		const postId = parseInt( jQuery( '#post_ID' ).val() );

		if ( $$.data( 'initialized' ) ) {
			return;
		}

		var getSelectedItems = function() {
			var selectedItems = $$.find( 'input.siteorigin-widget-input' ).val();
			return selectedItems.length === 0 ? [] : selectedItems.split( ',' );
		};

		var updateSelectedItems = function() {
			var selectedItems = getSelectedItems();
			$$.find( 'ul.items > li' ).each( function( index, element ) {
				var $li = $( this );

				if ( selectedItems.indexOf( $li.data( 'value' ) ) > -1 ) {
					$li.addClass( 'selected' );
				} else {
					$li.removeClass( 'selected' );
				}
			} );
		};

		const $itemList = $$.find( 'ul.items' );
		const $noResults = $$.find( '.content-no-results' );
		let request = null;
		const refreshList = () => {
			if ( request !== null ) {
				request.abort();
			}

			const $contentSearchInput = $$.find( '.content-text-search' );
			const query = $contentSearchInput.val();
			const source = $contentSearchInput.data( 'source' );
			const postTypes = $contentSearchInput.data( 'postTypes' );
			const ajaxData = {
				action: 'so_widgets_search_' + source,
				postId: postId,
			};

			if ( source === 'posts' ) {
				ajaxData.query = query;
				ajaxData.postTypes = postTypes;
			} else if ( source === 'terms' ) {
				ajaxData.term = query;
			}

			// If WPML is enabled for this page, include page language for filtering.
			if ( typeof icl_this_lang == 'string' ) {
				ajaxData.language = icl_this_lang;
			}

			// Visually prep the field.
			$noResults.addClass( 'hidden' );
			$itemList.empty();
			$itemList.removeClass( 'hidden' )
			$itemList.addClass( 'loading' );

			return $.get(
				soWidgets.ajaxurl,
				ajaxData,
				( results ) => {
					// If there aren't any results, show a message.
					if ( results.length === 0 ) {
						$noResults.removeClass( 'hidden' );
						$itemList.addClass( 'hidden' );
						$itemList.removeClass( 'loading' );
						return;
					}


					results.forEach( ( item ) => {
						if ( item.label === '' ) {
							item.label = ' ';
						}
						// Add all the items.
						$itemList.append(
							$( '<li>' )
								.html( item.label + '<span>(' + item.type + ')</span>' )
								.data( item )
						);
					} );
					$itemList.removeClass( 'loading' );
				}
			);
		};

		$$.find( '.siteorigin-widget-autocomplete-input' ).on( 'click', () => {
			$noResults.addClass( 'hidden' );
			$itemList.show();
			$contentSelector.show();

			let refreshPromise = new $.Deferred();
			if( $contentSelector.is( ':visible' ) && $contentSelector.find( 'ul.items li' ).length === 0 ) {
				refreshPromise = refreshList();
			} else {
				refreshPromise.resolve();
			}

			refreshPromise.done( updateSelectedItems );
		} );

		var closeContent = function() {
			$contentSelector.hide();
		};

		$( window ).on( 'mousedown', function( event ) {
			var mouseDownOutside = $$.find( event.target ).length === 0;
			if ( mouseDownOutside ) {
				closeContent();
			}
		} );

		$$.find( '.button-close' ).on( 'click', closeContent );

		// Clicking on one of the url items.
		$$.on( 'click keypress', '.items li', function( e ) {
			e.preventDefault();

			if ( e.type == 'keyup' && ! window.sowbForms.isEnter( e ) ) {
				return;
			}
			var $input = $$.find( 'input.siteorigin-widget-input' );
			var $li = $( this );
			var clickedItem = $li.data( 'value' );

			if ( $contentSelector.data( 'multiple' ) ) {
				var selectedItems = getSelectedItems();

				var curIndex = selectedItems.indexOf( clickedItem );

				if ( curIndex > -1 ) {
					selectedItems.splice( curIndex, 1 );
					$li.removeClass( 'selected' );
				} else {
					selectedItems.push( clickedItem );
					$li.addClass( 'selected' );
				}
				$input.val( selectedItems.join( ',' ) );
			} else {
				$li.parent().find( '.selected' ).removeClass( 'selected' );
				$li.addClass( 'selected' );
				$input.val( clickedItem );
				closeContent();
			}
			$input.trigger( 'change' );
		} );

		var interval = null;
		$$.find( '.content-text-search' ).on( 'keyup', function() {
			if( interval !== null ) {
				clearTimeout( interval );
			}

			interval = setTimeout( function() {
				refreshList();
			}, 500 );
		} );

		$$.data( 'initialized', true );
	} );

} )( jQuery );

Copyright © 2019 by b0y-101