playbook_ui 14.10.0.pre.alpha.play16825206 → 14.10.0.pre.alpha.play16825301

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +11 -16
  3. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +1 -1
  4. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +8 -1
  5. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.html.erb +1 -3
  6. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.html.erb +1 -1
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.md +1 -1
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers.html.erb +43 -0
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_multiple.html.erb +58 -0
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +3 -0
  11. data/app/pb_kits/playbook/pb_advanced_table/index.js +185 -92
  12. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +1 -1
  13. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +55 -8
  14. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +17 -14
  15. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +78 -0
  16. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +4 -3
  17. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +13 -2
  18. data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.html.erb +2 -6
  19. data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.rb +6 -4
  20. data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.scss +11 -9
  21. data/app/pb_kits/playbook/pb_badge/_badge.scss +4 -2
  22. data/app/pb_kits/playbook/pb_bread_crumbs/_bread_crumbs.scss +3 -1
  23. data/app/pb_kits/playbook/pb_button/_button.scss +3 -1
  24. data/app/pb_kits/playbook/pb_card/_card.scss +21 -3
  25. data/app/pb_kits/playbook/pb_card/docs/_card_header.html.erb +18 -0
  26. data/app/pb_kits/playbook/pb_card/docs/_card_header.jsx +40 -0
  27. data/app/pb_kits/playbook/pb_circle_icon_button/_circle_icon_button.scss +4 -2
  28. data/app/pb_kits/playbook/pb_date_picker/sass_partials/_input_styles.scss +3 -1
  29. data/app/pb_kits/playbook/pb_date_picker/sass_partials/_overrides.scss +5 -3
  30. data/app/pb_kits/playbook/pb_date_range_inline/_date_range_inline.scss +6 -4
  31. data/app/pb_kits/playbook/pb_date_time_stacked/_date_time_stacked.scss +4 -2
  32. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +10 -8
  33. data/app/pb_kits/playbook/pb_file_upload/_file_upload.tsx +24 -15
  34. data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_accept.jsx +3 -1
  35. data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_custom_description.jsx +4 -1
  36. data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_max_size.jsx +1 -1
  37. data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +6 -4
  38. data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.scss +3 -1
  39. data/app/pb_kits/playbook/pb_label_value/_label_value.scss +4 -2
  40. data/app/pb_kits/playbook/pb_message/_message_mixins.scss +3 -1
  41. data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.scss +3 -1
  42. data/app/pb_kits/playbook/pb_passphrase/_passphrase.scss +5 -3
  43. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.scss +10 -8
  44. data/app/pb_kits/playbook/pb_pill/_pill.scss +4 -2
  45. data/app/pb_kits/playbook/pb_progress_simple/_progress_simple.scss +4 -2
  46. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.scss +4 -2
  47. data/app/pb_kits/playbook/pb_select/_select.scss +5 -3
  48. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +5 -3
  49. data/app/pb_kits/playbook/pb_table/_table.tsx +8 -1
  50. data/app/pb_kits/playbook/pb_table/docs/example.yml +2 -0
  51. data/app/pb_kits/playbook/pb_table/docs/index.js +2 -0
  52. data/app/pb_kits/playbook/pb_text_input/_text_input.scss +3 -1
  53. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_mask.jsx +18 -0
  54. data/app/pb_kits/playbook/pb_text_input/inputMask.ts +22 -1
  55. data/app/pb_kits/playbook/pb_text_input/text_input.test.js +80 -0
  56. data/app/pb_kits/playbook/pb_textarea/_textarea.scss +3 -1
  57. data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.scss +5 -4
  58. data/app/pb_kits/playbook/pb_timeline/_timeline.scss +4 -2
  59. data/app/pb_kits/playbook/pb_timeline/_timeline.tsx +5 -5
  60. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_gap.html.erb +4 -5
  61. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_gap.jsx +4 -4
  62. data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_gap.md +1 -1
  63. data/app/pb_kits/playbook/pb_timeline/timeline.rb +6 -6
  64. data/app/pb_kits/playbook/pb_toggle/_toggle.scss +5 -3
  65. data/dist/chunks/_typeahead-C2iCBqxQ.js +36 -0
  66. data/dist/chunks/_weekday_stacked-CWnbnW7m.js +45 -0
  67. data/dist/chunks/vendor.js +1 -1
  68. data/dist/playbook-doc.js +1 -1
  69. data/dist/playbook-rails-react-bindings.js +1 -1
  70. data/dist/playbook-rails.js +1 -1
  71. data/dist/playbook.css +1 -1
  72. data/lib/playbook/version.rb +1 -1
  73. metadata +6 -4
  74. data/dist/chunks/_typeahead-CbKUtXZa.js +0 -22
  75. data/dist/chunks/_weekday_stacked-CEpLoHbM.js +0 -45
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/colors";
2
4
  @import "../tokens/spacing";
3
5
  @import "../tokens/typography";
@@ -122,7 +124,7 @@
122
124
 
123
125
  &.error {
124
126
  [class*=pb_body_kit] {
125
- margin-top: $space_xs / 2;
127
+ margin-top: math.div($space_xs, 2);
126
128
  }
127
129
 
128
130
  [class*="dropdown_trigger_wrapper"] {
@@ -146,7 +148,7 @@
146
148
  &[class*="subtle"] {
147
149
  .dropdown_wrapper {
148
150
  .pb_dropdown_container {
149
-
151
+
150
152
  [class*="pb_dropdown_option"]:first-child {
151
153
  margin-top: $space_xs;
152
154
  }
@@ -161,7 +163,7 @@
161
163
  border-radius: $border_radius_md;
162
164
  border-bottom: none;
163
165
  position: relative;
164
-
166
+
165
167
  &::after {
166
168
  content: "";
167
169
  position: absolute;
@@ -172,20 +174,20 @@
172
174
  background: $border_light;
173
175
  }
174
176
  }
175
-
177
+
176
178
  [class*="pb_dropdown_option"]:last-child::after {
177
- display: none;
179
+ display: none;
178
180
  }
179
181
  }
180
182
  }
181
-
183
+
182
184
  &[class*="separators_hidden"] {
183
185
  .dropdown_wrapper {
184
186
  .pb_dropdown_container {
185
187
  [class*="pb_dropdown_option"]:first-child {
186
188
  margin-top: $space_xs;
187
189
  }
188
-
190
+
189
191
  [class*="pb_dropdown_option"]:last-child {
190
192
  margin-bottom: $space_xs;
191
193
  }
@@ -193,7 +195,7 @@
193
195
  [class*="pb_dropdown_option"] {
194
196
  padding: $space_xxs $space_xs;
195
197
  margin: $space_xxs $space_xs;
196
-
198
+
197
199
  &::after {
198
200
  height: 0px;
199
201
  }
@@ -1,5 +1,5 @@
1
1
  import React, { useEffect, useCallback, useRef } from 'react'
2
- import { useDropzone, DropzoneInputProps, DropzoneRootProps } from 'react-dropzone'
2
+ import { useDropzone, DropzoneInputProps, DropzoneRootProps, FileRejection } from 'react-dropzone'
3
3
  import classnames from 'classnames'
4
4
 
5
5
  import { buildCss, buildDataProps, noop, buildHtmlProps } from '../utilities/props'
@@ -9,8 +9,10 @@ import type { Callback } from '../types'
9
9
  import Body from '../pb_body/_body'
10
10
  import Card from '../pb_card/_card'
11
11
 
12
+ import { isEmpty } from '../utilities/object'
13
+
12
14
  type FileUploadProps = {
13
- accept?: string[],
15
+ accept?: Record<string, string[]>,
14
16
  className?: string,
15
17
  customMessage?: string,
16
18
  dark?: boolean,
@@ -19,7 +21,7 @@ type FileUploadProps = {
19
21
  acceptedFilesDescription?: string,
20
22
  maxSize?: number,
21
23
  onFilesAccepted: Callback<File, File>,
22
- onFilesRejected: (error: string, files: File[]) => void,
24
+ onFilesRejected: (error: string, files: readonly FileRejection[]) => void,
23
25
  }
24
26
 
25
27
  const getFormattedFileSize = (fileSize: number): string => {
@@ -28,7 +30,7 @@ const getFormattedFileSize = (fileSize: number): string => {
28
30
 
29
31
  const FileUpload = (props: FileUploadProps): React.ReactElement => {
30
32
  const {
31
- accept = null,
33
+ accept = {},
32
34
  acceptedFilesDescription = '',
33
35
  className,
34
36
  customMessage,
@@ -48,30 +50,37 @@ const FileUpload = (props: FileUploadProps): React.ReactElement => {
48
50
  getRootProps: () => DropzoneRootProps & any;
49
51
  getInputProps: () => DropzoneInputProps & any;
50
52
  isDragActive: boolean;
51
- rejectedFiles: File[];
53
+ fileRejections: readonly FileRejection[];
52
54
  }
53
55
 
54
- const { getRootProps, getInputProps, isDragActive, rejectedFiles }: DropZoneProps = useDropzone({
56
+ const { getRootProps, getInputProps, isDragActive, fileRejections }: DropZoneProps = useDropzone({
55
57
  accept,
56
58
  maxSize,
57
59
  onDrop,
58
60
  })
59
61
 
60
- const prevRejected = useRef<File[] | null>(null);
62
+ const prevRejected = useRef<readonly FileRejection[] | null>(null);
61
63
 
62
- const maxFileSizeText = `Max file size is ${getFormattedFileSize(maxSize)}.`
64
+ let maxFileSizeText = ''
65
+ if (maxSize !== undefined) {
66
+ maxFileSizeText = `Max file size is ${getFormattedFileSize(maxSize)}.`
67
+ }
63
68
 
64
69
  useEffect(() => {
65
- if (rejectedFiles === prevRejected.current) return
66
- const isFileTooLarge = maxSize && rejectedFiles.length > 0 && rejectedFiles[0].size > maxSize;
70
+ if (fileRejections === prevRejected.current) return
71
+ const isFileTooLarge = maxSize && fileRejections.length > 0 && fileRejections[0].file.size > maxSize;
67
72
  if (isFileTooLarge) {
68
- onFilesRejected(`File size is too large! ${maxFileSizeText}`, rejectedFiles)
73
+ onFilesRejected(`File size is too large! ${maxFileSizeText}`, fileRejections)
69
74
  }
70
- prevRejected.current = rejectedFiles
71
- }, [maxFileSizeText, maxSize, onFilesRejected, rejectedFiles])
75
+ prevRejected.current = fileRejections
76
+ }, [maxFileSizeText, maxSize, onFilesRejected, fileRejections])
72
77
 
73
78
  const acceptedFileTypes = () => {
74
- return accept.map((fileType) => {
79
+ if (!accept) {
80
+ return []
81
+ }
82
+
83
+ return Object.keys(accept).map((fileType) => {
75
84
  if (fileType.startsWith('image/')) {
76
85
  return fileType.replace('image/', ' ')
77
86
  } else {
@@ -86,7 +95,7 @@ const FileUpload = (props: FileUploadProps): React.ReactElement => {
86
95
  const getDescription = () => {
87
96
  return customMessage
88
97
  ? customMessage
89
- : `Choose a file or drag it here.${accept === null ? '' : ` The accepted file types are: ${acceptedFilesDescription || acceptedFileTypes()}.`}${maxSize ? ` ${maxFileSizeText}` : ''}`;
98
+ : `Choose a file or drag it here.${isEmpty(accept) ? '' : ` The accepted file types are: ${acceptedFilesDescription || acceptedFileTypes()}.`}${maxSize ? ` ${maxFileSizeText}` : ''}`;
90
99
  }
91
100
 
92
101
  return (
@@ -28,7 +28,9 @@ const FileUploadAccept = (props) => {
28
28
  {...props}
29
29
  />
30
30
  <FileUpload
31
- accept={['image/svg+xml']}
31
+ accept={{
32
+ "image/svg+xml": [".svg", ".xml"],
33
+ }}
32
34
  onFilesAccepted={handleOnFilesAccepted}
33
35
  {...props}
34
36
  />
@@ -25,7 +25,10 @@ const FileUploadCustomDescription = (props) => {
25
25
  {...props}
26
26
  />
27
27
  <FileUpload
28
- accept={['application/pdf','application/vnd.openxmlformats-officedocument.spreadsheetml.sheet']}
28
+ accept={{
29
+ "application/pdf": [".pdf"],
30
+ "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": [".xlsx"],
31
+ }}
29
32
  acceptedFilesDescription="Adobe (.pdf) and Microsoft (.xslx)"
30
33
  onFilesAccepted={handleOnFilesAccepted}
31
34
  {...props}
@@ -18,7 +18,7 @@ const AcceptedFilesList = ({ files }) => (
18
18
  const RejectedFilesList = ({ files }) => (
19
19
  <List>
20
20
  {files.map((file) => (
21
- <ListItem key={file.name}><Body color="error">{`${file.name} (file too large)`}</Body></ListItem>
21
+ <ListItem key={file.file.name}><Body color="error">{`${file.file.name} (file too large)`}</Body></ListItem>
22
22
  ))}
23
23
  </List>
24
24
  )
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/spacing";
2
4
  @import "../tokens/colors";
3
5
  @import "../tokens/opacity";
@@ -14,9 +16,9 @@ $form_pill_colors: map-merge($status_color_text, map-merge($data_colors, $produc
14
16
  display: inline-flex;
15
17
  justify-content: center;
16
18
  align-items: center;
17
- padding: 0 $space-md/2;
19
+ padding: 0 math.div($space-md, 2);
18
20
  height: $pb_form_pill_height;
19
- border-radius: $pb_form_pill_height/2;
21
+ border-radius: math.div($pb_form_pill_height, 2);
20
22
  margin-bottom: 2px;
21
23
  margin-top: 2px;
22
24
  cursor: pointer;
@@ -142,7 +144,7 @@ $form_pill_colors: map-merge($status_color_text, map-merge($data_colors, $produc
142
144
  height: 12px !important;
143
145
  width: 12px !important;
144
146
  padding-right: $space_xs;
145
- + .pb_form_pill_text, + .pb_form_pill_tag,
147
+ + .pb_form_pill_text, + .pb_form_pill_tag,
146
148
  + .pb_tooltip_kit .pb_form_pill_text, + .pb_tooltip_kit .pb_form_pill_tag,
147
149
  + div .pb_form_pill_text, + div .pb_form_pill_tag {
148
150
  padding-left: 0;
@@ -171,7 +173,7 @@ $form_pill_colors: map-merge($status_color_text, map-merge($data_colors, $produc
171
173
  }
172
174
  .pb_form_pill_icon {
173
175
  padding-right: $space_xxs;
174
- + .pb_form_pill_text, + .pb_form_pill_tag,
176
+ + .pb_form_pill_text, + .pb_form_pill_tag,
175
177
  + .pb_tooltip_kit .pb_form_pill_text, + .pb_tooltip_kit .pb_form_pill_tag,
176
178
  + div .pb_form_pill_text, + div .pb_form_pill_tag {
177
179
  padding-left: 0;
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/border_radius";
2
4
  @import "../tokens/colors";
3
5
  @import "../tokens/typography";
@@ -44,7 +46,7 @@ $pb_icon_circle_sizes: (
44
46
  &[class*=_size_#{$name}] {
45
47
  width: $size;
46
48
  height: $size;
47
- border-radius: $size/2;
49
+ border-radius: math.div($size, 2);
48
50
  background: $silver;
49
51
  color: $text_lt_light;
50
52
  font-size: if($name == "xxs", $size - 6px, $size * 0.38);
@@ -1,7 +1,9 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/spacing";
2
4
 
3
5
  [class^=pb_label_value_kit] {
4
6
  [class^=pb_caption_kit] {
5
- margin-bottom: $space-xs/1.5;
7
+ margin-bottom: math.div($space-xs, 1.5);
6
8
  }
7
- }
9
+ }
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/spacing";
2
4
 
3
5
  @mixin pb_message {
@@ -17,7 +19,7 @@
17
19
  }
18
20
 
19
21
  .message_text {
20
- margin: 0 0 $space-xs/2;
22
+ margin: 0 0 math.div($space-xs, 2);
21
23
  }
22
24
 
23
25
  .message_title {
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/colors";
2
4
  @import "../utilities/colors";
3
5
  @import "../tokens/opacity";
@@ -18,7 +20,7 @@ $pb_multiple_users_size_xxs: map-get($avatar-sizes, "xxs");
18
20
  justify-content: center;
19
21
  width: $pb_multiple_users_size;
20
22
  height: $pb_multiple_users_size;
21
- border-radius: $pb_multiple_users_size / 2 + 2;
23
+ border-radius: math.div($pb_multiple_users_size, 2) + 2;
22
24
  background: tint($primary, 90%);
23
25
  border: $pb_multiple_users_border_size solid $white;
24
26
  color: $primary;
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/colors";
2
4
  @import "../tokens/spacing";
3
5
  @import "../tokens/screen_sizes";
@@ -21,14 +23,14 @@
21
23
  }
22
24
 
23
25
  .passphrase-label {
24
- margin-right: $space_xs / 2;
26
+ margin-right: math.div($space_xs, 2);
25
27
  }
26
28
 
27
29
  .passphrase-text-input-wrapper {
28
30
  position: relative;
29
31
 
30
32
  .pb_text_input_kit_label {
31
- margin-bottom: $space_xs / 2;
33
+ margin-bottom: math.div($space_xs, 2);
32
34
  }
33
35
 
34
36
  .passphrase-text-input input {
@@ -57,7 +59,7 @@
57
59
  }
58
60
 
59
61
  .pb_progress_simple_wrapper, .pb_progress_simple_wrapper_dark {
60
- margin-bottom: $space_xs/2;
62
+ margin-bottom: math.div($space_xs, 2);
61
63
 
62
64
  &.progress-empty-input {
63
65
  visibility: hidden;
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "./intlTelInput";
2
4
  @import "../tokens/colors";
3
5
 
@@ -39,7 +41,7 @@ $flag-min-resolution: 192dpi;
39
41
  color: $charcoal;
40
42
  }
41
43
 
42
- // iti-spacer-horizontal's default is 8px, or $space_xs
44
+ // iti-spacer-horizontal's default is 8px, or $space_xs
43
45
  .iti__country-list .iti__flag, .iti__country-name {
44
46
  margin-right: $space_xs;
45
47
  }
@@ -73,7 +75,7 @@ $flag-min-resolution: 192dpi;
73
75
  }
74
76
 
75
77
  .iti__divider {
76
- border-bottom: 1px solid $border_light !important;
78
+ border-bottom: 1px solid $border_light !important;
77
79
  }
78
80
 
79
81
  .iti__selected-country-primary {
@@ -93,7 +95,7 @@ $flag-min-resolution: 192dpi;
93
95
  justify-content: center;
94
96
  align-items: center;
95
97
  border-width: 0;
96
- border-radius: $space_xxs;
98
+ border-radius: $space_xxs;
97
99
 
98
100
  &[aria-expanded="true"] {
99
101
  color: $primary_action;
@@ -163,7 +165,7 @@ $flag-min-resolution: 192dpi;
163
165
  }
164
166
 
165
167
  .iti__arrow.iti__arrow--up::before {
166
- transform: rotate(-($transform-rotate-deg/3));
168
+ transform: rotate(-(math.div($transform-rotate-deg, 3)));
167
169
  top: $space_xs + 4px;
168
170
  color: $primary_action;
169
171
  }
@@ -196,7 +198,7 @@ $flag-min-resolution: 192dpi;
196
198
  }
197
199
 
198
200
  .iti__dropdown-content {
199
- border-radius: $space_xs;
201
+ border-radius: $space_xs;
200
202
  border: 1px solid $border_light !important;
201
203
  position: absolute;
202
204
  top: 100%;
@@ -225,12 +227,12 @@ $flag-min-resolution: 192dpi;
225
227
  }
226
228
 
227
229
  .iti__dropdown-content {
228
- border-radius: $space_xs;
230
+ border-radius: $space_xs;
229
231
  border: 1px solid $border_dark !important;
230
232
  }
231
233
 
232
234
  .iti__divider {
233
- border-bottom: 1px solid $border_dark !important;
235
+ border-bottom: 1px solid $border_dark !important;
234
236
  }
235
237
 
236
238
  .iti__country-list {
@@ -265,7 +267,7 @@ $flag-min-resolution: 192dpi;
265
267
  color: $white;
266
268
  }
267
269
  }
268
-
270
+
269
271
  @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: $flag-min-resolution) {
270
272
  .iti__flag {
271
273
  background-image: url("https://unpkg.com/intl-tel-input@24.6.0/build/img/flags@2x.png");
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/spacing";
2
4
  @import "../tokens/colors";
3
5
  @import "../tokens/opacity";
@@ -9,9 +11,9 @@ $pb_pill_height: 22px;
9
11
  display: inline-flex;
10
12
  justify-content: center;
11
13
  align-items: center;
12
- padding: 0 $space-sm/1.8;
14
+ padding: 0 math.div($space-sm, 1.8);
13
15
  height: $pb_pill_height;
14
- border-radius: $pb_pill_height/2;
16
+ border-radius: math.div($pb_pill_height, 2);
15
17
  white-space: nowrap;
16
18
 
17
19
  &[class*=lowercase] {
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/colors";
2
4
  @import "../tokens/opacity";
3
5
  @import "../tokens/colors";
@@ -21,7 +23,7 @@ $pb_progress_simple_height: 4px;
21
23
  [class^=pb_progress_simple_kit] {
22
24
  width: 100%;
23
25
  height: $pb_progress_simple_height;
24
- border-radius: $pb_progress_simple_height/2;
26
+ border-radius: math.div($pb_progress_simple_height, 2);
25
27
  background: rgba($primary, $opacity-1);
26
28
  &[class*=_positive] {
27
29
  .progress_simple_value {
@@ -42,7 +44,7 @@ $pb_progress_simple_height: 4px;
42
44
  [class^=progress_simple_value] {
43
45
  width: 0%;
44
46
  height: 100%;
45
- border-radius: $pb_progress_simple_height/2;
47
+ border-radius: math.div($pb_progress_simple_height, 2);
46
48
  background: $primary;
47
49
  }
48
50
 
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../pb_textarea/textarea_mixin";
2
4
  @import "../pb_button/_button_mixins";
3
5
  @import "../tokens/border_radius";
@@ -94,7 +96,7 @@
94
96
  .trix-button--icon {
95
97
  height: $space_lg;
96
98
  width: $space_lg;
97
- margin: $space_xs / 2;
99
+ margin: math.div($space_xs, 2);
98
100
  border-radius: $border_rad_heavier;
99
101
  &::before {
100
102
  background-size: auto;
@@ -104,7 +106,7 @@
104
106
  background: $white;
105
107
  border: 1px solid #E4E8F0;
106
108
  border-bottom: none;
107
- padding: $space_xs / 2;
109
+ padding: math.div($space_xs, 2);
108
110
  border-top-left-radius: $border_rad_heavier;
109
111
  border-top-right-radius: $border_rad_heavier;
110
112
  .trix-button-group {
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../pb_body/body_mixins";
2
4
  @import "../pb_textarea/textarea_mixin";
3
5
  @import "../tokens/titles";
@@ -81,7 +83,7 @@
81
83
  display: block;
82
84
  &.error {
83
85
  [class*=pb_body_kit] {
84
- margin-top: $space_xs / 2;
86
+ margin-top: math.div($space_xs, 2);
85
87
  }
86
88
  > select:first-child {
87
89
  border-color: $error;
@@ -133,7 +135,7 @@
133
135
  box-shadow: none;
134
136
  border-color: transparent;
135
137
  padding: 4px 8px;
136
- padding-right: $space_lg;
138
+ padding-right: $space_lg;
137
139
  border-radius: 4px;
138
140
  option {
139
141
  background-color: $white;
@@ -240,7 +242,7 @@
240
242
  border-color: transparent;
241
243
  background: transparent;
242
244
  padding: 4px 8px;
243
- padding-right: $space_lg;
245
+ padding-right: $space_lg;
244
246
  border-radius: 4px;
245
247
  option {
246
248
  background-color: $white;
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../tokens/animation-curves";
2
4
  @import "../tokens/colors";
3
5
  @import "../tokens/opacity";
@@ -60,7 +62,7 @@ $pb_selectable_paddings: (
60
62
  align-items: center;
61
63
  height: $pb_selectable_card_indicator_size;
62
64
  width: $pb_selectable_card_indicator_size;
63
- border-radius: $pb_selectable_card_indicator_size/2 + $pb_selectable_card_border/2;
65
+ border-radius: (math.div($pb_selectable_card_indicator_size, 2)) + (math.div($pb_selectable_card_border, 2));
64
66
  border-width: $pb_selectable_card_border;
65
67
  border-style: solid;
66
68
  border-color: $white;
@@ -69,8 +71,8 @@ $pb_selectable_paddings: (
69
71
  font-size: $font_smaller;
70
72
  text-align: center;
71
73
  position: absolute;
72
- top: -($pb_selectable_card_indicator_size/2);
73
- right: -($pb_selectable_card_indicator_size/2);
74
+ top: -(math.div($pb_selectable_card_indicator_size, 2));
75
+ right: -(math.div($pb_selectable_card_indicator_size, 2));
74
76
  opacity: 0;
75
77
  }
76
78
  }
@@ -69,6 +69,7 @@ const Table = (props: TableProps): React.ReactElement => {
69
69
  const outerPaddingCss = outerPadding ? `outer_padding_${spaceCssName}${outerPadding}` : ''
70
70
  const isTableTag = tag === 'table'
71
71
  const dynamicInlineProps = globalInlineProps(props)
72
+ const stickyRightColumnReversed = stickyRightColumn.reverse()
72
73
 
73
74
  const classNames = classnames(
74
75
  'pb_table',
@@ -148,7 +149,7 @@ const Table = (props: TableProps): React.ReactElement => {
148
149
  if (!stickyRightColumn.length) return;
149
150
  let accumulatedWidth = 0;
150
151
 
151
- stickyRightColumn.reverse().forEach((colId, index) => {
152
+ stickyRightColumnReversed.forEach((colId, index) => {
152
153
  const isLastColumn = index === stickyRightColumn.length - 1;
153
154
  const header = document.querySelector(`th[id="${colId}"]`);
154
155
  const cells = document.querySelectorAll(`td[id="${colId}"]`);
@@ -186,6 +187,12 @@ const Table = (props: TableProps): React.ReactElement => {
186
187
  setTimeout(() => {
187
188
  handleStickyRightColumns();
188
189
  }, 10);
190
+
191
+ window.addEventListener('resize', handleStickyRightColumns);
192
+
193
+ return () => {
194
+ window.removeEventListener('resize', handleStickyRightColumns);
195
+ };
189
196
  }, [stickyRightColumn]);
190
197
 
191
198
  useEffect(() => {
@@ -35,6 +35,8 @@ examples:
35
35
  - table_lg: Large
36
36
  - table_sticky: Sticky Header
37
37
  - table_sticky_left_columns: Sticky Left Column
38
+ - table_sticky_right_columns: Sticky Right Column
39
+ - table_sticky_columns: Sticky Left and Right Columns
38
40
  - table_alignment_row: Row Alignment
39
41
  - table_alignment_column: Cell Alignment
40
42
  - table_alignment_shift_row: Row Shift
@@ -26,6 +26,8 @@ export { default as TableWithSubcomponents } from './_table_with_subcomponents.j
26
26
  export { default as TableWithSubcomponentsAsDivs } from './_table_with_subcomponents_as_divs.jsx'
27
27
  export { default as TableOuterPadding } from './_table_outer_padding.jsx'
28
28
  export { default as TableStickyLeftColumns } from './_table_sticky_left_columns.jsx'
29
+ export { default as TableStickyRightColumns } from './_table_sticky_right_columns.jsx'
30
+ export { default as TableStickyColumns } from './_table_sticky_columns.jsx'
29
31
  export { default as TableWithCollapsible } from './_table_with_collapsible.jsx'
30
32
  export { default as TableWithCollapsibleWithCustomContent } from './_table_with_collapsible_with_custom_content.jsx'
31
33
  export { default as TableWithCollapsibleWithNestedTable } from './_table_with_collapsible_with_nested_table.jsx'
@@ -1,3 +1,5 @@
1
+ @use "sass:math";
2
+
1
3
  @import "../pb_textarea/textarea_mixin";
2
4
  @import "../tokens/titles";
3
5
  @import "../tokens/colors";
@@ -100,7 +102,7 @@
100
102
  &.error {
101
103
  .text_input_wrapper {
102
104
  [class*="pb_body_kit"] {
103
- margin-top: $space_xs / 2;
105
+ margin-top: math.div($space_xs, 2);
104
106
  }
105
107
  input,
106
108
  .text_input {
@@ -16,6 +16,8 @@ const TextInputMask = (props) => {
16
16
  zipCode: '',
17
17
  postalCode: '',
18
18
  ssn: '',
19
+ creditCard: '',
20
+ cvv: ''
19
21
  })
20
22
 
21
23
  const handleOnChangeFormField = ({ target }) => {
@@ -57,6 +59,22 @@ const TextInputMask = (props) => {
57
59
  value={formFields.ssn}
58
60
  {...props}
59
61
  />
62
+ <TextInput
63
+ label="Credit Card"
64
+ mask="creditCard"
65
+ name="creditCard"
66
+ onChange={handleOnChangeFormField}
67
+ value={formFields.creditCard}
68
+ {...props}
69
+ />
70
+ <TextInput
71
+ label="CVV"
72
+ mask="cvv"
73
+ name="cvv"
74
+ onChange={handleOnChangeFormField}
75
+ value={formFields.cvv}
76
+ {...props}
77
+ />
60
78
 
61
79
  <br />
62
80
  <br />
@@ -6,7 +6,7 @@ type InputMask = {
6
6
  }
7
7
 
8
8
  type InputMaskDictionary = {
9
- [key in 'currency' | 'zipCode' | 'postalCode' | 'ssn']: InputMask
9
+ [key in 'currency' | 'zipCode' | 'postalCode' | 'ssn' | 'creditCard' | 'cvv']: InputMask
10
10
  }
11
11
 
12
12
  const formatCurrencyDefaultValue = (value: string): string => {
@@ -58,6 +58,15 @@ const formatSSN = (value: string): string => {
58
58
  .replace(/(\d{3})(?=\d)/, '$1-')
59
59
  }
60
60
 
61
+ const formatCreditCard = (value: string): string => {
62
+ const cleaned = value.replace(/\D/g, '').slice(0, 16)
63
+ return cleaned.replace(/(\d{4})(?=\d)/g, '$1 ')
64
+ }
65
+
66
+ const formatCVV = (value: string): string => {
67
+ return value.replace(/\D/g, '').slice(0, 4)
68
+ }
69
+
61
70
  export const INPUTMASKS: InputMaskDictionary = {
62
71
  currency: {
63
72
  format: formatCurrency,
@@ -84,4 +93,16 @@ export const INPUTMASKS: InputMaskDictionary = {
84
93
  pattern: '\\d{3}-\\d{2}-\\d{4}',
85
94
  placeholder: '123-45-6789',
86
95
  },
96
+ creditCard: {
97
+ format: formatCreditCard,
98
+ formatDefaultValue: formatCreditCard,
99
+ pattern: '\\d{4} \\d{4} \\d{4} \\d{4}',
100
+ placeholder: '1234 5678 9012 3456',
101
+ },
102
+ cvv: {
103
+ format: formatCVV,
104
+ formatDefaultValue: formatCVV,
105
+ pattern: '\\d{3,4}',
106
+ placeholder: '123',
107
+ },
87
108
  }