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