@campxdev/react-native-blueprint 0.1.17 → 0.1.18

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.
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ import figma from '@figma/code-connect';
4
+ import { FeedCard } from "./FeedCard.js";
5
+ import { jsx as _jsx } from "react/jsx-runtime";
6
+ const FIGMA_URL = 'https://www.figma.com/design/66WaqopqU3WXgwVtyQuTUf/React-Native-Blueprint-Library?node-id=511-10139';
7
+ figma.connect(FeedCard, FIGMA_URL, {
8
+ props: {
9
+ type: figma.enum('type', {
10
+ post: 'post',
11
+ announcement: 'announcement'
12
+ }),
13
+ authorName: figma.string('authorName'),
14
+ postTitle: figma.string('postTitle'),
15
+ subtitle: figma.string('subtitle'),
16
+ postContent: figma.string('postContent'),
17
+ showHeader: figma.boolean('Show Header'),
18
+ showLeading: figma.boolean('Show Leading'),
19
+ showMedia: figma.boolean('Show Media'),
20
+ showPostContent: figma.boolean('Show PostContent'),
21
+ showSubtitle: figma.boolean('Show Subtitle'),
22
+ showBadges: figma.boolean('Show Badges'),
23
+ showFooterActions: figma.boolean('Show FooterActions'),
24
+ showSecondaryButton: figma.boolean('Show SecondaryButton')
25
+ },
26
+ example: props => /*#__PURE__*/_jsx(FeedCard, {
27
+ type: props.type,
28
+ authorName: props.authorName,
29
+ postTitle: props.postTitle,
30
+ subtitle: props.subtitle,
31
+ postContent: props.postContent,
32
+ showHeader: props.showHeader,
33
+ showLeading: props.showLeading,
34
+ showMedia: props.showMedia,
35
+ showPostContent: props.showPostContent,
36
+ showSubtitle: props.showSubtitle,
37
+ showBadges: props.showBadges,
38
+ showFooterActions: props.showFooterActions,
39
+ showSecondaryButton: props.showSecondaryButton
40
+ })
41
+ });
42
+ //# sourceMappingURL=FeedCard.figma.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["figma","FeedCard","jsx","_jsx","FIGMA_URL","connect","props","type","enum","post","announcement","authorName","string","postTitle","subtitle","postContent","showHeader","boolean","showLeading","showMedia","showPostContent","showSubtitle","showBadges","showFooterActions","showSecondaryButton","example"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/FeedCard/FeedCard.figma.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,qBAAqB;AACvC,SAASC,QAAQ,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEtC,MAAMC,SAAS,GACb,sGAAsG;AAExGJ,KAAK,CAACK,OAAO,CAACJ,QAAQ,EAAEG,SAAS,EAAE;EACjCE,KAAK,EAAE;IACLC,IAAI,EAAEP,KAAK,CAACQ,IAAI,CAAC,MAAM,EAAE;MACvBC,IAAI,EAAE,MAAM;MACZC,YAAY,EAAE;IAChB,CAAC,CAAC;IACFC,UAAU,EAAEX,KAAK,CAACY,MAAM,CAAC,YAAY,CAAC;IACtCC,SAAS,EAAEb,KAAK,CAACY,MAAM,CAAC,WAAW,CAAC;IACpCE,QAAQ,EAAEd,KAAK,CAACY,MAAM,CAAC,UAAU,CAAC;IAClCG,WAAW,EAAEf,KAAK,CAACY,MAAM,CAAC,aAAa,CAAC;IACxCI,UAAU,EAAEhB,KAAK,CAACiB,OAAO,CAAC,aAAa,CAAC;IACxCC,WAAW,EAAElB,KAAK,CAACiB,OAAO,CAAC,cAAc,CAAC;IAC1CE,SAAS,EAAEnB,KAAK,CAACiB,OAAO,CAAC,YAAY,CAAC;IACtCG,eAAe,EAAEpB,KAAK,CAACiB,OAAO,CAAC,kBAAkB,CAAC;IAClDI,YAAY,EAAErB,KAAK,CAACiB,OAAO,CAAC,eAAe,CAAC;IAC5CK,UAAU,EAAEtB,KAAK,CAACiB,OAAO,CAAC,aAAa,CAAC;IACxCM,iBAAiB,EAAEvB,KAAK,CAACiB,OAAO,CAAC,oBAAoB,CAAC;IACtDO,mBAAmB,EAAExB,KAAK,CAACiB,OAAO,CAAC,sBAAsB;EAC3D,CAAC;EACDQ,OAAO,EAAGnB,KAAK,iBACbH,IAAA,CAACF,QAAQ;IACPM,IAAI,EAAED,KAAK,CAACC,IAAK;IACjBI,UAAU,EAAEL,KAAK,CAACK,UAAW;IAC7BE,SAAS,EAAEP,KAAK,CAACO,SAAU;IAC3BC,QAAQ,EAAER,KAAK,CAACQ,QAAS;IACzBC,WAAW,EAAET,KAAK,CAACS,WAAY;IAC/BC,UAAU,EAAEV,KAAK,CAACU,UAAW;IAC7BE,WAAW,EAAEZ,KAAK,CAACY,WAAY;IAC/BC,SAAS,EAAEb,KAAK,CAACa,SAAU;IAC3BC,eAAe,EAAEd,KAAK,CAACc,eAAgB;IACvCC,YAAY,EAAEf,KAAK,CAACe,YAAa;IACjCC,UAAU,EAAEhB,KAAK,CAACgB,UAAW;IAC7BC,iBAAiB,EAAEjB,KAAK,CAACiB,iBAAkB;IAC3CC,mBAAmB,EAAElB,KAAK,CAACkB;EAAoB,CAChD;AAEL,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,261 @@
1
+ "use strict";
2
+
3
+ // @ts-nocheck
4
+ import { View as RNView, Text as RNTextBase, Image as RNImage } from 'react-native';
5
+ import { cssInterop } from 'nativewind';
6
+ import { cva } from 'class-variance-authority';
7
+ import { cn } from "../../../lib/utils.js";
8
+ import { Button } from "../../Input/Button/Button.js";
9
+ import { Badge } from "../Badge/Badge.js";
10
+ import { Text } from "../../Input/Text/Text.js";
11
+ import { Avatar } from "../Avatar/Avatar.js";
12
+ import { AspectRatio } from "../../Layout/AspectRatio/Aspect-Ratio.js";
13
+
14
+ // Default placeholder image
15
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
16
+ const DEFAULT_MEDIA_IMAGE = 'https://images.unsplash.com/photo-1470071459604-3b5ec3a7fe3e?w=400&h=224&fit=crop';
17
+
18
+ // NativeWind interop (className -> style)
19
+ const View = cssInterop(RNView, {
20
+ className: 'style'
21
+ });
22
+ const RNText = cssInterop(RNTextBase, {
23
+ className: 'style'
24
+ });
25
+ const Image = cssInterop(RNImage, {
26
+ className: 'style'
27
+ });
28
+
29
+ /* ============================================================================
30
+ * VARIANTS
31
+ * ============================================================================ */
32
+
33
+ export const FeedCardVariants = {
34
+ type: ['post', 'announcement']
35
+ };
36
+ const rootVariants = cva('w-full overflow-hidden rounded-3xl', {
37
+ variants: {
38
+ type: {
39
+ post: 'bg-surface-default',
40
+ announcement: 'bg-surface-default border border-border-default'
41
+ }
42
+ },
43
+ defaultVariants: {
44
+ type: 'post'
45
+ }
46
+ });
47
+ const metaRowVariants = cva('w-full flex-row p-4', {
48
+ variants: {
49
+ type: {
50
+ post: 'items-center gap-2',
51
+ announcement: 'items-center justify-between'
52
+ }
53
+ },
54
+ defaultVariants: {
55
+ type: 'post'
56
+ }
57
+ });
58
+ const mediaWrapVariants = cva('w-full overflow-hidden px-4 pb-4');
59
+ const contentWrapVariants = cva('w-full px-4 pb-4 flex-col');
60
+ const headerVariants = cva('w-full gap-1 flex-col');
61
+ const titleVariants = cva('text-base font-semibold text-text-primary');
62
+ const subtitleVariants = cva('text-xs font-medium text-text-secondary');
63
+ const bodyVariants = cva('text-sm font-medium text-text-primary');
64
+ const badgesRowVariants = cva('w-full flex-row items-start gap-2 pb-4 px-4');
65
+ const footerRowVariants = cva('w-full flex-row items-center justify-between px-4 pb-4');
66
+ const leftButtonsVariants = cva('flex-row items-center gap-2');
67
+ const rightButtonsVariants = cva('flex-row items-center');
68
+
69
+ /* ============================================================================
70
+ * HELPERS
71
+ * ============================================================================ */
72
+
73
+ function normalizeType(v) {
74
+ const s = String(v ?? 'post').toLowerCase();
75
+ return s === 'announcement' ? 'announcement' : 'post';
76
+ }
77
+
78
+ /* ============================================================================
79
+ * PROPS
80
+ * ============================================================================ */
81
+
82
+ /* ============================================================================
83
+ * COMPONENT
84
+ * ============================================================================ */
85
+
86
+ export function FeedCard(props) {
87
+ const {
88
+ authorName = 'Author Name',
89
+ postTitle = 'Post Title',
90
+ subtitle = 'Subtitle of the card goes here',
91
+ postContent = 'The card may contain body content which can be truncated to 1-2 lines. Swap Content in Props.',
92
+ image,
93
+ type = 'post',
94
+ showHeader = true,
95
+ showLeading = true,
96
+ showMedia = true,
97
+ showPostContent = true,
98
+ showSubtitle = true,
99
+ showBadges = true,
100
+ showFooterActions = true,
101
+ showSecondaryButton = true,
102
+ badge1Text = 'Badge',
103
+ badge2Text = 'Badge',
104
+ primaryActionText = 'Button',
105
+ secondaryActionText = 'Button',
106
+ onPrimaryActionPress,
107
+ onSecondaryActionPress,
108
+ onTertiaryActionPress,
109
+ style,
110
+ testID
111
+ } = props;
112
+ const cardType = normalizeType(type);
113
+ const isAnnouncement = cardType === 'announcement';
114
+ return /*#__PURE__*/_jsxs(View, {
115
+ testID: testID ?? 'feed-card',
116
+ className: cn(rootVariants({
117
+ type: cardType
118
+ })),
119
+ style: style,
120
+ children: [/*#__PURE__*/_jsxs(View, {
121
+ testID: "feed-card-meta",
122
+ className: cn(metaRowVariants({
123
+ type: cardType
124
+ })),
125
+ children: [showLeading && /*#__PURE__*/_jsx(View, {
126
+ testID: "feed-card-leading",
127
+ className: "items-center justify-center",
128
+ children: /*#__PURE__*/_jsx(Avatar, {
129
+ initials: (authorName ?? 'AA').slice(0, 2).toUpperCase(),
130
+ size: "Default",
131
+ type: "Initials"
132
+ })
133
+ }), /*#__PURE__*/_jsxs(View, {
134
+ testID: "feed-card-author",
135
+ className: "flex-col flex-1 gap-0.5",
136
+ children: [/*#__PURE__*/_jsx(RNText, {
137
+ testID: "feed-card-author-name",
138
+ numberOfLines: 1,
139
+ className: "text-sm font-semibold text-text-primary",
140
+ children: authorName
141
+ }), /*#__PURE__*/_jsx(RNText, {
142
+ testID: "feed-card-timestamp",
143
+ numberOfLines: 1,
144
+ className: "text-xs font-normal text-text-secondary",
145
+ children: "Posted 1 day ago"
146
+ })]
147
+ }), isAnnouncement && /*#__PURE__*/_jsx(Badge, {
148
+ testID: "feed-card-type-badge",
149
+ variant: "default",
150
+ size: "sm",
151
+ showLeftIcon: false,
152
+ showRightIcon: false,
153
+ children: /*#__PURE__*/_jsx(Text, {
154
+ children: "Announcement"
155
+ })
156
+ })]
157
+ }), showMedia && /*#__PURE__*/_jsx(View, {
158
+ testID: "feed-card-media-wrap",
159
+ className: cn(mediaWrapVariants()),
160
+ children: /*#__PURE__*/_jsx(AspectRatio, {
161
+ variant: "16:9",
162
+ children: /*#__PURE__*/_jsx(View, {
163
+ className: "w-full h-full bg-surface-subtle rounded-3xl overflow-hidden",
164
+ children: /*#__PURE__*/_jsx(Image, {
165
+ testID: "feed-card-media",
166
+ source: image || {
167
+ uri: DEFAULT_MEDIA_IMAGE
168
+ },
169
+ resizeMode: "cover",
170
+ className: "w-full h-full"
171
+ })
172
+ })
173
+ })
174
+ }), showPostContent && /*#__PURE__*/_jsxs(View, {
175
+ testID: "feed-card-content",
176
+ className: cn(contentWrapVariants()),
177
+ children: [showHeader && /*#__PURE__*/_jsxs(View, {
178
+ testID: "feed-card-header",
179
+ className: cn(headerVariants()),
180
+ children: [/*#__PURE__*/_jsx(RNText, {
181
+ testID: "feed-card-title",
182
+ numberOfLines: 1,
183
+ className: cn(titleVariants()),
184
+ children: postTitle
185
+ }), showSubtitle && /*#__PURE__*/_jsx(RNText, {
186
+ testID: "feed-card-subtitle",
187
+ numberOfLines: 1,
188
+ className: cn(subtitleVariants()),
189
+ children: subtitle
190
+ })]
191
+ }), /*#__PURE__*/_jsx(RNText, {
192
+ testID: "feed-card-body",
193
+ numberOfLines: 2,
194
+ className: cn(bodyVariants()),
195
+ children: postContent
196
+ })]
197
+ }), showBadges && /*#__PURE__*/_jsxs(View, {
198
+ testID: "feed-card-badges",
199
+ className: cn(badgesRowVariants()),
200
+ children: [/*#__PURE__*/_jsx(Badge, {
201
+ testID: "feed-card-badge-1",
202
+ variant: "default",
203
+ size: "sm",
204
+ showLeftIcon: false,
205
+ showRightIcon: false,
206
+ children: /*#__PURE__*/_jsx(Text, {
207
+ children: badge1Text
208
+ })
209
+ }), /*#__PURE__*/_jsx(Badge, {
210
+ testID: "feed-card-badge-2",
211
+ variant: "default",
212
+ size: "sm",
213
+ showLeftIcon: false,
214
+ showRightIcon: false,
215
+ children: /*#__PURE__*/_jsx(Text, {
216
+ children: badge2Text
217
+ })
218
+ })]
219
+ }), showFooterActions && /*#__PURE__*/_jsxs(View, {
220
+ testID: "feed-card-footer",
221
+ className: cn(footerRowVariants()),
222
+ children: [/*#__PURE__*/_jsxs(View, {
223
+ testID: "feed-card-footer-left",
224
+ className: cn(leftButtonsVariants()),
225
+ children: [/*#__PURE__*/_jsx(Button, {
226
+ testID: "feed-card-primary-action",
227
+ disabled: false,
228
+ size: "default",
229
+ variant: "default",
230
+ showLeftIcon: false,
231
+ showRightIcon: false,
232
+ onPress: onPrimaryActionPress,
233
+ children: primaryActionText
234
+ }), showSecondaryButton && /*#__PURE__*/_jsx(Button, {
235
+ testID: "feed-card-secondary-action",
236
+ disabled: false,
237
+ size: "default",
238
+ variant: "secondary",
239
+ showLeftIcon: false,
240
+ showRightIcon: false,
241
+ onPress: onSecondaryActionPress,
242
+ children: secondaryActionText
243
+ })]
244
+ }), /*#__PURE__*/_jsx(View, {
245
+ testID: "feed-card-footer-right",
246
+ className: cn(rightButtonsVariants()),
247
+ children: /*#__PURE__*/_jsx(Button, {
248
+ testID: "feed-card-tertiary-action",
249
+ disabled: false,
250
+ size: "icon",
251
+ variant: "secondary",
252
+ showLeftIcon: false,
253
+ showRightIcon: false,
254
+ onPress: onTertiaryActionPress
255
+ })
256
+ })]
257
+ })]
258
+ });
259
+ }
260
+ FeedCard.displayName = 'FeedCard';
261
+ //# sourceMappingURL=FeedCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["View","RNView","Text","RNTextBase","Image","RNImage","cssInterop","cva","cn","Button","Badge","Avatar","AspectRatio","jsx","_jsx","jsxs","_jsxs","DEFAULT_MEDIA_IMAGE","className","RNText","FeedCardVariants","type","rootVariants","variants","post","announcement","defaultVariants","metaRowVariants","mediaWrapVariants","contentWrapVariants","headerVariants","titleVariants","subtitleVariants","bodyVariants","badgesRowVariants","footerRowVariants","leftButtonsVariants","rightButtonsVariants","normalizeType","v","s","String","toLowerCase","FeedCard","props","authorName","postTitle","subtitle","postContent","image","showHeader","showLeading","showMedia","showPostContent","showSubtitle","showBadges","showFooterActions","showSecondaryButton","badge1Text","badge2Text","primaryActionText","secondaryActionText","onPrimaryActionPress","onSecondaryActionPress","onTertiaryActionPress","style","testID","cardType","isAnnouncement","children","initials","slice","toUpperCase","size","numberOfLines","variant","showLeftIcon","showRightIcon","source","uri","resizeMode","disabled","onPress","displayName"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/FeedCard/FeedCard.tsx"],"mappings":";;AAAA;AACA,SACEA,IAAI,IAAIC,MAAM,EACdC,IAAI,IAAIC,UAAU,EAClBC,KAAK,IAAIC,OAAO,QAIX,cAAc;AACrB,SAASC,UAAU,QAAQ,YAAY;AACvC,SAASC,GAAG,QAAQ,0BAA0B;AAE9C,SAASC,EAAE,QAAQ,uBAAoB;AACvC,SAASC,MAAM,QAAQ,8BAA2B;AAClD,SAASC,KAAK,QAAQ,mBAAgB;AACtC,SAASR,IAAI,QAAQ,0BAAuB;AAC5C,SAASS,MAAM,QAAQ,qBAAkB;AACzC,SAASC,WAAW,QAAQ,0CAAuC;;AAEnE;AAAA,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AACA,MAAMC,mBAAmB,GACvB,mFAAmF;;AAErF;AACA,MAAMjB,IAAI,GAAGM,UAAU,CAACL,MAAM,EAAE;EAAEiB,SAAS,EAAE;AAAQ,CAAC,CAAC;AACvD,MAAMC,MAAM,GAAGb,UAAU,CAACH,UAAU,EAAE;EAAEe,SAAS,EAAE;AAAQ,CAAC,CAAC;AAC7D,MAAMd,KAAK,GAAGE,UAAU,CAACD,OAAO,EAAE;EAAEa,SAAS,EAAE;AAAQ,CAAC,CAAC;;AAEzD;AACA;AACA;;AAEA,OAAO,MAAME,gBAAgB,GAAG;EAC9BC,IAAI,EAAE,CAAC,MAAM,EAAE,cAAc;AAC/B,CAAU;AAIV,MAAMC,YAAY,GAAGf,GAAG,CAAC,oCAAoC,EAAE;EAC7DgB,QAAQ,EAAE;IACRF,IAAI,EAAE;MACJG,IAAI,EAAE,oBAAoB;MAC1BC,YAAY,EAAE;IAChB;EACF,CAAC;EACDC,eAAe,EAAE;IACfL,IAAI,EAAE;EACR;AACF,CAAC,CAAC;AAEF,MAAMM,eAAe,GAAGpB,GAAG,CAAC,qBAAqB,EAAE;EACjDgB,QAAQ,EAAE;IACRF,IAAI,EAAE;MACJG,IAAI,EAAE,oBAAoB;MAC1BC,YAAY,EAAE;IAChB;EACF,CAAC;EACDC,eAAe,EAAE;IACfL,IAAI,EAAE;EACR;AACF,CAAC,CAAC;AAEF,MAAMO,iBAAiB,GAAGrB,GAAG,CAAC,kCAAkC,CAAC;AAEjE,MAAMsB,mBAAmB,GAAGtB,GAAG,CAAC,2BAA2B,CAAC;AAE5D,MAAMuB,cAAc,GAAGvB,GAAG,CAAC,uBAAuB,CAAC;AAEnD,MAAMwB,aAAa,GAAGxB,GAAG,CAAC,2CAA2C,CAAC;AAEtE,MAAMyB,gBAAgB,GAAGzB,GAAG,CAAC,yCAAyC,CAAC;AAEvE,MAAM0B,YAAY,GAAG1B,GAAG,CAAC,uCAAuC,CAAC;AAEjE,MAAM2B,iBAAiB,GAAG3B,GAAG,CAAC,6CAA6C,CAAC;AAE5E,MAAM4B,iBAAiB,GAAG5B,GAAG,CAC3B,wDACF,CAAC;AAED,MAAM6B,mBAAmB,GAAG7B,GAAG,CAAC,6BAA6B,CAAC;AAE9D,MAAM8B,oBAAoB,GAAG9B,GAAG,CAAC,uBAAuB,CAAC;;AAEzD;AACA;AACA;;AAEA,SAAS+B,aAAaA,CAACC,CAAM,EAAgB;EAC3C,MAAMC,CAAC,GAAGC,MAAM,CAACF,CAAC,IAAI,MAAM,CAAC,CAACG,WAAW,CAAC,CAAC;EAC3C,OAAOF,CAAC,KAAK,cAAc,GAAG,cAAc,GAAG,MAAM;AACvD;;AAEA;AACA;AACA;;AAmDA;AACA;AACA;;AAEA,OAAO,SAASG,QAAQA,CAACC,KAAoB,EAAE;EAC7C,MAAM;IACJC,UAAU,GAAG,aAAa;IAC1BC,SAAS,GAAG,YAAY;IACxBC,QAAQ,GAAG,gCAAgC;IAC3CC,WAAW,GAAG,+FAA+F;IAC7GC,KAAK;IAEL5B,IAAI,GAAG,MAAM;IAEb6B,UAAU,GAAG,IAAI;IACjBC,WAAW,GAAG,IAAI;IAClBC,SAAS,GAAG,IAAI;IAChBC,eAAe,GAAG,IAAI;IACtBC,YAAY,GAAG,IAAI;IACnBC,UAAU,GAAG,IAAI;IACjBC,iBAAiB,GAAG,IAAI;IACxBC,mBAAmB,GAAG,IAAI;IAE1BC,UAAU,GAAG,OAAO;IACpBC,UAAU,GAAG,OAAO;IAEpBC,iBAAiB,GAAG,QAAQ;IAC5BC,mBAAmB,GAAG,QAAQ;IAE9BC,oBAAoB;IACpBC,sBAAsB;IACtBC,qBAAqB;IAErBC,KAAK;IACLC;EACF,CAAC,GAAGtB,KAAK;EAET,MAAMuB,QAAQ,GAAG7B,aAAa,CAACjB,IAAI,CAAC;EACpC,MAAM+C,cAAc,GAAGD,QAAQ,KAAK,cAAc;EAElD,oBACEnD,KAAA,CAAChB,IAAI;IACHkE,MAAM,EAAEA,MAAM,IAAI,WAAY;IAC9BhD,SAAS,EAAEV,EAAE,CAACc,YAAY,CAAC;MAAED,IAAI,EAAE8C;IAAS,CAAC,CAAC,CAAE;IAChDF,KAAK,EAAEA,KAAM;IAAAI,QAAA,gBAGbrD,KAAA,CAAChB,IAAI;MACHkE,MAAM,EAAC,gBAAgB;MACvBhD,SAAS,EAAEV,EAAE,CAACmB,eAAe,CAAC;QAAEN,IAAI,EAAE8C;MAAS,CAAC,CAAC,CAAE;MAAAE,QAAA,GAElDlB,WAAW,iBACVrC,IAAA,CAACd,IAAI;QACHkE,MAAM,EAAC,mBAAmB;QAC1BhD,SAAS,EAAC,6BAA6B;QAAAmD,QAAA,eAEvCvD,IAAA,CAACH,MAAM;UACL2D,QAAQ,EAAE,CAACzB,UAAU,IAAI,IAAI,EAAE0B,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAACC,WAAW,CAAC,CAAE;UACzDC,IAAI,EAAC,SAAS;UACdpD,IAAI,EAAC;QAAU,CAChB;MAAC,CACE,CACP,eAGDL,KAAA,CAAChB,IAAI;QAACkE,MAAM,EAAC,kBAAkB;QAAChD,SAAS,EAAC,yBAAyB;QAAAmD,QAAA,gBACjEvD,IAAA,CAACK,MAAM;UACL+C,MAAM,EAAC,uBAAuB;UAC9BQ,aAAa,EAAE,CAAE;UACjBxD,SAAS,EAAC,yCAAyC;UAAAmD,QAAA,EAElDxB;QAAU,CACL,CAAC,eACT/B,IAAA,CAACK,MAAM;UACL+C,MAAM,EAAC,qBAAqB;UAC5BQ,aAAa,EAAE,CAAE;UACjBxD,SAAS,EAAC,yCAAyC;UAAAmD,QAAA,EACpD;QAED,CAAQ,CAAC;MAAA,CACL,CAAC,EAGND,cAAc,iBACbtD,IAAA,CAACJ,KAAK;QACJwD,MAAM,EAAC,sBAAsB;QAC7BS,OAAO,EAAC,SAAS;QACjBF,IAAI,EAAC,IAAI;QACTG,YAAY,EAAE,KAAM;QACpBC,aAAa,EAAE,KAAM;QAAAR,QAAA,eAErBvD,IAAA,CAACZ,IAAI;UAAAmE,QAAA,EAAC;QAAY,CAAM;MAAC,CACpB,CACR;IAAA,CACG,CAAC,EAGNjB,SAAS,iBACRtC,IAAA,CAACd,IAAI;MAACkE,MAAM,EAAC,sBAAsB;MAAChD,SAAS,EAAEV,EAAE,CAACoB,iBAAiB,CAAC,CAAC,CAAE;MAAAyC,QAAA,eACrEvD,IAAA,CAACF,WAAW;QAAC+D,OAAO,EAAC,MAAM;QAAAN,QAAA,eACzBvD,IAAA,CAACd,IAAI;UAACkB,SAAS,EAAC,6DAA6D;UAAAmD,QAAA,eAC3EvD,IAAA,CAACV,KAAK;YACJ8D,MAAM,EAAC,iBAAiB;YACxBY,MAAM,EAAE7B,KAAK,IAAI;cAAE8B,GAAG,EAAE9D;YAAoB,CAAE;YAC9C+D,UAAU,EAAC,OAAO;YAClB9D,SAAS,EAAC;UAAe,CAC1B;QAAC,CACE;MAAC,CACI;IAAC,CACV,CACP,EAGAmC,eAAe,iBACdrC,KAAA,CAAChB,IAAI;MAACkE,MAAM,EAAC,mBAAmB;MAAChD,SAAS,EAAEV,EAAE,CAACqB,mBAAmB,CAAC,CAAC,CAAE;MAAAwC,QAAA,GAEnEnB,UAAU,iBACTlC,KAAA,CAAChB,IAAI;QAACkE,MAAM,EAAC,kBAAkB;QAAChD,SAAS,EAAEV,EAAE,CAACsB,cAAc,CAAC,CAAC,CAAE;QAAAuC,QAAA,gBAC9DvD,IAAA,CAACK,MAAM;UACL+C,MAAM,EAAC,iBAAiB;UACxBQ,aAAa,EAAE,CAAE;UACjBxD,SAAS,EAAEV,EAAE,CAACuB,aAAa,CAAC,CAAC,CAAE;UAAAsC,QAAA,EAE9BvB;QAAS,CACJ,CAAC,EAERQ,YAAY,iBACXxC,IAAA,CAACK,MAAM;UACL+C,MAAM,EAAC,oBAAoB;UAC3BQ,aAAa,EAAE,CAAE;UACjBxD,SAAS,EAAEV,EAAE,CAACwB,gBAAgB,CAAC,CAAC,CAAE;UAAAqC,QAAA,EAEjCtB;QAAQ,CACH,CACT;MAAA,CACG,CACP,eAGDjC,IAAA,CAACK,MAAM;QACL+C,MAAM,EAAC,gBAAgB;QACvBQ,aAAa,EAAE,CAAE;QACjBxD,SAAS,EAAEV,EAAE,CAACyB,YAAY,CAAC,CAAC,CAAE;QAAAoC,QAAA,EAE7BrB;MAAW,CACN,CAAC;IAAA,CACL,CACP,EAGAO,UAAU,iBACTvC,KAAA,CAAChB,IAAI;MAACkE,MAAM,EAAC,kBAAkB;MAAChD,SAAS,EAAEV,EAAE,CAAC0B,iBAAiB,CAAC,CAAC,CAAE;MAAAmC,QAAA,gBACjEvD,IAAA,CAACJ,KAAK;QACJwD,MAAM,EAAC,mBAAmB;QAC1BS,OAAO,EAAC,SAAS;QACjBF,IAAI,EAAC,IAAI;QACTG,YAAY,EAAE,KAAM;QACpBC,aAAa,EAAE,KAAM;QAAAR,QAAA,eAErBvD,IAAA,CAACZ,IAAI;UAAAmE,QAAA,EAAEX;QAAU,CAAO;MAAC,CACpB,CAAC,eACR5C,IAAA,CAACJ,KAAK;QACJwD,MAAM,EAAC,mBAAmB;QAC1BS,OAAO,EAAC,SAAS;QACjBF,IAAI,EAAC,IAAI;QACTG,YAAY,EAAE,KAAM;QACpBC,aAAa,EAAE,KAAM;QAAAR,QAAA,eAErBvD,IAAA,CAACZ,IAAI;UAAAmE,QAAA,EAAEV;QAAU,CAAO;MAAC,CACpB,CAAC;IAAA,CACJ,CACP,EAGAH,iBAAiB,iBAChBxC,KAAA,CAAChB,IAAI;MAACkE,MAAM,EAAC,kBAAkB;MAAChD,SAAS,EAAEV,EAAE,CAAC2B,iBAAiB,CAAC,CAAC,CAAE;MAAAkC,QAAA,gBACjErD,KAAA,CAAChB,IAAI;QACHkE,MAAM,EAAC,uBAAuB;QAC9BhD,SAAS,EAAEV,EAAE,CAAC4B,mBAAmB,CAAC,CAAC,CAAE;QAAAiC,QAAA,gBAErCvD,IAAA,CAACL,MAAM;UACLyD,MAAM,EAAC,0BAA0B;UACjCe,QAAQ,EAAE,KAAM;UAChBR,IAAI,EAAC,SAAS;UACdE,OAAO,EAAC,SAAS;UACjBC,YAAY,EAAE,KAAM;UACpBC,aAAa,EAAE,KAAM;UACrBK,OAAO,EAAEpB,oBAAqB;UAAAO,QAAA,EAE7BT;QAAiB,CACZ,CAAC,EAERH,mBAAmB,iBAClB3C,IAAA,CAACL,MAAM;UACLyD,MAAM,EAAC,4BAA4B;UACnCe,QAAQ,EAAE,KAAM;UAChBR,IAAI,EAAC,SAAS;UACdE,OAAO,EAAC,WAAW;UACnBC,YAAY,EAAE,KAAM;UACpBC,aAAa,EAAE,KAAM;UACrBK,OAAO,EAAEnB,sBAAuB;UAAAM,QAAA,EAE/BR;QAAmB,CACd,CACT;MAAA,CACG,CAAC,eAEP/C,IAAA,CAACd,IAAI;QACHkE,MAAM,EAAC,wBAAwB;QAC/BhD,SAAS,EAAEV,EAAE,CAAC6B,oBAAoB,CAAC,CAAC,CAAE;QAAAgC,QAAA,eAEtCvD,IAAA,CAACL,MAAM;UACLyD,MAAM,EAAC,2BAA2B;UAClCe,QAAQ,EAAE,KAAM;UAChBR,IAAI,EAAC,MAAM;UACXE,OAAO,EAAC,WAAW;UACnBC,YAAY,EAAE,KAAM;UACpBC,aAAa,EAAE,KAAM;UACrBK,OAAO,EAAElB;QAAsB,CAChC;MAAC,CACE,CAAC;IAAA,CACH,CACP;EAAA,CACG,CAAC;AAEX;AAEArB,QAAQ,CAACwC,WAAW,GAAG,UAAU","ignoreList":[]}
@@ -3,12 +3,19 @@
3
3
  import figma from '@figma/code-connect';
4
4
  import { Greeting } from "./Greeting.js";
5
5
  import { jsx as _jsx } from "react/jsx-runtime";
6
- const FIGMA_URL = 'https://www.figma.com/design/66WaqopqU3WXgwVtyQuTUf/React-Native-Blueprint-Library?node-id=448-8146';
6
+ const FIGMA_URL = 'https://www.figma.com/design/66WaqopqU3WXgwVtyQuTUf/React-Native-Blueprint-Library?node-id=495-8995';
7
7
  figma.connect(Greeting, FIGMA_URL, {
8
8
  props: {
9
+ ctaLayout: figma.enum('CTA Layout', {
10
+ 'icon': 'icon',
11
+ 'none': 'none',
12
+ 'floating': 'floating',
13
+ 'ai summary': 'ai summary'
14
+ }),
9
15
  showNextUp: figma.boolean('Show NextUp')
10
16
  },
11
17
  example: props => /*#__PURE__*/_jsx(Greeting, {
18
+ ctaLayout: props.ctaLayout,
12
19
  showNextUp: props.showNextUp
13
20
  })
14
21
  });
@@ -1 +1 @@
1
- {"version":3,"names":["figma","Greeting","jsx","_jsx","FIGMA_URL","connect","props","showNextUp","boolean","example"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/Greeting/Greeting.figma.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,qBAAqB;AACvC,SAASC,QAAQ,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEtC,MAAMC,SAAS,GACb,qGAAqG;AAEvGJ,KAAK,CAACK,OAAO,CAACJ,QAAQ,EAAEG,SAAS,EAAE;EACjCE,KAAK,EAAE;IACLC,UAAU,EAAEP,KAAK,CAACQ,OAAO,CAAC,aAAa;EACzC,CAAC;EACDC,OAAO,EAAGH,KAAK,iBAAKH,IAAA,CAACF,QAAQ;IAACM,UAAU,EAAED,KAAK,CAACC;EAAW,CAAE;AAC/D,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["figma","Greeting","jsx","_jsx","FIGMA_URL","connect","props","ctaLayout","enum","showNextUp","boolean","example"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/Greeting/Greeting.figma.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,qBAAqB;AACvC,SAASC,QAAQ,QAAQ,eAAY;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEtC,MAAMC,SAAS,GACb,qGAAqG;AAEvGJ,KAAK,CAACK,OAAO,CAACJ,QAAQ,EAAEG,SAAS,EAAE;EACjCE,KAAK,EAAE;IACLC,SAAS,EAAEP,KAAK,CAACQ,IAAI,CAAC,YAAY,EAAE;MAClC,MAAM,EAAE,MAAM;MACd,MAAM,EAAE,MAAM;MACd,UAAU,EAAE,UAAU;MACtB,YAAY,EAAE;IAChB,CAAC,CAAC;IACFC,UAAU,EAAET,KAAK,CAACU,OAAO,CAAC,aAAa;EACzC,CAAC;EACDC,OAAO,EAAGL,KAAK,iBACbH,IAAA,CAACF,QAAQ;IAACM,SAAS,EAAED,KAAK,CAACC,SAAU;IAACE,UAAU,EAAEH,KAAK,CAACG;EAAW,CAAE;AAEzE,CAAC,CAAC","ignoreList":[]}
@@ -2,12 +2,14 @@
2
2
 
3
3
  // @ts-nocheck
4
4
  import * as React from 'react';
5
- import { Pressable as RNPressable, StyleSheet, View as RNView } from 'react-native';
5
+ import { Pressable as RNPressable, View as RNView } from 'react-native';
6
+ import { LinearGradient } from 'expo-linear-gradient';
6
7
  import { cssInterop } from 'nativewind';
7
8
  import { Calendar } from 'lucide-react-native';
8
9
  import { cn } from "../../../lib/utils.js";
9
10
  import { Text } from "../../Input/Text/Text.js";
10
11
  import { Icon } from "../../ui/Icon.js";
12
+ import { Button } from "../../Input/Button/Button.js";
11
13
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
12
14
  cssInterop(RNView, {
13
15
  className: 'style'
@@ -15,6 +17,9 @@ cssInterop(RNView, {
15
17
  cssInterop(RNPressable, {
16
18
  className: 'style'
17
19
  });
20
+ cssInterop(LinearGradient, {
21
+ className: 'style'
22
+ });
18
23
  const View = RNView;
19
24
  const Pressable = RNPressable;
20
25
 
@@ -52,7 +57,8 @@ export function Greeting({
52
57
  userName = 'Marshall',
53
58
  greetingText = 'Good Morning',
54
59
  subtitle = 'You have 3 Classes today',
55
- showScheduleButton = true,
60
+ ctaLayout = 'icon',
61
+ showScheduleButton,
56
62
  onSchedulePress,
57
63
  showNextUp = true,
58
64
  nextUpTitle = 'Digital Logic Design',
@@ -60,11 +66,19 @@ export function Greeting({
60
66
  className,
61
67
  testID
62
68
  }) {
69
+ // Handle backwards compatibility: showScheduleButton prop takes precedence if explicitly set
70
+ const effectiveCtaLayout = showScheduleButton !== undefined ? showScheduleButton ? 'icon' : 'none' : ctaLayout;
71
+ const isAiSummary = effectiveCtaLayout === 'ai summary';
72
+ const isFloating = effectiveCtaLayout === 'floating';
73
+ const isIconOrFloatingOrNoneOrAiSummary = ['icon', 'floating', 'none', 'ai summary'].includes(effectiveCtaLayout);
74
+ const isNone = effectiveCtaLayout === 'none';
63
75
  return /*#__PURE__*/_jsxs(View, {
64
76
  testID: testID,
65
- className: cn('w-full max-w-[400px] flex-col gap-4 items-start justify-end rounded-lg border border-border-default bg-surface-default px-3 py-4', className),
77
+ className: cn('w-full max-w-[400px] flex-col items-start justify-end bg-surface-default',
78
+ // Base styling based on ctaLayout
79
+ isAiSummary ? 'gap-4 rounded-3xl border border-border-default px-0 pt-4 pb-0 overflow-hidden' : isFloating ? 'gap-4 rounded-3xl border border-border-default px-0 pt-4 pb-0 overflow-hidden' : isNone ? 'gap-4 rounded-3xl border border-border-default px-0 py-4' : 'gap-4 rounded-3xl border border-border-default px-0 py-4', className),
66
80
  children: [/*#__PURE__*/_jsxs(View, {
67
- className: "w-full flex-row items-center justify-between",
81
+ className: cn('w-full flex-row items-center', isFloating || isAiSummary ? 'justify-between px-3' : isNone ? 'px-3' : 'px-3'),
68
82
  children: [/*#__PURE__*/_jsxs(View, {
69
83
  className: "flex-1 flex-col gap-1",
70
84
  children: [/*#__PURE__*/_jsx(Text, {
@@ -74,19 +88,27 @@ export function Greeting({
74
88
  className: "font-medium text-xs text-text-secondary",
75
89
  children: subtitle
76
90
  })]
77
- }), showScheduleButton && /*#__PURE__*/_jsx(Pressable, {
91
+ }), effectiveCtaLayout === 'icon' && /*#__PURE__*/_jsx(Pressable, {
78
92
  onPress: onSchedulePress,
79
93
  hitSlop: 12,
80
- className: "ml-3 flex-row items-center justify-center rounded-lg bg-highlight-purple p-3",
81
- style: styles.scheduleButton,
94
+ className: "ml-3 flex-row items-center justify-center rounded-lg p-3 bg-highlight-purple",
95
+ children: /*#__PURE__*/_jsx(Icon, {
96
+ as: Calendar,
97
+ size: 16,
98
+ color: "white"
99
+ })
100
+ }), isAiSummary && /*#__PURE__*/_jsx(Pressable, {
101
+ onPress: onSchedulePress,
102
+ hitSlop: 12,
103
+ className: "ml-3 flex-row items-center justify-center rounded-lg p-3 bg-highlight-purple",
82
104
  children: /*#__PURE__*/_jsx(Icon, {
83
105
  as: Calendar,
84
106
  size: 16,
85
107
  color: "white"
86
108
  })
87
109
  })]
88
- }), showNextUp && /*#__PURE__*/_jsxs(View, {
89
- className: "w-full flex-col gap-1",
110
+ }), isIconOrFloatingOrNoneOrAiSummary && showNextUp && /*#__PURE__*/_jsxs(View, {
111
+ className: "w-full flex-col gap-1 px-3",
90
112
  children: [/*#__PURE__*/_jsx(Text, {
91
113
  className: "font-medium text-xs text-text-secondary",
92
114
  children: "Next up"
@@ -102,20 +124,52 @@ export function Greeting({
102
124
  children: nextUpTime
103
125
  })]
104
126
  })]
127
+ }), isAiSummary && /*#__PURE__*/_jsx(LinearGradient, {
128
+ colors: ['#573dab', '#f2353c'],
129
+ start: {
130
+ x: 0,
131
+ y: 0
132
+ },
133
+ end: {
134
+ x: 1,
135
+ y: 0
136
+ },
137
+ className: "w-full items-center justify-center",
138
+ style: {
139
+ paddingVertical: 8,
140
+ borderBottomLeftRadius: 20,
141
+ borderBottomRightRadius: 20
142
+ },
143
+ children: /*#__PURE__*/_jsx(Pressable, {
144
+ onPress: onSchedulePress,
145
+ className: "w-full items-center justify-center",
146
+ style: {
147
+ paddingVertical: 0
148
+ },
149
+ children: /*#__PURE__*/_jsx(Text, {
150
+ className: "font-semibold text-sm text-white",
151
+ children: "AI Summary for Today"
152
+ })
153
+ })
154
+ }), isFloating && /*#__PURE__*/_jsx(View, {
155
+ className: "w-full bg-surface-default",
156
+ style: {
157
+ borderBottomLeftRadius: 20,
158
+ borderBottomRightRadius: 20
159
+ },
160
+ children: /*#__PURE__*/_jsx(Button, {
161
+ variant: "outline",
162
+ size: "default",
163
+ showRightIcon: true,
164
+ rightIcon: Calendar,
165
+ onPress: onSchedulePress,
166
+ style: {
167
+ width: '100%'
168
+ },
169
+ children: "View Schedule"
170
+ })
105
171
  })]
106
172
  });
107
173
  }
108
174
  Greeting.displayName = 'Greeting';
109
- const styles = StyleSheet.create({
110
- scheduleButton: {
111
- shadowColor: '#573dab',
112
- shadowOffset: {
113
- width: 0,
114
- height: 0
115
- },
116
- shadowOpacity: 0.5,
117
- shadowRadius: 12,
118
- elevation: 8
119
- }
120
- });
121
175
  //# sourceMappingURL=Greeting.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["React","Pressable","RNPressable","StyleSheet","View","RNView","cssInterop","Calendar","cn","Text","Icon","jsx","_jsx","jsxs","_jsxs","className","Greeting","userName","greetingText","subtitle","showScheduleButton","onSchedulePress","showNextUp","nextUpTitle","nextUpTime","testID","children","onPress","hitSlop","style","styles","scheduleButton","as","size","color","displayName","create","shadowColor","shadowOffset","width","height","shadowOpacity","shadowRadius","elevation"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/Greeting/Greeting.tsx"],"mappings":";;AAAA;AACA,OAAO,KAAKA,KAAK,MAAM,OAAO;AAC9B,SACEC,SAAS,IAAIC,WAAW,EACxBC,UAAU,EACVC,IAAI,IAAIC,MAAM,QACT,cAAc;AACrB,SAASC,UAAU,QAAQ,YAAY;AACvC,SAASC,QAAQ,QAAQ,qBAAqB;AAC9C,SAASC,EAAE,QAAQ,uBAAoB;AACvC,SAASC,IAAI,QAAQ,0BAAuB;AAC5C,SAASC,IAAI,QAAQ,kBAAe;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAErCR,UAAU,CAACD,MAAM,EAAE;EAAEU,SAAS,EAAE;AAAQ,CAAC,CAAC;AAC1CT,UAAU,CAACJ,WAAW,EAAE;EAAEa,SAAS,EAAE;AAAQ,CAAC,CAAC;AAE/C,MAAMX,IAAI,GAAGC,MAEZ;AACD,MAAMJ,SAAS,GAAGC,WAEjB;;AAED;AACA;AACA;;AAwBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASc,QAAQA,CAAC;EACvBC,QAAQ,GAAG,UAAU;EACrBC,YAAY,GAAG,cAAc;EAC7BC,QAAQ,GAAG,0BAA0B;EACrCC,kBAAkB,GAAG,IAAI;EACzBC,eAAe;EACfC,UAAU,GAAG,IAAI;EACjBC,WAAW,GAAG,sBAAsB;EACpCC,UAAU,GAAG,UAAU;EACvBT,SAAS;EACTU;AACa,CAAC,EAAE;EAChB,oBACEX,KAAA,CAACV,IAAI;IACHqB,MAAM,EAAEA,MAAO;IACfV,SAAS,EAAEP,EAAE,CACX,kIAAkI,EAClIO,SACF,CAAE;IAAAW,QAAA,gBAGFZ,KAAA,CAACV,IAAI;MAACW,SAAS,EAAC,8CAA8C;MAAAW,QAAA,gBAE5DZ,KAAA,CAACV,IAAI;QAACW,SAAS,EAAC,uBAAuB;QAAAW,QAAA,gBACrCd,IAAA,CAACH,IAAI;UAACM,SAAS,EAAC,2CAA2C;UAAAW,QAAA,EACxD,OAAOT,QAAQ,KAAKC,YAAY;QAAE,CAC/B,CAAC,eACPN,IAAA,CAACH,IAAI;UAACM,SAAS,EAAC,yCAAyC;UAAAW,QAAA,EACtDP;QAAQ,CACL,CAAC;MAAA,CACH,CAAC,EAGNC,kBAAkB,iBACjBR,IAAA,CAACX,SAAS;QACR0B,OAAO,EAAEN,eAAgB;QACzBO,OAAO,EAAE,EAAG;QACZb,SAAS,EAAC,8EAA8E;QACxFc,KAAK,EAAEC,MAAM,CAACC,cAAe;QAAAL,QAAA,eAE7Bd,IAAA,CAACF,IAAI;UAACsB,EAAE,EAAEzB,QAAS;UAAC0B,IAAI,EAAE,EAAG;UAACC,KAAK,EAAC;QAAO,CAAE;MAAC,CACrC,CACZ;IAAA,CACG,CAAC,EAGNZ,UAAU,iBACTR,KAAA,CAACV,IAAI;MAACW,SAAS,EAAC,uBAAuB;MAAAW,QAAA,gBACrCd,IAAA,CAACH,IAAI;QAACM,SAAS,EAAC,yCAAyC;QAAAW,QAAA,EAAC;MAE1D,CAAM,CAAC,eAEPZ,KAAA,CAACV,IAAI;QAACW,SAAS,EAAC,oCAAoC;QAAAW,QAAA,gBAClDd,IAAA,CAACH,IAAI;UAACM,SAAS,EAAC,2CAA2C;UAAAW,QAAA,EACxDH;QAAW,CACR,CAAC,eAEPX,IAAA,CAACR,IAAI;UAACW,SAAS,EAAC;QAA4C,CAAE,CAAC,eAC/DH,IAAA,CAACH,IAAI;UAACM,SAAS,EAAC,2CAA2C;UAAAW,QAAA,EACxDF;QAAU,CACP,CAAC;MAAA,CACH,CAAC;IAAA,CACH,CACP;EAAA,CACG,CAAC;AAEX;AAEAR,QAAQ,CAACmB,WAAW,GAAG,UAAU;AAEjC,MAAML,MAAM,GAAG3B,UAAU,CAACiC,MAAM,CAAC;EAC/BL,cAAc,EAAE;IACdM,WAAW,EAAE,SAAS;IACtBC,YAAY,EAAE;MAAEC,KAAK,EAAE,CAAC;MAAEC,MAAM,EAAE;IAAE,CAAC;IACrCC,aAAa,EAAE,GAAG;IAClBC,YAAY,EAAE,EAAE;IAChBC,SAAS,EAAE;EACb;AACF,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["React","Pressable","RNPressable","View","RNView","LinearGradient","cssInterop","Calendar","cn","Text","Icon","Button","jsx","_jsx","jsxs","_jsxs","className","Greeting","userName","greetingText","subtitle","ctaLayout","showScheduleButton","onSchedulePress","showNextUp","nextUpTitle","nextUpTime","testID","effectiveCtaLayout","undefined","isAiSummary","isFloating","isIconOrFloatingOrNoneOrAiSummary","includes","isNone","children","onPress","hitSlop","as","size","color","colors","start","x","y","end","style","paddingVertical","borderBottomLeftRadius","borderBottomRightRadius","variant","showRightIcon","rightIcon","width","displayName"],"sourceRoot":"../../../../../src","sources":["components/DataDisplay/Greeting/Greeting.tsx"],"mappings":"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","ignoreList":[]}
@@ -21,6 +21,7 @@ export * from "../Layout/Bottomsheet/Bottom-Sheet.js";
21
21
  export * from "../Input/Button/Button.js";
22
22
  export * from "../DataDisplay/Card/Card.js";
23
23
  export * from "../DataDisplay/CalendarItem/CalendarItem.js";
24
+ export * from "../DataDisplay/FeedCard/FeedCard.js";
24
25
  export * from "../DataDisplay/Greeting/Greeting.js";
25
26
  export * from "../DataDisplay/MonthCalendar/MonthCalendar.js";
26
27
  export * from "../DataDisplay/DataCard/DataCard.js";
@@ -1 +1 @@
1
- {"version":3,"names":[],"sourceRoot":"../../../../src","sources":["components/ui/index.ts"],"mappings":";;AAAA;AACA,cAAc,uCAAoC;AAClD,cAAc,+CAA4C;AAC1D,cAAc,4BAAyB;AACvC,cAAc,yCAAsC;AACpD,cAAc,gCAA6B;AAC3C,cAAc,gCAA6B;AAC3C,cAAc,uCAAoC;AAClD,cAAc,iCAA8B;AAC5C,cAAc,+BAA4B;AAC1C,cAAc,iCAA8B;AAC5C,cAAc,+BAA4B;AAC1C,cAAc,qCAAkC;AAChD,cAAc,uCAAoC;AAClD,cAAc,8CAA2C;AACzD,cAAc,kDAA+C;AAC7D,cAAc,sCAAmC;AACjD,cAAc,uCAAoC;AAClD,cAAc,2BAAwB;AACtC,cAAc,6BAA0B;AACxC,cAAc,6CAA0C;AACxD,cAAc,qCAAkC;AAChD,cAAc,+CAA4C;AAC1D,cAAc,qCAAkC;AAChD,cAAc,+BAA4B;AAC1C,cAAc,kBAAe;AAC7B,cAAc,2CAAwC;AACtD,cAAc,kBAAe;AAC7B,cAAc,gCAA6B;AAC3C,cAAc,oBAAiB;AAC/B,cAAc,iDAA8C;AAE5D,cAAc,iBAAc;AAC5B,cAAc,WAAQ;AACtB,cAAc,YAAS;AACvB,cAAc,YAAS;AACvB,cAAc,cAAW;AACzB,cAAc,gCAA6B;AAC3C,cAAc,kCAA+B;AAC7C,cAAc,iDAA8C;AAC5D,cAAc,+CAA4C;AAC1D,cAAc,mDAAgD;AAC9D,cAAc,gCAA6B;AAC3C,cAAc,oCAAiC;AAC/C,cAAc,2BAAwB;AACtC,cAAc,uCAAoC;AAClD,cAAc,eAAY;AAC1B,cAAc,qCAAkC;AAChD,cAAc,aAAU;AACxB,cAAc,2BAAwB;AACtC,cAAc,YAAS;AACvB,cAAc,wBAAqB;AACnC,cAAc,uBAAoB;AAClC,cAAc,iCAA8B;AAC5C,cAAc,2CAAwC;AACtD,cAAc,YAAS;AACvB,cAAc,2BAAwB;AACtC,cAAc,sCAAmC;AACjD,cAAc,mCAAgC;AAC9C,cAAc,6CAA0C;AACxD,cAAc,qCAAkC","ignoreList":[]}
1
+ {"version":3,"names":[],"sourceRoot":"../../../../src","sources":["components/ui/index.ts"],"mappings":";;AAAA;AACA,cAAc,uCAAoC;AAClD,cAAc,+CAA4C;AAC1D,cAAc,4BAAyB;AACvC,cAAc,yCAAsC;AACpD,cAAc,gCAA6B;AAC3C,cAAc,gCAA6B;AAC3C,cAAc,uCAAoC;AAClD,cAAc,iCAA8B;AAC5C,cAAc,+BAA4B;AAC1C,cAAc,iCAA8B;AAC5C,cAAc,+BAA4B;AAC1C,cAAc,qCAAkC;AAChD,cAAc,uCAAoC;AAClD,cAAc,8CAA2C;AACzD,cAAc,kDAA+C;AAC7D,cAAc,sCAAmC;AACjD,cAAc,uCAAoC;AAClD,cAAc,2BAAwB;AACtC,cAAc,6BAA0B;AACxC,cAAc,6CAA0C;AACxD,cAAc,qCAAkC;AAChD,cAAc,qCAAkC;AAChD,cAAc,+CAA4C;AAC1D,cAAc,qCAAkC;AAChD,cAAc,+BAA4B;AAC1C,cAAc,kBAAe;AAC7B,cAAc,2CAAwC;AACtD,cAAc,kBAAe;AAC7B,cAAc,gCAA6B;AAC3C,cAAc,oBAAiB;AAC/B,cAAc,iDAA8C;AAE5D,cAAc,iBAAc;AAC5B,cAAc,WAAQ;AACtB,cAAc,YAAS;AACvB,cAAc,YAAS;AACvB,cAAc,cAAW;AACzB,cAAc,gCAA6B;AAC3C,cAAc,kCAA+B;AAC7C,cAAc,iDAA8C;AAC5D,cAAc,+CAA4C;AAC1D,cAAc,mDAAgD;AAC9D,cAAc,gCAA6B;AAC3C,cAAc,oCAAiC;AAC/C,cAAc,2BAAwB;AACtC,cAAc,uCAAoC;AAClD,cAAc,eAAY;AAC1B,cAAc,qCAAkC;AAChD,cAAc,aAAU;AACxB,cAAc,2BAAwB;AACtC,cAAc,YAAS;AACvB,cAAc,wBAAqB;AACnC,cAAc,uBAAoB;AAClC,cAAc,iCAA8B;AAC5C,cAAc,2CAAwC;AACtD,cAAc,YAAS;AACvB,cAAc,2BAAwB;AACtC,cAAc,sCAAmC;AACjD,cAAc,mCAAgC;AAC9C,cAAc,6CAA0C;AACxD,cAAc,qCAAkC","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@campxdev/react-native-blueprint",
3
- "version": "0.1.17",
3
+ "version": "0.1.18",
4
4
  "description": "This is a react-native package for mobile apps",
5
5
  "main": "./lib/module/index.js",
6
6
  "types": "./lib/typescript/src/index.d.ts",
@@ -43,7 +43,7 @@
43
43
  "typecheck": "tsc --project tsconfig.build.json",
44
44
  "lint": "eslint \"**/*.{js,ts,tsx}\"",
45
45
  "clean": "del-cli lib",
46
- "prepare": "bob build --target module",
46
+ "prepare": "bob build --target module && cp global.css lib/global.css",
47
47
  "build:full": "bob build && cp global.css lib/",
48
48
  "release": "release-it --only-version"
49
49
  },
@@ -0,0 +1,43 @@
1
+ import figma from '@figma/code-connect';
2
+ import { FeedCard } from './FeedCard';
3
+
4
+ const FIGMA_URL =
5
+ 'https://www.figma.com/design/66WaqopqU3WXgwVtyQuTUf/React-Native-Blueprint-Library?node-id=511-10139';
6
+
7
+ figma.connect(FeedCard, FIGMA_URL, {
8
+ props: {
9
+ type: figma.enum('type', {
10
+ post: 'post',
11
+ announcement: 'announcement',
12
+ }),
13
+ authorName: figma.string('authorName'),
14
+ postTitle: figma.string('postTitle'),
15
+ subtitle: figma.string('subtitle'),
16
+ postContent: figma.string('postContent'),
17
+ showHeader: figma.boolean('Show Header'),
18
+ showLeading: figma.boolean('Show Leading'),
19
+ showMedia: figma.boolean('Show Media'),
20
+ showPostContent: figma.boolean('Show PostContent'),
21
+ showSubtitle: figma.boolean('Show Subtitle'),
22
+ showBadges: figma.boolean('Show Badges'),
23
+ showFooterActions: figma.boolean('Show FooterActions'),
24
+ showSecondaryButton: figma.boolean('Show SecondaryButton'),
25
+ },
26
+ example: (props) => (
27
+ <FeedCard
28
+ type={props.type}
29
+ authorName={props.authorName}
30
+ postTitle={props.postTitle}
31
+ subtitle={props.subtitle}
32
+ postContent={props.postContent}
33
+ showHeader={props.showHeader}
34
+ showLeading={props.showLeading}
35
+ showMedia={props.showMedia}
36
+ showPostContent={props.showPostContent}
37
+ showSubtitle={props.showSubtitle}
38
+ showBadges={props.showBadges}
39
+ showFooterActions={props.showFooterActions}
40
+ showSecondaryButton={props.showSecondaryButton}
41
+ />
42
+ ),
43
+ });