jfs-components 0.0.2 → 0.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/lib/commonjs/components/Accordion/Accordion.js +217 -0
  2. package/lib/commonjs/components/Accordion/Accordion.js.map +1 -0
  3. package/lib/commonjs/components/Accordion/Accordion.mdx +122 -0
  4. package/lib/commonjs/components/ActionTile/ActionTile.js +93 -0
  5. package/lib/commonjs/components/ActionTile/ActionTile.js.map +1 -0
  6. package/lib/commonjs/components/ActionTile/ActionTile.mdx +54 -0
  7. package/lib/commonjs/components/ActionTile/index.js +14 -0
  8. package/lib/commonjs/components/ActionTile/index.js.map +1 -0
  9. package/lib/commonjs/components/CtaCard/CtaCard.js +122 -0
  10. package/lib/commonjs/components/CtaCard/CtaCard.js.map +1 -0
  11. package/lib/commonjs/components/CtaCard/CtaCard.mdx +66 -0
  12. package/lib/commonjs/components/CtaCard/index.js +14 -0
  13. package/lib/commonjs/components/CtaCard/index.js.map +1 -0
  14. package/lib/commonjs/components/MoneyValue/MoneyValue.js +36 -4
  15. package/lib/commonjs/components/MoneyValue/MoneyValue.js.map +1 -1
  16. package/lib/commonjs/components/ThreadHero/ThreadHero.js +114 -0
  17. package/lib/commonjs/components/ThreadHero/ThreadHero.js.map +1 -0
  18. package/lib/commonjs/components/ThreadHero/ThreadHero.mdx +69 -0
  19. package/lib/commonjs/components/TransactionBubble/TransactionBubble.js +101 -0
  20. package/lib/commonjs/components/TransactionBubble/TransactionBubble.js.map +1 -0
  21. package/lib/commonjs/components/TransactionBubble/TransactionBubble.mdx +40 -0
  22. package/lib/commonjs/components/TransactionDetails/TransactionDetails.js +177 -0
  23. package/lib/commonjs/components/TransactionDetails/TransactionDetails.js.map +1 -0
  24. package/lib/commonjs/components/TransactionDetails/TransactionDetails.mdx +98 -0
  25. package/lib/commonjs/components/TransactionStatus/TransactionStatus.js +82 -0
  26. package/lib/commonjs/components/TransactionStatus/TransactionStatus.js.map +1 -0
  27. package/lib/commonjs/components/TransactionStatus/TransactionStatus.mdx +41 -0
  28. package/lib/commonjs/components/index.js +35 -0
  29. package/lib/commonjs/components/index.js.map +1 -1
  30. package/lib/commonjs/design-tokens/figma-variables-resolver.js +3 -9
  31. package/lib/commonjs/icons/registry.js +1 -1
  32. package/lib/module/components/Accordion/Accordion.js +212 -0
  33. package/lib/module/components/Accordion/Accordion.js.map +1 -0
  34. package/lib/module/components/Accordion/Accordion.mdx +122 -0
  35. package/lib/module/components/ActionTile/ActionTile.js +88 -0
  36. package/lib/module/components/ActionTile/ActionTile.js.map +1 -0
  37. package/lib/module/components/ActionTile/ActionTile.mdx +54 -0
  38. package/lib/module/components/ActionTile/index.js +4 -0
  39. package/lib/module/components/ActionTile/index.js.map +1 -0
  40. package/lib/module/components/CtaCard/CtaCard.js +117 -0
  41. package/lib/module/components/CtaCard/CtaCard.js.map +1 -0
  42. package/lib/module/components/CtaCard/CtaCard.mdx +66 -0
  43. package/lib/module/components/CtaCard/index.js +4 -0
  44. package/lib/module/components/CtaCard/index.js.map +1 -0
  45. package/lib/module/components/MoneyValue/MoneyValue.js +36 -4
  46. package/lib/module/components/MoneyValue/MoneyValue.js.map +1 -1
  47. package/lib/module/components/ThreadHero/ThreadHero.js +109 -0
  48. package/lib/module/components/ThreadHero/ThreadHero.js.map +1 -0
  49. package/lib/module/components/ThreadHero/ThreadHero.mdx +69 -0
  50. package/lib/module/components/TransactionBubble/TransactionBubble.js +96 -0
  51. package/lib/module/components/TransactionBubble/TransactionBubble.js.map +1 -0
  52. package/lib/module/components/TransactionBubble/TransactionBubble.mdx +40 -0
  53. package/lib/module/components/TransactionDetails/TransactionDetails.js +174 -0
  54. package/lib/module/components/TransactionDetails/TransactionDetails.js.map +1 -0
  55. package/lib/module/components/TransactionDetails/TransactionDetails.mdx +98 -0
  56. package/lib/module/components/TransactionStatus/TransactionStatus.js +77 -0
  57. package/lib/module/components/TransactionStatus/TransactionStatus.js.map +1 -0
  58. package/lib/module/components/TransactionStatus/TransactionStatus.mdx +41 -0
  59. package/lib/module/components/index.js +5 -0
  60. package/lib/module/components/index.js.map +1 -1
  61. package/lib/module/icons/registry.js +1 -1
  62. package/lib/typescript/components/Accordion/Accordion.d.ts +58 -0
  63. package/lib/typescript/components/Accordion/Accordion.d.ts.map +1 -0
  64. package/lib/typescript/components/ActionTile/ActionTile.d.ts +26 -0
  65. package/lib/typescript/components/ActionTile/ActionTile.d.ts.map +1 -0
  66. package/lib/typescript/components/ActionTile/index.d.ts +2 -0
  67. package/lib/typescript/components/ActionTile/index.d.ts.map +1 -0
  68. package/lib/typescript/components/CtaCard/CtaCard.d.ts +61 -0
  69. package/lib/typescript/components/CtaCard/CtaCard.d.ts.map +1 -0
  70. package/lib/typescript/components/CtaCard/index.d.ts +2 -0
  71. package/lib/typescript/components/CtaCard/index.d.ts.map +1 -0
  72. package/lib/typescript/components/MoneyValue/MoneyValue.d.ts +9 -2
  73. package/lib/typescript/components/MoneyValue/MoneyValue.d.ts.map +1 -1
  74. package/lib/typescript/components/ThreadHero/ThreadHero.d.ts +21 -0
  75. package/lib/typescript/components/ThreadHero/ThreadHero.d.ts.map +1 -0
  76. package/lib/typescript/components/TransactionBubble/TransactionBubble.d.ts +24 -0
  77. package/lib/typescript/components/TransactionBubble/TransactionBubble.d.ts.map +1 -0
  78. package/lib/typescript/components/TransactionDetails/TransactionDetails.d.ts +57 -0
  79. package/lib/typescript/components/TransactionDetails/TransactionDetails.d.ts.map +1 -0
  80. package/lib/typescript/components/TransactionStatus/TransactionStatus.d.ts +16 -0
  81. package/lib/typescript/components/TransactionStatus/TransactionStatus.d.ts.map +1 -0
  82. package/lib/typescript/components/index.d.ts +5 -0
  83. package/lib/typescript/components/index.d.ts.map +1 -1
  84. package/lib/typescript/icons/registry.d.ts +1 -1
  85. package/package.json +5 -2
  86. package/src/components/.token-metadata.json +161 -0
  87. package/src/components/Accordion/Accordion.mdx +122 -0
  88. package/src/components/Accordion/Accordion.tsx +279 -0
  89. package/src/components/ActionTile/ActionTile.mdx +54 -0
  90. package/src/components/ActionTile/ActionTile.tsx +100 -0
  91. package/src/components/ActionTile/index.ts +1 -0
  92. package/src/components/CtaCard/CtaCard.mdx +66 -0
  93. package/src/components/CtaCard/CtaCard.tsx +185 -0
  94. package/src/components/CtaCard/index.ts +1 -0
  95. package/src/components/MoneyValue/MoneyValue.tsx +39 -3
  96. package/src/components/ThreadHero/ThreadHero.mdx +69 -0
  97. package/src/components/ThreadHero/ThreadHero.tsx +124 -0
  98. package/src/components/TransactionBubble/TransactionBubble.mdx +40 -0
  99. package/src/components/TransactionBubble/TransactionBubble.tsx +113 -0
  100. package/src/components/TransactionDetails/TransactionDetails.mdx +98 -0
  101. package/src/components/TransactionDetails/TransactionDetails.tsx +236 -0
  102. package/src/components/TransactionStatus/TransactionStatus.mdx +41 -0
  103. package/src/components/TransactionStatus/TransactionStatus.tsx +94 -0
  104. package/src/components/index.ts +5 -0
  105. package/src/icons/registry.ts +1 -1
@@ -0,0 +1,66 @@
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.
66
+
@@ -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":[]}
@@ -53,29 +53,56 @@ const CURRENCY_SYMBOLS = {
53
53
  * (e.g. "INR", "USD"). When an ISO code is provided, it will be mapped to the
54
54
  * appropriate symbol, with special care to support INR and other major currencies.
55
55
  *
56
+ * Negative values are auto-detected from the value prop (e.g., -500 or "-500").
57
+ * The `negative` prop can be used to explicitly override this behavior.
58
+ *
56
59
  * @component
57
60
  * @param {Object} props
58
- * @param {string|number} [props.value="500"] - Monetary value to display.
61
+ * @param {string|number} [props.value="500"] - Monetary value to display. Negative values are auto-detected.
59
62
  * @param {string} [props.currency="₹"] - Currency symbol or ISO code (e.g. "INR").
63
+ * @param {boolean} [props.negative] - Explicitly override negative display. If undefined, auto-detects from value.
60
64
  * @param {Object} [props.modes={}] - Modes object passed directly to `getVariableByName`.
61
65
  * Example: {"MoneyValue / Theme": "Default"}
62
66
  * @param {Object} [props.style] - Optional container style overrides.
63
67
  * @param {Object} [props.valueStyle] - Optional value text style overrides.
64
68
  * @param {Object} [props.currencyStyle] - Optional currency text style overrides.
69
+ * @param {Object} [props.negativeSignStyle] - Optional negative sign text style overrides.
65
70
  * @param {string} [props.accessibilityLabel] - Accessibility label for screen readers. If not provided, generates from value and currency
66
71
  * @param {string} [props.accessibilityHint] - Additional accessibility hint for screen readers
67
72
  */
68
73
  function MoneyValue({
69
74
  value = '500',
70
75
  currency = '₹',
76
+ negative,
71
77
  modes = {},
72
78
  style,
73
79
  valueStyle,
74
80
  currencyStyle,
81
+ negativeSignStyle,
75
82
  accessibilityLabel,
76
83
  accessibilityHint,
77
84
  ...rest
78
85
  }) {
86
+ // Auto-detect negative from value and compute display value
87
+ const {
88
+ isNegative,
89
+ displayValue
90
+ } = _react.default.useMemo(() => {
91
+ const stringValue = String(value);
92
+ const trimmed = stringValue.trim();
93
+ const valueIsNegative = trimmed.startsWith('-') || typeof value === 'number' && value < 0;
94
+
95
+ // Strip leading minus sign for display (we show it separately)
96
+ const absoluteValue = trimmed.startsWith('-') ? trimmed.slice(1) : trimmed;
97
+
98
+ // Use explicit negative prop if provided, otherwise use auto-detected
99
+ const showNegative = negative !== undefined ? negative : valueIsNegative;
100
+ return {
101
+ isNegative: showNegative,
102
+ displayValue: absoluteValue
103
+ };
104
+ }, [value, negative]);
105
+
79
106
  // Resolve typography and layout tokens from Figma
80
107
  const textColor = (0, _figmaVariablesResolver.getVariableByName)('moneyValue/text/color', modes) || '#0f0d0a';
81
108
  const fontSize = (0, _figmaVariablesResolver.getVariableByName)('moneyValue/supportText/fontSize', modes) || 14;
@@ -105,14 +132,19 @@ function MoneyValue({
105
132
  };
106
133
 
107
134
  // Generate default accessibility label from value and currency
108
- const defaultAccessibilityLabel = accessibilityLabel || `${resolvedCurrency} ${value}`;
135
+ const defaultAccessibilityLabel = accessibilityLabel || `${isNegative ? 'negative ' : ''}${resolvedCurrency} ${displayValue}`;
109
136
  return /*#__PURE__*/(0, _jsxRuntime.jsxs)(_reactNative.View, {
110
137
  style: [containerStyle, style],
111
138
  accessibilityRole: "text",
112
139
  accessibilityLabel: defaultAccessibilityLabel,
113
140
  accessibilityHint: accessibilityHint,
114
141
  ...rest,
115
- children: [/*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
142
+ children: [isNegative && /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
143
+ style: [baseTextStyle, negativeSignStyle],
144
+ accessibilityElementsHidden: true,
145
+ importantForAccessibility: "no",
146
+ children: "-"
147
+ }), /*#__PURE__*/(0, _jsxRuntime.jsx)(_reactNative.Text, {
116
148
  style: [baseTextStyle, currencyStyle],
117
149
  accessibilityElementsHidden: true,
118
150
  importantForAccessibility: "no",
@@ -121,7 +153,7 @@ function MoneyValue({
121
153
  style: [baseTextStyle, valueStyle],
122
154
  accessibilityElementsHidden: true,
123
155
  importantForAccessibility: "no",
124
- children: value
156
+ children: displayValue
125
157
  })]
126
158
  });
127
159
  }
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","_figmaVariablesResolver","_jsxRuntime","e","__esModule","default","CURRENCY_SYMBOLS","INR","USD","EUR","GBP","JPY","CNY","AUD","CAD","CHF","HKD","SGD","NZD","SEK","NOK","DKK","RUB","BRL","ZAR","AED","SAR","TRY","KRW","IDR","THB","MYR","PHP","VND","PKR","BDT","LKR","NPR","MoneyValue","value","currency","modes","style","valueStyle","currencyStyle","accessibilityLabel","accessibilityHint","rest","textColor","getVariableByName","fontSize","lineHeight","fontWeightValue","fontWeight","toString","fontFamily","gap","resolvedCurrency","React","useMemo","upper","toUpperCase","baseTextStyle","color","containerStyle","flexDirection","alignItems","defaultAccessibilityLabel","jsxs","View","accessibilityRole","children","jsx","Text","accessibilityElementsHidden","importantForAccessibility","_default","exports"],"sourceRoot":"../../../../src","sources":["components/MoneyValue/MoneyValue.tsx"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","_figmaVariablesResolver","_jsxRuntime","e","__esModule","default","CURRENCY_SYMBOLS","INR","USD","EUR","GBP","JPY","CNY","AUD","CAD","CHF","HKD","SGD","NZD","SEK","NOK","DKK","RUB","BRL","ZAR","AED","SAR","TRY","KRW","IDR","THB","MYR","PHP","VND","PKR","BDT","LKR","NPR","MoneyValue","value","currency","negative","modes","style","valueStyle","currencyStyle","negativeSignStyle","accessibilityLabel","accessibilityHint","rest","isNegative","displayValue","React","useMemo","stringValue","String","trimmed","trim","valueIsNegative","startsWith","absoluteValue","slice","showNegative","undefined","textColor","getVariableByName","fontSize","lineHeight","fontWeightValue","fontWeight","toString","fontFamily","gap","resolvedCurrency","upper","toUpperCase","baseTextStyle","color","containerStyle","flexDirection","alignItems","defaultAccessibilityLabel","jsxs","View","accessibilityRole","children","jsx","Text","accessibilityElementsHidden","importantForAccessibility","_default","exports"],"sourceRoot":"../../../../src","sources":["components/MoneyValue/MoneyValue.tsx"],"mappings":"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","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.