mirror of
https://github.com/openfoodfoundation/openfoodnetwork
synced 2026-02-28 01:53:25 +00:00
Compare commits
192 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c13785f2e3 | ||
|
|
0c0304b1c1 | ||
|
|
7922bf7b65 | ||
|
|
2d46676bb4 | ||
|
|
2808a41f0d | ||
|
|
18869979db | ||
|
|
708dbb2270 | ||
|
|
83ec97e720 | ||
|
|
c0b6f26338 | ||
|
|
f6c426ef17 | ||
|
|
0a42f15c25 | ||
|
|
95412bd203 | ||
|
|
81aac877a5 | ||
|
|
2330c7cfc2 | ||
|
|
68c7d8f9f5 | ||
|
|
cf3175c16e | ||
|
|
85c903cb7f | ||
|
|
ebd7b0b24d | ||
|
|
78cf0434d6 | ||
|
|
74e7e9b17b | ||
|
|
2b32d53911 | ||
|
|
2cff5bc4df | ||
|
|
1dbcddf799 | ||
|
|
702db32595 | ||
|
|
d770049d2d | ||
|
|
424e25f83e | ||
|
|
ce12bc4dbc | ||
|
|
9d79119eb0 | ||
|
|
f2eec5685e | ||
|
|
8aac400c14 | ||
|
|
f31976a3a4 | ||
|
|
0bb2c867e0 | ||
|
|
cd68ddc34f | ||
|
|
98775bfdb8 | ||
|
|
47ef21deb3 | ||
|
|
f80b484b12 | ||
|
|
b455755bfc | ||
|
|
1f7c08bbb0 | ||
|
|
fcb9439cd2 | ||
|
|
96c2b75a0a | ||
|
|
b6438992b9 | ||
|
|
69108df206 | ||
|
|
c66b9611b6 | ||
|
|
de873ae42c | ||
|
|
ed701b00dc | ||
|
|
52e2fb923e | ||
|
|
a2a9d32c5b | ||
|
|
619ecf9432 | ||
|
|
4f152a9151 | ||
|
|
8d7252f078 | ||
|
|
08399e753d | ||
|
|
8d721ccac8 | ||
|
|
b7a1b39c1a | ||
|
|
e276fb0386 | ||
|
|
e98244fe63 | ||
|
|
b348536d12 | ||
|
|
b528bb47a0 | ||
|
|
f86eb3fb82 | ||
|
|
0d46a3bc2e | ||
|
|
0418163ad7 | ||
|
|
2e67899bcc | ||
|
|
e2536ffe71 | ||
|
|
2c6b758f66 | ||
|
|
fb0f379c43 | ||
|
|
7a4aa9dcb1 | ||
|
|
4e8d37b0b5 | ||
|
|
616de3a9c0 | ||
|
|
16b3da66c2 | ||
|
|
691995eeaa | ||
|
|
045482e07d | ||
|
|
62f25d4d31 | ||
|
|
618c7028e2 | ||
|
|
13cec27f6b | ||
|
|
5b925517f0 | ||
|
|
167099badf | ||
|
|
40d8839bc4 | ||
|
|
da1e1a9859 | ||
|
|
43ad7654b6 | ||
|
|
1d4bbfa506 | ||
|
|
15d83724ea | ||
|
|
47652e9d25 | ||
|
|
4b689d00a4 | ||
|
|
b5315c2123 | ||
|
|
97ce4eaccd | ||
|
|
8814427677 | ||
|
|
4b69e192ec | ||
|
|
9c99f4868c | ||
|
|
39d59c3a5f | ||
|
|
ad9a12da0e | ||
|
|
9968776726 | ||
|
|
d99a88817d | ||
|
|
1b36cce816 | ||
|
|
4b157abd4d | ||
|
|
dc494bb0f9 | ||
|
|
b3e7b12b86 | ||
|
|
b69e6827cc | ||
|
|
340f459912 | ||
|
|
33a96d5a0f | ||
|
|
93d6db9d44 | ||
|
|
c1068af0ba | ||
|
|
482c2a4a6e | ||
|
|
2557a4de39 | ||
|
|
ab1f43f1ac | ||
|
|
f921524588 | ||
|
|
5cbd507c1e | ||
|
|
532bfaaa2d | ||
|
|
70b31a4212 | ||
|
|
9da3b0ea01 | ||
|
|
51df612c51 | ||
|
|
3be0cca230 | ||
|
|
283d13eb35 | ||
|
|
b21224d5ff | ||
|
|
4744d7b741 | ||
|
|
ac1dd74e23 | ||
|
|
970f486ec0 | ||
|
|
8c244e8b56 | ||
|
|
c3cc01c677 | ||
|
|
c63e60d782 | ||
|
|
11e8c9456d | ||
|
|
860a21f86f | ||
|
|
d24af18ff4 | ||
|
|
33b191f439 | ||
|
|
a690d39864 | ||
|
|
7c0586db7b | ||
|
|
461fd00ccd | ||
|
|
d33cabd6b2 | ||
|
|
7b21a9d30f | ||
|
|
c00e7eeecf | ||
|
|
afdb044386 | ||
|
|
b98552003c | ||
|
|
38f1754738 | ||
|
|
f872201fef | ||
|
|
ad23735384 | ||
|
|
6fd78d4647 | ||
|
|
cd3a80c502 | ||
|
|
f8c88ea8c7 | ||
|
|
4ba55c4067 | ||
|
|
813249bad7 | ||
|
|
162c58ac39 | ||
|
|
02d47d0a0d | ||
|
|
e86bf441ab | ||
|
|
f9617b8156 | ||
|
|
4650e30c09 | ||
|
|
2749965e73 | ||
|
|
e87965bda0 | ||
|
|
9f2c35d407 | ||
|
|
79af9efd29 | ||
|
|
9dcb3ec748 | ||
|
|
90c23d0245 | ||
|
|
99e238d92d | ||
|
|
b731f9b9e4 | ||
|
|
da90cdd9f6 | ||
|
|
f86c925209 | ||
|
|
0040e4d454 | ||
|
|
876d37d19a | ||
|
|
36d617bceb | ||
|
|
7c0528ad83 | ||
|
|
f25d51e772 | ||
|
|
8eb9709a04 | ||
|
|
5f31baa022 | ||
|
|
c115ab7a0d | ||
|
|
f3428494fc | ||
|
|
d748972fca | ||
|
|
b9c7925008 | ||
|
|
c11b93a4dc | ||
|
|
61e0688392 | ||
|
|
5971cdc6e2 | ||
|
|
b3a1d1269a | ||
|
|
a0011bd2e9 | ||
|
|
5e57325ce2 | ||
|
|
cd956dadda | ||
|
|
e6d556c809 | ||
|
|
f35b2be228 | ||
|
|
cc9cb966b5 | ||
|
|
34f9e08824 | ||
|
|
7d5db81017 | ||
|
|
1b03528aca | ||
|
|
9a90e46b78 | ||
|
|
b58834b11f | ||
|
|
d4811648f1 | ||
|
|
77fe1fa6f9 | ||
|
|
30804da259 | ||
|
|
1e2b8bad3f | ||
|
|
88a0737916 | ||
|
|
f5823bd618 | ||
|
|
d9453979b1 | ||
|
|
2cde74b91a | ||
|
|
3fd007fa3d | ||
|
|
e3431c7954 | ||
|
|
9fa715c709 | ||
|
|
03b7c07495 | ||
|
|
a3c08ceb7c |
4
.github/dependabot.yml
vendored
4
.github/dependabot.yml
vendored
@@ -31,6 +31,8 @@ updates:
|
|||||||
directory: "/"
|
directory: "/"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
|
cooldown:
|
||||||
|
default-days: 7
|
||||||
|
|
||||||
# Only specific requirements are specified in Gemfile, so don't touch it.
|
# Only specific requirements are specified in Gemfile, so don't touch it.
|
||||||
versioning-strategy: lockfile-only
|
versioning-strategy: lockfile-only
|
||||||
@@ -39,6 +41,8 @@ updates:
|
|||||||
directory: "/"
|
directory: "/"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
|
cooldown:
|
||||||
|
default-days: 7
|
||||||
|
|
||||||
# Only specific requirements are specified in package.json, so don't touch it.
|
# Only specific requirements are specified in package.json, so don't touch it.
|
||||||
versioning-strategy: lockfile-only
|
versioning-strategy: lockfile-only
|
||||||
|
|||||||
8
.github/workflows/build.yml
vendored
8
.github/workflows/build.yml
vendored
@@ -46,7 +46,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup redis
|
- name: Setup redis
|
||||||
uses: supercharge/redis-github-action@1.4.0
|
uses: supercharge/redis-github-action@1.8.1
|
||||||
with:
|
with:
|
||||||
redis-version: 6
|
redis-version: 6
|
||||||
|
|
||||||
@@ -124,7 +124,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup redis
|
- name: Setup redis
|
||||||
uses: supercharge/redis-github-action@1.4.0
|
uses: supercharge/redis-github-action@1.8.1
|
||||||
with:
|
with:
|
||||||
redis-version: 6
|
redis-version: 6
|
||||||
|
|
||||||
@@ -211,7 +211,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup redis
|
- name: Setup redis
|
||||||
uses: supercharge/redis-github-action@1.4.0
|
uses: supercharge/redis-github-action@1.8.1
|
||||||
with:
|
with:
|
||||||
redis-version: 6
|
redis-version: 6
|
||||||
|
|
||||||
@@ -290,7 +290,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Setup redis
|
- name: Setup redis
|
||||||
uses: supercharge/redis-github-action@1.4.0
|
uses: supercharge/redis-github-action@1.8.1
|
||||||
with:
|
with:
|
||||||
redis-version: 6
|
redis-version: 6
|
||||||
|
|
||||||
|
|||||||
10
Gemfile
10
Gemfile
@@ -18,7 +18,7 @@ gem 'activemerchant'
|
|||||||
gem 'angular-rails-templates'
|
gem 'angular-rails-templates'
|
||||||
gem 'ransack', '~> 4.1.0'
|
gem 'ransack', '~> 4.1.0'
|
||||||
gem 'responders'
|
gem 'responders'
|
||||||
gem 'shakapacker', '7.2.3'
|
gem 'shakapacker', '8.4.0'
|
||||||
|
|
||||||
# Indirect dependency but we access it directly in JS specs.
|
# Indirect dependency but we access it directly in JS specs.
|
||||||
# It turns out to be hard to upgrade but please do if you can.
|
# It turns out to be hard to upgrade but please do if you can.
|
||||||
@@ -58,6 +58,7 @@ gem 'stringex', '~> 2.8.5', require: false
|
|||||||
|
|
||||||
gem 'paypal-sdk-merchant', '1.117.2'
|
gem 'paypal-sdk-merchant', '1.117.2'
|
||||||
gem 'stripe', '~> 15'
|
gem 'stripe', '~> 15'
|
||||||
|
gem "taler"
|
||||||
|
|
||||||
gem 'devise'
|
gem 'devise'
|
||||||
gem 'devise-encryptable'
|
gem 'devise-encryptable'
|
||||||
@@ -111,7 +112,7 @@ gem "turbo_power"
|
|||||||
gem "turbo-rails"
|
gem "turbo-rails"
|
||||||
|
|
||||||
gem 'combine_pdf'
|
gem 'combine_pdf'
|
||||||
gem 'wicked_pdf'
|
gem 'wicked_pdf', github: "openfoodfoundation/wicked_pdf", branch: "master"
|
||||||
gem 'wkhtmltopdf-binary'
|
gem 'wkhtmltopdf-binary'
|
||||||
|
|
||||||
gem 'immigrant'
|
gem 'immigrant'
|
||||||
@@ -126,9 +127,8 @@ gem 'angular_rails_csrf'
|
|||||||
|
|
||||||
gem 'jquery-rails', '4.4.0'
|
gem 'jquery-rails', '4.4.0'
|
||||||
gem 'jquery-ui-rails', '~> 4.2'
|
gem 'jquery-ui-rails', '~> 4.2'
|
||||||
# TODO move away from sass-rails, master branch will get rid of dependency, so we can move to
|
gem "select2-rails", github: "openfoodfoundation/select2-rails",
|
||||||
# https://github.com/sass/embedded-host-node
|
branch: "v349_with-relaxed-dependencies"
|
||||||
gem "select2-rails", github: "openfoodfoundation/select2-rails", branch: "v349_with_thor_v1"
|
|
||||||
|
|
||||||
gem 'good_migrations'
|
gem 'good_migrations'
|
||||||
|
|
||||||
|
|||||||
174
Gemfile.lock
174
Gemfile.lock
@@ -10,13 +10,21 @@ GIT
|
|||||||
|
|
||||||
GIT
|
GIT
|
||||||
remote: https://github.com/openfoodfoundation/select2-rails.git
|
remote: https://github.com/openfoodfoundation/select2-rails.git
|
||||||
revision: fc240e85fbdf1878ff3c39d972c0cd9a312f5ed4
|
revision: 9693e0cc5b04938da46692d3fa83aa8934791981
|
||||||
branch: v349_with_thor_v1
|
branch: v349_with-relaxed-dependencies
|
||||||
specs:
|
specs:
|
||||||
select2-rails (3.4.9)
|
select2-rails (3.4.9)
|
||||||
sass-rails
|
|
||||||
thor (>= 0.14)
|
thor (>= 0.14)
|
||||||
|
|
||||||
|
GIT
|
||||||
|
remote: https://github.com/openfoodfoundation/wicked_pdf.git
|
||||||
|
revision: bce498de547cdf00d037fdbec29fae844d69ee8e
|
||||||
|
branch: master
|
||||||
|
specs:
|
||||||
|
wicked_pdf (2.8.1)
|
||||||
|
activesupport
|
||||||
|
ostruct
|
||||||
|
|
||||||
GIT
|
GIT
|
||||||
remote: https://github.com/podia/stimulus_reflex_testing.git
|
remote: https://github.com/podia/stimulus_reflex_testing.git
|
||||||
revision: abac2ee34de347c589795b4d1a8e83e0baafb201
|
revision: abac2ee34de347c589795b4d1a8e83e0baafb201
|
||||||
@@ -104,7 +112,7 @@ GEM
|
|||||||
rails-html-sanitizer (~> 1.6)
|
rails-html-sanitizer (~> 1.6)
|
||||||
active_model_serializers (0.8.4)
|
active_model_serializers (0.8.4)
|
||||||
activemodel (>= 3.0)
|
activemodel (>= 3.0)
|
||||||
active_storage_validations (3.0.2)
|
active_storage_validations (3.0.3)
|
||||||
activejob (>= 6.1.4)
|
activejob (>= 6.1.4)
|
||||||
activemodel (>= 6.1.4)
|
activemodel (>= 6.1.4)
|
||||||
activestorage (>= 6.1.4)
|
activestorage (>= 6.1.4)
|
||||||
@@ -202,12 +210,12 @@ GEM
|
|||||||
bigdecimal (3.3.1)
|
bigdecimal (3.3.1)
|
||||||
bindata (2.5.1)
|
bindata (2.5.1)
|
||||||
bindex (0.8.1)
|
bindex (0.8.1)
|
||||||
bootsnap (1.19.0)
|
bootsnap (1.22.0)
|
||||||
msgpack (~> 1.2)
|
msgpack (~> 1.2)
|
||||||
bugsnag (6.28.0)
|
bugsnag (6.28.0)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
builder (3.3.0)
|
builder (3.3.0)
|
||||||
bullet (8.0.8)
|
bullet (8.1.0)
|
||||||
activesupport (>= 3.0.0)
|
activesupport (>= 3.0.0)
|
||||||
uniform_notifier (~> 1.11)
|
uniform_notifier (~> 1.11)
|
||||||
cable_ready (5.0.6)
|
cable_ready (5.0.6)
|
||||||
@@ -234,7 +242,7 @@ GEM
|
|||||||
marcel (~> 1.0)
|
marcel (~> 1.0)
|
||||||
nokogiri (~> 1.10, >= 1.10.4)
|
nokogiri (~> 1.10, >= 1.10.4)
|
||||||
rubyzip (>= 1.3.0, < 3)
|
rubyzip (>= 1.3.0, < 3)
|
||||||
cgi (0.5.0)
|
cgi (0.5.1)
|
||||||
childprocess (5.0.0)
|
childprocess (5.0.0)
|
||||||
choice (0.2.0)
|
choice (0.2.0)
|
||||||
chronic (0.10.2)
|
chronic (0.10.2)
|
||||||
@@ -249,7 +257,7 @@ GEM
|
|||||||
combine_pdf (1.0.31)
|
combine_pdf (1.0.31)
|
||||||
matrix
|
matrix
|
||||||
ruby-rc4 (>= 0.1.5)
|
ruby-rc4 (>= 0.1.5)
|
||||||
concurrent-ruby (1.3.5)
|
concurrent-ruby (1.3.6)
|
||||||
connection_pool (2.5.5)
|
connection_pool (2.5.5)
|
||||||
cookiejar (0.3.4)
|
cookiejar (0.3.4)
|
||||||
crack (1.0.1)
|
crack (1.0.1)
|
||||||
@@ -259,9 +267,9 @@ GEM
|
|||||||
css_parser (1.21.1)
|
css_parser (1.21.1)
|
||||||
addressable
|
addressable
|
||||||
csv (3.3.5)
|
csv (3.3.5)
|
||||||
cuprite (0.15)
|
cuprite (0.17)
|
||||||
capybara (~> 3.0)
|
capybara (~> 3.0)
|
||||||
ferrum (~> 0.14.0)
|
ferrum (~> 0.17.0)
|
||||||
database_cleaner (2.1.0)
|
database_cleaner (2.1.0)
|
||||||
database_cleaner-active_record (>= 2, < 3)
|
database_cleaner-active_record (>= 2, < 3)
|
||||||
database_cleaner-active_record (2.2.2)
|
database_cleaner-active_record (2.2.2)
|
||||||
@@ -270,7 +278,7 @@ GEM
|
|||||||
database_cleaner-core (2.0.1)
|
database_cleaner-core (2.0.1)
|
||||||
datafoodconsortium-connector (1.2.0)
|
datafoodconsortium-connector (1.2.0)
|
||||||
virtual_assembly-semantizer (~> 1.0, >= 1.0.5)
|
virtual_assembly-semantizer (~> 1.0, >= 1.0.5)
|
||||||
date (3.5.0)
|
date (3.5.1)
|
||||||
debug (1.11.0)
|
debug (1.11.0)
|
||||||
irb (~> 1.10)
|
irb (~> 1.10)
|
||||||
reline (>= 0.3.8)
|
reline (>= 0.3.8)
|
||||||
@@ -305,9 +313,9 @@ GEM
|
|||||||
eventmachine (>= 1.0.0.beta.1)
|
eventmachine (>= 1.0.0.beta.1)
|
||||||
email_validator (2.2.4)
|
email_validator (2.2.4)
|
||||||
activemodel
|
activemodel
|
||||||
erb (6.0.0)
|
erb (6.0.1)
|
||||||
erubi (1.13.1)
|
erubi (1.13.1)
|
||||||
et-orbi (1.3.0)
|
et-orbi (1.4.0)
|
||||||
tzinfo
|
tzinfo
|
||||||
eventmachine (1.2.7)
|
eventmachine (1.2.7)
|
||||||
eventmachine_httpserver (0.2.1)
|
eventmachine_httpserver (0.2.1)
|
||||||
@@ -318,19 +326,22 @@ GEM
|
|||||||
factory_bot_rails (6.2.0)
|
factory_bot_rails (6.2.0)
|
||||||
factory_bot (~> 6.2.0)
|
factory_bot (~> 6.2.0)
|
||||||
railties (>= 5.0.0)
|
railties (>= 5.0.0)
|
||||||
faraday (2.9.0)
|
faraday (2.14.1)
|
||||||
faraday-net_http (>= 2.0, < 3.2)
|
faraday-net_http (>= 2.0, < 3.5)
|
||||||
|
json
|
||||||
|
logger
|
||||||
faraday-follow_redirects (0.4.0)
|
faraday-follow_redirects (0.4.0)
|
||||||
faraday (>= 1, < 3)
|
faraday (>= 1, < 3)
|
||||||
faraday-net_http (3.1.1)
|
faraday-net_http (3.4.2)
|
||||||
net-http
|
net-http (~> 0.5)
|
||||||
ferrum (0.14)
|
ferrum (0.17.1)
|
||||||
addressable (~> 2.5)
|
addressable (~> 2.5)
|
||||||
|
base64 (~> 0.2)
|
||||||
concurrent-ruby (~> 1.1)
|
concurrent-ruby (~> 1.1)
|
||||||
webrick (~> 1.7)
|
webrick (~> 1.7)
|
||||||
websocket-driver (>= 0.6, < 0.8)
|
websocket-driver (~> 0.7)
|
||||||
ffaker (2.25.0)
|
ffaker (2.25.0)
|
||||||
ffi (1.17.2)
|
ffi (1.17.3)
|
||||||
flipper (1.3.6)
|
flipper (1.3.6)
|
||||||
concurrent-ruby (< 2)
|
concurrent-ruby (< 2)
|
||||||
flipper-active_record (1.3.6)
|
flipper-active_record (1.3.6)
|
||||||
@@ -361,8 +372,8 @@ GEM
|
|||||||
foreman (0.90.0)
|
foreman (0.90.0)
|
||||||
thor (~> 1.4)
|
thor (~> 1.4)
|
||||||
formatador (0.2.5)
|
formatador (0.2.5)
|
||||||
fugit (1.11.1)
|
fugit (1.12.1)
|
||||||
et-orbi (~> 1, >= 1.2.11)
|
et-orbi (~> 1.4)
|
||||||
raabro (~> 1.4)
|
raabro (~> 1.4)
|
||||||
fuubar (2.5.1)
|
fuubar (2.5.1)
|
||||||
rspec-core (~> 3.0)
|
rspec-core (~> 3.0)
|
||||||
@@ -388,7 +399,8 @@ GEM
|
|||||||
sysexits (~> 1.1)
|
sysexits (~> 1.1)
|
||||||
hashdiff (1.2.1)
|
hashdiff (1.2.1)
|
||||||
hashery (2.1.2)
|
hashery (2.1.2)
|
||||||
hashie (5.0.0)
|
hashie (5.1.0)
|
||||||
|
logger
|
||||||
highline (3.1.2)
|
highline (3.1.2)
|
||||||
reline
|
reline
|
||||||
htmlentities (4.4.2)
|
htmlentities (4.4.2)
|
||||||
@@ -417,10 +429,11 @@ GEM
|
|||||||
activerecord (>= 3.0)
|
activerecord (>= 3.0)
|
||||||
invisible_captcha (2.3.0)
|
invisible_captcha (2.3.0)
|
||||||
rails (>= 5.2)
|
rails (>= 5.2)
|
||||||
io-console (0.8.1)
|
io-console (0.8.2)
|
||||||
ipaddress (0.8.3)
|
ipaddress (0.8.3)
|
||||||
irb (1.15.3)
|
irb (1.17.0)
|
||||||
pp (>= 0.6.0)
|
pp (>= 0.6.0)
|
||||||
|
prism (>= 1.3.0)
|
||||||
rdoc (>= 4.0.0)
|
rdoc (>= 4.0.0)
|
||||||
reline (>= 0.4.2)
|
reline (>= 0.4.2)
|
||||||
jmespath (1.6.2)
|
jmespath (1.6.2)
|
||||||
@@ -430,7 +443,7 @@ GEM
|
|||||||
thor (>= 0.14, < 2.0)
|
thor (>= 0.14, < 2.0)
|
||||||
jquery-ui-rails (4.2.1)
|
jquery-ui-rails (4.2.1)
|
||||||
railties (>= 3.2.16)
|
railties (>= 3.2.16)
|
||||||
json (2.15.2)
|
json (2.18.1)
|
||||||
json-canonicalization (1.0.0)
|
json-canonicalization (1.0.0)
|
||||||
json-jwt (1.17.0)
|
json-jwt (1.17.0)
|
||||||
activesupport (>= 4.2)
|
activesupport (>= 4.2)
|
||||||
@@ -456,7 +469,7 @@ GEM
|
|||||||
activesupport (>= 4.2)
|
activesupport (>= 4.2)
|
||||||
jwt (2.10.2)
|
jwt (2.10.2)
|
||||||
base64
|
base64
|
||||||
knapsack_pro (8.4.0)
|
knapsack_pro (9.2.2)
|
||||||
rake
|
rake
|
||||||
language_server-protocol (3.17.0.5)
|
language_server-protocol (3.17.0.5)
|
||||||
launchy (3.0.0)
|
launchy (3.0.0)
|
||||||
@@ -466,11 +479,12 @@ GEM
|
|||||||
launchy (>= 2.2, < 4)
|
launchy (>= 2.2, < 4)
|
||||||
link_header (0.0.8)
|
link_header (0.0.8)
|
||||||
lint_roller (1.1.0)
|
lint_roller (1.1.0)
|
||||||
listen (3.9.0)
|
listen (3.10.0)
|
||||||
|
logger
|
||||||
rb-fsevent (~> 0.10, >= 0.10.3)
|
rb-fsevent (~> 0.10, >= 0.10.3)
|
||||||
rb-inotify (~> 0.9, >= 0.9.10)
|
rb-inotify (~> 0.9, >= 0.9.10)
|
||||||
logger (1.7.0)
|
logger (1.7.0)
|
||||||
loofah (2.24.1)
|
loofah (2.25.0)
|
||||||
crass (~> 1.0.2)
|
crass (~> 1.0.2)
|
||||||
nokogiri (>= 1.12.0)
|
nokogiri (>= 1.12.0)
|
||||||
mail (2.9.0)
|
mail (2.9.0)
|
||||||
@@ -493,7 +507,8 @@ GEM
|
|||||||
logger
|
logger
|
||||||
mini_mime (1.1.5)
|
mini_mime (1.1.5)
|
||||||
mini_portile2 (2.8.6)
|
mini_portile2 (2.8.6)
|
||||||
minitest (5.26.2)
|
minitest (6.0.1)
|
||||||
|
prism (~> 1.5)
|
||||||
monetize (1.13.0)
|
monetize (1.13.0)
|
||||||
money (~> 6.12)
|
money (~> 6.12)
|
||||||
money (6.16.0)
|
money (6.16.0)
|
||||||
@@ -502,8 +517,8 @@ GEM
|
|||||||
multi_json (1.17.0)
|
multi_json (1.17.0)
|
||||||
multi_xml (0.6.0)
|
multi_xml (0.6.0)
|
||||||
mutex_m (0.3.0)
|
mutex_m (0.3.0)
|
||||||
net-http (0.7.0)
|
net-http (0.9.1)
|
||||||
uri
|
uri (>= 0.11.1)
|
||||||
net-imap (0.5.12)
|
net-imap (0.5.12)
|
||||||
date
|
date
|
||||||
net-protocol
|
net-protocol
|
||||||
@@ -515,7 +530,7 @@ GEM
|
|||||||
net-protocol
|
net-protocol
|
||||||
newrelic_rpm (9.24.0)
|
newrelic_rpm (9.24.0)
|
||||||
nio4r (2.7.5)
|
nio4r (2.7.5)
|
||||||
nokogiri (1.18.10)
|
nokogiri (1.19.1)
|
||||||
mini_portile2 (~> 2.8.2)
|
mini_portile2 (~> 2.8.2)
|
||||||
racc (~> 1.4)
|
racc (~> 1.4)
|
||||||
nokogiri-html5-inference (0.3.0)
|
nokogiri-html5-inference (0.3.0)
|
||||||
@@ -532,7 +547,7 @@ GEM
|
|||||||
logger
|
logger
|
||||||
rack (>= 2.2.3)
|
rack (>= 2.2.3)
|
||||||
rack-protection
|
rack-protection
|
||||||
omniauth-rails_csrf_protection (1.0.2)
|
omniauth-rails_csrf_protection (2.0.1)
|
||||||
actionpack (>= 4.2)
|
actionpack (>= 4.2)
|
||||||
omniauth (~> 2.0)
|
omniauth (~> 2.0)
|
||||||
omniauth_openid_connect (0.8.0)
|
omniauth_openid_connect (0.8.0)
|
||||||
@@ -561,7 +576,7 @@ GEM
|
|||||||
parallel (1.27.0)
|
parallel (1.27.0)
|
||||||
paranoia (2.6.4)
|
paranoia (2.6.4)
|
||||||
activerecord (>= 5.1, < 7.2)
|
activerecord (>= 5.1, < 7.2)
|
||||||
parser (3.3.10.0)
|
parser (3.3.10.2)
|
||||||
ast (~> 2.4.1)
|
ast (~> 2.4.1)
|
||||||
racc
|
racc
|
||||||
paypal-sdk-core (0.3.4)
|
paypal-sdk-core (0.3.4)
|
||||||
@@ -579,15 +594,16 @@ GEM
|
|||||||
pp (0.6.3)
|
pp (0.6.3)
|
||||||
prettyprint
|
prettyprint
|
||||||
prettyprint (0.2.0)
|
prettyprint (0.2.0)
|
||||||
prism (1.7.0)
|
prism (1.9.0)
|
||||||
private_address_check (0.5.0)
|
private_address_check (0.5.0)
|
||||||
pry (0.15.2)
|
pry (0.16.0)
|
||||||
coderay (~> 1.1)
|
coderay (~> 1.1)
|
||||||
method_source (~> 1.0)
|
method_source (~> 1.0)
|
||||||
psych (5.2.6)
|
reline (>= 0.6.0)
|
||||||
|
psych (5.3.1)
|
||||||
date
|
date
|
||||||
stringio
|
stringio
|
||||||
public_suffix (7.0.0)
|
public_suffix (7.0.2)
|
||||||
puffing-billy (4.0.2)
|
puffing-billy (4.0.2)
|
||||||
addressable (~> 2.5)
|
addressable (~> 2.5)
|
||||||
em-http-request (~> 1.1, >= 1.1.0)
|
em-http-request (~> 1.1, >= 1.1.0)
|
||||||
@@ -603,7 +619,7 @@ GEM
|
|||||||
railties (>= 4.2)
|
railties (>= 4.2)
|
||||||
raabro (1.4.0)
|
raabro (1.4.0)
|
||||||
racc (1.8.1)
|
racc (1.8.1)
|
||||||
rack (2.2.21)
|
rack (2.2.22)
|
||||||
rack-mini-profiler (2.3.4)
|
rack-mini-profiler (2.3.4)
|
||||||
rack (>= 1.2.0)
|
rack (>= 1.2.0)
|
||||||
rack-oauth2 (2.3.0)
|
rack-oauth2 (2.3.0)
|
||||||
@@ -677,7 +693,7 @@ GEM
|
|||||||
activesupport (>= 6.1.5)
|
activesupport (>= 6.1.5)
|
||||||
i18n
|
i18n
|
||||||
rb-fsevent (0.11.2)
|
rb-fsevent (0.11.2)
|
||||||
rb-inotify (0.10.1)
|
rb-inotify (0.11.1)
|
||||||
ffi (~> 1.0)
|
ffi (~> 1.0)
|
||||||
rdf (3.3.4)
|
rdf (3.3.4)
|
||||||
bcp47_spec (~> 0.2)
|
bcp47_spec (~> 0.2)
|
||||||
@@ -686,7 +702,7 @@ GEM
|
|||||||
logger (~> 1.5)
|
logger (~> 1.5)
|
||||||
ostruct (~> 0.6)
|
ostruct (~> 0.6)
|
||||||
readline (~> 0.0)
|
readline (~> 0.0)
|
||||||
rdoc (6.16.0)
|
rdoc (7.2.0)
|
||||||
erb
|
erb
|
||||||
psych (>= 4.0.0)
|
psych (>= 4.0.0)
|
||||||
tsort
|
tsort
|
||||||
@@ -695,16 +711,16 @@ GEM
|
|||||||
redcarpet (3.6.1)
|
redcarpet (3.6.1)
|
||||||
redis (5.4.1)
|
redis (5.4.1)
|
||||||
redis-client (>= 0.22.0)
|
redis-client (>= 0.22.0)
|
||||||
redis-client (0.26.1)
|
redis-client (0.26.4)
|
||||||
connection_pool
|
connection_pool
|
||||||
regexp_parser (2.11.3)
|
regexp_parser (2.11.3)
|
||||||
reline (0.6.3)
|
reline (0.6.3)
|
||||||
io-console (~> 0.5)
|
io-console (~> 0.5)
|
||||||
request_store (1.7.0)
|
request_store (1.7.0)
|
||||||
rack (>= 1.4)
|
rack (>= 1.4)
|
||||||
responders (3.1.1)
|
responders (3.2.0)
|
||||||
actionpack (>= 5.2)
|
actionpack (>= 7.0)
|
||||||
railties (>= 5.2)
|
railties (>= 7.0)
|
||||||
rexml (3.4.4)
|
rexml (3.4.4)
|
||||||
roadie (5.2.1)
|
roadie (5.2.1)
|
||||||
css_parser (~> 1.4)
|
css_parser (~> 1.4)
|
||||||
@@ -759,7 +775,7 @@ GEM
|
|||||||
rswag-ui (2.17.0)
|
rswag-ui (2.17.0)
|
||||||
actionpack (>= 5.2, < 8.2)
|
actionpack (>= 5.2, < 8.2)
|
||||||
railties (>= 5.2, < 8.2)
|
railties (>= 5.2, < 8.2)
|
||||||
rubocop (1.81.7)
|
rubocop (1.84.2)
|
||||||
json (~> 2.3)
|
json (~> 2.3)
|
||||||
language_server-protocol (~> 3.17.0.2)
|
language_server-protocol (~> 3.17.0.2)
|
||||||
lint_roller (~> 1.1.0)
|
lint_roller (~> 1.1.0)
|
||||||
@@ -767,25 +783,25 @@ GEM
|
|||||||
parser (>= 3.3.0.2)
|
parser (>= 3.3.0.2)
|
||||||
rainbow (>= 2.2.2, < 4.0)
|
rainbow (>= 2.2.2, < 4.0)
|
||||||
regexp_parser (>= 2.9.3, < 3.0)
|
regexp_parser (>= 2.9.3, < 3.0)
|
||||||
rubocop-ast (>= 1.47.1, < 2.0)
|
rubocop-ast (>= 1.49.0, < 2.0)
|
||||||
ruby-progressbar (~> 1.7)
|
ruby-progressbar (~> 1.7)
|
||||||
unicode-display_width (>= 2.4.0, < 4.0)
|
unicode-display_width (>= 2.4.0, < 4.0)
|
||||||
rubocop-ast (1.48.0)
|
rubocop-ast (1.49.0)
|
||||||
parser (>= 3.3.7.2)
|
parser (>= 3.3.7.2)
|
||||||
prism (~> 1.4)
|
prism (~> 1.7)
|
||||||
rubocop-capybara (2.22.1)
|
rubocop-capybara (2.22.1)
|
||||||
lint_roller (~> 1.1)
|
lint_roller (~> 1.1)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
rubocop (~> 1.72, >= 1.72.1)
|
||||||
rubocop-factory_bot (2.28.0)
|
rubocop-factory_bot (2.28.0)
|
||||||
lint_roller (~> 1.1)
|
lint_roller (~> 1.1)
|
||||||
rubocop (~> 1.72, >= 1.72.1)
|
rubocop (~> 1.72, >= 1.72.1)
|
||||||
rubocop-rails (2.34.2)
|
rubocop-rails (2.34.3)
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
lint_roller (~> 1.1)
|
lint_roller (~> 1.1)
|
||||||
rack (>= 1.1)
|
rack (>= 1.1)
|
||||||
rubocop (>= 1.75.0, < 2.0)
|
rubocop (>= 1.75.0, < 2.0)
|
||||||
rubocop-ast (>= 1.44.0, < 2.0)
|
rubocop-ast (>= 1.44.0, < 2.0)
|
||||||
rubocop-rspec (3.8.0)
|
rubocop-rspec (3.9.0)
|
||||||
lint_roller (~> 1.1)
|
lint_roller (~> 1.1)
|
||||||
rubocop (~> 1.81)
|
rubocop (~> 1.81)
|
||||||
rubocop-rspec_rails (2.32.0)
|
rubocop-rspec_rails (2.32.0)
|
||||||
@@ -800,23 +816,16 @@ GEM
|
|||||||
ffi (~> 1.12)
|
ffi (~> 1.12)
|
||||||
logger
|
logger
|
||||||
rubyzip (2.4.1)
|
rubyzip (2.4.1)
|
||||||
rufus-scheduler (3.8.2)
|
rufus-scheduler (3.9.2)
|
||||||
fugit (~> 1.1, >= 1.1.6)
|
fugit (~> 1.1, >= 1.11.1)
|
||||||
rugged (1.9.0)
|
rugged (1.9.0)
|
||||||
sanitize (7.0.0)
|
sanitize (7.0.0)
|
||||||
crass (~> 1.0.2)
|
crass (~> 1.0.2)
|
||||||
nokogiri (>= 1.16.8)
|
nokogiri (>= 1.16.8)
|
||||||
sass (3.4.25)
|
|
||||||
sass-rails (5.0.8)
|
|
||||||
railties (>= 5.2.0)
|
|
||||||
sass (~> 3.1)
|
|
||||||
sprockets (>= 2.8, < 4.0)
|
|
||||||
sprockets-rails (>= 2.0, < 4.0)
|
|
||||||
tilt (>= 1.1, < 3)
|
|
||||||
sd_notify (0.1.1)
|
sd_notify (0.1.1)
|
||||||
securerandom (0.4.1)
|
securerandom (0.4.1)
|
||||||
semantic_range (3.1.0)
|
semantic_range (3.1.0)
|
||||||
shakapacker (7.2.3)
|
shakapacker (8.4.0)
|
||||||
activesupport (>= 5.2)
|
activesupport (>= 5.2)
|
||||||
package_json
|
package_json
|
||||||
rack-proxy (>= 0.6.1)
|
rack-proxy (>= 0.6.1)
|
||||||
@@ -824,15 +833,15 @@ GEM
|
|||||||
semantic_range (>= 2.3.0)
|
semantic_range (>= 2.3.0)
|
||||||
shoulda-matchers (7.0.1)
|
shoulda-matchers (7.0.1)
|
||||||
activesupport (>= 7.1)
|
activesupport (>= 7.1)
|
||||||
sidekiq (7.2.4)
|
sidekiq (7.3.10)
|
||||||
concurrent-ruby (< 2)
|
base64
|
||||||
connection_pool (>= 2.3.0)
|
connection_pool (>= 2.3.0, < 3)
|
||||||
rack (>= 2.2.4)
|
logger
|
||||||
redis-client (>= 0.19.0)
|
rack (>= 2.2.4, < 3.3)
|
||||||
sidekiq-scheduler (5.0.3)
|
redis-client (>= 0.23.0, < 1)
|
||||||
|
sidekiq-scheduler (6.0.1)
|
||||||
rufus-scheduler (~> 3.2)
|
rufus-scheduler (~> 3.2)
|
||||||
sidekiq (>= 6, < 8)
|
sidekiq (>= 7.3, < 9)
|
||||||
tilt (>= 1.4.0)
|
|
||||||
simplecov (0.22.0)
|
simplecov (0.22.0)
|
||||||
docile (~> 1.1)
|
docile (~> 1.1)
|
||||||
simplecov-html (~> 0.11)
|
simplecov-html (~> 0.11)
|
||||||
@@ -843,7 +852,7 @@ GEM
|
|||||||
caxlsx (<= 4.0)
|
caxlsx (<= 4.0)
|
||||||
csv
|
csv
|
||||||
rodf
|
rodf
|
||||||
spring (4.4.0)
|
spring (4.4.2)
|
||||||
spring-commands-rspec (1.0.4)
|
spring-commands-rspec (1.0.4)
|
||||||
spring (>= 0.9.1)
|
spring (>= 0.9.1)
|
||||||
spring-commands-rubocop (0.4.0)
|
spring-commands-rubocop (0.4.0)
|
||||||
@@ -876,7 +885,7 @@ GEM
|
|||||||
railties (>= 5.2)
|
railties (>= 5.2)
|
||||||
redis (>= 4.0, < 6.0)
|
redis (>= 4.0, < 6.0)
|
||||||
stringex (2.8.6)
|
stringex (2.8.6)
|
||||||
stringio (3.1.8)
|
stringio (3.2.0)
|
||||||
stripe (15.5.0)
|
stripe (15.5.0)
|
||||||
swd (2.0.3)
|
swd (2.0.3)
|
||||||
activesupport (>= 3)
|
activesupport (>= 3)
|
||||||
@@ -884,13 +893,14 @@ GEM
|
|||||||
faraday (~> 2.0)
|
faraday (~> 2.0)
|
||||||
faraday-follow_redirects
|
faraday-follow_redirects
|
||||||
sysexits (1.2.0)
|
sysexits (1.2.0)
|
||||||
|
taler (0.2.0)
|
||||||
temple (0.10.4)
|
temple (0.10.4)
|
||||||
terminal-table (4.0.0)
|
terminal-table (4.0.0)
|
||||||
unicode-display_width (>= 1.1.1, < 4)
|
unicode-display_width (>= 1.1.1, < 4)
|
||||||
thor (1.4.0)
|
thor (1.5.0)
|
||||||
thread-local (1.1.0)
|
thread-local (1.1.0)
|
||||||
tilt (2.6.1)
|
tilt (2.7.0)
|
||||||
timeout (0.4.4)
|
timeout (0.6.0)
|
||||||
tsort (0.2.0)
|
tsort (0.2.0)
|
||||||
ttfunk (1.8.0)
|
ttfunk (1.8.0)
|
||||||
bigdecimal (~> 3.1)
|
bigdecimal (~> 3.1)
|
||||||
@@ -912,7 +922,7 @@ GEM
|
|||||||
unicode-display_width (3.2.0)
|
unicode-display_width (3.2.0)
|
||||||
unicode-emoji (~> 4.1)
|
unicode-emoji (~> 4.1)
|
||||||
unicode-emoji (4.2.0)
|
unicode-emoji (4.2.0)
|
||||||
uniform_notifier (1.17.0)
|
uniform_notifier (1.18.0)
|
||||||
uri (1.1.1)
|
uri (1.1.1)
|
||||||
valid_email2 (5.2.3)
|
valid_email2 (5.2.3)
|
||||||
activemodel (>= 3.2)
|
activemodel (>= 3.2)
|
||||||
@@ -950,20 +960,17 @@ GEM
|
|||||||
crack (>= 0.3.2)
|
crack (>= 0.3.2)
|
||||||
hashdiff (>= 0.4.0, < 2.0.0)
|
hashdiff (>= 0.4.0, < 2.0.0)
|
||||||
webrick (1.9.2)
|
webrick (1.9.2)
|
||||||
websocket-driver (0.7.7)
|
websocket-driver (0.8.0)
|
||||||
base64
|
base64
|
||||||
websocket-extensions (>= 0.1.0)
|
websocket-extensions (>= 0.1.0)
|
||||||
websocket-extensions (0.1.5)
|
websocket-extensions (0.1.5)
|
||||||
whenever (1.1.0)
|
whenever (1.1.0)
|
||||||
chronic (>= 0.6.3)
|
chronic (>= 0.6.3)
|
||||||
wicked_pdf (2.8.2)
|
|
||||||
activesupport
|
|
||||||
ostruct
|
|
||||||
wkhtmltopdf-binary (0.12.6.10)
|
wkhtmltopdf-binary (0.12.6.10)
|
||||||
xml-simple (1.1.8)
|
xml-simple (1.1.8)
|
||||||
xpath (3.2.0)
|
xpath (3.2.0)
|
||||||
nokogiri (~> 1.8)
|
nokogiri (~> 1.8)
|
||||||
zeitwerk (2.7.3)
|
zeitwerk (2.7.4)
|
||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
ruby
|
ruby
|
||||||
@@ -1085,7 +1092,7 @@ DEPENDENCIES
|
|||||||
rubocop-rspec_rails
|
rubocop-rspec_rails
|
||||||
sd_notify
|
sd_notify
|
||||||
select2-rails!
|
select2-rails!
|
||||||
shakapacker (= 7.2.3)
|
shakapacker (= 8.4.0)
|
||||||
shoulda-matchers
|
shoulda-matchers
|
||||||
sidekiq
|
sidekiq
|
||||||
sidekiq-scheduler
|
sidekiq-scheduler
|
||||||
@@ -1100,6 +1107,7 @@ DEPENDENCIES
|
|||||||
stimulus_reflex_testing!
|
stimulus_reflex_testing!
|
||||||
stringex (~> 2.8.5)
|
stringex (~> 2.8.5)
|
||||||
stripe (~> 15)
|
stripe (~> 15)
|
||||||
|
taler
|
||||||
turbo-rails
|
turbo-rails
|
||||||
turbo_power
|
turbo_power
|
||||||
undercover
|
undercover
|
||||||
@@ -1112,7 +1120,7 @@ DEPENDENCIES
|
|||||||
web-console
|
web-console
|
||||||
webmock
|
webmock
|
||||||
whenever
|
whenever
|
||||||
wicked_pdf
|
wicked_pdf!
|
||||||
wkhtmltopdf-binary
|
wkhtmltopdf-binary
|
||||||
|
|
||||||
RUBY VERSION
|
RUBY VERSION
|
||||||
|
|||||||
2
Procfile
2
Procfile
@@ -1,5 +1,5 @@
|
|||||||
# Foreman Procfile. Start all dev server processes with: `foreman start`
|
# Foreman Procfile. Start all dev server processes with: `foreman start`
|
||||||
|
|
||||||
rails: DEV_CACHING=true bundle exec rails s -p 3000
|
rails: DEV_CACHING=true bundle exec rails s -p 3000
|
||||||
webpack: ./bin/shakacker-dev-server
|
webpack: ./bin/shakapacker-dev-server
|
||||||
sidekiq: DEV_CACHING=true bundle exec sidekiq -q mailers -q default
|
sidekiq: DEV_CACHING=true bundle exec sidekiq -q mailers -q default
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
angular.module('Darkswarm').controller "HomeCtrl", ($scope) ->
|
|
||||||
$scope.brandStoryExpanded = false
|
|
||||||
|
|
||||||
$scope.toggleBrandStory = ->
|
|
||||||
$scope.brandStoryExpanded = !$scope.brandStoryExpanded
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
@import './mail/all.scss';
|
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
@import '../../../webpacker/css/admin/globals/palette.scss';
|
|
||||||
@import 'email';
|
|
||||||
@import 'payments_list';
|
|
||||||
@@ -1,17 +1,18 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class SearchableDropdownComponent < ViewComponent::Base
|
class SearchableDropdownComponent < ViewComponent::Base
|
||||||
REMOVED_SEARCH_PLUGIN = { 'tom-select-options-value': '{ "plugins": [] }' }.freeze
|
|
||||||
MINIMUM_OPTIONS_FOR_SEARCH_FIELD = 11 # at least 11 options are required for the search field
|
MINIMUM_OPTIONS_FOR_SEARCH_FIELD = 11 # at least 11 options are required for the search field
|
||||||
|
|
||||||
def initialize(
|
def initialize(
|
||||||
form:,
|
|
||||||
name:,
|
name:,
|
||||||
options:,
|
options:,
|
||||||
selected_option:,
|
selected_option:,
|
||||||
placeholder_value:,
|
form: nil,
|
||||||
|
placeholder_value: '',
|
||||||
include_blank: false,
|
include_blank: false,
|
||||||
aria_label: '',
|
aria_label: '',
|
||||||
|
multiple: false,
|
||||||
|
remote_url: nil,
|
||||||
other_attrs: {}
|
other_attrs: {}
|
||||||
)
|
)
|
||||||
@f = form
|
@f = form
|
||||||
@@ -21,13 +22,15 @@ class SearchableDropdownComponent < ViewComponent::Base
|
|||||||
@placeholder_value = placeholder_value
|
@placeholder_value = placeholder_value
|
||||||
@include_blank = include_blank
|
@include_blank = include_blank
|
||||||
@aria_label = aria_label
|
@aria_label = aria_label
|
||||||
|
@multiple = multiple
|
||||||
|
@remote_url = remote_url
|
||||||
@other_attrs = other_attrs
|
@other_attrs = other_attrs
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
attr_reader :f, :name, :options, :selected_option, :placeholder_value, :include_blank,
|
attr_reader :f, :name, :options, :selected_option, :placeholder_value, :include_blank,
|
||||||
:aria_label, :other_attrs
|
:aria_label, :multiple, :remote_url, :other_attrs
|
||||||
|
|
||||||
def classes
|
def classes
|
||||||
"fullwidth #{'no-input' if remove_search_plugin?}"
|
"fullwidth #{'no-input' if remove_search_plugin?}"
|
||||||
@@ -36,11 +39,33 @@ class SearchableDropdownComponent < ViewComponent::Base
|
|||||||
def data
|
def data
|
||||||
{
|
{
|
||||||
controller: "tom-select",
|
controller: "tom-select",
|
||||||
'tom-select-placeholder-value': placeholder_value
|
'tom-select-placeholder-value': placeholder_value,
|
||||||
}.merge(remove_search_plugin? ? REMOVED_SEARCH_PLUGIN : {})
|
'tom-select-options-value': tom_select_options_value,
|
||||||
|
'tom-select-remote-url-value': remote_url,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def tom_select_options_value
|
||||||
|
plugins = []
|
||||||
|
plugins << 'virtual_scroll' if @remote_url.present?
|
||||||
|
plugins << 'dropdown_input' unless remove_search_plugin?
|
||||||
|
plugins << 'remove_button' if multiple
|
||||||
|
|
||||||
|
{
|
||||||
|
plugins:,
|
||||||
|
maxItems: multiple ? nil : 1,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
def uses_form_builder?
|
||||||
|
f.present?
|
||||||
end
|
end
|
||||||
|
|
||||||
def remove_search_plugin?
|
def remove_search_plugin?
|
||||||
@remove_search_plugin ||= options.count < MINIMUM_OPTIONS_FOR_SEARCH_FIELD
|
# Remove the search plugin when:
|
||||||
|
# - the select is multiple (it already includes a search field), or
|
||||||
|
# - there is no remote URL and the options are below the search threshold
|
||||||
|
@remove_search_plugin ||= multiple ||
|
||||||
|
(@remote_url.nil? && options.count < MINIMUM_OPTIONS_FOR_SEARCH_FIELD)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1 +1,4 @@
|
|||||||
= f.select name, options_for_select(options, selected_option), { include_blank: }, class: classes, data:, 'aria-label': aria_label, **other_attrs
|
- if uses_form_builder?
|
||||||
|
= f.select name, options, { selected: selected_option, include_blank:, multiple: }, class: classes, data:, 'aria-label': aria_label, **other_attrs
|
||||||
|
- else
|
||||||
|
= select_tag name, options_for_select(options, selected_option), include_blank:, multiple:, class: classes, data:, 'aria-label': aria_label, **other_attrs
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ module Admin
|
|||||||
flash[:success] = I18n.t('admin.products_v3.bulk_update.success')
|
flash[:success] = I18n.t('admin.products_v3.bulk_update.success')
|
||||||
redirect_to [:index,
|
redirect_to [:index,
|
||||||
{ page: @page, per_page: @per_page, search_term: @search_term,
|
{ page: @page, per_page: @per_page, search_term: @search_term,
|
||||||
producer_id: @producer_id, category_id: @category_id }]
|
producer_id: @producer_id, category_id: @category_id, tags_name_in: @tags }]
|
||||||
elsif product_set.errors.present?
|
elsif product_set.errors.present?
|
||||||
@error_counts = { saved: product_set.saved_count, invalid: product_set.invalid.count }
|
@error_counts = { saved: product_set.saved_count, invalid: product_set.invalid.count }
|
||||||
|
|
||||||
@@ -120,7 +120,7 @@ module Admin
|
|||||||
@search_term = params[:search_term] || params[:_search_term]
|
@search_term = params[:search_term] || params[:_search_term]
|
||||||
@producer_id = params[:producer_id] || params[:_producer_id]
|
@producer_id = params[:producer_id] || params[:_producer_id]
|
||||||
@category_id = params[:category_id] || params[:_category_id]
|
@category_id = params[:category_id] || params[:_category_id]
|
||||||
@tags = params[:tags_name_in] || params[:_tags_name_in]
|
@tags = params[:tags_name_in] || []
|
||||||
end
|
end
|
||||||
|
|
||||||
def init_pagination_params
|
def init_pagination_params
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ module Admin
|
|||||||
class ReportsController < Spree::Admin::BaseController
|
class ReportsController < Spree::Admin::BaseController
|
||||||
include ActiveStorage::SetCurrent
|
include ActiveStorage::SetCurrent
|
||||||
include ReportsActions
|
include ReportsActions
|
||||||
|
include Reports::AjaxSearch
|
||||||
|
|
||||||
helper ReportsHelper
|
helper ReportsHelper
|
||||||
|
|
||||||
|
|||||||
108
app/controllers/concerns/reports/ajax_search.rb
Normal file
108
app/controllers/concerns/reports/ajax_search.rb
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Reports
|
||||||
|
module AjaxSearch
|
||||||
|
extend ActiveSupport::Concern
|
||||||
|
|
||||||
|
def search_enterprise_fees
|
||||||
|
report = report_class.new(spree_current_user, params, render: false)
|
||||||
|
fee_ids = enterprise_fee_ids(report.search.result)
|
||||||
|
query = EnterpriseFee.where(id: fee_ids)
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
def search_enterprise_fee_owners
|
||||||
|
report = report_class.new(spree_current_user, params, render: false)
|
||||||
|
owner_ids = enterprise_fee_owner_ids(report.search.result)
|
||||||
|
query = Enterprise.where(id: owner_ids)
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
def search_distributors
|
||||||
|
query = frontend_data.distributors
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
def search_order_cycles
|
||||||
|
query = frontend_data.order_cycles
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
def search_order_customers
|
||||||
|
query = frontend_data.order_customers
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
def search_suppliers
|
||||||
|
query = frontend_data.orders_suppliers
|
||||||
|
|
||||||
|
render json: build_search_response(query)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def build_search_response(query)
|
||||||
|
page = (params[:page] || 1).to_i
|
||||||
|
per_page = 30
|
||||||
|
|
||||||
|
filtered_query = apply_search_filter(query)
|
||||||
|
total_count = filtered_query.size
|
||||||
|
items = paginated_items(filtered_query, page, per_page)
|
||||||
|
results = format_results(items)
|
||||||
|
|
||||||
|
{ results: results, pagination: { more: (page * per_page) < total_count } }
|
||||||
|
end
|
||||||
|
|
||||||
|
def apply_search_filter(query)
|
||||||
|
search_term = params[:q]
|
||||||
|
return query if search_term.blank?
|
||||||
|
|
||||||
|
escaped_search_term = ActiveRecord::Base.sanitize_sql_like(search_term)
|
||||||
|
pattern = "%#{escaped_search_term}%"
|
||||||
|
|
||||||
|
# Handle different model types
|
||||||
|
if query.model == OrderCycle
|
||||||
|
query.where("order_cycles.name ILIKE ?", pattern)
|
||||||
|
elsif query.model == Customer
|
||||||
|
query.where("customers.email ILIKE ?", pattern)
|
||||||
|
else
|
||||||
|
query.where("name ILIKE ?", pattern)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def paginated_items(query, page, per_page)
|
||||||
|
if query.model == Customer
|
||||||
|
query.order(:email).offset((page - 1) * per_page).limit(per_page).pluck(:email, :id)
|
||||||
|
elsif query.model == OrderCycle
|
||||||
|
query.order('order_cycles.orders_close_at DESC')
|
||||||
|
.offset((page - 1) * per_page)
|
||||||
|
.limit(per_page).pluck(
|
||||||
|
:name, :id
|
||||||
|
)
|
||||||
|
else
|
||||||
|
query.order(:name).offset((page - 1) * per_page).limit(per_page).pluck(:name, :id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def format_results(items)
|
||||||
|
items.map { |label, value| { value:, label: } }
|
||||||
|
end
|
||||||
|
|
||||||
|
def frontend_data
|
||||||
|
@frontend_data ||= Reporting::FrontendData.new(spree_current_user)
|
||||||
|
end
|
||||||
|
|
||||||
|
def enterprise_fee_owner_ids(orders)
|
||||||
|
EnterpriseFee.where(id: enterprise_fee_ids(orders)).select(:enterprise_id)
|
||||||
|
end
|
||||||
|
|
||||||
|
def enterprise_fee_ids(orders)
|
||||||
|
Spree::Adjustment.enterprise_fee.where(order_id: orders.select(:id)).select(:originator_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
16
app/controllers/payment_gateways/taler_controller.rb
Normal file
16
app/controllers/payment_gateways/taler_controller.rb
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module PaymentGateways
|
||||||
|
class TalerController < BaseController
|
||||||
|
include OrderCompletion
|
||||||
|
|
||||||
|
# The Taler merchant backend has taken the payment.
|
||||||
|
# Now we just need to confirm that and update our local database
|
||||||
|
# before finalising the order.
|
||||||
|
def confirm
|
||||||
|
payment = Spree::Payment.find(params[:payment_id])
|
||||||
|
@order = payment.order
|
||||||
|
process_payment_completion!
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -14,6 +14,7 @@ module Spree
|
|||||||
Spree::Gateway::PayPalExpress
|
Spree::Gateway::PayPalExpress
|
||||||
Spree::Gateway::StripeSCA
|
Spree::Gateway::StripeSCA
|
||||||
Spree::PaymentMethod::Check
|
Spree::PaymentMethod::Check
|
||||||
|
Spree::PaymentMethod::Taler
|
||||||
}.freeze
|
}.freeze
|
||||||
|
|
||||||
def create
|
def create
|
||||||
@@ -137,7 +138,7 @@ module Spree
|
|||||||
|
|
||||||
providers.delete("Spree::Gateway::StripeSCA") unless show_stripe?
|
providers.delete("Spree::Gateway::StripeSCA") unless show_stripe?
|
||||||
|
|
||||||
providers.map(&:constantize)
|
providers
|
||||||
end
|
end
|
||||||
|
|
||||||
# Show Stripe as an option if enabled, or if the
|
# Show Stripe as an option if enabled, or if the
|
||||||
|
|||||||
@@ -95,8 +95,7 @@ module Spree
|
|||||||
private
|
private
|
||||||
|
|
||||||
def load_payment_source
|
def load_payment_source
|
||||||
if @payment.payment_method.is_a?(Spree::Gateway) &&
|
if @payment.payment_method.is_a?(Gateway::StripeSCA) &&
|
||||||
@payment.payment_method.payment_profiles_supported? &&
|
|
||||||
params[:card].present? &&
|
params[:card].present? &&
|
||||||
(params[:card] != 'new')
|
(params[:card] != 'new')
|
||||||
@payment.source = CreditCard.find_by(id: params[:card])
|
@payment.source = CreditCard.find_by(id: params[:card])
|
||||||
|
|||||||
@@ -9,7 +9,6 @@ module Spree
|
|||||||
include Spree::Core::ControllerHelpers::Auth
|
include Spree::Core::ControllerHelpers::Auth
|
||||||
include Spree::Core::ControllerHelpers::Common
|
include Spree::Core::ControllerHelpers::Common
|
||||||
include Spree::Core::ControllerHelpers::Order
|
include Spree::Core::ControllerHelpers::Order
|
||||||
include CablecarResponses
|
|
||||||
|
|
||||||
helper 'spree/base'
|
helper 'spree/base'
|
||||||
|
|
||||||
@@ -24,14 +23,12 @@ module Spree
|
|||||||
if spree_user_signed_in?
|
if spree_user_signed_in?
|
||||||
flash[:success] = t('devise.success.logged_in_succesfully')
|
flash[:success] = t('devise.success.logged_in_succesfully')
|
||||||
|
|
||||||
render cable_ready: cable_car.redirect_to(
|
redirect_to return_url_or_default(after_sign_in_path_for(spree_current_user))
|
||||||
url: return_url_or_default(after_sign_in_path_for(spree_current_user))
|
|
||||||
)
|
|
||||||
else
|
else
|
||||||
render status: :unauthorized, cable_ready: cable_car.inner_html(
|
message = t('devise.failure.invalid')
|
||||||
"#login-feedback",
|
render turbo_stream: turbo_stream.update(
|
||||||
partial("layouts/alert", locals: { type: "alert", message: t('devise.failure.invalid') })
|
'login-feedback', partial: 'layouts/alert', locals: { message:, type: 'alert' }
|
||||||
)
|
), status: :unprocessable_entity
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -60,11 +57,13 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
def render_unconfirmed_response
|
def render_unconfirmed_response
|
||||||
render status: :unprocessable_entity, cable_ready: cable_car.inner_html(
|
message = t(:email_unconfirmed)
|
||||||
"#login-feedback",
|
|
||||||
partial("layouts/alert", locals: { type: "alert", message: t(:email_unconfirmed),
|
render turbo_stream: turbo_stream.update(
|
||||||
unconfirmed: true, tab: "login" })
|
'login-feedback',
|
||||||
)
|
partial: 'layouts/alert', locals: { type: "alert", message:, unconfirmed: true,
|
||||||
|
tab: "login", email: params.dig(:spree_user, :email) }
|
||||||
|
), status: :unprocessable_entity
|
||||||
end
|
end
|
||||||
|
|
||||||
def ensure_valid_locale_persisted
|
def ensure_valid_locale_persisted
|
||||||
|
|||||||
@@ -3,7 +3,6 @@
|
|||||||
module Spree
|
module Spree
|
||||||
class UsersController < ::BaseController
|
class UsersController < ::BaseController
|
||||||
include I18nHelper
|
include I18nHelper
|
||||||
include CablecarResponses
|
|
||||||
|
|
||||||
layout 'darkswarm'
|
layout 'darkswarm'
|
||||||
|
|
||||||
@@ -25,34 +24,17 @@ module Spree
|
|||||||
@unconfirmed_email = spree_current_user.unconfirmed_email
|
@unconfirmed_email = spree_current_user.unconfirmed_email
|
||||||
end
|
end
|
||||||
|
|
||||||
# Endpoint for queries to check if a user is already registered
|
|
||||||
def registered_email
|
|
||||||
registered = Spree::User.find_by(email: params[:email]).present?
|
|
||||||
|
|
||||||
if registered
|
|
||||||
render status: :ok, cable_ready: cable_car.
|
|
||||||
inner_html(
|
|
||||||
"#login-feedback",
|
|
||||||
partial("layouts/alert",
|
|
||||||
locals: { type: "alert", message: t('devise.failure.already_registered') })
|
|
||||||
).
|
|
||||||
dispatch_event(name: "login:modal:open")
|
|
||||||
else
|
|
||||||
head :not_found
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def create
|
def create
|
||||||
@user = Spree::User.new(user_params)
|
@user = Spree::User.new(user_params)
|
||||||
|
|
||||||
if @user.save
|
if @user.save
|
||||||
flash[:success] = t('devise.user_registrations.spree_user.signed_up_but_unconfirmed')
|
flash[:success] = t('devise.user_registrations.spree_user.signed_up_but_unconfirmed')
|
||||||
render cable_ready: cable_car.redirect_to(url: main_app.root_path)
|
redirect_to main_app.root_path
|
||||||
else
|
else
|
||||||
render status: :unprocessable_entity, cable_ready: cable_car.morph(
|
render turbo_stream: turbo_stream.update(
|
||||||
"#signup-tab",
|
'signup-tab',
|
||||||
partial("layouts/signup_tab", locals: { signup_form_user: @user })
|
partial: 'layouts/signup_tab', locals: { signup_form_user: @user }
|
||||||
)
|
), status: :unprocessable_entity
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -97,13 +79,10 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
def render_alert_timestamp_error_message
|
def render_alert_timestamp_error_message
|
||||||
render cable_ready: cable_car.inner_html(
|
render turbo_stream: turbo_stream.update(
|
||||||
"#signup-feedback",
|
'signup-feedback',
|
||||||
partial("layouts/alert",
|
partial: 'layouts/alert',
|
||||||
locals: {
|
locals: { type: "alert", message: InvisibleCaptcha.timestamp_error_message }
|
||||||
type: "alert",
|
|
||||||
message: InvisibleCaptcha.timestamp_error_message
|
|
||||||
})
|
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -3,7 +3,6 @@
|
|||||||
class UserConfirmationsController < DeviseController
|
class UserConfirmationsController < DeviseController
|
||||||
# Needed for access to current_ability, so we can authorize! actions
|
# Needed for access to current_ability, so we can authorize! actions
|
||||||
include Spree::Core::ControllerHelpers::Auth
|
include Spree::Core::ControllerHelpers::Auth
|
||||||
include CablecarResponses
|
|
||||||
|
|
||||||
# GET /resource/confirmation?confirmation_token=abcdef
|
# GET /resource/confirmation?confirmation_token=abcdef
|
||||||
def show
|
def show
|
||||||
@@ -29,12 +28,12 @@ class UserConfirmationsController < DeviseController
|
|||||||
set_flash_message(:error, :confirmation_not_sent)
|
set_flash_message(:error, :confirmation_not_sent)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
render cable_ready: cable_car.inner_html(
|
flash.now[:sucess] = t("devise.confirmations.send_instructions")
|
||||||
"##{params[:tab] || 'forgot'}-feedback",
|
|
||||||
partial("layouts/alert",
|
return render turbo_stream: turbo_stream.update(
|
||||||
locals: { type: "success", message: t("devise.confirmations.send_instructions") })
|
"#{params[:tab] || 'forgot'}-feedback",
|
||||||
|
partial: 'shared/flashes', locals: { flashes: flash }
|
||||||
)
|
)
|
||||||
return
|
|
||||||
end
|
end
|
||||||
|
|
||||||
respond_with_navigational(resource){ redirect_to login_path }
|
respond_with_navigational(resource){ redirect_to login_path }
|
||||||
|
|||||||
@@ -1,37 +1,40 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class UserPasswordsController < Spree::UserPasswordsController
|
class UserPasswordsController < Spree::UserPasswordsController
|
||||||
include CablecarResponses
|
|
||||||
|
|
||||||
layout 'darkswarm'
|
layout 'darkswarm'
|
||||||
|
|
||||||
def create
|
def create
|
||||||
return render_unconfirmed_response if user_unconfirmed?
|
return render_unconfirmed_response if user_unconfirmed?
|
||||||
|
|
||||||
self.resource = resource_class.send_reset_password_instructions(raw_params[resource_name])
|
self.resource = resource_class.send_reset_password_instructions(raw_params[resource_name])
|
||||||
|
status = :ok
|
||||||
|
|
||||||
if resource.errors.empty?
|
if resource.errors.empty?
|
||||||
render cable_ready: cable_car.inner_html(
|
message, type = [t(:password_reset_sent), :success]
|
||||||
"#forgot-feedback",
|
|
||||||
partial("layouts/alert", locals: { type: "success", message: t(:password_reset_sent) })
|
|
||||||
)
|
|
||||||
else
|
else
|
||||||
render status: :not_found, cable_ready: cable_car.inner_html(
|
message, type = [t(:email_not_found), :alert]
|
||||||
"#forgot-feedback",
|
status = :not_found
|
||||||
partial("layouts/alert", locals: { type: "alert", message: t(:email_not_found) })
|
|
||||||
)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
render turbo_stream: turbo_stream.update(
|
||||||
|
'forgot-feedback',
|
||||||
|
partial: 'layouts/alert',
|
||||||
|
locals: { type:, message:, tab: 'forgot',
|
||||||
|
unconfirmed: false, email: params.dig(:spree_user, :email) }
|
||||||
|
), status:
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def render_unconfirmed_response
|
def render_unconfirmed_response
|
||||||
render status: :unprocessable_entity, cable_ready: cable_car.inner_html(
|
message, type, unconfirmed, tab = [t(:email_unconfirmed), :alert, true, 'forgot']
|
||||||
"#forgot-feedback",
|
|
||||||
partial("layouts/alert",
|
render turbo_stream: turbo_stream.update(
|
||||||
locals: { type: "alert", message: t(:email_unconfirmed),
|
'forgot-feedback',
|
||||||
unconfirmed: true, tab: "forgot" })
|
partial: 'layouts/alert',
|
||||||
)
|
locals: { type:, message:, tab:,
|
||||||
|
unconfirmed:, email: params.dig(:spree_user, :email) }
|
||||||
|
), status: :unprocessable_entity
|
||||||
end
|
end
|
||||||
|
|
||||||
def user_unconfirmed?
|
def user_unconfirmed?
|
||||||
|
|||||||
@@ -74,6 +74,21 @@ module ApplicationHelper
|
|||||||
|
|
||||||
# Update "v1" to invalidate existing cache key
|
# Update "v1" to invalidate existing cache key
|
||||||
def cache_key_with_locale(key, locale)
|
def cache_key_with_locale(key, locale)
|
||||||
Array.wrap(key) + ["v2", locale.to_s, I18nDigests.for_locale(locale)]
|
Array.wrap(key) + ["v3", locale.to_s, I18nDigests.for_locale(locale)]
|
||||||
|
end
|
||||||
|
|
||||||
|
def pdf_stylesheet_pack_tag(source)
|
||||||
|
# With shakapacker dev server running, the wicked_pdf_stylesheet_pack_tag will produce a
|
||||||
|
# relative path, because we don't have `config.action_controller.asset_host`. Relative path
|
||||||
|
# can't be resolved by `wkhtmltopdf`. So we pass the wepacker dev server host and port to
|
||||||
|
# the shakapacker helper, so it generates the correct url.
|
||||||
|
# For more info: https://stackoverflow.com/questions/58490299/how-to-include-css-stylesheet-into-wicked-pdf/60541688#60541688
|
||||||
|
if running_in_development?
|
||||||
|
options = { media: "all",
|
||||||
|
host: "#{Shakapacker.dev_server.host}:#{Shakapacker.dev_server.port}" }
|
||||||
|
stylesheet_pack_tag(source, **options)
|
||||||
|
else
|
||||||
|
wicked_pdf_stylesheet_pack_tag(source)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -34,29 +34,8 @@ module ReportsHelper
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def fee_name_options(orders)
|
|
||||||
EnterpriseFee.where(id: enterprise_fee_ids(orders))
|
|
||||||
.pluck(:name, :id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def fee_owner_options(orders)
|
|
||||||
Enterprise.where(id: enterprise_fee_owner_ids(orders))
|
|
||||||
.pluck(:name, :id)
|
|
||||||
end
|
|
||||||
|
|
||||||
delegate :currency_symbol, to: :'Spree::Money'
|
delegate :currency_symbol, to: :'Spree::Money'
|
||||||
|
|
||||||
def enterprise_fee_owner_ids(orders)
|
|
||||||
EnterpriseFee.where(id: enterprise_fee_ids(orders))
|
|
||||||
.pluck(:enterprise_id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def enterprise_fee_ids(orders)
|
|
||||||
Spree::Adjustment.enterprise_fee
|
|
||||||
.where(order_id: orders.map(&:id))
|
|
||||||
.pluck(:originator_id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def datepicker_time(datetime)
|
def datepicker_time(datetime)
|
||||||
datetime = Time.zone.parse(datetime) if datetime.is_a? String
|
datetime = Time.zone.parse(datetime) if datetime.is_a? String
|
||||||
datetime.strftime('%Y-%m-%d %H:%M')
|
datetime.strftime('%Y-%m-%d %H:%M')
|
||||||
|
|||||||
18
app/helpers/spree/admin/payment_methods_helper.rb
Normal file
18
app/helpers/spree/admin/payment_methods_helper.rb
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Spree
|
||||||
|
module Admin
|
||||||
|
module PaymentMethodsHelper
|
||||||
|
def payment_method_type_name(class_name)
|
||||||
|
scope = "spree.admin.payment_methods.providers"
|
||||||
|
key = class_name.demodulize.downcase
|
||||||
|
|
||||||
|
I18n.t(key, scope:)
|
||||||
|
end
|
||||||
|
|
||||||
|
def payment_method_type_options(providers)
|
||||||
|
providers.map { |p| [payment_method_type_name(p), p] }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -6,11 +6,9 @@ class PaymentMailer < ApplicationMailer
|
|||||||
def authorize_payment(payment)
|
def authorize_payment(payment)
|
||||||
@payment = payment
|
@payment = payment
|
||||||
@order = @payment.order
|
@order = @payment.order
|
||||||
subject = I18n.t('spree.payment_mailer.authorize_payment.subject',
|
|
||||||
distributor: @order.distributor.name)
|
|
||||||
I18n.with_locale valid_locale(@order.user) do
|
I18n.with_locale valid_locale(@order.user) do
|
||||||
mail(to: @order.email,
|
mail(to: @order.email,
|
||||||
subject:,
|
subject: default_i18n_subject(distributor: @order.distributor.name),
|
||||||
reply_to: @order.distributor.contact.email)
|
reply_to: @order.distributor.contact.email)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -18,11 +16,20 @@ class PaymentMailer < ApplicationMailer
|
|||||||
def authorization_required(payment)
|
def authorization_required(payment)
|
||||||
@order = payment.order
|
@order = payment.order
|
||||||
shop_owner = @order.distributor.owner
|
shop_owner = @order.distributor.owner
|
||||||
subject = I18n.t('spree.payment_mailer.authorization_required.subject',
|
|
||||||
order: @order)
|
|
||||||
I18n.with_locale valid_locale(shop_owner) do
|
I18n.with_locale valid_locale(shop_owner) do
|
||||||
mail(to: shop_owner.email,
|
mail(to: shop_owner.email, reply_to: @order.email)
|
||||||
subject:,
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def refund_available(payment, taler_order_status_url)
|
||||||
|
@order = payment.order
|
||||||
|
@shop = @order.distributor.name
|
||||||
|
@amount = payment.display_amount
|
||||||
|
@taler_order_status_url = taler_order_status_url
|
||||||
|
|
||||||
|
I18n.with_locale valid_locale(@order.user) do
|
||||||
|
mail(to: @order.email,
|
||||||
|
subject: default_i18n_subject(shop: @shop),
|
||||||
reply_to: @order.email)
|
reply_to: @order.email)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ class Invoice < ApplicationRecord
|
|||||||
self.belongs_to_required_by_default = false
|
self.belongs_to_required_by_default = false
|
||||||
|
|
||||||
belongs_to :order, class_name: 'Spree::Order'
|
belongs_to :order, class_name: 'Spree::Order'
|
||||||
serialize :data, Hash, coder: YAML
|
serialize :data, type: Hash, coder: YAML
|
||||||
before_validation :serialize_order
|
before_validation :serialize_order
|
||||||
after_create :cancel_previous_invoices
|
after_create :cancel_previous_invoices
|
||||||
default_scope { order(created_at: :desc) }
|
default_scope { order(created_at: :desc) }
|
||||||
|
|||||||
@@ -95,8 +95,8 @@ class Invoice
|
|||||||
def display_line_item_tax_rate(item)
|
def display_line_item_tax_rate(item)
|
||||||
all_tax_adjustments.select { |a|
|
all_tax_adjustments.select { |a|
|
||||||
a.adjustable.type == 'Spree::LineItem' && a.adjustable.id == item.id
|
a.adjustable.type == 'Spree::LineItem' && a.adjustable.id == item.id
|
||||||
}.map(&:originator).map { |tr|
|
}.map(&:originator).map(&:amount).sort.map { |amount|
|
||||||
number_to_percentage(tr.amount * 100, precision: 1)
|
number_to_percentage(amount * 100, precision: 1)
|
||||||
}.join(", ")
|
}.join(", ")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -4,5 +4,5 @@ class ReportRenderingOptions < ApplicationRecord
|
|||||||
self.belongs_to_required_by_default = false
|
self.belongs_to_required_by_default = false
|
||||||
|
|
||||||
belongs_to :user, class_name: "Spree::User"
|
belongs_to :user, class_name: "Spree::User"
|
||||||
serialize :options, Hash, coder: YAML
|
serialize :options, type: Hash, coder: YAML
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -6,6 +6,11 @@ module Spree
|
|||||||
class Ability
|
class Ability
|
||||||
include CanCan::Ability
|
include CanCan::Ability
|
||||||
|
|
||||||
|
REPORTS_SEARCH_ACTIONS = [
|
||||||
|
:search_enterprise_fees, :search_enterprise_fee_owners, :search_distributors,
|
||||||
|
:search_suppliers, :search_order_cycles, :search_order_customers
|
||||||
|
].freeze
|
||||||
|
|
||||||
def initialize(user)
|
def initialize(user)
|
||||||
clear_aliased_actions
|
clear_aliased_actions
|
||||||
|
|
||||||
@@ -260,7 +265,8 @@ module Spree
|
|||||||
can [:admin, :index, :import], ::Admin::DfcProductImportsController
|
can [:admin, :index, :import], ::Admin::DfcProductImportsController
|
||||||
|
|
||||||
# Reports page
|
# Reports page
|
||||||
can [:admin, :index, :show, :create], ::Admin::ReportsController
|
can [:admin, :index, :show, :create, *REPORTS_SEARCH_ACTIONS],
|
||||||
|
::Admin::ReportsController
|
||||||
can [:admin, :show, :create, :customers, :orders_and_distributors, :group_buys, :payments,
|
can [:admin, :show, :create, :customers, :orders_and_distributors, :group_buys, :payments,
|
||||||
:orders_and_fulfillment, :products_and_inventory, :order_cycle_management,
|
:orders_and_fulfillment, :products_and_inventory, :order_cycle_management,
|
||||||
:packing, :enterprise_fee_summary, :bulk_coop, :suppliers], :report
|
:packing, :enterprise_fee_summary, :bulk_coop, :suppliers], :report
|
||||||
@@ -392,7 +398,7 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Reports page
|
# Reports page
|
||||||
can [:admin, :index, :show, :create], ::Admin::ReportsController
|
can [:admin, :index, :show, :create, *REPORTS_SEARCH_ACTIONS], ::Admin::ReportsController
|
||||||
can [:admin, :customers, :group_buys, :sales_tax, :payments,
|
can [:admin, :customers, :group_buys, :sales_tax, :payments,
|
||||||
:orders_and_distributors, :orders_and_fulfillment, :products_and_inventory,
|
:orders_and_distributors, :orders_and_fulfillment, :products_and_inventory,
|
||||||
:order_cycle_management, :xero_invoices, :enterprise_fee_summary, :bulk_coop], :report
|
:order_cycle_management, :xero_invoices, :enterprise_fee_summary, :bulk_coop], :report
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ module Spree
|
|||||||
acts_as_taggable
|
acts_as_taggable
|
||||||
include PaymentMethodDistributors
|
include PaymentMethodDistributors
|
||||||
|
|
||||||
delegate :authorize, :purchase, :capture, :void, :credit, to: :provider
|
delegate :authorize, :purchase, :capture, :void, :credit, :refund, to: :provider
|
||||||
|
|
||||||
validates :name, :type, presence: true
|
validates :name, :type, presence: true
|
||||||
|
|
||||||
@@ -35,6 +35,10 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
def method_missing(method, *)
|
def method_missing(method, *)
|
||||||
|
message = "Deprecated delegation of Gateway##{method}"
|
||||||
|
Alert.raise(message)
|
||||||
|
raise message if Rails.env.local?
|
||||||
|
|
||||||
if @provider.nil? || !@provider.respond_to?(method)
|
if @provider.nil? || !@provider.respond_to?(method)
|
||||||
super
|
super
|
||||||
else
|
else
|
||||||
@@ -42,10 +46,6 @@ module Spree
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def payment_profiles_supported?
|
|
||||||
false
|
|
||||||
end
|
|
||||||
|
|
||||||
def method_type
|
def method_type
|
||||||
'gateway'
|
'gateway'
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -35,10 +35,6 @@ module Spree
|
|||||||
ActiveMerchant::Billing::StripePaymentIntentsGateway
|
ActiveMerchant::Billing::StripePaymentIntentsGateway
|
||||||
end
|
end
|
||||||
|
|
||||||
def payment_profiles_supported?
|
|
||||||
true
|
|
||||||
end
|
|
||||||
|
|
||||||
def stripe_account_id
|
def stripe_account_id
|
||||||
StripeAccount.find_by(enterprise_id: preferred_enterprise_id)&.stripe_user_id
|
StripeAccount.find_by(enterprise_id: preferred_enterprise_id)&.stripe_user_id
|
||||||
end
|
end
|
||||||
@@ -84,7 +80,7 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
# NOTE: this method is required by Spree::Payment::Processing
|
# NOTE: this method is required by Spree::Payment::Processing
|
||||||
def void(payment_intent_id, _creditcard, gateway_options)
|
def void(payment_intent_id, gateway_options)
|
||||||
payment_intent_response = Stripe::PaymentIntent.retrieve(
|
payment_intent_response = Stripe::PaymentIntent.retrieve(
|
||||||
payment_intent_id, stripe_account: stripe_account_id
|
payment_intent_id, stripe_account: stripe_account_id
|
||||||
)
|
)
|
||||||
@@ -101,7 +97,13 @@ module Spree
|
|||||||
end
|
end
|
||||||
|
|
||||||
# NOTE: this method is required by Spree::Payment::Processing
|
# NOTE: this method is required by Spree::Payment::Processing
|
||||||
def credit(money, _creditcard, payment_intent_id, gateway_options)
|
def credit(money, payment_intent_id, gateway_options)
|
||||||
|
gateway_options[:stripe_account] = stripe_account_id
|
||||||
|
provider.refund(money, payment_intent_id, gateway_options)
|
||||||
|
end
|
||||||
|
|
||||||
|
# NOTE: this method is required by Spree::Payment::Processing
|
||||||
|
def refund(money, payment_intent_id, gateway_options)
|
||||||
gateway_options[:stripe_account] = stripe_account_id
|
gateway_options[:stripe_account] = stripe_account_id
|
||||||
provider.refund(money, payment_intent_id, gateway_options)
|
provider.refund(money, payment_intent_id, gateway_options)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -24,6 +24,8 @@ module Spree
|
|||||||
before_validation :copy_price
|
before_validation :copy_price
|
||||||
before_validation :copy_tax_category
|
before_validation :copy_tax_category
|
||||||
before_validation :copy_dimensions
|
before_validation :copy_dimensions
|
||||||
|
before_validation :copy_product_name, on: :create
|
||||||
|
before_validation :copy_variant_name, on: :create
|
||||||
|
|
||||||
validates :quantity, numericality: {
|
validates :quantity, numericality: {
|
||||||
only_integer: true,
|
only_integer: true,
|
||||||
@@ -250,6 +252,18 @@ module Spree
|
|||||||
adjustments.enterprise_fee
|
adjustments.enterprise_fee
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def full_variant_name
|
||||||
|
return variant_name if variant_name.present?
|
||||||
|
|
||||||
|
variant.full_name
|
||||||
|
end
|
||||||
|
|
||||||
|
def full_product_name
|
||||||
|
return product_name if product_name.present?
|
||||||
|
|
||||||
|
variant.product.name
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def computed_weight_from_variant
|
def computed_weight_from_variant
|
||||||
@@ -274,6 +288,18 @@ module Spree
|
|||||||
order.create_tax_charge!
|
order.create_tax_charge!
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def copy_product_name
|
||||||
|
return if variant.nil? || variant.product.nil?
|
||||||
|
|
||||||
|
self.product_name = variant.product.name
|
||||||
|
end
|
||||||
|
|
||||||
|
def copy_variant_name
|
||||||
|
return if variant.nil?
|
||||||
|
|
||||||
|
self.variant_name = variant.full_name
|
||||||
|
end
|
||||||
|
|
||||||
def update_inventory_before_destroy
|
def update_inventory_before_destroy
|
||||||
# This is necessary before destroying the line item
|
# This is necessary before destroying the line item
|
||||||
# so that update_inventory will restore stock to the variant
|
# so that update_inventory will restore stock to the variant
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ module Spree
|
|||||||
|
|
||||||
# invalidate previously entered payments
|
# invalidate previously entered payments
|
||||||
after_create :invalidate_old_payments
|
after_create :invalidate_old_payments
|
||||||
after_save :create_payment_profile, if: :profiles_supported?
|
after_save :create_payment_profile
|
||||||
|
|
||||||
# update the order totals, etc.
|
# update the order totals, etc.
|
||||||
after_save :ensure_correct_adjustment, :update_order
|
after_save :ensure_correct_adjustment, :update_order
|
||||||
@@ -217,18 +217,13 @@ module Spree
|
|||||||
errors.blank?
|
errors.blank?
|
||||||
end
|
end
|
||||||
|
|
||||||
def profiles_supported?
|
|
||||||
payment_method.respond_to?(:payment_profiles_supported?) &&
|
|
||||||
payment_method.payment_profiles_supported?
|
|
||||||
end
|
|
||||||
|
|
||||||
def create_payment_profile
|
def create_payment_profile
|
||||||
return unless source.is_a?(CreditCard)
|
return unless source.is_a?(CreditCard)
|
||||||
return unless source.try(:save_requested_by_customer?)
|
return unless source.try(:save_requested_by_customer?)
|
||||||
return unless source.number || source.gateway_payment_profile_id
|
return unless source.number || source.gateway_payment_profile_id
|
||||||
return unless source.gateway_customer_profile_id.nil?
|
return unless source.gateway_customer_profile_id.nil?
|
||||||
|
|
||||||
payment_method.create_profile(self)
|
payment_method.try(:create_profile, self)
|
||||||
rescue ActiveMerchant::ConnectionError => e
|
rescue ActiveMerchant::ConnectionError => e
|
||||||
gateway_error e
|
gateway_error e
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -58,16 +58,7 @@ module Spree
|
|||||||
protect_from_connection_error do
|
protect_from_connection_error do
|
||||||
check_environment
|
check_environment
|
||||||
|
|
||||||
response = if payment_method.payment_profiles_supported?
|
response = payment_method.void(response_code, gateway_options)
|
||||||
# Gateways supporting payment profiles will need access to credit
|
|
||||||
# card object because this stores the payment profile information
|
|
||||||
# so supply the authorization itself as well as the credit card,
|
|
||||||
# rather than just the authorization code
|
|
||||||
payment_method.void(response_code, source, gateway_options)
|
|
||||||
else
|
|
||||||
# Standard ActiveMerchant void usage
|
|
||||||
payment_method.void(response_code, gateway_options)
|
|
||||||
end
|
|
||||||
|
|
||||||
record_response(response)
|
record_response(response)
|
||||||
|
|
||||||
@@ -86,20 +77,11 @@ module Spree
|
|||||||
|
|
||||||
credit_amount = calculate_refund_amount(credit_amount)
|
credit_amount = calculate_refund_amount(credit_amount)
|
||||||
|
|
||||||
response = if payment_method.payment_profiles_supported?
|
response = payment_method.credit(
|
||||||
payment_method.credit(
|
(credit_amount * 100).round,
|
||||||
(credit_amount * 100).round,
|
response_code,
|
||||||
source,
|
gateway_options
|
||||||
response_code,
|
)
|
||||||
gateway_options
|
|
||||||
)
|
|
||||||
else
|
|
||||||
payment_method.credit(
|
|
||||||
(credit_amount * 100).round,
|
|
||||||
response_code,
|
|
||||||
gateway_options
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
record_response(response)
|
record_response(response)
|
||||||
|
|
||||||
@@ -125,20 +107,11 @@ module Spree
|
|||||||
|
|
||||||
refund_amount = calculate_refund_amount(refund_amount)
|
refund_amount = calculate_refund_amount(refund_amount)
|
||||||
|
|
||||||
response = if payment_method.payment_profiles_supported?
|
response = payment_method.refund(
|
||||||
payment_method.refund(
|
(refund_amount * 100).round,
|
||||||
(refund_amount * 100).round,
|
response_code,
|
||||||
source,
|
gateway_options
|
||||||
response_code,
|
)
|
||||||
gateway_options
|
|
||||||
)
|
|
||||||
else
|
|
||||||
payment_method.refund(
|
|
||||||
(refund_amount * 100).round,
|
|
||||||
response_code,
|
|
||||||
gateway_options
|
|
||||||
)
|
|
||||||
end
|
|
||||||
|
|
||||||
record_response(response)
|
record_response(response)
|
||||||
|
|
||||||
@@ -183,6 +156,7 @@ module Spree
|
|||||||
|
|
||||||
options.merge!({ billing_address: order.bill_address.try(:active_merchant_hash),
|
options.merge!({ billing_address: order.bill_address.try(:active_merchant_hash),
|
||||||
shipping_address: order.ship_address.try(:active_merchant_hash) })
|
shipping_address: order.ship_address.try(:active_merchant_hash) })
|
||||||
|
options.merge!(payment: self)
|
||||||
|
|
||||||
options
|
options
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -93,10 +93,6 @@ module Spree
|
|||||||
unscoped { find(*) }
|
unscoped { find(*) }
|
||||||
end
|
end
|
||||||
|
|
||||||
def payment_profiles_supported?
|
|
||||||
false
|
|
||||||
end
|
|
||||||
|
|
||||||
def source_required?
|
def source_required?
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
@@ -113,11 +109,6 @@ module Spree
|
|||||||
distributors.include?(distributor)
|
distributors.include?(distributor)
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.clean_name
|
|
||||||
scope = "spree.admin.payment_methods.providers"
|
|
||||||
I18n.t(name.demodulize.downcase, scope:)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def distributor_validation
|
def distributor_validation
|
||||||
|
|||||||
118
app/models/spree/payment_method/taler.rb
Normal file
118
app/models/spree/payment_method/taler.rb
Normal file
@@ -0,0 +1,118 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require "taler"
|
||||||
|
|
||||||
|
module Spree
|
||||||
|
class PaymentMethod
|
||||||
|
# GNU Taler is a distributed, open source payment system.
|
||||||
|
# You need a hosted Taler backend server to process payments.
|
||||||
|
#
|
||||||
|
# For testing, you can use the official demo backend:
|
||||||
|
#
|
||||||
|
# - Merchant UX: https://backend.demo.taler.net
|
||||||
|
# - Username: sandbox
|
||||||
|
# - Password: sandbox
|
||||||
|
#
|
||||||
|
# Configure this payment method for testing with:
|
||||||
|
#
|
||||||
|
# - backend_url: https://backend.demo.taler.net/instances/sandbox
|
||||||
|
# - api_key: sandbox
|
||||||
|
class Taler < PaymentMethod
|
||||||
|
preference :backend_url, :string
|
||||||
|
preference :api_key, :password
|
||||||
|
|
||||||
|
def actions
|
||||||
|
%w{void}
|
||||||
|
end
|
||||||
|
|
||||||
|
def can_void?(payment)
|
||||||
|
payment.state == "completed"
|
||||||
|
end
|
||||||
|
|
||||||
|
# Name of the view to display during checkout
|
||||||
|
def method_type
|
||||||
|
"check" # empty view
|
||||||
|
end
|
||||||
|
|
||||||
|
def external_gateway?
|
||||||
|
true
|
||||||
|
end
|
||||||
|
|
||||||
|
# The backend provides this URL. It can look like this:
|
||||||
|
# https://backend.demo.taler.net/instances/blog/orders/2026..?token=S8Y..&session_id=b0b..
|
||||||
|
def external_payment_url(options)
|
||||||
|
order = options.fetch(:order)
|
||||||
|
payment = load_payment(order)
|
||||||
|
|
||||||
|
payment.source ||= self
|
||||||
|
payment.response_code ||= create_taler_order(payment)
|
||||||
|
payment.save! if payment.changed?
|
||||||
|
|
||||||
|
taler_order.status_url
|
||||||
|
end
|
||||||
|
|
||||||
|
# Main method called by Spree::Payment::Processing during checkout
|
||||||
|
# when the user is redirected back to the app.
|
||||||
|
#
|
||||||
|
# The payment has already been made and we need to verify the success.
|
||||||
|
def purchase(_money, _source, gateway_options)
|
||||||
|
payment = gateway_options[:payment]
|
||||||
|
|
||||||
|
return unless payment.response_code
|
||||||
|
|
||||||
|
taler_order = taler_order(id: payment.response_code)
|
||||||
|
status = taler_order.fetch("order_status")
|
||||||
|
success = (status == "paid")
|
||||||
|
message = I18n.t(status, default: status, scope: "taler.order_status")
|
||||||
|
|
||||||
|
ActiveMerchant::Billing::Response.new(success, message)
|
||||||
|
end
|
||||||
|
|
||||||
|
def void(response_code, gateway_options)
|
||||||
|
payment = gateway_options[:payment]
|
||||||
|
taler_order = taler_order(id: response_code)
|
||||||
|
status = taler_order.fetch("order_status")
|
||||||
|
|
||||||
|
if status == "claimed"
|
||||||
|
return ActiveMerchant::Billing::Response.new(true, "Already expired")
|
||||||
|
end
|
||||||
|
|
||||||
|
raise "Unsupported action" if status != "paid"
|
||||||
|
|
||||||
|
amount = taler_order.fetch("contract_terms")["amount"]
|
||||||
|
taler_order.refund(refund: amount, reason: "void")
|
||||||
|
|
||||||
|
PaymentMailer.refund_available(payment, taler_order.status_url).deliver_later
|
||||||
|
|
||||||
|
ActiveMerchant::Billing::Response.new(true, "Refund initiated")
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def load_payment(order)
|
||||||
|
order.payments.checkout.where(payment_method: self).last
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_taler_order(payment)
|
||||||
|
# We are ignoring currency for now so that we can test with the
|
||||||
|
# current demo backend only working with the KUDOS currency.
|
||||||
|
taler_amount = "KUDOS:#{payment.amount}"
|
||||||
|
urls = Rails.application.routes.url_helpers
|
||||||
|
fulfillment_url = urls.payment_gateways_confirm_taler_url(payment_id: payment.id)
|
||||||
|
taler_order.create(
|
||||||
|
amount: taler_amount,
|
||||||
|
summary: I18n.t("payment_method_taler.order_summary"),
|
||||||
|
fulfillment_url:,
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
def taler_order(id: nil)
|
||||||
|
@taler_order ||= ::Taler::Order.new(
|
||||||
|
backend_url: preferred_backend_url,
|
||||||
|
password: preferred_api_key,
|
||||||
|
id:,
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -251,7 +251,7 @@ module Spree
|
|||||||
transaction do
|
transaction do
|
||||||
ExchangeVariant.
|
ExchangeVariant.
|
||||||
where(exchange_variants: { variant_id: variants.with_deleted.
|
where(exchange_variants: { variant_id: variants.with_deleted.
|
||||||
select(:id) }).destroy_all
|
select(:id) }).destroy_all
|
||||||
|
|
||||||
yield
|
yield
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -35,8 +35,8 @@ module Spree
|
|||||||
taxons
|
taxons
|
||||||
.pluck('spree_taxons.id, enterprises.id AS enterprise_id')
|
.pluck('spree_taxons.id, enterprises.id AS enterprise_id')
|
||||||
.each_with_object({}) do |(taxon_id, enterprise_id), collection|
|
.each_with_object({}) do |(taxon_id, enterprise_id), collection|
|
||||||
collection[enterprise_id.to_i] ||= Set.new
|
collection[enterprise_id.to_i] ||= Set.new
|
||||||
collection[enterprise_id.to_i] << taxon_id
|
collection[enterprise_id.to_i] << taxon_id
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -167,8 +167,8 @@ module Spree
|
|||||||
# In Rails 3, merging two scopes on the same column will consider only the last scope.
|
# In Rails 3, merging two scopes on the same column will consider only the last scope.
|
||||||
def self.in_distributor(distributor)
|
def self.in_distributor(distributor)
|
||||||
where(id: ExchangeVariant.select(:variant_id).
|
where(id: ExchangeVariant.select(:variant_id).
|
||||||
joins(:exchange).
|
joins(:exchange).
|
||||||
where('exchanges.incoming = ? AND exchanges.receiver_id = ?', false, distributor))
|
where('exchanges.incoming = ? AND exchanges.receiver_id = ?', false, distributor))
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.indexed
|
def self.indexed
|
||||||
@@ -179,11 +179,11 @@ module Spree
|
|||||||
# "where(id:" is necessary so that the returned relation has no includes
|
# "where(id:" is necessary so that the returned relation has no includes
|
||||||
# The relation without includes will not be readonly and allow updates on it
|
# The relation without includes will not be readonly and allow updates on it
|
||||||
where(spree_variants: { id: joins(:prices).
|
where(spree_variants: { id: joins(:prices).
|
||||||
where(deleted_at: nil).
|
where(deleted_at: nil).
|
||||||
where('spree_prices.currency' =>
|
where('spree_prices.currency' =>
|
||||||
currency || CurrentConfig.get(:currency)).
|
currency || CurrentConfig.get(:currency)).
|
||||||
where.not(spree_prices: { amount: nil }).
|
where.not(spree_prices: { amount: nil }).
|
||||||
select("spree_variants.id") })
|
select("spree_variants.id") })
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.linked_to(semantic_id)
|
def self.linked_to(semantic_id)
|
||||||
|
|||||||
@@ -60,8 +60,8 @@ class ProductScopeQuery
|
|||||||
|
|
||||||
def product_query_includes
|
def product_query_includes
|
||||||
[
|
[
|
||||||
image: { attachment_attachment: :blob },
|
{ image: { attachment_attachment: :blob },
|
||||||
variants: [:default_price, :stock_items, :variant_overrides]
|
variants: [:default_price, :stock_items, :variant_overrides] }
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -42,10 +42,10 @@ class DfcCatalogImporter
|
|||||||
.includes(:semantic_links).references(:semantic_links)
|
.includes(:semantic_links).references(:semantic_links)
|
||||||
.where.not(semantic_links: { semantic_id: present_ids })
|
.where.not(semantic_links: { semantic_id: present_ids })
|
||||||
.select do |variant|
|
.select do |variant|
|
||||||
# Variants that were in the same catalog before:
|
# Variants that were in the same catalog before:
|
||||||
variant.semantic_links.map(&:semantic_id).any? do |semantic_id|
|
variant.semantic_links.map(&:semantic_id).any? do |semantic_id|
|
||||||
FdcUrlBuilder.new(semantic_id).catalog_url == catalog_url
|
FdcUrlBuilder.new(semantic_id).catalog_url == catalog_url
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -51,8 +51,8 @@ class LineItemSyncer
|
|||||||
def destroy_obsolete_items(order)
|
def destroy_obsolete_items(order)
|
||||||
order.line_items.
|
order.line_items.
|
||||||
where(variant_id: subscription_line_items.
|
where(variant_id: subscription_line_items.
|
||||||
select(&:marked_for_destruction?).
|
select(&:marked_for_destruction?).
|
||||||
map(&:variant_id)).
|
map(&:variant_id)).
|
||||||
destroy_all
|
destroy_all
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -77,7 +77,7 @@ class LineItemSyncer
|
|||||||
end
|
end
|
||||||
|
|
||||||
def add_order_update_issue(order, line_item)
|
def add_order_update_issue(order, line_item)
|
||||||
issue_description = "#{line_item.product.name} - #{line_item.variant.full_name}"
|
issue_description = "#{line_item.product.name} - #{line_item.full_variant_name}"
|
||||||
issue_description << " - #{stock_issue_description(line_item)}" if line_item.insufficient_stock?
|
issue_description << " - #{stock_issue_description(line_item)}" if line_item.insufficient_stock?
|
||||||
order_update_issues.add(order, issue_description)
|
order_update_issues.add(order, issue_description)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -130,12 +130,11 @@ module Orders
|
|||||||
|
|
||||||
def order_cycle_fees
|
def order_cycle_fees
|
||||||
return @order_cycle_fees if defined? @order_cycle_fees
|
return @order_cycle_fees if defined? @order_cycle_fees
|
||||||
|
return [] unless order_cycle && distributor
|
||||||
|
|
||||||
@order_cycle_fees = begin
|
@order_cycle_fees = begin
|
||||||
fees = []
|
fees = []
|
||||||
|
|
||||||
return fees unless order_cycle && distributor
|
|
||||||
|
|
||||||
order_cycle.exchanges.supplying_to(distributor).each do |exchange|
|
order_cycle.exchanges.supplying_to(distributor).each do |exchange|
|
||||||
exchange.enterprise_fees.per_item.each do |enterprise_fee|
|
exchange.enterprise_fees.per_item.each do |enterprise_fee|
|
||||||
fee_value = FeeValue.new(fee: enterprise_fee, role: exchange.role)
|
fee_value = FeeValue.new(fee: enterprise_fee, role: exchange.role)
|
||||||
|
|||||||
@@ -14,12 +14,12 @@ module PermittedAttributes
|
|||||||
|
|
||||||
def self.attributes
|
def self.attributes
|
||||||
basic_permitted_attributes + [
|
basic_permitted_attributes + [
|
||||||
group_ids: [], user_ids: [],
|
{ group_ids: [], user_ids: [],
|
||||||
shipping_method_ids: [], payment_method_ids: [],
|
shipping_method_ids: [], payment_method_ids: [],
|
||||||
address_attributes: PermittedAttributes::Address.attributes,
|
address_attributes: PermittedAttributes::Address.attributes,
|
||||||
business_address_attributes: PermittedAttributes::BusinessAddress.attributes,
|
business_address_attributes: PermittedAttributes::BusinessAddress.attributes,
|
||||||
producer_properties_attributes: [:id, :property_name, :value, :_destroy],
|
producer_properties_attributes: [:id, :property_name, :value, :_destroy],
|
||||||
custom_tab_attributes: PermittedAttributes::CustomTab.attributes,
|
custom_tab_attributes: PermittedAttributes::CustomTab.attributes },
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -25,8 +25,8 @@ module PermittedAttributes
|
|||||||
private
|
private
|
||||||
|
|
||||||
def attributes
|
def attributes
|
||||||
self.class.basic_attributes + [incoming_exchanges: permitted_exchange_attributes,
|
self.class.basic_attributes + [{ incoming_exchanges: permitted_exchange_attributes,
|
||||||
outgoing_exchanges: permitted_exchange_attributes]
|
outgoing_exchanges: permitted_exchange_attributes }]
|
||||||
end
|
end
|
||||||
|
|
||||||
def permitted_exchange_attributes
|
def permitted_exchange_attributes
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ module PermittedAttributes
|
|||||||
[:name, :description, :type, :active,
|
[:name, :description, :type, :active,
|
||||||
:environment, :display_on, :tag_list,
|
:environment, :display_on, :tag_list,
|
||||||
:preferred_enterprise_id, :preferred_server, :preferred_login, :preferred_password,
|
:preferred_enterprise_id, :preferred_server, :preferred_login, :preferred_password,
|
||||||
:calculator_type, :preferred_api_key,
|
:calculator_type, :preferred_api_key, :preferred_backend_url,
|
||||||
:preferred_signature, :preferred_solution, :preferred_landing_page, :preferred_logourl,
|
:preferred_signature, :preferred_solution, :preferred_landing_page, :preferred_logourl,
|
||||||
:preferred_test_mode, :calculator_type, { distributor_ids: [] },
|
:preferred_test_mode, :calculator_type, { distributor_ids: [] },
|
||||||
{ calculator_attributes: PermittedAttributes::Calculator.attributes }]
|
{ calculator_attributes: PermittedAttributes::Calculator.attributes }]
|
||||||
|
|||||||
@@ -26,11 +26,11 @@ module PermittedAttributes
|
|||||||
|
|
||||||
def other_permitted_attributes
|
def other_permitted_attributes
|
||||||
[
|
[
|
||||||
subscription_line_items_attributes: [
|
{ subscription_line_items_attributes: [
|
||||||
:id, :quantity, :variant_id, :price_estimate, :_destroy
|
:id, :quantity, :variant_id, :price_estimate, :_destroy
|
||||||
],
|
],
|
||||||
bill_address_attributes: PermittedAttributes::Address.attributes,
|
bill_address_attributes: PermittedAttributes::Address.attributes,
|
||||||
ship_address_attributes: PermittedAttributes::Address.attributes
|
ship_address_attributes: PermittedAttributes::Address.attributes }
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
%fieldset.no-border-top
|
%fieldset.no-border-top
|
||||||
.add_producer_properties
|
.add_producer_properties
|
||||||
= image_pack_tag 'images/spinner.gif', :plugin => 'spree', :style => 'display:none;', :id => 'busy_indicator'
|
= image_pack_tag 'spinner.gif', :plugin => 'spree', :style => 'display:none;', :id => 'busy_indicator'
|
||||||
%table.index.sortable{"data-sortable-link" => main_app.update_positions_admin_enterprise_producer_properties_url(@enterprise)}
|
%table.index.sortable{"data-sortable-link" => main_app.update_positions_admin_enterprise_producer_properties_url(@enterprise)}
|
||||||
%thead
|
%thead
|
||||||
%tr
|
%tr
|
||||||
|
|||||||
@@ -13,6 +13,8 @@
|
|||||||
= hidden_field_tag :search_term, @search_term
|
= hidden_field_tag :search_term, @search_term
|
||||||
= hidden_field_tag :producer_id, @producer_id
|
= hidden_field_tag :producer_id, @producer_id
|
||||||
= hidden_field_tag :category_id, @category_id
|
= hidden_field_tag :category_id, @category_id
|
||||||
|
- @tags.each do |tag|
|
||||||
|
= hidden_field_tag 'tags_name_in[]', tag
|
||||||
|
|
||||||
%table.products{ 'data-column-preferences-target': "table", class: (hide_producer_column?(producer_options) ? 'hide-producer' : '') }
|
%table.products{ 'data-column-preferences-target': "table", class: (hide_producer_column?(producer_options) ? 'hide-producer' : '') }
|
||||||
%colgroup
|
%colgroup
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
%td.col-sku.field.naked_inputs
|
%td.col-sku.field.naked_inputs
|
||||||
= f.text_field :sku, 'aria-label': t('admin.products_page.columns.sku')
|
= f.text_field :sku, 'aria-label': t('admin.products_page.columns.sku')
|
||||||
= error_message_on variant, :sku
|
= error_message_on variant, :sku
|
||||||
%td.col-unir_scale.field.naked_inputs{ 'data-controller': 'toggle-control', 'data-toggle-control-match-value': 'items' }
|
%td.col-unit_scale.field.naked_inputs{ 'data-controller': 'toggle-control', 'data-toggle-control-match-value': 'items' }
|
||||||
= f.hidden_field :variant_unit
|
= f.hidden_field :variant_unit
|
||||||
= f.hidden_field :variant_unit_scale
|
= f.hidden_field :variant_unit_scale
|
||||||
= f.select :variant_unit_with_scale,
|
= f.select :variant_unit_with_scale,
|
||||||
|
|||||||
@@ -1,23 +1,50 @@
|
|||||||
|
- search_url_query = {report_type: :enterprise_fee_summary, report_subtype: :enterprise_fees_with_tax_report_by_order}
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_hubs)
|
.alpha.two.columns= label_tag nil, t(:report_hubs)
|
||||||
.omega.fourteen.columns= f.collection_select(:distributor_id_in, @data.distributors, :id, :name, {}, {class: "select2 fullwidth", multiple: true})
|
.omega.fourteen.columns
|
||||||
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :distributor_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :distributor_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_distributors_url))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_customers_cycle)
|
.alpha.two.columns= label_tag nil, t(:report_customers_cycle)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:order_cycle_id_in, report_order_cycle_options(@data.order_cycles), {selected: params.dig(:q, :order_cycle_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :order_cycle_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :order_cycle_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_order_cycles_url))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:fee_name)
|
.alpha.two.columns= label_tag nil, t(:fee_name)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:enterprise_fee_id_in, fee_name_options(@report.search.result), {selected: params.dig(:q, :enterprise_fee_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :enterprise_fee_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :enterprise_fee_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_enterprise_fees_url(search_url_query)))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:fee_owner)
|
.alpha.two.columns= label_tag nil, t(:fee_owner)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:enterprise_fee_owner_id_in, fee_owner_options(@report.search.result), {selected: params.dig(:q, :enterprise_fee_owner_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :enterprise_fee_owner_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :enterprise_fee_owner_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_enterprise_fee_owners_url(search_url_query)))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_customers)
|
.alpha.two.columns= label_tag nil, t(:report_customers)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:customer_id_in, customer_email_options(@data.order_customers), {selected: params.dig(:q, :customer_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :customer_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :customer_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_order_customers_url))
|
||||||
|
|||||||
@@ -1,27 +1,57 @@
|
|||||||
|
- search_url_query = {report_type: :enterprise_fee_summary, report_subtype: :enterprise_fees_with_tax_report_by_producer}
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_hubs)
|
.alpha.two.columns= label_tag nil, t(:report_hubs)
|
||||||
.omega.fourteen.columns= f.collection_select(:distributor_id_in, @data.distributors, :id, :name, {}, {class: "select2 fullwidth", multiple: true})
|
.omega.fourteen.columns
|
||||||
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :distributor_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :distributor_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_distributors_url))
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_producers)
|
.alpha.two.columns= label_tag nil, t(:report_producers)
|
||||||
.omega.fourteen.columns= select_tag(:supplier_id_in, options_from_collection_for_select(@data.orders_suppliers, :id, :name, params[:supplier_id_in]), {class: "select2 fullwidth", multiple: true})
|
.omega.fourteen.columns
|
||||||
|
= render(SearchableDropdownComponent.new(name: :supplier_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:supplier_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_suppliers_url))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_customers_cycle)
|
.alpha.two.columns= label_tag nil, t(:report_customers_cycle)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:order_cycle_id_in, report_order_cycle_options(@data.order_cycles), {selected: params.dig(:q, :order_cycle_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :order_cycle_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :order_cycle_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_order_cycles_url))
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:fee_name)
|
.alpha.two.columns= label_tag nil, t(:fee_name)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:enterprise_fee_id_in, fee_name_options(@report.search.result), {selected: params.dig(:q, :enterprise_fee_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :enterprise_fee_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :enterprise_fee_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_enterprise_fees_url(search_url_query)))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:fee_owner)
|
.alpha.two.columns= label_tag nil, t(:fee_owner)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:enterprise_fee_owner_id_in, fee_owner_options(@report.search.result), {selected: params.dig(:q, :enterprise_fee_owner_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :enterprise_fee_owner_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :enterprise_fee_owner_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_enterprise_fee_owners_url(search_url_query)))
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.alpha.two.columns= label_tag nil, t(:report_customers)
|
.alpha.two.columns= label_tag nil, t(:report_customers)
|
||||||
.omega.fourteen.columns
|
.omega.fourteen.columns
|
||||||
= f.select(:customer_id_in, customer_email_options(@data.order_customers), {selected: params.dig(:q, :customer_id_in)}, {class: "select2 fullwidth", multiple: true})
|
= render(SearchableDropdownComponent.new(form: f,
|
||||||
|
name: :customer_id_in,
|
||||||
|
options: [],
|
||||||
|
selected_option: params.dig(:q, :customer_id_in),
|
||||||
|
multiple: true,
|
||||||
|
remote_url: admin_reports_search_order_customers_url))
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
= cache do
|
= cache do
|
||||||
%img.spinner{ src: image_pack_path("images/spinning-circles.svg"), style: "max-width: 100%" }
|
%img.spinner{ src: image_pack_path("spinning-circles.svg"), style: "max-width: 100%" }
|
||||||
|
|||||||
@@ -6,21 +6,21 @@
|
|||||||
%p
|
%p
|
||||||
= t :brandstory_intro
|
= t :brandstory_intro
|
||||||
|
|
||||||
#brand-story-text.hide-show.slideable
|
%details#brand-story-text
|
||||||
%p
|
%summary
|
||||||
= t :brandstory_part1
|
%i.ofn-i_005-caret-down
|
||||||
%p
|
%i.ofn-i_006-caret-up
|
||||||
= t :brandstory_part2
|
.brand-story-content
|
||||||
%p
|
%p
|
||||||
= t :brandstory_part3
|
= t :brandstory_part1
|
||||||
%p
|
%p
|
||||||
= t :brandstory_part4
|
= t :brandstory_part2
|
||||||
%p
|
%p
|
||||||
%strong
|
= t :brandstory_part3
|
||||||
= t :brandstory_part5_strong
|
%p
|
||||||
%p
|
= t :brandstory_part4
|
||||||
= t :brandstory_part6
|
%p
|
||||||
|
%strong
|
||||||
%a.text-vbig{"slide-toggle" => "#brand-story-text", "ng-click" => "toggleBrandStory()"}
|
= t :brandstory_part5_strong
|
||||||
%i.ofn-i_005-caret-down{"ng-hide" => "brandStoryExpanded"}
|
%p
|
||||||
%i.ofn-i_006-caret-up{ "ng-show" => "brandStoryExpanded"}
|
= t :brandstory_part6
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
.row
|
.row
|
||||||
.small-12.text-center.columns
|
.small-12.text-center.columns
|
||||||
%h1
|
%h1
|
||||||
%img{src: image_pack_path("images/logo-white-notext.png"), title: Spree::Config.site_name}
|
%img{src: image_pack_path("logo-white-notext.png"), title: Spree::Config.site_name}
|
||||||
%br/
|
%br/
|
||||||
%a.button.transparent{href: "/shops"}
|
%a.button.transparent{href: "/shops"}
|
||||||
= t :home_shop
|
= t :home_shop
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
- content_for :page_alert do
|
- content_for :page_alert do
|
||||||
= render "shared/menu/alert"
|
= render "shared/menu/alert"
|
||||||
|
|
||||||
%div{"ng-controller" => "HomeCtrl"}
|
%div
|
||||||
= render "home/tagline"
|
= render "home/tagline"
|
||||||
|
|
||||||
#panes
|
#panes
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
.alert-box{ class: "#{type}" }
|
.alert-box{ class: "#{type}" }
|
||||||
= message
|
= message
|
||||||
- if local_assigns[:unconfirmed]
|
- if local_assigns[:unconfirmed]
|
||||||
%a{ "data-action": "login-modal#resend_confirmation", "data-tab": local_assigns[:tab] }
|
= link_to spree_user_confirmation_path(spree_user: { email: }, tab: local_assigns[:tab]), data: { turbo_method: :post } do
|
||||||
= t('devise.confirmations.resend_confirmation_email')
|
= t('devise.confirmations.resend_confirmation_email')
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
#forgot-tab
|
#forgot-tab
|
||||||
= form_with url: spree_user_password_path, scope: :spree_user, data: { remote: "true" } do |form|
|
= form_with url: spree_user_password_path, scope: :spree_user, data: { turbo: true } do |form|
|
||||||
.row
|
.row
|
||||||
.large-12.columns#forgot-feedback
|
.large-12.columns#forgot-feedback
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
= form.label :email, t(:signup_email)
|
= form.label :email, t(:signup_email)
|
||||||
= form.email_field :email, { tabindex: 1, inputmode: "email", "data-login-modal-target": "email", "data-action": "input->login-modal#emailOnInput" }
|
= form.email_field :email, { tabindex: 1, inputmode: "email" }
|
||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
= form.submit t(:reset_password), { class: "button primary", tabindex: 2 }
|
= form.submit t(:reset_password), { class: "button primary", tabindex: 2 }
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#login-content
|
#login-content
|
||||||
= form_with url: spree_user_session_path, scope: :spree_user, data: { remote: "true" } do |form|
|
= form_with url: spree_user_session_path, scope: :spree_user, data: { turbo: true } do |form|
|
||||||
.row
|
.row
|
||||||
.large-12.columns#login-feedback
|
.large-12.columns#login-feedback
|
||||||
- confirmation_result = request.query_parameters[:validation]
|
- confirmation_result = request.query_parameters[:validation]
|
||||||
@@ -10,7 +10,7 @@
|
|||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
= form.label :email, t(:email)
|
= form.label :email, t(:email)
|
||||||
= form.email_field :email, { tabindex: 1, inputmode: "email", autocomplete: "off", "data-login-modal-target": "email", "data-action": "input->login-modal#emailOnInput" }
|
= form.email_field :email, { tabindex: 1, inputmode: "email", autocomplete: "off" }
|
||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
= form.label :password, t(:password)
|
= form.label :password, t(:password)
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
- signup_form_user = Spree::User.new if local_assigns[:signup_form_user].nil?
|
- signup_form_user = Spree::User.new if local_assigns[:signup_form_user].nil?
|
||||||
|
|
||||||
#signup-tab
|
#signup-tab
|
||||||
= form_with model: signup_form_user, url: spree.account_path, scope: :user, data: { remote: "true" } do |form|
|
= form_with model: signup_form_user, url: spree.account_path, scope: :user, data: { turbo: true } do |form|
|
||||||
.row
|
.row
|
||||||
.large-12.columns#signup-feedback
|
.large-12.columns#signup-feedback
|
||||||
|
|
||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
= form.label :email, t(:signup_email)
|
= form.label :email, t(:signup_email)
|
||||||
= form.email_field :email, { tabindex: 1, "data-login-modal-target": "email", "data-action": "input->login-modal#emailOnInput" }
|
= form.email_field :email, { tabindex: 1 }
|
||||||
= form.error_message_on :email
|
= form.error_message_on :email
|
||||||
.row
|
.row
|
||||||
.large-12.columns
|
.large-12.columns
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
- else
|
- else
|
||||||
= favicon_link_tag "/favicon-staging.ico"
|
= favicon_link_tag "/favicon-staging.ico"
|
||||||
%link{href: "https://fonts.googleapis.com/css?family=Roboto:400,300italic,400italic,300,700,700italic|Oswald:300,400,700", rel: "stylesheet", type: "text/css"}
|
%link{href: "https://fonts.googleapis.com/css?family=Roboto:400,300italic,400italic,300,700,700italic|Oswald:300,400,700", rel: "stylesheet", type: "text/css"}
|
||||||
%link{href: asset_pack_path("static/fonts/OFN-v2.woff"), rel: "preload", as: "font", crossorigin: "anonymous"}
|
%link{href: asset_pack_path("static/OFN-v2.woff"), rel: "preload", as: "font", crossorigin: "anonymous"}
|
||||||
= render "layouts/matomo_tag"
|
= render "layouts/matomo_tag"
|
||||||
= language_meta_tags
|
= language_meta_tags
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
%meta{:content => "text/html; charset=UTF-8", "http-equiv" => "Content-Type"}/
|
%meta{:content => "text/html; charset=UTF-8", "http-equiv" => "Content-Type"}/
|
||||||
%title
|
%title
|
||||||
= Spree::Config[:site_name]
|
= Spree::Config[:site_name]
|
||||||
= stylesheet_link_tag 'mail', media: "screen"
|
= stylesheet_pack_tag "mail", media: "screen"
|
||||||
%body{:bgcolor => "#FFFFFF" }
|
%body{:bgcolor => "#FFFFFF" }
|
||||||
- unless @hide_ofn_navigation
|
- unless @hide_ofn_navigation
|
||||||
%table.head-wrap
|
%table.head-wrap
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
= csrf_meta_tags
|
= csrf_meta_tags
|
||||||
|
|
||||||
%body.off-canvas{ style: "background-image: url(#{image_pack_path('images/tile-wide.png')})", "data-turbo": "false" }
|
%body.off-canvas{ style: "background-image: url(#{image_pack_path('tile-wide.png')})", "data-turbo": "false" }
|
||||||
.off-canvas-wrap{offcanvas: true}
|
.off-canvas-wrap{offcanvas: true}
|
||||||
.inner-wrap
|
.inner-wrap
|
||||||
|
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
= t('spree.payment_mailer.authorization_required.message', order_number: @order.number)
|
= t(".message", order_number: @order.number)
|
||||||
= link_to spree.edit_admin_order_url(@order), spree.edit_admin_order_url(@order)
|
= link_to spree.edit_admin_order_url(@order), spree.edit_admin_order_url(@order)
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
= t('spree.payment_mailer.authorize_payment.instructions', distributor: @payment.order.distributor.name, amount: @payment.display_amount)
|
= t(".instructions", distributor: @payment.order.distributor.name, amount: @payment.display_amount)
|
||||||
= link_to main_app.authorize_payment_url(@payment), main_app.authorize_payment_url(@payment)
|
= link_to main_app.authorize_payment_url(@payment), main_app.authorize_payment_url(@payment)
|
||||||
|
|||||||
2
app/views/payment_mailer/refund_available.html.haml
Normal file
2
app/views/payment_mailer/refund_available.html.haml
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
%p= t(".message", shop: @shop, amount: @amount)
|
||||||
|
%p= link_to @taler_order_status_url, @taler_order_status_url
|
||||||
@@ -41,7 +41,7 @@
|
|||||||
|
|
||||||
%p.word-wrap{"ng-if" => "::producer.whatsapp_phone"}
|
%p.word-wrap{"ng-if" => "::producer.whatsapp_phone"}
|
||||||
%a{"ng-href" => "{{::producer.whatsapp_url}}", target: "_blank"}
|
%a{"ng-href" => "{{::producer.whatsapp_url}}", target: "_blank"}
|
||||||
%img{ src: image_pack_path("images/social-logos/whatsapp.svg") }
|
%img{ src: image_pack_path("social-logos/whatsapp.svg") }
|
||||||
%span{"ng-bind" => "::producer.whatsapp_phone"}
|
%span{"ng-bind" => "::producer.whatsapp_phone"}
|
||||||
|
|
||||||
%p.word-wrap{"ng-if" => "::producer.email_address"}
|
%p.word-wrap{"ng-if" => "::producer.email_address"}
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
%h4= t(".message")
|
%h4= t(".message")
|
||||||
.row
|
.row
|
||||||
.small-12.medium-3.large-2.columns.text-right.hide-for-small-only
|
.small-12.medium-3.large-2.columns.text-right.hide-for-small-only
|
||||||
%img{:src => image_pack_path("images/potatoes.png") }
|
%img{:src => image_pack_path("potatoes.png") }
|
||||||
.small-12.medium-9.large-10.columns
|
.small-12.medium-9.large-10.columns
|
||||||
%p
|
%p
|
||||||
= t(".text")
|
= t(".text")
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
.row
|
.row
|
||||||
.small-12.columns.text-center
|
.small-12.columns.text-center
|
||||||
.logo
|
.logo
|
||||||
%img{src: image_pack_path("images/logo-white-notext.png") }
|
%img{src: image_pack_path("logo-white-notext.png") }
|
||||||
.row
|
.row
|
||||||
.small-12.medium-8.medium-offset-2.columns.text-center
|
.small-12.medium-8.medium-offset-2.columns.text-center
|
||||||
.alert-box
|
.alert-box
|
||||||
|
|||||||
@@ -4,6 +4,6 @@
|
|||||||
%span
|
%span
|
||||||
= t '.cart'
|
= t '.cart'
|
||||||
%span.count
|
%span.count
|
||||||
%img{ src: image_pack_path("images/menu/icn-cart.svg") }
|
%img{ src: image_pack_path("menu/icn-cart.svg") }
|
||||||
%span
|
%span
|
||||||
{{ Cart.total_item_count() }}
|
{{ Cart.total_item_count() }}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
%nav.tab-bar.show-for-medium-down
|
%nav.tab-bar.show-for-medium-down
|
||||||
%section.left
|
%section.left
|
||||||
%a.left-off-canvas-toggle.menu-icon
|
%a.left-off-canvas-toggle.menu-icon
|
||||||
= image_pack_tag "images/menu/btn-menu-mobile.png"
|
= image_pack_tag "menu/btn-menu-mobile.png"
|
||||||
|
|
||||||
%section.left
|
%section.left
|
||||||
.ofn-logo
|
.ofn-logo
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
%span
|
%span
|
||||||
= t '.cart'
|
= t '.cart'
|
||||||
%span.count
|
%span.count
|
||||||
= image_pack_tag "images/menu/icn-cart.svg"
|
= image_pack_tag "menu/icn-cart.svg"
|
||||||
%span
|
%span
|
||||||
{{ Cart.total_item_count() }}
|
{{ Cart.total_item_count() }}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
%li.user-menu.has-dropdown.not-click
|
%li.user-menu.has-dropdown.not-click
|
||||||
|
|
||||||
%a{href: "#", class: "top-bar--menu-item-with-icon"}
|
%a{href: "#", class: "top-bar--menu-item-with-icon"}
|
||||||
%img{ src: image_pack_path("images/menu/icn-profile.svg") }
|
%img{ src: image_pack_path("menu/icn-profile.svg") }
|
||||||
%span
|
%span
|
||||||
= t '.profile'
|
= t '.profile'
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
= cache_with_locale do
|
= cache_with_locale do
|
||||||
%li#login-link{ "data-controller": "login-modal" }
|
%li#login-link{ "data-controller": "login-modal" }
|
||||||
%a{"auth": "login", "data-action": "click->login-modal#call" }
|
%a{"auth": "login", "data-action": "click->login-modal#call" }
|
||||||
%img{ src: image_pack_path("images/menu/icn-login.svg") }
|
%img{ src: image_pack_path("menu/icn-login.svg") }
|
||||||
%span
|
%span
|
||||||
= t 'label_login'
|
= t 'label_login'
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
"ng-debounce" => "200",
|
"ng-debounce" => "200",
|
||||||
"disable-enter-with-blur" => true}
|
"disable-enter-with-blur" => true}
|
||||||
%a.clear{ type: 'button', "focus-search": true, "ng-show": 'query', "ng-click": 'clearQuery()' }
|
%a.clear{ type: 'button', "focus-search": true, "ng-show": 'query', "ng-click": 'clearQuery()' }
|
||||||
= image_pack_tag "images/icn-close.png"
|
= image_pack_tag "icn-close.png"
|
||||||
|
|
||||||
.hide-for-large-up
|
.hide-for-large-up
|
||||||
%button{ type: 'button', "ng-click": 'toggleFilterSidebar()' }
|
%button{ type: 'button', "ng-click": 'toggleFilterSidebar()' }
|
||||||
|
|||||||
@@ -27,7 +27,7 @@
|
|||||||
%br
|
%br
|
||||||
- if current_distributor.whatsapp_phone.present?
|
- if current_distributor.whatsapp_phone.present?
|
||||||
%a{href: current_distributor.whatsapp_url, target: "_blank" }
|
%a{href: current_distributor.whatsapp_url, target: "_blank" }
|
||||||
%img{ src: image_pack_path("images/social-logos/whatsapp.svg") }
|
%img{ src: image_pack_path("social-logos/whatsapp.svg") }
|
||||||
= current_distributor.whatsapp_phone
|
= current_distributor.whatsapp_phone
|
||||||
%br
|
%br
|
||||||
- if current_distributor.website.present?
|
- if current_distributor.website.present?
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
= wicked_pdf_stylesheet_link_tag "mail"
|
= pdf_stylesheet_pack_tag "mail"
|
||||||
|
|
||||||
%table{:width => "100%"}
|
%table{:width => "100%"}
|
||||||
%tbody
|
%tbody
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
= wicked_pdf_stylesheet_link_tag "mail"
|
= pdf_stylesheet_pack_tag "mail"
|
||||||
|
|
||||||
%table{:width => "100%"}
|
%table{:width => "100%"}
|
||||||
%tbody
|
%tbody
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
= wicked_pdf_stylesheet_link_tag "mail"
|
= pdf_stylesheet_pack_tag "mail"
|
||||||
|
|
||||||
%table{:width => "100%"}
|
%table{:width => "100%"}
|
||||||
%tbody
|
%tbody
|
||||||
@@ -102,4 +102,4 @@
|
|||||||
= render partial: 'spree/admin/orders/_invoice/order_note'
|
= render partial: 'spree/admin/orders/_invoice/order_note'
|
||||||
|
|
||||||
.text-center
|
.text-center
|
||||||
= link_to_platform_terms
|
= link_to_platform_terms
|
||||||
|
|||||||
@@ -3,6 +3,6 @@
|
|||||||
.alpha.four.columns
|
.alpha.four.columns
|
||||||
= label :payment_method, :type, t('.provider')
|
= label :payment_method, :type, t('.provider')
|
||||||
.omega.twelve.columns
|
.omega.twelve.columns
|
||||||
= collection_select(:payment_method, :type, @providers, :to_s, :clean_name, {}, { class: 'select2 fullwidth', 'provider-prefs-for' => "#{@object.id}"})
|
= select(:payment_method, :type, payment_method_type_options(@providers), {}, { class: 'select2 fullwidth', required: true, placeholder: t("admin.choose"), 'provider-prefs-for' => "#{@object.id}"})
|
||||||
|
|
||||||
%div{"ng-include" => "include_html" }
|
%div{"ng-include" => "include_html" }
|
||||||
|
|||||||
@@ -37,7 +37,7 @@
|
|||||||
- method.distributors.each do |distributor|
|
- method.distributors.each do |distributor|
|
||||||
= distributor.name
|
= distributor.name
|
||||||
%br/
|
%br/
|
||||||
%td= method.class.clean_name
|
%td= payment_method_type_name(method.class.name)
|
||||||
- if spree_current_user.admin?
|
- if spree_current_user.admin?
|
||||||
%td.align-center= method.environment.to_s.titleize
|
%td.align-center= method.environment.to_s.titleize
|
||||||
%td.align-center= method.display_on.blank? ? t('.both') : t('.' + method.display_on.to_s)
|
%td.align-center= method.display_on.blank? ? t('.both') : t('.' + method.display_on.to_s)
|
||||||
|
|||||||
@@ -18,5 +18,5 @@
|
|||||||
%span{class: "state #{payment.state}"}= t(payment.state, scope: "spree.payment_states", default: payment.state.capitalize)
|
%span{class: "state #{payment.state}"}= t(payment.state, scope: "spree.payment_states", default: payment.state.capitalize)
|
||||||
%td.actions
|
%td.actions
|
||||||
- payment.actions.each do |action|
|
- payment.actions.each do |action|
|
||||||
= link_to_with_icon "icon-#{action}", Spree.t(action), fire_admin_order_payment_path(@order, payment, e: action),
|
= link_to "", fire_admin_order_payment_path(@order, payment, e: action),
|
||||||
no_text: true, data: { method: :put, action: action, disable_with: "" }
|
class: "icon_link icon-#{action} no-text", data: { method: :put, action: action, disable_with: "" }, title: Spree.t(action)
|
||||||
|
|||||||
@@ -41,5 +41,5 @@
|
|||||||
%a.info.cvvLink{href: "/content/cvv", target: "_blank"}
|
%a.info.cvvLink{href: "/content/cvv", target: "_blank"}
|
||||||
(#{t(:what_is_this)})
|
(#{t(:what_is_this)})
|
||||||
.nine.columns
|
.nine.columns
|
||||||
= image_pack_tag 'images/credit_cards/credit_card.gif', class: 'credit-card-image'
|
= image_pack_tag 'credit_cards/credit_card.gif', class: 'credit-card-image'
|
||||||
.clear
|
.clear
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
= form_for @product, url: admin_product_url(@product, @url_filters), method: :put do |f|
|
= form_for @product, url: admin_product_url(@product, @url_filters), method: :put do |f|
|
||||||
%fieldset.no-border-top
|
%fieldset.no-border-top
|
||||||
.add_product_properties
|
.add_product_properties
|
||||||
= image_pack_tag 'images/select2-spinner.gif', plugin: 'spree', style: 'display:none;', id: 'busy_indicator'
|
= image_pack_tag 'select2-spinner.gif', plugin: 'spree', style: 'display:none;', id: 'busy_indicator'
|
||||||
|
|
||||||
%table.index.sortable{"data-sortable-link" => update_positions_admin_product_product_properties_url}
|
%table.index.sortable{"data-sortable-link" => update_positions_admin_product_product_properties_url}
|
||||||
%thead
|
%thead
|
||||||
|
|||||||
@@ -29,7 +29,7 @@
|
|||||||
.sixteen.columns.alpha
|
.sixteen.columns.alpha
|
||||||
.eight.columns.alpha
|
.eight.columns.alpha
|
||||||
= f.field_container :variant_unit do
|
= f.field_container :variant_unit do
|
||||||
= f.label :variant_unit, t(".units")
|
= f.label :variant_unit_with_scale, t(".units")
|
||||||
%span.required *
|
%span.required *
|
||||||
= f.select 'variant_unit', [],
|
= f.select 'variant_unit', [],
|
||||||
{ include_blank: true },
|
{ include_blank: true },
|
||||||
|
|||||||
@@ -11,6 +11,6 @@
|
|||||||
- databaseurl = "#{admin_states_path(format: :js)}?country_id="
|
- databaseurl = "#{admin_states_path(format: :js)}?country_id="
|
||||||
%select#country.observe_field.select2.fullwidth{"data-base-url" => databaseurl, "data-update" => "#state-list"}
|
%select#country.observe_field.select2.fullwidth{"data-base-url" => databaseurl, "data-update" => "#state-list"}
|
||||||
= options_from_collection_for_select(@countries, :id, :name, @country.id)
|
= options_from_collection_for_select(@countries, :id, :name, @country.id)
|
||||||
= image_pack_tag 'images/select2-spinner.gif', plugin: 'spree', style: 'display:none;', id: 'busy_indicator'
|
= image_pack_tag 'select2-spinner.gif', plugin: 'spree', style: 'display:none;', id: 'busy_indicator'
|
||||||
#state-list
|
#state-list
|
||||||
= render partial: 'state_list'
|
= render partial: 'state_list'
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
import { Controller } from "stimulus";
|
import { Controller } from "stimulus";
|
||||||
|
|
||||||
export default class extends Controller {
|
export default class extends Controller {
|
||||||
static targets = ["background", "modal", "email"];
|
static targets = ["background", "modal"];
|
||||||
static values = { email: String };
|
|
||||||
|
|
||||||
connect() {
|
connect() {
|
||||||
if (this.hasModalTarget) {
|
if (this.hasModalTarget) {
|
||||||
@@ -19,13 +18,6 @@ export default class extends Controller {
|
|||||||
window.dispatchEvent(new Event("login:modal:open"));
|
window.dispatchEvent(new Event("login:modal:open"));
|
||||||
}
|
}
|
||||||
|
|
||||||
emailOnInput(event) {
|
|
||||||
this.emailValue = event.currentTarget.value;
|
|
||||||
this.emailTargets.forEach((element) => {
|
|
||||||
element.value = this.emailValue;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
open = () => {
|
open = () => {
|
||||||
if (!location.hash.substr(1).includes("/login")) {
|
if (!location.hash.substr(1).includes("/login")) {
|
||||||
history.pushState({}, "", "#/login");
|
history.pushState({}, "", "#/login");
|
||||||
@@ -57,19 +49,6 @@ export default class extends Controller {
|
|||||||
}, 200);
|
}, 200);
|
||||||
}
|
}
|
||||||
|
|
||||||
resend_confirmation(event) {
|
|
||||||
fetch("/user/spree_user/confirmation", {
|
|
||||||
method: "POST",
|
|
||||||
body: JSON.stringify({
|
|
||||||
spree_user: { email: this.emailValue },
|
|
||||||
tab: event.currentTarget.dataset.tab,
|
|
||||||
}),
|
|
||||||
headers: { "Content-type": "application/json; charset=UTF-8" },
|
|
||||||
})
|
|
||||||
.then((data) => data.json())
|
|
||||||
.then(CableReady.perform);
|
|
||||||
}
|
|
||||||
|
|
||||||
returnHome() {
|
returnHome() {
|
||||||
window.location = "/";
|
window.location = "/";
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,16 @@
|
|||||||
import { Controller } from "stimulus";
|
import { Controller } from "stimulus";
|
||||||
import TomSelect from "tom-select/dist/esm/tom-select.complete";
|
import TomSelect from "tom-select/dist/esm/tom-select.complete";
|
||||||
|
import showHttpError from "../../webpacker/js/services/show_http_error";
|
||||||
|
|
||||||
export default class extends Controller {
|
export default class extends Controller {
|
||||||
static values = { options: Object, placeholder: String };
|
static values = {
|
||||||
|
options: Object,
|
||||||
|
placeholder: String,
|
||||||
|
remoteUrl: String,
|
||||||
|
};
|
||||||
|
|
||||||
connect(options = {}) {
|
connect(options = {}) {
|
||||||
this.control = new TomSelect(this.element, {
|
let tomSelectOptions = {
|
||||||
maxItems: 1,
|
maxItems: 1,
|
||||||
maxOptions: null,
|
maxOptions: null,
|
||||||
plugins: ["dropdown_input"],
|
plugins: ["dropdown_input"],
|
||||||
@@ -16,7 +21,13 @@ export default class extends Controller {
|
|||||||
},
|
},
|
||||||
...this.optionsValue,
|
...this.optionsValue,
|
||||||
...options,
|
...options,
|
||||||
});
|
};
|
||||||
|
|
||||||
|
if (this.remoteUrlValue) {
|
||||||
|
this.#addRemoteOptions(tomSelectOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.control = new TomSelect(this.element, tomSelectOptions);
|
||||||
}
|
}
|
||||||
|
|
||||||
disconnect() {
|
disconnect() {
|
||||||
@@ -29,4 +40,78 @@ export default class extends Controller {
|
|||||||
const optionsArray = [...this.element.options];
|
const optionsArray = [...this.element.options];
|
||||||
return optionsArray.find((option) => [null, ""].includes(option.value))?.text;
|
return optionsArray.find((option) => [null, ""].includes(option.value))?.text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#buildUrl(query, page = 1) {
|
||||||
|
const url = new URL(this.remoteUrlValue, window.location.origin);
|
||||||
|
url.searchParams.set("q", query);
|
||||||
|
url.searchParams.set("page", page);
|
||||||
|
return url.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
#fetchOptions(query, callback) {
|
||||||
|
const url = this.control.getUrl(query);
|
||||||
|
|
||||||
|
fetch(url)
|
||||||
|
.then((response) => {
|
||||||
|
if (!response.ok) {
|
||||||
|
showHttpError(response.status);
|
||||||
|
throw response;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
})
|
||||||
|
.then((json) => {
|
||||||
|
/**
|
||||||
|
* Expected API shape:
|
||||||
|
* {
|
||||||
|
* results: [{ value, label }],
|
||||||
|
* pagination: { more: boolean }
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
if (json.pagination?.more) {
|
||||||
|
const currentUrl = new URL(url);
|
||||||
|
const currentPage = parseInt(currentUrl.searchParams.get("page") || "1");
|
||||||
|
const nextUrl = this.#buildUrl(query, currentPage + 1);
|
||||||
|
this.control.setNextUrl(query, nextUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
callback(json.results || []);
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
callback();
|
||||||
|
console.error(error);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
#addRemoteOptions(options) {
|
||||||
|
this.openedByClick = false;
|
||||||
|
|
||||||
|
options.firstUrl = (query) => {
|
||||||
|
return this.#buildUrl(query, 1);
|
||||||
|
};
|
||||||
|
|
||||||
|
options.load = this.#fetchOptions.bind(this);
|
||||||
|
|
||||||
|
options.onFocus = function () {
|
||||||
|
this.control.load("", () => {});
|
||||||
|
}.bind(this);
|
||||||
|
|
||||||
|
options.onDropdownOpen = function () {
|
||||||
|
this.openedByClick = true;
|
||||||
|
}.bind(this);
|
||||||
|
|
||||||
|
options.onType = function () {
|
||||||
|
this.openedByClick = false;
|
||||||
|
}.bind(this);
|
||||||
|
|
||||||
|
// As per TomSelect source code, Loading state is shown on the UI when this function returns true.
|
||||||
|
// By default it shows loading state only when there is some input in the search box.
|
||||||
|
// We want to show loading state on focus as well (when there is no input) to indicate that options are being loaded.
|
||||||
|
options.shouldLoad = function (query) {
|
||||||
|
return this.openedByClick || query.length > 0;
|
||||||
|
}.bind(this);
|
||||||
|
|
||||||
|
options.valueField = "value";
|
||||||
|
options.labelField = "label";
|
||||||
|
options.searchField = "label";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -71,8 +71,50 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
a.text-vbig i {
|
#brand-story-text {
|
||||||
font-size: 75px;
|
text-align: center;
|
||||||
|
margin-top: 1rem;
|
||||||
|
|
||||||
|
summary {
|
||||||
|
list-style: none;
|
||||||
|
cursor: pointer;
|
||||||
|
display: inline-block;
|
||||||
|
|
||||||
|
&::-webkit-details-marker {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
&::marker {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
i {
|
||||||
|
font-size: 75px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ofn-i_005-caret-down {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ofn-i_006-caret-up {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&[open] summary {
|
||||||
|
.ofn-i_005-caret-down {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ofn-i_006-caret-up {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.brand-story-content {
|
||||||
|
margin-top: 1rem;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
3
app/webpacker/css/mail/all.scss
Normal file
3
app/webpacker/css/mail/all.scss
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
@import '../admin/globals/palette.scss';
|
||||||
|
@import 'email';
|
||||||
|
@import 'payments_list';
|
||||||
@@ -9,7 +9,7 @@ document.addEventListener("turbo:frame-missing", (event) => {
|
|||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
// show error message instead
|
// show error message instead
|
||||||
showError(event.detail.response?.status);
|
showHttpError(event.detail.response?.status);
|
||||||
});
|
});
|
||||||
|
|
||||||
document.addEventListener("turbo:submit-end", (event) => {
|
document.addEventListener("turbo:submit-end", (event) => {
|
||||||
|
|||||||
1
app/webpacker/packs/mail.scss
Normal file
1
app/webpacker/packs/mail.scss
Normal file
@@ -0,0 +1 @@
|
|||||||
|
@import "../css/mail/all.scss";
|
||||||
@@ -41,7 +41,7 @@ FileUtils.chdir APP_ROOT do
|
|||||||
system! "rm -f tmp/invoices/*.pdf"
|
system! "rm -f tmp/invoices/*.pdf"
|
||||||
system! "rm -f tmp/javascripts/*.js"
|
system! "rm -f tmp/javascripts/*.js"
|
||||||
system! "rm -f tmp/karma_unit.js*"
|
system! "rm -f tmp/karma_unit.js*"
|
||||||
system! "rm -f tmp/product_import-*"
|
system! "rm -rf tmp/product_import-*"
|
||||||
|
|
||||||
puts "\n== Removing any precompiled assets that would be out of date now =="
|
puts "\n== Removing any precompiled assets that would be out of date now =="
|
||||||
system! "rm -rf public/assets/"
|
system! "rm -rf public/assets/"
|
||||||
|
|||||||
@@ -74,8 +74,6 @@ Rails.application.configure do
|
|||||||
allowed_warnings = [
|
allowed_warnings = [
|
||||||
# List strings here to allow matching deprecations.
|
# List strings here to allow matching deprecations.
|
||||||
#
|
#
|
||||||
"Passing the class as positional argument",
|
|
||||||
|
|
||||||
# Spree::CreditCard model aliases `cc_type` and has a method called `cc_type=` defined. Starting in Rails 7.2 `brand=` will not be calling `cc_type=` anymore. You may want to additionally define `brand=` to preserve the current behavior.
|
# Spree::CreditCard model aliases `cc_type` and has a method called `cc_type=` defined. Starting in Rails 7.2 `brand=` will not be calling `cc_type=` anymore. You may want to additionally define `brand=` to preserve the current behavior.
|
||||||
"model aliases",
|
"model aliases",
|
||||||
|
|
||||||
|
|||||||
@@ -19,6 +19,5 @@ Rails.application.config.assets.precompile += [
|
|||||||
'web/all.js',
|
'web/all.js',
|
||||||
'darkswarm/all.js',
|
'darkswarm/all.js',
|
||||||
'shared/*',
|
'shared/*',
|
||||||
'mail.scss',
|
|
||||||
'*.jpg', '*.jpeg', '*.png', '*.gif' '*.svg',
|
'*.jpg', '*.jpeg', '*.png', '*.gif' '*.svg',
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -2,16 +2,27 @@ require_relative 'spree'
|
|||||||
|
|
||||||
Rails.application.reloader.to_prepare do
|
Rails.application.reloader.to_prepare do
|
||||||
# See: https://github.com/openfoodfoundation/db2fog
|
# See: https://github.com/openfoodfoundation/db2fog
|
||||||
DB2Fog.config = {
|
if ENV['S3_BACKUPS_HOST'].present?
|
||||||
|
DB2Fog.config = {
|
||||||
|
aws_access_key_id: ENV['S3_BACKUPS_ACCESS_KEY'],
|
||||||
|
aws_secret_access_key: ENV['S3_BACKUPS_SECRET'],
|
||||||
|
directory: ENV['S3_BACKUPS_BUCKET'],
|
||||||
|
provider: 'AWS',
|
||||||
|
scheme: ENV['S3_BACKUPS_SCHEME'],
|
||||||
|
host: ENV['S3_BACKUPS_HOST']
|
||||||
|
}
|
||||||
|
else
|
||||||
|
DB2Fog.config = {
|
||||||
:aws_access_key_id => Spree::Config[:s3_access_key],
|
:aws_access_key_id => Spree::Config[:s3_access_key],
|
||||||
:aws_secret_access_key => Spree::Config[:s3_secret],
|
:aws_secret_access_key => Spree::Config[:s3_secret],
|
||||||
:directory => ENV['S3_BACKUPS_BUCKET'],
|
:directory => ENV['S3_BACKUPS_BUCKET'],
|
||||||
:provider => 'AWS'
|
:provider => 'AWS'
|
||||||
}
|
}
|
||||||
|
|
||||||
region = ENV['S3_BACKUPS_REGION'] || ENV['S3_REGION']
|
region = ENV['S3_BACKUPS_REGION'] || ENV['S3_REGION']
|
||||||
|
|
||||||
# If no region is defined we leave this config key undefined (instead of nil),
|
# If no region is defined we leave this config key undefined (instead of nil),
|
||||||
# so that db2fog correctly applies it's default
|
# so that db2fog correctly applies it's default
|
||||||
DB2Fog.config[:region] = region if region
|
DB2Fog.config[:region] = region if region
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -273,6 +273,13 @@ ar:
|
|||||||
join_community: "انظم إلى المجتمع"
|
join_community: "انظم إلى المجتمع"
|
||||||
invite_manager:
|
invite_manager:
|
||||||
subject: "تلقيت دعوة من %{enterprise} لتصبح مديرًا"
|
subject: "تلقيت دعوة من %{enterprise} لتصبح مديرًا"
|
||||||
|
payment_mailer:
|
||||||
|
authorize_payment:
|
||||||
|
subject: "يرجى تفويض الدفع الخاص بك إلى %{distributor} على OFN"
|
||||||
|
instructions: "يتطلب الدفع الخاص بك من %{amount} إلى %{distributor} مصادقة إضافية. الرجاء زيارة URL التالي لتفويض الدفع الخاص بك:"
|
||||||
|
authorization_required:
|
||||||
|
subject: "يتطلب الدفع إذنًا من العميل"
|
||||||
|
message: "يتطلب الدفع للطلب %{order_number} تفويضًا إضافيًا من العميل. تم إخطار العميل عبر البريد الإلكتروني وسيظهر الدفع على أنه معلق حتى يتم التصريح به."
|
||||||
producer_mailer:
|
producer_mailer:
|
||||||
order_cycle:
|
order_cycle:
|
||||||
subject: "تقرير دورة الطلبية لـ %{producer}"
|
subject: "تقرير دورة الطلبية لـ %{producer}"
|
||||||
@@ -3765,6 +3772,7 @@ ar:
|
|||||||
alt_text: "نص بديل"
|
alt_text: "نص بديل"
|
||||||
thumbnail: "الباقة"
|
thumbnail: "الباقة"
|
||||||
back_to_images_list: "العودة إلى قائمة الصور"
|
back_to_images_list: "العودة إلى قائمة الصور"
|
||||||
|
api_key: "مفتاح API"
|
||||||
email: البريد الإلكتروني
|
email: البريد الإلكتروني
|
||||||
account_updated: "تم تحديث الحساب!"
|
account_updated: "تم تحديث الحساب!"
|
||||||
email_updated: "سيتم تحديث الحساب بمجرد تأكيد البريد الإلكتروني الجديد."
|
email_updated: "سيتم تحديث الحساب بمجرد تأكيد البريد الإلكتروني الجديد."
|
||||||
@@ -4065,9 +4073,7 @@ ar:
|
|||||||
providers:
|
providers:
|
||||||
provider: "مزود"
|
provider: "مزود"
|
||||||
check: "النقد / التحويل الإلكتروني / إلخ. (المدفوعات التي لا تتطلب المصادقة التلقائية)"
|
check: "النقد / التحويل الإلكتروني / إلخ. (المدفوعات التي لا تتطلب المصادقة التلقائية)"
|
||||||
pin: "المدفوعات دبوس"
|
|
||||||
paypalexpress: "باي بال اكسبريس"
|
paypalexpress: "باي بال اكسبريس"
|
||||||
stripeconnect: "Stripe SCA"
|
|
||||||
stripesca: "Stripe SCA"
|
stripesca: "Stripe SCA"
|
||||||
payments:
|
payments:
|
||||||
source_forms:
|
source_forms:
|
||||||
@@ -4290,13 +4296,6 @@ ar:
|
|||||||
subject: "تعليمات إعادة تعيين كلمة المرور"
|
subject: "تعليمات إعادة تعيين كلمة المرور"
|
||||||
confirmation_instructions:
|
confirmation_instructions:
|
||||||
subject: "يرجى تأكيد حسابك OFN"
|
subject: "يرجى تأكيد حسابك OFN"
|
||||||
payment_mailer:
|
|
||||||
authorize_payment:
|
|
||||||
subject: "يرجى تفويض الدفع الخاص بك إلى %{distributor} على OFN"
|
|
||||||
instructions: "يتطلب الدفع الخاص بك من %{amount} إلى %{distributor} مصادقة إضافية. الرجاء زيارة URL التالي لتفويض الدفع الخاص بك:"
|
|
||||||
authorization_required:
|
|
||||||
subject: "يتطلب الدفع إذنًا من العميل"
|
|
||||||
message: "يتطلب الدفع للطلب %{order_number} تفويضًا إضافيًا من العميل. تم إخطار العميل عبر البريد الإلكتروني وسيظهر الدفع على أنه معلق حتى يتم التصريح به."
|
|
||||||
shipment_mailer:
|
shipment_mailer:
|
||||||
shipped_email:
|
shipped_email:
|
||||||
dear_customer: "عزيزي العميل،"
|
dear_customer: "عزيزي العميل،"
|
||||||
|
|||||||
@@ -283,6 +283,13 @@ ca:
|
|||||||
join_community: "Uneix-te a la comunitat"
|
join_community: "Uneix-te a la comunitat"
|
||||||
invite_manager:
|
invite_manager:
|
||||||
subject: "%{enterprise} t'ha convidat a ser administrador"
|
subject: "%{enterprise} t'ha convidat a ser administrador"
|
||||||
|
payment_mailer:
|
||||||
|
authorize_payment:
|
||||||
|
subject: "Autoritzeu el vostre pagament a %{distributor} a OFN"
|
||||||
|
instructions: "El vostre pagament de %{amount} a %{distributor} requereix una autenticació addicional. Visiteu l’URL següent per autoritzar el vostre pagament:"
|
||||||
|
authorization_required:
|
||||||
|
subject: "Un pagament requereix l’autorització del client"
|
||||||
|
message: "El pagament de la comanda %{order_number} requereix una autorització addicional del client. El client ha rebut una notificació per correu electrònic i el pagament apareixerà pendent fins que no s’autoritzi."
|
||||||
producer_mailer:
|
producer_mailer:
|
||||||
order_cycle:
|
order_cycle:
|
||||||
subject: "Informe del cicle de comanda per %{producer}"
|
subject: "Informe del cicle de comanda per %{producer}"
|
||||||
@@ -3645,6 +3652,7 @@ ca:
|
|||||||
alt_text: "Text alternatiu"
|
alt_text: "Text alternatiu"
|
||||||
thumbnail: "Miniatura"
|
thumbnail: "Miniatura"
|
||||||
back_to_images_list: "Torna a la llista d’imatges"
|
back_to_images_list: "Torna a la llista d’imatges"
|
||||||
|
api_key: "Clau API"
|
||||||
email: Correu electrònic
|
email: Correu electrònic
|
||||||
account_updated: "Compte actualitzat!"
|
account_updated: "Compte actualitzat!"
|
||||||
email_updated: "El compte s’actualitzarà un cop es confirmi el nou correu electrònic."
|
email_updated: "El compte s’actualitzarà un cop es confirmi el nou correu electrònic."
|
||||||
@@ -3943,9 +3951,7 @@ ca:
|
|||||||
providers:
|
providers:
|
||||||
provider: "Proveïdor"
|
provider: "Proveïdor"
|
||||||
check: "Efectiu / transferència / etc. (pagaments per als quals no és necessària la validació automàtica)"
|
check: "Efectiu / transferència / etc. (pagaments per als quals no és necessària la validació automàtica)"
|
||||||
pin: "Pin Payments"
|
|
||||||
paypalexpress: "PayPal Express"
|
paypalexpress: "PayPal Express"
|
||||||
stripeconnect: "Stripe (obsolet)"
|
|
||||||
stripesca: "Stripe SCA"
|
stripesca: "Stripe SCA"
|
||||||
payments:
|
payments:
|
||||||
source_forms:
|
source_forms:
|
||||||
@@ -4171,13 +4177,6 @@ ca:
|
|||||||
subject: "Instruccions per restablir la contrasenya"
|
subject: "Instruccions per restablir la contrasenya"
|
||||||
confirmation_instructions:
|
confirmation_instructions:
|
||||||
subject: "Si us plau confirma el teu compte d'OFN"
|
subject: "Si us plau confirma el teu compte d'OFN"
|
||||||
payment_mailer:
|
|
||||||
authorize_payment:
|
|
||||||
subject: "Autoritzeu el vostre pagament a %{distributor} a OFN"
|
|
||||||
instructions: "El vostre pagament de %{amount} a %{distributor} requereix una autenticació addicional. Visiteu l’URL següent per autoritzar el vostre pagament:"
|
|
||||||
authorization_required:
|
|
||||||
subject: "Un pagament requereix l’autorització del client"
|
|
||||||
message: "El pagament de la comanda %{order_number} requereix una autorització addicional del client. El client ha rebut una notificació per correu electrònic i el pagament apareixerà pendent fins que no s’autoritzi."
|
|
||||||
shipment_mailer:
|
shipment_mailer:
|
||||||
shipped_email:
|
shipped_email:
|
||||||
dear_customer: "Benvolguda consumidora:"
|
dear_customer: "Benvolguda consumidora:"
|
||||||
|
|||||||
@@ -348,6 +348,13 @@ cy:
|
|||||||
join_community: "Ymunwch â'r gymuned"
|
join_community: "Ymunwch â'r gymuned"
|
||||||
invite_manager:
|
invite_manager:
|
||||||
subject: "mae %{enterprise} wedi eich gwahodd i fod yn rheolwr"
|
subject: "mae %{enterprise} wedi eich gwahodd i fod yn rheolwr"
|
||||||
|
payment_mailer:
|
||||||
|
authorize_payment:
|
||||||
|
subject: "Gofynnir ichi awdurdodi eich taliad i %{distributor} ar y Open Food Network"
|
||||||
|
instructions: "Mae angen dilysu ychwanegol ar gyfer eich taliad o %{amount} i %{distributor} . Dilynwch yr URL canlynol i awdurdodi eich taliad."
|
||||||
|
authorization_required:
|
||||||
|
subject: "Mae angen i gwsmer awdurdodi taliad."
|
||||||
|
message: "Mae angen awdurdod ychwanegol gan y cwsmer i dalu am archeb %{order_number} Hysbyswyd y cwsmer trwy ebost a bydd y taliad yn ymddangos fel taliad yn yr arfaeth nes ei awdurdodi."
|
||||||
producer_mailer:
|
producer_mailer:
|
||||||
order_cycle:
|
order_cycle:
|
||||||
subject: "Adroddiad cylch archebu ar gyfer %{producer}"
|
subject: "Adroddiad cylch archebu ar gyfer %{producer}"
|
||||||
@@ -4105,6 +4112,7 @@ cy:
|
|||||||
alt_text: "Testun Amgen"
|
alt_text: "Testun Amgen"
|
||||||
thumbnail: "Cryno-lun"
|
thumbnail: "Cryno-lun"
|
||||||
back_to_images_list: "Yn ôl i'r Rhestr Delweddau"
|
back_to_images_list: "Yn ôl i'r Rhestr Delweddau"
|
||||||
|
api_key: "Allwedd API"
|
||||||
email: E-bost
|
email: E-bost
|
||||||
account_updated: "Diweddarwyd y cyfrif!"
|
account_updated: "Diweddarwyd y cyfrif!"
|
||||||
email_updated: "Bydd y cyfrif yn cael ei ddiweddaru ar ôl cadarnhau'r cyfeiriad e-bost newydd."
|
email_updated: "Bydd y cyfrif yn cael ei ddiweddaru ar ôl cadarnhau'r cyfeiriad e-bost newydd."
|
||||||
@@ -4420,9 +4428,7 @@ cy:
|
|||||||
providers:
|
providers:
|
||||||
provider: "Darparwr"
|
provider: "Darparwr"
|
||||||
check: "Arian/TRhE/ac ati (taliadau lle nad oes angen dilysu awtomatig)."
|
check: "Arian/TRhE/ac ati (taliadau lle nad oes angen dilysu awtomatig)."
|
||||||
pin: "Taliadau Pin"
|
|
||||||
paypalexpress: "PayPal Express"
|
paypalexpress: "PayPal Express"
|
||||||
stripeconnect: "Stripe"
|
|
||||||
stripesca: "Stripe SCA"
|
stripesca: "Stripe SCA"
|
||||||
payments:
|
payments:
|
||||||
source_forms:
|
source_forms:
|
||||||
@@ -4670,13 +4676,6 @@ cy:
|
|||||||
subject: "Cyfarwyddiadau ailosod cyfrinair"
|
subject: "Cyfarwyddiadau ailosod cyfrinair"
|
||||||
confirmation_instructions:
|
confirmation_instructions:
|
||||||
subject: "Gofynnir ichi gadarnhau eich cyfrif y Open Food Network os gwelwch yn dda"
|
subject: "Gofynnir ichi gadarnhau eich cyfrif y Open Food Network os gwelwch yn dda"
|
||||||
payment_mailer:
|
|
||||||
authorize_payment:
|
|
||||||
subject: "Gofynnir ichi awdurdodi eich taliad i %{distributor} ar y Open Food Network"
|
|
||||||
instructions: "Mae angen dilysu ychwanegol ar gyfer eich taliad o %{amount} i %{distributor} . Dilynwch yr URL canlynol i awdurdodi eich taliad."
|
|
||||||
authorization_required:
|
|
||||||
subject: "Mae angen i gwsmer awdurdodi taliad."
|
|
||||||
message: "Mae angen awdurdod ychwanegol gan y cwsmer i dalu am archeb %{order_number} Hysbyswyd y cwsmer trwy ebost a bydd y taliad yn ymddangos fel taliad yn yr arfaeth nes ei awdurdodi."
|
|
||||||
shipment_mailer:
|
shipment_mailer:
|
||||||
shipped_email:
|
shipped_email:
|
||||||
dear_customer: "Annwyl Gwsmer,"
|
dear_customer: "Annwyl Gwsmer,"
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user