spree_multi_vendor 2.3.0 → 2.4.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +25 -25
- data/app/controllers/spree/api/v1/vendors_controller.rb +1 -1
- data/app/controllers/spree_multi_vendor/spree/api/base_controller_decorator.rb +2 -2
- data/app/controllers/spree_multi_vendor/spree/api/v1/products_controller_decorator.rb +1 -1
- data/app/controllers/spree_multi_vendor/spree/api/v1/users_controller_decorator.rb +1 -1
- data/app/helpers/spree_multi_vendor/spree/api/api_helpers_decorator.rb +1 -1
- data/app/models/spree/vendor.rb +1 -1
- data/app/models/spree_multi_vendor/spree/variant_decorator.rb +0 -1
- data/app/overrides/spree/admin/shared/_main_menu.rb +1 -18
- data/app/overrides/spree/admin/users/_form.rb +1 -1
- data/app/views/spree/admin/vendors/index.html.erb +2 -2
- data/config/initializers/spree_permitted_attributes.rb +0 -2
- data/config/locales/en.yml +1 -0
- data/config/locales/es.yml +1 -0
- data/config/locales/fr.yml +1 -0
- data/db/migrate/20210728120910_change_vendor_id_and_user_id_type_for_spree_vendor_users.rb +7 -1
- data/db/migrate/20210728121024_change_vendor_id_and_order_id_type_for_spree_order_commissions.rb +7 -1
- data/lib/spree_multi_vendor/configuration.rb +27 -0
- data/lib/spree_multi_vendor/engine.rb +10 -0
- data/lib/spree_multi_vendor/version.rb +1 -1
- data/lib/spree_multi_vendor.rb +1 -0
- metadata +6 -6
- data/app/models/spree_multi_vendor/configuration.rb +0 -10
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 956455a7ff13df68945b50b576880f345e2dbd4f5c4c32dc99420f0a1c5698e7
|
4
|
+
data.tar.gz: 8daf1f4488fad039a96e4c43a2211521d5b15297c5e628f018368d38fca70121
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 6b10eaa1316ee480d4b8b2e456e1648b3da2b01561effa253c65671de1963e3cb7369c1a061a4a298d443f5be4c018a7d9fff45d0a0514a2115f17f400f4fbf6
|
7
|
+
data.tar.gz: ad4aac2625a258d534c9fa553a8261907601443a53859ef55e4e76523c6868c59083dac7904026741dc040b3b80b1da42a6aca9e35060fe82f17579ad111f0af
|
data/README.md
CHANGED
@@ -1,30 +1,31 @@
|
|
1
1
|
# Spree Multi Vendor
|
2
2
|
|
3
|
-
[
|
3
|
+
This is a spree [multi vendor marketplace](https://getvendo.com) extension. It's a great starting point if you're building a marketplace on top of [Spree](https://spreecommerce.org). Our goal was flexibility to allow you to tweak it to your needs.
|
4
4
|
|
5
|
-
|
5
|
+
## Developed by
|
6
6
|
|
7
|
-
|
7
|
+
[![Vendo](https://assets-global.website-files.com/6230c485f2c32ea1b0daa438/623372f40a8c54ca9aea34e8_vendo%202.svg)](https://getvendo.com?utm_source=spree_multi_vendor_github)
|
8
8
|
|
9
|
-
|
9
|
+
> All-in-one platform for all your multi-vendor Marketplace needs. [Get your free account](https://app.getvendo.com/users/new?utm_source=spree_multi_vendor_github)
|
10
10
|
|
11
|
-
|
11
|
+
## Open source vs Vendo
|
12
12
|
|
13
|
-
|
13
|
+
If you need a product that has all of the features out of the box, such us supplier onboarding, Stripe connect payment splitting and payouts, and don't require any custom development - we recommend using [Vendo](https://app.getvendo.com/users/new?utm_source=spree_multi_vendor_github).
|
14
14
|
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
15
|
+
| feature | open source | [vendo] |
|
16
|
+
|---|---|---|
|
17
|
+
| basic vendorization | ✔️ | ✔️ |
|
18
|
+
| supplier onboarding | | ✔️ |
|
19
|
+
| supplier dashboard | | ✔️ |
|
20
|
+
| supplier management | | ✔️ |
|
21
|
+
| supplier product curation | | ✔️ |
|
22
|
+
| automatic payment splitting | | ✔️ |
|
23
|
+
| automatic payouts | | ✔️ |
|
24
|
+
| Afterpay / klarna / apple pay | | ✔️ |
|
25
|
+
| shopify / bigcommerce / woocommerce integration | | ✔️ |
|
26
|
+
| USPS, UPS, FedEx, DHL, and more | | ✔️ |
|
27
|
+
| bulk upload / import of products from CSV and XSLX | | ✔️ |
|
28
|
+
| bulk export of orders, shipments and more | | ✔️ |
|
28
29
|
|
29
30
|
## Installation
|
30
31
|
|
@@ -165,13 +166,12 @@ and may be redistributed under the terms specified in the
|
|
165
166
|
|
166
167
|
[LICENSE]: https://github.com/spark-solutions/spree_braintree_vzero/blob/master/LICENSE
|
167
168
|
|
168
|
-
## About
|
169
|
+
## About Vendo
|
169
170
|
|
170
|
-
[
|
171
|
+
> [Vendo][vendo] is a great fit for marketplaces of all sizes - either with own fulfillment and multiple warehouses or in a dropshipping model. Vendo **automates everything** from **vendor onboarding**, accepting buyer **payments in over 135 currencies**, to supplier **payouts in 50 countries**.
|
171
172
|
|
172
|
-
|
173
|
+
> Vendo ensures excellent buyer experience with smooth product discovery and search, a multitude of payment methods and optimal shipping cost calculation. Vendo keeps suppliers happy with easy onboarding, automated products sync using their preferred method and easy payouts.
|
173
174
|
|
174
|
-
|
175
|
-
We are [available for hire][spark].
|
175
|
+
> [Get your free account](https://app.getvendo.com/users/new?utm_source=spree_multi_vendor_github)
|
176
176
|
|
177
|
-
[
|
177
|
+
[vendo]:https://app.getvendo.com/users/new?utm_source=spree_multi_vendor_github
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module SpreeMultiVendor::Spree::Api::BaseControllerDecorator
|
2
|
-
Spree::Api::BaseController.include(Spree::Api::VendorHelper)
|
2
|
+
Spree::Api::V1::BaseController.include(Spree::Api::VendorHelper) if SpreeMultiVendor::Engine.api_v1_available?
|
3
3
|
|
4
4
|
def self.prepended(base)
|
5
5
|
base.helper_method :current_spree_vendor
|
@@ -14,4 +14,4 @@ module SpreeMultiVendor::Spree::Api::BaseControllerDecorator
|
|
14
14
|
end
|
15
15
|
end
|
16
16
|
|
17
|
-
::Spree::Api::BaseController.prepend SpreeMultiVendor::Spree::Api::BaseControllerDecorator
|
17
|
+
::Spree::Api::V1::BaseController.prepend SpreeMultiVendor::Spree::Api::BaseControllerDecorator if SpreeMultiVendor::Engine.api_v1_available?
|
@@ -6,4 +6,4 @@ module SpreeMultiVendor::Spree::Api::V1::ProductsControllerDecorator
|
|
6
6
|
end
|
7
7
|
end
|
8
8
|
|
9
|
-
Spree::Api::V1::ProductsController.prepend SpreeMultiVendor::Spree::Api::V1::ProductsControllerDecorator
|
9
|
+
Spree::Api::V1::ProductsController.prepend SpreeMultiVendor::Spree::Api::V1::ProductsControllerDecorator if SpreeMultiVendor::Engine.api_v1_available?
|
@@ -10,4 +10,4 @@ module SpreeMultiVendor::Spree::Api::V1::UsersControllerDecorator
|
|
10
10
|
end
|
11
11
|
end
|
12
12
|
|
13
|
-
Spree::Api::V1::UsersController.prepend SpreeMultiVendor::Spree::Api::V1::UsersControllerDecorator
|
13
|
+
Spree::Api::V1::UsersController.prepend SpreeMultiVendor::Spree::Api::V1::UsersControllerDecorator if SpreeMultiVendor::Engine.api_v1_available?
|
data/app/models/spree/vendor.rb
CHANGED
@@ -61,7 +61,7 @@ module Spree
|
|
61
61
|
private
|
62
62
|
|
63
63
|
def create_stock_location
|
64
|
-
stock_locations.where(name: name, country: Spree::
|
64
|
+
stock_locations.where(name: name, country: Spree::Store.default.default_country).first_or_create!
|
65
65
|
end
|
66
66
|
|
67
67
|
def should_generate_new_friendly_id?
|
@@ -7,7 +7,6 @@ module SpreeMultiVendor::Spree::VariantDecorator
|
|
7
7
|
|
8
8
|
def vendor
|
9
9
|
@vendor ||= if self.class.reflect_on_association(:vendor) && self[:vendor_id].present?
|
10
|
-
product.vendor
|
11
10
|
::Spree::Vendor.unscoped.find(self[:vendor_id])
|
12
11
|
elsif Spree::Product.reflect_on_association(:vendor) && product.vendor_id.present?
|
13
12
|
product.vendor
|
@@ -3,21 +3,4 @@ Deface::Override.new(
|
|
3
3
|
name: 'Display configuration tab for vendors',
|
4
4
|
replace: 'erb[silent]:contains("current_store")',
|
5
5
|
text: '<% if can?(:admin, current_store) || current_spree_user&.vendors&.any? %>'
|
6
|
-
)
|
7
|
-
Deface::Override.new(
|
8
|
-
virtual_path: 'spree/admin/shared/_main_menu',
|
9
|
-
name: 'vendors_main_menu_tabs',
|
10
|
-
insert_bottom: 'nav',
|
11
|
-
text: <<-HTML
|
12
|
-
<% if current_spree_user.respond_to?(:has_spree_role?) && current_spree_user.has_spree_role?(:admin) %>
|
13
|
-
<ul class="nav nav-sidebar border-bottom">
|
14
|
-
<%= tab plural_resource_name(Spree::Vendor), url: admin_vendors_path, icon: 'money' %>
|
15
|
-
</ul>
|
16
|
-
<% end %>
|
17
|
-
<% if defined?(current_spree_vendor) && current_spree_vendor %>
|
18
|
-
<ul class="nav nav-sidebar border-bottom">
|
19
|
-
<%= tab Spree::Vendor.model_name.human, url: admin_vendor_settings_path, icon: 'money' %>
|
20
|
-
</ul>
|
21
|
-
<% end %>
|
22
|
-
HTML
|
23
|
-
)
|
6
|
+
)
|
@@ -5,7 +5,7 @@ Deface::Override.new(
|
|
5
5
|
text: <<-HTML
|
6
6
|
<% if current_spree_user.respond_to?(:has_spree_role?) && current_spree_user.has_spree_role?(:admin) %>
|
7
7
|
<%= f.field_container :vendor_ids, class: ['form-group'] do %>
|
8
|
-
<%= f.label :vendor_ids,
|
8
|
+
<%= f.label :vendor_ids, plural_resource_name(Spree::Vendor) %>
|
9
9
|
<%= f.collection_select(:vendor_ids, Spree::Vendor.all, :id, :name, { }, { class: 'select2', multiple: true }) %>
|
10
10
|
<% end %>
|
11
11
|
<% end %>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
<% content_for :page_title do %>
|
2
|
-
<%=
|
2
|
+
<%= plural_resource_name(Spree::Vendor) %>
|
3
3
|
<% end %>
|
4
4
|
|
5
5
|
<% content_for :page_actions do %>
|
@@ -33,7 +33,7 @@
|
|
33
33
|
<%= render partial: 'spree/admin/shared/index_table_options', locals: { collection: @collection } %>
|
34
34
|
|
35
35
|
<% if @vendors.any? %>
|
36
|
-
<table class="table sortable" data-hook="vendors_table" data-sortable-link="<%= update_positions_admin_vendors_url %>">
|
36
|
+
<table class="table border rounded sortable" data-hook="vendors_table" data-sortable-link="<%= update_positions_admin_vendors_url %>">
|
37
37
|
<thead>
|
38
38
|
<tr data-hook="vendors_header">
|
39
39
|
<th>
|
@@ -6,7 +6,5 @@ module Spree
|
|
6
6
|
|
7
7
|
@@vendor_attributes = [:name, :about_us, :contact_us, :notification_email]
|
8
8
|
@@vendor_attributes << :image if Spree.version.to_f >= 3.6
|
9
|
-
|
10
|
-
@@product_attributes << :vendor_id if SpreeMultiVendor::Config[:vendorized_models].include?('product')
|
11
9
|
end
|
12
10
|
end
|
data/config/locales/en.yml
CHANGED
data/config/locales/es.yml
CHANGED
data/config/locales/fr.yml
CHANGED
@@ -1,8 +1,14 @@
|
|
1
1
|
class ChangeVendorIdAndUserIdTypeForSpreeVendorUsers < ActiveRecord::Migration[4.2]
|
2
|
-
def
|
2
|
+
def up
|
3
3
|
change_table(:spree_vendor_users) do |t|
|
4
4
|
t.change :vendor_id, :bigint
|
5
5
|
t.change :user_id, :bigint
|
6
6
|
end
|
7
7
|
end
|
8
|
+
def down
|
9
|
+
change_table(:spree_vendor_users) do |t|
|
10
|
+
t.change :vendor_id, :integer
|
11
|
+
t.change :user_id, :integer
|
12
|
+
end
|
13
|
+
end
|
8
14
|
end
|
data/db/migrate/20210728121024_change_vendor_id_and_order_id_type_for_spree_order_commissions.rb
CHANGED
@@ -1,8 +1,14 @@
|
|
1
1
|
class ChangeVendorIdAndOrderIdTypeForSpreeOrderCommissions < ActiveRecord::Migration[4.2]
|
2
|
-
def
|
2
|
+
def up
|
3
3
|
change_table(:spree_order_commissions) do |t|
|
4
4
|
t.change :vendor_id, :bigint
|
5
5
|
t.change :order_id, :bigint
|
6
6
|
end
|
7
7
|
end
|
8
|
+
def down
|
9
|
+
change_table(:spree_order_commissions) do |t|
|
10
|
+
t.change :vendor_id, :integer
|
11
|
+
t.change :order_id, :integer
|
12
|
+
end
|
13
|
+
end
|
8
14
|
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
module SpreeMultiVendor
|
2
|
+
class Configuration
|
3
|
+
DEFAULT_VENDORIZED_MODELS ||= %w[product variant stock_location shipping_method].freeze
|
4
|
+
|
5
|
+
attr_accessor :vendorized_models
|
6
|
+
|
7
|
+
def initialize
|
8
|
+
self.vendorized_models = DEFAULT_VENDORIZED_MODELS
|
9
|
+
end
|
10
|
+
|
11
|
+
def configure
|
12
|
+
yield(self) if block_given?
|
13
|
+
end
|
14
|
+
|
15
|
+
def get(preference)
|
16
|
+
send(preference)
|
17
|
+
end
|
18
|
+
|
19
|
+
alias [] get
|
20
|
+
|
21
|
+
def set(preference, value)
|
22
|
+
send("#{preference}=", value)
|
23
|
+
end
|
24
|
+
|
25
|
+
alias []= set
|
26
|
+
end
|
27
|
+
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
require_relative 'configuration'
|
2
|
+
|
1
3
|
module SpreeMultiVendor
|
2
4
|
class Engine < Rails::Engine
|
3
5
|
require 'spree/core'
|
@@ -13,12 +15,20 @@ module SpreeMultiVendor
|
|
13
15
|
SpreeMultiVendor::Config = SpreeMultiVendor::Configuration.new
|
14
16
|
end
|
15
17
|
|
18
|
+
config.after_initialize do
|
19
|
+
::Spree::PermittedAttributes.product_attributes << :vendor_id if SpreeMultiVendor::Config[:vendorized_models].include?('product')
|
20
|
+
end
|
21
|
+
|
16
22
|
def self.activate
|
17
23
|
Dir.glob(File.join(File.dirname(__FILE__), '../../app/**/*_decorator*.rb')) do |c|
|
18
24
|
Rails.configuration.cache_classes ? require(c) : load(c)
|
19
25
|
end
|
20
26
|
end
|
21
27
|
|
28
|
+
def self.api_v1_available?
|
29
|
+
@@api_v1_available ||= Gem::Specification.find_all_by_name('spree_api_v1').any?
|
30
|
+
end
|
31
|
+
|
22
32
|
config.to_prepare &method(:activate).to_proc
|
23
33
|
end
|
24
34
|
end
|
data/lib/spree_multi_vendor.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: spree_multi_vendor
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.4.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Spark Solutions
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-11-14 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: spree
|
@@ -148,7 +148,6 @@ files:
|
|
148
148
|
- app/models/spree/vendor_image.rb
|
149
149
|
- app/models/spree/vendor_order_totals.rb
|
150
150
|
- app/models/spree/vendor_user.rb
|
151
|
-
- app/models/spree_multi_vendor/configuration.rb
|
152
151
|
- app/models/spree_multi_vendor/spree/ability_decorator.rb
|
153
152
|
- app/models/spree_multi_vendor/spree/base_decorator.rb
|
154
153
|
- app/models/spree_multi_vendor/spree/line_item_decorator.rb
|
@@ -209,6 +208,7 @@ files:
|
|
209
208
|
- lib/generators/spree_multi_vendor/mailers_preview/mailers_preview_generator.rb
|
210
209
|
- lib/generators/spree_multi_vendor/mailers_preview/templates/mailers/previews/vendor_notification_preview.rb
|
211
210
|
- lib/spree_multi_vendor.rb
|
211
|
+
- lib/spree_multi_vendor/configuration.rb
|
212
212
|
- lib/spree_multi_vendor/engine.rb
|
213
213
|
- lib/spree_multi_vendor/factories.rb
|
214
214
|
- lib/spree_multi_vendor/version.rb
|
@@ -250,9 +250,9 @@ licenses:
|
|
250
250
|
- BSD-3-Clause
|
251
251
|
metadata:
|
252
252
|
bug_tracker_uri: https://github.com/spree-contrib/spree_multi_vendor/issues
|
253
|
-
changelog_uri: https://github.com/spree-contrib/spree_multi_vendor/releases/tag/v2.
|
253
|
+
changelog_uri: https://github.com/spree-contrib/spree_multi_vendor/releases/tag/v2.4.1
|
254
254
|
documentation_uri: https://guides.spreecommerce.org/
|
255
|
-
source_code_uri: https://github.com/spree-contrib/spree_multi_vendor/tree/v2.
|
255
|
+
source_code_uri: https://github.com/spree-contrib/spree_multi_vendor/tree/v2.4.1
|
256
256
|
post_install_message:
|
257
257
|
rdoc_options: []
|
258
258
|
require_paths:
|
@@ -269,7 +269,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
269
269
|
version: '0'
|
270
270
|
requirements:
|
271
271
|
- none
|
272
|
-
rubygems_version: 3.
|
272
|
+
rubygems_version: 3.4.1
|
273
273
|
signing_key:
|
274
274
|
specification_version: 4
|
275
275
|
summary: Spree Commerce multi vendor marketplace extension
|
@@ -1,10 +0,0 @@
|
|
1
|
-
module SpreeMultiVendor
|
2
|
-
class Configuration < ::Spree::Preferences::Configuration
|
3
|
-
DEFAULT_VENDORIZED_MODELS ||= %w[product variant stock_location shipping_method].freeze
|
4
|
-
|
5
|
-
# Some example preferences are shown below, for more information visit:
|
6
|
-
# https://guides.spreecommerce.org/developer/core/preferences.html
|
7
|
-
|
8
|
-
preference :vendorized_models, :array, default: DEFAULT_VENDORIZED_MODELS
|
9
|
-
end
|
10
|
-
end
|