Try out Vison!
- 🖥️ Modern UI: Clean, beginner-friendly interface for effortless JSON editing and viewing.
- 🪄 Non-technical Friendly: Vison is a web application designed to help non-technical individuals easily view, edit and JSON data.
- 📊 Table & Tree Views: Instantly switch between table and tree views for simple or deeply nested JSON.
- 📝 Direct Editing: Edit JSON values directly in the table or tree view.
- 📥 Download: Export your edited JSON as a file with a single click.
- 📄 Copy to Clipboard: Copy formatted JSON to your clipboard instantly.
- 🔐 Secure Share: End-to-end encrypted sharing, your data is encrypted in your browser, and only those with your unique link can access it.
- ⏳ Expiring Links: Shared links expire after 30 minutes for extra privacy.
- ☁️ Supabase Integration: Secure Share feature uses Supabase for backend storage (bring your own keys).
Note
Vison is currently in Beta. You might encounter bugs (most of the codebase was vibe-coded). Feel free to open an issue or submit a pull request.
- Node.js (LTS version recommended)
- Vite
- TypeScript
- React
- shadcn-ui
- Tailwind CSS
- Clone the repository:
git clone https://github.com/wazeerc/vison.git
cd vison- Install dependencies:
npm install- Set up environment variables:
Copy the example environment file and configure your Supabase credentials:
cp .env.example .envEdit the .env file with your actual Supabase credentials (see Supabase Setup below).
- Run the development server:
npm run devThe application will be available at http://localhost:8080.
To use the Secure Share feature, you need a free Supabase account.
- Create a Supabase project and get your Project URL and anon key from the API settings.
- Copy .env.exampleto.envand update with your credentials:
VITE_SUPABASE_URL=https://your-project.supabase.co
VITE_SUPABASE_KEY=your-anon-key- Create the table in the SQL editor:
CREATE TABLE IF NOT EXISTS vison (
    id uuid PRIMARY KEY DEFAULT gen_random_uuid(),
    json jsonb NOT NULL,
    created_at timestamp with time zone DEFAULT timezone('utc', now())
  );
  CREATE INDEX IF NOT EXISTS idx_vison_created_at ON vison(created_at);- Optional: Set up automatic cleanup (Edge Function or cron) to delete rows older than 30 minutes:
DELETE FROM vison WHERE created_at < NOW() - INTERVAL '30 minutes';Note: In the current implementation, the Supabase table is cleared every 24 hours using a cron job which invokes an Edge Function.
Found a bug or have a feature request? Please check the issues page or open a new one. Pull requests are also welcome!
Important
Please make sure to follow the code style and guidelines in the CODE_STYLE.md file. Run npm run fix to format your code before submitting a PR.