import React, {useEffect, useState} from 'react'; const { __ } = wp.i18n; export function SearchDropdown( props ) { const [searchResultsFieldStatus, setSearchResultsFieldStatus] = useState( 'closed' ); const [textareaValue, setTextareaValue] = useState( '' ); const [dropdownMarkup, setDropdownMarkup] = useState( '' ); const [reset, setReset] = useState( false ); let searchResultsItems = []; /** * Sets the dropdown content when there's a change on any of props.searchResults, props.showDefaultMessage, props.showNoResultsMessage */ useEffect(() => { if ( props.searchResults ) { searchResultsItems = props.searchResults; } else { searchResultsItems = []; } if ( ! props.showDefaultMessage && ! props.showNoResultsMessage ) { setDropdownMarkup( printItems() ); } else { setDropdownMarkup( dropdownContent() ); } }, [props.searchResults, props.showDefaultMessage, props.showNoResultsMessage], reset); /** * Initially sets the dropdown content to the default message. */ useEffect( () => { setDropdownMarkup( getDefaultMessage() ); }, [] ); /** * On dropdown container focus, the textarea gets focused so user can start typing immediately. * @param el */ const handleSearchDropdownFocus = ( el ) => { if ( 'closed' === searchResultsFieldStatus ) { const textarea = el.currentTarget.querySelector( 'textarea' ); if ( 'undefined' !== typeof textarea && textarea !== null ) { textarea.tabIndex = '-1'; textarea.focus(); } } } const handleSearchDropdownClick = ( el ) => { } /** * On keydown sets the value of textarea. * @param el */ const handleSearchDropdownKeyDown = ( el ) => { setTextareaValue( el.currentTarget.value ) setSearchResultsFieldStatus( 'open' ); } /** * Expands results area upon textarea focus. * @param el */ const handleTextareaFocus = ( el ) => { setSearchResultsFieldStatus( 'open' ); } const handleSearchDropdownBlur = ( el ) => { const blurTimer = setInterval(function() { const resultsWrapperId = `sui-select-dropdown-wrap-${props.id}`, textareaId = `search-dropdown-textbox-${props.id}`, rendererWrapId = `blc-search-dropdown__renderer_wrap-${props.id}`; if ( resultsWrapperId !== document.activeElement.id && textareaId !== document.activeElement.id && rendererWrapId !== document.activeElement.id ) { setSearchResultsFieldStatus( 'closed' ); setTextareaValue( '' ); } clearInterval( blurTimer ); }, 160); } const handleResultsContainerClick = ( el ) => { el.currentTarget.tabIndex = '-1'; el.currentTarget.focus(); } const clearDropdown = () => { setSearchResultsFieldStatus( 'closed' ); setTextareaValue( '' ); //props.searchResults = []; setDropdownMarkup( ''); //props.showDefaultMessage = true; //props.showNoResultsMessage = false; setDropdownMarkup( getDefaultMessage() ); setReset( true ) } const printItems = () => { if ( typeof searchResultsItems !== 'undefined' && searchResultsItems.length > 0 ) { return ( searchResultsItems.map( (listItem) => ( ( typeof listItem !== 'undefined' && listItem.hasOwnProperty( 'key' ) ) &&
Vulkan Vegas Recenzja 2024: 6000 Z\u0142 I 200 Darmowych Spin\u00f3w<\/p>\n
Content<\/p>\n
Jest dost\u0119pna na urz\u0105dzenia z systemami Android i urz\u0105dzenia firmy Apple, z iOS-em. Jak wida\u0107 na screenie, mo\u017cna j\u0105 pobra\u0107 bezpo\u015brednio ze strony, zagl\u0105daj\u0105c do sekcji \u201eMobilna aplikacja\u201d, kt\u00f3ra jest zlokalizowana watts stopce witryny. Oferty Vulkan Vegas zawsze maj\u0105 czytelny regulamin i przyjazne warunki promocji. Casino cz\u0119sto organizuje dla spo\u0142eczno\u015bci r\u00f3\u017cne udogodnienia, simply by utrzyma\u0107 zainteresowanie u\u017cytkownik\u00f3w i jak wida\u0107 dzia\u0142a to skutecznie od kilku \u0142adnych lat. Je\u015bli planujesz aktywowa\u0107 bonus bez depozytu z kodem promocyjnym, to koniecznie sprawd\u017a poni\u017csze wskaz\u00f3wki i list\u0119 kork\u00f3w, by niczego nie und nimmer pomin\u0105\u0107. Vulkan Las vegas nie pozostawia kamienia na kamieniu, je\u015bli chodzi o zak\u0142ady sportowe, oferuj\u0105c szerok\u0105 gam\u0119 sport\u00f3w, aby zaspokoi\u0107 preferencje ka\u017cdego gracza.<\/p>\n