@campxdev/react-native-blueprint 0.1.16 → 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.
- package/lib/global.css +672 -0
- package/lib/module/components/DataDisplay/FeedCard/FeedCard.figma.js +42 -0
- package/lib/module/components/DataDisplay/FeedCard/FeedCard.figma.js.map +1 -0
- package/lib/module/components/DataDisplay/FeedCard/FeedCard.js +261 -0
- package/lib/module/components/DataDisplay/FeedCard/FeedCard.js.map +1 -0
- package/lib/module/components/DataDisplay/Greeting/Greeting.figma.js +8 -1
- package/lib/module/components/DataDisplay/Greeting/Greeting.figma.js.map +1 -1
- package/lib/module/components/DataDisplay/Greeting/Greeting.js +75 -21
- package/lib/module/components/DataDisplay/Greeting/Greeting.js.map +1 -1
- package/lib/module/components/ui/index.js +1 -0
- package/lib/module/components/ui/index.js.map +1 -1
- package/package.json +4 -3
- package/src/components/DataDisplay/FeedCard/FeedCard.figma.tsx +43 -0
- package/src/components/DataDisplay/FeedCard/FeedCard.tsx +376 -0
- package/src/components/DataDisplay/Greeting/Greeting.figma.tsx +10 -2
- package/src/components/DataDisplay/Greeting/Greeting.tsx +107 -26
- package/src/components/ui/index.ts +1 -0
|
@@ -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":"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","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=
|
|
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,
|
|
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,
|
|
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
|
-
|
|
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
|
|
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:
|
|
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
|
-
}),
|
|
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
|
|
81
|
-
|
|
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","
|
|
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.
|
|
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",
|
|
@@ -30,7 +30,8 @@
|
|
|
30
30
|
"!**/__tests__",
|
|
31
31
|
"!**/__fixtures__",
|
|
32
32
|
"!**/__mocks__",
|
|
33
|
-
"
|
|
33
|
+
"!lib/**/.map",
|
|
34
|
+
"!src/**/__*"
|
|
34
35
|
],
|
|
35
36
|
"scripts": {
|
|
36
37
|
"example": "yarn workspace react-native-blueprint-example",
|
|
@@ -42,7 +43,7 @@
|
|
|
42
43
|
"typecheck": "tsc --project tsconfig.build.json",
|
|
43
44
|
"lint": "eslint \"**/*.{js,ts,tsx}\"",
|
|
44
45
|
"clean": "del-cli lib",
|
|
45
|
-
"prepare": "bob build --target module",
|
|
46
|
+
"prepare": "bob build --target module && cp global.css lib/global.css",
|
|
46
47
|
"build:full": "bob build && cp global.css lib/",
|
|
47
48
|
"release": "release-it --only-version"
|
|
48
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
|
+
});
|