Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tofran/fastapi-htmx-full-text-search-demo
🔎 Python FastAPI HTMX full-text-search demo using SQLite FTS5 and Algolia search.
https://github.com/tofran/fastapi-htmx-full-text-search-demo
algolia fastapi htmx sqlite
Last synced: 3 months ago
JSON representation
🔎 Python FastAPI HTMX full-text-search demo using SQLite FTS5 and Algolia search.
- Host: GitHub
- URL: https://github.com/tofran/fastapi-htmx-full-text-search-demo
- Owner: tofran
- License: mit
- Created: 2024-03-11T14:09:29.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-09-26T16:32:50.000Z (4 months ago)
- Last Synced: 2024-10-15T17:21:09.427Z (3 months ago)
- Topics: algolia, fastapi, htmx, sqlite
- Language: Python
- Homepage:
- Size: 382 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Python FastAPI HTMX full-text-search demo
This project is a **demo** full-text-search application that compares the results from
[SQLite FT5](https://www.sqlite.org/fts5.html) and
[Algolia Search platform](https://www.algolia.com/).
Conceived as an experimental venture, this project serves as a demonstration of an *unconventional*
monolith tech stack. It features an interactive front-end, using a mix of traditional
Server Side Rendering (SSR) declarative web framework with zero custom JS:- [FastAPI](https://fastapi.tiangolo.com/) the server framework;
- [Jinja](https://jinja.palletsprojects.com/) for the SSR templating;
- [HTMX](https://htmx.org/) to enable front-end interactivity declaratively directly in the HTML.## Description and demo
**[Live demo](https://full-text-search-demo.tofran.com/)**
(the server goes to sleep, give at least 30s for a cold start)https://github.com/tofran/fastapi-htmx-full-text-search-demo/assets/5692603/43d642fd-52d5-4e5b-836a-6609d0c3d782
The outcome of this project is something very simple and minimal. The served content is **tiny** and
**fast**. There's no initial loading, everything is pre-rendered on the server, and each API request
renders HTML that is injected into the DOM - no need for Hydration, Resumability nor even data
serialization. It is compatible with most browsers, all the way back to IE11, where it struggles a
little with style, but *works*.![OpenAPI spec (swagger)](https://github.com/tofran/fastapi-htmx-full-text-search-demo/assets/5692603/541f1f1a-fe1d-475c-8723-8f5a13e8f0df)
The application works by serving a full rendered Jinja HTML template when the user navigates to a
Front-End route.
These templates are composed via smaller reusable templates (using `include`).
And then the templates (*components*) are also served, de-coupled from the whole page in the
*HTML API* (`/html-api/...`).
HTMX handles the rest, listens to DOM events and updates it when when necessary.![Example HTML API request/response](https://github.com/tofran/fastapi-htmx-full-text-search-demo/assets/5692603/8e1aa2a0-53dd-443a-a1d2-caee11cad65c)
## Development
- Create a `.env` file based on the `.env.template`.
You will need an Algolia account, more info in their
[Quick start guide](https://www.algolia.com/doc/guides/getting-started/quick-start/).
More information about the env vars can be found in `./text_search_app/config.py`- Setup a local environment with `make setup-venv`,
activate it with `source ./venv/bin/activate`
(or with your favourite tool).
- Install dependencies: `make install-dev`.- Start the development server: `make dev`.
## Deployment
For deployment one would use the `./Dockerfile` and set the required environment variables.
For running locally a production like build, install the dependencies with `make install`
and run the application with `make start`. That's it.## Uploading a dataset
To keep this repository clean, no sample data is provided.
You can upload your own data via the `/index/upload-csv` endpoint.
Information about the supported CSV columns available in the Swagger UI (`/docs`).Recommended datasets (adapt column names when needed):
- [Zara Products on Kaggle](https://www.kaggle.com/datasets/maparla/zara-products)
- [Amazon Products Dataset 2023 on Kaggle](https://www.kaggle.com/datasets/asaniczka/amazon-products-dataset-2023-1-4m-products/)## License
MIT