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' ) ) &&
  • { listItem.onClick(); clearDropdown(); } } > {listItem.display}
  • ) ) ) } } const getDefaultMessage = () => { return
  • {props.defaultMessage}
  • ; } const dropdownContent = () => { if ( props.showDefaultMessage && props.defaultMessage ) { return getDefaultMessage(); } else if ( props.showNoResultsMessage && props.noResultsMessage ) { return
  • {props.noResultsMessage}
  • ; } return printItems(); } return(
    { handleSearchDropdownFocus(e) }} onClick={(e)=> { handleSearchDropdownClick(e) }} onKeyDown={(e)=> { handleSearchDropdownKeyDown(e) }} onBlur={(e)=> { handleSearchDropdownBlur(e) }} >
    { handleResultsContainerClick(e) }} >
      {dropdownMarkup}
    ) }
    {"id":512,"date":"2024-04-29T17:25:55","date_gmt":"2024-04-29T20:25:55","guid":{"rendered":"https:\/\/automax.net.br\/?p=512"},"modified":"2024-04-29T17:25:57","modified_gmt":"2024-04-29T20:25:57","slug":"a-importancia-da-manutencao-preventiva-para-donos-de-carros-e-como-a-automax-simplifica-esse-processo","status":"publish","type":"post","link":"https:\/\/automax.net.br\/a-importancia-da-manutencao-preventiva-para-donos-de-carros-e-como-a-automax-simplifica-esse-processo\/","title":{"rendered":"A Import\u00e2ncia da Manuten\u00e7\u00e3o Preventiva para Donos de Carros e Como a Automax Simplifica Esse Processo"},"content":{"rendered":"\n

    A manuten\u00e7\u00e3o preventiva \u00e9 um aspecto crucial da propriedade de ve\u00edculos, garantindo sua seguran\u00e7a, confiabilidade e longevidade.<\/p>\n\n\n\n

    Para donos de carros que frequentam oficinas mec\u00e2nicas, \u00e9 essencial compreender a import\u00e2ncia dessa pr\u00e1tica e como ela pode ser simplificada com o aux\u00edlio da Automax.<\/p>\n\n\n\n

    Exploraremos a relev\u00e2ncia da manuten\u00e7\u00e3o preventiva para os propriet\u00e1rios de ve\u00edculos e como a Automax pode tornar esse processo mais f\u00e1cil e eficiente.<\/p>\n\n\n\n

    Import\u00e2ncia da Manuten\u00e7\u00e3o Preventiva para Donos de Carros<\/strong><\/p>\n\n\n\n

    Para os propriet\u00e1rios de ve\u00edculos, a manuten\u00e7\u00e3o preventiva desempenha um papel vital na garantia de um funcionamento seguro e confi\u00e1vel de seus carros.<\/p>\n\n\n\n

    Realizar inspe\u00e7\u00f5es regulares, trocar \u00f3leo, verificar freios e pneus, entre outras pr\u00e1ticas, pode ajudar a prevenir problemas mec\u00e2nicos graves e at\u00e9 mesmo acidentes.<\/p>\n\n\n\n

    Al\u00e9m disso, a manuten\u00e7\u00e3o preventiva pode prolongar a vida \u00fatil do ve\u00edculo e ajudar a evitar despesas imprevistas com reparos.<\/p>\n\n\n\n

    Como a Automax Simplifica a Manuten\u00e7\u00e3o Preventiva<\/strong><\/p>\n\n\n\n

    A Automax oferece uma s\u00e9rie de recursos que simplificam o processo de manuten\u00e7\u00e3o preventiva para donos de carros e oficinas mec\u00e2nicas.<\/p>\n\n\n\n

    Com a Automax, \u00e9 poss\u00edvel agendar lembretes autom\u00e1ticos para servi\u00e7os de manuten\u00e7\u00e3o, acompanhar o hist\u00f3rico de manuten\u00e7\u00e3o de cada ve\u00edculo e receber notifica\u00e7\u00f5es sobre itens de manuten\u00e7\u00e3o pendentes.<\/p>\n\n\n\n

    Al\u00e9m disso, a Automax oferece integra\u00e7\u00e3o com fornecedores de pe\u00e7as, facilitando a reposi\u00e7\u00e3o de pe\u00e7as conforme necess\u00e1rio.<\/p>\n\n\n\n

    Dicas Pr\u00e1ticas para Donos de Carros<\/strong><\/p>\n\n\n\n