playbook_ui 13.30.0 → 13.31.0.pre.alpha.PLAY10863202

Sign up to get free protection for your applications and to get access to all the features.
Files changed (127) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.html.erb +59 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.md +6 -0
  4. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +3 -2
  5. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +4 -4
  6. data/app/pb_kits/playbook/pb_background/background.html.erb +2 -11
  7. data/app/pb_kits/playbook/pb_body/body.html.erb +1 -6
  8. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +1 -6
  9. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +1 -6
  10. data/app/pb_kits/playbook/pb_caption/caption.html.erb +1 -6
  11. data/app/pb_kits/playbook/pb_card/_card.tsx +4 -3
  12. data/app/pb_kits/playbook/pb_card/card.html.erb +1 -7
  13. data/app/pb_kits/playbook/pb_collapsible/index.js +6 -1
  14. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_default_swift.md +33 -0
  15. data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_props_swift.md +18 -0
  16. data/app/pb_kits/playbook/pb_date_time_stacked/docs/example.yml +6 -1
  17. data/app/pb_kits/playbook/pb_date_year_stacked/docs/_date_year_stacked_default.jsx +4 -1
  18. data/app/pb_kits/playbook/pb_detail/detail.html.erb +1 -6
  19. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +1 -6
  20. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +1 -6
  21. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +2 -5
  22. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +1 -6
  23. data/app/pb_kits/playbook/pb_draggable/_draggable.scss +2 -4
  24. data/app/pb_kits/playbook/pb_draggable/context/index.tsx +84 -50
  25. data/app/pb_kits/playbook/pb_draggable/context/types.ts +31 -0
  26. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_default.jsx +15 -19
  27. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_default.md +5 -3
  28. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_multiple_containers.jsx +5 -1
  29. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_cards.jsx +11 -4
  30. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_cards.md +8 -2
  31. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list.jsx +2 -2
  32. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list.md +5 -1
  33. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list.jsx +6 -4
  34. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list.md +5 -0
  35. data/app/pb_kits/playbook/pb_draggable/draggable.test.jsx +142 -15
  36. data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableItem.tsx +6 -5
  37. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +18 -0
  38. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +228 -218
  39. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +9 -0
  40. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.jsx +34 -0
  41. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +2 -0
  42. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +2 -1
  43. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +16 -12
  44. data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +9 -0
  45. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +17 -2
  46. data/app/pb_kits/playbook/pb_dropdown/index.js +33 -4
  47. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.tsx +9 -3
  48. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_custom_icon.html.erb +32 -0
  49. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_custom_icon.jsx +48 -0
  50. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/example.yml +2 -0
  51. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/index.js +1 -0
  52. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.rb +16 -11
  53. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.test.js +72 -0
  54. data/app/pb_kits/playbook/pb_flex/flex.html.erb +1 -5
  55. data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +9 -0
  56. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +1 -6
  57. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +1 -5
  58. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +1 -5
  59. data/app/pb_kits/playbook/pb_icon/_icon.tsx +37 -6
  60. data/app/pb_kits/playbook/pb_icon/docs/_icon_default.html.erb +1 -1
  61. data/app/pb_kits/playbook/pb_icon/docs/_icon_default.jsx +2 -3
  62. data/app/pb_kits/playbook/pb_icon/icon.rb +21 -1
  63. data/app/pb_kits/playbook/pb_icon/icon_aliases.json +39 -0
  64. data/app/pb_kits/playbook/pb_list/_list.tsx +4 -4
  65. data/app/pb_kits/playbook/pb_list/_list_item.tsx +7 -3
  66. data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav.html.erb +1 -1
  67. data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav.jsx +1 -0
  68. data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav.md +3 -1
  69. data/app/pb_kits/playbook/pb_nav/item.html.erb +1 -1
  70. data/app/pb_kits/playbook/pb_nav/item.rb +1 -0
  71. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_default.html.erb +24 -0
  72. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_default.md +4 -4
  73. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_multi_directional.html.erb +11 -0
  74. data/app/pb_kits/playbook/pb_overlay/docs/example.yml +4 -0
  75. data/app/pb_kits/playbook/pb_overlay/overlay.html.erb +27 -0
  76. data/app/pb_kits/playbook/pb_overlay/overlay.rb +110 -0
  77. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +8 -23
  78. data/app/pb_kits/playbook/pb_selectable_list/_item.tsx +7 -3
  79. data/app/pb_kits/playbook/pb_selectable_list/_selectable_list.tsx +3 -3
  80. data/app/pb_kits/playbook/pb_table/_table.tsx +1 -1
  81. data/app/pb_kits/playbook/pb_table/index.ts +4 -4
  82. data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +1 -1
  83. data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +1 -1
  84. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +1 -1
  85. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +1 -1
  86. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +1 -1
  87. data/app/pb_kits/playbook/pb_table/table.test.js +2 -0
  88. data/app/pb_kits/playbook/pb_table/table_header.html.erb +16 -2
  89. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +1 -1
  90. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.jsx +1 -1
  91. data/app/pb_kits/playbook/pb_textarea/_textarea.tsx +45 -27
  92. data/app/pb_kits/playbook/pb_textarea/index.tsx +3 -3
  93. data/app/pb_kits/playbook/pb_time/_time.tsx +3 -3
  94. data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.tsx +1 -1
  95. data/app/pb_kits/playbook/pb_timeline/_item.tsx +12 -11
  96. data/app/pb_kits/playbook/pb_timeline/_timeline.tsx +9 -7
  97. data/app/pb_kits/playbook/pb_title/_title.tsx +2 -1
  98. data/app/pb_kits/playbook/pb_title_detail/_title_detail.tsx +10 -10
  99. data/app/pb_kits/playbook/pb_toggle/_toggle.tsx +1 -1
  100. data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +3 -3
  101. data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.tsx +3 -4
  102. data/app/pb_kits/playbook/pb_treemap_chart/treemapChart.test.js +2 -0
  103. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +5 -4
  104. data/app/pb_kits/playbook/pb_typeahead/components/ClearIndicator.tsx +12 -4
  105. data/app/pb_kits/playbook/pb_typeahead/components/Control.tsx +11 -7
  106. data/app/pb_kits/playbook/pb_typeahead/components/IndicatorsContainer.tsx +8 -3
  107. data/app/pb_kits/playbook/pb_typeahead/components/MenuList.tsx +6 -1
  108. data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +26 -21
  109. data/app/pb_kits/playbook/pb_typeahead/components/Option.tsx +21 -6
  110. data/app/pb_kits/playbook/pb_typeahead/components/Placeholder.tsx +13 -6
  111. data/app/pb_kits/playbook/pb_typeahead/components/ValueContainer.tsx +7 -3
  112. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_menu_list.jsx +2 -0
  113. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +7 -1
  114. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async.jsx +2 -2
  115. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_custom_options.jsx +1 -1
  116. data/app/pb_kits/playbook/pb_typeahead/index.ts +33 -33
  117. data/app/pb_kits/playbook/pb_user/_user.tsx +1 -1
  118. data/app/pb_kits/playbook/pb_user_badge/_user_badge.tsx +6 -6
  119. data/app/pb_kits/playbook/pb_user_badge/badges/million-dollar.tsx +236 -235
  120. data/app/pb_kits/playbook/pb_user_badge/badges/veteran.tsx +1 -1
  121. data/app/pb_kits/playbook/pb_walkthrough/_walkthrough.tsx +68 -63
  122. data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.tsx +2 -2
  123. data/app/pb_kits/playbook/utilities/globalProps.ts +1 -0
  124. data/dist/menu.yml +566 -472
  125. data/dist/playbook-rails.js +7 -7
  126. data/lib/playbook/version.rb +2 -2
  127. metadata +21 -5
@@ -4,24 +4,24 @@ import { debounce } from 'lodash'
4
4
  export default class PbTypeahead extends PbEnhancedElement {
5
5
  _searchInput: HTMLInputElement
6
6
  _resultsElement: HTMLElement
7
- _debouncedSearch: Function
7
+ _debouncedSearch: () => void
8
8
  _resultsLoadingIndicator: HTMLElement
9
9
  _resultOptionTemplate: HTMLElement
10
10
  _resultsOptionCache: Map<string, Array<DocumentFragment>>
11
11
  _searchContext: string
12
12
 
13
- static get selector() {
13
+ static get selector(): string {
14
14
  return '[data-pb-typeahead-kit]'
15
15
  }
16
16
 
17
- connect() {
17
+ connect(): void {
18
18
  this.element.addEventListener('keydown', (event: KeyboardEvent) => this.handleKeydown(event))
19
- this.searchInput.addEventListener('focus', () => this.debouncedSearch())
20
- this.searchInput.addEventListener('input', () => this.debouncedSearch())
19
+ this.searchInput.addEventListener('focus', () => this.debouncedSearch)
20
+ this.searchInput.addEventListener('input', () => this.debouncedSearch)
21
21
  this.resultsElement.addEventListener('click', (event: MouseEvent) => this.optionSelected(event))
22
22
  }
23
23
 
24
- handleKeydown(event: KeyboardEvent) {
24
+ handleKeydown(event: KeyboardEvent): void {
25
25
  if (event.key === 'ArrowUp') {
26
26
  event.preventDefault()
27
27
  this.focusPreviousOption()
@@ -31,7 +31,7 @@ export default class PbTypeahead extends PbEnhancedElement {
31
31
  }
32
32
  }
33
33
 
34
- search() {
34
+ search(): void {
35
35
  if (this.searchTerm.length < parseInt(this.searchTermMinimumLength)) return this.clearResults()
36
36
 
37
37
  this.toggleResultsLoadingIndicator(true)
@@ -49,7 +49,7 @@ export default class PbTypeahead extends PbEnhancedElement {
49
49
  this.element.dispatchEvent(new CustomEvent('pb-typeahead-kit-search', { bubbles: true, detail: search }))
50
50
  }
51
51
 
52
- resultsCacheUpdate(searchTerm: string, searchContext: string, results: Array<DocumentFragment>) {
52
+ resultsCacheUpdate(searchTerm: string, searchContext: string, results: Array<DocumentFragment>): void {
53
53
  const searchTermAndContext = this.cacheKeyFor(searchTerm, searchContext)
54
54
  if (this.resultsOptionCache.has(searchTermAndContext)) this.resultsOptionCache.delete(searchTermAndContext)
55
55
  if (this.resultsOptionCache.size > 32) this.resultsOptionCache.delete(this.resultsOptionCache.keys().next().value)
@@ -58,18 +58,18 @@ export default class PbTypeahead extends PbEnhancedElement {
58
58
  this.showResults()
59
59
  }
60
60
 
61
- resultsCacheClear() {
61
+ resultsCacheClear(): void {
62
62
  this.resultsOptionCache.clear()
63
63
  }
64
64
 
65
- get debouncedSearch() {
65
+ get debouncedSearch(): void {
66
66
  return this._debouncedSearch = (
67
67
  this._debouncedSearch ||
68
68
  debounce(this.search, parseInt(this.searchDebounceTimeout)).bind(this)
69
69
  )
70
70
  }
71
71
 
72
- showResults() {
72
+ showResults(): void {
73
73
  if (!this.resultsOptionCache.has(this.searchTermAndContext)) return
74
74
 
75
75
  this.toggleResultsLoadingIndicator(false)
@@ -82,7 +82,7 @@ export default class PbTypeahead extends PbEnhancedElement {
82
82
  }
83
83
  }
84
84
 
85
- optionSelected(event: MouseEvent) {
85
+ optionSelected(event: MouseEvent): void {
86
86
  const resultOption = (event.target as Element).closest('[data-result-option-item]')
87
87
  if (!resultOption) return
88
88
 
@@ -93,17 +93,17 @@ export default class PbTypeahead extends PbEnhancedElement {
93
93
  this.element.dispatchEvent(new CustomEvent('pb-typeahead-kit-result-option-selected', { bubbles: true, detail: { selected: resultOption, typeahead: this } }))
94
94
  }
95
95
 
96
- clearResults() {
96
+ clearResults(): void {
97
97
  this.resultsElement.innerHTML = ''
98
98
  }
99
99
 
100
- newResultOption(content: DocumentFragment) {
100
+ newResultOption(content: DocumentFragment | Node): Element {
101
101
  const resultOption = (this.resultOptionTemplate as HTMLTemplateElement).content.cloneNode(true) as Element
102
102
  resultOption.querySelector('slot[name="content"]').replaceWith(content)
103
103
  return resultOption
104
104
  }
105
105
 
106
- focusPreviousOption() {
106
+ focusPreviousOption(): void {
107
107
  const currentIndex = this.resultOptionItems.indexOf(this.currentSelectedResultOptionItem)
108
108
  const previousIndex = currentIndex - 1
109
109
  const previousOptionItem = (
@@ -113,7 +113,7 @@ export default class PbTypeahead extends PbEnhancedElement {
113
113
  (previousOptionItem as HTMLElement).focus()
114
114
  }
115
115
 
116
- focusNextOption() {
116
+ focusNextOption(): void {
117
117
  const currentIndex = this.resultOptionItems.indexOf(this.currentSelectedResultOptionItem)
118
118
  const nextIndex = currentIndex + 1
119
119
  const nextOptionItem = (
@@ -123,23 +123,23 @@ export default class PbTypeahead extends PbEnhancedElement {
123
123
  (nextOptionItem as HTMLElement).focus()
124
124
  }
125
125
 
126
- get resultOptionItems() {
126
+ get resultOptionItems(): HTMLElement[] {
127
127
  return Array.from(this.resultsElement.querySelectorAll('[data-result-option-item]'))
128
128
  }
129
129
 
130
- get currentSelectedResultOptionItem() {
130
+ get currentSelectedResultOptionItem(): HTMLElement | null {
131
131
  return document.activeElement.closest('[data-result-option-item]')
132
132
  }
133
133
 
134
- get searchInput() {
134
+ get searchInput(): HTMLInputElement | null {
135
135
  return this._searchInput = (this._searchInput || this.element.querySelector('input[type="search"]'))
136
136
  }
137
137
 
138
- get searchTerm() {
138
+ get searchTerm(): string {
139
139
  return this.searchInput.value
140
140
  }
141
141
 
142
- get searchContext() {
142
+ get searchContext(): string | null {
143
143
  if (this._searchContext) return this._searchContext
144
144
 
145
145
  const selector = (this.element as HTMLElement).dataset.searchContextValueSelector
@@ -151,57 +151,57 @@ export default class PbTypeahead extends PbEnhancedElement {
151
151
  return null
152
152
  }
153
153
 
154
- set searchContext(value) {
154
+ set searchContext(value: string) {
155
155
  this._searchContext = value
156
156
  }
157
157
 
158
- get searchTermAndContext() {
158
+ get searchTermAndContext(): string {
159
159
  return this.cacheKeyFor(this.searchTerm, this.searchContext)
160
160
  }
161
161
 
162
- cacheKeyFor(searchTerm: string, searchContext: string) {
162
+ cacheKeyFor(searchTerm: string, searchContext: string): string {
163
163
  return [searchTerm, JSON.stringify(searchContext)].join()
164
164
  }
165
165
 
166
- searchInputClear() {
166
+ searchInputClear(): void {
167
167
  this.searchInput.value = ''
168
168
  }
169
169
 
170
- get searchTermMinimumLength() {
170
+ get searchTermMinimumLength(): string | undefined {
171
171
  return (this.element as HTMLElement).dataset.pbTypeaheadKitSearchTermMinimumLength
172
172
  }
173
173
 
174
- get searchDebounceTimeout() {
174
+ get searchDebounceTimeout(): string | undefined {
175
175
  return (this.element as HTMLElement).dataset.pbTypeaheadKitSearchDebounceTimeout
176
176
  }
177
177
 
178
- get resultsElement() {
178
+ get resultsElement(): HTMLElement | null {
179
179
  return this._resultsElement = (this._resultsElement || this.element.querySelector('[data-pb-typeahead-kit-results]'))
180
180
  }
181
181
 
182
- get resultOptionTemplate() {
182
+ get resultOptionTemplate(): HTMLElement | null {
183
183
  return this._resultOptionTemplate = (
184
184
  this._resultOptionTemplate ||
185
185
  this.element.querySelector('template[data-pb-typeahead-kit-result-option]')
186
186
  )
187
187
  }
188
188
 
189
- get resultsOptionCache() {
189
+ get resultsOptionCache(): Map<string, Array<DocumentFragment>> {
190
190
  return this._resultsOptionCache = (
191
191
  this._resultsOptionCache ||
192
192
  new Map
193
193
  )
194
194
  }
195
195
 
196
- get resultsLoadingIndicator() {
196
+ get resultsLoadingIndicator(): HTMLElement | null {
197
197
  return this._resultsLoadingIndicator = (
198
198
  this._resultsLoadingIndicator ||
199
199
  this.element.querySelector('[data-pb-typeahead-kit-loading-indicator]')
200
200
  )
201
201
  }
202
202
 
203
- toggleResultsLoadingIndicator(visible: boolean) {
204
- var visibilityProperty = '0'
203
+ toggleResultsLoadingIndicator(visible: boolean): void {
204
+ let visibilityProperty = '0'
205
205
  if (visible) visibilityProperty = '1'
206
206
  this.resultsLoadingIndicator.style.opacity = visibilityProperty
207
207
  }
@@ -26,7 +26,7 @@ type UserProps = {
26
26
  title?: string,
27
27
  } & GlobalProps
28
28
 
29
- const User = (props: UserProps) => {
29
+ const User = (props: UserProps): React.ReactElement => {
30
30
  const {
31
31
  align = 'left',
32
32
  aria = {},
@@ -15,7 +15,7 @@ type UserBadgeProps = {
15
15
  size?: "sm" | "md" | "lg",
16
16
  }
17
17
 
18
- const UserBadge = (props: UserBadgeProps) => {
18
+ const UserBadge = (props: UserBadgeProps): React.ReactElement => {
19
19
  const {
20
20
  aria = {},
21
21
  badge = 'million-dollar',
@@ -38,11 +38,11 @@ const UserBadge = (props: UserBadgeProps) => {
38
38
 
39
39
  return (
40
40
  <div
41
- {...ariaProps}
42
- {...dataProps}
43
- {...htmlProps}
44
- className={classes}
45
- id={id}
41
+ {...ariaProps}
42
+ {...dataProps}
43
+ {...htmlProps}
44
+ className={classes}
45
+ id={id}
46
46
  >
47
47
  <div className="pb_user_badge_wrapper">
48
48
  {image}