playbook_ui 11.10.0 → 11.11.0.pre.alpha.paginate1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (29) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/_playbook.scss +2 -0
  3. data/app/pb_kits/playbook/data/menu.yml +1 -0
  4. data/app/pb_kits/playbook/index.js +2 -1
  5. data/app/pb_kits/playbook/pb_pagination/_pagination.scss +52 -0
  6. data/app/pb_kits/playbook/pb_pagination/_pagination.tsx +41 -0
  7. data/app/pb_kits/playbook/pb_pagination/docs/_pagination_default.html.erb +1 -0
  8. data/app/pb_kits/playbook/pb_pagination/docs/_pagination_default.jsx +12 -0
  9. data/app/pb_kits/playbook/pb_pagination/docs/example.yml +9 -0
  10. data/app/pb_kits/playbook/pb_pagination/docs/index.js +1 -0
  11. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +7 -0
  12. data/app/pb_kits/playbook/pb_pagination/pagination.rb +8 -0
  13. data/app/pb_kits/playbook/pb_pagination/pagination.test.jsx +17 -0
  14. data/app/pb_kits/playbook/pb_user/_user.tsx +15 -1
  15. data/app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_rails.html.erb +36 -0
  16. data/app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_rails.md +1 -0
  17. data/app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_react.jsx +56 -0
  18. data/app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_react.md +1 -0
  19. data/app/pb_kits/playbook/pb_user/docs/_user_subtitle.html.erb +23 -0
  20. data/app/pb_kits/playbook/pb_user/docs/_user_subtitle.jsx +33 -0
  21. data/app/pb_kits/playbook/pb_user/docs/example.yml +4 -3
  22. data/app/pb_kits/playbook/pb_user/docs/index.js +2 -0
  23. data/app/pb_kits/playbook/pb_user/user.html.erb +10 -2
  24. data/app/pb_kits/playbook/pb_user/user.rb +1 -0
  25. data/app/pb_kits/playbook/pb_user/user.test.js +28 -0
  26. data/app/pb_kits/playbook/playbook-doc.js +2 -0
  27. data/lib/playbook/pagination/pagination_renderer.rb +39 -0
  28. data/lib/playbook/version.rb +2 -2
  29. metadata +21 -4
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0cae07073769e635a2939918a0073c3b64119f9ded3a1390688945395ecbd9df
4
- data.tar.gz: 38d8898737006ea27c5bcf4c2b65734dd1df5ef004a351638dc00015ca6bcbaa
3
+ metadata.gz: c6b41796c2693b117dbbb0b3f6df657d367060abfd50fc55c4db6e3f1ed6c971
4
+ data.tar.gz: 7215f63899347c3044650422911ee5224b63f3858591dd5a0a17d555085aca3f
5
5
  SHA512:
6
- metadata.gz: 787832d4132fb8a9373f06a684645f0945998476c5d5b2ab44718b0078eae552995cfe1d550a758a57f79d9a03267ffafee6882a5330fdf016d5c3a16f6a6ae2
7
- data.tar.gz: a675526b2eec32a03c1f2409919a30deba79dfcd8bf3c06970c7153d35e4d37db4f665b0d66e05dc117e1937b2cbbb7a68b17b1e67f8555b7926c4c4c7cc7107
6
+ metadata.gz: 8fb4dd90e9216feb799fdbfd3167d6b5088d7e54843030e916976f512607ecf12f5f09db978ae93b1ebb3d733ffd2e487acbc78996fc4b27d1be710a246ec8e9
7
+ data.tar.gz: 64fcecd54d4630c3001e5341a0382cb378d0bcad69631c7a5c872513a94592ae1c00d830fe41760fd205ffa6f42e98de9c57e105eccc9ad41ad15cfc1f339e19
@@ -103,3 +103,5 @@
103
103
  @import './utilities/line_height';
104
104
  @import './utilities/display';
105
105
  @import './utilities/flexbox';
106
+
107
+ @import 'pb_pagination/pagination';
@@ -104,3 +104,4 @@ kits:
104
104
  - title_detail
105
105
  - user_badge
106
106
  - walkthrough
107
+ - pagination
@@ -52,9 +52,9 @@ export { default as LabelPill } from './pb_label_pill/_label_pill'
52
52
  export { default as LabelValue } from './pb_label_value/_label_value'
53
53
  export { default as Layout } from './pb_layout/_layout'
54
54
  export { default as Legend } from './pb_legend/_legend'
55
+ export { default as Lightbox } from './pb_lightbox/_lightbox'
55
56
  export { default as LineGraph } from './pb_line_graph/_line_graph'
56
57
  export { default as List } from './pb_list/_list'
57
- export { default as Lightbox } from './pb_lightbox/_lightbox'
58
58
  export { default as ListItem } from './pb_list/_list_item'
59
59
  export { default as LoadingInline } from './pb_loading_inline/_loading_inline'
60
60
  export { default as Message } from './pb_message/_message'
@@ -63,6 +63,7 @@ export { default as MultipleUsersStacked } from './pb_multiple_users_stacked/_mu
63
63
  export { default as Nav } from './pb_nav/_nav'
64
64
  export { default as NavItem } from './pb_nav/_item'
65
65
  export { default as OnlineStatus } from './pb_online_status/_online_status'
66
+ export { default as Pagination} from './pb_pagination/_pagination'
66
67
  export { default as Passphrase } from './pb_passphrase/_passphrase'
67
68
  export { default as PbReactPopover } from './pb_popover/_popover'
68
69
  export { default as Person } from './pb_person/_person'
@@ -0,0 +1,52 @@
1
+ @import "tokens/colors";
2
+ @import "tokens/typography";
3
+ @import "tokens/border_radius";
4
+ @import "tokens/shadows";
5
+
6
+ .pb_pagination {
7
+ li > a, li > span {
8
+ border: 0 !important;
9
+ margin-top: 1px;
10
+ margin-bottom: 1px;
11
+ }
12
+ li:first-child > a, li:first-child > span {
13
+ border-right: 1px solid $border_light !important;
14
+ z-index: 2;
15
+ }
16
+ li:last-child > a, li:last-child > span {
17
+ border-left: 1px solid $border_light !important;
18
+ z-index: 2;
19
+ }
20
+ border: 1px solid $border_light;
21
+ background-color: $white;
22
+ a {
23
+ color: $text_lt_default !important;
24
+ font-size: $text_small;
25
+ font-weight: $bold;
26
+ border: none;
27
+ margin-left: 1px;
28
+ margin-right: 1px;
29
+
30
+ &:hover {
31
+ background-color: $active_light;
32
+ color: $primary !important;
33
+ border-radius: $border_rad_light;
34
+ }
35
+
36
+ &:focus {
37
+ outline: 1px solid $primary !important;
38
+ border-radius: $border_rad_light;
39
+ outline-offset: -1px;
40
+ }
41
+ }
42
+ .active > span {
43
+ background-color: $primary;
44
+ border-radius: $border_rad_light;
45
+ margin-left: 1px;
46
+ margin-right: 1px;
47
+
48
+ &:hover {
49
+ box-shadow: $shadow_deeper;
50
+ }
51
+ }
52
+ }
@@ -0,0 +1,41 @@
1
+
2
+
3
+ /* @flow */
4
+
5
+ import React from 'react'
6
+ import classnames from 'classnames'
7
+ import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'
8
+ import { globalProps } from '../utilities/globalProps'
9
+
10
+ type PaginationProps = {
11
+ aria?: { [key: string]: string },
12
+ className?: string,
13
+ data?: { [key: string]: string },
14
+ id?: string,
15
+ }
16
+
17
+ const Pagination = (props: PaginationProps) => {
18
+ const {
19
+ aria = {},
20
+ className,
21
+ data = {},
22
+ id,
23
+ } = props
24
+
25
+ const ariaProps = buildAriaProps(aria)
26
+ const dataProps = buildDataProps(data)
27
+ const classes = classnames(buildCss('pb_pagination'), globalProps(props), className)
28
+
29
+ return (
30
+ <div
31
+ {...ariaProps}
32
+ {...dataProps}
33
+ className={classes}
34
+ id={id}
35
+ >
36
+ {className}
37
+ </div>
38
+ )
39
+ }
40
+
41
+ export default Pagination
@@ -0,0 +1 @@
1
+ <%= pb_rails("pagination") %>
@@ -0,0 +1,12 @@
1
+ import React from 'react'
2
+ import Pagination from '../_pagination'
3
+
4
+ const PaginationDefault = (props) => (
5
+ <div>
6
+ <Pagination
7
+ {...props}
8
+ />
9
+ </div>
10
+ )
11
+
12
+ export default PaginationDefault
@@ -0,0 +1,9 @@
1
+ examples:
2
+
3
+ rails:
4
+ - pagination_default: Default
5
+
6
+
7
+ react:
8
+ - pagination_default: Default
9
+
@@ -0,0 +1 @@
1
+ export { default as PaginationDefault } from './_pagination_default.jsx'
@@ -0,0 +1,7 @@
1
+ <%= content_tag(:div,
2
+ aria: object.aria,
3
+ class: object.classname,
4
+ data: object.data,
5
+ id: object.id) do %>
6
+ <span>PAGINATION CONTENT</span>
7
+ <% end %>
@@ -0,0 +1,8 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbPagination
5
+ class Pagination < ::Playbook::KitBase
6
+ end
7
+ end
8
+ end
@@ -0,0 +1,17 @@
1
+ import { renderKit } from '../utilities/test-utils'
2
+
3
+ import { Pagination } from '../'
4
+
5
+ /* See these resources for more testing info:
6
+ - https://github.com/testing-library/jest-dom#usage for useage and examples
7
+ - https://jestjs.io/docs/en/using-matchers
8
+ */
9
+
10
+ test('generated scaffold test - update me', () => {
11
+ const props = {
12
+ data: { testid: 'default' }
13
+ }
14
+
15
+ const kit = renderKit(Pagination , props)
16
+ expect(kit).toBeInTheDocument()
17
+ })
@@ -1,4 +1,3 @@
1
-
2
1
  import React from 'react'
3
2
  import classnames from 'classnames'
4
3
 
@@ -21,6 +20,7 @@ type UserProps = {
21
20
  name?: string,
22
21
  orientation?: "horiztonal" | "vertical",
23
22
  size?: "sm" | "md" | "lg",
23
+ subtitle?: string | Array<Node> | Node,
24
24
  territory?: string,
25
25
  title?: string,
26
26
  } & GlobalProps
@@ -38,6 +38,7 @@ const User = (props: UserProps) => {
38
38
  name,
39
39
  orientation = 'horizontal',
40
40
  size = 'sm',
41
+ subtitle,
41
42
  territory = '',
42
43
  title = '',
43
44
  } = props
@@ -81,6 +82,19 @@ const User = (props: UserProps) => {
81
82
  >
82
83
  {territory === '' ? title : `${territory} • ${title}`}
83
84
  </Body>
85
+ { typeof(subtitle) === 'string' &&
86
+ <Body
87
+ color="light"
88
+ dark={dark}
89
+ text={subtitle}
90
+ variant={null}
91
+ />
92
+ }
93
+ { typeof(subtitle) !== 'string' &&
94
+ <>
95
+ {subtitle}
96
+ </>
97
+ }
84
98
  </div>
85
99
  </div>
86
100
  )
@@ -0,0 +1,36 @@
1
+ <div class="pb--doc-demo-row">
2
+ <%= pb_rails("user", props: {
3
+ align: "left",
4
+ avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
5
+ name: "Anna Black",
6
+ orientation: "horizontal",
7
+ size: "md",
8
+ territory: "PHL",
9
+ title: "Remodeling Consultant"
10
+ }) do %>
11
+ <%= pb_rails("flex", props: { align: "center" }) do %>
12
+ <%= pb_rails("icon", props: { icon: "users" }) %>
13
+ <%= pb_rails("caption", props: { padding_left: "xs", text: "Admin" }) %>
14
+ <% end %>
15
+ <% end %>
16
+
17
+ <%= pb_rails("user", props: {
18
+ align: "left",
19
+ avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
20
+ name: "Anna Black",
21
+ orientation: "horizontal",
22
+ size: "md",
23
+ }) do %>
24
+ <%= pb_rails("contact", props: {
25
+ contact_type: "cell",
26
+ contact_value: "349-185-9988"
27
+ }) %>
28
+ <%= pb_rails("contact", props: {
29
+ contact_value: 5555555555
30
+ }) %>
31
+ <%= pb_rails("contact", props: {
32
+ contact_type: "email",
33
+ contact_value: "email@example.com"
34
+ }) %>
35
+ <% end %>
36
+ </div>
@@ -0,0 +1 @@
1
+ The kit accepts block content and whatever is passed as block content will display in the subtitle section.
@@ -0,0 +1,56 @@
1
+ import React from "react"
2
+ import { Caption, Contact, Flex, Icon, User } from "../.."
3
+
4
+ const MentorSubtitle = (
5
+ <Flex>
6
+ <Icon icon="users" />
7
+ <Caption
8
+ paddingLeft="xs"
9
+ text="Admin"
10
+ />
11
+ </Flex>
12
+ )
13
+
14
+ const ContactSubtitle = (
15
+ <>
16
+ <Contact
17
+ contactType="cell"
18
+ contactValue="349-185-9988"
19
+ />
20
+ <Contact
21
+ contactValue="5555555555"
22
+ />
23
+ <Contact
24
+ contactType="email"
25
+ contactValue="email@example.com"
26
+ />
27
+ </>
28
+ )
29
+
30
+ const UserBlockContentSubtitleReact = (props) => {
31
+ return (
32
+ <div className="pb--doc-demo-row">
33
+ <User
34
+ align="left"
35
+ avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
36
+ name="Anna Black"
37
+ orientation="horizontal"
38
+ subtitle={MentorSubtitle}
39
+ territory="PHL"
40
+ title="Remodeling Consultant"
41
+ {...props}
42
+ />
43
+
44
+ <User
45
+ align="left"
46
+ avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
47
+ name="Anna Black"
48
+ orientation="horizontal"
49
+ subtitle={ContactSubtitle}
50
+ {...props}
51
+ />
52
+ </div>
53
+ )
54
+ }
55
+
56
+ export default UserBlockContentSubtitleReact
@@ -0,0 +1 @@
1
+ The `subtitle` prop accepts strings as well as nodes. Whatever node is passed will display in the subtitle section.
@@ -0,0 +1,23 @@
1
+ <div class="pb--doc-demo-row">
2
+ <%= pb_rails("user", props: {
3
+ align: "center",
4
+ avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
5
+ name: "Anna Black",
6
+ orientation: "vertical",
7
+ size: "md",
8
+ subtitle: "User ID: 12345",
9
+ territory: "PHL",
10
+ title: "Remodeling Consultant"
11
+ }) %>
12
+
13
+ <%= pb_rails("user", props: {
14
+ align: "left",
15
+ avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
16
+ name: "Anna Black",
17
+ orientation: "horizontal",
18
+ size: "md",
19
+ subtitle: "User ID: 12345",
20
+ territory: "PHL",
21
+ title: "Remodeling Consultant"
22
+ }) %>
23
+ </div>
@@ -0,0 +1,33 @@
1
+ import React from "react"
2
+ import { User } from "../../"
3
+
4
+ const UserSubtitle = (props) => {
5
+ return (
6
+ <div className="pb--doc-demo-row">
7
+ <User
8
+ align="center"
9
+ avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
10
+ name="Anna Black"
11
+ orientation="vertical"
12
+ size="lg"
13
+ subtitle="User ID: 12345"
14
+ territory="PHL"
15
+ title="Remodeling Consultant"
16
+ {...props}
17
+ />
18
+
19
+ <User
20
+ align="left"
21
+ avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
22
+ name="Anna Black"
23
+ orientation="horizontal"
24
+ subtitle="User ID: 12345"
25
+ territory="PHL"
26
+ title="Remodeling Consultant"
27
+ {...props}
28
+ />
29
+ </div>
30
+ )
31
+ }
32
+
33
+ export default UserSubtitle
@@ -6,9 +6,8 @@ examples:
6
6
  - user_text_only: Text Only
7
7
  - user_size: Horizontal Size
8
8
  - user_vertical_size: Vertical Size
9
-
10
-
11
-
9
+ - user_subtitle: Subtitle
10
+ - user_block_content_subtitle_rails: Block Content Subtitle
12
11
 
13
12
  react:
14
13
  - user_default: Default
@@ -16,3 +15,5 @@ examples:
16
15
  - user_text_only: Text Only
17
16
  - user_size: Horizontal Size
18
17
  - user_vertical_size: Vertical Size
18
+ - user_subtitle: Subtitle
19
+ - user_block_content_subtitle_react: Block Content Subtitle
@@ -3,3 +3,5 @@ export { default as UserWithTerritory } from './_user_with_territory.jsx'
3
3
  export { default as UserTextOnly } from './_user_text_only.jsx'
4
4
  export { default as UserSize } from './_user_size.jsx'
5
5
  export { default as UserVerticalSize } from './_user_vertical_size.jsx'
6
+ export { default as UserSubtitle } from './_user_subtitle.jsx'
7
+ export { default as UserBlockContentSubtitleReact } from './_user_block_content_subtitle_react.jsx'
@@ -10,13 +10,21 @@
10
10
  image_url: object.avatar_url
11
11
  }) %>
12
12
  <% end %>
13
- <%= content_tag(:div,
14
- class: "content_wrapper") do %>
13
+ <%= content_tag(:div, class: "content_wrapper") do %>
15
14
  <%= pb_rails("title", props: { text: object.name, size: object.title_size, dark: object.dark }) %>
16
15
  <%= pb_rails("body", props: {
17
16
  text: "#{object.details}",
18
17
  dark: object.dark,
19
18
  color: "light"
20
19
  }) %>
20
+ <% if content %>
21
+ <%= content.presence %>
22
+ <% else %>
23
+ <%= pb_rails("body", props: {
24
+ text: "#{object.subtitle}",
25
+ dark: object.dark,
26
+ color: "light"
27
+ }) %>
28
+ <% end %>
21
29
  <% end %>
22
30
  <% end %>
@@ -16,6 +16,7 @@ module Playbook
16
16
  prop :size, type: Playbook::Props::Enum,
17
17
  values: %w[lg md sm],
18
18
  default: "sm"
19
+ prop :subtitle
19
20
  prop :title
20
21
  prop :territory
21
22
 
@@ -0,0 +1,28 @@
1
+ import React from 'react'
2
+ import { render, screen } from '../utilities/test-utils'
3
+ import User from './_user'
4
+ import Caption from "../pb_caption/_caption"
5
+
6
+ test('subtitle prop adds subtitle text', () => {
7
+ render(
8
+ <User
9
+ data={{ testid: 'test-subtitle' }}
10
+ subtitle='test subtitle'
11
+ />
12
+ )
13
+
14
+ expect(screen.getByTestId('test-subtitle')).toHaveTextContent('test subtitle')
15
+ })
16
+
17
+ test('subtitle prop accepts a node', () => {
18
+ const TestCaption = <Caption text='test caption' />
19
+
20
+ render(
21
+ <User
22
+ data={{ testid: 'test-subtitle-block' }}
23
+ subtitle={TestCaption}
24
+ />
25
+ )
26
+
27
+ expect(screen.getByTestId('test-subtitle-block')).toHaveTextContent('test caption')
28
+ })
@@ -60,6 +60,7 @@ import * as MultipleUsers from 'pb_multiple_users/docs'
60
60
  import * as MultipleUsersStacked from 'pb_multiple_users_stacked/docs'
61
61
  import * as Nav from 'pb_nav/docs'
62
62
  import * as OnlineStatus from 'pb_online_status/docs'
63
+ import * as Pagination from 'pb_pagination/docs'
63
64
  import * as Passphrase from 'pb_passphrase/docs'
64
65
  import * as PbReactPopover from 'pb_popover/docs'
65
66
  import * as Person from 'pb_person/docs'
@@ -157,6 +158,7 @@ WebpackerReact.setup({
157
158
  ...MultipleUsersStacked,
158
159
  ...Nav,
159
160
  ...OnlineStatus,
161
+ ...Pagination,
160
162
  ...Passphrase,
161
163
  ...PbReactPopover,
162
164
  ...Person,
@@ -0,0 +1,39 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ class LinkRenderer < WillPaginate::ActionView::LinkRenderer
5
+ def container_attributes
6
+ { class: "pb_pagination pagination" }
7
+ end
8
+
9
+ def page_number(page)
10
+ if page == current_page
11
+ tag("li", tag("span", page), class: "active")
12
+ else
13
+ tag("li", link(page, page, rel: rel_value(page)))
14
+ end
15
+ end
16
+
17
+ def previous_or_next_page(page, text, classname)
18
+ if page
19
+ tag("li", link(text, page), class: classname)
20
+ else
21
+ tag("li", tag("span", text), class: "%s disabled")
22
+ end
23
+ end
24
+
25
+ def gap
26
+ tag("li", tag("span", "&hellip;"), class: "disabled")
27
+ end
28
+
29
+ def previous_page
30
+ num = @collection.current_page > 1 && @collection.current_page - 1
31
+ previous_or_next_page(num, "<i class='far fa-chevron-left'></i>", "prev")
32
+ end
33
+
34
+ def next_page
35
+ num = @collection.current_page < @collection.total_pages && @collection.current_page + 1
36
+ previous_or_next_page(num, "<i class='far fa-chevron-right'></i>", "next")
37
+ end
38
+ end
39
+ end
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Playbook
4
- PREVIOUS_VERSION = "11.9.0"
5
- VERSION = "11.10.0"
4
+ PREVIOUS_VERSION = "11.11.0"
5
+ VERSION = "11.11.0.pre.alpha.paginate1"
6
6
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: playbook_ui
3
3
  version: !ruby/object:Gem::Version
4
- version: 11.10.0
4
+ version: 11.11.0.pre.alpha.paginate1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Power UX
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2022-10-25 00:00:00.000000000 Z
12
+ date: 2022-11-09 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: actionpack
@@ -1433,6 +1433,15 @@ files:
1433
1433
  - app/pb_kits/playbook/pb_online_status/docs/index.js
1434
1434
  - app/pb_kits/playbook/pb_online_status/online_status.html.erb
1435
1435
  - app/pb_kits/playbook/pb_online_status/online_status.rb
1436
+ - app/pb_kits/playbook/pb_pagination/_pagination.scss
1437
+ - app/pb_kits/playbook/pb_pagination/_pagination.tsx
1438
+ - app/pb_kits/playbook/pb_pagination/docs/_pagination_default.html.erb
1439
+ - app/pb_kits/playbook/pb_pagination/docs/_pagination_default.jsx
1440
+ - app/pb_kits/playbook/pb_pagination/docs/example.yml
1441
+ - app/pb_kits/playbook/pb_pagination/docs/index.js
1442
+ - app/pb_kits/playbook/pb_pagination/pagination.html.erb
1443
+ - app/pb_kits/playbook/pb_pagination/pagination.rb
1444
+ - app/pb_kits/playbook/pb_pagination/pagination.test.jsx
1436
1445
  - app/pb_kits/playbook/pb_passphrase/_passphrase.jsx
1437
1446
  - app/pb_kits/playbook/pb_passphrase/_passphrase.scss
1438
1447
  - app/pb_kits/playbook/pb_passphrase/docs/_passphrase_breached.html.erb
@@ -2130,10 +2139,16 @@ files:
2130
2139
  - app/pb_kits/playbook/pb_user/_user.tsx
2131
2140
  - app/pb_kits/playbook/pb_user/docs/_description.md
2132
2141
  - app/pb_kits/playbook/pb_user/docs/_footer.md
2142
+ - app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_rails.html.erb
2143
+ - app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_rails.md
2144
+ - app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_react.jsx
2145
+ - app/pb_kits/playbook/pb_user/docs/_user_block_content_subtitle_react.md
2133
2146
  - app/pb_kits/playbook/pb_user/docs/_user_default.html.erb
2134
2147
  - app/pb_kits/playbook/pb_user/docs/_user_default.jsx
2135
2148
  - app/pb_kits/playbook/pb_user/docs/_user_size.html.erb
2136
2149
  - app/pb_kits/playbook/pb_user/docs/_user_size.jsx
2150
+ - app/pb_kits/playbook/pb_user/docs/_user_subtitle.html.erb
2151
+ - app/pb_kits/playbook/pb_user/docs/_user_subtitle.jsx
2137
2152
  - app/pb_kits/playbook/pb_user/docs/_user_text_only.html.erb
2138
2153
  - app/pb_kits/playbook/pb_user/docs/_user_text_only.jsx
2139
2154
  - app/pb_kits/playbook/pb_user/docs/_user_vertical_size.html.erb
@@ -2144,6 +2159,7 @@ files:
2144
2159
  - app/pb_kits/playbook/pb_user/docs/index.js
2145
2160
  - app/pb_kits/playbook/pb_user/user.html.erb
2146
2161
  - app/pb_kits/playbook/pb_user/user.rb
2162
+ - app/pb_kits/playbook/pb_user/user.test.js
2147
2163
  - app/pb_kits/playbook/pb_user_badge/_user_badge.jsx
2148
2164
  - app/pb_kits/playbook/pb_user_badge/_user_badge.scss
2149
2165
  - app/pb_kits/playbook/pb_user_badge/badges/million-dollar.svg
@@ -2283,6 +2299,7 @@ files:
2283
2299
  - lib/playbook/markdown/template_handler.rb
2284
2300
  - lib/playbook/number_spacing.rb
2285
2301
  - lib/playbook/order.rb
2302
+ - lib/playbook/pagination/pagination_renderer.rb
2286
2303
  - lib/playbook/pb_doc_helper.rb
2287
2304
  - lib/playbook/pb_forms_helper.rb
2288
2305
  - lib/playbook/pb_kit_helper.rb
@@ -2321,9 +2338,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
2321
2338
  version: '0'
2322
2339
  required_rubygems_version: !ruby/object:Gem::Requirement
2323
2340
  requirements:
2324
- - - ">="
2341
+ - - ">"
2325
2342
  - !ruby/object:Gem::Version
2326
- version: '0'
2343
+ version: 1.3.1
2327
2344
  requirements: []
2328
2345
  rubygems_version: 3.3.7
2329
2346
  signing_key: