Create a product which is composed of other products.
Add the following line to your Gemfile
:
gem 'solidus_product_assembly', github: 'solidusio-contrib/solidus_product_assembly', branch: 'master'
Run bundle install as well as the extension intall command to copy and run migrations and append solidus_product_assembly to your js manifest file:
bundle install
rails g solidus_product_assembly:install
To build a bundle (assembly product) you'd need to first check the "Can be part" flag on each product you want to be part of the bundle. Then create a product and add parts to it. By doing that you're making that product an assembly.
The store will treat assemblies a bit different than regular products on checkout. Spree will create and track inventory units for its parts rather than for the product itself. That means you essentially have a product composed of other products. From a customer perspective it's like they are paying a single amount for a collection of products.
We use gem-release to release this extension with ease.
Supposing you are on the master branch and you are working on a fork of this
extension, upstream
is the main remote and you have write access to it, you
can simply run:
gem bump --version minor --tag --release
This command will:
- bump the gem version to the next minor (changing the
version.rb
file) - commit the change and push it to upstream master
- create a git tag
- push the tag to the upstream remote
- release the new version on RubyGems
Or you can run these commands individually:
gem bump --version minor
gem tag
gem release
After the release is done we can generate the updated CHANGELOG using github-changelog-generator by running the following command:
bundle exec github_changelog_generator solidusio/solidus_auth_devise --token YOUR_GITHUB_TOKEN
git commit -am 'Update CHANGELOG'
git push upstream master
Spree is an open source project and we encourage contributions. Please see the Community Guidelines before contributing.
In the spirit of free software, everyone is encouraged to help improve this project.
Here are some ways you can contribute:
- by using prerelease versions
- by reporting bugs
- by suggesting new features
- by writing translations
- by writing or editing documentation
- by writing specifications
- by writing code (no patch is too small: fix typos, add comments, clean up inconsistent whitespace)
- by refactoring code
- by resolving issues
- by reviewing patches
Starting point:
- Fork the repo
- Clone your repo
- Run
bundle install
- Run
bundle exec rake test_app
to create the test application inspec/test_app
- Make your changes
- Ensure specs pass by running
bundle exec rspec spec
- Submit your pull request
Copyright (c) 2014 Spree Commerce Inc. and contributors, released under the New BSD License