playbook_ui 12.18.0.pre.alpha.play786multilevelselectimprovements627 → 12.18.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 71565d1e911bd318cffad56ff64e34bab539bc740f5138b68d1f1896c1a6808e
4
- data.tar.gz: '0278d976d8320ee5013b5cc1cb9ae03349ba1948317c315624291a4ef1c9c93a'
3
+ metadata.gz: 066fe5069146426c6fb9111de27a23e19513b840bc5c0173fe862f05c9a6ad3a
4
+ data.tar.gz: b72f2e69c675d622a6dbdebec865da68d2914cadafa00b2f729319cb66b9e442
5
5
  SHA512:
6
- metadata.gz: 01c0a50b86ab971669772bfffb39f010929ca496ded033027592aac11de73efb74f40a13b24705a379bba1e81df2b0e4a863415ab1c51b281a1b313a967cd216
7
- data.tar.gz: e0703c831017c9f2adb8b05f0eeb61a934142e52beca288c37fa3ee08d6268a6db7198e146e2efb743238a5a5245b7bd54b1a5e0f2c5c7518eb63a8fed94e114
6
+ metadata.gz: ac985c76a200cc24cfb19fc1c7cf58f0ff7d1d514c5f1d3b25f49e191498a283096d57b046a3fdafbece5f51373c1bb3c92b03fe2b5c62557243b6b38813eb49
7
+ data.tar.gz: bc02a9551e56ff2ba4ac05d4afa7cf9b488abe1d5b3293347798ceb8b563bea793fe6f64b1925eb70d4da1d649b6556e18e7586501feb12d73eb2850baf2bbce
@@ -36,9 +36,10 @@
36
36
  vertical-align: top;
37
37
  width: 0.6em;
38
38
  top: 10px;
39
+ transform: rotate(135deg);
39
40
  font-size: 0.5em;
40
41
 
41
- transform: rotate(45deg);
42
+ transform: rotate(-45deg);
42
43
  top: 12px;
43
44
  }
44
45
 
@@ -2,7 +2,7 @@ import React, { useState, useEffect, useMemo } from "react";
2
2
  import classnames from "classnames";
3
3
  import { buildAriaProps, buildCss, buildDataProps } from "../utilities/props";
4
4
  import { globalProps } from "../utilities/globalProps";
5
- import { findItemById, checkIt, unCheckIt, getParentAndAncestorsIds } from "./helper_functions";
5
+ import { findItemById, checkIt, unCheckIt } from "./helper_functions";
6
6
  import MultiSelectHelper from "./_multi_select_helper";
7
7
 
8
8
  type MultiLevelSelectProps = {
@@ -42,31 +42,17 @@ const MultiLevelSelect = (props: MultiLevelSelectProps) => {
42
42
  const updatedData = formattedData.map((item: any) => {
43
43
  if (item.id === currentNode._id) {
44
44
  if (currentNode.checked) {
45
- checkIt(item, selectedItems, setSelectedItems, false);
45
+ checkIt(item, selectedItems, setSelectedItems);
46
46
  } else {
47
- unCheckIt(item, selectedItems, setSelectedItems, false);
47
+ unCheckIt(item, selectedItems, setSelectedItems);
48
48
  }
49
49
  } else if (item.children) {
50
50
  const foundItem = findItemById(item.children, currentNode._id);
51
51
  if (foundItem) {
52
52
  if (currentNode.checked) {
53
- checkIt(foundItem, selectedItems, setSelectedItems, false);
54
- if (currentNode._parent) {
55
- const parents = getParentAndAncestorsIds(currentNode._parent, formattedData)
56
- parents.forEach((item:string) => {
57
- const ancestor = findItemById(formattedData,item)
58
- ancestor.expanded = true
59
- });
60
- }
53
+ checkIt(foundItem, selectedItems, setSelectedItems);
61
54
  } else {
62
- unCheckIt(foundItem, selectedItems, setSelectedItems, false);
63
- if (currentNode._parent) {
64
- const parents = getParentAndAncestorsIds(currentNode._parent, formattedData)
65
- parents.forEach((item:string) => {
66
- const ancestor = findItemById(formattedData,item)
67
- ancestor.expanded = true
68
- });
69
- }
55
+ unCheckIt(foundItem, selectedItems, setSelectedItems);
70
56
  }
71
57
  }
72
58
  }
@@ -106,18 +92,17 @@ const MultiLevelSelect = (props: MultiLevelSelectProps) => {
106
92
  treeData={formattedData}
107
93
  onChange={(
108
94
  // @ts-ignore
109
- selectedNodes: { [key: string]: any }[],
95
+ selectedNodes: { [key: string]: any }[],
110
96
  currentNode: { [key: string]: any }[]
111
97
  ) => {
112
98
  setCheckedData(currentNode);
113
99
  onSelect(currentNode);
114
-
115
100
  }}
116
101
  id={id}
117
102
  {...props}
118
103
  />
119
104
  );
120
- }, [formattedData])
105
+ }, [formattedData]);
121
106
 
122
107
  return (
123
108
  <div {...ariaProps} {...dataProps} className={classes} id={id}>
@@ -19,20 +19,19 @@ export const findItemById = (
19
19
  export const checkIt = (
20
20
  foundItem: { [key: string]: any },
21
21
  selectedItems: any[],
22
- setSelectedItems: Function,
23
- expand: boolean
22
+ setSelectedItems: Function
24
23
  ) => {
25
24
  if (!foundItem) {
26
25
  return;
27
26
  }
28
27
 
29
28
  foundItem.checked = true;
30
- foundItem.expanded = expand;
29
+ foundItem.expanded = true;
31
30
  selectedItems.push(foundItem);
32
31
 
33
32
  if (foundItem.children) {
34
33
  foundItem.children.map((x: any) => {
35
- checkIt(x, selectedItems, setSelectedItems, expand);
34
+ checkIt(x, selectedItems, setSelectedItems);
36
35
  });
37
36
  }
38
37
 
@@ -42,46 +41,20 @@ export const checkIt = (
42
41
  export const unCheckIt = (
43
42
  foundItem: { [key: string]: any },
44
43
  selectedItems: any,
45
- setSelectedItems: any,
46
- expand: boolean
44
+ setSelectedItems: any
47
45
  ) => {
48
46
  if (!foundItem) {
49
47
  return;
50
48
  }
51
49
 
52
50
  foundItem.checked = false;
53
- foundItem.expanded = false;
54
51
  const newSelectedItems = selectedItems.filter(
55
52
  (item: any) => item.id !== foundItem.id
56
53
  );
57
54
  if (foundItem.children) {
58
55
  foundItem.children.map((x: any) => {
59
- unCheckIt(x, selectedItems, setSelectedItems, expand);
56
+ unCheckIt(x, selectedItems, setSelectedItems);
60
57
  });
61
58
  }
62
59
  setSelectedItems([...newSelectedItems]);
63
60
  };
64
-
65
-
66
- export const getParentAndAncestorsIds = (itemId:string, items:{ [key: string]: string; }[], ancestors:string[] = []):any => {
67
- for (let i = 0; i < items.length; i++) {
68
- const item:any = items[i];
69
- if (item.id === itemId) {
70
- // item found in current level of items array
71
- return [...ancestors, item.id];
72
- }
73
- if (item.children && item.children.length > 0) {
74
- // recursively search through children
75
- const foundAncestors = getParentAndAncestorsIds(
76
- itemId,
77
- item.children,
78
- [...ancestors, item.id]
79
- );
80
- if (foundAncestors) {
81
- return foundAncestors;
82
- }
83
- }
84
- }
85
- // item not found in this level of items array or its children
86
- return null;
87
- }
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Playbook
4
- PREVIOUS_VERSION = "12.18.0"
5
- VERSION = "12.18.0.pre.alpha.play786multilevelselectimprovements627"
4
+ PREVIOUS_VERSION = "12.17.1"
5
+ VERSION = "12.18.0"
6
6
  end
metadata CHANGED
@@ -1,15 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: playbook_ui
3
3
  version: !ruby/object:Gem::Version
4
- version: 12.18.0.pre.alpha.play786multilevelselectimprovements627
4
+ version: 12.18.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Power UX
8
8
  - Power Devs
9
- autorequire:
9
+ autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2023-05-09 00:00:00.000000000 Z
12
+ date: 2023-05-03 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: actionpack
@@ -2485,7 +2485,7 @@ homepage: http://playbook.powerapp.cloud
2485
2485
  licenses:
2486
2486
  - ISC
2487
2487
  metadata: {}
2488
- post_install_message:
2488
+ post_install_message:
2489
2489
  rdoc_options: []
2490
2490
  require_paths:
2491
2491
  - lib
@@ -2496,12 +2496,12 @@ required_ruby_version: !ruby/object:Gem::Requirement
2496
2496
  version: '0'
2497
2497
  required_rubygems_version: !ruby/object:Gem::Requirement
2498
2498
  requirements:
2499
- - - ">"
2499
+ - - ">="
2500
2500
  - !ruby/object:Gem::Version
2501
- version: 1.3.1
2501
+ version: '0'
2502
2502
  requirements: []
2503
2503
  rubygems_version: 3.3.7
2504
- signing_key:
2504
+ signing_key:
2505
2505
  specification_version: 4
2506
2506
  summary: Playbook Design System
2507
2507
  test_files: []