Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

autocompleter-caba

Package Overview
Dependencies
Maintainers
0
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

autocompleter-caba

Un paquete para que permite obtener información sobre direcciones y sitios de interés de la Ciudad de Buenos Aires.

  • 0.1.5
  • npm
  • Socket score

Version published
Weekly downloads
109
increased by1457.14%
Maintainers
0
Weekly downloads
 
Created
Source

Documentación del Paquete Autocompleter

Este paquete proporciona funcionalidades para obtener sugerencias e información para direcciones y sitios de interés de la Ciudad de Buenos Aires.

Instalación

Para instalar el paquete, utilizar npm:

npm install autocompleter-caba

Uso

Importar el paquete:

import { Autocompleter } from 'autocompleter-caba/dist/src/index';

Crear una instancia de Autocompleter:

const autocompleter = new Autocompleter();

Configuración de Credenciales

Establecer las credenciales del cliente utilizando el método setCredentials(clientId, clientSecret):

autocompleter.setCredentials("tu_client_id", "tu_client_secret");

Habilitar/Desactivar Suggesters

Se puede habilitar o desactivar los suggesters según necesidades utilizando los métodos enableSuggester(suggester) y disableSuggester(suggester):

autocompleter.enableSuggester("AddressSuggester");
autocompleter.disableSuggester("PlaceSuggester");

Obtener Sugerencias

Para obtener sugerencias basadas en la entrada del usuario, utilizar el método getSuggestions(input):

const suggestions = await autocompleter.getSuggestions("Callao 520");

Buscar Direcciones

Para buscar direcciones, utilizar el método getSearch(address):

const searchResult = await autocompleter.getSearch("Callao 520");

Buscar Lugares de Interés

Para buscar sitios de interés, utilizar el método getSearchPlaces(place):

const searchResult = await autocompleter.getSearchPlaces("hospital");

Las siguientes funciones permiten a los usuarios interactuar con la aplicación Autocompleter de diversas maneras, desde configurar sus credenciales hasta obtener sugerencias y resultados de búsqueda específicos.

Métodos

  • getClientId(): Devuelve el atributo clientId.

  • getClientSecret(): Devuelve el atributo clientSecret.

  • setCredentials(clientId: string, clientSecret: string): Permite establecer las credenciales del cliente proporcionando los atributos clientId y clientSecret.

  • findSuggester(suggesterType: SuggestersOptions): Busca y devuelve el suggester correspondiente según el tipo especificado.

  • enableSuggester(suggester: SuggestersOptions): Permite habilitar un suggester específico.

  • disableSuggester(suggester: SuggestersOptions): Desactiva un suggester específico.

  • getSuggesters(): Devuelve un objeto que contiene todos los suggesters disponibles en la aplicación.

  • getSuggestions(input: string, typeSuggester: string): Busca sugerencias basadas en la entrada de texto proporcionada. TypeSuggester pueder ser "address" o "place", por dafault es "all".

  • getSearch(input: string): Busca información sobre la dirección o sitio de interés ingresado.

  • getSearchPlaces(place: string): Busca información del sitios de interés ingresado.

  • getSearchAddress(address: string): Busca información de la dirección ingresada.

Ejemplos:

Autocompleter en Angular

Creación del Proyecto

Utilizar Angular CLI para crear un nuevo proyecto. Abrir una consola de comando y ejecutar:

ng new autocompleter-app

Seguir las instrucciones para configurar el proyecto. Una vez creado, navegar hacia la raiz del proyecto:

cd autocompleter-app
Instalación del Paquete

Instalar el autocompleter-caba:

npm install autocompleter-caba
Configuración de Componentes

En el archivo .ts (por ejemplo src/app/app.component.ts):

  • Incializar e instanciar la clase Autocompleter en el constructor del componente AppComponent.
  • Esteblecer las credenciales para el uso del Autocompleter.
  • Crear y definir las funciones que utilizarán los métodos de la clase Autocompleter (ejemplo: getSuggestions y getSearch.)
export class AppComponent {
  title = 'autocompleter-app';
  calle: string = '';
  suggestions: any[] = [];
  search: any = null;
  autocompleter: Autocompleter;
  typingTimeout: any;

  constructor() {
    this.autocompleter = new Autocompleter();
    this.autocompleter.setCredentials('client_id', 'client_secret_id');
  }

  onInputChange() {

    clearTimeout(this.typingTimeout);

    this.typingTimeout = setTimeout(() => {
      this.getSuggestions();
    }, 1000);
  }

  getSuggestions() {
    if (this.calle) {
      this.autocompleter.getSuggestions(this.calle, 'address').then((data: any) => {
        this.search = null;
        this.suggestions = data;
        console.log(data);
      }).catch((error: any) => {
        console.error('Error obteniendo sugerencias:', error);
      });
    }
    if (this.calle == ""){
      this.suggestions = [];
    }
  }

  getSearch() {
    if (this.calle) {
      this.autocompleter.getSearch(this.calle).then((data: any) => {
        this.search = data.data;
        this.suggestions = [];
      }).catch((error: any) => {
        console.error('Error obteniendo dirección:', error);
      });
    }
    if (this.calle == ""){
      this.suggestions = [];
    }
  }
}

En un template crear la estructura necesaria para observar los resultados de la clase Autocompleter. Por ejemplo, en src/app/app.component.html agregar la siguiente estructura:

<div style="text-align:center">
  <h1> {{ title }} </h1>
  <input
    id="calle"
    [(ngModel)]="calle"
    (input)="onInputChange()"
    placeholder="Ingrese la calle"
  />

  <button (click)="getSearch()">Buscar</button>

  <ul *ngIf="suggestions.length > 0" style="list-style: none;">
    <li *ngFor="let suggestion of suggestions">{{ suggestion.value }}</li>
  </ul>
  <div *ngIf="search != null">{{search.direccion}}</div>
  <div id="mapa"></div>
</div>

Autocompleter en ReactJs

Creación del Proyecto

Crear un proyecto con CRA o Vite. Abrir una consola de comando y ejecutar:

npm create vite@latest autocompleter-app

Seguir las instrucciones para configurar el proyecto. Una vez creado, navegar hacia la raiz del proyecto:

cd autocompleter-app
Instalación del Paquete

Instalar el autocompleter-caba:

npm install autocompleter-caba
Configuración de Componentes
  • Crear un archivo App.jsx y configurar el componente App para utilizar el autocompleter.
function App() {
  const [calle, setCalle] = useState('');
  const [suggestions, setSuggestions] = useState([]);
  const [search, setSearch] = useState(null);
  const [typingTimeout, setTypingTimeout] = useState(null);
  const autocompleter = new Autocompleter();
  
  // ...
}
  • Inicializar e instanciar la clase Autocompleter en el componente App.
const autocompleter = new Autocompleter();
  • Establecer las credenciales para el uso del Autocompleter.
  useEffect(() => {
    autocompleter.setCredentials('client_id', 'client_secret_id');
  }, []);
  • Crear y definir las funciones que utilizarán los métodos de la clase Autocompleter (ejemplo: getSuggestions y getSearch) dentro del componente App.
const handleInputChange = (e) => {
    setCalle(e.target.value);
    clearTimeout(typingTimeout);

    setTypingTimeout(
      setTimeout(() => {
        getSuggestions();
      }, 1000)
    );
  };

  const getSuggestions = () => {
    if (calle) {
      autocompleter
        .getSuggestions(calle, 'address')
        .then((data) => {
          setSearch(null);
          setSuggestions(data);
          console.log(data);
        })
        .catch((error) => {
          console.error('Error obteniendo sugerencias:', error);
        });
    }
    if (calle === '') {
      setSuggestions([]);
    }
  };

  const getSearch = () => {
    if (calle) {
      autocompleter
        .getSearch(calle)
        .then((data) => {
          setSearch(data.data);
          setSuggestions([]);
        })
        .catch((error) => {
          console.error('Error obteniendo dirección:', error);
        });
    }
    if (calle === '') {
      setSuggestions([]);
    }
  };
  • Estructura de la Interfaz: En el return del componente se debe crear la estructura necesaria para mostrar los resultados del autocompleter.
 return (
    <div style={{ textAlign: 'center' }}>
      <h1>Autocompleter App</h1>
      <input
        id="calle"
        value={calle}
        onChange={handleInputChange}
        placeholder="Ingrese la calle"
      />
      <button onClick={getSearch}>Buscar</button>

      <ul style={{ listStyle: 'none', padding: 0 }}>
        {suggestions.map((suggestion, index) => (
          <li key={index}>{suggestion.value}</li>
        ))}
      </ul>

      {search && <div>{search.direccion}</div>}
    </div>
  );
}

Notas

  • Asegurarse de establecer las credenciales del cliente antes de realizar cualquier búsqueda.
  • Los suggesters deben estar habilitados antes de utilizar las funciones de búsqueda correspondientes.
  • El paquete tiene restricciones en cuanto a la longitud mínima de texto y el número máximo de sugerencias.

Keywords

FAQs

Package last updated on 17 Oct 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc