genesys-react-components 0.1.6 → 0.2.0-devengage-1376.132

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 (37) hide show
  1. package/README.md +4 -0
  2. package/build/index.d.ts +1 -2
  3. package/build/index.js +6 -6
  4. package/build/index.js.map +1 -1
  5. package/package.json +52 -47
  6. package/src/alertblock/AlertBlock.scss +108 -0
  7. package/src/alertblock/AlertBlock.tsx +80 -0
  8. package/src/copybutton/CopyButton.scss +8 -0
  9. package/src/copybutton/CopyButton.tsx +42 -0
  10. package/src/dxaccordion/DxAccordion.scss +41 -0
  11. package/src/dxaccordion/DxAccordion.tsx +49 -0
  12. package/src/dxaccordion/DxAccordionGroup.scss +3 -0
  13. package/src/dxaccordion/DxAccordionGroup.tsx +12 -0
  14. package/src/dxbutton/DxButton.scss +79 -0
  15. package/src/dxbutton/DxButton.tsx +31 -0
  16. package/src/dxitemgroup/DxCheckbox.scss +145 -0
  17. package/src/dxitemgroup/DxCheckbox.tsx +46 -0
  18. package/src/dxitemgroup/DxItemGroup.scss +6 -0
  19. package/src/dxitemgroup/DxItemGroup.tsx +133 -0
  20. package/src/dxitemgroup/dropdown.scss +53 -0
  21. package/src/dxitemgroup/multiselect.scss +74 -0
  22. package/src/dxitemgroup/radiobutton.scss +2 -0
  23. package/src/dxlabel/DxLabel.scss +31 -0
  24. package/src/dxlabel/DxLabel.tsx +39 -0
  25. package/src/dxtabbedcontent/DxTabPanel.scss +0 -0
  26. package/src/dxtabbedcontent/DxTabPanel.tsx +8 -0
  27. package/src/dxtabbedcontent/DxTabbedContent.scss +45 -0
  28. package/src/dxtabbedcontent/DxTabbedContent.tsx +28 -0
  29. package/src/dxtextbox/DxTextbox.scss +107 -0
  30. package/src/dxtextbox/DxTextbox.tsx +159 -0
  31. package/src/dxtoggle/DxToggle.scss +76 -0
  32. package/src/dxtoggle/DxToggle.tsx +51 -0
  33. package/src/index.ts +141 -0
  34. package/src/loadingplaceholder/LoadingPlaceholder.scss +58 -0
  35. package/src/loadingplaceholder/LoadingPlaceholder.tsx +17 -0
  36. package/src/tooltip/Tooltip.scss +108 -0
  37. package/src/tooltip/Tooltip.tsx +46 -0
package/src/index.ts ADDED
@@ -0,0 +1,141 @@
1
+ import { GenesysDevIcons } from 'genesys-dev-icons';
2
+ import DxAccordion from './dxaccordion/DxAccordion';
3
+ import DxAccordionGroup from './dxaccordion/DxAccordionGroup';
4
+ import DxButton from './dxbutton/DxButton';
5
+ import DxItemGroup from './dxitemgroup/DxItemGroup';
6
+ import DxCheckbox from './dxitemgroup/DxCheckbox';
7
+ import DxLabel from './dxlabel/DxLabel';
8
+ import DxTabbedContent from './dxtabbedcontent/DxTabbedContent';
9
+ import DxTabPanel from './dxtabbedcontent/DxTabPanel';
10
+ import DxTextbox from './dxtextbox/DxTextbox';
11
+ import DxToggle from './dxtoggle/DxToggle';
12
+ import AlertBlock from './alertblock/AlertBlock';
13
+ import LoadingPlaceholder from './loadingplaceholder/LoadingPlaceholder';
14
+ import Tooltip from './tooltip/Tooltip';
15
+ import CopyButton from './copybutton/CopyButton';
16
+
17
+ export {
18
+ DxAccordion,
19
+ DxAccordionGroup,
20
+ DxButton,
21
+ DxItemGroup,
22
+ DxCheckbox,
23
+ DxLabel,
24
+ DxTabbedContent,
25
+ DxTabPanel,
26
+ DxTextbox,
27
+ DxToggle,
28
+ Tooltip,
29
+ CopyButton,
30
+ LoadingPlaceholder,
31
+ AlertBlock,
32
+ };
33
+
34
+ export interface StringChangedCallback {
35
+ (value: string): void;
36
+ }
37
+
38
+ export interface BooleanChangedCallback {
39
+ (value?: boolean): void;
40
+ }
41
+
42
+ export interface CheckedChangedCallback {
43
+ (checked: boolean): void;
44
+ }
45
+
46
+ export interface VoidEventCallback {
47
+ (): void;
48
+ }
49
+
50
+ // Item in a DxItemGroup
51
+ export interface DxItemGroupItem {
52
+ label: string;
53
+ value: string;
54
+ disabled?: boolean;
55
+ isSelected?: boolean;
56
+ }
57
+
58
+ // Item value of a DxItemGroupItem in a DxItemGroup
59
+ export interface DxItemGroupItemValue {
60
+ item: DxItemGroupItem;
61
+ isSelected: boolean;
62
+ }
63
+
64
+ export interface ItemChangedCallback {
65
+ (item: DxItemGroupItem, isSelected: boolean): void;
66
+ }
67
+
68
+ export interface ItemGroupChangedCallback {
69
+ (items: DxItemGroupItemValue[]): void;
70
+ }
71
+
72
+ export interface DxToggleProps {
73
+ isTriState?: boolean;
74
+ initialValue?: boolean;
75
+ value?: boolean;
76
+ label?: string;
77
+ description?: string;
78
+ trueIcon?: GenesysDevIcons;
79
+ falseIcon?: GenesysDevIcons;
80
+ disabled?: boolean;
81
+ onChange?: BooleanChangedCallback;
82
+ className?: string;
83
+ }
84
+
85
+ export type DxTextboxType = 'text' | 'textarea' | 'password' | 'email' | 'date' | 'datetime-local' | 'time' | 'integer' | 'decimal';
86
+
87
+ export interface DxTextboxProps {
88
+ initialValue?: string;
89
+ value?: string;
90
+ inputType?: DxTextboxType;
91
+ label?: string;
92
+ description?: string;
93
+ placeholder?: string;
94
+ icon?: GenesysDevIcons;
95
+ clearButton?: boolean;
96
+ onChange?: StringChangedCallback;
97
+ changeDebounceMs?: number;
98
+ inputRef?: React.RefObject<HTMLInputElement>;
99
+ onFocus?: VoidEventCallback;
100
+ onBlur?: VoidEventCallback;
101
+ disabled?: boolean;
102
+ className?: string;
103
+ autoFocus?: boolean;
104
+ }
105
+
106
+ export interface DxAccordionProps {
107
+ title: React.ReactNode;
108
+ children: React.ReactNode;
109
+ showOpen?: boolean;
110
+ className?: string;
111
+ expandTrigger?: any;
112
+ showOpenTrigger?: any;
113
+ containerId?: string;
114
+ headingIcon?: any;
115
+ headingColor?: string;
116
+ }
117
+
118
+ export interface DxItemGroupProps {
119
+ title?: string;
120
+ description?: string;
121
+ format: DxItemGroupFormat;
122
+ items: DxItemGroupItem[];
123
+ disabled?: boolean;
124
+ className?: string;
125
+ onItemChanged?: ItemChangedCallback;
126
+ onItemsChanged?: ItemGroupChangedCallback;
127
+ }
128
+
129
+ export type DxItemGroupFormat = 'checkbox' | 'radio' | 'dropdown' | 'multiselect';
130
+
131
+ export interface DxTabbedContentProps {
132
+ children: React.ReactNode;
133
+ initialTabId?: number;
134
+ className?: string;
135
+ }
136
+
137
+ export interface DxTabPanelProps {
138
+ title: React.ReactNode;
139
+ children: React.ReactNode;
140
+ className?: string;
141
+ }
@@ -0,0 +1,58 @@
1
+ @import '../../utils/theme/variables.scss';
2
+
3
+ $size: 160px;
4
+
5
+ .loading-placeholder {
6
+ position: relative;
7
+ width: $size;
8
+ height: $size;
9
+ margin: 60px auto;
10
+
11
+ .text {
12
+ display: flex;
13
+ flex-flow: row nowrap;
14
+ align-items: center;
15
+ justify-content: center;
16
+ width: 100%;
17
+ height: 100%;
18
+ font-style: normal;
19
+ font-weight: 300;
20
+ font-size: 16px;
21
+ line-height: 20px;
22
+ color: var($--theme-loadingplaceholder-text-color);
23
+ position: relative;
24
+ top: 5px;
25
+ left: 5px;
26
+ opacity: 0.5;
27
+ }
28
+
29
+ div {
30
+ position: absolute;
31
+ border: 4px solid var($--theme-loadingplaceholder-wave-color);
32
+ opacity: 1;
33
+ border-radius: 50%;
34
+ animation: loading-placeholder 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
35
+ }
36
+
37
+ div:nth-child(2) {
38
+ animation-delay: -0.5s;
39
+ }
40
+
41
+ @keyframes loading-placeholder {
42
+ 0% {
43
+ top: calc($size / 2);
44
+ left: calc($size / 2);
45
+ width: 0;
46
+ height: 0;
47
+ opacity: 1;
48
+ }
49
+
50
+ 100% {
51
+ top: 0px;
52
+ left: 0px;
53
+ width: $size;
54
+ height: $size;
55
+ opacity: 0;
56
+ }
57
+ }
58
+ }
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+
3
+ import './LoadingPlaceholder.scss';
4
+
5
+ interface IProps {
6
+ text?: string;
7
+ }
8
+
9
+ export default function LoadingPlaceholder(props: IProps) {
10
+ return (
11
+ <div className="loading-placeholder">
12
+ <span className="text">{props.text || 'Loading'}</span>
13
+ <div></div>
14
+ <div></div>
15
+ </div>
16
+ );
17
+ }
@@ -0,0 +1,108 @@
1
+ /* Custom properties */
2
+ :root {
3
+ --tooltip-text-color: white;
4
+ --tooltip-background-color: black;
5
+ --tooltip-margin: 10px;
6
+ --tooltip-arrow-size: 6px;
7
+ }
8
+
9
+ /* Wrapping */
10
+ .tooltip-container {
11
+ display: inline-block;
12
+ position: relative;
13
+ line-height: 0;
14
+
15
+ /* Absolute positioning */
16
+ .tooltip-tip {
17
+ position: absolute;
18
+ border-radius: 4px;
19
+ left: 50%;
20
+ transform: translateX(-50%);
21
+ padding: 6px;
22
+ color: var(--tooltip-text-color);
23
+ background: var(--tooltip-background-color);
24
+ font-size: 14px;
25
+ line-height: 1;
26
+ z-index: 10000;
27
+ max-width: 300px;
28
+ width: max-content;
29
+ opacity: 0;
30
+ visibility: hidden;
31
+ transition: visibility 1.1s ease-out, opacity 1s ease-out;
32
+
33
+ &.visible {
34
+ opacity: 1;
35
+ visibility: visible;
36
+ transition: visibility 0s, opacity 0.1s ease-in;
37
+ }
38
+
39
+ /* CSS border triangles */
40
+ &::before {
41
+ content: ' ';
42
+ left: 50%;
43
+ border: solid transparent;
44
+ height: 0;
45
+ width: 0;
46
+ position: absolute;
47
+ pointer-events: none;
48
+ border-width: var(--tooltip-arrow-size);
49
+ margin-left: calc(var(--tooltip-arrow-size) * -1);
50
+ }
51
+
52
+ /* Absolute positioning */
53
+ &.top {
54
+ // top: calc(var(--tooltip-margin) * -1);
55
+ bottom: 130%;
56
+
57
+ /* CSS border triangles */
58
+ &::before {
59
+ top: 100%;
60
+ border-top-color: var(--tooltip-background-color);
61
+ }
62
+ }
63
+
64
+ /* Absolute positioning */
65
+ &.right {
66
+ left: calc(100% + var(--tooltip-margin));
67
+ top: 50%;
68
+ transform: translateX(0) translateY(-50%);
69
+
70
+ /* CSS border triangles */
71
+ &::before {
72
+ left: calc(var(--tooltip-arrow-size) * -1);
73
+ top: 50%;
74
+ transform: translateX(0) translateY(-50%);
75
+ border-right-color: var(--tooltip-background-color);
76
+ }
77
+ }
78
+
79
+ /* Absolute positioning */
80
+ &.bottom {
81
+ // bottom: calc(var(--tooltip-margin) * -1);
82
+ top: 110%;
83
+
84
+ /* CSS border triangles */
85
+ &::before {
86
+ bottom: 100%;
87
+ border-bottom-color: var(--tooltip-background-color);
88
+ }
89
+ }
90
+
91
+ /* Absolute positioning */
92
+ &.left {
93
+ left: auto;
94
+ right: calc(100% + var(--tooltip-margin));
95
+ top: 50%;
96
+ transform: translateX(0) translateY(-50%);
97
+
98
+ /* CSS border triangles */
99
+ &::before {
100
+ left: auto;
101
+ right: calc(var(--tooltip-arrow-size) * -2);
102
+ top: 50%;
103
+ transform: translateX(0) translateY(-50%);
104
+ border-left-color: var(--tooltip-background-color);
105
+ }
106
+ }
107
+ }
108
+ }
@@ -0,0 +1,46 @@
1
+ import React, { ReactNode, useEffect, useRef, useState } from 'react';
2
+
3
+ import './Tooltip.scss';
4
+
5
+ interface IProps {
6
+ text: string;
7
+ position?: 'top' | 'right' | 'bottom' | 'left';
8
+ children?: ReactNode;
9
+ className?: string;
10
+ // Setting this to any value enables manual control
11
+ isShowing?: boolean;
12
+ }
13
+
14
+ // Inspired by https://paladini.dev/posts/how-to-make-an-extremely-reusable-tooltip-component-with-react--and-nothing-else/
15
+ export default function Tooltip(props: IProps) {
16
+ const [isShowing, setIsShowing] = useState(false);
17
+ const timeout = useRef<NodeJS.Timeout | undefined>();
18
+
19
+ useEffect(() => {
20
+ if (props.isShowing === undefined) return;
21
+ setIsShowing(props.isShowing === true);
22
+ }, [props.isShowing]);
23
+
24
+ const showTip = (e: React.MouseEvent<HTMLDivElement, MouseEvent>) => {
25
+ // Ignore mouse events from the tooltip itself
26
+ if ((e.target as HTMLDivElement).className.includes('tooltip-tip')) return;
27
+ // Ignore mouse events when manually controlled
28
+ if (props.isShowing !== undefined) return;
29
+ timeout.current = setTimeout(() => {
30
+ setIsShowing(true);
31
+ }, 100);
32
+ };
33
+
34
+ const hideTip = () => {
35
+ if (props.isShowing !== undefined) return;
36
+ if (timeout.current) clearInterval(timeout.current);
37
+ setIsShowing(false);
38
+ };
39
+
40
+ return (
41
+ <div className={`tooltip-container ${props.className || ''}`} onMouseEnter={showTip} onMouseLeave={hideTip}>
42
+ {props.children}
43
+ <div className={`tooltip-tip ${props.position || 'top'}${isShowing ? ' visible' : ''}`}>{props.text}</div>
44
+ </div>
45
+ );
46
+ }