@spaced-out/ui-design-system 0.1.75 → 0.1.77
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.
- package/.cspell/custom-words.txt +1 -0
- package/.github/workflows/publish_to_npm.yml +1 -1
- package/CHANGELOG.md +14 -0
- package/lib/components/Badge/Badge.js +40 -4
- package/lib/components/Badge/Badge.js.flow +90 -11
- package/lib/components/Badge/Badge.module.css +16 -2
- package/lib/components/Modal/Modal.js +18 -5
- package/lib/components/Modal/Modal.js.flow +14 -0
- package/lib/components/Modal/Modal.module.css +6 -0
- package/lib/components/PageTitle/PageTitle.js +15 -0
- package/lib/components/PageTitle/PageTitle.js.flow +15 -0
- package/lib/components/SideMenuLink/SideMenuLink.js +20 -0
- package/lib/components/SideMenuLink/SideMenuLink.js.flow +20 -0
- package/package.json +1 -1
package/.cspell/custom-words.txt
CHANGED
|
@@ -22,7 +22,7 @@ jobs:
|
|
|
22
22
|
- name: Check Permissions
|
|
23
23
|
id: check-permissions
|
|
24
24
|
env:
|
|
25
|
-
ALLOWED_USERS: superrover, Anant-Raj, nsfmc, ashwini-sensehq, aditya-kaushal, vish-sah
|
|
25
|
+
ALLOWED_USERS: superrover, Anant-Raj, nsfmc, ashwini-sensehq, aditya-kaushal, vish-sah, VishalBarnawal
|
|
26
26
|
if: ${{ !contains(env.ALLOWED_USERS, github.actor) }}
|
|
27
27
|
run: |
|
|
28
28
|
echo "You don't have correct permissions to do this release"
|
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,20 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
### [0.1.77](https://github.com/spaced-out/ui-design-system/compare/v0.1.76...v0.1.77) (2024-01-23)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* icon badge ([#160](https://github.com/spaced-out/ui-design-system/issues/160)) ([787e97a](https://github.com/spaced-out/ui-design-system/commit/787e97a781f56a1c44d4f384cd5a9a727c2239b8))
|
|
11
|
+
|
|
12
|
+
### [0.1.76](https://github.com/spaced-out/ui-design-system/compare/v0.1.75...v0.1.76) (2024-01-19)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### Features
|
|
16
|
+
|
|
17
|
+
* added new tabs for referral portal in side menu link component ([#158](https://github.com/spaced-out/ui-design-system/issues/158)) ([75c6835](https://github.com/spaced-out/ui-design-system/commit/75c68351ea6687de6b5696b89420cf13ee78ca09))
|
|
18
|
+
|
|
5
19
|
### [0.1.75](https://github.com/spaced-out/ui-design-system/compare/v0.1.74...v0.1.75) (2024-01-10)
|
|
6
20
|
|
|
7
21
|
|
|
@@ -3,11 +3,12 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.Badge = exports.BADGE_COLOR = void 0;
|
|
6
|
+
exports.IconBadge = exports.Badge = exports.BADGE_COLOR = void 0;
|
|
7
7
|
var React = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _color = require("../../styles/variables/_color");
|
|
9
9
|
var _classify = _interopRequireDefault(require("../../utils/classify"));
|
|
10
|
-
var
|
|
10
|
+
var _Icon = require("../Icon");
|
|
11
|
+
var _Text = require("../Text");
|
|
11
12
|
var _BadgeModule = _interopRequireDefault(require("./Badge.module.css"));
|
|
12
13
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
14
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
@@ -33,6 +34,7 @@ const Badge = /*#__PURE__*/React.forwardRef((_ref, ref) => {
|
|
|
33
34
|
text,
|
|
34
35
|
fill = 'gray'
|
|
35
36
|
} = _ref;
|
|
37
|
+
const isDark = fill.includes('Dark');
|
|
36
38
|
return /*#__PURE__*/React.createElement("div", {
|
|
37
39
|
"data-testid": "Badge",
|
|
38
40
|
style: {
|
|
@@ -43,7 +45,41 @@ const Badge = /*#__PURE__*/React.forwardRef((_ref, ref) => {
|
|
|
43
45
|
}, classNames?.wrapper),
|
|
44
46
|
ref: ref
|
|
45
47
|
}, /*#__PURE__*/React.createElement(_Text.ButtonTextSmall, {
|
|
46
|
-
className:
|
|
48
|
+
className: (0, _classify.default)({
|
|
49
|
+
[_BadgeModule.default.dark]: isDark,
|
|
50
|
+
[_BadgeModule.default.light]: !isDark
|
|
51
|
+
}, classNames?.text)
|
|
47
52
|
}, text));
|
|
48
53
|
});
|
|
49
|
-
exports.Badge = Badge;
|
|
54
|
+
exports.Badge = Badge;
|
|
55
|
+
const IconBadge = /*#__PURE__*/React.forwardRef((_ref2, ref) => {
|
|
56
|
+
let {
|
|
57
|
+
classNames,
|
|
58
|
+
fill = 'gray',
|
|
59
|
+
iconName,
|
|
60
|
+
iconSize = 'small',
|
|
61
|
+
iconType = 'solid',
|
|
62
|
+
ariaLabel,
|
|
63
|
+
onClick
|
|
64
|
+
} = _ref2;
|
|
65
|
+
const isDark = fill.includes('Dark');
|
|
66
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
67
|
+
"data-testid": "Badge",
|
|
68
|
+
style: {
|
|
69
|
+
'--wrapperBgColor': BADGE_COLOR[fill]
|
|
70
|
+
},
|
|
71
|
+
className: (0, _classify.default)(_BadgeModule.default.badgeWrapper, _BadgeModule.default.iconContainer, classNames?.wrapper),
|
|
72
|
+
ref: ref
|
|
73
|
+
}, /*#__PURE__*/React.createElement(_Icon.Icon, {
|
|
74
|
+
name: iconName,
|
|
75
|
+
type: iconType,
|
|
76
|
+
size: iconSize,
|
|
77
|
+
ariaLabel: ariaLabel,
|
|
78
|
+
onClick: onClick,
|
|
79
|
+
className: (0, _classify.default)({
|
|
80
|
+
[_BadgeModule.default.dark]: isDark,
|
|
81
|
+
[_BadgeModule.default.light]: !isDark
|
|
82
|
+
}, classNames?.icon)
|
|
83
|
+
}));
|
|
84
|
+
});
|
|
85
|
+
exports.IconBadge = IconBadge;
|
|
@@ -16,12 +16,14 @@ import {
|
|
|
16
16
|
colorWarningLightest,
|
|
17
17
|
} from '../../styles/variables/_color';
|
|
18
18
|
import classify from '../../utils/classify';
|
|
19
|
-
import {
|
|
19
|
+
import type {IconSize, IconType} from '../Icon';
|
|
20
|
+
import {Icon} from '../Icon';
|
|
21
|
+
import {ButtonTextSmall} from '../Text';
|
|
20
22
|
|
|
21
23
|
import css from './Badge.module.css';
|
|
22
24
|
|
|
23
25
|
|
|
24
|
-
type ClassNames = $ReadOnly<{wrapper?: string, text?: string}>;
|
|
26
|
+
type ClassNames = $ReadOnly<{wrapper?: string, text?: string, icon?: string}>;
|
|
25
27
|
|
|
26
28
|
export const BADGE_COLOR = Object.freeze({
|
|
27
29
|
gray: colorGrayLightest,
|
|
@@ -39,15 +41,80 @@ export const BADGE_COLOR = Object.freeze({
|
|
|
39
41
|
|
|
40
42
|
export type BadgeColorType = $Keys<typeof BADGE_COLOR>;
|
|
41
43
|
|
|
42
|
-
export type
|
|
44
|
+
export type BaseBadgeProps = {
|
|
43
45
|
classNames?: ClassNames,
|
|
44
|
-
text: string,
|
|
45
46
|
fill?: BadgeColorType,
|
|
46
47
|
};
|
|
47
48
|
|
|
49
|
+
export type BadgeProps = {
|
|
50
|
+
...BaseBadgeProps,
|
|
51
|
+
text: string,
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export type IconBadgeProps = {
|
|
55
|
+
...BaseBadgeProps,
|
|
56
|
+
iconName: string,
|
|
57
|
+
iconType?: IconType,
|
|
58
|
+
iconSize?: IconSize,
|
|
59
|
+
onClick?: ?(SyntheticEvent<HTMLElement>) => mixed,
|
|
60
|
+
ariaLabel?: string,
|
|
61
|
+
};
|
|
62
|
+
|
|
48
63
|
export const Badge: React$AbstractComponent<BadgeProps, HTMLDivElement> =
|
|
49
64
|
React.forwardRef<BadgeProps, HTMLDivElement>(
|
|
50
|
-
({classNames, text, fill = 'gray'}: BadgeProps, ref): React.Node =>
|
|
65
|
+
({classNames, text, fill = 'gray'}: BadgeProps, ref): React.Node => {
|
|
66
|
+
const isDark = fill.includes('Dark');
|
|
67
|
+
|
|
68
|
+
return (
|
|
69
|
+
<div
|
|
70
|
+
data-testid="Badge"
|
|
71
|
+
style={{
|
|
72
|
+
'--wrapperBgColor': BADGE_COLOR[fill],
|
|
73
|
+
}}
|
|
74
|
+
className={classify(
|
|
75
|
+
css.badgeWrapper,
|
|
76
|
+
{
|
|
77
|
+
[css.fixedWidth]: text.length <= 2,
|
|
78
|
+
},
|
|
79
|
+
classNames?.wrapper,
|
|
80
|
+
)}
|
|
81
|
+
ref={ref}
|
|
82
|
+
>
|
|
83
|
+
<ButtonTextSmall
|
|
84
|
+
className={classify(
|
|
85
|
+
{
|
|
86
|
+
[css.dark]: isDark,
|
|
87
|
+
[css.light]: !isDark,
|
|
88
|
+
},
|
|
89
|
+
classNames?.text,
|
|
90
|
+
)}
|
|
91
|
+
>
|
|
92
|
+
{text}
|
|
93
|
+
</ButtonTextSmall>
|
|
94
|
+
</div>
|
|
95
|
+
);
|
|
96
|
+
},
|
|
97
|
+
);
|
|
98
|
+
|
|
99
|
+
export const IconBadge: React$AbstractComponent<
|
|
100
|
+
IconBadgeProps,
|
|
101
|
+
HTMLDivElement,
|
|
102
|
+
> = React.forwardRef<IconBadgeProps, HTMLDivElement>(
|
|
103
|
+
(
|
|
104
|
+
{
|
|
105
|
+
classNames,
|
|
106
|
+
fill = 'gray',
|
|
107
|
+
iconName,
|
|
108
|
+
iconSize = 'small',
|
|
109
|
+
iconType = 'solid',
|
|
110
|
+
ariaLabel,
|
|
111
|
+
onClick,
|
|
112
|
+
}: IconBadgeProps,
|
|
113
|
+
ref,
|
|
114
|
+
): React.Node => {
|
|
115
|
+
const isDark = fill.includes('Dark');
|
|
116
|
+
|
|
117
|
+
return (
|
|
51
118
|
<div
|
|
52
119
|
data-testid="Badge"
|
|
53
120
|
style={{
|
|
@@ -55,14 +122,26 @@ export const Badge: React$AbstractComponent<BadgeProps, HTMLDivElement> =
|
|
|
55
122
|
}}
|
|
56
123
|
className={classify(
|
|
57
124
|
css.badgeWrapper,
|
|
58
|
-
|
|
59
|
-
[css.fixedWidth]: text.length <= 2,
|
|
60
|
-
},
|
|
125
|
+
css.iconContainer,
|
|
61
126
|
classNames?.wrapper,
|
|
62
127
|
)}
|
|
63
128
|
ref={ref}
|
|
64
129
|
>
|
|
65
|
-
<
|
|
130
|
+
<Icon
|
|
131
|
+
name={iconName}
|
|
132
|
+
type={iconType}
|
|
133
|
+
size={iconSize}
|
|
134
|
+
ariaLabel={ariaLabel}
|
|
135
|
+
onClick={onClick}
|
|
136
|
+
className={classify(
|
|
137
|
+
{
|
|
138
|
+
[css.dark]: isDark,
|
|
139
|
+
[css.light]: !isDark,
|
|
140
|
+
},
|
|
141
|
+
classNames?.icon,
|
|
142
|
+
)}
|
|
143
|
+
/>
|
|
66
144
|
</div>
|
|
67
|
-
)
|
|
68
|
-
|
|
145
|
+
);
|
|
146
|
+
},
|
|
147
|
+
);
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
@value (size22, size100) from '../../styles/variables/_size.css';
|
|
1
|
+
@value (size12, size22, size100) from '../../styles/variables/_size.css';
|
|
2
2
|
@value (spaceXSmall, spaceNone) from '../../styles/variables/_space.css';
|
|
3
|
-
@value (colorGrayLightest) from '../../styles/variables/_color.css';
|
|
3
|
+
@value (colorGrayLightest, colorTextInversePrimary, colorTextPrimary) from '../../styles/variables/_color.css';
|
|
4
4
|
|
|
5
5
|
.badgeWrapper {
|
|
6
6
|
--wrapperBgColor: colorGrayLightest;
|
|
@@ -13,6 +13,20 @@
|
|
|
13
13
|
min-width: fit-content;
|
|
14
14
|
width: fit-content;
|
|
15
15
|
background-color: var(--wrapperBgColor);
|
|
16
|
+
color: colorTextInversePrimary;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.iconContainer {
|
|
20
|
+
height: initial;
|
|
21
|
+
padding: calc(size12 / 4);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.dark {
|
|
25
|
+
color: colorTextInversePrimary;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
.light {
|
|
29
|
+
color: colorTextPrimary;
|
|
16
30
|
}
|
|
17
31
|
|
|
18
32
|
.fixedWidth {
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.ModalHeader = exports.ModalFooter = exports.ModalBody = exports.Modal = void 0;
|
|
6
|
+
exports.ModalHeader = exports.ModalFooter = exports.ModalBody = exports.Modal = exports.FullScreenModal = void 0;
|
|
7
7
|
var React = _interopRequireWildcard(require("react"));
|
|
8
8
|
var _reactDom = require("react-dom");
|
|
9
9
|
var _react2 = require("@floating-ui/react");
|
|
@@ -18,9 +18,7 @@ var _ModalModule = _interopRequireDefault(require("./Modal.module.css"));
|
|
|
18
18
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
19
19
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
20
20
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
21
|
-
|
|
22
|
-
// $FlowFixMe[untyped-import]
|
|
23
|
-
|
|
21
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
24
22
|
const DEFAULT_MODAL_ANIMATION = {
|
|
25
23
|
duration: {
|
|
26
24
|
open: parseInt(_motion.motionDurationSlow),
|
|
@@ -228,4 +226,19 @@ const Modal = _ref4 => {
|
|
|
228
226
|
}
|
|
229
227
|
}, children))), portalRootRef.current);
|
|
230
228
|
};
|
|
231
|
-
|
|
229
|
+
|
|
230
|
+
// FullScreen modal that just calls the Modal component with a wrapper className set which sets the width and height to sizeFluid
|
|
231
|
+
exports.Modal = Modal;
|
|
232
|
+
const FullScreenModal = _ref5 => {
|
|
233
|
+
let {
|
|
234
|
+
classNames,
|
|
235
|
+
...props
|
|
236
|
+
} = _ref5;
|
|
237
|
+
return /*#__PURE__*/React.createElement(Modal, _extends({
|
|
238
|
+
classNames: {
|
|
239
|
+
...classNames,
|
|
240
|
+
content: (0, _classify.default)(_ModalModule.default.fullscreenModalContainer, classNames?.content)
|
|
241
|
+
}
|
|
242
|
+
}, props));
|
|
243
|
+
};
|
|
244
|
+
exports.FullScreenModal = FullScreenModal;
|
|
@@ -336,3 +336,17 @@ export const Modal = ({
|
|
|
336
336
|
portalRootRef.current,
|
|
337
337
|
);
|
|
338
338
|
};
|
|
339
|
+
|
|
340
|
+
// FullScreen modal that just calls the Modal component with a wrapper className set which sets the width and height to sizeFluid
|
|
341
|
+
export const FullScreenModal = ({
|
|
342
|
+
classNames,
|
|
343
|
+
...props
|
|
344
|
+
}: ModalProps): React.Node => (
|
|
345
|
+
<Modal
|
|
346
|
+
classNames={{
|
|
347
|
+
...classNames,
|
|
348
|
+
content: classify(css.fullscreenModalContainer, classNames?.content),
|
|
349
|
+
}}
|
|
350
|
+
{...props}
|
|
351
|
+
/>
|
|
352
|
+
);
|
|
@@ -39,6 +39,12 @@
|
|
|
39
39
|
width: size640;
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
+
.fullscreenModalContainer {
|
|
43
|
+
width: sizeFluid;
|
|
44
|
+
height: sizeFluid;
|
|
45
|
+
border-radius: initial;
|
|
46
|
+
}
|
|
47
|
+
|
|
42
48
|
.modalContainer.open.in .modal {
|
|
43
49
|
opacity: opacity100;
|
|
44
50
|
transform: translate(spaceNegHalfFluid, spaceNegHalfFluid) scale(1);
|
|
@@ -115,6 +115,21 @@ const PAGE_NAME_LIST = Object.freeze({
|
|
|
115
115
|
iconName: 'browser',
|
|
116
116
|
iconType: 'duotone',
|
|
117
117
|
iconSwapOpacity: true
|
|
118
|
+
},
|
|
119
|
+
tracking: {
|
|
120
|
+
title: 'Tracking',
|
|
121
|
+
iconName: 'user-check',
|
|
122
|
+
iconType: 'duotone'
|
|
123
|
+
},
|
|
124
|
+
earnings: {
|
|
125
|
+
title: 'Earnings',
|
|
126
|
+
iconName: 'wallet',
|
|
127
|
+
iconType: 'duotone'
|
|
128
|
+
},
|
|
129
|
+
settings: {
|
|
130
|
+
title: 'Settings',
|
|
131
|
+
iconName: 'gear',
|
|
132
|
+
iconType: 'duotone'
|
|
118
133
|
}
|
|
119
134
|
});
|
|
120
135
|
exports.PAGE_NAME_LIST = PAGE_NAME_LIST;
|
|
@@ -124,6 +124,21 @@ export const PAGE_NAME_LIST = Object.freeze({
|
|
|
124
124
|
iconType: 'duotone',
|
|
125
125
|
iconSwapOpacity: true,
|
|
126
126
|
},
|
|
127
|
+
tracking: {
|
|
128
|
+
title: 'Tracking',
|
|
129
|
+
iconName: 'user-check',
|
|
130
|
+
iconType: 'duotone',
|
|
131
|
+
},
|
|
132
|
+
earnings: {
|
|
133
|
+
title: 'Earnings',
|
|
134
|
+
iconName: 'wallet',
|
|
135
|
+
iconType: 'duotone',
|
|
136
|
+
},
|
|
137
|
+
settings: {
|
|
138
|
+
title: 'Settings',
|
|
139
|
+
iconName: 'gear',
|
|
140
|
+
iconType: 'duotone',
|
|
141
|
+
},
|
|
127
142
|
});
|
|
128
143
|
|
|
129
144
|
export type TabSlotProps = {
|
|
@@ -98,6 +98,26 @@ const MENU_NAME_LIST = Object.freeze({
|
|
|
98
98
|
title: 'AI Copilot',
|
|
99
99
|
iconName: 'sparkles',
|
|
100
100
|
iconType: 'duotone'
|
|
101
|
+
},
|
|
102
|
+
tracking: {
|
|
103
|
+
title: 'Tracking',
|
|
104
|
+
iconName: 'user-check',
|
|
105
|
+
iconType: 'duotone'
|
|
106
|
+
},
|
|
107
|
+
jobs: {
|
|
108
|
+
title: 'Jobs',
|
|
109
|
+
iconName: 'briefcase',
|
|
110
|
+
iconType: 'duotone'
|
|
111
|
+
},
|
|
112
|
+
earnings: {
|
|
113
|
+
title: 'Earnings',
|
|
114
|
+
iconName: 'wallet',
|
|
115
|
+
iconType: 'duotone'
|
|
116
|
+
},
|
|
117
|
+
settings: {
|
|
118
|
+
title: 'Settings',
|
|
119
|
+
iconName: 'gear',
|
|
120
|
+
iconType: 'duotone'
|
|
101
121
|
}
|
|
102
122
|
});
|
|
103
123
|
exports.MENU_NAME_LIST = MENU_NAME_LIST;
|
|
@@ -95,6 +95,26 @@ export const MENU_NAME_LIST = Object.freeze({
|
|
|
95
95
|
iconName: 'sparkles',
|
|
96
96
|
iconType: 'duotone',
|
|
97
97
|
},
|
|
98
|
+
tracking: {
|
|
99
|
+
title: 'Tracking',
|
|
100
|
+
iconName: 'user-check',
|
|
101
|
+
iconType: 'duotone',
|
|
102
|
+
},
|
|
103
|
+
jobs: {
|
|
104
|
+
title: 'Jobs',
|
|
105
|
+
iconName: 'briefcase',
|
|
106
|
+
iconType: 'duotone',
|
|
107
|
+
},
|
|
108
|
+
earnings: {
|
|
109
|
+
title: 'Earnings',
|
|
110
|
+
iconName: 'wallet',
|
|
111
|
+
iconType: 'duotone',
|
|
112
|
+
},
|
|
113
|
+
settings: {
|
|
114
|
+
title: 'Settings',
|
|
115
|
+
iconName: 'gear',
|
|
116
|
+
iconType: 'duotone',
|
|
117
|
+
},
|
|
98
118
|
});
|
|
99
119
|
|
|
100
120
|
type ClassNames = $ReadOnly<{wrapper?: string}>;
|