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' ) ) &&
Todos temos o objetivo de trabalhar com o que gostamos de fazer ou pelo menos na \u00e1rea mais pr\u00f3xima, isso \u00e9 fato. Quando conseguimos, atrav\u00e9s de esfor\u00e7o e planejamento, abrir uma empresa especializada nisso que gostamos de fazer, melhor ainda! Mas e como proceder quando gerenciar essa empresa envolve processos engenhosos e que acabam atrapalhando a sua produtividade?<\/p>\n\n\n\n
\u00c9 o que acontece com muitas oficinas a qual seu propriet\u00e1rio entende muito bem de mec\u00e2nica automotiva ou da sua especializa\u00e7\u00e3o, mas na hora de gerenciar as finan\u00e7as do estabelecimento, acaba sofrendo e n\u00e3o tendo o resultado esperado, podendo at\u00e9 mesmo causar confus\u00f5es e desentendimentos. E, mesmo que n\u00e3o seja um trabalho nada f\u00e1cil, a gest\u00e3o completa de custos \u00e9 muito importante. Afinal, como controlar o financeiro da sua oficina de forma simples e eficaz?<\/p>\n\n\n\n
Nesse caso, temos dois principais caminhos. O primeiro, que talvez n\u00e3o seja vi\u00e1vel para todas as oficinas, \u00e9 a contrata\u00e7\u00e3o de um profissional especializado na \u00e1rea, que faria a gest\u00e3o de todas as finan\u00e7as. J\u00e1 o segundo caminho, prop\u00edcios para pequenas oficinas ou estabelecimentos que buscam economizar, \u00e9 um sistema capaz de englobar tudo que envolve o financeiro e que ofere\u00e7a as melhores ferramentas para esse controle. Mas como?<\/p>\n\n\n\n
Al\u00e9m de ferramentas aptas para gerir o dinheiro do neg\u00f3cio, uma lista de itens essenciais para n\u00e3o se perder em todo esse processo \u00e9 fundamental. Cada passo deve ser feito com cuidado e de forma constante, confira:<\/p>\n\n\n\n
Pensando nesse processo que demanda tempo e dedica\u00e7\u00e3o, a Automax oferece todas as ferramentas necess\u00e1rias para ter o controle total do financeiro da sua oficina. Conte com cada informa\u00e7\u00e3o que voc\u00ea precisar organizada em listagens intuitivas e r\u00e1pidas no nosso sistema de gest\u00e3o de custos.<\/p>\n\n\n\n