From 6499969ab91802b7c87818ef4f0b35b966ffc5b2 Mon Sep 17 00:00:00 2001 From: Domizio Demichelis Date: Wed, 8 Jan 2025 06:28:52 +0700 Subject: [PATCH] WIP: Super refactoring --- ...{Keyset_ForUI.xml => Keyset_Augmented.xml} | 4 +- .rubocop.yml | 6 +- Gemfile.lock | 11 +- docs/api/javascript/setup.md | 4 +- docs/api/keyset.md | 2 +- docs/api/keyset_for_ui.md | 24 ++-- docs/extras/keyset_for_ui.md | 2 +- docs/extras/limit.md | 4 +- gem/apps/keyset.ru | 2 +- .../{keyset_for_ui.ru => keyset_augmented.ru} | 18 ++- gem/apps/keyset_sequel.ru | 4 +- gem/config/pagy.rb | 14 +- gem/lib/pagy.rb | 122 +++++++++++------ gem/lib/pagy/autoloading.rb | 55 ++++++++ gem/lib/pagy/b64.rb | 2 +- gem/lib/pagy/backend.rb | 16 +-- gem/lib/pagy/calendar.rb | 84 ------------ gem/lib/pagy/calendar/day.rb | 41 ------ gem/lib/pagy/calendar/month.rb | 42 ------ gem/lib/pagy/calendar/quarter.rb | 49 ------- gem/lib/pagy/calendar/unit.rb | 103 -------------- gem/lib/pagy/calendar/week.rb | 39 ------ gem/lib/pagy/calendar/year.rb | 35 ----- gem/lib/pagy/countless.rb | 38 ------ gem/lib/pagy/extras/arel.rb | 28 ---- gem/lib/pagy/extras/array.rb | 19 --- gem/lib/pagy/extras/countless.rb | 32 ----- gem/lib/pagy/extras/gearbox.rb | 93 +++++++------ gem/lib/pagy/extras/i18n.rb | 4 +- gem/lib/pagy/extras/jsonapi.rb | 2 +- gem/lib/pagy/extras/keyset.rb | 30 ---- gem/lib/pagy/extras/keyset_for_ui.rb | 39 ------ gem/lib/pagy/extras/limit.rb | 6 +- gem/lib/pagy/extras/overflow.rb | 81 ----------- gem/lib/pagy/extras/size.rb | 64 ++++----- gem/lib/pagy/extras/standalone.rb | 2 +- gem/lib/pagy/frontend.rb | 22 ++- gem/lib/pagy/frontend/javascript.rb | 50 ------- gem/lib/pagy/keyset.rb | 34 ++--- gem/lib/pagy/keyset/active_record_adapter.rb | 36 ----- gem/lib/pagy/keyset/adapters/active_record.rb | 38 ++++++ gem/lib/pagy/keyset/adapters/sequel.rb | 51 +++++++ gem/lib/pagy/keyset/augmented.rb | 129 ++++++++++++++++++ gem/lib/pagy/keyset/sequel_adapter.rb | 49 ------- gem/lib/pagy/keyset_for_ui.rb | 129 ------------------ gem/lib/pagy/mixin/arel.rb | 31 +++++ gem/lib/pagy/mixin/array.rb | 23 ++++ gem/lib/pagy/{extras => mixin}/bootstrap.rb | 12 +- gem/lib/pagy/{extras => mixin}/bulma.rb | 12 +- gem/lib/pagy/{extras => mixin}/calendar.rb | 18 +-- gem/lib/pagy/mixin/countless.rb | 32 +++++ .../{extras => mixin}/elasticsearch_rails.rb | 26 ++-- gem/lib/pagy/{extras => mixin}/headers.rb | 12 +- gem/lib/pagy/mixin/keyset.rb | 32 +++++ gem/lib/pagy/mixin/keyset_augmented.rb | 37 +++++ gem/lib/pagy/{extras => mixin}/meilisearch.rb | 16 ++- gem/lib/pagy/{extras => mixin}/metadata.rb | 12 +- gem/lib/pagy/mixin/offset.rb | 31 +++++ gem/lib/pagy/{extras => mixin}/pagy.rb | 10 +- gem/lib/pagy/{extras => mixin}/searchkick.rb | 18 +-- gem/lib/pagy/offset.rb | 70 ++++++++++ gem/lib/pagy/offset/calendar.rb | 86 ++++++++++++ gem/lib/pagy/offset/calendar/day.rb | 45 ++++++ gem/lib/pagy/offset/calendar/month.rb | 46 +++++++ gem/lib/pagy/offset/calendar/quarter.rb | 53 +++++++ gem/lib/pagy/offset/calendar/unit.rb | 119 ++++++++++++++++ gem/lib/pagy/offset/calendar/week.rb | 43 ++++++ gem/lib/pagy/offset/calendar/year.rb | 39 ++++++ gem/lib/pagy/offset/countless.rb | 54 ++++++++ gem/lib/pagy/shared_methods.rb | 69 ---------- gem/pagy.gemspec | 1 + src/pagy.ts | 2 +- test/helpers/nav_tests.rb | 31 +++-- test/mock_helpers/elasticsearch_rails.rb | 2 - test/mock_helpers/pagy_buggy.rb | 3 +- test/pagy/backend_test.rb | 8 +- test/pagy/calendar_dst_test.rb | 34 ++--- test/pagy/calendar_test.rb | 46 +++---- test/pagy/countless_test.rb | 17 ++- test/pagy/exceptions_test.rb | 16 +-- test/pagy/extras/arel_test.rb | 5 +- test/pagy/extras/array_test.rb | 5 +- test/pagy/extras/bootstrap_test.rb | 4 +- test/pagy/extras/bootstrap_test.rb.yaml | 7 + test/pagy/extras/bulma_test.rb | 2 +- test/pagy/extras/bulma_test.rb.yaml | 9 ++ test/pagy/extras/calendar_extra_test.rb | 13 +- test/pagy/extras/countless_extra_test.rb | 1 - test/pagy/extras/elasticsearch_rails_test.rb | 33 +++-- test/pagy/extras/gearbox_test.rb | 129 +++++++++--------- test/pagy/extras/headers_test.rb | 28 ++-- test/pagy/extras/i18n_calendar_extra_test.rb | 16 +-- test/pagy/extras/i18n_extra_test.rb | 8 +- test/pagy/extras/javascripts_test.rb | 15 +- test/pagy/extras/jsonapi_test.rb | 1 - ...set_for_ui_test.rb => keyset_augmented.rb} | 25 ++-- test/pagy/extras/keyset_test.rb | 1 - test/pagy/extras/limit_test.rb | 15 +- test/pagy/extras/meilisearch_test.rb | 14 +- test/pagy/extras/metadata_test.rb | 12 +- test/pagy/extras/metadata_test.rb.yaml | 102 +++----------- test/pagy/extras/overflow_test.rb | 56 ++++---- test/pagy/extras/pagy_test.rb | 6 +- test/pagy/extras/pagy_test.rb.yaml | 7 + test/pagy/extras/searchkick_test.rb | 16 +-- test/pagy/extras/size_test.rb | 20 +-- test/pagy/extras/standalone_limit_test.rb | 6 +- test/pagy/extras/standalone_test.rb | 30 ++-- test/pagy/frontend_test.rb | 20 +-- test/pagy/keyset_for_ui_test.rb | 62 ++++----- test/pagy/keyset_test.rb | 2 - test/{pagy_test.rb => pagy/offset_test.rb} | 106 +++++++------- test/pagy/url_helpers_test.rb | 22 +-- 113 files changed, 1774 insertions(+), 1789 deletions(-) rename .idea/runConfigurations/{Keyset_ForUI.xml => Keyset_Augmented.xml} (86%) rename gem/apps/{keyset_for_ui.ru => keyset_augmented.ru} (93%) create mode 100644 gem/lib/pagy/autoloading.rb delete mode 100644 gem/lib/pagy/calendar.rb delete mode 100644 gem/lib/pagy/calendar/day.rb delete mode 100644 gem/lib/pagy/calendar/month.rb delete mode 100644 gem/lib/pagy/calendar/quarter.rb delete mode 100644 gem/lib/pagy/calendar/unit.rb delete mode 100644 gem/lib/pagy/calendar/week.rb delete mode 100644 gem/lib/pagy/calendar/year.rb delete mode 100644 gem/lib/pagy/countless.rb delete mode 100644 gem/lib/pagy/extras/arel.rb delete mode 100644 gem/lib/pagy/extras/array.rb delete mode 100644 gem/lib/pagy/extras/countless.rb delete mode 100644 gem/lib/pagy/extras/keyset.rb delete mode 100644 gem/lib/pagy/extras/keyset_for_ui.rb delete mode 100644 gem/lib/pagy/extras/overflow.rb delete mode 100644 gem/lib/pagy/frontend/javascript.rb delete mode 100644 gem/lib/pagy/keyset/active_record_adapter.rb create mode 100644 gem/lib/pagy/keyset/adapters/active_record.rb create mode 100644 gem/lib/pagy/keyset/adapters/sequel.rb create mode 100644 gem/lib/pagy/keyset/augmented.rb delete mode 100644 gem/lib/pagy/keyset/sequel_adapter.rb delete mode 100644 gem/lib/pagy/keyset_for_ui.rb create mode 100644 gem/lib/pagy/mixin/arel.rb create mode 100644 gem/lib/pagy/mixin/array.rb rename gem/lib/pagy/{extras => mixin}/bootstrap.rb (95%) rename gem/lib/pagy/{extras => mixin}/bulma.rb (95%) rename gem/lib/pagy/{extras => mixin}/calendar.rb (84%) create mode 100644 gem/lib/pagy/mixin/countless.rb rename gem/lib/pagy/{extras => mixin}/elasticsearch_rails.rb (77%) rename gem/lib/pagy/{extras => mixin}/headers.rb (83%) create mode 100644 gem/lib/pagy/mixin/keyset.rb create mode 100644 gem/lib/pagy/mixin/keyset_augmented.rb rename gem/lib/pagy/{extras => mixin}/meilisearch.rb (85%) rename gem/lib/pagy/{extras => mixin}/metadata.rb (79%) create mode 100644 gem/lib/pagy/mixin/offset.rb rename gem/lib/pagy/{extras => mixin}/pagy.rb (94%) rename gem/lib/pagy/{extras => mixin}/searchkick.rb (84%) create mode 100644 gem/lib/pagy/offset.rb create mode 100644 gem/lib/pagy/offset/calendar.rb create mode 100644 gem/lib/pagy/offset/calendar/day.rb create mode 100644 gem/lib/pagy/offset/calendar/month.rb create mode 100644 gem/lib/pagy/offset/calendar/quarter.rb create mode 100644 gem/lib/pagy/offset/calendar/unit.rb create mode 100644 gem/lib/pagy/offset/calendar/week.rb create mode 100644 gem/lib/pagy/offset/calendar/year.rb create mode 100644 gem/lib/pagy/offset/countless.rb delete mode 100644 gem/lib/pagy/shared_methods.rb rename test/pagy/extras/{keyset_for_ui_test.rb => keyset_augmented.rb} (80%) rename test/{pagy_test.rb => pagy/offset_test.rb} (75%) diff --git a/.idea/runConfigurations/Keyset_ForUI.xml b/.idea/runConfigurations/Keyset_Augmented.xml similarity index 86% rename from .idea/runConfigurations/Keyset_ForUI.xml rename to .idea/runConfigurations/Keyset_Augmented.xml index 430327d84..b2ed7582c 100644 --- a/.idea/runConfigurations/Keyset_ForUI.xml +++ b/.idea/runConfigurations/Keyset_Augmented.xml @@ -1,5 +1,5 @@ - + @@ -25,7 +25,7 @@ - + \ No newline at end of file diff --git a/.rubocop.yml b/.rubocop.yml index 096492273..311a15c27 100644 --- a/.rubocop.yml +++ b/.rubocop.yml @@ -69,7 +69,7 @@ Style/LambdaCall: Enabled: false -# cannot inline the disabling in the file because rubocop complains anyway +# Cannot inline the disabling in the file because rubocop complains anyway Style/RedundantInitialize: Exclude: - test/mock_helpers/arel.rb @@ -78,7 +78,9 @@ Style/RedundantInitialize: Style/StringConcatenation: Enabled: false -# these cops are disabled only in the test files in order to +Style/Documentation: + Enabled: false +# These cops are disabled only in the test files in order to # allow to copy and paste the failed output for test reconciliation Style/StringLiterals: Enabled: true diff --git a/Gemfile.lock b/Gemfile.lock index 9e98c7651..eaacd6ab8 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -2,6 +2,7 @@ PATH remote: gem specs: pagy (9.3.3) + json GEM remote: https://rubygems.org/ @@ -154,7 +155,7 @@ GEM mustermann (3.0.3) ruby2_keywords (~> 0.0.1) mutex_m (0.3.0) - net-imap (0.5.4) + net-imap (0.5.5) date net-protocol net-pop (0.1.2) @@ -203,7 +204,8 @@ GEM base64 (>= 0.1.0) logger (>= 1.6.0) rack (>= 3.0.0, < 4) - rack-session (2.0.0) + rack-session (2.1.0) + base64 (>= 0.1.0) rack (>= 3.0.0) rack-test (2.2.0) rack (>= 1.3) @@ -271,7 +273,7 @@ GEM rubocop-ast (>= 1.31.1, < 2.0) rubocop-packaging (0.5.2) rubocop (>= 1.33, < 2.0) - rubocop-performance (1.23.0) + rubocop-performance (1.23.1) rubocop (>= 1.48.1, < 2.0) rubocop-ast (>= 1.31.1, < 2.0) rubocop-rake (0.6.0) @@ -315,7 +317,8 @@ GEM unicode-emoji (4.0.4) uri (1.0.2) useragent (0.16.11) - websocket-driver (0.7.6) + websocket-driver (0.7.7) + base64 websocket-extensions (>= 0.1.0) websocket-extensions (0.1.5) zeitwerk (2.7.1) diff --git a/docs/api/javascript/setup.md b/docs/api/javascript/setup.md index 1bfa56f93..d903f3b69 100644 --- a/docs/api/javascript/setup.md +++ b/docs/api/javascript/setup.md @@ -8,7 +8,7 @@ order: 4 !!!info Notice -A javascript setup is required only for the `pagy*_js` helpers and the `pagy*_nav` for `Pagy::KeysetForUI` instances. Just using +A javascript setup is required only for the `pagy*_js` helpers and the `pagy*_nav` for `Pagy::Keyset::Augmented` instances. Just using something like `anchor_string: 'data-remote="true"'` in any instances, works out of the box with any helper and without this setup. !!! @@ -21,7 +21,7 @@ setup. ### How does it work? -All the `pagy*_js` helpers, and the `pagy*_nav` for `Pagy::KeysetForUI` instances, complete their component on the +All the `pagy*_js` helpers, and the `pagy*_nav` for `Pagy::Keyset::Augmented` instances, complete their component on the client side. The helper methods serves just a minimal HTML tag that contains a `data-pagy` attribute. Your app should [serve or bundle](#2-configure) a small [javascript file](#1-pick-a-javascript-file) and [run the `Pagy.init() diff --git a/docs/api/keyset.md b/docs/api/keyset.md index 27e81e643..54a42fb25 100644 --- a/docs/api/keyset.md +++ b/docs/api/keyset.md @@ -227,7 +227,7 @@ which naturally ends with the end of the `set`, so it doesn't have any `cutoff` - A `cutoff` identifies a "cutoff value", for a `page` in the `set`. It is not a record nor a reference to it. - Its value is derived from the `keyset attributes values` array of the last record of the `page`, converted to JSON, and encoded as a Base64 URL-safe string, for easy use in URLs. - - `Pagy::Keyset` embeds it in the request URL; `Pagy::KeysetForUI` caches it on the client `sessionStorage`. + - `Pagy::Keyset` embeds it in the request URL; `Pagy::Keyset::Augmented` caches it on the client `sessionStorage`. - All the `page`s but the last, end with the `cutoff`. - All the `page`s but the first, begin AFTER the `cutoff` of the previous `page`. diff --git a/docs/api/keyset_for_ui.md b/docs/api/keyset_for_ui.md index af2377dc7..7b56e159a 100644 --- a/docs/api/keyset_for_ui.md +++ b/docs/api/keyset_for_ui.md @@ -1,11 +1,11 @@ --- -title: Pagy::KeysetForUI +title: Pagy::Keyset::Augmented category: - Feature - Class --- -# Pagy::KeysetForUI +# Pagy::Keyset::Augmented A [Pagy::Keyset](keyset.md) subclass supporting `pagy_*nav` and other Frontend helpers. @@ -17,7 +17,7 @@ A [Pagy::Keyset](keyset.md) subclass supporting `pagy_*nav` and other Frontend h The regular `Pagy::Keyset` uses the fastest technique for SQL pagination, but it cannot work with any Frontend helper because they require a pagy object with numeric variables. -That's why we created `Pagy::KeysetForUI`: it uses the fast keyset pagination AND supports `pagy_*navs` and other Frontend +That's why we created `Pagy::Keyset::Augmented`: it uses the fast keyset pagination AND supports `pagy_*navs` and other Frontend helpers. !!! @@ -45,7 +45,7 @@ The Keyset pagination for UI adds the numeric variables (`page`, `last`, `prev`, usage with most Frontend helpers. It does so by transparently exchanging data back and forth with the client, that stores the state of the pagination. -You can use a `Pagy::KeysetForUI` object as you would with a standard `Pagy` (offset countless) object. You need just a different +You can use a `Pagy::Keyset::Augmented` object as you would with a standard `Pagy` (offset countless) object. You need just a different setup and you will get a lot more performance. ==- In-depth: Understanding the data exchange @@ -182,24 +182,24 @@ user by: ## ORMs -`Pagy::KeysetForUI` implements the subclasses for `ActiveRecord::Relation` and `Sequel::Dataset` sets and instantiate them +`Pagy::Keyset::Augmented` implements the subclasses for `ActiveRecord::Relation` and `Sequel::Dataset` sets and instantiate them internally: ```ruby -Pagy::KeysetForUI.new(active_record_set) -#=> # +Pagy::Keyset::Augmented.new(active_record_set) +#=> # -Pagy::KeysetForUI.new(sequel_set) -#=> # +Pagy::Keyset::Augmented.new(sequel_set) +#=> # ``` ## Methods -==- `Pagy::KeysetForUI.new(set, **vars)` +==- `Pagy::Keyset::Augmented.new(set, **vars)` The constructor takes the `set`, and an optional hash of [variables](#variables). It returns a -`Pagy::KeysetForUI::ActiveRecord` or -`Pagy::KeysetForUI::Sequel` object (depending on the `set` class). +`Pagy::Keyset::Augmented::ActiveRecord` or +`Pagy::Keyset::Augmented::Sequel` object (depending on the `set` class). ==- `records` diff --git a/docs/extras/keyset_for_ui.md b/docs/extras/keyset_for_ui.md index c51321bc8..9555d25d4 100644 --- a/docs/extras/keyset_for_ui.md +++ b/docs/extras/keyset_for_ui.md @@ -17,7 +17,7 @@ and other Frontend helpers. ## Overview -This is a wrapper around the [Pagy::KeysetForUI API](/docs/api/keyset_for_ui.md). Please refer to the following resources: +This is a wrapper around the [Pagy::Keyset::Augmented API](/docs/api/keyset_for_ui.md). Please refer to the following resources: [!ref Keyset For UI: Documentation](/docs/api/keyset_for_ui.md) diff --git a/docs/extras/limit.md b/docs/extras/limit.md index fd445c38d..a2f907d74 100644 --- a/docs/extras/limit.md +++ b/docs/extras/limit.md @@ -102,9 +102,9 @@ The `limit` extra adds the `pagy_limit_selector_js` helper to the `Pagy::Fronten ==- `pagy_limit_selector_js(pagy, **vars)` -!!!warning Not for KeysetForUI instances! +!!!warning Not for Keyset::Augmented instances! -This helper doesn't make sense, and doesn't work with `Pagy::KeysetForUI` instances. +This helper doesn't make sense, and doesn't work with `Pagy::Keyset::Augmented` instances. !!! This helper provides a limit selector UI, which allows the user to select any arbitrary limit per page (below the `:limit_max` diff --git a/gem/apps/keyset.ru b/gem/apps/keyset.ru index 6fa2900df..985b535a0 100644 --- a/gem/apps/keyset.ru +++ b/gem/apps/keyset.ru @@ -40,7 +40,7 @@ Pagy::DEFAULT.freeze # Sinatra setup require 'sinatra/base' # Sinatra application -class PagyKeyset < Sinatra::Base +class PagyKeysetAugmented < Sinatra::Base include Pagy::Backend # Root route/action get '/' do diff --git a/gem/apps/keyset_for_ui.ru b/gem/apps/keyset_augmented.ru similarity index 93% rename from gem/apps/keyset_for_ui.ru rename to gem/apps/keyset_augmented.ru index ffb2a8060..2e219b8a0 100644 --- a/gem/apps/keyset_for_ui.ru +++ b/gem/apps/keyset_augmented.ru @@ -10,8 +10,8 @@ # bundle exec pagy -h # # DEV USAGE -# bundle exec pagy clone keyset_for_ui -# bundle exec pagy ./keyset_for_ui.ru +# bundle exec pagy clone keyet_augmented +# bundle exec pagy ./keyset_augmented.ru # # URL # http://0.0.0.0:8000 @@ -31,16 +31,14 @@ gemfile(ENV['PAGY_INSTALL_BUNDLE'] == 'true') do end # Pagy initializer -require 'pagy/extras/keyset_for_ui' require 'pagy/extras/limit' -require 'pagy/extras/pagy' Pagy::DEFAULT[:limit] = 4 Pagy::DEFAULT.freeze # Sinatra setup require 'sinatra/base' # Sinatra application -class PagyKeyset < Sinatra::Base +class PagyKeysetAugmented < Sinatra::Base include Pagy::Backend get('/javascripts/:file') do @@ -58,7 +56,7 @@ class PagyKeyset < Sinatra::Base Time.zone = 'UTC' @order = { animal: :asc, name: :asc, birthdate: :desc, id: :asc } - @pagy, @pets = pagy_keyset_for_ui(Pet.order(@order)) + @pagy, @pets = pagy_keyset_augmented_js(Pet.order(@order)) @ids = @pets.pluck(:id) erb :main end @@ -78,7 +76,7 @@ class PagyKeyset < Sinatra::Base - Pagy Keyset For UI App + Pagy Keyset Augmented App