playbook_ui_docs 13.32.0.pre.alpha.PBNTR405dropdownformfixesrails3301 → 13.32.0.pre.alpha.PLAY1138iconkitaddcolorprop3268

Sign up to get free protection for your applications and to get access to all the features.
Files changed (32) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.md +0 -4
  3. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +0 -4
  4. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +1 -3
  5. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_example.html.erb +1 -5
  6. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_example.jsx +0 -1
  7. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_size.html.erb +0 -2
  8. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_size.jsx +0 -2
  9. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_tag.html.erb +1 -4
  10. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_tag.jsx +2 -3
  11. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_user.html.erb +0 -2
  12. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_user.jsx +0 -2
  13. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.html.erb +7 -0
  14. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.jsx +46 -0
  15. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.md +1 -0
  16. data/app/pb_kits/playbook/pb_icon/docs/example.yml +2 -0
  17. data/app/pb_kits/playbook/pb_icon/docs/index.js +1 -0
  18. data/app/pb_kits/playbook/pb_nav/docs/example.yml +0 -1
  19. data/app/pb_kits/playbook/pb_star_rating/docs/example.yml +1 -1
  20. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.jsx +1 -1
  21. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_menu_list.jsx +0 -2
  22. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default.html.erb +57 -22
  23. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async.jsx +2 -2
  24. data/dist/playbook-doc.js +9 -9
  25. metadata +5 -9
  26. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.html.erb +0 -10
  27. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_blank_selection.jsx +0 -31
  28. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.html.erb +0 -10
  29. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_value.jsx +0 -31
  30. data/app/pb_kits/playbook/pb_nav/docs/_tab_nav.html.erb +0 -48
  31. data/app/pb_kits/playbook/pb_nav/docs/_tab_nav.md +0 -3
  32. data/app/pb_kits/playbook/pb_star_rating/docs/_star_rating_interactive.html.erb +0 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 9ee442a9f15b539ec0ab29bb4efaaac22f644679be3f03719778bf3b02b8bcf8
4
- data.tar.gz: 3011b3404ce091a1f4aeb669deb4ecd6191f59bf536d3b8577fdf694f7ef709a
3
+ metadata.gz: 0202d59ed4925de375ff662bf89dbc2267e4d2448dccbed8f657f67b07010788
4
+ data.tar.gz: ba326a997028b871950ae3c7c7dbec43191ef6796e5877944c73d4c979158a92
5
5
  SHA512:
6
- metadata.gz: 0e35db9d43b40767e402c5693d27870013ef7b7e456093c4cf9b6bfffcde57457bf861dac81082007eef21edf52c823a0565e7210f79292191ec8a116704e83e
7
- data.tar.gz: d2f09a6b5b8498cb4e378ebdb78236f812c241580fd6a3d046312fde7a608d62a4b8133316b85973f4ef713638fdc52de7c791a33fbf3624af5afd3804635f7c
6
+ metadata.gz: 21d0ffdb91a6b98437c49acc9d8b1b7b225a992d72d448a4cecc9f103013365707c70b5dd1199ef129dfde8f983e8964479597a089d493dc66c8c120a2b5e4bd
7
+ data.tar.gz: 0f88b7bf28a5b21475deffd253ed1e3671ff457e41b903935c067dd503a682250e809b3da56aeffa31e150c8e2710ca44a10d5c597a5d16dcb50959991db9092
@@ -1,6 +1,2 @@
1
1
  The `customOptions` prop provides comprehensive access to additional [Highcharts options](https://api.highcharts.com/highcharts/) that are not explicitly defined as props.
2
2
  It's important to note that certain options may require specific script imports to function properly.
3
-
4
- Note: If you are having trouble getting any Highcharts options to work, please match the formatting of our [staticOptions](https://github.com/powerhome/playbook/blob/master/playbook/app/pb_kits/playbook/pb_bar_graph/_bar_graph.tsx#L85-L141). For example, `yAxis` will need to be wrapped with square brackets.
5
-
6
- You may also need to override any of the [defaults](https://github.com/powerhome/playbook/blob/master/playbook/app/pb_kits/playbook/pb_bar_graph/_bar_graph.tsx#L45-L73) in order to get that options to work.
@@ -8,8 +8,6 @@ examples:
8
8
  - dropdown_with_custom_trigger_rails: Custom Trigger
9
9
  - dropdown_with_custom_padding: Custom Option Padding
10
10
  - dropdown_error: Dropdown with Error
11
- - dropdown_default_value: Default Value
12
- - dropdown_blank_selection: Blank Selection
13
11
 
14
12
  react:
15
13
  - dropdown_default: Default
@@ -20,8 +18,6 @@ examples:
20
18
  - dropdown_with_custom_trigger: Custom Trigger
21
19
  - dropdown_with_custom_padding: Custom Option Padding
22
20
  - dropdown_error: Dropdown with Error
23
- - dropdown_default_value: Default Value
24
- - dropdown_blank_selection: Blank Selection
25
21
  # - dropdown_with_autocomplete: Autocomplete
26
22
  # - dropdown_with_autocomplete_and_custom_display: Autocomplete with Custom Display
27
23
  # - dropdown_with_external_control: useDropdown Hook
@@ -9,6 +9,4 @@ export { default as DropdownWithLabel } from './_dropdown_with_label.jsx'
9
9
  export { default as DropdownWithExternalControl } from './_dropdown_with_external_control.jsx'
10
10
  export { default as DropdownWithHook } from './_dropdown_with_hook.jsx'
11
11
  export { default as DropdownSubcomponentStructure } from './_dropdown_subcomponent_structure.jsx'
12
- export { default as DropdownError } from './_dropdown_error.jsx'
13
- export { default as DropdownDefaultValue } from './_dropdown_default_value.jsx'
14
- export { default as DropdownBlankSelection } from './_dropdown_blank_selection.jsx'
12
+ export { default as DropdownError } from './_dropdown_error.jsx'
@@ -1,5 +1 @@
1
- <%= pb_rails("form_pill", props: {
2
- text_transform: "lowercase" ,
3
- text: "THIS IS A TAG",
4
- tabindex: 0,
5
- }) %>
1
+ <%= pb_rails("form_pill", props: { text_transform: "lowercase" , text: "THIS IS A TAG" }) %>
@@ -6,7 +6,6 @@ const FormPillExample = (props) => {
6
6
  <div>
7
7
  <FormPill
8
8
  onClick={() => alert('Click!')}
9
- tabIndex={0}
10
9
  text="THIS IS A TAG"
11
10
  textTransform="lowercase"
12
11
  {...props}
@@ -2,7 +2,6 @@
2
2
  name: "Anna Black",
3
3
  avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
4
4
  size: "small",
5
- tabindex: 0,
6
5
  }) %>
7
6
 
8
7
  <br />
@@ -11,5 +10,4 @@
11
10
  <%= pb_rails("form_pill", props: {
12
11
  name: "Anna Black",
13
12
  size: "small",
14
- tabindex: 0,
15
13
  }) %>
@@ -9,7 +9,6 @@ const FormPillSize = (props) => {
9
9
  avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
10
10
  name="Anna Black"
11
11
  size="small"
12
- tabIndex={0}
13
12
  {...props}
14
13
  />
15
14
  <br />
@@ -17,7 +16,6 @@ const FormPillSize = (props) => {
17
16
  <FormPill
18
17
  name="Anna Black"
19
18
  size="small"
20
- tabIndex={0}
21
19
  {...props}
22
20
  />
23
21
  </div>
@@ -1,4 +1 @@
1
- <%= pb_rails("form_pill", props: {
2
- text: "this is a tag",
3
- tabindex: 0,
4
- }) %>
1
+ <%= pb_rails("form_pill", props: { text: "this is a tag" }) %>
@@ -6,9 +6,8 @@ const FormPillDefault = (props) => {
6
6
  <div>
7
7
  <FormPill
8
8
  onClick={() => {
9
- alert('Click!')
10
- }}
11
- tabIndex={0}
9
+ alert('Click!')
10
+ }}
12
11
  text="this is a tag"
13
12
  {...props}
14
13
  />
@@ -1,7 +1,6 @@
1
1
  <%= pb_rails("form_pill", props: {
2
2
  name: "Anna Black",
3
3
  avatar_url: "https://randomuser.me/api/portraits/women/44.jpg",
4
- tabindex: 0,
5
4
  }) %>
6
5
 
7
6
  <br />
@@ -9,5 +8,4 @@
9
8
 
10
9
  <%= pb_rails("form_pill", props: {
11
10
  name: "Anna Black",
12
- tabindex: 0,
13
11
  }) %>
@@ -9,7 +9,6 @@ const FormPillDefault = (props) => {
9
9
  avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
10
10
  name="Anna Black"
11
11
  onClick={() => alert('Click!')}
12
- tabIndex={0}
13
12
  {...props}
14
13
  />
15
14
  <br />
@@ -17,7 +16,6 @@ const FormPillDefault = (props) => {
17
16
  <FormPill
18
17
  name="Anna Black"
19
18
  onClick={() => alert('Click!')}
20
- tabIndex={0}
21
19
  {...props}
22
20
  />
23
21
  </div>
@@ -0,0 +1,7 @@
1
+ <%= pb_rails("flex", props: {orientation: "column"}) do %>
2
+ <%= pb_rails("icon", props: { icon: "user", fixed_width: true, color: "primary", size: "2x" }) %>
3
+ <%= pb_rails("icon", props: { icon: "recycle", fixed_width: true, color: "info", size: "2x" }) %>
4
+ <%= pb_rails("icon", props: { icon: "frog", fixed_width: true, color: "data_4", size: "2x" }) %>
5
+ <%= pb_rails("icon", props: { icon: "vial", fixed_width: true, color: "text_lt_lighter", size: "2x" }) %>
6
+ <%= pb_rails("icon", props: { icon: "roofing", fixed_width: true, color: "product_roofing", size: "2x" }) %>
7
+ <% end %>
@@ -0,0 +1,46 @@
1
+ import React from "react"
2
+ import Icon from "../_icon"
3
+
4
+ const IconDefault = (props) => {
5
+ return (
6
+ <div style={{ display: "flex", flexDirection: "column"}}>
7
+ <Icon
8
+ color="primary"
9
+ fixedWidth
10
+ icon="user"
11
+ size="2x"
12
+ {...props}
13
+ />
14
+ <Icon
15
+ color="info"
16
+ fixedWidth
17
+ icon="recycle"
18
+ size="2x"
19
+ {...props}
20
+ />
21
+ <Icon
22
+ color="data_4"
23
+ fixedWidth
24
+ icon="frog"
25
+ size="2x"
26
+ {...props}
27
+ />
28
+ <Icon
29
+ color="text_lt_lighter"
30
+ fixedWidth
31
+ icon="vial"
32
+ size="2x"
33
+ {...props}
34
+ />
35
+ <Icon
36
+ color="roofing"
37
+ fixedWidth
38
+ icon="product-roofing"
39
+ size="2x"
40
+ {...props}
41
+ />
42
+ </div>
43
+ )
44
+ }
45
+
46
+ export default IconDefault
@@ -0,0 +1 @@
1
+ Pass any Playbook <a href="https://playbook.powerapp.cloud/visual_guidelines/colors" target="_blank">color token</a> to the `color` prop to change any icon's color.
@@ -9,6 +9,7 @@ examples:
9
9
  - icon_sizes: Icon Sizes
10
10
  - icon_custom: Icon Custom
11
11
  - icon_fa_kit: Icon with FontAwesome Kit
12
+ - icon_color: Icon Color
12
13
 
13
14
  react:
14
15
  - icon_default: Icon Default
@@ -20,6 +21,7 @@ examples:
20
21
  - icon_sizes: Icon Sizes
21
22
  - icon_custom: Icon Custom
22
23
  - icon_fa_kit: Icon with FontAwesome Kit
24
+ - icon_color: Icon Color
23
25
 
24
26
  swift:
25
27
  - icon_default_swift: Icon Default
@@ -7,3 +7,4 @@ export { default as IconBorder } from './_icon_border.jsx'
7
7
  export { default as IconSizes } from './_icon_sizes.jsx'
8
8
  export { default as IconCustom } from './_icon_custom.jsx'
9
9
  export { default as IconFaKit} from './_icon_fa_kit.jsx'
10
+ export { default as IconColor } from './_icon_color.jsx'
@@ -19,7 +19,6 @@ examples:
19
19
  - block_nav: Block
20
20
  - block_no_title_nav: Without Title
21
21
  - new_tab: Open in a New Tab
22
- - tab_nav: Tab Nav
23
22
 
24
23
  react:
25
24
  - default_nav: Default
@@ -13,4 +13,4 @@ examples:
13
13
  - star_rating_background_options: Background Options
14
14
  - star_rating_hide: Layout Options
15
15
  - star_rating_number_config: Number Config
16
- - star_rating_size_options: Size Options
16
+ - star_rating_size_options: Size Options
@@ -5,12 +5,12 @@ import TextInput from '../../pb_text_input/_text_input'
5
5
  import Title from '../../pb_title/_title'
6
6
 
7
7
  const TextInputDefault = (props) => {
8
- const [firstName, setFirstName] = useState('')
9
8
  const handleOnChangeFirstName = ({ target }) => {
10
9
  setFirstName(target.value)
11
10
  }
12
11
  const ref = React.createRef()
13
12
 
13
+ const [firstName, setFirstName] = useState('')
14
14
  const [formFields, setFormFields] = useState({
15
15
  firstName: 'Jane',
16
16
  lastName: 'Doe',
@@ -1,5 +1,3 @@
1
- /* eslint-disable react/no-multi-comp */
2
-
3
1
  import React, { useState } from 'react'
4
2
 
5
3
  import {
@@ -1,28 +1,63 @@
1
- <%
2
- options = [
3
- { label: 'Orange', value: '#FFA500' },
4
- { label: 'Red', value: '#FF0000' },
5
- { label: 'Green', value: '#00FF00' },
6
- { label: 'Blue', value: '#0000FF' },
7
- ]
8
- %>
9
-
10
1
  <%= pb_rails("typeahead", props: {
11
- id: "typeahead-default",
12
- placeholder: "All Colors",
13
- options: options,
14
- label: "Colors",
15
- name: :foo,
16
- is_multi: false
17
- })
18
- %>
2
+ label: "user",
3
+ name: :foo,
4
+ data: { typeahead_example: true },
5
+ input_options: {
6
+ classname: "my-typeahead-class",
7
+ data: {
8
+ typeahead_testing: "data field test"
9
+ },
10
+ id: "typeahead-input-id-test",
11
+ },
12
+ })%>
13
+
14
+ <br><br><br>
15
+
16
+ <%= pb_rails("card", props: { padding: "xl", data: { typeahead_example_selected_option: true } }) do %>
17
+ <%= pb_rails("body") do %>
18
+ Use the above input to search for users on Github, and see the results as you type.
19
+ <% end %>
20
+
21
+ <%= pb_rails("body") do %>
22
+ When you make a selection, you will see it appear in the list below
23
+ <% end %>
24
+
25
+ <div data-selected-option></div>
26
+ <% end %>
27
+
28
+ <template data-typeahead-example-result-option>
29
+ <%= pb_rails("user", props: {
30
+ name: tag(:slot, name: "name"),
31
+ orientation: "horizontal",
32
+ align: "left",
33
+ avatar_url: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR4nGP6zwAAAgcBApocMXEAAAAASUVORK5CYII=",
34
+ avatar: true
35
+ }) %>
36
+ </template>
19
37
 
20
38
  <%= javascript_tag defer: "defer" do %>
21
- document.addEventListener("pb-typeahead-kit-typeahead-default-result-option-select", function(event) {
22
- console.log('Single Option selected')
23
- console.dir(event.detail)
39
+ document.addEventListener("pb-typeahead-kit-search", function(event) {
40
+ if (!event.target.dataset || !event.target.dataset.typeaheadExample) return;
41
+
42
+ fetch(`https://api.github.com/search/users?q=${encodeURIComponent(event.detail.searchingFor)}`)
43
+ .then(response => response.json())
44
+ .then((result) => {
45
+ const resultOptionTemplate = document.querySelector("[data-typeahead-example-result-option]")
46
+
47
+ event.detail.setResults((result.items || []).map((user) => {
48
+ const wrapper = resultOptionTemplate.content.cloneNode(true)
49
+ wrapper.querySelector('slot[name="name"]').replaceWith(user.login)
50
+ wrapper.querySelector('img').dataset.src = user.avatar_url
51
+ return wrapper
52
+ }))
53
+ })
24
54
  })
25
- document.addEventListener("pb-typeahead-kit-typeahead-default-result-clear", function() {
26
- console.log('All options cleared')
55
+
56
+
57
+ document.addEventListener("pb-typeahead-kit-result-option-selected", function(event) {
58
+ if (!event.target.dataset.typeaheadExample) return;
59
+
60
+ document.querySelector("[data-typeahead-example-selected-option] [data-selected-option]").innerHTML = ""
61
+ document.querySelector("[data-typeahead-example-selected-option] [data-selected-option]").innerHTML = event.detail.selected.innerHTML
27
62
  })
28
63
  <% end %>
@@ -47,6 +47,8 @@ const promiseOptions = (inputValue) =>
47
47
 
48
48
  const TypeaheadWithPillsAsync = (props) => {
49
49
  const [users, setUsers] = useState([])
50
+ const handleOnChange = (value) => setUsers(formatUsers(value))
51
+ const formatValue = (users) => formatUsers(users)
50
52
  const formatUsers = (users) => {
51
53
  const results = () => (users.map((user) => {
52
54
  if (Object.keys(user)[0] === 'name' || Object.keys(user)[1] === 'id'){
@@ -57,8 +59,6 @@ const TypeaheadWithPillsAsync = (props) => {
57
59
  }))
58
60
  return results()
59
61
  }
60
- const handleOnChange = (value) => setUsers(formatUsers(value))
61
- const formatValue = (users) => formatUsers(users)
62
62
 
63
63
  return (
64
64
  <>