@drivy/cobalt 0.31.2 → 0.31.3
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/components/BasicCell/index.js +4 -2
- package/components/BasicCell/index.js.map +1 -1
- package/components/ProgressBanner/index.js +27 -0
- package/components/ProgressBanner/index.js.map +1 -0
- package/components/ProgressCircular/index.js +26 -0
- package/components/ProgressCircular/index.js.map +1 -0
- package/index.js +2 -0
- package/index.js.map +1 -1
- package/package.json +4 -4
- package/styles/components/BasicCell/index.scss +6 -0
- package/styles/components/Calendar/CalendarRangePicker/index.scss +1 -0
- package/styles/components/ProgressBanner/index.scss +76 -0
- package/styles/components/ProgressCircular/index.scss +85 -0
- package/styles/components.scss +2 -0
- package/types/components/BasicCell/index.d.ts +2 -1
- package/types/components/ProgressBanner/index.d.ts +15 -0
- package/types/components/ProgressCircular/index.d.ts +10 -0
- package/types/index.d.ts +2 -0
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import cx from 'classnames';
|
|
3
3
|
|
|
4
|
-
const BasicCell = ({ leftAddonIcon, leftAddonThumbUrl, leftAddonThumbAlt, title, children, rightAddonIcon, large = false, }) => {
|
|
4
|
+
const BasicCell = ({ leftAddonIcon, leftAddonThumbUrl, leftAddonThumbAlt, leftAddonThumbSquare, title, children, rightAddonIcon, large = false, }) => {
|
|
5
5
|
let leftAddon = null;
|
|
6
6
|
if (leftAddonIcon != null)
|
|
7
7
|
leftAddon = leftAddonIcon;
|
|
8
8
|
else if (leftAddonThumbUrl != null) {
|
|
9
9
|
const leftAddonThumbSize = large ? 64 : 44;
|
|
10
|
-
leftAddon = (React.createElement("div", { className: "cobalt-BasicCell__Thumb"
|
|
10
|
+
leftAddon = (React.createElement("div", { className: cx("cobalt-BasicCell__Thumb", {
|
|
11
|
+
"cobalt-BasicCell__Thumb--square": leftAddonThumbSquare,
|
|
12
|
+
}) },
|
|
11
13
|
React.createElement("img", { src: leftAddonThumbUrl, alt: leftAddonThumbAlt, width: leftAddonThumbSize, height: leftAddonThumbSize })));
|
|
12
14
|
}
|
|
13
15
|
return (React.createElement("div", { className: cx("cobalt-BasicCell", {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../src/components/BasicCell/index.tsx"],"sourcesContent":["import React from \"react\"\nimport cx from \"classnames\"\n\nexport interface BasicCellProps {\n children: React.ReactNode\n leftAddonIcon?: React.ReactNode\n leftAddonThumbUrl?: string\n leftAddonThumbAlt?: string\n title: string\n rightAddonIcon?: React.ReactNode\n large?: boolean\n}\n\nexport const BasicCell = ({\n leftAddonIcon,\n leftAddonThumbUrl,\n leftAddonThumbAlt,\n title,\n children,\n rightAddonIcon,\n large = false,\n}: BasicCellProps) => {\n let leftAddon: React.ReactNode | BasicCellProps[\"leftAddonIcon\"] | null = null\n\n if (leftAddonIcon != null) leftAddon = leftAddonIcon\n else if (leftAddonThumbUrl != null) {\n const leftAddonThumbSize = large ? 64 : 44\n leftAddon = (\n <div
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/BasicCell/index.tsx"],"sourcesContent":["import React from \"react\"\nimport cx from \"classnames\"\n\nexport interface BasicCellProps {\n children: React.ReactNode\n leftAddonIcon?: React.ReactNode\n leftAddonThumbUrl?: string\n leftAddonThumbAlt?: string\n leftAddonThumbSquare?: boolean\n title: string\n rightAddonIcon?: React.ReactNode\n large?: boolean\n}\n\nexport const BasicCell = ({\n leftAddonIcon,\n leftAddonThumbUrl,\n leftAddonThumbAlt,\n leftAddonThumbSquare,\n title,\n children,\n rightAddonIcon,\n large = false,\n}: BasicCellProps) => {\n let leftAddon: React.ReactNode | BasicCellProps[\"leftAddonIcon\"] | null = null\n\n if (leftAddonIcon != null) leftAddon = leftAddonIcon\n else if (leftAddonThumbUrl != null) {\n const leftAddonThumbSize = large ? 64 : 44\n leftAddon = (\n <div\n className={cx(\"cobalt-BasicCell__Thumb\", {\n \"cobalt-BasicCell__Thumb--square\": leftAddonThumbSquare,\n })}\n >\n <img\n src={leftAddonThumbUrl}\n alt={leftAddonThumbAlt}\n width={leftAddonThumbSize}\n height={leftAddonThumbSize}\n />\n </div>\n )\n }\n\n return (\n <div\n className={cx(\"cobalt-BasicCell\", {\n \"cobalt-BasicCell--large\": large === true,\n })}\n >\n {leftAddon != null && (\n <div className=\"cobalt-BasicCell__LeftAddon\">{leftAddon}</div>\n )}\n <div className=\"cobalt-BasicCell__Main\">\n <div className=\"cobalt-BasicCell__Title\">{title}</div>\n <div className=\"cobalt-BasicCell__Content\">{children}</div>\n </div>\n {rightAddonIcon != null && (\n <div className=\"cobalt-BasicCell__RightAddonIcon\">{rightAddonIcon}</div>\n )}\n </div>\n )\n}\n"],"names":[],"mappings":";;;AAca,MAAA,SAAS,GAAG,CAAC,EACxB,aAAa,EACb,iBAAiB,EACjB,iBAAiB,EACjB,oBAAoB,EACpB,KAAK,EACL,QAAQ,EACR,cAAc,EACd,KAAK,GAAG,KAAK,GACE,KAAI;IACnB,IAAI,SAAS,GAA6D,IAAI,CAAA;IAE9E,IAAI,aAAa,IAAI,IAAI;QAAE,SAAS,GAAG,aAAa,CAAA;SAC/C,IAAI,iBAAiB,IAAI,IAAI,EAAE;QAClC,MAAM,kBAAkB,GAAG,KAAK,GAAG,EAAE,GAAG,EAAE,CAAA;QAC1C,SAAS,IACP,KACE,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,yBAAyB,EAAE;AACvC,gBAAA,iCAAiC,EAAE,oBAAoB;aACxD,CAAC,EAAA;AAEF,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACE,GAAG,EAAE,iBAAiB,EACtB,GAAG,EAAE,iBAAiB,EACtB,KAAK,EAAE,kBAAkB,EACzB,MAAM,EAAE,kBAAkB,EAC1B,CAAA,CACE,CACP,CAAA;AACF,KAAA;AAED,IAAA,QACE,KACE,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,kBAAkB,EAAE;YAChC,yBAAyB,EAAE,KAAK,KAAK,IAAI;SAC1C,CAAC,EAAA;QAED,SAAS,IAAI,IAAI,KAChB,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,6BAA6B,EAAA,EAAE,SAAS,CAAO,CAC/D;QACD,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,wBAAwB,EAAA;AACrC,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,yBAAyB,EAAA,EAAE,KAAK,CAAO;AACtD,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,2BAA2B,EAAE,EAAA,QAAQ,CAAO,CACvD;AACL,QAAA,cAAc,IAAI,IAAI,KACrB,6BAAK,SAAS,EAAC,kCAAkC,EAAA,EAAE,cAAc,CAAO,CACzE,CACG,EACP;AACH;;;;"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import cx from 'classnames';
|
|
3
|
+
import { ProgressCircular } from '../ProgressCircular/index.js';
|
|
4
|
+
import '../Icon/index.js';
|
|
5
|
+
import CheckIcon from '../Icon/__generated__/CheckIcon.js';
|
|
6
|
+
|
|
7
|
+
function ProgressBanner({ progress, title, description, completed = false, animated = false, fullWidth = false, className, }) {
|
|
8
|
+
return (React.createElement("div", { className: cx("cobalt-progressBanner", className, {
|
|
9
|
+
"cobalt-progressBanner--completed": completed,
|
|
10
|
+
"cobalt-progressBanner--fullWidth": fullWidth,
|
|
11
|
+
}) },
|
|
12
|
+
progress && !completed && (React.createElement(ProgressCircular, { size: 48, progress: (progress.done * 100) / progress.total, animated: animated },
|
|
13
|
+
React.createElement("div", { className: "cobalt-progressBanner__progress-container" },
|
|
14
|
+
progress.done,
|
|
15
|
+
"/",
|
|
16
|
+
progress.total))),
|
|
17
|
+
completed && (React.createElement("div", { className: cx("cobalt-progressBanner__completed-icon-container", {
|
|
18
|
+
"cobalt-progressBanner__completed-icon-container--animated": animated,
|
|
19
|
+
}) },
|
|
20
|
+
React.createElement(CheckIcon, { color: "success", size: 32 }))),
|
|
21
|
+
React.createElement("div", { className: "cobalt-progressBanner__text-container" },
|
|
22
|
+
React.createElement("div", { className: "cobalt-progressBanner__title" }, title),
|
|
23
|
+
React.createElement("div", { className: "cobalt-progressBanner__description" }, description))));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export { ProgressBanner };
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/ProgressBanner/index.tsx"],"sourcesContent":["import React from \"react\"\nimport cx from \"classnames\"\nimport { ProgressCircular } from \"../ProgressCircular\"\nimport { CheckIcon } from \"../Icon\"\n\ntype ProgressBannerPropsType = {\n progress?: {\n done: number\n total: number\n }\n title: string\n description: string\n completed?: boolean\n animated?: boolean\n fullWidth?: boolean\n className?: string\n}\n\nexport function ProgressBanner({\n progress,\n title,\n description,\n completed = false,\n animated = false,\n fullWidth = false,\n className,\n}: ProgressBannerPropsType) {\n return (\n <div\n className={cx(\"cobalt-progressBanner\", className, {\n \"cobalt-progressBanner--completed\": completed,\n \"cobalt-progressBanner--fullWidth\": fullWidth,\n })}\n >\n {progress && !completed && (\n <ProgressCircular\n size={48}\n progress={(progress.done * 100) / progress.total}\n animated={animated}\n >\n <div className=\"cobalt-progressBanner__progress-container\">\n {progress.done}/{progress.total}\n </div>\n </ProgressCircular>\n )}\n\n {completed && (\n <div\n className={cx(\"cobalt-progressBanner__completed-icon-container\", {\n \"cobalt-progressBanner__completed-icon-container--animated\":\n animated,\n })}\n >\n <CheckIcon color=\"success\" size={32} />\n </div>\n )}\n\n <div className=\"cobalt-progressBanner__text-container\">\n <div className=\"cobalt-progressBanner__title\">{title}</div>\n <div className=\"cobalt-progressBanner__description\">{description}</div>\n </div>\n </div>\n )\n}\n"],"names":[],"mappings":";;;;;;AAkBM,SAAU,cAAc,CAAC,EAC7B,QAAQ,EACR,KAAK,EACL,WAAW,EACX,SAAS,GAAG,KAAK,EACjB,QAAQ,GAAG,KAAK,EAChB,SAAS,GAAG,KAAK,EACjB,SAAS,GACe,EAAA;IACxB,QACE,6BACE,SAAS,EAAE,EAAE,CAAC,uBAAuB,EAAE,SAAS,EAAE;AAChD,YAAA,kCAAkC,EAAE,SAAS;AAC7C,YAAA,kCAAkC,EAAE,SAAS;SAC9C,CAAC,EAAA;AAED,QAAA,QAAQ,IAAI,CAAC,SAAS,KACrB,KAAA,CAAA,aAAA,CAAC,gBAAgB,EAAA,EACf,IAAI,EAAE,EAAE,EACR,QAAQ,EAAE,CAAC,QAAQ,CAAC,IAAI,GAAG,GAAG,IAAI,QAAQ,CAAC,KAAK,EAChD,QAAQ,EAAE,QAAQ,EAAA;YAElB,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,2CAA2C,EAAA;AACvD,gBAAA,QAAQ,CAAC,IAAI;;AAAG,gBAAA,QAAQ,CAAC,KAAK,CAC3B,CACW,CACpB;QAEA,SAAS,KACR,KACE,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CAAC,iDAAiD,EAAE;AAC/D,gBAAA,2DAA2D,EACzD,QAAQ;aACX,CAAC,EAAA;YAEF,KAAC,CAAA,aAAA,CAAA,SAAS,EAAC,EAAA,KAAK,EAAC,SAAS,EAAC,IAAI,EAAE,EAAE,EAAI,CAAA,CACnC,CACP;QAED,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,uCAAuC,EAAA;AACpD,YAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,8BAA8B,EAAA,EAAE,KAAK,CAAO;YAC3D,KAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAC,oCAAoC,EAAA,EAAE,WAAW,CAAO,CACnE,CACF,EACP;AACH;;;;"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React, { useRef, useLayoutEffect } from 'react';
|
|
2
|
+
import cx from 'classnames';
|
|
3
|
+
|
|
4
|
+
const ProgressCircular = ({ progress, size, status = "info", animated = false, className, children, }) => {
|
|
5
|
+
const pathRef = useRef(null);
|
|
6
|
+
useLayoutEffect(() => {
|
|
7
|
+
if (!pathRef.current)
|
|
8
|
+
return;
|
|
9
|
+
const length = pathRef.current.getTotalLength();
|
|
10
|
+
const value = progress;
|
|
11
|
+
const to = length * ((100 - value) / 100);
|
|
12
|
+
// Trigger Layout in Safari hack https://jakearchibald.com/2013/animated-line-drawing-svg/
|
|
13
|
+
pathRef.current.getBoundingClientRect();
|
|
14
|
+
pathRef.current.style.strokeDashoffset = "" + Math.max(0, to);
|
|
15
|
+
}, []);
|
|
16
|
+
return (React.createElement("div", { className: cx(`cobalt-circularProgressBar cobalt-circularProgressBar--size${size}`, className, {
|
|
17
|
+
"cobalt-circularProgressBar--animated": animated,
|
|
18
|
+
[`cobalt-circularProgressBar--${status}`]: status,
|
|
19
|
+
}) },
|
|
20
|
+
React.createElement("div", { className: "cobalt-circularProgressBar__content" }, children),
|
|
21
|
+
React.createElement("svg", { viewBox: "0 0 100 100", xmlns: "http://www.w3.org/2000/svg", preserveAspectRatio: "none", "data-value": "75" },
|
|
22
|
+
React.createElement("path", { ref: pathRef, className: "cobalt-circularProgressBar__bar", d: "M5,50a45,45 0 1,0 90,0a45,45 0 1,0 -90,0", strokeLinecap: "round", strokeLinejoin: "round", strokeDashoffset: "282.78302001953125", strokeDasharray: "282.78302001953125" }))));
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
export { ProgressCircular };
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/ProgressCircular/index.tsx"],"sourcesContent":["import React, { useLayoutEffect, useRef } from \"react\"\nimport cx from \"classnames\"\n\nexport interface ProgressBarProps {\n children: React.ReactNode\n progress: number\n status?: \"info\" | \"success\" | \"error\"\n size: 32 | 48 | 64 | 96\n animated?: boolean\n className?: string\n}\n\nexport const ProgressCircular = ({\n progress,\n size,\n status = \"info\",\n animated = false,\n className,\n children,\n}: ProgressBarProps) => {\n const pathRef = useRef<SVGGeometryElement>(null)\n\n useLayoutEffect(() => {\n if (!pathRef.current) return\n const length = pathRef.current.getTotalLength()\n\n const value = progress\n\n const to = length * ((100 - value) / 100)\n // Trigger Layout in Safari hack https://jakearchibald.com/2013/animated-line-drawing-svg/\n pathRef.current.getBoundingClientRect()\n\n pathRef.current.style.strokeDashoffset = \"\" + Math.max(0, to)\n }, [])\n\n return (\n <div\n className={cx(\n `cobalt-circularProgressBar cobalt-circularProgressBar--size${size}`,\n className,\n {\n \"cobalt-circularProgressBar--animated\": animated,\n [`cobalt-circularProgressBar--${status}`]: status,\n }\n )}\n >\n <div className=\"cobalt-circularProgressBar__content\">{children}</div>\n <svg\n viewBox=\"0 0 100 100\"\n xmlns=\"http://www.w3.org/2000/svg\"\n preserveAspectRatio=\"none\"\n data-value=\"75\"\n >\n {/* <circle r=\"45\" cx=\"50\" cy=\"50\" /> */}\n <path\n ref={pathRef}\n className=\"cobalt-circularProgressBar__bar\"\n d=\"M5,50a45,45 0 1,0 90,0a45,45 0 1,0 -90,0\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeDashoffset=\"282.78302001953125\"\n strokeDasharray=\"282.78302001953125\"\n />\n </svg>\n </div>\n )\n}\n"],"names":[],"mappings":";;;MAYa,gBAAgB,GAAG,CAAC,EAC/B,QAAQ,EACR,IAAI,EACJ,MAAM,GAAG,MAAM,EACf,QAAQ,GAAG,KAAK,EAChB,SAAS,EACT,QAAQ,GACS,KAAI;AACrB,IAAA,MAAM,OAAO,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAA;IAEhD,eAAe,CAAC,MAAK;QACnB,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE,OAAM;QAC5B,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,cAAc,EAAE,CAAA;QAE/C,MAAM,KAAK,GAAG,QAAQ,CAAA;AAEtB,QAAA,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,GAAG,GAAG,KAAK,IAAI,GAAG,CAAC,CAAA;;AAEzC,QAAA,OAAO,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAA;AAEvC,QAAA,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;KAC9D,EAAE,EAAE,CAAC,CAAA;IAEN,QACE,KACE,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,SAAS,EAAE,EAAE,CACX,CAAA,2DAAA,EAA8D,IAAI,CAAA,CAAE,EACpE,SAAS,EACT;AACE,YAAA,sCAAsC,EAAE,QAAQ;AAChD,YAAA,CAAC,CAA+B,4BAAA,EAAA,MAAM,CAAE,CAAA,GAAG,MAAM;SAClD,CACF,EAAA;AAED,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,qCAAqC,EAAA,EAAE,QAAQ,CAAO;AACrE,QAAA,KAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EACE,OAAO,EAAC,aAAa,EACrB,KAAK,EAAC,4BAA4B,EAClC,mBAAmB,EAAC,MAAM,EAAA,YAAA,EACf,IAAI,EAAA;AAGf,YAAA,KAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EACE,GAAG,EAAE,OAAO,EACZ,SAAS,EAAC,iCAAiC,EAC3C,CAAC,EAAC,0CAA0C,EAC5C,aAAa,EAAC,OAAO,EACrB,cAAc,EAAC,OAAO,EACtB,gBAAgB,EAAC,oBAAoB,EACrC,eAAe,EAAC,oBAAoB,EAAA,CACpC,CACE,CACF,EACP;AACH;;;;"}
|
package/index.js
CHANGED
|
@@ -21,6 +21,8 @@ export { default as PhotoDropzone } from './components/PhotoDropzone/index.js';
|
|
|
21
21
|
export { Pill, PillGroup } from './components/Pill/index.js';
|
|
22
22
|
export { PriceTable, PriceTableRow } from './components/PriceTable/index.js';
|
|
23
23
|
export { ProgressBar } from './components/ProgressBar/index.js';
|
|
24
|
+
export { ProgressCircular } from './components/ProgressCircular/index.js';
|
|
25
|
+
export { ProgressBanner } from './components/ProgressBanner/index.js';
|
|
24
26
|
export { Tab, Tabs } from './components/Tabs/index.js';
|
|
25
27
|
export { Tag } from './components/Tag/index.js';
|
|
26
28
|
export { Chip } from './components/Chip/index.js';
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@drivy/cobalt",
|
|
3
|
-
"version": "0.31.
|
|
3
|
+
"version": "0.31.3",
|
|
4
4
|
"description": "Opinionated design system for Drivy's projects.",
|
|
5
5
|
"main": "src/index.js",
|
|
6
6
|
"types": "types/index.d.ts",
|
|
@@ -65,9 +65,9 @@
|
|
|
65
65
|
"@types/react": "18.0.26",
|
|
66
66
|
"@whitespace/storybook-addon-html": "^5.1.1",
|
|
67
67
|
"autoprefixer": "10.4.13",
|
|
68
|
-
"core-js": "3.
|
|
68
|
+
"core-js": "3.29.0",
|
|
69
69
|
"css-loader": "6.7.3",
|
|
70
|
-
"eslint": "8.
|
|
70
|
+
"eslint": "8.35.0",
|
|
71
71
|
"file-loader": "6.2.0",
|
|
72
72
|
"jest": "29.3.1",
|
|
73
73
|
"jest-environment-jsdom": "29.3.1",
|
|
@@ -87,7 +87,7 @@
|
|
|
87
87
|
"rollup-plugin-postcss": "4.0.2",
|
|
88
88
|
"rollup-plugin-svgo": "2.0.0",
|
|
89
89
|
"rollup-plugin-typescript2": "0.34.1",
|
|
90
|
-
"sass": "1.58.
|
|
90
|
+
"sass": "1.58.3",
|
|
91
91
|
"sass-loader": "13.2.0",
|
|
92
92
|
"sharp": "0.31.3",
|
|
93
93
|
"sharp-cli": "4.1.0",
|
|
@@ -24,6 +24,8 @@
|
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
&BasicCell__Thumb {
|
|
27
|
+
@include bg-color(neutralAlt);
|
|
28
|
+
|
|
27
29
|
display: flex;
|
|
28
30
|
flex-direction: column;
|
|
29
31
|
justify-content: center;
|
|
@@ -39,6 +41,10 @@
|
|
|
39
41
|
}
|
|
40
42
|
}
|
|
41
43
|
|
|
44
|
+
&BasicCell__Thumb--square {
|
|
45
|
+
border-radius: border-radius(lg);
|
|
46
|
+
}
|
|
47
|
+
|
|
42
48
|
&BasicCell__LeftAddon {
|
|
43
49
|
padding-right: spacing(sm);
|
|
44
50
|
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
.cobalt-progressBanner {
|
|
2
|
+
@include bg-color(info);
|
|
3
|
+
@include text-color(info);
|
|
4
|
+
|
|
5
|
+
display: inline-flex;
|
|
6
|
+
align-items: center;
|
|
7
|
+
|
|
8
|
+
padding: spacing(sm);
|
|
9
|
+
|
|
10
|
+
border-radius: border-radius(xl);
|
|
11
|
+
|
|
12
|
+
gap: spacing(sm);
|
|
13
|
+
|
|
14
|
+
&__progress-container {
|
|
15
|
+
font-weight: 600;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
&__completed-icon-container {
|
|
19
|
+
@include bg-color(primary);
|
|
20
|
+
|
|
21
|
+
display: flex;
|
|
22
|
+
|
|
23
|
+
justify-content: center;
|
|
24
|
+
align-items: center;
|
|
25
|
+
|
|
26
|
+
width: spacing(xl);
|
|
27
|
+
height: spacing(xl);
|
|
28
|
+
|
|
29
|
+
margin: 0 5px; // ProgressCircular stroke width
|
|
30
|
+
|
|
31
|
+
flex-shrink: 0;
|
|
32
|
+
|
|
33
|
+
border-radius: 50%;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
&__text-container {
|
|
37
|
+
display: flex;
|
|
38
|
+
flex-direction: column;
|
|
39
|
+
gap: spacing("2xs");
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
&__title {
|
|
43
|
+
@include c-text-title-xs;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
&__description {
|
|
47
|
+
font-size: 14px;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
&--completed {
|
|
51
|
+
@include bg-color(successAlt);
|
|
52
|
+
@include text-color(successAlt);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
&__completed-icon-container--animated .cobalt-Icon {
|
|
56
|
+
animation: progressBanner__animation--zoom-in 650ms ease;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
&--fullWidth {
|
|
60
|
+
display: flex;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
@keyframes progressBanner__animation--zoom-in {
|
|
65
|
+
0% {
|
|
66
|
+
transform: scale(0, 0);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
50% {
|
|
70
|
+
transform: scale(1.2, 1.2);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
100% {
|
|
74
|
+
transform: scale(1, 1);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
.cobalt-circularProgressBar {
|
|
2
|
+
--content-size: 64px;
|
|
3
|
+
--total-size: calc((var(--content-size) / 4) + var(--content-size));
|
|
4
|
+
--progress-color: #{color-var(fill, base)};
|
|
5
|
+
|
|
6
|
+
position: relative;
|
|
7
|
+
|
|
8
|
+
display: flex;
|
|
9
|
+
justify-content: center;
|
|
10
|
+
align-items: center;
|
|
11
|
+
|
|
12
|
+
width: var(--total-size);
|
|
13
|
+
height: var(--total-size);
|
|
14
|
+
|
|
15
|
+
flex-shrink: 0;
|
|
16
|
+
|
|
17
|
+
svg {
|
|
18
|
+
position: absolute;
|
|
19
|
+
|
|
20
|
+
display: inline-flex;
|
|
21
|
+
|
|
22
|
+
width: calc(var(--total-size) - 2px);
|
|
23
|
+
height: calc(var(--total-size) - 2px);
|
|
24
|
+
|
|
25
|
+
vertical-align: bottom;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
&__bar {
|
|
29
|
+
fill: none;
|
|
30
|
+
|
|
31
|
+
transform: rotate(-90deg) scaleX(-1);
|
|
32
|
+
transform-origin: center center;
|
|
33
|
+
|
|
34
|
+
stroke-width: 8px;
|
|
35
|
+
stroke: var(--progress-color);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
&__content {
|
|
39
|
+
@include bg-color(primary);
|
|
40
|
+
|
|
41
|
+
position: absolute;
|
|
42
|
+
|
|
43
|
+
display: flex;
|
|
44
|
+
|
|
45
|
+
justify-content: center;
|
|
46
|
+
align-items: center;
|
|
47
|
+
|
|
48
|
+
width: var(--content-size);
|
|
49
|
+
height: var(--content-size);
|
|
50
|
+
|
|
51
|
+
border-radius: 50%;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
&--animated .cobalt-circularProgressBar__bar {
|
|
55
|
+
transition: stroke-dashoffset 1s cubic-bezier(0.43, 0.41, 0.22, 0.91);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
&--size96 {
|
|
59
|
+
--content-size: 96px;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
&--size64 {
|
|
63
|
+
--content-size: 64px;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
&--size48 {
|
|
67
|
+
--content-size: 48px;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
&--size32 {
|
|
71
|
+
--content-size: 32px;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
&--info {
|
|
75
|
+
--progress-color: #{color-var(fill, secondary)};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
&--error {
|
|
79
|
+
--progress-color: #{color-var(fill, error)};
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
&--success {
|
|
83
|
+
--progress-color: #{color-var(fill, success)};
|
|
84
|
+
}
|
|
85
|
+
}
|
package/styles/components.scss
CHANGED
|
@@ -4,8 +4,9 @@ export interface BasicCellProps {
|
|
|
4
4
|
leftAddonIcon?: React.ReactNode;
|
|
5
5
|
leftAddonThumbUrl?: string;
|
|
6
6
|
leftAddonThumbAlt?: string;
|
|
7
|
+
leftAddonThumbSquare?: boolean;
|
|
7
8
|
title: string;
|
|
8
9
|
rightAddonIcon?: React.ReactNode;
|
|
9
10
|
large?: boolean;
|
|
10
11
|
}
|
|
11
|
-
export declare const BasicCell: ({ leftAddonIcon, leftAddonThumbUrl, leftAddonThumbAlt, title, children, rightAddonIcon, large, }: BasicCellProps) => JSX.Element;
|
|
12
|
+
export declare const BasicCell: ({ leftAddonIcon, leftAddonThumbUrl, leftAddonThumbAlt, leftAddonThumbSquare, title, children, rightAddonIcon, large, }: BasicCellProps) => JSX.Element;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
type ProgressBannerPropsType = {
|
|
3
|
+
progress?: {
|
|
4
|
+
done: number;
|
|
5
|
+
total: number;
|
|
6
|
+
};
|
|
7
|
+
title: string;
|
|
8
|
+
description: string;
|
|
9
|
+
completed?: boolean;
|
|
10
|
+
animated?: boolean;
|
|
11
|
+
fullWidth?: boolean;
|
|
12
|
+
className?: string;
|
|
13
|
+
};
|
|
14
|
+
export declare function ProgressBanner({ progress, title, description, completed, animated, fullWidth, className, }: ProgressBannerPropsType): JSX.Element;
|
|
15
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
export interface ProgressBarProps {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
progress: number;
|
|
5
|
+
status?: "info" | "success" | "error";
|
|
6
|
+
size: 32 | 48 | 64 | 96;
|
|
7
|
+
animated?: boolean;
|
|
8
|
+
className?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare const ProgressCircular: ({ progress, size, status, animated, className, children, }: ProgressBarProps) => JSX.Element;
|
package/types/index.d.ts
CHANGED
|
@@ -21,6 +21,8 @@ export { default as PhotoDropzone } from "./components/PhotoDropzone";
|
|
|
21
21
|
export { Pill, PillGroup } from "./components/Pill";
|
|
22
22
|
export { PriceTable, PriceTableRow } from "./components/PriceTable";
|
|
23
23
|
export { ProgressBar } from "./components/ProgressBar";
|
|
24
|
+
export { ProgressCircular } from "./components/ProgressCircular";
|
|
25
|
+
export { ProgressBanner } from "./components/ProgressBanner";
|
|
24
26
|
export { Tabs, Tab } from "./components/Tabs";
|
|
25
27
|
export { Tag } from "./components/Tag";
|
|
26
28
|
export { Chip } from "./components/Chip";
|