Store Tracker v2 — React + Vite + Tailwind frontend
Find a file
Maddox 7152d6b492 Replace tag text input with autocomplete tag picker
TagInput component shows selected tags as removable chips, autocompletes
from existing tags in the database, and allows adding new tags inline.
Enter/comma to confirm, Backspace to remove last tag.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-07 18:20:47 -04:00
public Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
src Replace tag text input with autocomplete tag picker 2026-04-07 18:20:47 -04:00
.gitignore Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
Dockerfile Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
eslint.config.js Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
index.html Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
nginx.conf Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
package-lock.json Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
package.json Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
README.md Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
tsconfig.app.json Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
tsconfig.json Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
tsconfig.node.json Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00
vite.config.ts Initial commit — Store Tracker v2 frontend 2026-04-06 20:40:08 -04:00

React + TypeScript + Vite

This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.

Currently, two official plugins are available:

React Compiler

The React Compiler is not enabled on this template because of its impact on dev & build performances. To add it, see this documentation.

Expanding the ESLint configuration

If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:

export default defineConfig([
  globalIgnores(['dist']),
  {
    files: ['**/*.{ts,tsx}'],
    extends: [
      // Other configs...

      // Remove tseslint.configs.recommended and replace with this
      tseslint.configs.recommendedTypeChecked,
      // Alternatively, use this for stricter rules
      tseslint.configs.strictTypeChecked,
      // Optionally, add this for stylistic rules
      tseslint.configs.stylisticTypeChecked,

      // Other configs...
    ],
    languageOptions: {
      parserOptions: {
        project: ['./tsconfig.node.json', './tsconfig.app.json'],
        tsconfigRootDir: import.meta.dirname,
      },
      // other options...
    },
  },
])

You can also install eslint-plugin-react-x and eslint-plugin-react-dom for React-specific lint rules:

// eslint.config.js
import reactX from 'eslint-plugin-react-x'
import reactDom from 'eslint-plugin-react-dom'

export default defineConfig([
  globalIgnores(['dist']),
  {
    files: ['**/*.{ts,tsx}'],
    extends: [
      // Other configs...
      // Enable lint rules for React
      reactX.configs['recommended-typescript'],
      // Enable lint rules for React DOM
      reactDom.configs.recommended,
    ],
    languageOptions: {
      parserOptions: {
        project: ['./tsconfig.node.json', './tsconfig.app.json'],
        tsconfigRootDir: import.meta.dirname,
      },
      // other options...
    },
  },
])