├── .browserslistrc
├── .github
├── ISSUE_TEMPLATE
│ ├── bug_report.md
│ └── feature_request.md
└── PULL_REQUEST_TEMPLATE.md
├── .gitignore
├── .ruby-version
├── CODE_OF_CONDUCT.md
├── CONTRIBUTING.md
├── Gemfile
├── Gemfile.lock
├── LICENSE
├── README.md
├── Rakefile
├── TUTORIAL.md
├── app
├── channels
│ └── application_cable
│ │ ├── channel.rb
│ │ └── connection.rb
├── controllers
│ ├── application_controller.rb
│ ├── concerns
│ │ └── .keep
│ └── restaurants_controller.rb
├── helpers
│ ├── application_helper.rb
│ └── restaurants_helper.rb
├── javascript
│ ├── controllers
│ │ ├── index.js
│ │ └── restaurants_controller.js
│ └── packs
│ │ ├── application.js
│ │ └── stylesheets.css
├── jobs
│ └── application_job.rb
├── mailers
│ └── application_mailer.rb
├── models
│ ├── application_record.rb
│ ├── concerns
│ │ └── .keep
│ └── restaurant.rb
├── reflexes
│ └── restaurants_reflex.rb
└── views
│ ├── kaminari
│ ├── _gap.html.erb
│ ├── _next_page.html.erb
│ ├── _page.html.erb
│ ├── _paginator.html.erb
│ └── _prev_page.html.erb
│ ├── layouts
│ ├── _header.html.erb
│ ├── application.html.erb
│ ├── mailer.html.erb
│ └── mailer.text.erb
│ └── restaurants
│ └── index.html.erb
├── babel.config.js
├── bin
├── bundle
├── rails
├── rake
├── setup
├── spring
├── webpack
├── webpack-dev-server
└── yarn
├── config.ru
├── config
├── application.rb
├── boot.rb
├── cable.yml
├── credentials.yml.enc
├── database.yml
├── environment.rb
├── environments
│ ├── development.rb
│ ├── production.rb
│ └── test.rb
├── initializers
│ ├── application_controller_renderer.rb
│ ├── assets.rb
│ ├── backtrace_silencers.rb
│ ├── content_security_policy.rb
│ ├── cookies_serializer.rb
│ ├── filter_parameter_logging.rb
│ ├── inflections.rb
│ ├── kaminari_config.rb
│ ├── mime_types.rb
│ └── wrap_parameters.rb
├── locales
│ └── en.yml
├── puma.rb
├── routes.rb
├── spring.rb
├── storage.yml
├── webpack
│ ├── development.js
│ ├── environment.js
│ ├── production.js
│ └── test.js
└── webpacker.yml
├── db
├── migrate
│ └── 20191011234259_create_restaurants.rb
├── schema.rb
└── seeds.rb
├── lib
├── assets
│ └── .keep
└── tasks
│ └── .keep
├── log
└── .keep
├── package.json
├── postcss.config.js
├── public
├── 404.html
├── 422.html
├── 500.html
├── apple-touch-icon-precomposed.png
├── apple-touch-icon.png
├── favicon.ico
└── robots.txt
├── storage
└── .keep
├── tailwind.config.js
├── test
├── application_system_test_case.rb
├── channels
│ └── application_cable
│ │ └── connection_test.rb
├── controllers
│ └── restaurants_controller_test.rb
├── fixtures
│ ├── files
│ │ └── .keep
│ └── restaurants.yml
├── helpers
│ └── .keep
├── integration
│ └── .keep
├── mailers
│ └── .keep
├── models
│ ├── .keep
│ └── restaurant_test.rb
├── system
│ └── restaurants_test.rb
└── test_helper.rb
├── tmp
└── .keep
├── vendor
└── .keep
└── yarn.lock
/.browserslistrc:
--------------------------------------------------------------------------------
1 | defaults
2 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/bug_report.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Bug report
3 | about: Create a report to help us improve
4 | title: ''
5 | labels: ''
6 | assignees: ''
7 |
8 | ---
9 |
10 | **Describe the bug**
11 | A clear and concise description of what the bug is.
12 |
13 | **To Reproduce**
14 | Steps to reproduce the behavior:
15 | 1. Go to '...'
16 | 2. Click on '....'
17 | 3. Scroll down to '....'
18 | 4. See error
19 |
20 | **Expected behavior**
21 | A clear and concise description of what you expected to happen.
22 |
23 | **Screenshots**
24 | If applicable, add screenshots to help explain your problem.
25 |
26 | **Additional context**
27 | Add any other context about the problem here.
28 |
--------------------------------------------------------------------------------
/.github/ISSUE_TEMPLATE/feature_request.md:
--------------------------------------------------------------------------------
1 | ---
2 | name: Feature request
3 | about: Suggest an idea for this project
4 | title: ''
5 | labels: ''
6 | assignees: ''
7 |
8 | ---
9 |
10 | **Is your feature request related to a problem? Please describe.**
11 | A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
12 |
13 | **Describe the solution you'd like**
14 | A clear and concise description of what you want to happen.
15 |
16 | **Describe alternatives you've considered**
17 | A clear and concise description of any alternative solutions or features you've considered.
18 |
19 | **Additional context**
20 | Add any other context or screenshots about the feature request here.
21 |
--------------------------------------------------------------------------------
/.github/PULL_REQUEST_TEMPLATE.md:
--------------------------------------------------------------------------------
1 | # Type of PR (feature, enhancement, bug fix, etc.)
2 |
3 | ## Description
4 |
5 | Please include a summary of the change and which issue is fixed.
6 |
7 | Fixes # (issue)
8 |
9 | ## Why should this be added
10 |
11 | Explain value.
12 |
13 | ## Checklist
14 |
15 | - [ ] My code follows the style guidelines of this project
16 | - [ ] Checks are passing
17 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | # See https://help.github.com/articles/ignoring-files for more about ignoring files.
2 | #
3 | # If you find yourself ignoring temporary files generated by your text editor
4 | # or operating system, you probably want to add a global ignore instead:
5 | # git config --global core.excludesfile '~/.gitignore_global'
6 |
7 | # Ignore bundler config.
8 | /.bundle
9 |
10 | # Ignore all logfiles and tempfiles.
11 | /log/*
12 | /tmp/*
13 | !/log/.keep
14 | !/tmp/.keep
15 |
16 | # Ignore uploaded files in development.
17 | /storage/*
18 | !/storage/.keep
19 |
20 | /public/assets
21 | .byebug_history
22 |
23 | # Ignore master key for decrypting credentials and more.
24 | /config/master.key
25 |
26 | /public/packs
27 | /public/packs-test
28 | /node_modules
29 | /yarn-error.log
30 | yarn-debug.log*
31 | .yarn-integrity
32 |
--------------------------------------------------------------------------------
/.ruby-version:
--------------------------------------------------------------------------------
1 | 2.6.5
2 |
--------------------------------------------------------------------------------
/CODE_OF_CONDUCT.md:
--------------------------------------------------------------------------------
1 | # Contributor Covenant Code of Conduct
2 |
3 | ## Our Pledge
4 |
5 | In the interest of fostering an open and welcoming environment, we as
6 | contributors and maintainers pledge to making participation in our project and
7 | our community a harassment-free experience for everyone, regardless of age, body
8 | size, disability, ethnicity, sex characteristics, gender identity and expression,
9 | level of experience, education, socio-economic status, nationality, personal
10 | appearance, race, religion, or sexual identity and orientation.
11 |
12 | ## Our Standards
13 |
14 | Examples of behavior that contributes to creating a positive environment
15 | include:
16 |
17 | * Using welcoming and inclusive language
18 | * Being respectful of differing viewpoints and experiences
19 | * Gracefully accepting constructive criticism
20 | * Focusing on what is best for the community
21 | * Showing empathy towards other community members
22 |
23 | Examples of unacceptable behavior by participants include:
24 |
25 | * The use of sexualized language or imagery and unwelcome sexual attention or
26 | advances
27 | * Trolling, insulting/derogatory comments, and personal or political attacks
28 | * Public or private harassment
29 | * Publishing others' private information, such as a physical or electronic
30 | address, without explicit permission
31 | * Other conduct which could reasonably be considered inappropriate in a
32 | professional setting
33 |
34 | ## Our Responsibilities
35 |
36 | Project maintainers are responsible for clarifying the standards of acceptable
37 | behavior and are expected to take appropriate and fair corrective action in
38 | response to any instances of unacceptable behavior.
39 |
40 | Project maintainers have the right and responsibility to remove, edit, or
41 | reject comments, commits, code, wiki edits, issues, and other contributions
42 | that are not aligned to this Code of Conduct, or to ban temporarily or
43 | permanently any contributor for other behaviors that they deem inappropriate,
44 | threatening, offensive, or harmful.
45 |
46 | ## Scope
47 |
48 | This Code of Conduct applies both within project spaces and in public spaces
49 | when an individual is representing the project or its community. Examples of
50 | representing a project or community include using an official project e-mail
51 | address, posting via an official social media account, or acting as an appointed
52 | representative at an online or offline event. Representation of a project may be
53 | further defined and clarified by project maintainers.
54 |
55 | ## Enforcement
56 |
57 | Instances of abusive, harassing, or otherwise unacceptable behavior may be
58 | reported by contacting the project team at andrewmcodes@protonmail.com. All
59 | complaints will be reviewed and investigated and will result in a response that
60 | is deemed necessary and appropriate to the circumstances. The project team is
61 | obligated to maintain confidentiality with regard to the reporter of an incident.
62 | Further details of specific enforcement policies may be posted separately.
63 |
64 | Project maintainers who do not follow or enforce the Code of Conduct in good
65 | faith may face temporary or permanent repercussions as determined by other
66 | members of the project's leadership.
67 |
68 | ## Attribution
69 |
70 | This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71 | available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html
72 |
73 | [homepage]: https://www.contributor-covenant.org
74 |
75 | For answers to common questions about this code of conduct, see
76 | https://www.contributor-covenant.org/faq
77 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | # Contributing
2 |
3 | [code-of-conduct]: CODE_OF_CONDUCT.md
4 |
5 | Hey, there! 👋 Any and all contributions are welcome.
6 |
7 | Please make sure to read the [code of conduct][code-of-conduct] before submitting issues or pull requests.
8 |
9 | To lend a helping hand:
10 | * [Fork the repository](https://help.github.com/articles/fork-a-repo/)
11 | * Make your desired changes
12 | * [Create a pull request](https://help.github.com/articles/creating-a-pull-request/)
13 |
--------------------------------------------------------------------------------
/Gemfile:
--------------------------------------------------------------------------------
1 | source "https://rubygems.org"
2 | git_source(:github) { |repo| "https://github.com/#{repo}.git" }
3 |
4 | ruby "2.6.5"
5 |
6 | gem "bootsnap", ">= 1.4.2", require: false
7 | gem "faker"
8 | gem "jbuilder", "~> 2.7"
9 | gem "pg", ">= 0.18", "< 2.0"
10 | gem "puma", "~> 3.11"
11 | gem "rails", "~> 6.0.0"
12 | gem "redis", "~> 4.0"
13 | gem "sass-rails", "~> 5"
14 | gem "stimulus_reflex", "~> 2.1.2"
15 | gem "turbolinks", "~> 5"
16 | gem "webpacker", "~> 4.0"
17 | gem "kaminari"
18 |
19 | group :development, :test do
20 | gem "pry-rails"
21 | end
22 |
23 | group :development do
24 | gem "annotate"
25 | gem "web-console", ">= 3.3.0"
26 | gem "listen", ">= 3.0.5", "< 3.2"
27 | gem "spring"
28 | gem "spring-watcher-listen", "~> 2.0.0"
29 | gem "standard"
30 | end
31 |
32 | group :test do
33 | gem "capybara", ">= 2.15"
34 | gem "selenium-webdriver"
35 | gem "webdrivers"
36 | end
37 |
38 | # Windows does not include zoneinfo files, so bundle the tzinfo-data gem
39 | gem "tzinfo-data", platforms: [:mingw, :mswin, :x64_mingw, :jruby]
40 |
--------------------------------------------------------------------------------
/Gemfile.lock:
--------------------------------------------------------------------------------
1 | GEM
2 | remote: https://rubygems.org/
3 | specs:
4 | actioncable (6.0.0)
5 | actionpack (= 6.0.0)
6 | nio4r (~> 2.0)
7 | websocket-driver (>= 0.6.1)
8 | actionmailbox (6.0.0)
9 | actionpack (= 6.0.0)
10 | activejob (= 6.0.0)
11 | activerecord (= 6.0.0)
12 | activestorage (= 6.0.0)
13 | activesupport (= 6.0.0)
14 | mail (>= 2.7.1)
15 | actionmailer (6.0.0)
16 | actionpack (= 6.0.0)
17 | actionview (= 6.0.0)
18 | activejob (= 6.0.0)
19 | mail (~> 2.5, >= 2.5.4)
20 | rails-dom-testing (~> 2.0)
21 | actionpack (6.0.0)
22 | actionview (= 6.0.0)
23 | activesupport (= 6.0.0)
24 | rack (~> 2.0)
25 | rack-test (>= 0.6.3)
26 | rails-dom-testing (~> 2.0)
27 | rails-html-sanitizer (~> 1.0, >= 1.2.0)
28 | actiontext (6.0.0)
29 | actionpack (= 6.0.0)
30 | activerecord (= 6.0.0)
31 | activestorage (= 6.0.0)
32 | activesupport (= 6.0.0)
33 | nokogiri (>= 1.8.5)
34 | actionview (6.0.0)
35 | activesupport (= 6.0.0)
36 | builder (~> 3.1)
37 | erubi (~> 1.4)
38 | rails-dom-testing (~> 2.0)
39 | rails-html-sanitizer (~> 1.1, >= 1.2.0)
40 | activejob (6.0.0)
41 | activesupport (= 6.0.0)
42 | globalid (>= 0.3.6)
43 | activemodel (6.0.0)
44 | activesupport (= 6.0.0)
45 | activerecord (6.0.0)
46 | activemodel (= 6.0.0)
47 | activesupport (= 6.0.0)
48 | activestorage (6.0.0)
49 | actionpack (= 6.0.0)
50 | activejob (= 6.0.0)
51 | activerecord (= 6.0.0)
52 | marcel (~> 0.3.1)
53 | activesupport (6.0.0)
54 | concurrent-ruby (~> 1.0, >= 1.0.2)
55 | i18n (>= 0.7, < 2)
56 | minitest (~> 5.1)
57 | tzinfo (~> 1.1)
58 | zeitwerk (~> 2.1, >= 2.1.8)
59 | addressable (2.7.0)
60 | public_suffix (>= 2.0.2, < 5.0)
61 | annotate (2.6.5)
62 | activerecord (>= 2.3.0)
63 | rake (>= 0.8.7)
64 | ast (2.4.0)
65 | bindex (0.8.1)
66 | bootsnap (1.4.5)
67 | msgpack (~> 1.0)
68 | builder (3.2.3)
69 | cable_ready (4.0.7)
70 | rails (>= 5.2)
71 | capybara (3.29.0)
72 | addressable
73 | mini_mime (>= 0.1.3)
74 | nokogiri (~> 1.8)
75 | rack (>= 1.6.0)
76 | rack-test (>= 0.6.3)
77 | regexp_parser (~> 1.5)
78 | xpath (~> 3.2)
79 | childprocess (3.0.0)
80 | coderay (1.1.2)
81 | concurrent-ruby (1.1.5)
82 | crass (1.0.4)
83 | erubi (1.9.0)
84 | faker (2.6.0)
85 | i18n (>= 1.6, < 1.8)
86 | ffi (1.11.1)
87 | globalid (0.4.2)
88 | activesupport (>= 4.2.0)
89 | i18n (1.7.0)
90 | concurrent-ruby (~> 1.0)
91 | jaro_winkler (1.5.3)
92 | jbuilder (2.9.1)
93 | activesupport (>= 4.2.0)
94 | kaminari (1.1.1)
95 | activesupport (>= 4.1.0)
96 | kaminari-actionview (= 1.1.1)
97 | kaminari-activerecord (= 1.1.1)
98 | kaminari-core (= 1.1.1)
99 | kaminari-actionview (1.1.1)
100 | actionview
101 | kaminari-core (= 1.1.1)
102 | kaminari-activerecord (1.1.1)
103 | activerecord
104 | kaminari-core (= 1.1.1)
105 | kaminari-core (1.1.1)
106 | listen (3.1.5)
107 | rb-fsevent (~> 0.9, >= 0.9.4)
108 | rb-inotify (~> 0.9, >= 0.9.7)
109 | ruby_dep (~> 1.2)
110 | loofah (2.3.0)
111 | crass (~> 1.0.2)
112 | nokogiri (>= 1.5.9)
113 | mail (2.7.1)
114 | mini_mime (>= 0.1.1)
115 | marcel (0.3.3)
116 | mimemagic (~> 0.3.2)
117 | method_source (0.9.2)
118 | mimemagic (0.3.3)
119 | mini_mime (1.0.2)
120 | mini_portile2 (2.4.0)
121 | minitest (5.12.2)
122 | msgpack (1.3.1)
123 | nio4r (2.5.2)
124 | nokogiri (1.10.4)
125 | mini_portile2 (~> 2.4.0)
126 | parallel (1.18.0)
127 | parser (2.6.5.0)
128 | ast (~> 2.4.0)
129 | pg (1.1.4)
130 | pry (0.12.2)
131 | coderay (~> 1.1.0)
132 | method_source (~> 0.9.0)
133 | pry-rails (0.3.9)
134 | pry (>= 0.10.4)
135 | public_suffix (4.0.1)
136 | puma (3.12.1)
137 | rack (2.0.7)
138 | rack-proxy (0.6.5)
139 | rack
140 | rack-test (1.1.0)
141 | rack (>= 1.0, < 3)
142 | rails (6.0.0)
143 | actioncable (= 6.0.0)
144 | actionmailbox (= 6.0.0)
145 | actionmailer (= 6.0.0)
146 | actionpack (= 6.0.0)
147 | actiontext (= 6.0.0)
148 | actionview (= 6.0.0)
149 | activejob (= 6.0.0)
150 | activemodel (= 6.0.0)
151 | activerecord (= 6.0.0)
152 | activestorage (= 6.0.0)
153 | activesupport (= 6.0.0)
154 | bundler (>= 1.3.0)
155 | railties (= 6.0.0)
156 | sprockets-rails (>= 2.0.0)
157 | rails-dom-testing (2.0.3)
158 | activesupport (>= 4.2.0)
159 | nokogiri (>= 1.6)
160 | rails-html-sanitizer (1.3.0)
161 | loofah (~> 2.3)
162 | railties (6.0.0)
163 | actionpack (= 6.0.0)
164 | activesupport (= 6.0.0)
165 | method_source
166 | rake (>= 0.8.7)
167 | thor (>= 0.20.3, < 2.0)
168 | rainbow (3.0.0)
169 | rake (13.0.0)
170 | rb-fsevent (0.10.3)
171 | rb-inotify (0.10.0)
172 | ffi (~> 1.0)
173 | redis (4.1.3)
174 | regexp_parser (1.6.0)
175 | rubocop (0.72.0)
176 | jaro_winkler (~> 1.5.1)
177 | parallel (~> 1.10)
178 | parser (>= 2.6)
179 | rainbow (>= 2.2.2, < 4.0)
180 | ruby-progressbar (~> 1.7)
181 | unicode-display_width (>= 1.4.0, < 1.7)
182 | rubocop-performance (1.4.1)
183 | rubocop (>= 0.71.0)
184 | ruby-progressbar (1.10.1)
185 | ruby_dep (1.5.0)
186 | rubyzip (2.0.0)
187 | sass (3.7.4)
188 | sass-listen (~> 4.0.0)
189 | sass-listen (4.0.0)
190 | rb-fsevent (~> 0.9, >= 0.9.4)
191 | rb-inotify (~> 0.9, >= 0.9.7)
192 | sass-rails (5.1.0)
193 | railties (>= 5.2.0)
194 | sass (~> 3.1)
195 | sprockets (>= 2.8, < 4.0)
196 | sprockets-rails (>= 2.0, < 4.0)
197 | tilt (>= 1.1, < 3)
198 | selenium-webdriver (3.142.6)
199 | childprocess (>= 0.5, < 4.0)
200 | rubyzip (>= 1.2.2)
201 | spring (2.1.0)
202 | spring-watcher-listen (2.0.1)
203 | listen (>= 2.7, < 4.0)
204 | spring (>= 1.2, < 3.0)
205 | sprockets (3.7.2)
206 | concurrent-ruby (~> 1.0)
207 | rack (> 1, < 3)
208 | sprockets-rails (3.2.1)
209 | actionpack (>= 4.0)
210 | activesupport (>= 4.0)
211 | sprockets (>= 3.0.0)
212 | standard (0.1.4)
213 | rubocop (~> 0.72.0)
214 | rubocop-performance (~> 1.4.0)
215 | stimulus_reflex (2.1.2)
216 | cable_ready (>= 4.0.7)
217 | nokogiri
218 | rack
219 | rails (>= 5.2)
220 | thor (0.20.3)
221 | thread_safe (0.3.6)
222 | tilt (2.0.10)
223 | turbolinks (5.2.1)
224 | turbolinks-source (~> 5.2)
225 | turbolinks-source (5.2.0)
226 | tzinfo (1.2.5)
227 | thread_safe (~> 0.1)
228 | unicode-display_width (1.6.0)
229 | web-console (4.0.1)
230 | actionview (>= 6.0.0)
231 | activemodel (>= 6.0.0)
232 | bindex (>= 0.4.0)
233 | railties (>= 6.0.0)
234 | webdrivers (4.1.3)
235 | nokogiri (~> 1.6)
236 | rubyzip (>= 1.3.0)
237 | selenium-webdriver (>= 3.0, < 4.0)
238 | webpacker (4.0.7)
239 | activesupport (>= 4.2)
240 | rack-proxy (>= 0.6.1)
241 | railties (>= 4.2)
242 | websocket-driver (0.7.1)
243 | websocket-extensions (>= 0.1.0)
244 | websocket-extensions (0.1.4)
245 | xpath (3.2.0)
246 | nokogiri (~> 1.8)
247 | zeitwerk (2.2.0)
248 |
249 | PLATFORMS
250 | ruby
251 |
252 | DEPENDENCIES
253 | annotate
254 | bootsnap (>= 1.4.2)
255 | capybara (>= 2.15)
256 | faker
257 | jbuilder (~> 2.7)
258 | kaminari
259 | listen (>= 3.0.5, < 3.2)
260 | pg (>= 0.18, < 2.0)
261 | pry-rails
262 | puma (~> 3.11)
263 | rails (~> 6.0.0)
264 | redis (~> 4.0)
265 | sass-rails (~> 5)
266 | selenium-webdriver
267 | spring
268 | spring-watcher-listen (~> 2.0.0)
269 | standard
270 | stimulus_reflex (~> 2.1.2)
271 | turbolinks (~> 5)
272 | tzinfo-data
273 | web-console (>= 3.3.0)
274 | webdrivers
275 | webpacker (~> 4.0)
276 |
277 | RUBY VERSION
278 | ruby 2.6.5p114
279 |
280 | BUNDLED WITH
281 | 2.0.2
282 |
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2019 Andrew Mason
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # README
2 |
3 | ## StimulusReflex
4 |
5 | Make sure you checkout [StimulusReflex](https://github.com/hopsoft/stimulus_reflex) for more information on how this awesomeness was achieved.
6 |
7 | You can find documentation on the project [here](https://docs.stimulusreflex.com). If you run into trouble, reach out to me on [Twitter](https://twitter.com/andrewmcodes) and I will try to help!
8 |
9 | ## Setup instructions
10 |
11 | 1. Dependencies
12 |
13 | Make sure you have ruby, node, and postgres installed and running.
14 |
15 | Here is what I am using:
16 |
17 | ```
18 | ➜ rbenv -v
19 | rbenv 1.1.2
20 |
21 | ➜ ruby -v
22 | ruby 2.6.5p114 (2019-10-01 revision 67812) [x86_64-darwin18]
23 |
24 | ➜ nvm --version
25 | 0.35.0
26 |
27 | ➜ node -v
28 | v12.11.1
29 |
30 | ➜ postgres --version
31 | postgres (PostgreSQL) 11.5
32 | ```
33 |
34 | 2. Clone the repo
35 |
36 | ```
37 | git clone https://github.com/andrewmcodes/stimulus_reflex_table_filter
38 | cd stimulus_reflex_table_filter
39 | ```
40 |
41 | 3. `bundle install && yarn`
42 |
43 | 4. `rails db:create db:migrate db:seed`
44 |
45 | 5. `rails s`
46 |
47 | 6. Go to `localhost:3000` and see the magic.
48 |
49 | 7. Feel free to experiment and submit pull requests!
50 |
51 | ## Tutorial
52 |
53 | This is still a work in progress, but the tutorial to create this can be found [here](TUTORIAL.md).
54 |
55 | ## Contributing
56 |
57 | ### Code of Conduct
58 |
59 | Everyone interacting with StimulusReflex is expected to follow the [Code of Conduct](CODE_OF_CONDUCT.md)
60 |
61 | ### Coding Standards
62 |
63 | This project uses [Standard](https://github.com/testdouble/standard) to minimize bike shedding related to code formatting.
64 |
65 | Please run `bundle exec standardrb --fix` prior submitting pull requests.
66 |
67 | ### Contributing Guide
68 |
69 | [Contributing Guide](/CONTRIBUTING.md)
70 |
71 | ## License
72 |
73 | [MIT](/LICENSE.md)
74 |
--------------------------------------------------------------------------------
/Rakefile:
--------------------------------------------------------------------------------
1 | # Add your own tasks in files placed in lib/tasks ending in .rake,
2 | # for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
3 |
4 | require_relative "config/application"
5 |
6 | Rails.application.load_tasks
7 |
--------------------------------------------------------------------------------
/TUTORIAL.md:
--------------------------------------------------------------------------------
1 |
2 | ## Steps taken:
3 |
4 | ### 1
5 |
6 | ```sh
7 | rails new stimulus_reflex_table_filter --skip-coffee --webpack=stimulus -d postgresql
8 | cd stimulus_reflex_table_filter
9 | rails db:create
10 | ```
11 |
12 | ### 2
13 |
14 | ```sh
15 | git init
16 | git add README.md
17 | git commit -m "first commit"
18 | git remote add origin https://github.com/andrewmcodes/stimulus_reflex_table_filter.git
19 | git push -u origin master
20 | ```
21 |
22 | ### 3
23 |
24 | Add stimulus_reflex, annotate, faker, and standard to `Gemfile`. If you want to deploy the app to heroku, also add the redis gem.
25 |
26 | ```sh
27 | bundle
28 | ```
29 |
30 | Add stimulus_reflex to our `package.json`
31 |
32 | ```sh
33 | yarn add stimulus_reflex
34 | ```
35 |
36 | ### 4
37 |
38 | Add Tailwind
39 |
40 | ```sh
41 | yarn add tailwindcss --dev
42 | ./node_modules/.bin/tailwind init
43 | ```
44 |
45 | Setup Tailwind: [instructions](https://dev.to/andrewmcodes/use-tailwind-css-1-0-in-your-rails-app-4pm4)
46 |
47 |
48 | ### 5
49 |
50 | Scaffold `Restaurant` and remove all actions except :index
51 |
52 | ```sh
53 | rails generate model Restaurant name:string stars:integer price:integer category:string
54 | rails generate controller restaurants index
55 | ```
56 |
57 | These commands should have generated:
58 | - `db/migrate/20191013003319_create_restaurants.rb`
59 | - `app/models/restaurant.rb`
60 | - `test/models/restaurant_test.rb`
61 | - `test/fixtures/restaurants.yml`
62 | - `app/controllers/restaurants_controller.rb`
63 | - `app/views/restaurants`
64 | - `app/views/restaurants/index.html.erb`
65 | - `test/controllers/restaurants_controller_test.rb`
66 | - `app/helpers/restaurants_helper.rb`
67 | - `app/assets/stylesheets/restaurants.scss`
68 |
69 | Lets check the generated migration and modify that slighly:
70 |
71 | ```rb
72 | class CreateRestaurants < ActiveRecord::Migration[6.0]
73 | def change
74 | create_table :restaurants do |t|
75 | t.string :name, null: false
76 | t.integer :stars, null: false, default: 0
77 | t.integer :price, null: false, default: 1
78 | t.string :category, null: false
79 |
80 | t.timestamps
81 | end
82 | end
83 | end
84 | ```
85 |
86 | Lets also add some seeds:
87 |
88 | ```rb
89 | # db/seeds.rb
90 |
91 | 101.times do
92 | Restaurant.create(
93 | name: Faker::Restaurant.name,
94 | stars: [1, 2, 3, 4, 5].sample,
95 | price: [1, 2, 3].sample,
96 | category: Faker::Restaurant.type,
97 | )
98 | end
99 | ```
100 |
101 | Ok now lets run `rails db:migrate db:seed` to run our migration and add some records to our database. Let's also run `bundle exec annotate` to annotate some of our files with our table info.
102 |
103 | ### 6
104 |
105 | Let's update `app/models/restaurant.rb`
106 |
107 | ```rb
108 | class Restaurant < ApplicationRecord
109 | validates_inclusion_of :stars, in: 0..5
110 | validates_inclusion_of :price, in: 1..3
111 |
112 | FILTERS = %w[name stars price category].freeze
113 | end
114 | ```
115 |
116 | ### 7
117 |
118 | Go to `config/routes.rb` and add `root "restaurants#index`.
119 |
120 | Your routes file should now look like:
121 |
122 | ```rb
123 | Rails.application.routes.draw do
124 | root "restaurants#index"
125 | end
126 | ```
127 |
128 | ### 8
129 |
130 | Update `app/controllers/restaurants_controller.rb` to only support the `:index` method.
131 |
132 | ```rb
133 | class RestaurantsController < ApplicationController
134 | def index
135 | session[:filter] = "name" unless filter_permitted?(session[:filter])
136 | @filtered_restaurants = set_filter_ordered_restaurants
137 | end
138 |
139 | private
140 |
141 | def set_filter_ordered_restaurants
142 | if session[:filter_order] == :reverse
143 | Restaurant.order(session[:filter]).reverse
144 | else
145 | Restaurant.order(session[:filter])
146 | end
147 | end
148 |
149 | def filter_permitted?(filter)
150 | Restaurant::FILTERS.include? filter
151 | end
152 | end
153 | ```
154 |
155 | ### 9
156 |
157 | Update `app/views/restaurants/index.html.erb` so that table column headers are wired to the StimulusReflex action `filter`, passing in the current active filter as an attribute.
158 |
159 | ```rb
160 |
161 |
162 | <% Restaurant::FILTERS.each do |filter| %>
163 |
164 | <%= link_to filter.capitalize, "#", class: filter_css(filter), data: { reflex: "click->RestaurantsReflex#filter", room: session.id, filter: filter } %>
165 |
166 | <% end %>
167 |
168 |
169 | ```
170 |
171 | ### 10
172 |
173 | Create `filter` Reflex method.. The sorting order is `:normal` unless the user clicks again on the same column heading multiple times.
174 |
175 | ```rb
176 | # app/reflexes/restaurants_reflex.rb
177 | class RestaurantsReflex < StimulusReflex::Reflex
178 | def filter
179 | session[:filter_order] = filter_order
180 | session[:filter] = element.dataset[:filter]
181 | end
182 |
183 | private
184 |
185 | def filter_order
186 | return :normal unless session[:filter] == element.dataset[:filter]
187 | if session[:filter_order] != :reverse
188 | :reverse
189 | else
190 | :normal
191 | end
192 | end
193 | end
194 | ```
195 |
196 | Now you should be able to click on table headers and have the list filter.
197 |
198 | ### 11
199 |
200 | Setup encrypted cookies-based session management for ActionCable, as described in the [StimulusReflex documentation for Security](https://docs.stimulusreflex.com/security). This code is literally cut-and-pasted into `app/controllers/application_controller.rb` and `app/channels/application_cable/connection.rb`.
201 |
202 | ### 12
203 |
204 | Let's add something fun... we'll fire off the confetti canon every time someone activates a Reflex.
205 |
206 | `yarn add dom-confetti`
207 |
208 | Create a stimulus controller.
209 |
210 | ```js
211 | // app/frontend/controllers/restaurants_controller.js
212 | import { Controller } from 'stimulus'
213 | import StimulusReflex from 'stimulus_reflex'
214 | import { confetti } from 'dom-confetti'
215 |
216 | export default class extends Controller {
217 | connect () {
218 | StimulusReflex.register(this)
219 | }
220 |
221 | afterReflex (anchorElement) {
222 | confetti(anchorElement)
223 | }
224 | }
225 | ```
226 |
227 | NOTE: If you did not follow my tailwind tutorial than this file will be at `app/javascript/controllers/restaurants_controller.js` not `app/frontend/controllers/restaurants_controller.js`
228 |
229 | Now clicking on the table headers should give a fun burst of confetti!
230 |
231 | ### 13
232 |
233 | Run Standard
234 |
235 | ```sh
236 | bundle exec standardrb --fix
237 | ```
238 |
--------------------------------------------------------------------------------
/app/channels/application_cable/channel.rb:
--------------------------------------------------------------------------------
1 | module ApplicationCable
2 | class Channel < ActionCable::Channel::Base
3 | end
4 | end
5 |
--------------------------------------------------------------------------------
/app/channels/application_cable/connection.rb:
--------------------------------------------------------------------------------
1 | module ApplicationCable
2 | class Connection < ActionCable::Connection::Base
3 | identified_by :session_id
4 |
5 | def connect
6 | self.session_id = cookies.encrypted[:session_id]
7 | end
8 | end
9 | end
10 |
--------------------------------------------------------------------------------
/app/controllers/application_controller.rb:
--------------------------------------------------------------------------------
1 | class ApplicationController < ActionController::Base
2 | before_action :set_action_cable_identifier
3 |
4 | private
5 |
6 | def set_action_cable_identifier
7 | cookies.encrypted[:session_id] = session.id
8 | end
9 | end
10 |
--------------------------------------------------------------------------------
/app/controllers/concerns/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/app/controllers/concerns/.keep
--------------------------------------------------------------------------------
/app/controllers/restaurants_controller.rb:
--------------------------------------------------------------------------------
1 | class RestaurantsController < ApplicationController
2 | def index
3 | session[:sort] = Restaurant::FILTERS.find { |f| f == session[:sort] } || "name"
4 | session[:page] ||= 1
5 | @restaurants = Restaurant
6 | .filtered(session[:filter])
7 | .sorted(session[:sort], session[:sort_order])
8 | .page(session[:page])
9 | end
10 | end
11 |
--------------------------------------------------------------------------------
/app/helpers/application_helper.rb:
--------------------------------------------------------------------------------
1 | module ApplicationHelper
2 | end
3 |
--------------------------------------------------------------------------------
/app/helpers/restaurants_helper.rb:
--------------------------------------------------------------------------------
1 | module RestaurantsHelper
2 | def price_to_dollar_signs(price)
3 | "$" * price
4 | end
5 |
6 | def stars_to_symbol(stars)
7 | "★" * stars
8 | end
9 |
10 | def sort_css(sort)
11 | "selected" if session[:sort] == sort
12 | end
13 |
14 | def arrow(current_sort, sort, direction)
15 | return unless current_sort == sort
16 | direction == :reverse ? "↑" : "↓"
17 | end
18 | end
19 |
--------------------------------------------------------------------------------
/app/javascript/controllers/index.js:
--------------------------------------------------------------------------------
1 | import { Application } from 'stimulus'
2 | import { definitionsFromContext } from 'stimulus/webpack-helpers'
3 | import StimulusReflex from 'stimulus_reflex'
4 |
5 | const application = Application.start()
6 | const context = require.context('controllers', true, /_controller\.js$/)
7 | application.load(definitionsFromContext(context))
8 | StimulusReflex.initialize(application)
9 |
--------------------------------------------------------------------------------
/app/javascript/controllers/restaurants_controller.js:
--------------------------------------------------------------------------------
1 | import { Controller } from 'stimulus'
2 | import StimulusReflex from 'stimulus_reflex'
3 | import { confetti } from 'dom-confetti'
4 |
5 | export default class extends Controller {
6 | connect () {
7 | StimulusReflex.register(this)
8 | }
9 |
10 | afterReflex (anchorElement) {
11 | confetti(anchorElement)
12 | }
13 | }
14 |
--------------------------------------------------------------------------------
/app/javascript/packs/application.js:
--------------------------------------------------------------------------------
1 | import 'controllers'
2 | import './stylesheets.css'
3 |
--------------------------------------------------------------------------------
/app/javascript/packs/stylesheets.css:
--------------------------------------------------------------------------------
1 | @tailwind base;
2 |
3 | @tailwind components;
4 |
5 | @tailwind utilities;
6 |
--------------------------------------------------------------------------------
/app/jobs/application_job.rb:
--------------------------------------------------------------------------------
1 | class ApplicationJob < ActiveJob::Base
2 | # Automatically retry jobs that encountered a deadlock
3 | # retry_on ActiveRecord::Deadlocked
4 |
5 | # Most jobs are safe to ignore if the underlying records are no longer available
6 | # discard_on ActiveJob::DeserializationError
7 | end
8 |
--------------------------------------------------------------------------------
/app/mailers/application_mailer.rb:
--------------------------------------------------------------------------------
1 | class ApplicationMailer < ActionMailer::Base
2 | default from: "from@example.com"
3 | layout "mailer"
4 | end
5 |
--------------------------------------------------------------------------------
/app/models/application_record.rb:
--------------------------------------------------------------------------------
1 | class ApplicationRecord < ActiveRecord::Base
2 | self.abstract_class = true
3 | end
4 |
--------------------------------------------------------------------------------
/app/models/concerns/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/app/models/concerns/.keep
--------------------------------------------------------------------------------
/app/models/restaurant.rb:
--------------------------------------------------------------------------------
1 | # == Schema Information
2 | #
3 | # Table name: restaurants
4 | #
5 | # id :integer not null, primary key
6 | # name :string not null
7 | # stars :integer default("0"), not null
8 | # price :integer default("1"), not null
9 | # category :string not null
10 | # created_at :datetime not null
11 | # updated_at :datetime not null
12 | #
13 |
14 | class Restaurant < ApplicationRecord
15 | scope :filtered, ->(name) { where("lower(name) LIKE ?", "%#{name&.downcase}%") }
16 | scope :sorted, ->(column, direction = :forward) { order(Arel.sql("#{column}#{" DESC" if direction == :reverse}")) }
17 |
18 | validates_inclusion_of :stars, in: 0..5
19 | validates_inclusion_of :price, in: 1..3
20 |
21 | FILTERS = %w[name stars price category].freeze
22 | end
23 |
--------------------------------------------------------------------------------
/app/reflexes/restaurants_reflex.rb:
--------------------------------------------------------------------------------
1 | class RestaurantsReflex < StimulusReflex::Reflex
2 | def sort
3 | session[:sort_order] = sort_order
4 | session[:sort] = element.dataset[:sort]
5 | end
6 |
7 | def filter
8 | session[:filter] = element[:value]
9 | session[:page] = 1
10 | end
11 |
12 | def page
13 | session[:page] = element.dataset[:page]
14 | end
15 |
16 | def sort_order
17 | return :reverse if session[:sort] == element.dataset[:sort] && session[:sort_order] != :reverse
18 | :forward
19 | end
20 | end
21 |
--------------------------------------------------------------------------------
/app/views/kaminari/_gap.html.erb:
--------------------------------------------------------------------------------
1 | <%# Non-link tag that stands for skipped pages...
2 | - available local variables
3 | current_page: a page object for the currently displayed page
4 | total_pages: total number of pages
5 | per_page: number of items to fetch per page
6 | remote: data-remote
7 | -%>
8 |
9 | <%= t('views.pagination.truncate').html_safe %>
10 |
11 |
--------------------------------------------------------------------------------
/app/views/kaminari/_next_page.html.erb:
--------------------------------------------------------------------------------
1 | <%# Link to the "Next" page
2 | - available local variables
3 | url: url to the next page
4 | current_page: a page object for the currently displayed page
5 | total_pages: total number of pages
6 | per_page: number of items to fetch per page
7 | remote: data-remote
8 | -%>
9 |
10 | <%=
11 | link_to_unless current_page.last?,
12 | t('views.pagination.next').html_safe,
13 | "#",
14 | "data-page": current_page + 1,
15 | "data-reflex": "click->RestaurantsReflex#page",
16 | class: "block hover:text-white hover:bg-black text-blue border-r border-grey-light px-3 py-2"
17 | %>
18 |
19 |
--------------------------------------------------------------------------------
/app/views/kaminari/_page.html.erb:
--------------------------------------------------------------------------------
1 | <%# Link showing page number
2 | - available local variables
3 | page: a page object for "this" page
4 | url: url to this page
5 | current_page: a page object for the currently displayed page
6 | total_pages: total number of pages
7 | per_page: number of items to fetch per page
8 | remote: data-remote
9 | -%>
10 |
11 | <% if page.current? %>
12 | <%= link_to page, "#", :"data-page" => page, :"data-reflex" => "click->RestaurantsReflex#page", class: "block text-black bg-white border-r border-blue px-3 py-2" %>
13 | <% else %>
14 | <%= link_to page, "#", :"data-page" => page, :"data-reflex" => "click->RestaurantsReflex#page", class: "block hover:text-white hover:bg-black text-blue border-r border-grey-light px-3 py-2" %>
15 | <% end %>
16 |
--------------------------------------------------------------------------------
/app/views/kaminari/_paginator.html.erb:
--------------------------------------------------------------------------------
1 | <%# The container tag
2 | - available local variables
3 | current_page: a page object for the currently displayed page
4 | total_pages: total number of pages
5 | per_page: number of items to fetch per page
6 | remote: data-remote
7 | paginator: the paginator that renders the pagination tags inside
8 | -%>
9 | <%= paginator.render do -%>
10 |
11 | <%= prev_page_tag unless current_page.first? %>
12 | <% each_page do |page| -%>
13 | <% if page.display_tag? -%>
14 | <%= page_tag page %>
15 | <% elsif !page.was_truncated? -%>
16 | <%= gap_tag %>
17 | <% end -%>
18 | <% end -%>
19 | <% unless current_page.out_of_range? %>
20 | <%= next_page_tag unless current_page.last? %>
21 | <% end %>
22 |
23 | <% end -%>
24 |
--------------------------------------------------------------------------------
/app/views/kaminari/_prev_page.html.erb:
--------------------------------------------------------------------------------
1 | <%# Link to the "Previous" page
2 | - available local variables
3 | url: url to the previous page
4 | current_page: a page object for the currently displayed page
5 | total_pages: total number of pages
6 | per_page: number of items to fetch per page
7 | remote: data-remote
8 | -%>
9 |
10 | <%=
11 | link_to_unless current_page.first?,
12 | t('views.pagination.previous').html_safe,
13 | "#",
14 | "data-page": current_page - 1,
15 | "data-reflex": "click->RestaurantsReflex#page",
16 | class: "block hover:text-white hover:bg-black text-blue border-r border-grey-light px-3 py-2"
17 | %>
18 |
19 |
--------------------------------------------------------------------------------
/app/views/layouts/_header.html.erb:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 | I had a lot of fun building this demo with StimulusReflex .
9 |
10 |
--------------------------------------------------------------------------------
/app/views/layouts/application.html.erb:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | StimulusReflexTableFilter
5 | <%= csrf_meta_tags %>
6 | <%= csp_meta_tag %>
7 | <%= action_cable_meta_tag %>
8 |
9 | <%= stylesheet_pack_tag "stylesheets" %>
10 | <%= javascript_pack_tag "application" %>
11 |
12 |
13 |
14 | <%= render 'layouts/header' %>
15 |
16 | <%= yield %>
17 |
18 |
19 |
20 |
--------------------------------------------------------------------------------
/app/views/layouts/mailer.html.erb:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
8 |
9 |
10 |
11 | <%= yield %>
12 |
13 |
14 |
--------------------------------------------------------------------------------
/app/views/layouts/mailer.text.erb:
--------------------------------------------------------------------------------
1 | <%= yield %>
2 |
--------------------------------------------------------------------------------
/app/views/restaurants/index.html.erb:
--------------------------------------------------------------------------------
1 | Restaurants
2 |
3 |
4 |
5 |
6 |
7 |
8 | <% Restaurant::FILTERS.each do |sort| %>
9 |
10 | <%= link_to sort.capitalize, "#", class: sort_css(sort), data: { reflex: "click->RestaurantsReflex#sort", sort: sort } %>
11 | <%= arrow(sort, session[:sort], session[:sort_order]) %>
12 |
13 | <% end %>
14 |
15 |
16 |
17 |
18 | <% @restaurants.each do |restaurant| %>
19 |
20 | <%= restaurant.name %>
21 | <%= stars_to_symbol(restaurant.stars) %>
22 | <%= price_to_dollar_signs(restaurant.price) %>
23 | <%= restaurant.category %>
24 |
25 | <% end %>
26 |
27 |
28 |
29 | <%= paginate @restaurants %>
--------------------------------------------------------------------------------
/babel.config.js:
--------------------------------------------------------------------------------
1 | module.exports = function(api) {
2 | var validEnv = ['development', 'test', 'production']
3 | var currentEnv = api.env()
4 | var isDevelopmentEnv = api.env('development')
5 | var isProductionEnv = api.env('production')
6 | var isTestEnv = api.env('test')
7 |
8 | if (!validEnv.includes(currentEnv)) {
9 | throw new Error(
10 | 'Please specify a valid `NODE_ENV` or ' +
11 | '`BABEL_ENV` environment variables. Valid values are "development", ' +
12 | '"test", and "production". Instead, received: ' +
13 | JSON.stringify(currentEnv) +
14 | '.'
15 | )
16 | }
17 |
18 | return {
19 | presets: [
20 | isTestEnv && [
21 | require('@babel/preset-env').default,
22 | {
23 | targets: {
24 | node: 'current'
25 | }
26 | }
27 | ],
28 | (isProductionEnv || isDevelopmentEnv) && [
29 | require('@babel/preset-env').default,
30 | {
31 | forceAllTransforms: true,
32 | useBuiltIns: 'entry',
33 | corejs: 3,
34 | modules: false,
35 | exclude: ['transform-typeof-symbol']
36 | }
37 | ]
38 | ].filter(Boolean),
39 | plugins: [
40 | require('babel-plugin-macros'),
41 | require('@babel/plugin-syntax-dynamic-import').default,
42 | isTestEnv && require('babel-plugin-dynamic-import-node'),
43 | require('@babel/plugin-transform-destructuring').default,
44 | [
45 | require('@babel/plugin-proposal-class-properties').default,
46 | {
47 | loose: true
48 | }
49 | ],
50 | [
51 | require('@babel/plugin-proposal-object-rest-spread').default,
52 | {
53 | useBuiltIns: true
54 | }
55 | ],
56 | [
57 | require('@babel/plugin-transform-runtime').default,
58 | {
59 | helpers: false,
60 | regenerator: true,
61 | corejs: false
62 | }
63 | ],
64 | [
65 | require('@babel/plugin-transform-regenerator').default,
66 | {
67 | async: false
68 | }
69 | ]
70 | ].filter(Boolean)
71 | }
72 | }
73 |
--------------------------------------------------------------------------------
/bin/bundle:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | # frozen_string_literal: true
3 |
4 | #
5 | # This file was generated by Bundler.
6 | #
7 | # The application 'bundle' is installed as part of a gem, and
8 | # this file is here to facilitate running it.
9 | #
10 |
11 | require "rubygems"
12 |
13 | m = Module.new do
14 | module_function
15 |
16 | def invoked_as_script?
17 | File.expand_path($0) == File.expand_path(__FILE__)
18 | end
19 |
20 | def env_var_version
21 | ENV["BUNDLER_VERSION"]
22 | end
23 |
24 | def cli_arg_version
25 | return unless invoked_as_script? # don't want to hijack other binstubs
26 | return unless "update".start_with?(ARGV.first || " ") # must be running `bundle update`
27 | bundler_version = nil
28 | update_index = nil
29 | ARGV.each_with_index do |a, i|
30 | if update_index && update_index.succ == i && a =~ Gem::Version::ANCHORED_VERSION_PATTERN
31 | bundler_version = a
32 | end
33 | next unless a =~ /\A--bundler(?:[= ](#{Gem::Version::VERSION_PATTERN}))?\z/
34 | bundler_version = $1 || ">= 0.a"
35 | update_index = i
36 | end
37 | bundler_version
38 | end
39 |
40 | def gemfile
41 | gemfile = ENV["BUNDLE_GEMFILE"]
42 | return gemfile if gemfile && !gemfile.empty?
43 |
44 | File.expand_path("../../Gemfile", __FILE__)
45 | end
46 |
47 | def lockfile
48 | lockfile =
49 | case File.basename(gemfile)
50 | when "gems.rb" then gemfile.sub(/\.rb$/, gemfile)
51 | else "#{gemfile}.lock"
52 | end
53 | File.expand_path(lockfile)
54 | end
55 |
56 | def lockfile_version
57 | return unless File.file?(lockfile)
58 | lockfile_contents = File.read(lockfile)
59 | return unless lockfile_contents =~ /\n\nBUNDLED WITH\n\s{2,}(#{Gem::Version::VERSION_PATTERN})\n/
60 | Regexp.last_match(1)
61 | end
62 |
63 | def bundler_version
64 | @bundler_version ||= begin
65 | env_var_version || cli_arg_version ||
66 | lockfile_version || "#{Gem::Requirement.default}.a"
67 | end
68 | end
69 |
70 | def load_bundler!
71 | ENV["BUNDLE_GEMFILE"] ||= gemfile
72 |
73 | # must dup string for RG < 1.8 compatibility
74 | activate_bundler(bundler_version.dup)
75 | end
76 |
77 | def activate_bundler(bundler_version)
78 | if Gem::Version.correct?(bundler_version) && Gem::Version.new(bundler_version).release < Gem::Version.new("2.0")
79 | bundler_version = "< 2"
80 | end
81 | gem_error = activation_error_handling do
82 | gem "bundler", bundler_version
83 | end
84 | return if gem_error.nil?
85 | require_error = activation_error_handling do
86 | require "bundler/version"
87 | end
88 | return if require_error.nil? && Gem::Requirement.new(bundler_version).satisfied_by?(Gem::Version.new(Bundler::VERSION))
89 | warn "Activating bundler (#{bundler_version}) failed:\n#{gem_error.message}\n\nTo install the version of bundler this project requires, run `gem install bundler -v '#{bundler_version}'`"
90 | exit 42
91 | end
92 |
93 | def activation_error_handling
94 | yield
95 | nil
96 | rescue StandardError, LoadError => e
97 | e
98 | end
99 | end
100 |
101 | m.load_bundler!
102 |
103 | if m.invoked_as_script?
104 | load Gem.bin_path("bundler", "bundle")
105 | end
106 |
--------------------------------------------------------------------------------
/bin/rails:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | begin
3 | load File.expand_path('../spring', __FILE__)
4 | rescue LoadError => e
5 | raise unless e.message.include?('spring')
6 | end
7 | APP_PATH = File.expand_path('../config/application', __dir__)
8 | require_relative '../config/boot'
9 | require 'rails/commands'
10 |
--------------------------------------------------------------------------------
/bin/rake:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | begin
3 | load File.expand_path('../spring', __FILE__)
4 | rescue LoadError => e
5 | raise unless e.message.include?('spring')
6 | end
7 | require_relative '../config/boot'
8 | require 'rake'
9 | Rake.application.run
10 |
--------------------------------------------------------------------------------
/bin/setup:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | require 'fileutils'
3 |
4 | # path to your application root.
5 | APP_ROOT = File.expand_path('..', __dir__)
6 |
7 | def system!(*args)
8 | system(*args) || abort("\n== Command #{args} failed ==")
9 | end
10 |
11 | FileUtils.chdir APP_ROOT do
12 | # This script is a way to setup or update your development environment automatically.
13 | # This script is idempotent, so that you can run it at anytime and get an expectable outcome.
14 | # Add necessary setup steps to this file.
15 |
16 | puts '== Installing dependencies =='
17 | system! 'gem install bundler --conservative'
18 | system('bundle check') || system!('bundle install')
19 |
20 | # Install JavaScript dependencies
21 | # system('bin/yarn')
22 |
23 | # puts "\n== Copying sample files =="
24 | # unless File.exist?('config/database.yml')
25 | # FileUtils.cp 'config/database.yml.sample', 'config/database.yml'
26 | # end
27 |
28 | puts "\n== Preparing database =="
29 | system! 'bin/rails db:prepare'
30 |
31 | puts "\n== Removing old logs and tempfiles =="
32 | system! 'bin/rails log:clear tmp:clear'
33 |
34 | puts "\n== Restarting application server =="
35 | system! 'bin/rails restart'
36 | end
37 |
--------------------------------------------------------------------------------
/bin/spring:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 |
3 | # This file loads Spring without using Bundler, in order to be fast.
4 | # It gets overwritten when you run the `spring binstub` command.
5 |
6 | unless defined?(Spring)
7 | require 'rubygems'
8 | require 'bundler'
9 |
10 | lockfile = Bundler::LockfileParser.new(Bundler.default_lockfile.read)
11 | spring = lockfile.specs.detect { |spec| spec.name == 'spring' }
12 | if spring
13 | Gem.use_paths Gem.dir, Bundler.bundle_path.to_s, *Gem.path
14 | gem 'spring', spring.version
15 | require 'spring/binstub'
16 | end
17 | end
18 |
--------------------------------------------------------------------------------
/bin/webpack:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 |
3 | ENV["RAILS_ENV"] ||= ENV["RACK_ENV"] || "development"
4 | ENV["NODE_ENV"] ||= "development"
5 |
6 | require "pathname"
7 | ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile",
8 | Pathname.new(__FILE__).realpath)
9 |
10 | require "rubygems"
11 | require "bundler/setup"
12 |
13 | require "webpacker"
14 | require "webpacker/webpack_runner"
15 |
16 | APP_ROOT = File.expand_path("..", __dir__)
17 | Dir.chdir(APP_ROOT) do
18 | Webpacker::WebpackRunner.run(ARGV)
19 | end
20 |
--------------------------------------------------------------------------------
/bin/webpack-dev-server:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 |
3 | ENV["RAILS_ENV"] ||= ENV["RACK_ENV"] || "development"
4 | ENV["NODE_ENV"] ||= "development"
5 |
6 | require "pathname"
7 | ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile",
8 | Pathname.new(__FILE__).realpath)
9 |
10 | require "rubygems"
11 | require "bundler/setup"
12 |
13 | require "webpacker"
14 | require "webpacker/dev_server_runner"
15 |
16 | APP_ROOT = File.expand_path("..", __dir__)
17 | Dir.chdir(APP_ROOT) do
18 | Webpacker::DevServerRunner.run(ARGV)
19 | end
20 |
--------------------------------------------------------------------------------
/bin/yarn:
--------------------------------------------------------------------------------
1 | #!/usr/bin/env ruby
2 | APP_ROOT = File.expand_path('..', __dir__)
3 | Dir.chdir(APP_ROOT) do
4 | begin
5 | exec "yarnpkg", *ARGV
6 | rescue Errno::ENOENT
7 | $stderr.puts "Yarn executable was not detected in the system."
8 | $stderr.puts "Download Yarn at https://yarnpkg.com/en/docs/install"
9 | exit 1
10 | end
11 | end
12 |
--------------------------------------------------------------------------------
/config.ru:
--------------------------------------------------------------------------------
1 | # This file is used by Rack-based servers to start the application.
2 |
3 | require_relative "config/environment"
4 |
5 | run Rails.application
6 |
--------------------------------------------------------------------------------
/config/application.rb:
--------------------------------------------------------------------------------
1 | require_relative "boot"
2 |
3 | require "rails/all"
4 |
5 | # Require the gems listed in Gemfile, including any gems
6 | # you've limited to :test, :development, or :production.
7 | Bundler.require(*Rails.groups)
8 |
9 | module StimulusReflexTableFilter
10 | class Application < Rails::Application
11 | # Initialize configuration defaults for originally generated Rails version.
12 | config.load_defaults 6.0
13 |
14 | # Settings in config/environments/* take precedence over those specified here.
15 | # Application configuration can go into files in config/initializers
16 | # -- all .rb files in that directory are automatically loaded after loading
17 | # the framework and any gems in your application.
18 | ActionCable.server.config.logger = Logger.new(nil)
19 | end
20 | end
21 |
--------------------------------------------------------------------------------
/config/boot.rb:
--------------------------------------------------------------------------------
1 | ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__)
2 |
3 | require "bundler/setup" # Set up gems listed in the Gemfile.
4 | require "bootsnap/setup" # Speed up boot time by caching expensive operations.
5 |
--------------------------------------------------------------------------------
/config/cable.yml:
--------------------------------------------------------------------------------
1 | development:
2 | adapter: async
3 |
4 | test:
5 | adapter: test
6 |
7 | production:
8 | adapter: redis
9 | url: <%= ENV.fetch("REDIS_URL") { "redis://localhost:6379/1" } %>
10 | channel_prefix: stimulus_reflex_table_filter_production
11 |
--------------------------------------------------------------------------------
/config/credentials.yml.enc:
--------------------------------------------------------------------------------
1 | fHQ2F1gNkONnK9t9vDzwSY4orpQRKh76l1roGExieZb+N7j8uvwhw0suE/dY71CswvKMf7kNbw/+Etjnsw+6T89mo5IrgHkQ+tqhfbMO0OMaBopXTlJ+oIiBzmCBLdS2zbhV4dB+Gd6n6vIhw9CA8x7KNW4C0hOhJVTK/qSlxvWUCnzL05VKioZPxg+UqAlCcNIDTETcNu9TQvTOsk+v/qUHeoOWXMdoRQV3rG16NHa6RxUu7/XQFpveHj12CsQRr+LgKv+sZlh7I+D58LY4fIILVmJBJUy4wE997nO1nMp5DiX/XPXi43/ByDI495nPLq6wr8eXbuuivm/nkEcKDANtEPzt7uPbNX1BxNBnj2ZUdbJ9jkaxK36jCL+sHDySbENRo6Qy/8mJHw4ffijfW5xvRQCQxacen2m6--VhZ5TitKAEDbLQ3e--MChS0DCdjqX2RKGxqt8ItQ==
--------------------------------------------------------------------------------
/config/database.yml:
--------------------------------------------------------------------------------
1 | # PostgreSQL. Versions 9.3 and up are supported.
2 | #
3 | # Install the pg driver:
4 | # gem install pg
5 | # On macOS with Homebrew:
6 | # gem install pg -- --with-pg-config=/usr/local/bin/pg_config
7 | # On macOS with MacPorts:
8 | # gem install pg -- --with-pg-config=/opt/local/lib/postgresql84/bin/pg_config
9 | # On Windows:
10 | # gem install pg
11 | # Choose the win32 build.
12 | # Install PostgreSQL and put its /bin directory on your path.
13 | #
14 | # Configure Using Gemfile
15 | # gem 'pg'
16 | #
17 | default: &default
18 | adapter: postgresql
19 | encoding: unicode
20 | # For details on connection pooling, see Rails configuration guide
21 | # https://guides.rubyonrails.org/configuring.html#database-pooling
22 | pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
23 |
24 | development:
25 | <<: *default
26 | database: stimulus_reflex_table_filter_development
27 |
28 | # The specified database role being used to connect to postgres.
29 | # To create additional roles in postgres see `$ createuser --help`.
30 | # When left blank, postgres will use the default role. This is
31 | # the same name as the operating system user that initialized the database.
32 | #username: stimulus_reflex_table_filter
33 |
34 | # The password associated with the postgres role (username).
35 | #password:
36 |
37 | # Connect on a TCP socket. Omitted by default since the client uses a
38 | # domain socket that doesn't need configuration. Windows does not have
39 | # domain sockets, so uncomment these lines.
40 | #host: localhost
41 |
42 | # The TCP port the server listens on. Defaults to 5432.
43 | # If your server runs on a different port number, change accordingly.
44 | #port: 5432
45 |
46 | # Schema search path. The server defaults to $user,public
47 | #schema_search_path: myapp,sharedapp,public
48 |
49 | # Minimum log levels, in increasing order:
50 | # debug5, debug4, debug3, debug2, debug1,
51 | # log, notice, warning, error, fatal, and panic
52 | # Defaults to warning.
53 | #min_messages: notice
54 |
55 | # Warning: The database defined as "test" will be erased and
56 | # re-generated from your development database when you run "rake".
57 | # Do not set this db to the same as development or production.
58 | test:
59 | <<: *default
60 | database: stimulus_reflex_table_filter_test
61 |
62 | # As with config/credentials.yml, you never want to store sensitive information,
63 | # like your database password, in your source code. If your source code is
64 | # ever seen by anyone, they now have access to your database.
65 | #
66 | # Instead, provide the password as a unix environment variable when you boot
67 | # the app. Read https://guides.rubyonrails.org/configuring.html#configuring-a-database
68 | # for a full rundown on how to provide these environment variables in a
69 | # production deployment.
70 | #
71 | # On Heroku and other platform providers, you may have a full connection URL
72 | # available as an environment variable. For example:
73 | #
74 | # DATABASE_URL="postgres://myuser:mypass@localhost/somedatabase"
75 | #
76 | # You can use this database configuration with:
77 | #
78 | # production:
79 | # url: <%= ENV['DATABASE_URL'] %>
80 | #
81 | production:
82 | <<: *default
83 | database: stimulus_reflex_table_filter_production
84 | username: stimulus_reflex_table_filter
85 | password: <%= ENV['STIMULUS_REFLEX_TABLE_FILTER_DATABASE_PASSWORD'] %>
86 |
--------------------------------------------------------------------------------
/config/environment.rb:
--------------------------------------------------------------------------------
1 | # Load the Rails application.
2 | require_relative "application"
3 |
4 | # Initialize the Rails application.
5 | Rails.application.initialize!
6 |
--------------------------------------------------------------------------------
/config/environments/development.rb:
--------------------------------------------------------------------------------
1 | Rails.application.configure do
2 | # Settings specified here will take precedence over those in config/application.rb.
3 |
4 | # In the development environment your application's code is reloaded on
5 | # every request. This slows down response time but is perfect for development
6 | # since you don't have to restart the web server when you make code changes.
7 | config.cache_classes = false
8 |
9 | # Do not eager load code on boot.
10 | config.eager_load = false
11 |
12 | # Show full error reports.
13 | config.consider_all_requests_local = true
14 |
15 | # Enable/disable caching. By default caching is disabled.
16 | # Run rails dev:cache to toggle caching.
17 | if Rails.root.join("tmp", "caching-dev.txt").exist?
18 | config.action_controller.perform_caching = true
19 | config.action_controller.enable_fragment_cache_logging = true
20 |
21 | config.cache_store = :memory_store
22 | config.public_file_server.headers = {
23 | "Cache-Control" => "public, max-age=#{2.days.to_i}",
24 | }
25 | else
26 | config.action_controller.perform_caching = false
27 |
28 | config.cache_store = :null_store
29 | end
30 |
31 | # Store uploaded files on the local file system (see config/storage.yml for options).
32 | config.active_storage.service = :local
33 |
34 | # Don't care if the mailer can't send.
35 | config.action_mailer.raise_delivery_errors = false
36 |
37 | config.action_mailer.perform_caching = false
38 |
39 | # Print deprecation notices to the Rails logger.
40 | config.active_support.deprecation = :log
41 |
42 | # Raise an error on page load if there are pending migrations.
43 | config.active_record.migration_error = :page_load
44 |
45 | # Highlight code that triggered database queries in logs.
46 | config.active_record.verbose_query_logs = true
47 |
48 | # Debug mode disables concatenation and preprocessing of assets.
49 | # This option may cause significant delays in view rendering with a large
50 | # number of complex assets.
51 | config.assets.debug = true
52 |
53 | # Suppress logger output for asset requests.
54 | config.assets.quiet = true
55 |
56 | # Raises error for missing translations.
57 | # config.action_view.raise_on_missing_translations = true
58 |
59 | # Use an evented file watcher to asynchronously detect changes in source code,
60 | # routes, locales, etc. This feature depends on the listen gem.
61 | config.file_watcher = ActiveSupport::EventedFileUpdateChecker
62 | end
63 |
--------------------------------------------------------------------------------
/config/environments/production.rb:
--------------------------------------------------------------------------------
1 | Rails.application.configure do
2 | # Settings specified here will take precedence over those in config/application.rb.
3 |
4 | # Code is not reloaded between requests.
5 | config.cache_classes = true
6 |
7 | # Eager load code on boot. This eager loads most of Rails and
8 | # your application in memory, allowing both threaded web servers
9 | # and those relying on copy on write to perform better.
10 | # Rake tasks automatically ignore this option for performance.
11 | config.eager_load = true
12 |
13 | # Full error reports are disabled and caching is turned on.
14 | config.consider_all_requests_local = false
15 | config.action_controller.perform_caching = true
16 |
17 | # Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
18 | # or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
19 | # config.require_master_key = true
20 |
21 | # Disable serving static files from the `/public` folder by default since
22 | # Apache or NGINX already handles this.
23 | config.public_file_server.enabled = ENV["RAILS_SERVE_STATIC_FILES"].present?
24 |
25 | # Compress CSS using a preprocessor.
26 | # config.assets.css_compressor = :sass
27 |
28 | # Do not fallback to assets pipeline if a precompiled asset is missed.
29 | config.assets.compile = false
30 |
31 | # Enable serving of images, stylesheets, and JavaScripts from an asset server.
32 | # config.action_controller.asset_host = 'http://assets.example.com'
33 |
34 | # Specifies the header that your server uses for sending files.
35 | # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
36 | # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
37 |
38 | # Store uploaded files on the local file system (see config/storage.yml for options).
39 | config.active_storage.service = :local
40 |
41 | # Mount Action Cable outside main process or domain.
42 | # config.action_cable.mount_path = nil
43 | # config.action_cable.url = 'wss://example.com/cable'
44 | # config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
45 |
46 | # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
47 | # config.force_ssl = true
48 |
49 | # Use the lowest log level to ensure availability of diagnostic information
50 | # when problems arise.
51 | config.log_level = :debug
52 |
53 | # Prepend all log lines with the following tags.
54 | config.log_tags = [:request_id]
55 |
56 | # Use a different cache store in production.
57 | # config.cache_store = :mem_cache_store
58 |
59 | # Use a real queuing backend for Active Job (and separate queues per environment).
60 | # config.active_job.queue_adapter = :resque
61 | # config.active_job.queue_name_prefix = "stimulus_reflex_table_filter_production"
62 |
63 | config.action_mailer.perform_caching = false
64 |
65 | # Ignore bad email addresses and do not raise email delivery errors.
66 | # Set this to true and configure the email server for immediate delivery to raise delivery errors.
67 | # config.action_mailer.raise_delivery_errors = false
68 |
69 | # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
70 | # the I18n.default_locale when a translation cannot be found).
71 | config.i18n.fallbacks = true
72 |
73 | # Send deprecation notices to registered listeners.
74 | config.active_support.deprecation = :notify
75 |
76 | # Use default logging formatter so that PID and timestamp are not suppressed.
77 | config.log_formatter = ::Logger::Formatter.new
78 |
79 | # Use a different logger for distributed setups.
80 | # require 'syslog/logger'
81 | # config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
82 |
83 | if ENV["RAILS_LOG_TO_STDOUT"].present?
84 | logger = ActiveSupport::Logger.new(STDOUT)
85 | logger.formatter = config.log_formatter
86 | config.logger = ActiveSupport::TaggedLogging.new(logger)
87 | end
88 |
89 | # Do not dump schema after migrations.
90 | config.active_record.dump_schema_after_migration = false
91 |
92 | # Inserts middleware to perform automatic connection switching.
93 | # The `database_selector` hash is used to pass options to the DatabaseSelector
94 | # middleware. The `delay` is used to determine how long to wait after a write
95 | # to send a subsequent read to the primary.
96 | #
97 | # The `database_resolver` class is used by the middleware to determine which
98 | # database is appropriate to use based on the time delay.
99 | #
100 | # The `database_resolver_context` class is used by the middleware to set
101 | # timestamps for the last write to the primary. The resolver uses the context
102 | # class timestamps to determine how long to wait before reading from the
103 | # replica.
104 | #
105 | # By default Rails will store a last write timestamp in the session. The
106 | # DatabaseSelector middleware is designed as such you can define your own
107 | # strategy for connection switching and pass that into the middleware through
108 | # these configuration options.
109 | # config.active_record.database_selector = { delay: 2.seconds }
110 | # config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
111 | # config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
112 | end
113 |
--------------------------------------------------------------------------------
/config/environments/test.rb:
--------------------------------------------------------------------------------
1 | # The test environment is used exclusively to run your application's
2 | # test suite. You never need to work with it otherwise. Remember that
3 | # your test database is "scratch space" for the test suite and is wiped
4 | # and recreated between test runs. Don't rely on the data there!
5 |
6 | Rails.application.configure do
7 | # Settings specified here will take precedence over those in config/application.rb.
8 |
9 | config.cache_classes = false
10 |
11 | # Do not eager load code on boot. This avoids loading your whole application
12 | # just for the purpose of running a single test. If you are using a tool that
13 | # preloads Rails for running tests, you may have to set it to true.
14 | config.eager_load = false
15 |
16 | # Configure public file server for tests with Cache-Control for performance.
17 | config.public_file_server.enabled = true
18 | config.public_file_server.headers = {
19 | "Cache-Control" => "public, max-age=#{1.hour.to_i}",
20 | }
21 |
22 | # Show full error reports and disable caching.
23 | config.consider_all_requests_local = true
24 | config.action_controller.perform_caching = false
25 | config.cache_store = :null_store
26 |
27 | # Raise exceptions instead of rendering exception templates.
28 | config.action_dispatch.show_exceptions = false
29 |
30 | # Disable request forgery protection in test environment.
31 | config.action_controller.allow_forgery_protection = false
32 |
33 | # Store uploaded files on the local file system in a temporary directory.
34 | config.active_storage.service = :test
35 |
36 | config.action_mailer.perform_caching = false
37 |
38 | # Tell Action Mailer not to deliver emails to the real world.
39 | # The :test delivery method accumulates sent emails in the
40 | # ActionMailer::Base.deliveries array.
41 | config.action_mailer.delivery_method = :test
42 |
43 | # Print deprecation notices to the stderr.
44 | config.active_support.deprecation = :stderr
45 |
46 | # Raises error for missing translations.
47 | # config.action_view.raise_on_missing_translations = true
48 | end
49 |
--------------------------------------------------------------------------------
/config/initializers/application_controller_renderer.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # ActiveSupport::Reloader.to_prepare do
4 | # ApplicationController.renderer.defaults.merge!(
5 | # http_host: 'example.org',
6 | # https: false
7 | # )
8 | # end
9 |
--------------------------------------------------------------------------------
/config/initializers/assets.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Version of your assets, change this if you want to expire all your assets.
4 | Rails.application.config.assets.version = "1.0"
5 |
6 | # Add additional assets to the asset load path.
7 | # Rails.application.config.assets.paths << Emoji.images_path
8 | # Add Yarn node_modules folder to the asset load path.
9 | Rails.application.config.assets.paths << Rails.root.join("node_modules")
10 |
11 | # Precompile additional assets.
12 | # application.js, application.css, and all non-JS/CSS in the app/assets
13 | # folder are already added.
14 | # Rails.application.config.assets.precompile += %w( admin.js admin.css )
15 |
--------------------------------------------------------------------------------
/config/initializers/backtrace_silencers.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4 | # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5 |
6 | # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7 | # Rails.backtrace_cleaner.remove_silencers!
8 |
--------------------------------------------------------------------------------
/config/initializers/content_security_policy.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Define an application-wide content security policy
4 | # For further information see the following documentation
5 | # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy
6 |
7 | # Rails.application.config.content_security_policy do |policy|
8 | # policy.default_src :self, :https
9 | # policy.font_src :self, :https, :data
10 | # policy.img_src :self, :https, :data
11 | # policy.object_src :none
12 | # policy.script_src :self, :https
13 | # policy.style_src :self, :https
14 | # # If you are using webpack-dev-server then specify webpack-dev-server host
15 | # policy.connect_src :self, :https, "http://localhost:3035", "ws://localhost:3035" if Rails.env.development?
16 |
17 | # # Specify URI for violation reports
18 | # # policy.report_uri "/csp-violation-report-endpoint"
19 | # end
20 |
21 | # If you are using UJS then enable automatic nonce generation
22 | # Rails.application.config.content_security_policy_nonce_generator = -> request { SecureRandom.base64(16) }
23 |
24 | # Set the nonce only to specific directives
25 | # Rails.application.config.content_security_policy_nonce_directives = %w(script-src)
26 |
27 | # Report CSP violations to a specified URI
28 | # For further information see the following documentation:
29 | # https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Content-Security-Policy-Report-Only
30 | # Rails.application.config.content_security_policy_report_only = true
31 |
--------------------------------------------------------------------------------
/config/initializers/cookies_serializer.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Specify a serializer for the signed and encrypted cookie jars.
4 | # Valid options are :json, :marshal, and :hybrid.
5 | Rails.application.config.action_dispatch.cookies_serializer = :json
6 |
--------------------------------------------------------------------------------
/config/initializers/filter_parameter_logging.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Configure sensitive parameters which will be filtered from the log file.
4 | Rails.application.config.filter_parameters += [:password]
5 |
--------------------------------------------------------------------------------
/config/initializers/inflections.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Add new inflection rules using the following format. Inflections
4 | # are locale specific, and you may define rules for as many different
5 | # locales as you wish. All of these examples are active by default:
6 | # ActiveSupport::Inflector.inflections(:en) do |inflect|
7 | # inflect.plural /^(ox)$/i, '\1en'
8 | # inflect.singular /^(ox)en/i, '\1'
9 | # inflect.irregular 'person', 'people'
10 | # inflect.uncountable %w( fish sheep )
11 | # end
12 |
13 | # These inflection rules are supported but not enabled by default:
14 | # ActiveSupport::Inflector.inflections(:en) do |inflect|
15 | # inflect.acronym 'RESTful'
16 | # end
17 |
--------------------------------------------------------------------------------
/config/initializers/kaminari_config.rb:
--------------------------------------------------------------------------------
1 | # frozen_string_literal: true
2 |
3 | Kaminari.configure do |config|
4 | config.default_per_page = 10
5 | # config.max_per_page = nil
6 | config.window = 2
7 | config.outer_window = 1
8 | # config.left = 0
9 | # config.right = 0
10 | # config.page_method_name = :page
11 | # config.param_name = :page
12 | # config.params_on_first_page = false
13 | end
14 |
--------------------------------------------------------------------------------
/config/initializers/mime_types.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # Add new mime types for use in respond_to blocks:
4 | # Mime::Type.register "text/richtext", :rtf
5 |
--------------------------------------------------------------------------------
/config/initializers/wrap_parameters.rb:
--------------------------------------------------------------------------------
1 | # Be sure to restart your server when you modify this file.
2 |
3 | # This file contains settings for ActionController::ParamsWrapper which
4 | # is enabled by default.
5 |
6 | # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7 | ActiveSupport.on_load(:action_controller) do
8 | wrap_parameters format: [:json]
9 | end
10 |
11 | # To enable root element in JSON for ActiveRecord objects.
12 | # ActiveSupport.on_load(:active_record) do
13 | # self.include_root_in_json = true
14 | # end
15 |
--------------------------------------------------------------------------------
/config/locales/en.yml:
--------------------------------------------------------------------------------
1 | # Files in the config/locales directory are used for internationalization
2 | # and are automatically loaded by Rails. If you want to use locales other
3 | # than English, add the necessary files in this directory.
4 | #
5 | # To use the locales, use `I18n.t`:
6 | #
7 | # I18n.t 'hello'
8 | #
9 | # In views, this is aliased to just `t`:
10 | #
11 | # <%= t('hello') %>
12 | #
13 | # To use a different locale, set it with `I18n.locale`:
14 | #
15 | # I18n.locale = :es
16 | #
17 | # This would use the information in config/locales/es.yml.
18 | #
19 | # The following keys must be escaped otherwise they will not be retrieved by
20 | # the default I18n backend:
21 | #
22 | # true, false, on, off, yes, no
23 | #
24 | # Instead, surround them with single quotes.
25 | #
26 | # en:
27 | # 'true': 'foo'
28 | #
29 | # To learn more, please read the Rails Internationalization guide
30 | # available at https://guides.rubyonrails.org/i18n.html.
31 |
32 | en:
33 | views:
34 | pagination:
35 | next: ">"
36 | previous: "<"
37 | first: "<<"
38 | last: ">>"
39 | truncate: "..."
--------------------------------------------------------------------------------
/config/puma.rb:
--------------------------------------------------------------------------------
1 | # Puma can serve each request in a thread from an internal thread pool.
2 | # The `threads` method setting takes two numbers: a minimum and maximum.
3 | # Any libraries that use thread pools should be configured to match
4 | # the maximum value specified for Puma. Default is set to 5 threads for minimum
5 | # and maximum; this matches the default thread size of Active Record.
6 | #
7 | max_threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
8 | min_threads_count = ENV.fetch("RAILS_MIN_THREADS") { max_threads_count }
9 | threads min_threads_count, max_threads_count
10 |
11 | # Specifies the `port` that Puma will listen on to receive requests; default is 3000.
12 | #
13 | port ENV.fetch("PORT") { 3000 }
14 |
15 | # Specifies the `environment` that Puma will run in.
16 | #
17 | environment ENV.fetch("RAILS_ENV") { "development" }
18 |
19 | # Specifies the `pidfile` that Puma will use.
20 | pidfile ENV.fetch("PIDFILE") { "tmp/pids/server.pid" }
21 |
22 | # Specifies the number of `workers` to boot in clustered mode.
23 | # Workers are forked web server processes. If using threads and workers together
24 | # the concurrency of the application would be max `threads` * `workers`.
25 | # Workers do not work on JRuby or Windows (both of which do not support
26 | # processes).
27 | #
28 | # workers ENV.fetch("WEB_CONCURRENCY") { 2 }
29 |
30 | # Use the `preload_app!` method when specifying a `workers` number.
31 | # This directive tells Puma to first boot the application and load code
32 | # before forking the application. This takes advantage of Copy On Write
33 | # process behavior so workers use less memory.
34 | #
35 | # preload_app!
36 |
37 | # Allow puma to be restarted by `rails restart` command.
38 | plugin :tmp_restart
39 |
--------------------------------------------------------------------------------
/config/routes.rb:
--------------------------------------------------------------------------------
1 | Rails.application.routes.draw do
2 | resources :restaurants, only: :index
3 | root "restaurants#index"
4 | end
5 |
--------------------------------------------------------------------------------
/config/spring.rb:
--------------------------------------------------------------------------------
1 | Spring.watch(
2 | ".ruby-version",
3 | ".rbenv-vars",
4 | "tmp/restart.txt",
5 | "tmp/caching-dev.txt"
6 | )
7 |
--------------------------------------------------------------------------------
/config/storage.yml:
--------------------------------------------------------------------------------
1 | test:
2 | service: Disk
3 | root: <%= Rails.root.join("tmp/storage") %>
4 |
5 | local:
6 | service: Disk
7 | root: <%= Rails.root.join("storage") %>
8 |
9 | # Use rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key)
10 | # amazon:
11 | # service: S3
12 | # access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %>
13 | # secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %>
14 | # region: us-east-1
15 | # bucket: your_own_bucket
16 |
17 | # Remember not to checkin your GCS keyfile to a repository
18 | # google:
19 | # service: GCS
20 | # project: your_project
21 | # credentials: <%= Rails.root.join("path/to/gcs.keyfile") %>
22 | # bucket: your_own_bucket
23 |
24 | # Use rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key)
25 | # microsoft:
26 | # service: AzureStorage
27 | # storage_account_name: your_account_name
28 | # storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %>
29 | # container: your_container_name
30 |
31 | # mirror:
32 | # service: Mirror
33 | # primary: local
34 | # mirrors: [ amazon, google, microsoft ]
35 |
--------------------------------------------------------------------------------
/config/webpack/development.js:
--------------------------------------------------------------------------------
1 | process.env.NODE_ENV = process.env.NODE_ENV || 'development'
2 |
3 | const environment = require('./environment')
4 |
5 | module.exports = environment.toWebpackConfig()
6 |
--------------------------------------------------------------------------------
/config/webpack/environment.js:
--------------------------------------------------------------------------------
1 | const { environment } = require('@rails/webpacker')
2 |
3 | module.exports = environment
4 |
--------------------------------------------------------------------------------
/config/webpack/production.js:
--------------------------------------------------------------------------------
1 | process.env.NODE_ENV = process.env.NODE_ENV || 'production'
2 |
3 | const environment = require('./environment')
4 |
5 | module.exports = environment.toWebpackConfig()
6 |
--------------------------------------------------------------------------------
/config/webpack/test.js:
--------------------------------------------------------------------------------
1 | process.env.NODE_ENV = process.env.NODE_ENV || 'development'
2 |
3 | const environment = require('./environment')
4 |
5 | module.exports = environment.toWebpackConfig()
6 |
--------------------------------------------------------------------------------
/config/webpacker.yml:
--------------------------------------------------------------------------------
1 | # Note: You must restart bin/webpack-dev-server for changes to take effect
2 |
3 | default: &default
4 | source_path: app/javascript
5 | source_entry_path: packs
6 | public_root_path: public
7 | public_output_path: packs
8 | cache_path: tmp/cache/webpacker
9 | check_yarn_integrity: false
10 | webpack_compile_output: true
11 |
12 | # Additional paths webpack should lookup modules
13 | # ['app/assets', 'engine/foo/app/assets']
14 | resolved_paths: []
15 |
16 | # Reload manifest.json on all requests so we reload latest compiled packs
17 | cache_manifest: false
18 |
19 | # Extract and emit a css file
20 | extract_css: false
21 |
22 | static_assets_extensions:
23 | - .jpg
24 | - .jpeg
25 | - .png
26 | - .gif
27 | - .tiff
28 | - .ico
29 | - .svg
30 | - .eot
31 | - .otf
32 | - .ttf
33 | - .woff
34 | - .woff2
35 |
36 | extensions:
37 | - .mjs
38 | - .js
39 | - .sass
40 | - .scss
41 | - .css
42 | - .module.sass
43 | - .module.scss
44 | - .module.css
45 | - .png
46 | - .svg
47 | - .gif
48 | - .jpeg
49 | - .jpg
50 |
51 | development:
52 | <<: *default
53 | compile: true
54 |
55 | # Verifies that correct packages and versions are installed by inspecting package.json, yarn.lock, and node_modules
56 | check_yarn_integrity: true
57 |
58 | # Reference: https://webpack.js.org/configuration/dev-server/
59 | dev_server:
60 | https: false
61 | host: localhost
62 | port: 3035
63 | public: localhost:3035
64 | hmr: false
65 | # Inline should be set to true if using HMR
66 | inline: true
67 | overlay: true
68 | compress: true
69 | disable_host_check: true
70 | use_local_ip: false
71 | quiet: false
72 | headers:
73 | 'Access-Control-Allow-Origin': '*'
74 | watch_options:
75 | ignored: '**/node_modules/**'
76 |
77 |
78 | test:
79 | <<: *default
80 | compile: true
81 |
82 | # Compile test packs to a separate directory
83 | public_output_path: packs-test
84 |
85 | production:
86 | <<: *default
87 |
88 | # Production depends on precompilation of packs prior to booting for performance.
89 | compile: false
90 |
91 | # Extract and emit a css file
92 | extract_css: true
93 |
94 | # Cache manifest.json for performance
95 | cache_manifest: true
96 |
--------------------------------------------------------------------------------
/db/migrate/20191011234259_create_restaurants.rb:
--------------------------------------------------------------------------------
1 | class CreateRestaurants < ActiveRecord::Migration[6.0]
2 | def change
3 | create_table :restaurants do |t|
4 | t.string :name, null: false
5 | t.integer :stars, null: false, default: 0
6 | t.integer :price, null: false, default: 1
7 | t.string :category, null: false
8 |
9 | t.timestamps
10 | end
11 | end
12 | end
13 |
--------------------------------------------------------------------------------
/db/schema.rb:
--------------------------------------------------------------------------------
1 | # This file is auto-generated from the current state of the database. Instead
2 | # of editing this file, please use the migrations feature of Active Record to
3 | # incrementally modify your database, and then regenerate this schema definition.
4 | #
5 | # This file is the source Rails uses to define your schema when running `rails
6 | # db:schema:load`. When creating a new database, `rails db:schema:load` tends to
7 | # be faster and is potentially less error prone than running all of your
8 | # migrations from scratch. Old migrations may fail to apply correctly if those
9 | # migrations use external dependencies or application code.
10 | #
11 | # It's strongly recommended that you check this file into your version control system.
12 |
13 | ActiveRecord::Schema.define(version: 2019_10_11_234259) do
14 |
15 | # These are extensions that must be enabled in order to support this database
16 | enable_extension "plpgsql"
17 |
18 | create_table "restaurants", force: :cascade do |t|
19 | t.string "name", null: false
20 | t.integer "stars", default: 0, null: false
21 | t.integer "price", default: 1, null: false
22 | t.string "category", null: false
23 | t.datetime "created_at", precision: 6, null: false
24 | t.datetime "updated_at", precision: 6, null: false
25 | end
26 |
27 | end
28 |
--------------------------------------------------------------------------------
/db/seeds.rb:
--------------------------------------------------------------------------------
1 | 101.times do
2 | Restaurant.create(
3 | name: Faker::Restaurant.name,
4 | stars: [1, 2, 3, 4, 5].sample,
5 | price: [1, 2, 3].sample,
6 | category: Faker::Restaurant.type,
7 | )
8 | end
9 |
--------------------------------------------------------------------------------
/lib/assets/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/lib/assets/.keep
--------------------------------------------------------------------------------
/lib/tasks/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/lib/tasks/.keep
--------------------------------------------------------------------------------
/log/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/log/.keep
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "stimulus_reflex_table_filter",
3 | "private": true,
4 | "dependencies": {
5 | "@rails/actioncable": "^6.0.0",
6 | "@rails/webpacker": "^4.0.7",
7 | "dom-confetti": "^0.1.1",
8 | "stimulus": "^1.1.1",
9 | "stimulus_reflex": "^2.1.2",
10 | "tailwindcss": "^1.1.2"
11 | },
12 | "version": "0.1.0",
13 | "devDependencies": {
14 | "webpack-dev-server": "^3.8.2"
15 | }
16 | }
17 |
--------------------------------------------------------------------------------
/postcss.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | plugins: [
3 | require('autoprefixer'),
4 | require('postcss-import'),
5 | require('tailwindcss'),
6 | require('postcss-flexbugs-fixes'),
7 | require('postcss-preset-env')({
8 | autoprefixer: {
9 | flexbox: 'no-2009'
10 | },
11 | stage: 3
12 | })
13 | ]
14 | }
15 |
--------------------------------------------------------------------------------
/public/404.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | The page you were looking for doesn't exist (404)
5 |
6 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
The page you were looking for doesn't exist.
62 |
You may have mistyped the address or the page may have moved.
63 |
64 |
If you are the application owner check the logs for more information.
65 |
66 |
67 |
68 |
--------------------------------------------------------------------------------
/public/422.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | The change you wanted was rejected (422)
5 |
6 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
The change you wanted was rejected.
62 |
Maybe you tried to change something you didn't have access to.
63 |
64 |
If you are the application owner check the logs for more information.
65 |
66 |
67 |
68 |
--------------------------------------------------------------------------------
/public/500.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 | We're sorry, but something went wrong (500)
5 |
6 |
55 |
56 |
57 |
58 |
59 |
60 |
61 |
We're sorry, but something went wrong.
62 |
63 |
If you are the application owner check the logs for more information.
64 |
65 |
66 |
67 |
--------------------------------------------------------------------------------
/public/apple-touch-icon-precomposed.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/public/apple-touch-icon-precomposed.png
--------------------------------------------------------------------------------
/public/apple-touch-icon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/public/apple-touch-icon.png
--------------------------------------------------------------------------------
/public/favicon.ico:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/public/favicon.ico
--------------------------------------------------------------------------------
/public/robots.txt:
--------------------------------------------------------------------------------
1 | # See https://www.robotstxt.org/robotstxt.html for documentation on how to use the robots.txt file
2 |
--------------------------------------------------------------------------------
/storage/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/storage/.keep
--------------------------------------------------------------------------------
/tailwind.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | theme: {
3 | extend: {}
4 | },
5 | variants: {},
6 | plugins: []
7 | }
8 |
--------------------------------------------------------------------------------
/test/application_system_test_case.rb:
--------------------------------------------------------------------------------
1 | require "test_helper"
2 |
3 | class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
4 | driven_by :selenium, using: :chrome, screen_size: [1400, 1400]
5 | end
6 |
--------------------------------------------------------------------------------
/test/channels/application_cable/connection_test.rb:
--------------------------------------------------------------------------------
1 | require "test_helper"
2 |
3 | class ApplicationCable::ConnectionTest < ActionCable::Connection::TestCase
4 | # test "connects with cookies" do
5 | # cookies.signed[:user_id] = 42
6 | #
7 | # connect
8 | #
9 | # assert_equal connection.user_id, "42"
10 | # end
11 | end
12 |
--------------------------------------------------------------------------------
/test/controllers/restaurants_controller_test.rb:
--------------------------------------------------------------------------------
1 | require "test_helper"
2 |
3 | class RestaurantsControllerTest < ActionDispatch::IntegrationTest
4 | setup do
5 | @restaurant = restaurants(:one)
6 | end
7 |
8 | test "should get index" do
9 | get restaurants_url
10 | assert_response :success
11 | end
12 | end
13 |
--------------------------------------------------------------------------------
/test/fixtures/files/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/test/fixtures/files/.keep
--------------------------------------------------------------------------------
/test/fixtures/restaurants.yml:
--------------------------------------------------------------------------------
1 | # == Schema Information
2 | #
3 | # Table name: restaurants
4 | #
5 | # id :integer not null, primary key
6 | # name :string not null
7 | # stars :integer default("0"), not null
8 | # price :integer default("1"), not null
9 | # category :string not null
10 | # created_at :datetime not null
11 | # updated_at :datetime not null
12 | #
13 |
14 | # Read about fixtures at https://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
15 |
16 | one:
17 | name: MyString
18 | stars: 1
19 | price: 1
20 | category: MyString
21 |
--------------------------------------------------------------------------------
/test/helpers/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/test/helpers/.keep
--------------------------------------------------------------------------------
/test/integration/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/test/integration/.keep
--------------------------------------------------------------------------------
/test/mailers/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/test/mailers/.keep
--------------------------------------------------------------------------------
/test/models/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/test/models/.keep
--------------------------------------------------------------------------------
/test/models/restaurant_test.rb:
--------------------------------------------------------------------------------
1 | # == Schema Information
2 | #
3 | # Table name: restaurants
4 | #
5 | # id :integer not null, primary key
6 | # name :string not null
7 | # stars :integer default("0"), not null
8 | # price :integer default("1"), not null
9 | # category :string not null
10 | # created_at :datetime not null
11 | # updated_at :datetime not null
12 | #
13 |
14 | require "test_helper"
15 |
16 | class RestaurantTest < ActiveSupport::TestCase
17 | # test "the truth" do
18 | # assert true
19 | # end
20 | end
21 |
--------------------------------------------------------------------------------
/test/system/restaurants_test.rb:
--------------------------------------------------------------------------------
1 | require "application_system_test_case"
2 |
3 | class RestaurantsTest < ApplicationSystemTestCase
4 | setup do
5 | @restaurant = restaurants(:one)
6 | end
7 |
8 | test "visiting the index" do
9 | visit restaurants_url
10 | assert_selector "h1", text: "Restaurants"
11 | end
12 | end
13 |
--------------------------------------------------------------------------------
/test/test_helper.rb:
--------------------------------------------------------------------------------
1 | ENV["RAILS_ENV"] ||= "test"
2 | require_relative "../config/environment"
3 | require "rails/test_help"
4 |
5 | class ActiveSupport::TestCase
6 | # Run tests in parallel with specified workers
7 | parallelize(workers: :number_of_processors)
8 |
9 | # Setup all fixtures in test/fixtures/*.yml for all tests in alphabetical order.
10 | fixtures :all
11 |
12 | # Add more helper methods to be used by all tests here...
13 | end
14 |
--------------------------------------------------------------------------------
/tmp/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/tmp/.keep
--------------------------------------------------------------------------------
/vendor/.keep:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/andrewmcodes/stimulus_reflex_table_filter/47e30e90a8e5fe88ad511f24667601dbb8f48cbe/vendor/.keep
--------------------------------------------------------------------------------