@commercetools-uikit/progress-bar 0.0.0-canary-20240206161325
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/LICENSE +21 -0
- package/README.md +51 -0
- package/dist/commercetools-uikit-progress-bar.cjs.d.ts +3 -0
- package/dist/commercetools-uikit-progress-bar.cjs.dev.js +172 -0
- package/dist/commercetools-uikit-progress-bar.cjs.js +7 -0
- package/dist/commercetools-uikit-progress-bar.cjs.prod.js +160 -0
- package/dist/commercetools-uikit-progress-bar.esm.js +150 -0
- package/dist/declarations/src/export-types.d.ts +1 -0
- package/dist/declarations/src/index.d.ts +3 -0
- package/dist/declarations/src/progress-bar.d.ts +21 -0
- package/dist/declarations/src/version.d.ts +2 -0
- package/package.json +49 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) commercetools GmbH
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
<!-- THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. -->
|
|
2
|
+
<!-- This file is created by the `yarn generate-readme` script. -->
|
|
3
|
+
|
|
4
|
+
# ProgressBar
|
|
5
|
+
|
|
6
|
+
## Description
|
|
7
|
+
|
|
8
|
+
A progress bar component used to visualize the progression of an extended operation
|
|
9
|
+
|
|
10
|
+
## Installation
|
|
11
|
+
|
|
12
|
+
```
|
|
13
|
+
yarn add @commercetools-uikit/progress-bar
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
```
|
|
17
|
+
npm --save install @commercetools-uikit/progress-bar
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Additionally install the peer dependencies (if not present)
|
|
21
|
+
|
|
22
|
+
```
|
|
23
|
+
yarn add react
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
npm --save install react
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
## Usage
|
|
31
|
+
|
|
32
|
+
```jsx
|
|
33
|
+
import ProgressBar from '@commercetools-uikit/progress-bar';
|
|
34
|
+
|
|
35
|
+
const Example = () => <ProgressBar label={`${50}% completed`} progress={50} />;
|
|
36
|
+
|
|
37
|
+
export default Example;
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## Properties
|
|
41
|
+
|
|
42
|
+
| Props | Type | Required | Default | Description |
|
|
43
|
+
| --------------- | ----------------------------------------------------------------------------------------------------------------------------- | :------: | --------- | ---------------------------------------------------------------------------------------------------- |
|
|
44
|
+
| `progress` | `number` | | `0` | The percentage of the task completion to fill the bar. |
|
|
45
|
+
| `label` | `union`<br/>Possible values:<br/>`, string, ReactElement, (MessageDescriptor & { values?: Record<string, ReactNode> }), null` | | `null` | The text to display alongside the bar. |
|
|
46
|
+
| `labelPosition` | `union`<br/>Possible values:<br/>`'top' , 'bottom' , 'left' , 'right'` | | `'top'` | Location of the text in relation to the bar. |
|
|
47
|
+
| `labelWidth` | `union`<br/>Possible values:<br/>`, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | The scale of the width for the label, uses values available in the Constraints.Horizontal component. |
|
|
48
|
+
| `isInverted` | `boolean` | | `false` | Specifies the use of light colors(default) or dark colors. |
|
|
49
|
+
| `isAnimated` | `boolean` | | `true` | Specifies whether the inner bar should have the styles animated. |
|
|
50
|
+
| `height` | `union`<br/>Possible values:<br/>`'10' , '20'` | | `'20'` | The scale of the height for the bar, also affects the styles of the label. |
|
|
51
|
+
| `barWidth` | `union`<br/>Possible values:<br/>`4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 'scale'` | | `6` | The scale of the width for the label, uses values available in the Constraints.Horizontal component. |
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from "./declarations/src/index";
|
|
2
|
+
export { default } from "./declarations/src/index";
|
|
3
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVyY2V0b29scy11aWtpdC1wcm9ncmVzcy1iYXIuY2pzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuL2RlY2xhcmF0aW9ucy9zcmMvaW5kZXguZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSJ9
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
6
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
7
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
8
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
9
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
10
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
11
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
12
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
13
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
var _pt = require('prop-types');
|
|
15
|
+
var reactIntl = require('react-intl');
|
|
16
|
+
var utils = require('@commercetools-uikit/utils');
|
|
17
|
+
var Constraints = require('@commercetools-uikit/constraints');
|
|
18
|
+
var SpacingsInline = require('@commercetools-uikit/spacings-inline');
|
|
19
|
+
var SpacingsStack = require('@commercetools-uikit/spacings-stack');
|
|
20
|
+
var Text = require('@commercetools-uikit/text');
|
|
21
|
+
var isNil = require('lodash/isNil');
|
|
22
|
+
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
23
|
+
var react = require('@emotion/react');
|
|
24
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
25
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
26
|
+
|
|
27
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
28
|
+
|
|
29
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
30
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
31
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
32
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
33
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
34
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
35
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
36
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
37
|
+
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
38
|
+
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
39
|
+
var SpacingsInline__default = /*#__PURE__*/_interopDefault(SpacingsInline);
|
|
40
|
+
var SpacingsStack__default = /*#__PURE__*/_interopDefault(SpacingsStack);
|
|
41
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
42
|
+
var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
43
|
+
|
|
44
|
+
var _templateObject;
|
|
45
|
+
const heightPerScale = {
|
|
46
|
+
'10': designSystem.designTokens.spacing25,
|
|
47
|
+
'20': designSystem.designTokens.spacing40
|
|
48
|
+
};
|
|
49
|
+
const progressPulse = react.keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n 0% {\n background-position: 100% 0;\n }\n 100% {\n background-position: -100% 0;\n }\n"])));
|
|
50
|
+
const getLabelStyles = props => {
|
|
51
|
+
var _props$height;
|
|
52
|
+
return /*#__PURE__*/react.css("min-height:", heightPerScale[(_props$height = props.height) !== null && _props$height !== void 0 ? _props$height : defaultProps.height], ";max-width:", Constraints__default["default"].getMaxPropTokenValue(props.labelWidth || defaultProps.labelWidth), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCUSIsImZpbGUiOiJwcm9ncmVzcy1iYXIuc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHsgZGVmYXVsdFByb3BzLCB0eXBlIFRQcm9ncmVzc0JhclByb3BzIH0gZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuXG5leHBvcnQgY29uc3QgaGVpZ2h0UGVyU2NhbGUgPSB7XG4gICcxMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nMjUsXG4gICcyMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nNDAsXG59O1xuXG5jb25zdCBwcm9ncmVzc1B1bHNlID0ga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgYmFja2dyb3VuZC1wb3NpdGlvbjogMTAwJSAwO1xuICB9XG4gIDEwMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IC0xMDAlIDA7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRMYWJlbFN0eWxlcyA9IChcbiAgcHJvcHM6IFRQcm9ncmVzc0JhclByb3BzICYgeyB0ZXh0QWxpZ25tZW50OiBzdHJpbmcgfVxuKSA9PiBjc3NgXG4gIG1pbi1oZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG1heC13aWR0aDogJHtDb25zdHJhaW50cy5nZXRNYXhQcm9wVG9rZW5WYWx1ZShcbiAgICBwcm9wcy5sYWJlbFdpZHRoIHx8IGRlZmF1bHRQcm9wcy5sYWJlbFdpZHRoIVxuICApfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRCYWNrZ3JvdW5kQmFyU3R5bGVzID0gKHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcykgPT4gY3NzYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcy5pc0ludmVydGVkXG4gICAgPyAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjQpJ1xuICAgIDogZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0Rm9yZWdyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6ICR7cHJvcHMucHJvZ3Jlc3N9JTtcbiAgdHJhbnNpdGlvbjogd2lkdGggNTAwbXMgZWFzZS1pbi1vdXQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZVxuICAgIDogYGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgIzAwRTVDQixcbiAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTI1fSxcbiAgICAgICMwMEU1Q0JcbiAgICApYH07XG4gIGJhY2tncm91bmQtc2l6ZTogMjAwJSAxMDAlO1xuICBhbmltYXRpb246ICR7cHJvcHMuaXNBbmltYXRlZCAmJiAhcHJvcHMuaXNJbnZlcnRlZFxuICAgID8gY3NzYFxuICAgICAgICAke3Byb2dyZXNzUHVsc2V9IDJzIGxpbmVhciBpbmZpbml0ZVxuICAgICAgYFxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuYDtcbiJdfQ== */");
|
|
53
|
+
};
|
|
54
|
+
const getBackgroundBarStyles = props => {
|
|
55
|
+
var _props$height2;
|
|
56
|
+
return /*#__PURE__*/react.css("width:100%;background-color:", props.isInverted ? 'rgba(255, 255, 255, 0.4)' : designSystem.designTokens.colorNeutral90, ";border-radius:", designSystem.designTokens.spacingL, ";height:", heightPerScale[(_props$height2 = props.height) !== null && _props$height2 !== void 0 ? _props$height2 : defaultProps.height], ";overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : ";label:getBackgroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCdUUiLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IENvbnN0cmFpbnRzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NvbnN0cmFpbnRzJztcbmltcG9ydCB7IGRlZmF1bHRQcm9wcywgdHlwZSBUUHJvZ3Jlc3NCYXJQcm9wcyB9IGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcblxuZXhwb3J0IGNvbnN0IGhlaWdodFBlclNjYWxlID0ge1xuICAnMTAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzI1LFxuICAnMjAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzQwLFxufTtcblxuY29uc3QgcHJvZ3Jlc3NQdWxzZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IDEwMCUgMDtcbiAgfVxuICAxMDAlIHtcbiAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAtMTAwJSAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0TGFiZWxTdHlsZXMgPSAoXG4gIHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcyAmIHsgdGV4dEFsaWdubWVudDogc3RyaW5nIH1cbikgPT4gY3NzYFxuICBtaW4taGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBtYXgtd2lkdGg6ICR7Q29uc3RyYWludHMuZ2V0TWF4UHJvcFRva2VuVmFsdWUoXG4gICAgcHJvcHMubGFiZWxXaWR0aCB8fCBkZWZhdWx0UHJvcHMubGFiZWxXaWR0aCFcbiAgKX07XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0QmFja2dyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC40KSdcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZvcmVncm91bmRCYXJTdHlsZXMgPSAocHJvcHM6IFRQcm9ncmVzc0JhclByb3BzKSA9PiBjc3NgXG4gIHdpZHRoOiAke3Byb3BzLnByb2dyZXNzfSU7XG4gIHRyYW5zaXRpb246IHdpZHRoIDUwMG1zIGVhc2UtaW4tb3V0O1xuICBkaXNwbGF5OiBibG9jaztcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGBsaW5lYXItZ3JhZGllbnQoXG4gICAgICB0byByaWdodCxcbiAgICAgICMwMEU1Q0IsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyNX0sXG4gICAgICAjMDBFNUNCXG4gICAgKWB9O1xuICBiYWNrZ3JvdW5kLXNpemU6IDIwMCUgMTAwJTtcbiAgYW5pbWF0aW9uOiAke3Byb3BzLmlzQW5pbWF0ZWQgJiYgIXByb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGNzc2BcbiAgICAgICAgJHtwcm9ncmVzc1B1bHNlfSAycyBsaW5lYXIgaW5maW5pdGVcbiAgICAgIGBcbiAgICA6ICdub25lJ307XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbmA7XG4iXX0= */");
|
|
57
|
+
};
|
|
58
|
+
const getForegroundBarStyles = props => {
|
|
59
|
+
var _props$height3;
|
|
60
|
+
return /*#__PURE__*/react.css("width:", props.progress, "%;transition:width 500ms ease-in-out;display:block;height:", heightPerScale[(_props$height3 = props.height) !== null && _props$height3 !== void 0 ? _props$height3 : defaultProps.height], ";background:", props.isInverted ? designSystem.designTokens.colorSurface : "linear-gradient(\n to right,\n #00E5CB,\n ".concat(designSystem.designTokens.colorPrimary25, ",\n #00E5CB\n )"), ";background-size:200% 100%;animation:", props.isAnimated && !props.isInverted ? /*#__PURE__*/react.css(progressPulse, " 2s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:getForegroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFEUyIsImZpbGUiOiJwcm9ncmVzcy1iYXIuc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHsgZGVmYXVsdFByb3BzLCB0eXBlIFRQcm9ncmVzc0JhclByb3BzIH0gZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuXG5leHBvcnQgY29uc3QgaGVpZ2h0UGVyU2NhbGUgPSB7XG4gICcxMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nMjUsXG4gICcyMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nNDAsXG59O1xuXG5jb25zdCBwcm9ncmVzc1B1bHNlID0ga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgYmFja2dyb3VuZC1wb3NpdGlvbjogMTAwJSAwO1xuICB9XG4gIDEwMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IC0xMDAlIDA7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRMYWJlbFN0eWxlcyA9IChcbiAgcHJvcHM6IFRQcm9ncmVzc0JhclByb3BzICYgeyB0ZXh0QWxpZ25tZW50OiBzdHJpbmcgfVxuKSA9PiBjc3NgXG4gIG1pbi1oZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG1heC13aWR0aDogJHtDb25zdHJhaW50cy5nZXRNYXhQcm9wVG9rZW5WYWx1ZShcbiAgICBwcm9wcy5sYWJlbFdpZHRoIHx8IGRlZmF1bHRQcm9wcy5sYWJlbFdpZHRoIVxuICApfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRCYWNrZ3JvdW5kQmFyU3R5bGVzID0gKHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcykgPT4gY3NzYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcy5pc0ludmVydGVkXG4gICAgPyAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjQpJ1xuICAgIDogZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0Rm9yZWdyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6ICR7cHJvcHMucHJvZ3Jlc3N9JTtcbiAgdHJhbnNpdGlvbjogd2lkdGggNTAwbXMgZWFzZS1pbi1vdXQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZVxuICAgIDogYGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgIzAwRTVDQixcbiAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTI1fSxcbiAgICAgICMwMEU1Q0JcbiAgICApYH07XG4gIGJhY2tncm91bmQtc2l6ZTogMjAwJSAxMDAlO1xuICBhbmltYXRpb246ICR7cHJvcHMuaXNBbmltYXRlZCAmJiAhcHJvcHMuaXNJbnZlcnRlZFxuICAgID8gY3NzYFxuICAgICAgICAke3Byb2dyZXNzUHVsc2V9IDJzIGxpbmVhciBpbmZpbml0ZVxuICAgICAgYFxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuYDtcbiJdfQ== */") : 'none', ";border-radius:", designSystem.designTokens.spacingL, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getForegroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDdUUiLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IENvbnN0cmFpbnRzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NvbnN0cmFpbnRzJztcbmltcG9ydCB7IGRlZmF1bHRQcm9wcywgdHlwZSBUUHJvZ3Jlc3NCYXJQcm9wcyB9IGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcblxuZXhwb3J0IGNvbnN0IGhlaWdodFBlclNjYWxlID0ge1xuICAnMTAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzI1LFxuICAnMjAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzQwLFxufTtcblxuY29uc3QgcHJvZ3Jlc3NQdWxzZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IDEwMCUgMDtcbiAgfVxuICAxMDAlIHtcbiAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAtMTAwJSAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0TGFiZWxTdHlsZXMgPSAoXG4gIHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcyAmIHsgdGV4dEFsaWdubWVudDogc3RyaW5nIH1cbikgPT4gY3NzYFxuICBtaW4taGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBtYXgtd2lkdGg6ICR7Q29uc3RyYWludHMuZ2V0TWF4UHJvcFRva2VuVmFsdWUoXG4gICAgcHJvcHMubGFiZWxXaWR0aCB8fCBkZWZhdWx0UHJvcHMubGFiZWxXaWR0aCFcbiAgKX07XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0QmFja2dyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC40KSdcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZvcmVncm91bmRCYXJTdHlsZXMgPSAocHJvcHM6IFRQcm9ncmVzc0JhclByb3BzKSA9PiBjc3NgXG4gIHdpZHRoOiAke3Byb3BzLnByb2dyZXNzfSU7XG4gIHRyYW5zaXRpb246IHdpZHRoIDUwMG1zIGVhc2UtaW4tb3V0O1xuICBkaXNwbGF5OiBibG9jaztcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGBsaW5lYXItZ3JhZGllbnQoXG4gICAgICB0byByaWdodCxcbiAgICAgICMwMEU1Q0IsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyNX0sXG4gICAgICAjMDBFNUNCXG4gICAgKWB9O1xuICBiYWNrZ3JvdW5kLXNpemU6IDIwMCUgMTAwJTtcbiAgYW5pbWF0aW9uOiAke3Byb3BzLmlzQW5pbWF0ZWQgJiYgIXByb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGNzc2BcbiAgICAgICAgJHtwcm9ncmVzc1B1bHNlfSAycyBsaW5lYXIgaW5maW5pdGVcbiAgICAgIGBcbiAgICA6ICdub25lJ307XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbmA7XG4iXX0= */");
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
64
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
65
|
+
const ProgressBarLabel = props => {
|
|
66
|
+
if (isNil__default["default"](props.label)) return null;
|
|
67
|
+
const TextComponent = props.height !== '10' ? Text__default["default"].Body : Text__default["default"].Detail;
|
|
68
|
+
const textProps = {
|
|
69
|
+
tone: props.isInverted ? 'inverted' : undefined,
|
|
70
|
+
as: props.height !== '10' ? 'span' : undefined,
|
|
71
|
+
fontWegith: props.height !== '10' ? 'medium' : undefined,
|
|
72
|
+
children: props.label.hasOwnProperty('defaultMessage') ? jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.label)) : props.label
|
|
73
|
+
};
|
|
74
|
+
return jsxRuntime.jsx("div", {
|
|
75
|
+
css: getLabelStyles(props),
|
|
76
|
+
children: jsxRuntime.jsx(TextComponent, _objectSpread({}, textProps))
|
|
77
|
+
});
|
|
78
|
+
};
|
|
79
|
+
const Bar = props => {
|
|
80
|
+
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
81
|
+
max: props.barWidth,
|
|
82
|
+
children: jsxRuntime.jsx("div", _objectSpread(_objectSpread({
|
|
83
|
+
css: getBackgroundBarStyles(props),
|
|
84
|
+
role: "progressbar",
|
|
85
|
+
"aria-valuenow": props.progress,
|
|
86
|
+
"aria-label": "Progress bar"
|
|
87
|
+
}, utils.filterAriaAttributes(props)), {}, {
|
|
88
|
+
children: jsxRuntime.jsx("div", {
|
|
89
|
+
css: getForegroundBarStyles(props)
|
|
90
|
+
})
|
|
91
|
+
}))
|
|
92
|
+
});
|
|
93
|
+
};
|
|
94
|
+
const layoutConfigMapping = {
|
|
95
|
+
top: {
|
|
96
|
+
textAlignment: 'center',
|
|
97
|
+
wrappingComponent: SpacingsStack__default["default"]
|
|
98
|
+
},
|
|
99
|
+
bottom: {
|
|
100
|
+
textAlignment: 'center',
|
|
101
|
+
wrappingComponent: SpacingsStack__default["default"]
|
|
102
|
+
},
|
|
103
|
+
left: {
|
|
104
|
+
textAlignment: 'right',
|
|
105
|
+
wrappingComponent: SpacingsInline__default["default"]
|
|
106
|
+
},
|
|
107
|
+
right: {
|
|
108
|
+
textAlignment: 'left',
|
|
109
|
+
wrappingComponent: SpacingsInline__default["default"]
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
const ProgressBar = props => {
|
|
113
|
+
const layoutConfig = layoutConfigMapping[props.labelPosition || 'top'];
|
|
114
|
+
const BarWithProps = jsxRuntime.jsx(Bar, {
|
|
115
|
+
progress: props.progress,
|
|
116
|
+
barWidth: props.barWidth,
|
|
117
|
+
isInverted: props.isInverted,
|
|
118
|
+
height: props.height,
|
|
119
|
+
isAnimated: props.isAnimated
|
|
120
|
+
});
|
|
121
|
+
const LabelWithProps = jsxRuntime.jsx(ProgressBarLabel, {
|
|
122
|
+
label: props.label,
|
|
123
|
+
labelWidth: props.labelWidth,
|
|
124
|
+
labelPosition: props.labelPosition,
|
|
125
|
+
isInverted: props.isInverted,
|
|
126
|
+
height: props.height,
|
|
127
|
+
textAlignment: layoutConfig.textAlignment
|
|
128
|
+
});
|
|
129
|
+
const WrappingComponent = layoutConfig.wrappingComponent;
|
|
130
|
+
let firstComponent = LabelWithProps;
|
|
131
|
+
let secondComponent = BarWithProps;
|
|
132
|
+
if (props.labelPosition === 'right' || props.labelPosition === 'bottom') {
|
|
133
|
+
firstComponent = BarWithProps;
|
|
134
|
+
secondComponent = LabelWithProps;
|
|
135
|
+
}
|
|
136
|
+
return jsxRuntime.jsxs(WrappingComponent, {
|
|
137
|
+
scale: props.height === '20' ? 'm' : 's',
|
|
138
|
+
alignItems: "center",
|
|
139
|
+
children: [firstComponent, secondComponent]
|
|
140
|
+
});
|
|
141
|
+
};
|
|
142
|
+
ProgressBar.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
143
|
+
progress: _pt__default["default"].number,
|
|
144
|
+
label: _pt__default["default"].oneOfType([_pt__default["default"].string, _pt__default["default"].element, _pt__default["default"].oneOfType([_pt__default["default"].any, _pt__default["default"].shape({
|
|
145
|
+
values: _pt__default["default"].objectOf(_pt__default["default"].node)
|
|
146
|
+
})]), _pt__default["default"].oneOf([null])]),
|
|
147
|
+
labelPosition: _pt__default["default"].oneOf(['top', 'bottom', 'left', 'right']),
|
|
148
|
+
labelWidth: _pt__default["default"].oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
149
|
+
isInverted: _pt__default["default"].bool,
|
|
150
|
+
isAnimated: _pt__default["default"].bool,
|
|
151
|
+
height: _pt__default["default"].oneOf(['10', '20']),
|
|
152
|
+
barWidth: _pt__default["default"].oneOf([4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale'])
|
|
153
|
+
} : {};
|
|
154
|
+
const defaultProps = {
|
|
155
|
+
progress: 0,
|
|
156
|
+
label: null,
|
|
157
|
+
labelPosition: 'top',
|
|
158
|
+
labelWidth: 'scale',
|
|
159
|
+
isInverted: false,
|
|
160
|
+
isAnimated: true,
|
|
161
|
+
height: '20',
|
|
162
|
+
barWidth: 6
|
|
163
|
+
};
|
|
164
|
+
ProgressBar.displayName = 'ProgressBar';
|
|
165
|
+
ProgressBar.defaultProps = defaultProps;
|
|
166
|
+
var ProgressBar$1 = ProgressBar;
|
|
167
|
+
|
|
168
|
+
// NOTE: This string will be replaced on build time with the package version.
|
|
169
|
+
var version = "17.0.0";
|
|
170
|
+
|
|
171
|
+
exports["default"] = ProgressBar$1;
|
|
172
|
+
exports.version = version;
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
6
|
+
var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
|
|
7
|
+
var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
|
|
8
|
+
var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
|
|
9
|
+
var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
|
|
10
|
+
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
11
|
+
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
12
|
+
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
13
|
+
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
14
|
+
require('prop-types');
|
|
15
|
+
var reactIntl = require('react-intl');
|
|
16
|
+
var utils = require('@commercetools-uikit/utils');
|
|
17
|
+
var Constraints = require('@commercetools-uikit/constraints');
|
|
18
|
+
var SpacingsInline = require('@commercetools-uikit/spacings-inline');
|
|
19
|
+
var SpacingsStack = require('@commercetools-uikit/spacings-stack');
|
|
20
|
+
var Text = require('@commercetools-uikit/text');
|
|
21
|
+
var isNil = require('lodash/isNil');
|
|
22
|
+
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
23
|
+
var react = require('@emotion/react');
|
|
24
|
+
var designSystem = require('@commercetools-uikit/design-system');
|
|
25
|
+
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
26
|
+
|
|
27
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
|
|
28
|
+
|
|
29
|
+
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
30
|
+
var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
|
|
31
|
+
var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
|
|
32
|
+
var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
|
|
33
|
+
var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
|
|
34
|
+
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
35
|
+
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
36
|
+
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
37
|
+
var Constraints__default = /*#__PURE__*/_interopDefault(Constraints);
|
|
38
|
+
var SpacingsInline__default = /*#__PURE__*/_interopDefault(SpacingsInline);
|
|
39
|
+
var SpacingsStack__default = /*#__PURE__*/_interopDefault(SpacingsStack);
|
|
40
|
+
var Text__default = /*#__PURE__*/_interopDefault(Text);
|
|
41
|
+
var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
42
|
+
|
|
43
|
+
var _templateObject;
|
|
44
|
+
const heightPerScale = {
|
|
45
|
+
'10': designSystem.designTokens.spacing25,
|
|
46
|
+
'20': designSystem.designTokens.spacing40
|
|
47
|
+
};
|
|
48
|
+
const progressPulse = react.keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n 0% {\n background-position: 100% 0;\n }\n 100% {\n background-position: -100% 0;\n }\n"])));
|
|
49
|
+
const getLabelStyles = props => {
|
|
50
|
+
var _props$height;
|
|
51
|
+
return /*#__PURE__*/react.css("min-height:", heightPerScale[(_props$height = props.height) !== null && _props$height !== void 0 ? _props$height : defaultProps.height], ";max-width:", Constraints__default["default"].getMaxPropTokenValue(props.labelWidth || defaultProps.labelWidth), ";" + ("" ), "" );
|
|
52
|
+
};
|
|
53
|
+
const getBackgroundBarStyles = props => {
|
|
54
|
+
var _props$height2;
|
|
55
|
+
return /*#__PURE__*/react.css("width:100%;background-color:", props.isInverted ? 'rgba(255, 255, 255, 0.4)' : designSystem.designTokens.colorNeutral90, ";border-radius:", designSystem.designTokens.spacingL, ";height:", heightPerScale[(_props$height2 = props.height) !== null && _props$height2 !== void 0 ? _props$height2 : defaultProps.height], ";overflow:hidden;" + ("" ), "" );
|
|
56
|
+
};
|
|
57
|
+
const getForegroundBarStyles = props => {
|
|
58
|
+
var _props$height3;
|
|
59
|
+
return /*#__PURE__*/react.css("width:", props.progress, "%;transition:width 500ms ease-in-out;display:block;height:", heightPerScale[(_props$height3 = props.height) !== null && _props$height3 !== void 0 ? _props$height3 : defaultProps.height], ";background:", props.isInverted ? designSystem.designTokens.colorSurface : "linear-gradient(\n to right,\n #00E5CB,\n ".concat(designSystem.designTokens.colorPrimary25, ",\n #00E5CB\n )"), ";background-size:200% 100%;animation:", props.isAnimated && !props.isInverted ? /*#__PURE__*/react.css(progressPulse, " 2s linear infinite;" + ("" ), "" ) : 'none', ";border-radius:", designSystem.designTokens.spacingL, ";" + ("" ), "" );
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
63
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
|
|
64
|
+
const ProgressBarLabel = props => {
|
|
65
|
+
if (isNil__default["default"](props.label)) return null;
|
|
66
|
+
const TextComponent = props.height !== '10' ? Text__default["default"].Body : Text__default["default"].Detail;
|
|
67
|
+
const textProps = {
|
|
68
|
+
tone: props.isInverted ? 'inverted' : undefined,
|
|
69
|
+
as: props.height !== '10' ? 'span' : undefined,
|
|
70
|
+
fontWegith: props.height !== '10' ? 'medium' : undefined,
|
|
71
|
+
children: props.label.hasOwnProperty('defaultMessage') ? jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread({}, props.label)) : props.label
|
|
72
|
+
};
|
|
73
|
+
return jsxRuntime.jsx("div", {
|
|
74
|
+
css: getLabelStyles(props),
|
|
75
|
+
children: jsxRuntime.jsx(TextComponent, _objectSpread({}, textProps))
|
|
76
|
+
});
|
|
77
|
+
};
|
|
78
|
+
const Bar = props => {
|
|
79
|
+
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
80
|
+
max: props.barWidth,
|
|
81
|
+
children: jsxRuntime.jsx("div", _objectSpread(_objectSpread({
|
|
82
|
+
css: getBackgroundBarStyles(props),
|
|
83
|
+
role: "progressbar",
|
|
84
|
+
"aria-valuenow": props.progress,
|
|
85
|
+
"aria-label": "Progress bar"
|
|
86
|
+
}, utils.filterAriaAttributes(props)), {}, {
|
|
87
|
+
children: jsxRuntime.jsx("div", {
|
|
88
|
+
css: getForegroundBarStyles(props)
|
|
89
|
+
})
|
|
90
|
+
}))
|
|
91
|
+
});
|
|
92
|
+
};
|
|
93
|
+
const layoutConfigMapping = {
|
|
94
|
+
top: {
|
|
95
|
+
textAlignment: 'center',
|
|
96
|
+
wrappingComponent: SpacingsStack__default["default"]
|
|
97
|
+
},
|
|
98
|
+
bottom: {
|
|
99
|
+
textAlignment: 'center',
|
|
100
|
+
wrappingComponent: SpacingsStack__default["default"]
|
|
101
|
+
},
|
|
102
|
+
left: {
|
|
103
|
+
textAlignment: 'right',
|
|
104
|
+
wrappingComponent: SpacingsInline__default["default"]
|
|
105
|
+
},
|
|
106
|
+
right: {
|
|
107
|
+
textAlignment: 'left',
|
|
108
|
+
wrappingComponent: SpacingsInline__default["default"]
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
const ProgressBar = props => {
|
|
112
|
+
const layoutConfig = layoutConfigMapping[props.labelPosition || 'top'];
|
|
113
|
+
const BarWithProps = jsxRuntime.jsx(Bar, {
|
|
114
|
+
progress: props.progress,
|
|
115
|
+
barWidth: props.barWidth,
|
|
116
|
+
isInverted: props.isInverted,
|
|
117
|
+
height: props.height,
|
|
118
|
+
isAnimated: props.isAnimated
|
|
119
|
+
});
|
|
120
|
+
const LabelWithProps = jsxRuntime.jsx(ProgressBarLabel, {
|
|
121
|
+
label: props.label,
|
|
122
|
+
labelWidth: props.labelWidth,
|
|
123
|
+
labelPosition: props.labelPosition,
|
|
124
|
+
isInverted: props.isInverted,
|
|
125
|
+
height: props.height,
|
|
126
|
+
textAlignment: layoutConfig.textAlignment
|
|
127
|
+
});
|
|
128
|
+
const WrappingComponent = layoutConfig.wrappingComponent;
|
|
129
|
+
let firstComponent = LabelWithProps;
|
|
130
|
+
let secondComponent = BarWithProps;
|
|
131
|
+
if (props.labelPosition === 'right' || props.labelPosition === 'bottom') {
|
|
132
|
+
firstComponent = BarWithProps;
|
|
133
|
+
secondComponent = LabelWithProps;
|
|
134
|
+
}
|
|
135
|
+
return jsxRuntime.jsxs(WrappingComponent, {
|
|
136
|
+
scale: props.height === '20' ? 'm' : 's',
|
|
137
|
+
alignItems: "center",
|
|
138
|
+
children: [firstComponent, secondComponent]
|
|
139
|
+
});
|
|
140
|
+
};
|
|
141
|
+
ProgressBar.propTypes = {};
|
|
142
|
+
const defaultProps = {
|
|
143
|
+
progress: 0,
|
|
144
|
+
label: null,
|
|
145
|
+
labelPosition: 'top',
|
|
146
|
+
labelWidth: 'scale',
|
|
147
|
+
isInverted: false,
|
|
148
|
+
isAnimated: true,
|
|
149
|
+
height: '20',
|
|
150
|
+
barWidth: 6
|
|
151
|
+
};
|
|
152
|
+
ProgressBar.displayName = 'ProgressBar';
|
|
153
|
+
ProgressBar.defaultProps = defaultProps;
|
|
154
|
+
var ProgressBar$1 = ProgressBar;
|
|
155
|
+
|
|
156
|
+
// NOTE: This string will be replaced on build time with the package version.
|
|
157
|
+
var version = "17.0.0";
|
|
158
|
+
|
|
159
|
+
exports["default"] = ProgressBar$1;
|
|
160
|
+
exports.version = version;
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
2
|
+
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
3
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
4
|
+
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
5
|
+
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
6
|
+
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
7
|
+
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
8
|
+
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
9
|
+
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
|
+
import _pt from 'prop-types';
|
|
11
|
+
import { FormattedMessage } from 'react-intl';
|
|
12
|
+
import { filterAriaAttributes } from '@commercetools-uikit/utils';
|
|
13
|
+
import Constraints from '@commercetools-uikit/constraints';
|
|
14
|
+
import SpacingsInline from '@commercetools-uikit/spacings-inline';
|
|
15
|
+
import SpacingsStack from '@commercetools-uikit/spacings-stack';
|
|
16
|
+
import Text from '@commercetools-uikit/text';
|
|
17
|
+
import isNil from 'lodash/isNil';
|
|
18
|
+
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
19
|
+
import { keyframes, css } from '@emotion/react';
|
|
20
|
+
import { designTokens } from '@commercetools-uikit/design-system';
|
|
21
|
+
import { jsx, jsxs } from '@emotion/react/jsx-runtime';
|
|
22
|
+
|
|
23
|
+
var _templateObject;
|
|
24
|
+
const heightPerScale = {
|
|
25
|
+
'10': designTokens.spacing25,
|
|
26
|
+
'20': designTokens.spacing40
|
|
27
|
+
};
|
|
28
|
+
const progressPulse = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n 0% {\n background-position: 100% 0;\n }\n 100% {\n background-position: -100% 0;\n }\n"])));
|
|
29
|
+
const getLabelStyles = props => {
|
|
30
|
+
var _props$height;
|
|
31
|
+
return /*#__PURE__*/css("min-height:", heightPerScale[(_props$height = props.height) !== null && _props$height !== void 0 ? _props$height : defaultProps.height], ";max-width:", Constraints.getMaxPropTokenValue(props.labelWidth || defaultProps.labelWidth), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getLabelStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCUSIsImZpbGUiOiJwcm9ncmVzcy1iYXIuc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHsgZGVmYXVsdFByb3BzLCB0eXBlIFRQcm9ncmVzc0JhclByb3BzIH0gZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuXG5leHBvcnQgY29uc3QgaGVpZ2h0UGVyU2NhbGUgPSB7XG4gICcxMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nMjUsXG4gICcyMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nNDAsXG59O1xuXG5jb25zdCBwcm9ncmVzc1B1bHNlID0ga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgYmFja2dyb3VuZC1wb3NpdGlvbjogMTAwJSAwO1xuICB9XG4gIDEwMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IC0xMDAlIDA7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRMYWJlbFN0eWxlcyA9IChcbiAgcHJvcHM6IFRQcm9ncmVzc0JhclByb3BzICYgeyB0ZXh0QWxpZ25tZW50OiBzdHJpbmcgfVxuKSA9PiBjc3NgXG4gIG1pbi1oZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG1heC13aWR0aDogJHtDb25zdHJhaW50cy5nZXRNYXhQcm9wVG9rZW5WYWx1ZShcbiAgICBwcm9wcy5sYWJlbFdpZHRoIHx8IGRlZmF1bHRQcm9wcy5sYWJlbFdpZHRoIVxuICApfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRCYWNrZ3JvdW5kQmFyU3R5bGVzID0gKHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcykgPT4gY3NzYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcy5pc0ludmVydGVkXG4gICAgPyAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjQpJ1xuICAgIDogZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0Rm9yZWdyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6ICR7cHJvcHMucHJvZ3Jlc3N9JTtcbiAgdHJhbnNpdGlvbjogd2lkdGggNTAwbXMgZWFzZS1pbi1vdXQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZVxuICAgIDogYGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgIzAwRTVDQixcbiAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTI1fSxcbiAgICAgICMwMEU1Q0JcbiAgICApYH07XG4gIGJhY2tncm91bmQtc2l6ZTogMjAwJSAxMDAlO1xuICBhbmltYXRpb246ICR7cHJvcHMuaXNBbmltYXRlZCAmJiAhcHJvcHMuaXNJbnZlcnRlZFxuICAgID8gY3NzYFxuICAgICAgICAke3Byb2dyZXNzUHVsc2V9IDJzIGxpbmVhciBpbmZpbml0ZVxuICAgICAgYFxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuYDtcbiJdfQ== */");
|
|
32
|
+
};
|
|
33
|
+
const getBackgroundBarStyles = props => {
|
|
34
|
+
var _props$height2;
|
|
35
|
+
return /*#__PURE__*/css("width:100%;background-color:", props.isInverted ? 'rgba(255, 255, 255, 0.4)' : designTokens.colorNeutral90, ";border-radius:", designTokens.spacingL, ";height:", heightPerScale[(_props$height2 = props.height) !== null && _props$height2 !== void 0 ? _props$height2 : defaultProps.height], ";overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : ";label:getBackgroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCdUUiLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IENvbnN0cmFpbnRzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NvbnN0cmFpbnRzJztcbmltcG9ydCB7IGRlZmF1bHRQcm9wcywgdHlwZSBUUHJvZ3Jlc3NCYXJQcm9wcyB9IGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcblxuZXhwb3J0IGNvbnN0IGhlaWdodFBlclNjYWxlID0ge1xuICAnMTAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzI1LFxuICAnMjAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzQwLFxufTtcblxuY29uc3QgcHJvZ3Jlc3NQdWxzZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IDEwMCUgMDtcbiAgfVxuICAxMDAlIHtcbiAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAtMTAwJSAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0TGFiZWxTdHlsZXMgPSAoXG4gIHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcyAmIHsgdGV4dEFsaWdubWVudDogc3RyaW5nIH1cbikgPT4gY3NzYFxuICBtaW4taGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBtYXgtd2lkdGg6ICR7Q29uc3RyYWludHMuZ2V0TWF4UHJvcFRva2VuVmFsdWUoXG4gICAgcHJvcHMubGFiZWxXaWR0aCB8fCBkZWZhdWx0UHJvcHMubGFiZWxXaWR0aCFcbiAgKX07XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0QmFja2dyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC40KSdcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZvcmVncm91bmRCYXJTdHlsZXMgPSAocHJvcHM6IFRQcm9ncmVzc0JhclByb3BzKSA9PiBjc3NgXG4gIHdpZHRoOiAke3Byb3BzLnByb2dyZXNzfSU7XG4gIHRyYW5zaXRpb246IHdpZHRoIDUwMG1zIGVhc2UtaW4tb3V0O1xuICBkaXNwbGF5OiBibG9jaztcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGBsaW5lYXItZ3JhZGllbnQoXG4gICAgICB0byByaWdodCxcbiAgICAgICMwMEU1Q0IsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyNX0sXG4gICAgICAjMDBFNUNCXG4gICAgKWB9O1xuICBiYWNrZ3JvdW5kLXNpemU6IDIwMCUgMTAwJTtcbiAgYW5pbWF0aW9uOiAke3Byb3BzLmlzQW5pbWF0ZWQgJiYgIXByb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGNzc2BcbiAgICAgICAgJHtwcm9ncmVzc1B1bHNlfSAycyBsaW5lYXIgaW5maW5pdGVcbiAgICAgIGBcbiAgICA6ICdub25lJ307XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbmA7XG4iXX0= */");
|
|
36
|
+
};
|
|
37
|
+
const getForegroundBarStyles = props => {
|
|
38
|
+
var _props$height3;
|
|
39
|
+
return /*#__PURE__*/css("width:", props.progress, "%;transition:width 500ms ease-in-out;display:block;height:", heightPerScale[(_props$height3 = props.height) !== null && _props$height3 !== void 0 ? _props$height3 : defaultProps.height], ";background:", props.isInverted ? designTokens.colorSurface : "linear-gradient(\n to right,\n #00E5CB,\n ".concat(designTokens.colorPrimary25, ",\n #00E5CB\n )"), ";background-size:200% 100%;animation:", props.isAnimated && !props.isInverted ? /*#__PURE__*/css(progressPulse, " 2s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:getForegroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFEUyIsImZpbGUiOiJwcm9ncmVzcy1iYXIuc3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgQ29uc3RyYWludHMgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvY29uc3RyYWludHMnO1xuaW1wb3J0IHsgZGVmYXVsdFByb3BzLCB0eXBlIFRQcm9ncmVzc0JhclByb3BzIH0gZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuXG5leHBvcnQgY29uc3QgaGVpZ2h0UGVyU2NhbGUgPSB7XG4gICcxMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nMjUsXG4gICcyMCc6IGRlc2lnblRva2Vucy5zcGFjaW5nNDAsXG59O1xuXG5jb25zdCBwcm9ncmVzc1B1bHNlID0ga2V5ZnJhbWVzYFxuICAwJSB7XG4gICAgYmFja2dyb3VuZC1wb3NpdGlvbjogMTAwJSAwO1xuICB9XG4gIDEwMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IC0xMDAlIDA7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRMYWJlbFN0eWxlcyA9IChcbiAgcHJvcHM6IFRQcm9ncmVzc0JhclByb3BzICYgeyB0ZXh0QWxpZ25tZW50OiBzdHJpbmcgfVxuKSA9PiBjc3NgXG4gIG1pbi1oZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG1heC13aWR0aDogJHtDb25zdHJhaW50cy5nZXRNYXhQcm9wVG9rZW5WYWx1ZShcbiAgICBwcm9wcy5sYWJlbFdpZHRoIHx8IGRlZmF1bHRQcm9wcy5sYWJlbFdpZHRoIVxuICApfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBnZXRCYWNrZ3JvdW5kQmFyU3R5bGVzID0gKHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcykgPT4gY3NzYFxuICB3aWR0aDogMTAwJTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtwcm9wcy5pc0ludmVydGVkXG4gICAgPyAncmdiYSgyNTUsIDI1NSwgMjU1LCAwLjQpJ1xuICAgIDogZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0Rm9yZWdyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6ICR7cHJvcHMucHJvZ3Jlc3N9JTtcbiAgdHJhbnNpdGlvbjogd2lkdGggNTAwbXMgZWFzZS1pbi1vdXQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBoZWlnaHQ6ICR7aGVpZ2h0UGVyU2NhbGVbcHJvcHMuaGVpZ2h0ID8/IGRlZmF1bHRQcm9wcy5oZWlnaHQhXX07XG4gIGJhY2tncm91bmQ6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZVxuICAgIDogYGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgIzAwRTVDQixcbiAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTI1fSxcbiAgICAgICMwMEU1Q0JcbiAgICApYH07XG4gIGJhY2tncm91bmQtc2l6ZTogMjAwJSAxMDAlO1xuICBhbmltYXRpb246ICR7cHJvcHMuaXNBbmltYXRlZCAmJiAhcHJvcHMuaXNJbnZlcnRlZFxuICAgID8gY3NzYFxuICAgICAgICAke3Byb2dyZXNzUHVsc2V9IDJzIGxpbmVhciBpbmZpbml0ZVxuICAgICAgYFxuICAgIDogJ25vbmUnfTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZ0x9O1xuYDtcbiJdfQ== */") : 'none', ";border-radius:", designTokens.spacingL, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getForegroundBarStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInByb2dyZXNzLWJhci5zdHlsZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDdUUiLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLnN0eWxlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIGtleWZyYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IENvbnN0cmFpbnRzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2NvbnN0cmFpbnRzJztcbmltcG9ydCB7IGRlZmF1bHRQcm9wcywgdHlwZSBUUHJvZ3Jlc3NCYXJQcm9wcyB9IGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcblxuZXhwb3J0IGNvbnN0IGhlaWdodFBlclNjYWxlID0ge1xuICAnMTAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzI1LFxuICAnMjAnOiBkZXNpZ25Ub2tlbnMuc3BhY2luZzQwLFxufTtcblxuY29uc3QgcHJvZ3Jlc3NQdWxzZSA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIGJhY2tncm91bmQtcG9zaXRpb246IDEwMCUgMDtcbiAgfVxuICAxMDAlIHtcbiAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAtMTAwJSAwO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0TGFiZWxTdHlsZXMgPSAoXG4gIHByb3BzOiBUUHJvZ3Jlc3NCYXJQcm9wcyAmIHsgdGV4dEFsaWdubWVudDogc3RyaW5nIH1cbikgPT4gY3NzYFxuICBtaW4taGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBtYXgtd2lkdGg6ICR7Q29uc3RyYWludHMuZ2V0TWF4UHJvcFRva2VuVmFsdWUoXG4gICAgcHJvcHMubGFiZWxXaWR0aCB8fCBkZWZhdWx0UHJvcHMubGFiZWxXaWR0aCFcbiAgKX07XG5gO1xuXG5leHBvcnQgY29uc3QgZ2V0QmFja2dyb3VuZEJhclN0eWxlcyA9IChwcm9wczogVFByb2dyZXNzQmFyUHJvcHMpID0+IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMuaXNJbnZlcnRlZFxuICAgID8gJ3JnYmEoMjU1LCAyNTUsIDI1NSwgMC40KSdcbiAgICA6IGRlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZvcmVncm91bmRCYXJTdHlsZXMgPSAocHJvcHM6IFRQcm9ncmVzc0JhclByb3BzKSA9PiBjc3NgXG4gIHdpZHRoOiAke3Byb3BzLnByb2dyZXNzfSU7XG4gIHRyYW5zaXRpb246IHdpZHRoIDUwMG1zIGVhc2UtaW4tb3V0O1xuICBkaXNwbGF5OiBibG9jaztcbiAgaGVpZ2h0OiAke2hlaWdodFBlclNjYWxlW3Byb3BzLmhlaWdodCA/PyBkZWZhdWx0UHJvcHMuaGVpZ2h0IV19O1xuICBiYWNrZ3JvdW5kOiAke3Byb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGRlc2lnblRva2Vucy5jb2xvclN1cmZhY2VcbiAgICA6IGBsaW5lYXItZ3JhZGllbnQoXG4gICAgICB0byByaWdodCxcbiAgICAgICMwMEU1Q0IsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyNX0sXG4gICAgICAjMDBFNUNCXG4gICAgKWB9O1xuICBiYWNrZ3JvdW5kLXNpemU6IDIwMCUgMTAwJTtcbiAgYW5pbWF0aW9uOiAke3Byb3BzLmlzQW5pbWF0ZWQgJiYgIXByb3BzLmlzSW52ZXJ0ZWRcbiAgICA/IGNzc2BcbiAgICAgICAgJHtwcm9ncmVzc1B1bHNlfSAycyBsaW5lYXIgaW5maW5pdGVcbiAgICAgIGBcbiAgICA6ICdub25lJ307XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmdMfTtcbmA7XG4iXX0= */");
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
43
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
44
|
+
const ProgressBarLabel = props => {
|
|
45
|
+
if (isNil(props.label)) return null;
|
|
46
|
+
const TextComponent = props.height !== '10' ? Text.Body : Text.Detail;
|
|
47
|
+
const textProps = {
|
|
48
|
+
tone: props.isInverted ? 'inverted' : undefined,
|
|
49
|
+
as: props.height !== '10' ? 'span' : undefined,
|
|
50
|
+
fontWegith: props.height !== '10' ? 'medium' : undefined,
|
|
51
|
+
children: props.label.hasOwnProperty('defaultMessage') ? jsx(FormattedMessage, _objectSpread({}, props.label)) : props.label
|
|
52
|
+
};
|
|
53
|
+
return jsx("div", {
|
|
54
|
+
css: getLabelStyles(props),
|
|
55
|
+
children: jsx(TextComponent, _objectSpread({}, textProps))
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
const Bar = props => {
|
|
59
|
+
return jsx(Constraints.Horizontal, {
|
|
60
|
+
max: props.barWidth,
|
|
61
|
+
children: jsx("div", _objectSpread(_objectSpread({
|
|
62
|
+
css: getBackgroundBarStyles(props),
|
|
63
|
+
role: "progressbar",
|
|
64
|
+
"aria-valuenow": props.progress,
|
|
65
|
+
"aria-label": "Progress bar"
|
|
66
|
+
}, filterAriaAttributes(props)), {}, {
|
|
67
|
+
children: jsx("div", {
|
|
68
|
+
css: getForegroundBarStyles(props)
|
|
69
|
+
})
|
|
70
|
+
}))
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
const layoutConfigMapping = {
|
|
74
|
+
top: {
|
|
75
|
+
textAlignment: 'center',
|
|
76
|
+
wrappingComponent: SpacingsStack
|
|
77
|
+
},
|
|
78
|
+
bottom: {
|
|
79
|
+
textAlignment: 'center',
|
|
80
|
+
wrappingComponent: SpacingsStack
|
|
81
|
+
},
|
|
82
|
+
left: {
|
|
83
|
+
textAlignment: 'right',
|
|
84
|
+
wrappingComponent: SpacingsInline
|
|
85
|
+
},
|
|
86
|
+
right: {
|
|
87
|
+
textAlignment: 'left',
|
|
88
|
+
wrappingComponent: SpacingsInline
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
const ProgressBar = props => {
|
|
92
|
+
const layoutConfig = layoutConfigMapping[props.labelPosition || 'top'];
|
|
93
|
+
const BarWithProps = jsx(Bar, {
|
|
94
|
+
progress: props.progress,
|
|
95
|
+
barWidth: props.barWidth,
|
|
96
|
+
isInverted: props.isInverted,
|
|
97
|
+
height: props.height,
|
|
98
|
+
isAnimated: props.isAnimated
|
|
99
|
+
});
|
|
100
|
+
const LabelWithProps = jsx(ProgressBarLabel, {
|
|
101
|
+
label: props.label,
|
|
102
|
+
labelWidth: props.labelWidth,
|
|
103
|
+
labelPosition: props.labelPosition,
|
|
104
|
+
isInverted: props.isInverted,
|
|
105
|
+
height: props.height,
|
|
106
|
+
textAlignment: layoutConfig.textAlignment
|
|
107
|
+
});
|
|
108
|
+
const WrappingComponent = layoutConfig.wrappingComponent;
|
|
109
|
+
let firstComponent = LabelWithProps;
|
|
110
|
+
let secondComponent = BarWithProps;
|
|
111
|
+
if (props.labelPosition === 'right' || props.labelPosition === 'bottom') {
|
|
112
|
+
firstComponent = BarWithProps;
|
|
113
|
+
secondComponent = LabelWithProps;
|
|
114
|
+
}
|
|
115
|
+
return jsxs(WrappingComponent, {
|
|
116
|
+
scale: props.height === '20' ? 'm' : 's',
|
|
117
|
+
alignItems: "center",
|
|
118
|
+
children: [firstComponent, secondComponent]
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
ProgressBar.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
122
|
+
progress: _pt.number,
|
|
123
|
+
label: _pt.oneOfType([_pt.string, _pt.element, _pt.oneOfType([_pt.any, _pt.shape({
|
|
124
|
+
values: _pt.objectOf(_pt.node)
|
|
125
|
+
})]), _pt.oneOf([null])]),
|
|
126
|
+
labelPosition: _pt.oneOf(['top', 'bottom', 'left', 'right']),
|
|
127
|
+
labelWidth: _pt.oneOf([6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto']),
|
|
128
|
+
isInverted: _pt.bool,
|
|
129
|
+
isAnimated: _pt.bool,
|
|
130
|
+
height: _pt.oneOf(['10', '20']),
|
|
131
|
+
barWidth: _pt.oneOf([4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale'])
|
|
132
|
+
} : {};
|
|
133
|
+
const defaultProps = {
|
|
134
|
+
progress: 0,
|
|
135
|
+
label: null,
|
|
136
|
+
labelPosition: 'top',
|
|
137
|
+
labelWidth: 'scale',
|
|
138
|
+
isInverted: false,
|
|
139
|
+
isAnimated: true,
|
|
140
|
+
height: '20',
|
|
141
|
+
barWidth: 6
|
|
142
|
+
};
|
|
143
|
+
ProgressBar.displayName = 'ProgressBar';
|
|
144
|
+
ProgressBar.defaultProps = defaultProps;
|
|
145
|
+
var ProgressBar$1 = ProgressBar;
|
|
146
|
+
|
|
147
|
+
// NOTE: This string will be replaced on build time with the package version.
|
|
148
|
+
var version = "17.0.0";
|
|
149
|
+
|
|
150
|
+
export { ProgressBar$1 as default, version };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type { TProgressBarProps } from "./progress-bar.js";
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { ReactElement, ReactNode } from 'react';
|
|
2
|
+
import { type MessageDescriptor } from 'react-intl';
|
|
3
|
+
export type TProgressBarProps = {
|
|
4
|
+
progress?: number;
|
|
5
|
+
label?: string | ReactElement | (MessageDescriptor & {
|
|
6
|
+
values?: Record<string, ReactNode>;
|
|
7
|
+
}) | null;
|
|
8
|
+
labelPosition?: 'top' | 'bottom' | 'left' | 'right';
|
|
9
|
+
labelWidth?: 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
10
|
+
isInverted?: boolean;
|
|
11
|
+
isAnimated?: boolean;
|
|
12
|
+
height?: '10' | '20';
|
|
13
|
+
barWidth?: 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale';
|
|
14
|
+
};
|
|
15
|
+
declare const ProgressBar: {
|
|
16
|
+
(props: TProgressBarProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
17
|
+
displayName: string;
|
|
18
|
+
defaultProps: TProgressBarProps;
|
|
19
|
+
};
|
|
20
|
+
export declare const defaultProps: TProgressBarProps;
|
|
21
|
+
export default ProgressBar;
|
package/package.json
ADDED
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@commercetools-uikit/progress-bar",
|
|
3
|
+
"description": "A progress bar component used to visualize the progression of an extended operation",
|
|
4
|
+
"version": "0.0.0-canary-20240206161325",
|
|
5
|
+
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "https://github.com/commercetools/ui-kit.git",
|
|
9
|
+
"directory": "packages/components/progress-bar"
|
|
10
|
+
},
|
|
11
|
+
"homepage": "https://uikit.commercetools.com",
|
|
12
|
+
"keywords": [
|
|
13
|
+
"javascript",
|
|
14
|
+
"typescript",
|
|
15
|
+
"design-system",
|
|
16
|
+
"react",
|
|
17
|
+
"uikit"
|
|
18
|
+
],
|
|
19
|
+
"license": "MIT",
|
|
20
|
+
"publishConfig": {
|
|
21
|
+
"access": "public"
|
|
22
|
+
},
|
|
23
|
+
"sideEffects": false,
|
|
24
|
+
"main": "dist/commercetools-uikit-progress-bar.cjs.js",
|
|
25
|
+
"module": "dist/commercetools-uikit-progress-bar.esm.js",
|
|
26
|
+
"files": [
|
|
27
|
+
"dist"
|
|
28
|
+
],
|
|
29
|
+
"dependencies": {
|
|
30
|
+
"@babel/runtime": "^7.20.13",
|
|
31
|
+
"@babel/runtime-corejs3": "^7.20.13",
|
|
32
|
+
"@commercetools-uikit/constraints": "0.0.0-canary-20240206161325",
|
|
33
|
+
"@commercetools-uikit/design-system": "0.0.0-canary-20240206161325",
|
|
34
|
+
"@commercetools-uikit/spacings-inline": "0.0.0-canary-20240206161325",
|
|
35
|
+
"@commercetools-uikit/spacings-stack": "0.0.0-canary-20240206161325",
|
|
36
|
+
"@commercetools-uikit/text": "0.0.0-canary-20240206161325",
|
|
37
|
+
"@commercetools-uikit/utils": "0.0.0-canary-20240206161325",
|
|
38
|
+
"@emotion/react": "^11.10.5",
|
|
39
|
+
"lodash": "4.17.21",
|
|
40
|
+
"prop-types": "15.8.1",
|
|
41
|
+
"react-intl": "^6.3.2"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"react": "17.0.2"
|
|
45
|
+
},
|
|
46
|
+
"peerDependencies": {
|
|
47
|
+
"react": "17.x"
|
|
48
|
+
}
|
|
49
|
+
}
|