jfs-components 0.0.3 → 0.0.5
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/lib/commonjs/Containers.js +16 -7
- package/lib/commonjs/Containers.js.map +1 -1
- package/lib/commonjs/components/Accordion/Accordion.js +217 -0
- package/lib/commonjs/components/Accordion/Accordion.js.map +1 -0
- package/lib/commonjs/components/Accordion/Accordion.mdx +123 -0
- package/lib/commonjs/components/ActionFooter/ActionFooter.mdx +1 -0
- package/lib/commonjs/components/ActionTile/ActionTile.js +93 -0
- package/lib/commonjs/components/ActionTile/ActionTile.js.map +1 -0
- package/lib/commonjs/components/ActionTile/ActionTile.mdx +54 -0
- package/lib/commonjs/components/ActionTile/index.js +14 -0
- package/lib/commonjs/components/ActionTile/index.js.map +1 -0
- package/lib/commonjs/components/CtaCard/CtaCard.js +122 -0
- package/lib/commonjs/components/CtaCard/CtaCard.js.map +1 -0
- package/lib/commonjs/components/CtaCard/CtaCard.mdx +65 -0
- package/lib/commonjs/components/CtaCard/index.js +14 -0
- package/lib/commonjs/components/CtaCard/index.js.map +1 -0
- package/lib/commonjs/components/Introduction.mdx +0 -1
- package/lib/commonjs/components/ThreadHero/ThreadHero.js +114 -0
- package/lib/commonjs/components/ThreadHero/ThreadHero.js.map +1 -0
- package/lib/commonjs/components/ThreadHero/ThreadHero.mdx +69 -0
- package/lib/commonjs/components/TransactionBubble/TransactionBubble.js +101 -0
- package/lib/commonjs/components/TransactionBubble/TransactionBubble.js.map +1 -0
- package/lib/commonjs/components/TransactionBubble/TransactionBubble.mdx +40 -0
- package/lib/commonjs/components/TransactionDetails/TransactionDetails.js +177 -0
- package/lib/commonjs/components/TransactionDetails/TransactionDetails.js.map +1 -0
- package/lib/commonjs/components/TransactionDetails/TransactionDetails.mdx +98 -0
- package/lib/commonjs/components/TransactionStatus/TransactionStatus.js +82 -0
- package/lib/commonjs/components/TransactionStatus/TransactionStatus.js.map +1 -0
- package/lib/commonjs/components/TransactionStatus/TransactionStatus.mdx +41 -0
- package/lib/commonjs/components/index.js +35 -0
- package/lib/commonjs/components/index.js.map +1 -1
- package/lib/commonjs/design-tokens/JFSThemeProvider.js +64 -0
- package/lib/commonjs/design-tokens/JFSThemeProvider.js.map +1 -0
- package/lib/commonjs/design-tokens/figma-variables-resolver.js +3 -9
- package/lib/commonjs/design-tokens/index.js +11 -0
- package/lib/commonjs/design-tokens/index.js.map +1 -1
- package/lib/commonjs/icons/registry.js +1 -1
- package/lib/module/Containers.js +15 -7
- package/lib/module/Containers.js.map +1 -1
- package/lib/module/components/Accordion/Accordion.js +212 -0
- package/lib/module/components/Accordion/Accordion.js.map +1 -0
- package/lib/module/components/Accordion/Accordion.mdx +123 -0
- package/lib/module/components/ActionFooter/ActionFooter.mdx +1 -0
- package/lib/module/components/ActionTile/ActionTile.js +88 -0
- package/lib/module/components/ActionTile/ActionTile.js.map +1 -0
- package/lib/module/components/ActionTile/ActionTile.mdx +54 -0
- package/lib/module/components/ActionTile/index.js +4 -0
- package/lib/module/components/ActionTile/index.js.map +1 -0
- package/lib/module/components/CtaCard/CtaCard.js +117 -0
- package/lib/module/components/CtaCard/CtaCard.js.map +1 -0
- package/lib/module/components/CtaCard/CtaCard.mdx +65 -0
- package/lib/module/components/CtaCard/index.js +4 -0
- package/lib/module/components/CtaCard/index.js.map +1 -0
- package/lib/module/components/Introduction.mdx +0 -1
- package/lib/module/components/ThreadHero/ThreadHero.js +109 -0
- package/lib/module/components/ThreadHero/ThreadHero.js.map +1 -0
- package/lib/module/components/ThreadHero/ThreadHero.mdx +69 -0
- package/lib/module/components/TransactionBubble/TransactionBubble.js +96 -0
- package/lib/module/components/TransactionBubble/TransactionBubble.js.map +1 -0
- package/lib/module/components/TransactionBubble/TransactionBubble.mdx +40 -0
- package/lib/module/components/TransactionDetails/TransactionDetails.js +174 -0
- package/lib/module/components/TransactionDetails/TransactionDetails.js.map +1 -0
- package/lib/module/components/TransactionDetails/TransactionDetails.mdx +98 -0
- package/lib/module/components/TransactionStatus/TransactionStatus.js +77 -0
- package/lib/module/components/TransactionStatus/TransactionStatus.js.map +1 -0
- package/lib/module/components/TransactionStatus/TransactionStatus.mdx +41 -0
- package/lib/module/components/index.js +5 -0
- package/lib/module/components/index.js.map +1 -1
- package/lib/module/design-tokens/JFSThemeProvider.js +57 -0
- package/lib/module/design-tokens/JFSThemeProvider.js.map +1 -0
- package/lib/module/design-tokens/index.js +1 -0
- package/lib/module/design-tokens/index.js.map +1 -1
- package/lib/module/icons/registry.js +1 -1
- package/lib/typescript/Containers.d.ts +2 -1
- package/lib/typescript/Containers.d.ts.map +1 -1
- package/lib/typescript/components/Accordion/Accordion.d.ts +58 -0
- package/lib/typescript/components/Accordion/Accordion.d.ts.map +1 -0
- package/lib/typescript/components/ActionTile/ActionTile.d.ts +26 -0
- package/lib/typescript/components/ActionTile/ActionTile.d.ts.map +1 -0
- package/lib/typescript/components/ActionTile/index.d.ts +2 -0
- package/lib/typescript/components/ActionTile/index.d.ts.map +1 -0
- package/lib/typescript/components/CtaCard/CtaCard.d.ts +61 -0
- package/lib/typescript/components/CtaCard/CtaCard.d.ts.map +1 -0
- package/lib/typescript/components/CtaCard/index.d.ts +2 -0
- package/lib/typescript/components/CtaCard/index.d.ts.map +1 -0
- package/lib/typescript/components/ThreadHero/ThreadHero.d.ts +21 -0
- package/lib/typescript/components/ThreadHero/ThreadHero.d.ts.map +1 -0
- package/lib/typescript/components/TransactionBubble/TransactionBubble.d.ts +24 -0
- package/lib/typescript/components/TransactionBubble/TransactionBubble.d.ts.map +1 -0
- package/lib/typescript/components/TransactionDetails/TransactionDetails.d.ts +57 -0
- package/lib/typescript/components/TransactionDetails/TransactionDetails.d.ts.map +1 -0
- package/lib/typescript/components/TransactionStatus/TransactionStatus.d.ts +16 -0
- package/lib/typescript/components/TransactionStatus/TransactionStatus.d.ts.map +1 -0
- package/lib/typescript/components/index.d.ts +5 -0
- package/lib/typescript/components/index.d.ts.map +1 -1
- package/lib/typescript/design-tokens/JFSThemeProvider.d.ts +44 -0
- package/lib/typescript/design-tokens/JFSThemeProvider.d.ts.map +1 -0
- package/lib/typescript/design-tokens/index.d.ts +1 -0
- package/lib/typescript/design-tokens/index.d.ts.map +1 -1
- package/lib/typescript/icons/registry.d.ts +1 -1
- package/package.json +3 -4
- package/src/Containers.tsx +15 -0
- package/src/components/.token-metadata.json +161 -0
- package/src/components/Accordion/Accordion.mdx +123 -0
- package/src/components/Accordion/Accordion.tsx +279 -0
- package/src/components/ActionFooter/ActionFooter.mdx +1 -0
- package/src/components/ActionTile/ActionTile.mdx +54 -0
- package/src/components/ActionTile/ActionTile.tsx +100 -0
- package/src/components/ActionTile/index.ts +1 -0
- package/src/components/CtaCard/CtaCard.mdx +65 -0
- package/src/components/CtaCard/CtaCard.tsx +185 -0
- package/src/components/CtaCard/index.ts +1 -0
- package/src/components/Divider/Divider.tsx +1 -0
- package/src/components/Introduction.mdx +0 -1
- package/src/components/NavArrow/NavArrow.tsx +1 -0
- package/src/components/ThreadHero/ThreadHero.mdx +69 -0
- package/src/components/ThreadHero/ThreadHero.tsx +124 -0
- package/src/components/TransactionBubble/TransactionBubble.mdx +40 -0
- package/src/components/TransactionBubble/TransactionBubble.tsx +113 -0
- package/src/components/TransactionDetails/TransactionDetails.mdx +98 -0
- package/src/components/TransactionDetails/TransactionDetails.tsx +236 -0
- package/src/components/TransactionStatus/TransactionStatus.mdx +41 -0
- package/src/components/TransactionStatus/TransactionStatus.tsx +94 -0
- package/src/components/index.ts +5 -0
- package/src/design-tokens/JFSThemeProvider.tsx +79 -0
- package/src/design-tokens/index.ts +1 -0
- package/src/icons/registry.ts +1 -1
- package/src/Containers.ts +0 -8
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _figmaVariablesResolver = require("../../design-tokens/figma-variables-resolver");
|
|
10
|
+
var _IconCapsule = _interopRequireDefault(require("../IconCapsule/IconCapsule"));
|
|
11
|
+
var _Button = _interopRequireDefault(require("../Button/Button"));
|
|
12
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
13
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
|
+
/**
|
|
15
|
+
* CtaCard component that maps directly to the Figma design using design tokens.
|
|
16
|
+
*
|
|
17
|
+
* @component
|
|
18
|
+
*/
|
|
19
|
+
function CtaCard({
|
|
20
|
+
title = "Lets create your UPI ID",
|
|
21
|
+
body = "Send and receive money securely.",
|
|
22
|
+
iconName = "ic_upi_number",
|
|
23
|
+
buttonLabel = "Get started",
|
|
24
|
+
onPressButton,
|
|
25
|
+
modes = {},
|
|
26
|
+
iconSlot,
|
|
27
|
+
titleSlot,
|
|
28
|
+
bodySlot,
|
|
29
|
+
buttonSlot,
|
|
30
|
+
style
|
|
31
|
+
}) {
|
|
32
|
+
// --- Token Resolution ---
|
|
33
|
+
// Container
|
|
34
|
+
const backgroundColor = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/background', modes) || '#0078ad';
|
|
35
|
+
const radius = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/radius', modes) || 16;
|
|
36
|
+
const paddingHorizontal = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/padding/horizontal', modes) || 20;
|
|
37
|
+
const paddingVertical = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/padding/vertical', modes) || 23;
|
|
38
|
+
const gap = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/gap', modes) || 16;
|
|
39
|
+
|
|
40
|
+
// Content Wrap
|
|
41
|
+
const contentGap = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/content/gap', modes) || 8;
|
|
42
|
+
|
|
43
|
+
// Title Text
|
|
44
|
+
const titleColor = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/title/color', modes) || '#ffffff';
|
|
45
|
+
const titleFontFamily = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/title/fontFamily', modes) || 'JioType Var';
|
|
46
|
+
const titleFontSize = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/title/fontSize', modes) || 23;
|
|
47
|
+
const titleLineHeight = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/title/lineHeight', modes) || 23;
|
|
48
|
+
|
|
49
|
+
// Body Text
|
|
50
|
+
const bodyColor = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/body/color', modes) || '#ffffff';
|
|
51
|
+
const bodyFontFamily = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/body/fontFamily', modes) || 'JioType Var';
|
|
52
|
+
const bodyFontSize = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/body/fontSize', modes) || 14;
|
|
53
|
+
const bodyLineHeight = (0, _figmaVariablesResolver.getVariableByName)('ctaCard/body/lineHeight', modes) || 17;
|
|
54
|
+
|
|
55
|
+
// --- Styles ---
|
|
56
|
+
const containerStyle = {
|
|
57
|
+
backgroundColor,
|
|
58
|
+
borderRadius: radius,
|
|
59
|
+
paddingHorizontal,
|
|
60
|
+
paddingVertical,
|
|
61
|
+
gap,
|
|
62
|
+
alignItems: 'flex-start',
|
|
63
|
+
width: '100%',
|
|
64
|
+
// Adjust based on layout needs, usually cards take full width available
|
|
65
|
+
overflow: 'hidden'
|
|
66
|
+
};
|
|
67
|
+
const contentWrapStyle = {
|
|
68
|
+
gap: contentGap,
|
|
69
|
+
alignItems: 'flex-start',
|
|
70
|
+
width: '100%'
|
|
71
|
+
};
|
|
72
|
+
const titleStyle = {
|
|
73
|
+
color: titleColor,
|
|
74
|
+
fontFamily: titleFontFamily,
|
|
75
|
+
fontSize: titleFontSize,
|
|
76
|
+
lineHeight: titleLineHeight,
|
|
77
|
+
fontWeight: '900' // "Black" in Figma often maps to 900
|
|
78
|
+
};
|
|
79
|
+
const bodyStyle = {
|
|
80
|
+
color: bodyColor,
|
|
81
|
+
fontFamily: bodyFontFamily,
|
|
82
|
+
fontSize: bodyFontSize,
|
|
83
|
+
lineHeight: bodyLineHeight,
|
|
84
|
+
fontWeight: '400' // Regular
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
// --- Slot Helper ---
|
|
88
|
+
// Helper to clone element with modes if no modes are already present on it (standard in this library)
|
|
89
|
+
const renderSlot = slot => {
|
|
90
|
+
if (/*#__PURE__*/_react.default.isValidElement(slot)) {
|
|
91
|
+
return /*#__PURE__*/_react.default.cloneElement(slot, {
|
|
92
|
+
modes: {
|
|
93
|
+
...modes,
|
|
94
|
+
...slot.props.modes
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
return slot;
|
|
99
|
+
};
|
|
100
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
101
|
+
style: [containerStyle, style],
|
|
102
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
103
|
+
style: contentWrapStyle,
|
|
104
|
+
children: [iconSlot ? renderSlot(iconSlot) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_IconCapsule.default, {
|
|
105
|
+
iconName: iconName,
|
|
106
|
+
modes: modes
|
|
107
|
+
}), titleSlot ? renderSlot(titleSlot) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
108
|
+
style: titleStyle,
|
|
109
|
+
children: title
|
|
110
|
+
}), bodySlot ? renderSlot(bodySlot) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
111
|
+
style: bodyStyle,
|
|
112
|
+
children: body
|
|
113
|
+
})]
|
|
114
|
+
}), buttonSlot ? renderSlot(buttonSlot) : /*#__PURE__*/(0, _jsxRuntime.jsx)(_Button.default, {
|
|
115
|
+
label: buttonLabel,
|
|
116
|
+
onPress: onPressButton,
|
|
117
|
+
modes: modes
|
|
118
|
+
})]
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
var _default = exports.default = CtaCard;
|
|
122
|
+
//# sourceMappingURL=CtaCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","_figmaVariablesResolver","_IconCapsule","_Button","_jsxRuntime","e","__esModule","default","CtaCard","title","body","iconName","buttonLabel","onPressButton","modes","iconSlot","titleSlot","bodySlot","buttonSlot","style","backgroundColor","getVariableByName","radius","paddingHorizontal","paddingVertical","gap","contentGap","titleColor","titleFontFamily","titleFontSize","titleLineHeight","bodyColor","bodyFontFamily","bodyFontSize","bodyLineHeight","containerStyle","borderRadius","alignItems","width","overflow","contentWrapStyle","titleStyle","color","fontFamily","fontSize","lineHeight","fontWeight","bodyStyle","renderSlot","slot","React","isValidElement","cloneElement","props","jsxs","View","children","jsx","Text","label","onPress","_default","exports"],"sourceRoot":"../../../../src","sources":["components/CtaCard/CtaCard.tsx"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AACA,IAAAE,uBAAA,GAAAF,OAAA;AACA,IAAAG,YAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,OAAA,GAAAL,sBAAA,CAAAC,OAAA;AAAsC,IAAAK,WAAA,GAAAL,OAAA;AAAA,SAAAD,uBAAAO,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAuDtC;AACA;AACA;AACA;AACA;AACA,SAASG,OAAOA,CAAC;EACbC,KAAK,GAAG,yBAAyB;EACjCC,IAAI,GAAG,kCAAkC;EACzCC,QAAQ,GAAG,eAAe;EAC1BC,WAAW,GAAG,aAAa;EAC3BC,aAAa;EACbC,KAAK,GAAG,CAAC,CAAC;EACVC,QAAQ;EACRC,SAAS;EACTC,QAAQ;EACRC,UAAU;EACVC;AACU,CAAC,EAAE;EACb;EACA;EACA,MAAMC,eAAe,GAAG,IAAAC,yCAAiB,EAAC,oBAAoB,EAAEP,KAAK,CAAC,IAAI,SAAS;EACnF,MAAMQ,MAAM,GAAG,IAAAD,yCAAiB,EAAC,gBAAgB,EAAEP,KAAK,CAAC,IAAI,EAAE;EAC/D,MAAMS,iBAAiB,GAAG,IAAAF,yCAAiB,EAAC,4BAA4B,EAAEP,KAAK,CAAC,IAAI,EAAE;EACtF,MAAMU,eAAe,GAAG,IAAAH,yCAAiB,EAAC,0BAA0B,EAAEP,KAAK,CAAC,IAAI,EAAE;EAClF,MAAMW,GAAG,GAAG,IAAAJ,yCAAiB,EAAC,aAAa,EAAEP,KAAK,CAAC,IAAI,EAAE;;EAEzD;EACA,MAAMY,UAAU,GAAG,IAAAL,yCAAiB,EAAC,qBAAqB,EAAEP,KAAK,CAAC,IAAI,CAAC;;EAEvE;EACA,MAAMa,UAAU,GAAG,IAAAN,yCAAiB,EAAC,qBAAqB,EAAEP,KAAK,CAAC,IAAI,SAAS;EAC/E,MAAMc,eAAe,GAAG,IAAAP,yCAAiB,EAAC,0BAA0B,EAAEP,KAAK,CAAC,IAAI,aAAa;EAC7F,MAAMe,aAAa,GAAG,IAAAR,yCAAiB,EAAC,wBAAwB,EAAEP,KAAK,CAAC,IAAI,EAAE;EAC9E,MAAMgB,eAAe,GAAG,IAAAT,yCAAiB,EAAC,0BAA0B,EAAEP,KAAK,CAAC,IAAI,EAAE;;EAElF;EACA,MAAMiB,SAAS,GAAG,IAAAV,yCAAiB,EAAC,oBAAoB,EAAEP,KAAK,CAAC,IAAI,SAAS;EAC7E,MAAMkB,cAAc,GAAG,IAAAX,yCAAiB,EAAC,yBAAyB,EAAEP,KAAK,CAAC,IAAI,aAAa;EAC3F,MAAMmB,YAAY,GAAG,IAAAZ,yCAAiB,EAAC,uBAAuB,EAAEP,KAAK,CAAC,IAAI,EAAE;EAC5E,MAAMoB,cAAc,GAAG,IAAAb,yCAAiB,EAAC,yBAAyB,EAAEP,KAAK,CAAC,IAAI,EAAE;;EAEhF;EACA,MAAMqB,cAAyB,GAAG;IAC9Bf,eAAe;IACfgB,YAAY,EAAEd,MAAM;IACpBC,iBAAiB;IACjBC,eAAe;IACfC,GAAG;IACHY,UAAU,EAAE,YAAY;IACxBC,KAAK,EAAE,MAAM;IAAE;IACfC,QAAQ,EAAE;EACd,CAAC;EAED,MAAMC,gBAA2B,GAAG;IAChCf,GAAG,EAAEC,UAAU;IACfW,UAAU,EAAE,YAAY;IACxBC,KAAK,EAAE;EACX,CAAC;EAED,MAAMG,UAAqB,GAAG;IAC1BC,KAAK,EAAEf,UAAU;IACjBgB,UAAU,EAAEf,eAAe;IAC3BgB,QAAQ,EAAEf,aAAa;IACvBgB,UAAU,EAAEf,eAAe;IAC3BgB,UAAU,EAAE,KAAK,CAAE;EACvB,CAAC;EAED,MAAMC,SAAoB,GAAG;IACzBL,KAAK,EAAEX,SAAS;IAChBY,UAAU,EAAEX,cAAc;IAC1BY,QAAQ,EAAEX,YAAY;IACtBY,UAAU,EAAEX,cAAc;IAC1BY,UAAU,EAAE,KAAK,CAAE;EACvB,CAAC;;EAED;EACA;EACA,MAAME,UAAU,GAAIC,IAAqB,IAAK;IAC1C,iBAAIC,cAAK,CAACC,cAAc,CAACF,IAAI,CAAC,EAAE;MAC5B,oBAAOC,cAAK,CAACE,YAAY,CAACH,IAAI,EAA6B;QACvDnC,KAAK,EAAE;UAAE,GAAGA,KAAK;UAAE,GAAImC,IAAI,CAASI,KAAK,CAACvC;QAAM;MACpD,CAAC,CAAC;IACN;IACA,OAAOmC,IAAI;EACf,CAAC;EAED,oBACI,IAAA7C,WAAA,CAAAkD,IAAA,EAACtD,YAAA,CAAAuD,IAAI;IAACpC,KAAK,EAAE,CAACgB,cAAc,EAAEhB,KAAK,CAAE;IAAAqC,QAAA,gBACjC,IAAApD,WAAA,CAAAkD,IAAA,EAACtD,YAAA,CAAAuD,IAAI;MAACpC,KAAK,EAAEqB,gBAAiB;MAAAgB,QAAA,GAEzBzC,QAAQ,GACLiC,UAAU,CAACjC,QAAQ,CAAC,gBAEpB,IAAAX,WAAA,CAAAqD,GAAA,EAACvD,YAAA,CAAAK,OAAW;QAACI,QAAQ,EAAEA,QAAS;QAACG,KAAK,EAAEA;MAAM,CAAE,CACnD,EAGAE,SAAS,GACNgC,UAAU,CAAChC,SAAS,CAAC,gBAErB,IAAAZ,WAAA,CAAAqD,GAAA,EAACzD,YAAA,CAAA0D,IAAI;QAACvC,KAAK,EAAEsB,UAAW;QAAAe,QAAA,EAAE/C;MAAK,CAAO,CACzC,EAGAQ,QAAQ,GACL+B,UAAU,CAAC/B,QAAQ,CAAC,gBAEpB,IAAAb,WAAA,CAAAqD,GAAA,EAACzD,YAAA,CAAA0D,IAAI;QAACvC,KAAK,EAAE4B,SAAU;QAAAS,QAAA,EAAE9C;MAAI,CAAO,CACvC;IAAA,CACC,CAAC,EAGNQ,UAAU,GACP8B,UAAU,CAAC9B,UAAU,CAAC,gBAEtB,IAAAd,WAAA,CAAAqD,GAAA,EAACtD,OAAA,CAAAI,OAAM;MACHoD,KAAK,EAAE/C,WAAY;MACnBgD,OAAO,EAAE/C,aAAc;MACvBC,KAAK,EAAEA;IAAM,CAChB,CACJ;EAAA,CACC,CAAC;AAEf;AAAC,IAAA+C,QAAA,GAAAC,OAAA,CAAAvD,OAAA,GAEcC,OAAO","ignoreList":[]}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Meta, Story, Canvas, PureArgsTable as ArgsTable } from '@storybook/addon-docs/blocks';
|
|
2
|
+
import * as CtaCardStories from './CtaCard.stories';
|
|
3
|
+
import CtaCard from './CtaCard';
|
|
4
|
+
|
|
5
|
+
<Meta of={CtaCardStories} />
|
|
6
|
+
|
|
7
|
+
# CtaCard
|
|
8
|
+
|
|
9
|
+
`CtaCard` is a component used to display a Call-to-Action with an icon, title, body text, and a button.
|
|
10
|
+
It is designed to be flexible, allowing content to be passed via props or fully customized via slots.
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
## Available Collections and Modes
|
|
14
|
+
|
|
15
|
+
This component does not use any design token collections with multiple modes.
|
|
16
|
+
## Usage
|
|
17
|
+
|
|
18
|
+
```tsx
|
|
19
|
+
import { CtaCard } from 'jfs-components'; // Adjust import based on your package structure
|
|
20
|
+
|
|
21
|
+
// Basic Usage
|
|
22
|
+
<CtaCard
|
|
23
|
+
title="Lets create your UPI ID"
|
|
24
|
+
body="Send and receive money securely."
|
|
25
|
+
iconName="ic_upi_number"
|
|
26
|
+
buttonLabel="Get started"
|
|
27
|
+
onPressButton={() => console.log('Pressed')}
|
|
28
|
+
/>
|
|
29
|
+
|
|
30
|
+
// Using Slots
|
|
31
|
+
<CtaCard
|
|
32
|
+
titleSlot={<CustomTitle />}
|
|
33
|
+
buttonSlot={<CustomButton />}
|
|
34
|
+
/>
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
<Canvas>
|
|
38
|
+
<Story of={CtaCardStories.Default} />
|
|
39
|
+
</Canvas>
|
|
40
|
+
|
|
41
|
+
## Props
|
|
42
|
+
|
|
43
|
+
<ArgsTable of={CtaCard} />
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
## Design Tokens
|
|
47
|
+
|
|
48
|
+
This component uses the following design tokens, resolved through `getVariableByName`:
|
|
49
|
+
|
|
50
|
+
- **`ctaCard/background`**
|
|
51
|
+
- **`ctaCard/body/color`**
|
|
52
|
+
- **`ctaCard/body/fontFamily`**
|
|
53
|
+
- **`ctaCard/body/fontSize`**
|
|
54
|
+
- **`ctaCard/body/lineHeight`**
|
|
55
|
+
- **`ctaCard/content/gap`**
|
|
56
|
+
- **`ctaCard/gap`**
|
|
57
|
+
- **`ctaCard/padding/horizontal`**
|
|
58
|
+
- **`ctaCard/padding/vertical`**
|
|
59
|
+
- **`ctaCard/radius`**
|
|
60
|
+
- **`ctaCard/title/color`**
|
|
61
|
+
- **`ctaCard/title/fontFamily`**
|
|
62
|
+
- **`ctaCard/title/fontSize`**
|
|
63
|
+
- **`ctaCard/title/lineHeight`**
|
|
64
|
+
|
|
65
|
+
All tokens support mode-based theming through the `modes` prop.
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "default", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _CtaCard.default;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
var _CtaCard = _interopRequireDefault(require("./CtaCard"));
|
|
13
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_CtaCard","_interopRequireDefault","require","e","__esModule","default"],"sourceRoot":"../../../../src","sources":["components/CtaCard/index.ts"],"mappings":";;;;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAoC,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA","ignoreList":[]}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = ThreadHero;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _figmaVariablesResolver = require("../../design-tokens/figma-variables-resolver");
|
|
10
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
11
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
12
|
+
/**
|
|
13
|
+
* ThreadHero component displaying a central identity with avatar, title, subtitle, and caption.
|
|
14
|
+
*/
|
|
15
|
+
function ThreadHero({
|
|
16
|
+
title = 'Subhash Rajan',
|
|
17
|
+
subtitle = 'Banking name: SHIVASHANKAR RAJAN',
|
|
18
|
+
caption,
|
|
19
|
+
renderAvatar,
|
|
20
|
+
modes = {},
|
|
21
|
+
style
|
|
22
|
+
}) {
|
|
23
|
+
// Container Gaps
|
|
24
|
+
const containerGap = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/gap', modes)) || 8;
|
|
25
|
+
const detailsGap = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/details/gap', modes)) || 2;
|
|
26
|
+
|
|
27
|
+
// Title Styles
|
|
28
|
+
const titleColor = (0, _figmaVariablesResolver.getVariableByName)('threadHero/title/color', modes) || '#191b1e';
|
|
29
|
+
const titleFontSize = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/title/fontSize', modes)) || 16;
|
|
30
|
+
const titleFontFamily = (0, _figmaVariablesResolver.getVariableByName)('threadHero/title/fontFamily', modes) || 'System';
|
|
31
|
+
const titleLineHeight = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/title/lineHeight', modes)) || 20;
|
|
32
|
+
const titleFontWeight = (0, _figmaVariablesResolver.getVariableByName)('threadHero/title/fontWeight', modes) || '600';
|
|
33
|
+
|
|
34
|
+
// Subtitle Styles
|
|
35
|
+
const subtitleColor = (0, _figmaVariablesResolver.getVariableByName)('threadHero/subtitle/color', modes) || '#5d5d61';
|
|
36
|
+
const subtitleFontSize = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/subtitle/fontSize', modes)) || 12;
|
|
37
|
+
const subtitleFontFamily = (0, _figmaVariablesResolver.getVariableByName)('threadHero/subtitle/fontFamily', modes) || 'System';
|
|
38
|
+
const subtitleLineHeight = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/subtitle/lineHeight', modes)) || 18;
|
|
39
|
+
const subtitleFontWeight = (0, _figmaVariablesResolver.getVariableByName)('threadHero/subtitle/fontWeight', modes) || '500';
|
|
40
|
+
|
|
41
|
+
// Caption Styles
|
|
42
|
+
const captionColor = (0, _figmaVariablesResolver.getVariableByName)('threadHero/caption/color', modes) || '#5d5d61';
|
|
43
|
+
const captionFontSize = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/caption/fontSize', modes)) || 12;
|
|
44
|
+
const captionFontFamily = (0, _figmaVariablesResolver.getVariableByName)('threadHero/caption/fontFamily', modes) || 'System';
|
|
45
|
+
const captionLineHeight = Number((0, _figmaVariablesResolver.getVariableByName)('threadHero/caption/lineHeight', modes)) || 18;
|
|
46
|
+
const captionFontWeight = (0, _figmaVariablesResolver.getVariableByName)('threadHero/caption/fontWeight', modes) || '500';
|
|
47
|
+
|
|
48
|
+
// Styles
|
|
49
|
+
const containerStyle = {
|
|
50
|
+
flexDirection: 'column',
|
|
51
|
+
alignItems: 'center',
|
|
52
|
+
gap: containerGap,
|
|
53
|
+
...style
|
|
54
|
+
};
|
|
55
|
+
const detailsStyle = {
|
|
56
|
+
flexDirection: 'column',
|
|
57
|
+
alignItems: 'center',
|
|
58
|
+
gap: detailsGap,
|
|
59
|
+
width: '100%'
|
|
60
|
+
};
|
|
61
|
+
const titleStyle = {
|
|
62
|
+
color: titleColor,
|
|
63
|
+
fontSize: titleFontSize,
|
|
64
|
+
fontFamily: titleFontFamily,
|
|
65
|
+
lineHeight: titleLineHeight,
|
|
66
|
+
fontWeight: titleFontWeight,
|
|
67
|
+
textAlign: 'center',
|
|
68
|
+
minWidth: '100%'
|
|
69
|
+
};
|
|
70
|
+
const subtitleStyle = {
|
|
71
|
+
color: subtitleColor,
|
|
72
|
+
fontSize: subtitleFontSize,
|
|
73
|
+
fontFamily: subtitleFontFamily,
|
|
74
|
+
lineHeight: subtitleLineHeight,
|
|
75
|
+
fontWeight: subtitleFontWeight,
|
|
76
|
+
textAlign: 'center',
|
|
77
|
+
minWidth: '100%'
|
|
78
|
+
};
|
|
79
|
+
const captionStyle = {
|
|
80
|
+
color: captionColor,
|
|
81
|
+
fontSize: captionFontSize,
|
|
82
|
+
fontFamily: captionFontFamily,
|
|
83
|
+
lineHeight: captionLineHeight,
|
|
84
|
+
fontWeight: captionFontWeight,
|
|
85
|
+
textAlign: 'center',
|
|
86
|
+
width: '100%'
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
// Process Avatar Slot to inject modes
|
|
90
|
+
const avatarContent = /*#__PURE__*/(0, _react.isValidElement)(renderAvatar) ? /*#__PURE__*/(0, _react.cloneElement)(renderAvatar, {
|
|
91
|
+
modes
|
|
92
|
+
}) : renderAvatar;
|
|
93
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
94
|
+
style: containerStyle,
|
|
95
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
96
|
+
style: detailsStyle,
|
|
97
|
+
children: [avatarContent, title ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
98
|
+
style: titleStyle,
|
|
99
|
+
children: title
|
|
100
|
+
}) : null, subtitle ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
101
|
+
style: subtitleStyle,
|
|
102
|
+
numberOfLines: 1,
|
|
103
|
+
ellipsizeMode: "tail",
|
|
104
|
+
children: subtitle
|
|
105
|
+
}) : null]
|
|
106
|
+
}), caption ? /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
107
|
+
style: captionStyle,
|
|
108
|
+
numberOfLines: 1,
|
|
109
|
+
ellipsizeMode: "tail",
|
|
110
|
+
children: caption
|
|
111
|
+
}) : null]
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
//# sourceMappingURL=ThreadHero.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_figmaVariablesResolver","_jsxRuntime","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ThreadHero","title","subtitle","caption","renderAvatar","modes","style","containerGap","Number","getVariableByName","detailsGap","titleColor","titleFontSize","titleFontFamily","titleLineHeight","titleFontWeight","subtitleColor","subtitleFontSize","subtitleFontFamily","subtitleLineHeight","subtitleFontWeight","captionColor","captionFontSize","captionFontFamily","captionLineHeight","captionFontWeight","containerStyle","flexDirection","alignItems","gap","detailsStyle","width","titleStyle","color","fontSize","fontFamily","lineHeight","fontWeight","textAlign","minWidth","subtitleStyle","captionStyle","avatarContent","isValidElement","cloneElement","jsxs","View","children","jsx","Text","numberOfLines","ellipsizeMode"],"sourceRoot":"../../../../src","sources":["components/ThreadHero/ThreadHero.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Meta, Story, Canvas, PureArgsTable as ArgsTable } from '@storybook/addon-docs/blocks';
|
|
2
|
+
import * as ThreadHeroStories from './ThreadHero.stories';
|
|
3
|
+
import ThreadHero from './ThreadHero';
|
|
4
|
+
|
|
5
|
+
<Meta of={ThreadHeroStories} />
|
|
6
|
+
|
|
7
|
+
# ThreadHero
|
|
8
|
+
|
|
9
|
+
The `ThreadHero` component displays a central user identity with an avatar, title, subtitle, and an optional caption.
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
## Available Collections and Modes
|
|
13
|
+
|
|
14
|
+
This component does not use any design token collections with multiple modes.
|
|
15
|
+
## Usage
|
|
16
|
+
|
|
17
|
+
```tsx
|
|
18
|
+
import ThreadHero from './ThreadHero';
|
|
19
|
+
import Avatar from '../Avatar/Avatar';
|
|
20
|
+
|
|
21
|
+
<ThreadHero
|
|
22
|
+
title="Subhash Rajan"
|
|
23
|
+
subtitle="Banking name: SHIVASHANKAR RAJAN"
|
|
24
|
+
caption="+91 00000 00000"
|
|
25
|
+
renderAvatar={<Avatar size="small" initials="SR" />}
|
|
26
|
+
/>
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
## Props
|
|
30
|
+
|
|
31
|
+
<ArgsTable of={ThreadHero} />
|
|
32
|
+
|
|
33
|
+
## Stories
|
|
34
|
+
|
|
35
|
+
### Default
|
|
36
|
+
|
|
37
|
+
<Canvas>
|
|
38
|
+
<Story of={ThreadHeroStories.Default} />
|
|
39
|
+
</Canvas>
|
|
40
|
+
|
|
41
|
+
### Without Caption
|
|
42
|
+
|
|
43
|
+
<Canvas>
|
|
44
|
+
<Story of={ThreadHeroStories.WithoutCaption} />
|
|
45
|
+
</Canvas>
|
|
46
|
+
|
|
47
|
+
## Design Tokens
|
|
48
|
+
|
|
49
|
+
This component uses the following design tokens, resolved through `getVariableByName`:
|
|
50
|
+
|
|
51
|
+
- **`threadHero/caption/color`**
|
|
52
|
+
- **`threadHero/caption/fontFamily`**
|
|
53
|
+
- **`threadHero/caption/fontSize`**
|
|
54
|
+
- **`threadHero/caption/fontWeight`**
|
|
55
|
+
- **`threadHero/caption/lineHeight`**
|
|
56
|
+
- **`threadHero/details/gap`**
|
|
57
|
+
- **`threadHero/gap`**
|
|
58
|
+
- **`threadHero/subtitle/color`**
|
|
59
|
+
- **`threadHero/subtitle/fontFamily`**
|
|
60
|
+
- **`threadHero/subtitle/fontSize`**
|
|
61
|
+
- **`threadHero/subtitle/fontWeight`**
|
|
62
|
+
- **`threadHero/subtitle/lineHeight`**
|
|
63
|
+
- **`threadHero/title/color`**
|
|
64
|
+
- **`threadHero/title/fontFamily`**
|
|
65
|
+
- **`threadHero/title/fontSize`**
|
|
66
|
+
- **`threadHero/title/fontWeight`**
|
|
67
|
+
- **`threadHero/title/lineHeight`**
|
|
68
|
+
|
|
69
|
+
All tokens support mode-based theming through the `modes` prop.
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = TransactionBubble;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _figmaVariablesResolver = require("../../design-tokens/figma-variables-resolver");
|
|
10
|
+
var _MoneyValue = _interopRequireDefault(require("../MoneyValue/MoneyValue"));
|
|
11
|
+
var _NavArrow = _interopRequireDefault(require("../NavArrow/NavArrow"));
|
|
12
|
+
var _TransactionStatus = _interopRequireDefault(require("../TransactionStatus/TransactionStatus"));
|
|
13
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
14
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
15
|
+
/**
|
|
16
|
+
* TransactionBubble component displaying transaction details in a bubble card.
|
|
17
|
+
*
|
|
18
|
+
* @component
|
|
19
|
+
*/
|
|
20
|
+
function TransactionBubble({
|
|
21
|
+
description = 'Payment to Uber India',
|
|
22
|
+
amount = '56',
|
|
23
|
+
currency = '₹',
|
|
24
|
+
status = 'Expired',
|
|
25
|
+
statusDate = '20 Mar 2025',
|
|
26
|
+
modes = {},
|
|
27
|
+
style
|
|
28
|
+
}) {
|
|
29
|
+
// --- Container Tokens ---
|
|
30
|
+
const backgroundColor = (0, _figmaVariablesResolver.getVariableByName)('transactionBubble/background', modes) || '#ffffff';
|
|
31
|
+
const borderColor = (0, _figmaVariablesResolver.getVariableByName)('transactionBubble/border/color', modes) || '#e5e5e5';
|
|
32
|
+
const borderWidth = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/border/size', modes)) || 1;
|
|
33
|
+
const borderRadius = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/radius', modes)) || 23;
|
|
34
|
+
const padding = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/padding', modes)) || 16;
|
|
35
|
+
const gap = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/gap', modes)) || 8;
|
|
36
|
+
|
|
37
|
+
// --- Description Tokens ---
|
|
38
|
+
const descColor = (0, _figmaVariablesResolver.getVariableByName)('transactionBubble/description/color', modes) || '#24262b';
|
|
39
|
+
const descFontSize = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/description/fontSize', modes)) || 14;
|
|
40
|
+
const descLineHeight = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/description/lineHeight', modes)) || 17;
|
|
41
|
+
const descFontFamily = (0, _figmaVariablesResolver.getVariableByName)('transactionBubble/description/fontFamily', modes) || 'System';
|
|
42
|
+
|
|
43
|
+
// --- Status Row Tokens ---
|
|
44
|
+
// Status wrapping gap from TransactionBubble definition for the row container
|
|
45
|
+
const statusHeight = Number((0, _figmaVariablesResolver.getVariableByName)('transactionBubble/statusWrap/height', modes)) || 18;
|
|
46
|
+
const containerStyle = {
|
|
47
|
+
backgroundColor,
|
|
48
|
+
borderColor,
|
|
49
|
+
borderWidth,
|
|
50
|
+
borderRadius,
|
|
51
|
+
padding,
|
|
52
|
+
gap,
|
|
53
|
+
alignItems: 'flex-start',
|
|
54
|
+
width: 231,
|
|
55
|
+
// Fixed width from design or prop? Design shows w-[231px]. We can make it auto or fixed. Let's respect style prop.
|
|
56
|
+
...style
|
|
57
|
+
};
|
|
58
|
+
const descriptionStyle = {
|
|
59
|
+
color: descColor,
|
|
60
|
+
fontSize: descFontSize,
|
|
61
|
+
lineHeight: descLineHeight,
|
|
62
|
+
fontFamily: descFontFamily,
|
|
63
|
+
fontWeight: '500' // Hardcoded in design as 'Medium' -> 500
|
|
64
|
+
};
|
|
65
|
+
return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
66
|
+
style: containerStyle,
|
|
67
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
68
|
+
style: {
|
|
69
|
+
gap: 8,
|
|
70
|
+
width: '100%'
|
|
71
|
+
},
|
|
72
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
|
|
73
|
+
style: descriptionStyle,
|
|
74
|
+
numberOfLines: 1,
|
|
75
|
+
ellipsizeMode: "tail",
|
|
76
|
+
children: description
|
|
77
|
+
}), /*#__PURE__*/(0, _jsxRuntime.jsx)(_MoneyValue.default, {
|
|
78
|
+
value: amount,
|
|
79
|
+
currency: currency,
|
|
80
|
+
modes: modes
|
|
81
|
+
})]
|
|
82
|
+
}), /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
|
|
83
|
+
style: {
|
|
84
|
+
flexDirection: 'row',
|
|
85
|
+
alignItems: 'center',
|
|
86
|
+
justifyContent: 'space-between',
|
|
87
|
+
width: '100%',
|
|
88
|
+
height: statusHeight // Enforce height from design
|
|
89
|
+
},
|
|
90
|
+
children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_TransactionStatus.default, {
|
|
91
|
+
status: status,
|
|
92
|
+
date: statusDate,
|
|
93
|
+
modes: modes
|
|
94
|
+
}), /*#__PURE__*/(0, _jsxRuntime.jsx)(_NavArrow.default, {
|
|
95
|
+
direction: "Forward",
|
|
96
|
+
modes: modes
|
|
97
|
+
})]
|
|
98
|
+
})]
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
//# sourceMappingURL=TransactionBubble.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","_figmaVariablesResolver","_MoneyValue","_NavArrow","_TransactionStatus","_jsxRuntime","e","__esModule","default","TransactionBubble","description","amount","currency","status","statusDate","modes","style","backgroundColor","getVariableByName","borderColor","borderWidth","Number","borderRadius","padding","gap","descColor","descFontSize","descLineHeight","descFontFamily","statusHeight","containerStyle","alignItems","width","descriptionStyle","color","fontSize","lineHeight","fontFamily","fontWeight","jsxs","View","children","jsx","Text","numberOfLines","ellipsizeMode","value","flexDirection","justifyContent","height","date","direction"],"sourceRoot":"../../../../src","sources":["components/TransactionBubble/TransactionBubble.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Meta, Story, Canvas, PureArgsTable as ArgsTable } from '@storybook/addon-docs/blocks';
|
|
2
|
+
import * as TransactionBubbleStories from './TransactionBubble.stories';
|
|
3
|
+
import TransactionBubble from './TransactionBubble';
|
|
4
|
+
|
|
5
|
+
<Meta of={TransactionBubbleStories} />
|
|
6
|
+
|
|
7
|
+
# TransactionBubble
|
|
8
|
+
|
|
9
|
+
TransactionBubble component with design-token-driven styling.
|
|
10
|
+
|
|
11
|
+
## Available Collections and Modes
|
|
12
|
+
|
|
13
|
+
This component does not use any design token collections with multiple modes.
|
|
14
|
+
## Usage
|
|
15
|
+
|
|
16
|
+
<Canvas>
|
|
17
|
+
<Story of={TransactionBubbleStories.Default} />
|
|
18
|
+
</Canvas>
|
|
19
|
+
|
|
20
|
+
## Props
|
|
21
|
+
|
|
22
|
+
<ArgsTable of={TransactionBubble} />
|
|
23
|
+
|
|
24
|
+
## Design Tokens
|
|
25
|
+
|
|
26
|
+
This component uses the following design tokens, resolved through `getVariableByName`:
|
|
27
|
+
|
|
28
|
+
- **`transactionBubble/background`**
|
|
29
|
+
- **`transactionBubble/border/color`**
|
|
30
|
+
- **`transactionBubble/border/size`**
|
|
31
|
+
- **`transactionBubble/description/color`**
|
|
32
|
+
- **`transactionBubble/description/fontFamily`**
|
|
33
|
+
- **`transactionBubble/description/fontSize`**
|
|
34
|
+
- **`transactionBubble/description/lineHeight`**
|
|
35
|
+
- **`transactionBubble/gap`**
|
|
36
|
+
- **`transactionBubble/padding`**
|
|
37
|
+
- **`transactionBubble/radius`**
|
|
38
|
+
- **`transactionBubble/statusWrap/height`**
|
|
39
|
+
|
|
40
|
+
All tokens support mode-based theming through the `modes` prop.
|