From bbf547e9c7decb0cee7df9df21ccb15dc51b728b Mon Sep 17 00:00:00 2001
From: Domizio Demichelis
Date: Mon, 10 Mar 2025 18:24:00 +0700
Subject: [PATCH] Version 9.3.4
---
.github/ISSUE_TEMPLATE/Code.yml | 2 +-
.github/latest_release_body.md | 8 +-
CHANGELOG.md | 6 +-
Gemfile.lock | 280 ++++++++++++++++--------------
README.md | 2 +-
gem/apps/calendar.ru | 2 +-
gem/apps/demo.ru | 2 +-
gem/apps/keyset_ar.ru | 2 +-
gem/apps/keyset_s.ru | 2 +-
gem/apps/rails.ru | 2 +-
gem/apps/repro.ru | 2 +-
gem/bin/pagy | 2 +-
gem/config/pagy.rb | 2 +-
gem/javascripts/pagy.min.js | 4 +-
gem/javascripts/pagy.min.js.map | 4 +-
gem/javascripts/pagy.mjs | 2 +-
gem/lib/pagy.rb | 2 +-
gem/pagy.gemspec | 2 +-
retype.yml | 2 +-
scripts/bump.rb | 2 +-
src/pagy.ts | 2 +-
test/pagy/extras/metadata_test.rb | 2 +-
22 files changed, 179 insertions(+), 157 deletions(-)
diff --git a/.github/ISSUE_TEMPLATE/Code.yml b/.github/ISSUE_TEMPLATE/Code.yml
index 8d67c40f2..16c07dfbb 100644
--- a/.github/ISSUE_TEMPLATE/Code.yml
+++ b/.github/ISSUE_TEMPLATE/Code.yml
@@ -19,7 +19,7 @@ body:
attributes:
label: 👀 Before submitting...
options:
- - label: I upgraded to pagy version 9.3.3
+ - label: I upgraded to pagy version 9.3.4
required: true
- label: I searched through the [Documentation](https://ddnexus.github.io/pagy/)
required: true
diff --git a/.github/latest_release_body.md b/.github/latest_release_body.md
index 43da64614..47ea73ab8 100644
--- a/.github/latest_release_body.md
+++ b/.github/latest_release_body.md
@@ -6,14 +6,10 @@
- See the [Changelog](https://ddnexus.github.io/pagy/changelog) for possible breaking changes
-### Changes in 9.3.3
+### Changes in 9.3.4
-- Add test for locales - to find problematic keys (#752)
-- Update locales: zh-CN, zh-HK, zh-TW (#751) (fix #608, fix #609, fix #610)
- - Remove :other from :aria_label key and code comment
- - Change :item_name which had :one_other keys to default to the :other key
- - Fix comment
+- Fix method visibility in JsonApiExtra (#765)
[CHANGELOG](https://ddnexus.github.io/pagy/changelog)
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 4ee57c3f8..92abec76a 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -16,7 +16,7 @@ can expect the old functionality to be supported ONLY during the next releases b
## Recommended Version Constraint
-Given a version number `MAJOR.MINOR.PATCH` (e.g. `9.3.3`):
+Given a version number `MAJOR.MINOR.PATCH` (e.g. `9.3.4`):
The `gem 'pagy', '~> 9.3'` Gemfile entry (without the PATCH number) ensures that the `bundle update` command will update pagy to
the most recent version WITHOUT BREAKING CHANGES.
@@ -42,6 +42,10 @@ If you upgrade from version `< 9.0.0` see the following:
- `:after_latest` keyset variable: use `:filter_newest`
+## Version 9.3.4
+
+- Fix method visibility in JsonApiExtra (#765)
+
## Version 9.3.3
- Add test for locales - to find problematic keys (#752)
diff --git a/Gemfile.lock b/Gemfile.lock
index c0752c4d0..16cfb2594 100644
--- a/Gemfile.lock
+++ b/Gemfile.lock
@@ -1,34 +1,34 @@
PATH
remote: gem
specs:
- pagy (9.3.3)
+ pagy (9.3.4)
GEM
remote: https://rubygems.org/
specs:
- actioncable (8.0.0)
- actionpack (= 8.0.0)
- activesupport (= 8.0.0)
+ actioncable (8.0.1)
+ actionpack (= 8.0.1)
+ activesupport (= 8.0.1)
nio4r (~> 2.0)
websocket-driver (>= 0.6.1)
zeitwerk (~> 2.6)
- actionmailbox (8.0.0)
- actionpack (= 8.0.0)
- activejob (= 8.0.0)
- activerecord (= 8.0.0)
- activestorage (= 8.0.0)
- activesupport (= 8.0.0)
+ actionmailbox (8.0.1)
+ actionpack (= 8.0.1)
+ activejob (= 8.0.1)
+ activerecord (= 8.0.1)
+ activestorage (= 8.0.1)
+ activesupport (= 8.0.1)
mail (>= 2.8.0)
- actionmailer (8.0.0)
- actionpack (= 8.0.0)
- actionview (= 8.0.0)
- activejob (= 8.0.0)
- activesupport (= 8.0.0)
+ actionmailer (8.0.1)
+ actionpack (= 8.0.1)
+ actionview (= 8.0.1)
+ activejob (= 8.0.1)
+ activesupport (= 8.0.1)
mail (>= 2.8.0)
rails-dom-testing (~> 2.2)
- actionpack (8.0.0)
- actionview (= 8.0.0)
- activesupport (= 8.0.0)
+ actionpack (8.0.1)
+ actionview (= 8.0.1)
+ activesupport (= 8.0.1)
nokogiri (>= 1.8.5)
rack (>= 2.2.4)
rack-session (>= 1.0.1)
@@ -36,35 +36,35 @@ GEM
rails-dom-testing (~> 2.2)
rails-html-sanitizer (~> 1.6)
useragent (~> 0.16)
- actiontext (8.0.0)
- actionpack (= 8.0.0)
- activerecord (= 8.0.0)
- activestorage (= 8.0.0)
- activesupport (= 8.0.0)
+ actiontext (8.0.1)
+ actionpack (= 8.0.1)
+ activerecord (= 8.0.1)
+ activestorage (= 8.0.1)
+ activesupport (= 8.0.1)
globalid (>= 0.6.0)
nokogiri (>= 1.8.5)
- actionview (8.0.0)
- activesupport (= 8.0.0)
+ actionview (8.0.1)
+ activesupport (= 8.0.1)
builder (~> 3.1)
erubi (~> 1.11)
rails-dom-testing (~> 2.2)
rails-html-sanitizer (~> 1.6)
- activejob (8.0.0)
- activesupport (= 8.0.0)
+ activejob (8.0.1)
+ activesupport (= 8.0.1)
globalid (>= 0.3.6)
- activemodel (8.0.0)
- activesupport (= 8.0.0)
- activerecord (8.0.0)
- activemodel (= 8.0.0)
- activesupport (= 8.0.0)
+ activemodel (8.0.1)
+ activesupport (= 8.0.1)
+ activerecord (8.0.1)
+ activemodel (= 8.0.1)
+ activesupport (= 8.0.1)
timeout (>= 0.4.0)
- activestorage (8.0.0)
- actionpack (= 8.0.0)
- activejob (= 8.0.0)
- activerecord (= 8.0.0)
- activesupport (= 8.0.0)
+ activestorage (8.0.1)
+ actionpack (= 8.0.1)
+ activejob (= 8.0.1)
+ activerecord (= 8.0.1)
+ activesupport (= 8.0.1)
marcel (~> 1.0)
- activesupport (8.0.0)
+ activesupport (8.0.1)
base64
benchmark (>= 0.3)
bigdecimal
@@ -83,26 +83,26 @@ GEM
ast (2.4.2)
base64 (0.2.0)
benchmark (0.4.0)
- bigdecimal (3.1.8)
+ bigdecimal (3.1.9)
builder (3.3.0)
- concurrent-ruby (1.3.4)
- connection_pool (2.4.1)
+ concurrent-ruby (1.3.5)
+ connection_pool (2.5.0)
crass (1.0.6)
date (3.4.1)
docile (1.4.1)
domain_name (0.6.20240107)
drb (2.2.1)
- erubi (1.13.0)
- ffi (1.17.0-aarch64-linux-gnu)
- ffi (1.17.0-aarch64-linux-musl)
- ffi (1.17.0-arm-linux-gnu)
- ffi (1.17.0-arm-linux-musl)
- ffi (1.17.0-arm64-darwin)
- ffi (1.17.0-x86-linux-gnu)
- ffi (1.17.0-x86-linux-musl)
- ffi (1.17.0-x86_64-darwin)
- ffi (1.17.0-x86_64-linux-gnu)
- ffi (1.17.0-x86_64-linux-musl)
+ erubi (1.13.1)
+ ffi (1.17.1-aarch64-linux-gnu)
+ ffi (1.17.1-aarch64-linux-musl)
+ ffi (1.17.1-arm-linux-gnu)
+ ffi (1.17.1-arm-linux-musl)
+ ffi (1.17.1-arm64-darwin)
+ ffi (1.17.1-x86-linux-gnu)
+ ffi (1.17.1-x86-linux-musl)
+ ffi (1.17.1-x86_64-darwin)
+ ffi (1.17.1-x86_64-linux-gnu)
+ ffi (1.17.1-x86_64-linux-musl)
ffi-compiler (1.3.2)
ffi (>= 1.15.5)
rake
@@ -116,25 +116,27 @@ GEM
http-cookie (~> 1.0)
http-form_data (~> 2.2)
llhttp-ffi (~> 0.5.0)
- http-cookie (1.0.7)
+ http-cookie (1.0.8)
domain_name (~> 0.5)
http-form_data (2.3.0)
- i18n (1.14.6)
+ i18n (1.14.7)
concurrent-ruby (~> 1.0)
io-console (0.8.0)
- irb (1.14.1)
+ irb (1.15.1)
+ pp (>= 0.6.0)
rdoc (>= 4.0.0)
reline (>= 0.4.2)
- json (2.9.0)
- language_server-protocol (3.17.0.3)
+ json (2.10.1)
+ language_server-protocol (3.17.0.4)
+ lint_roller (1.1.0)
listen (3.9.0)
rb-fsevent (~> 0.10, >= 0.10.3)
rb-inotify (~> 0.9, >= 0.9.10)
llhttp-ffi (0.5.0)
ffi-compiler (~> 1.0)
rake (~> 13.0)
- logger (1.6.2)
- loofah (2.23.1)
+ logger (1.6.6)
+ loofah (2.24.0)
crass (~> 1.0.2)
nokogiri (>= 1.12.0)
mail (2.8.1)
@@ -144,7 +146,8 @@ GEM
net-smtp
marcel (1.0.4)
mini_mime (1.1.5)
- minitest (5.25.2)
+ mini_portile2 (2.8.8)
+ minitest (5.25.4)
minitest-reporters (1.7.1)
ansi
builder
@@ -153,78 +156,90 @@ GEM
mustermann (3.0.3)
ruby2_keywords (~> 0.0.1)
mutex_m (0.3.0)
- net-imap (0.5.1)
+ net-imap (0.5.6)
date
net-protocol
net-pop (0.1.2)
net-protocol
net-protocol (0.2.2)
timeout
- net-smtp (0.5.0)
+ net-smtp (0.5.1)
net-protocol
nio4r (2.7.4)
- nokogiri (1.16.8-aarch64-linux)
+ nokogiri (1.18.3)
+ mini_portile2 (~> 2.8.2)
racc (~> 1.4)
- nokogiri (1.16.8-arm-linux)
+ nokogiri (1.18.3-aarch64-linux-gnu)
racc (~> 1.4)
- nokogiri (1.16.8-arm64-darwin)
+ nokogiri (1.18.3-aarch64-linux-musl)
racc (~> 1.4)
- nokogiri (1.16.8-x86-linux)
+ nokogiri (1.18.3-arm-linux-gnu)
racc (~> 1.4)
- nokogiri (1.16.8-x86_64-darwin)
+ nokogiri (1.18.3-arm-linux-musl)
racc (~> 1.4)
- nokogiri (1.16.8-x86_64-linux)
+ nokogiri (1.18.3-arm64-darwin)
racc (~> 1.4)
- oj (3.16.7)
+ nokogiri (1.18.3-x86_64-darwin)
+ racc (~> 1.4)
+ nokogiri (1.18.3-x86_64-linux-gnu)
+ racc (~> 1.4)
+ nokogiri (1.18.3-x86_64-linux-musl)
+ racc (~> 1.4)
+ oj (3.16.10)
bigdecimal (>= 3.0)
ostruct (>= 0.2)
ostruct (0.6.1)
parallel (1.26.3)
- parser (3.3.6.0)
+ parser (3.3.7.1)
ast (~> 2.4.1)
racc
- psych (5.2.1)
+ pp (0.6.2)
+ prettyprint
+ prettyprint (0.2.0)
+ pstore (0.1.4)
+ psych (5.2.3)
date
stringio
public_suffix (6.0.1)
- puma (6.5.0)
+ puma (6.6.0)
nio4r (~> 2.0)
racc (1.8.1)
- rack (3.1.8)
+ rack (3.1.11)
rack-protection (4.1.1)
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.1.0)
+ rack-test (2.2.0)
rack (>= 1.3)
rackup (2.2.1)
rack (>= 3)
- rails (8.0.0)
- actioncable (= 8.0.0)
- actionmailbox (= 8.0.0)
- actionmailer (= 8.0.0)
- actionpack (= 8.0.0)
- actiontext (= 8.0.0)
- actionview (= 8.0.0)
- activejob (= 8.0.0)
- activemodel (= 8.0.0)
- activerecord (= 8.0.0)
- activestorage (= 8.0.0)
- activesupport (= 8.0.0)
+ rails (8.0.1)
+ actioncable (= 8.0.1)
+ actionmailbox (= 8.0.1)
+ actionmailer (= 8.0.1)
+ actionpack (= 8.0.1)
+ actiontext (= 8.0.1)
+ actionview (= 8.0.1)
+ activejob (= 8.0.1)
+ activemodel (= 8.0.1)
+ activerecord (= 8.0.1)
+ activestorage (= 8.0.1)
+ activesupport (= 8.0.1)
bundler (>= 1.15.0)
- railties (= 8.0.0)
+ railties (= 8.0.1)
rails-dom-testing (2.2.0)
activesupport (>= 5.0.0)
minitest
nokogiri (>= 1.6)
- rails-html-sanitizer (1.6.1)
+ rails-html-sanitizer (1.6.2)
loofah (~> 2.21)
nokogiri (>= 1.15.7, != 1.16.7, != 1.16.6, != 1.16.5, != 1.16.4, != 1.16.3, != 1.16.2, != 1.16.1, != 1.16.0.rc1, != 1.16.0)
- railties (8.0.0)
- actionpack (= 8.0.0)
- activesupport (= 8.0.0)
+ railties (8.0.1)
+ actionpack (= 8.0.1)
+ activesupport (= 8.0.1)
irb (~> 1.13)
rackup (>= 1.0.0)
rake (>= 12.2)
@@ -235,41 +250,47 @@ GEM
rb-fsevent (0.11.2)
rb-inotify (0.11.1)
ffi (~> 1.0)
- rdoc (6.8.1)
+ rdoc (6.12.0)
psych (>= 4.0.0)
- regexp_parser (2.9.3)
- reline (0.5.12)
+ regexp_parser (2.10.0)
+ reline (0.6.0)
io-console (~> 0.5)
- rematch (3.1.0)
+ rematch (3.2.0)
+ logger
+ pstore
rerun (0.14.0)
listen (~> 3.0)
rouge (4.5.1)
- rubocop (1.69.1)
+ rubocop (1.73.2)
json (~> 2.3)
- language_server-protocol (>= 3.17.0)
+ language_server-protocol (~> 3.17.0.2)
+ lint_roller (~> 1.1.0)
parallel (~> 1.10)
parser (>= 3.3.0.2)
rainbow (>= 2.2.2, < 4.0)
regexp_parser (>= 2.9.3, < 3.0)
- rubocop-ast (>= 1.36.2, < 2.0)
+ rubocop-ast (>= 1.38.0, < 2.0)
ruby-progressbar (~> 1.7)
unicode-display_width (>= 2.4.0, < 4.0)
- rubocop-ast (1.36.2)
+ rubocop-ast (1.38.1)
parser (>= 3.3.1.0)
- rubocop-minitest (0.36.0)
- rubocop (>= 1.61, < 2.0)
- rubocop-ast (>= 1.31.1, < 2.0)
+ rubocop-minitest (0.37.1)
+ lint_roller (~> 1.1)
+ rubocop (>= 1.72.1, < 2.0)
+ rubocop-ast (>= 1.38.0, < 2.0)
rubocop-packaging (0.5.2)
rubocop (>= 1.33, < 2.0)
- rubocop-performance (1.23.0)
- rubocop (>= 1.48.1, < 2.0)
- rubocop-ast (>= 1.31.1, < 2.0)
- rubocop-rake (0.6.0)
- rubocop (~> 1.0)
+ rubocop-performance (1.24.0)
+ lint_roller (~> 1.1)
+ rubocop (>= 1.72.1, < 2.0)
+ rubocop-ast (>= 1.38.0, < 2.0)
+ rubocop-rake (0.7.1)
+ lint_roller (~> 1.1)
+ rubocop (>= 1.72.1)
ruby-progressbar (1.13.0)
ruby2_keywords (0.0.5)
- securerandom (0.4.0)
- sequel (5.87.0)
+ securerandom (0.4.1)
+ sequel (5.90.0)
bigdecimal
simplecov (0.22.0)
docile (~> 1.1)
@@ -284,31 +305,32 @@ GEM
rack-protection (= 4.1.1)
rack-session (>= 2.0.0, < 3)
tilt (~> 2.0)
- sqlite3 (2.3.1-aarch64-linux-gnu)
- sqlite3 (2.3.1-aarch64-linux-musl)
- sqlite3 (2.3.1-arm-linux-gnu)
- sqlite3 (2.3.1-arm-linux-musl)
- sqlite3 (2.3.1-arm64-darwin)
- sqlite3 (2.3.1-x86-linux-gnu)
- sqlite3 (2.3.1-x86-linux-musl)
- sqlite3 (2.3.1-x86_64-darwin)
- sqlite3 (2.3.1-x86_64-linux-gnu)
- sqlite3 (2.3.1-x86_64-linux-musl)
- stringio (3.1.2)
+ sqlite3 (2.6.0-aarch64-linux-gnu)
+ sqlite3 (2.6.0-aarch64-linux-musl)
+ sqlite3 (2.6.0-arm-linux-gnu)
+ sqlite3 (2.6.0-arm-linux-musl)
+ sqlite3 (2.6.0-arm64-darwin)
+ sqlite3 (2.6.0-x86-linux-gnu)
+ sqlite3 (2.6.0-x86-linux-musl)
+ sqlite3 (2.6.0-x86_64-darwin)
+ sqlite3 (2.6.0-x86_64-linux-gnu)
+ sqlite3 (2.6.0-x86_64-linux-musl)
+ stringio (3.1.5)
thor (1.3.2)
- tilt (2.4.0)
- timeout (0.4.2)
+ tilt (2.6.0)
+ timeout (0.4.3)
tzinfo (2.0.6)
concurrent-ruby (~> 1.0)
- unicode-display_width (3.1.2)
+ unicode-display_width (3.1.4)
unicode-emoji (~> 4.0, >= 4.0.4)
unicode-emoji (4.0.4)
- uri (1.0.2)
- useragent (0.16.10)
- websocket-driver (0.7.6)
+ uri (1.0.3)
+ useragent (0.16.11)
+ websocket-driver (0.7.7)
+ base64
websocket-extensions (>= 0.1.0)
websocket-extensions (0.1.5)
- zeitwerk (2.7.1)
+ zeitwerk (2.7.2)
PLATFORMS
aarch64-linux
@@ -354,4 +376,4 @@ DEPENDENCIES
sqlite3
BUNDLED WITH
- 2.5.3
+ 2.6.2
diff --git a/README.md b/README.md
index cc4cf5828..9659d005a 100644
--- a/README.md
+++ b/README.md
@@ -279,7 +279,7 @@ See also the [How To Page](https://ddnexus.github.io/pagy/docs/how-to)
-[
](https://github.com/ddnexus/pagy/commits?author=ddnexus)[
](https://github.com/ddnexus/pagy/commits?author=benkoshy)[
](https://github.com/ddnexus/pagy/commits?author=grosser)[
](https://github.com/ddnexus/pagy/commits?author=Earlopain)[
](https://github.com/ddnexus/pagy/commits?author=workgena)[
](https://github.com/ddnexus/pagy/commits?author=espen)[
](https://github.com/ddnexus/pagy/commits?author=enzinia)[
](https://github.com/ddnexus/pagy/commits?author=sunny)[
](https://github.com/ddnexus/pagy/commits?author=molfar)[
](https://github.com/ddnexus/pagy/commits?author=bquorning)[
](https://github.com/ddnexus/pagy/commits?author=djpremier)[
](https://github.com/ddnexus/pagy/commits?author=simonneutert)[
](https://github.com/ddnexus/pagy/commits?author=tersor)[
](https://github.com/ddnexus/pagy/commits?author=thomasklemm)[
](https://github.com/ddnexus/pagy/commits?author=gamafranco)[
](https://github.com/ddnexus/pagy/commits?author=tiagotex)[
](https://github.com/ddnexus/pagy/commits?author=wimdavies)[
](https://github.com/ddnexus/pagy/commits?author=renshuki)[
](https://github.com/ddnexus/pagy/commits?author=berniechiu)[
](https://github.com/ddnexus/pagy/commits?author=rbngzlv)[
](https://github.com/ddnexus/pagy/commits?author=rainerborene)[
](https://github.com/ddnexus/pagy/commits?author=petergoldstein)[
](https://github.com/ddnexus/pagy/commits?author=sabljak)[
](https://github.com/ddnexus/pagy/commits?author=cseelus)[
](https://github.com/ddnexus/pagy/commits?author=ashmaroli)[
](https://github.com/ddnexus/pagy/commits?author=747)[
](https://github.com/ddnexus/pagy/commits?author=woller)[
](https://github.com/ddnexus/pagy/commits?author=WilliamHorel)[
](https://github.com/ddnexus/pagy/commits?author=okuramasafumi)[
](https://github.com/ddnexus/pagy/commits?author=olieidel)[
](https://github.com/ddnexus/pagy/commits?author=olleolleolle)[
](https://github.com/ddnexus/pagy/commits?author=PedroAugustoRamalhoDuarte)[
](https://github.com/ddnexus/pagy/commits?author=pedrocarmona)[
](https://github.com/ddnexus/pagy/commits?author=rafaeelaudibert)[
](https://github.com/ddnexus/pagy/commits?author=rafaelmontas)[
](https://github.com/ddnexus/pagy/commits?author=yenshirak)[
](https://github.com/ddnexus/pagy/commits?author=rogermarlow)[
](https://github.com/ddnexus/pagy/commits?author=Tolchi)[
](https://github.com/ddnexus/pagy/commits?author=artplan1)[
](https://github.com/ddnexus/pagy/commits?author=sk8higher)[
](https://github.com/ddnexus/pagy/commits?author=muhammadnawzad)[
](https://github.com/ddnexus/pagy/commits?author=ronald)[
](https://github.com/ddnexus/pagy/commits?author=achmiral)[
](https://github.com/ddnexus/pagy/commits?author=mauro-ni)[
](https://github.com/ddnexus/pagy/commits?author=borama)[
](https://github.com/ddnexus/pagy/commits?author=creativetags)[
](https://github.com/ddnexus/pagy/commits?author=mcary)[
](https://github.com/ddnexus/pagy/commits?author=marckohlbrugge)[
](https://github.com/ddnexus/pagy/commits?author=fluser)[
](https://github.com/ddnexus/pagy/commits?author=maful)[
](https://github.com/ddnexus/pagy/commits?author=LuukvH)[
](https://github.com/ddnexus/pagy/commits?author=AngelGuerra)[
](https://github.com/ddnexus/pagy/commits?author=tr4b4nt)[
](https://github.com/ddnexus/pagy/commits?author=tiejianluo)[
](https://github.com/ddnexus/pagy/commits?author=szTheory)[
](https://github.com/ddnexus/pagy/commits?author=smoothdvd)[
](https://github.com/ddnexus/pagy/commits?author=rhodes-david)[
](https://github.com/ddnexus/pagy/commits?author=radinreth)[
](https://github.com/ddnexus/pagy/commits?author=pranavbabu)[
](https://github.com/ddnexus/pagy/commits?author=okliv)[
](https://github.com/ddnexus/pagy/commits?author=nedimdz)[
](https://github.com/ddnexus/pagy/commits?author=msdundar)[
](https://github.com/ddnexus/pagy/commits?author=m-abdurrehman)[
](https://github.com/ddnexus/pagy/commits?author=dwieringa)[
](https://github.com/ddnexus/pagy/commits?author=jyuvaraj03)[
](https://github.com/ddnexus/pagy/commits?author=YutoYasunaga)[
](https://github.com/ddnexus/pagy/commits?author=iamyujinwon)[
](https://github.com/ddnexus/pagy/commits?author=yhk1038)[
](https://github.com/ddnexus/pagy/commits?author=ya-s-u)[
](https://github.com/ddnexus/pagy/commits?author=yshmarov)[
](https://github.com/ddnexus/pagy/commits?author=thattimc)[
](https://github.com/ddnexus/pagy/commits?author=thomaschauffour)[
](https://github.com/ddnexus/pagy/commits?author=snkashis)[
](https://github.com/ddnexus/pagy/commits?author=sliminas)[
](https://github.com/ddnexus/pagy/commits?author=serghost)[
](https://github.com/ddnexus/pagy/commits?author=tulak)[
](https://github.com/ddnexus/pagy/commits?author=Federico-G)[
](https://github.com/ddnexus/pagy/commits?author=egimenos)[
](https://github.com/ddnexus/pagy/commits?author=elliotlarson)[
](https://github.com/ddnexus/pagy/commits?author=hungdiep97)[
](https://github.com/ddnexus/pagy/commits?author=davidwessman)[
](https://github.com/ddnexus/pagy/commits?author=david-a-wheeler)[
](https://github.com/ddnexus/pagy/commits?author=daniel-rikowski)[
](https://github.com/ddnexus/pagy/commits?author=connie-feng)[
](https://github.com/ddnexus/pagy/commits?author=MrMoins)[
](https://github.com/ddnexus/pagy/commits?author=excid3)[
](https://github.com/ddnexus/pagy/commits?author=cellvinchung)[
](https://github.com/ddnexus/pagy/commits?author=brunoocasali)[
](https://github.com/ddnexus/pagy/commits?author=branson-simplethread)[
](https://github.com/ddnexus/pagy/commits?author=BrandonKlotz)[
](https://github.com/ddnexus/pagy/commits?author=benjaminwols)[
](https://github.com/ddnexus/pagy/commits?author=Atul9)[
](https://github.com/ddnexus/pagy/commits?author=amenon)[
](https://github.com/ddnexus/pagy/commits?author=artinboghosian)[
](https://github.com/ddnexus/pagy/commits?author=antonzaharia)[
](https://github.com/ddnexus/pagy/commits?author=PyrinAndrii)[
](https://github.com/ddnexus/pagy/commits?author=andrew)[
](https://github.com/ddnexus/pagy/commits?author=AliOsm)[
](https://github.com/ddnexus/pagy/commits?author=AbelToy)[
](https://github.com/ddnexus/pagy/commits?author=loed-idzinga)
+[
](https://github.com/ddnexus/pagy/commits?author=ddnexus)[
](https://github.com/ddnexus/pagy/commits?author=benkoshy)[
](https://github.com/ddnexus/pagy/commits?author=grosser)[
](https://github.com/ddnexus/pagy/commits?author=Earlopain)[
](https://github.com/ddnexus/pagy/commits?author=workgena)[
](https://github.com/ddnexus/pagy/commits?author=espen)[
](https://github.com/ddnexus/pagy/commits?author=enzinia)[
](https://github.com/ddnexus/pagy/commits?author=sunny)[
](https://github.com/ddnexus/pagy/commits?author=molfar)[
](https://github.com/ddnexus/pagy/commits?author=bquorning)[
](https://github.com/ddnexus/pagy/commits?author=djpremier)[
](https://github.com/ddnexus/pagy/commits?author=simonneutert)[
](https://github.com/ddnexus/pagy/commits?author=tersor)[
](https://github.com/ddnexus/pagy/commits?author=thomasklemm)[
](https://github.com/ddnexus/pagy/commits?author=gamafranco)[
](https://github.com/ddnexus/pagy/commits?author=tiagotex)[
](https://github.com/ddnexus/pagy/commits?author=wimdavies)[
](https://github.com/ddnexus/pagy/commits?author=renshuki)[
](https://github.com/ddnexus/pagy/commits?author=berniechiu)[
](https://github.com/ddnexus/pagy/commits?author=747)[
](https://github.com/ddnexus/pagy/commits?author=ashmaroli)[
](https://github.com/ddnexus/pagy/commits?author=cseelus)[
](https://github.com/ddnexus/pagy/commits?author=sabljak)[
](https://github.com/ddnexus/pagy/commits?author=petergoldstein)[
](https://github.com/ddnexus/pagy/commits?author=rainerborene)[
](https://github.com/ddnexus/pagy/commits?author=yenshirak)[
](https://github.com/ddnexus/pagy/commits?author=rbngzlv)[
](https://github.com/ddnexus/pagy/commits?author=WilliamHorel)[
](https://github.com/ddnexus/pagy/commits?author=okuramasafumi)[
](https://github.com/ddnexus/pagy/commits?author=olieidel)[
](https://github.com/ddnexus/pagy/commits?author=olleolleolle)[
](https://github.com/ddnexus/pagy/commits?author=PedroAugustoRamalhoDuarte)[
](https://github.com/ddnexus/pagy/commits?author=pedrocarmona)[
](https://github.com/ddnexus/pagy/commits?author=peter50216)[
](https://github.com/ddnexus/pagy/commits?author=rafaeelaudibert)[
](https://github.com/ddnexus/pagy/commits?author=rafaelmontas)[
](https://github.com/ddnexus/pagy/commits?author=rogermarlow)[
](https://github.com/ddnexus/pagy/commits?author=Tolchi)[
](https://github.com/ddnexus/pagy/commits?author=serghost)[
](https://github.com/ddnexus/pagy/commits?author=artplan1)[
](https://github.com/ddnexus/pagy/commits?author=woller)[
](https://github.com/ddnexus/pagy/commits?author=sk8higher)[
](https://github.com/ddnexus/pagy/commits?author=muhammadnawzad)[
](https://github.com/ddnexus/pagy/commits?author=ronald)[
](https://github.com/ddnexus/pagy/commits?author=achmiral)[
](https://github.com/ddnexus/pagy/commits?author=mauro-ni)[
](https://github.com/ddnexus/pagy/commits?author=borama)[
](https://github.com/ddnexus/pagy/commits?author=creativetags)[
](https://github.com/ddnexus/pagy/commits?author=mcary)[
](https://github.com/ddnexus/pagy/commits?author=marckohlbrugge)[
](https://github.com/ddnexus/pagy/commits?author=fluser)[
](https://github.com/ddnexus/pagy/commits?author=maful)[
](https://github.com/ddnexus/pagy/commits?author=AngelGuerra)[
](https://github.com/ddnexus/pagy/commits?author=tr4b4nt)[
](https://github.com/ddnexus/pagy/commits?author=tiejianluo)[
](https://github.com/ddnexus/pagy/commits?author=szTheory)[
](https://github.com/ddnexus/pagy/commits?author=smoothdvd)[
](https://github.com/ddnexus/pagy/commits?author=rhodes-david)[
](https://github.com/ddnexus/pagy/commits?author=radinreth)[
](https://github.com/ddnexus/pagy/commits?author=pranavbabu)[
](https://github.com/ddnexus/pagy/commits?author=okliv)[
](https://github.com/ddnexus/pagy/commits?author=nedimdz)[
](https://github.com/ddnexus/pagy/commits?author=msdundar)[
](https://github.com/ddnexus/pagy/commits?author=m-abdurrehman)[
](https://github.com/ddnexus/pagy/commits?author=dwieringa)[
](https://github.com/ddnexus/pagy/commits?author=jyuvaraj03)[
](https://github.com/ddnexus/pagy/commits?author=YutoYasunaga)[
](https://github.com/ddnexus/pagy/commits?author=iamyujinwon)[
](https://github.com/ddnexus/pagy/commits?author=yhk1038)[
](https://github.com/ddnexus/pagy/commits?author=ya-s-u)[
](https://github.com/ddnexus/pagy/commits?author=yshmarov)[
](https://github.com/ddnexus/pagy/commits?author=Davidzhu001)[
](https://github.com/ddnexus/pagy/commits?author=thattimc)[
](https://github.com/ddnexus/pagy/commits?author=thomaschauffour)[
](https://github.com/ddnexus/pagy/commits?author=snkashis)[
](https://github.com/ddnexus/pagy/commits?author=sliminas)[
](https://github.com/ddnexus/pagy/commits?author=LuukvH)[
](https://github.com/ddnexus/pagy/commits?author=tulak)[
](https://github.com/ddnexus/pagy/commits?author=Federico-G)[
](https://github.com/ddnexus/pagy/commits?author=egimenos)[
](https://github.com/ddnexus/pagy/commits?author=elliotlarson)[
](https://github.com/ddnexus/pagy/commits?author=hungdiep97)[
](https://github.com/ddnexus/pagy/commits?author=davidwessman)[
](https://github.com/ddnexus/pagy/commits?author=david-a-wheeler)[
](https://github.com/ddnexus/pagy/commits?author=daniel-rikowski)[
](https://github.com/ddnexus/pagy/commits?author=connie-feng)[
](https://github.com/ddnexus/pagy/commits?author=MrMoins)[
](https://github.com/ddnexus/pagy/commits?author=excid3)[
](https://github.com/ddnexus/pagy/commits?author=cellvinchung)[
](https://github.com/ddnexus/pagy/commits?author=brunoocasali)[
](https://github.com/ddnexus/pagy/commits?author=branson-simplethread)[
](https://github.com/ddnexus/pagy/commits?author=BrandonKlotz)[
](https://github.com/ddnexus/pagy/commits?author=benjaminwols)[
](https://github.com/ddnexus/pagy/commits?author=Atul9)[
](https://github.com/ddnexus/pagy/commits?author=amenon)[
](https://github.com/ddnexus/pagy/commits?author=artinboghosian)[
](https://github.com/ddnexus/pagy/commits?author=antonzaharia)[
](https://github.com/ddnexus/pagy/commits?author=PyrinAndrii)[
](https://github.com/ddnexus/pagy/commits?author=andrew)[
](https://github.com/ddnexus/pagy/commits?author=AliOsm)
diff --git a/gem/apps/calendar.ru b/gem/apps/calendar.ru
index 7c6eb1ea5..140566dc2 100644
--- a/gem/apps/calendar.ru
+++ b/gem/apps/calendar.ru
@@ -16,7 +16,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Bundle
require 'bundler/inline'
diff --git a/gem/apps/demo.ru b/gem/apps/demo.ru
index a7aca93d6..8baad5b2c 100644
--- a/gem/apps/demo.ru
+++ b/gem/apps/demo.ru
@@ -19,7 +19,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Bundle
require 'bundler/inline'
diff --git a/gem/apps/keyset_ar.ru b/gem/apps/keyset_ar.ru
index d07740f1b..91803fc5c 100644
--- a/gem/apps/keyset_ar.ru
+++ b/gem/apps/keyset_ar.ru
@@ -16,7 +16,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Bundle
require 'bundler/inline'
diff --git a/gem/apps/keyset_s.ru b/gem/apps/keyset_s.ru
index 4efcc3777..34a5cdb22 100644
--- a/gem/apps/keyset_s.ru
+++ b/gem/apps/keyset_s.ru
@@ -16,7 +16,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Bundle
require 'bundler/inline'
diff --git a/gem/apps/rails.ru b/gem/apps/rails.ru
index c7d715e7f..ab23870d1 100644
--- a/gem/apps/rails.ru
+++ b/gem/apps/rails.ru
@@ -16,7 +16,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Gemfile
require 'bundler/inline'
diff --git a/gem/apps/repro.ru b/gem/apps/repro.ru
index 32a16d7fa..05660e7ec 100644
--- a/gem/apps/repro.ru
+++ b/gem/apps/repro.ru
@@ -16,7 +16,7 @@
# URL
# http://0.0.0.0:8000
-VERSION = '9.3.3'
+VERSION = '9.3.4'
# Bundle
require 'bundler/inline'
diff --git a/gem/bin/pagy b/gem/bin/pagy
index ca05d010b..fdbf28a18 100755
--- a/gem/bin/pagy
+++ b/gem/bin/pagy
@@ -1,7 +1,7 @@
#!/usr/bin/env ruby
# frozen_string_literal: true
-VERSION = '9.3.3'
+VERSION = '9.3.4'
LINUX = RbConfig::CONFIG['host_os'].include?('linux')
HOST = '0.0.0.0'
PORT = '8000'
diff --git a/gem/config/pagy.rb b/gem/config/pagy.rb
index 976ce8daf..b39712a5a 100644
--- a/gem/config/pagy.rb
+++ b/gem/config/pagy.rb
@@ -1,6 +1,6 @@
# frozen_string_literal: true
-# Pagy initializer file (9.3.3)
+# Pagy initializer file (9.3.4)
# Customize only what you really need and notice that the core Pagy works also without any of the following lines.
# Should you just cherry pick part of this file, please maintain the require-order of the extras
diff --git a/gem/javascripts/pagy.min.js b/gem/javascripts/pagy.min.js
index 69dbafab0..deb0c0224 100644
--- a/gem/javascripts/pagy.min.js
+++ b/gem/javascripts/pagy.min.js
@@ -1,4 +1,4 @@
-window.Pagy=(()=>{const j=new ResizeObserver((B)=>B.forEach((D)=>D.target.querySelectorAll(".pagy-rjs").forEach((E)=>E.pagyRender()))),x=(B,[D,E,z,G])=>{const F=B.parentElement??B,K=Object.keys(E).map((H)=>parseInt(H)).sort((H,M)=>M-H);let L=-1;const T=(H,M,R)=>H.replace(/__pagy_page__/g,M).replace(/__pagy_label__/g,R);if((B.pagyRender=function(){const H=K.find((Q)=>QQ.toString());R.forEach((Q,J)=>{const $=X[J];let U;if(typeof Q==="number")U=T(D.a,Q.toString(),$);else if(Q==="gap")U=D.gap;else U=T(D.current,Q,$);M+=typeof G==="string"&&Q==1?Z(U,G):U}),M+=D.after,B.innerHTML="",B.insertAdjacentHTML("afterbegin",M),L=H})(),B.classList.contains("pagy-rjs"))j.observe(F)},A=(B,[D,E])=>Y(B,(z)=>[z,D.replace(/__pagy_page__/,z)],E),C=(B,[D,E,z])=>{Y(B,(G)=>{const F=Math.max(Math.ceil(D/parseInt(G)),1).toString(),K=E.replace(/__pagy_page__/,F).replace(/__pagy_limit__/,G);return[F,K]},z)},Y=(B,D,E)=>{const z=B.querySelector("input"),G=B.querySelector("a"),F=z.value,K=function(){if(z.value===F)return;const[L,T,H]=[z.min,z.value,z.max].map((X)=>parseInt(X)||0);if(TH){z.value=F,z.select();return}let[M,R]=D(z.value);if(typeof E==="string"&&M==="1")R=Z(R,E);G.href=R,G.click()};["change","focus"].forEach((L)=>z.addEventListener(L,()=>z.select())),z.addEventListener("focusout",K),z.addEventListener("keypress",(L)=>{if(L.key==="Enter")K()})},Z=(B,D)=>B.replace(new RegExp(`[?&]${D}=1\\b(?!&)|\\b${D}=1&`),"");return{version:"9.3.3",init(B){const E=(B instanceof Element?B:document).querySelectorAll("[data-pagy]");for(let z of E)try{const G=Uint8Array.from(atob(z.getAttribute("data-pagy")),(L)=>L.charCodeAt(0)),[F,...K]=JSON.parse(new TextDecoder().decode(G));if(F==="nav")x(z,K);else if(F==="combo")A(z,K);else if(F==="selector")C(z,K);else console.warn("Skipped Pagy.init() for: %o\nUnknown keyword '%s'",z,F)}catch(G){console.warn("Skipped Pagy.init() for: %o\n%s",z,G)}}}})();
+window.Pagy=(()=>{const j=new ResizeObserver((B)=>B.forEach((D)=>D.target.querySelectorAll(".pagy-rjs").forEach((E)=>E.pagyRender()))),x=(B,[D,E,z,G])=>{const F=B.parentElement??B,K=Object.keys(E).map((H)=>parseInt(H)).sort((H,M)=>M-H);let L=-1;const T=(H,M,R)=>H.replace(/__pagy_page__/g,M).replace(/__pagy_label__/g,R);if((B.pagyRender=function(){const H=K.find((Q)=>QQ.toString());R.forEach((Q,J)=>{const $=X[J];let U;if(typeof Q==="number")U=T(D.a,Q.toString(),$);else if(Q==="gap")U=D.gap;else U=T(D.current,Q,$);M+=typeof G==="string"&&Q==1?Z(U,G):U}),M+=D.after,B.innerHTML="",B.insertAdjacentHTML("afterbegin",M),L=H})(),B.classList.contains("pagy-rjs"))j.observe(F)},A=(B,[D,E])=>Y(B,(z)=>[z,D.replace(/__pagy_page__/,z)],E),C=(B,[D,E,z])=>{Y(B,(G)=>{const F=Math.max(Math.ceil(D/parseInt(G)),1).toString(),K=E.replace(/__pagy_page__/,F).replace(/__pagy_limit__/,G);return[F,K]},z)},Y=(B,D,E)=>{const z=B.querySelector("input"),G=B.querySelector("a"),F=z.value,K=function(){if(z.value===F)return;const[L,T,H]=[z.min,z.value,z.max].map((X)=>parseInt(X)||0);if(TH){z.value=F,z.select();return}let[M,R]=D(z.value);if(typeof E==="string"&&M==="1")R=Z(R,E);G.href=R,G.click()};["change","focus"].forEach((L)=>z.addEventListener(L,()=>z.select())),z.addEventListener("focusout",K),z.addEventListener("keypress",(L)=>{if(L.key==="Enter")K()})},Z=(B,D)=>B.replace(new RegExp(`[?&]${D}=1\\b(?!&)|\\b${D}=1&`),"");return{version:"9.3.4",init(B){const E=(B instanceof Element?B:document).querySelectorAll("[data-pagy]");for(let z of E)try{const G=Uint8Array.from(atob(z.getAttribute("data-pagy")),(L)=>L.charCodeAt(0)),[F,...K]=JSON.parse(new TextDecoder().decode(G));if(F==="nav")x(z,K);else if(F==="combo")A(z,K);else if(F==="selector")C(z,K);else console.warn("Skipped Pagy.init() for: %o\nUnknown keyword '%s'",z,F)}catch(G){console.warn("Skipped Pagy.init() for: %o\n%s",z,G)}}}})();
-//# debugId=3B38F8757344DCA164756E2164756E21
+//# debugId=645A69572EDFDB9764756E2164756E21
//# sourceMappingURL=pagy.min.js.map
diff --git a/gem/javascripts/pagy.min.js.map b/gem/javascripts/pagy.min.js.map
index 781c8bf42..d7a969af2 100644
--- a/gem/javascripts/pagy.min.js.map
+++ b/gem/javascripts/pagy.min.js.map
@@ -2,9 +2,9 @@
"version": 3,
"sources": ["../../src/pagy.ts"],
"sourcesContent": [
- "type NavArgs = readonly [Tokens, Sequels, null | LabelSequels, string?]\ntype ComboArgs = readonly [string, string?]\ntype SelectorArgs = readonly [number, string, string?]\ntype JsonArgs = ['nav', NavArgs] | ['combo', ComboArgs] | ['selector', SelectorArgs]\n\ninterface Tokens {\n readonly before:string\n readonly a:string\n readonly current:string\n readonly gap:string\n readonly after:string\n}\ninterface Sequels {readonly [width:string]:(string | number)[]}\ninterface LabelSequels {readonly [width:string]:string[]}\ninterface NavElement extends Element {pagyRender():void}\n\nconst Pagy = (() => {\n // The observer instance for responsive navs\n const rjsObserver = new ResizeObserver(\n entries => entries.forEach(e => e.target.querySelectorAll(\".pagy-rjs\")\n .forEach(el => el.pagyRender())));\n // Init the *_nav_js helpers\n const initNav = (el:NavElement, [tokens, sequels, labelSequels, trimParam]:NavArgs) => {\n const container = el.parentElement ?? el;\n const widths = Object.keys(sequels).map(w => parseInt(w)).sort((a, b) => b - a);\n let lastWidth = -1;\n const fillIn = (a:string, page:string, label:string):string =>\n a.replace(/__pagy_page__/g, page).replace(/__pagy_label__/g, label);\n (el.pagyRender = function () {\n const width = widths.find(w => w < container.clientWidth) || 0;\n if (width === lastWidth) { return } // no change: abort\n let html = tokens.before; // already trimmed in html\n const series = sequels[width.toString()];\n const labels = labelSequels?.[width.toString()] ?? series.map(l => l.toString());\n series.forEach((item, i) => {\n const label = labels[i];\n let filled;\n if (typeof item === \"number\") {\n filled = fillIn(tokens.a, item.toString(), label);\n } else if (item === \"gap\") {\n filled = tokens.gap;\n } else { // active page\n filled = fillIn(tokens.current, item, label);\n }\n html += (typeof trimParam === \"string\" && item == 1) ? trim(filled, trimParam) : filled;\n });\n html += tokens.after;\n el.innerHTML = \"\";\n el.insertAdjacentHTML(\"afterbegin\", html);\n lastWidth = width;\n })();\n if (el.classList.contains(\"pagy-rjs\")) { rjsObserver.observe(container) }\n };\n\n // Init the *_combo_nav_js helpers\n const initCombo = (el:Element, [url_token, trimParam]:ComboArgs) =>\n initInput(el, inputValue => [inputValue, url_token.replace(/__pagy_page__/, inputValue)], trimParam);\n\n // Init the limit_selector_js helper\n const initSelector = (el:Element, [from, url_token, trimParam]:SelectorArgs) => {\n initInput(el, inputValue => {\n const page = Math.max(Math.ceil(from / parseInt(inputValue)), 1).toString();\n const url = url_token.replace(/__pagy_page__/, page).replace(/__pagy_limit__/, inputValue);\n return [page, url];\n }, trimParam);\n };\n\n // Init the input element\n const initInput = (el:Element, getVars:(v:string) => [string, string], trimParam?:string) => {\n const input = el.querySelector(\"input\") as HTMLInputElement;\n const link = el.querySelector(\"a\") as HTMLAnchorElement;\n const initial = input.value;\n const action = function () {\n if (input.value === initial) { return } // not changed\n const [min, val, max] = [input.min, input.value, input.max].map(n => parseInt(n) || 0);\n if (val < min || val > max) { // reset invalid/out-of-range\n input.value = initial;\n input.select();\n return;\n }\n let [page, url] = getVars(input.value); // eslint-disable-line prefer-const\n if (typeof trimParam === \"string\" && page === \"1\") { url = trim(url, trimParam) }\n link.href = url;\n link.click();\n };\n [\"change\", \"focus\"].forEach(e => input.addEventListener(e, () => input.select())); // auto-select\n input.addEventListener(\"focusout\", action); // trigger action\n input.addEventListener(\"keypress\", e => { if (e.key === \"Enter\") { action() } }); // trigger action\n };\n\n // Trim the ${page-param}=1 params in links\n const trim = (a:string, param:string) =>\n a.replace(new RegExp(`[?&]${param}=1\\\\b(?!&)|\\\\b${param}=1&`), \"\");\n\n // Public interface\n return {\n version: \"9.3.3\",\n\n // Scan for elements with a \"data-pagy\" attribute and call their init functions with the decoded args\n init(arg?:Element) {\n const target = arg instanceof Element ? arg : document;\n const elements = target.querySelectorAll(\"[data-pagy]\");\n for (const el of elements) {\n try {\n const uint8array = Uint8Array.from(atob(el.getAttribute(\"data-pagy\") as string), c => c.charCodeAt(0));\n const [keyword, ...args] = JSON.parse((new TextDecoder()).decode(uint8array)) as JsonArgs; // base64-utf8 -> JSON -> Array\n if (keyword === \"nav\") {\n initNav(el as NavElement, args as unknown as NavArgs);\n } else if (keyword === \"combo\") {\n initCombo(el, args as unknown as ComboArgs);\n } else if (keyword === \"selector\") {\n initSelector(el, args as unknown as SelectorArgs);\n } else {\n console.warn(\"Skipped Pagy.init() for: %o\\nUnknown keyword '%s'\", el, keyword);\n }\n } catch (err) { console.warn(\"Skipped Pagy.init() for: %o\\n%s\", el, err) }\n }\n }\n };\n})();\n\nexport default Pagy;\n"
+ "type NavArgs = readonly [Tokens, Sequels, null | LabelSequels, string?]\ntype ComboArgs = readonly [string, string?]\ntype SelectorArgs = readonly [number, string, string?]\ntype JsonArgs = ['nav', NavArgs] | ['combo', ComboArgs] | ['selector', SelectorArgs]\n\ninterface Tokens {\n readonly before:string\n readonly a:string\n readonly current:string\n readonly gap:string\n readonly after:string\n}\ninterface Sequels {readonly [width:string]:(string | number)[]}\ninterface LabelSequels {readonly [width:string]:string[]}\ninterface NavElement extends Element {pagyRender():void}\n\nconst Pagy = (() => {\n // The observer instance for responsive navs\n const rjsObserver = new ResizeObserver(\n entries => entries.forEach(e => e.target.querySelectorAll(\".pagy-rjs\")\n .forEach(el => el.pagyRender())));\n // Init the *_nav_js helpers\n const initNav = (el:NavElement, [tokens, sequels, labelSequels, trimParam]:NavArgs) => {\n const container = el.parentElement ?? el;\n const widths = Object.keys(sequels).map(w => parseInt(w)).sort((a, b) => b - a);\n let lastWidth = -1;\n const fillIn = (a:string, page:string, label:string):string =>\n a.replace(/__pagy_page__/g, page).replace(/__pagy_label__/g, label);\n (el.pagyRender = function () {\n const width = widths.find(w => w < container.clientWidth) || 0;\n if (width === lastWidth) { return } // no change: abort\n let html = tokens.before; // already trimmed in html\n const series = sequels[width.toString()];\n const labels = labelSequels?.[width.toString()] ?? series.map(l => l.toString());\n series.forEach((item, i) => {\n const label = labels[i];\n let filled;\n if (typeof item === \"number\") {\n filled = fillIn(tokens.a, item.toString(), label);\n } else if (item === \"gap\") {\n filled = tokens.gap;\n } else { // active page\n filled = fillIn(tokens.current, item, label);\n }\n html += (typeof trimParam === \"string\" && item == 1) ? trim(filled, trimParam) : filled;\n });\n html += tokens.after;\n el.innerHTML = \"\";\n el.insertAdjacentHTML(\"afterbegin\", html);\n lastWidth = width;\n })();\n if (el.classList.contains(\"pagy-rjs\")) { rjsObserver.observe(container) }\n };\n\n // Init the *_combo_nav_js helpers\n const initCombo = (el:Element, [url_token, trimParam]:ComboArgs) =>\n initInput(el, inputValue => [inputValue, url_token.replace(/__pagy_page__/, inputValue)], trimParam);\n\n // Init the limit_selector_js helper\n const initSelector = (el:Element, [from, url_token, trimParam]:SelectorArgs) => {\n initInput(el, inputValue => {\n const page = Math.max(Math.ceil(from / parseInt(inputValue)), 1).toString();\n const url = url_token.replace(/__pagy_page__/, page).replace(/__pagy_limit__/, inputValue);\n return [page, url];\n }, trimParam);\n };\n\n // Init the input element\n const initInput = (el:Element, getVars:(v:string) => [string, string], trimParam?:string) => {\n const input = el.querySelector(\"input\") as HTMLInputElement;\n const link = el.querySelector(\"a\") as HTMLAnchorElement;\n const initial = input.value;\n const action = function () {\n if (input.value === initial) { return } // not changed\n const [min, val, max] = [input.min, input.value, input.max].map(n => parseInt(n) || 0);\n if (val < min || val > max) { // reset invalid/out-of-range\n input.value = initial;\n input.select();\n return;\n }\n let [page, url] = getVars(input.value); // eslint-disable-line prefer-const\n if (typeof trimParam === \"string\" && page === \"1\") { url = trim(url, trimParam) }\n link.href = url;\n link.click();\n };\n [\"change\", \"focus\"].forEach(e => input.addEventListener(e, () => input.select())); // auto-select\n input.addEventListener(\"focusout\", action); // trigger action\n input.addEventListener(\"keypress\", e => { if (e.key === \"Enter\") { action() } }); // trigger action\n };\n\n // Trim the ${page-param}=1 params in links\n const trim = (a:string, param:string) =>\n a.replace(new RegExp(`[?&]${param}=1\\\\b(?!&)|\\\\b${param}=1&`), \"\");\n\n // Public interface\n return {\n version: \"9.3.4\",\n\n // Scan for elements with a \"data-pagy\" attribute and call their init functions with the decoded args\n init(arg?:Element) {\n const target = arg instanceof Element ? arg : document;\n const elements = target.querySelectorAll(\"[data-pagy]\");\n for (const el of elements) {\n try {\n const uint8array = Uint8Array.from(atob(el.getAttribute(\"data-pagy\") as string), c => c.charCodeAt(0));\n const [keyword, ...args] = JSON.parse((new TextDecoder()).decode(uint8array)) as JsonArgs; // base64-utf8 -> JSON -> Array\n if (keyword === \"nav\") {\n initNav(el as NavElement, args as unknown as NavArgs);\n } else if (keyword === \"combo\") {\n initCombo(el, args as unknown as ComboArgs);\n } else if (keyword === \"selector\") {\n initSelector(el, args as unknown as SelectorArgs);\n } else {\n console.warn(\"Skipped Pagy.init() for: %o\\nUnknown keyword '%s'\", el, keyword);\n }\n } catch (err) { console.warn(\"Skipped Pagy.init() for: %o\\n%s\", el, err) }\n }\n }\n };\n})();\n\nexport default Pagy;\n"
],
"mappings": "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",
- "debugId": "3B38F8757344DCA164756E2164756E21",
+ "debugId": "645A69572EDFDB9764756E2164756E21",
"names": []
}
\ No newline at end of file
diff --git a/gem/javascripts/pagy.mjs b/gem/javascripts/pagy.mjs
index 6eac86570..b8bb93eaf 100644
--- a/gem/javascripts/pagy.mjs
+++ b/gem/javascripts/pagy.mjs
@@ -73,7 +73,7 @@ const Pagy = (() => {
};
const trim = (a, param) => a.replace(new RegExp(`[?&]${param}=1\\b(?!&)|\\b${param}=1&`), "");
return {
- version: "9.3.3",
+ version: "9.3.4",
init(arg) {
const target = arg instanceof Element ? arg : document;
const elements = target.querySelectorAll("[data-pagy]");
diff --git a/gem/lib/pagy.rb b/gem/lib/pagy.rb
index b1e63eca6..651c04ae9 100644
--- a/gem/lib/pagy.rb
+++ b/gem/lib/pagy.rb
@@ -6,7 +6,7 @@
# Top superclass: it should define only what's common to all the subclasses
class Pagy
- VERSION = '9.3.3'
+ VERSION = '9.3.4'
# Core default: constant for easy access, but mutable for customizable defaults
DEFAULT = { count_args: [:all], # rubocop:disable Style/MutableConstant
diff --git a/gem/pagy.gemspec b/gem/pagy.gemspec
index e7040d35d..38e2943ca 100644
--- a/gem/pagy.gemspec
+++ b/gem/pagy.gemspec
@@ -2,7 +2,7 @@
Gem::Specification.new do |s|
s.name = 'pagy'
- s.version = '9.3.3'
+ s.version = '9.3.4'
s.authors = ['Domizio Demichelis']
s.email = ['dd.nexus@gmail.com']
s.summary = 'The best pagination ruby gem'
diff --git a/retype.yml b/retype.yml
index 0c89d47a9..024fcf179 100644
--- a/retype.yml
+++ b/retype.yml
@@ -8,7 +8,7 @@ url: https://ddnexus.github.io/pagy
branding:
title: Pagy
- label: 9.3.3
+ label: 9.3.4
colors:
label:
text: "#FFFFFF"
diff --git a/scripts/bump.rb b/scripts/bump.rb
index f9541a16d..2332e3ce7 100755
--- a/scripts/bump.rb
+++ b/scripts/bump.rb
@@ -41,7 +41,7 @@
gitlog.puts body
end
# Abort if there is no gem change
-abort("No gem changes since version #{old_version}!") if gitlog.size.zero? # rubocop:disable Style/ZeroLengthPredicate (bug)
+abort("No gem changes since version #{old_version}!") if gitlog.size.zero? # rubocop:disable Style/ZeroLengthPredicate
gitlog.close
diff --git a/src/pagy.ts b/src/pagy.ts
index 0736dcbb6..d5f833cb5 100644
--- a/src/pagy.ts
+++ b/src/pagy.ts
@@ -94,7 +94,7 @@ const Pagy = (() => {
// Public interface
return {
- version: "9.3.3",
+ version: "9.3.4",
// Scan for elements with a "data-pagy" attribute and call their init functions with the decoded args
init(arg?:Element) {
diff --git a/test/pagy/extras/metadata_test.rb b/test/pagy/extras/metadata_test.rb
index 42d11b117..b3df971d3 100644
--- a/test/pagy/extras/metadata_test.rb
+++ b/test/pagy/extras/metadata_test.rb
@@ -20,7 +20,7 @@
_(Pagy::DEFAULT[:metadata]).must_rematch :metadata
end
it 'returns the full pagy metadata' do
- pagy, _records = app.send(:pagy, @collection, metadata: (Pagy::DEFAULT[:metadata]) + [:sequels])
+ pagy, _records = app.send(:pagy, @collection, metadata: Pagy::DEFAULT[:metadata] + [:sequels])
_(app.send(:pagy_metadata, pagy)).must_rematch :metadata
end
it 'checks for unknown metadata' do