A fresh take on an Admin UI for Spree, this is currently intended to be highly experimental and should not be used for production.
Spree Admin is free of legacy dependencies and constraints, the goal is to speed up development and find new intuitive ways of using Spree Admin while completely modernizing the tech stack for the developers happiness.
- Product Images can be tagged to their applicable option(s).
- New order process, more akin to building an invoice than attempting to replicate a shopping cart in an admin UI (WIP).
- Modern UI (WIP).
- Adaptive Light/Dark modes.
Starting with a freshly generated Rails 7 app running Propshaft, add the following gems to your Gemfile:
# USE THESE FOR NOW...
gem 'spree', github: 'MatthewKennedy/spree', branch: 'custom/spree_admin'
gem 'spree_admin', github: 'MatthewKennedy/spree_admin', branch: 'main'
gem 'spree_auth_devise', github: 'MatthewKennedy/spree_auth_devise', branch: 'custom/spree_admin'
From the command line run the following commands:
Install Spree
bin/rails g spree:install --user_class=Spree::User
Install Spree Auth Devise
bin/rails g spree:auth:install
If you are using NPM to manage your javascript and want to import the javascript via node_modules run:
yarn add @matthewkennedy/spree-admin
And then create a new file in app/javascript
called spree_admin.js
and then import import '@matthewkennedy/spree-admin'
.
- All ES6 Vanilla JavaScript.
- CSS and images all set for Rails Propshaft.
- Uses the Rails Hotwire ecosystem where possible.
- Bootstrap 5.
From the root of spree_admin
run:
yarn watch
cd spree_admin
bundle update
yarn build
bundle exec rake test_app
bundle exec rspec
Single test file:
bundle exec rspec spec/features/admin/users_spec.rb
ChromeDriver is required for feature tests. On MacOS you can install it by running:
brew install chromedriver