@fanvue/ui 2.14.2 → 2.14.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,6 +4,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("react/jsx-runtime");
5
5
  const React = require("react");
6
6
  const cn = require("../../utils/cn.cjs");
7
+ const Avatar = require("../Avatar/Avatar.cjs");
7
8
  function _interopNamespaceDefault(e) {
8
9
  const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
9
10
  if (e) {
@@ -22,12 +23,12 @@ function _interopNamespaceDefault(e) {
22
23
  }
23
24
  const React__namespace = /* @__PURE__ */ _interopNamespaceDefault(React);
24
25
  const ASPECT_RATIO_CLASSES = {
25
- tall: "aspect-1/2",
26
- medium: "aspect-2/3",
27
- short: "aspect-4/5"
26
+ tall: "aspect-5/4",
27
+ medium: "aspect-3/2",
28
+ short: "aspect-9/5"
28
29
  };
29
30
  const CreatorTile = React__namespace.forwardRef(
30
- ({ className, imageSrc, imageAlt = "", name, tagline, aspectRatio = "medium", ...props }, ref) => {
31
+ ({ className, background, name, tagline, avatar, action, aspectRatio = "medium", ...props }, ref) => {
31
32
  const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];
32
33
  return /* @__PURE__ */ jsxRuntime.jsxs(
33
34
  "div",
@@ -40,19 +41,27 @@ const CreatorTile = React__namespace.forwardRef(
40
41
  ),
41
42
  ...props,
42
43
  children: [
43
- /* @__PURE__ */ jsxRuntime.jsx(
44
- "img",
45
- {
46
- src: imageSrc,
47
- alt: imageAlt,
48
- loading: "lazy",
49
- className: "absolute inset-0 -z-10 h-full w-full object-cover"
50
- }
51
- ),
52
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "pointer-events-none absolute inset-0 -z-10 bg-linear-to-b from-64% from-transparent to-black/40" }),
53
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-col gap-1 px-6 pb-6", children: [
54
- /* @__PURE__ */ jsxRuntime.jsx("p", { className: "m-0 font-black text-4xl text-white leading-none tracking-tight", children: name }),
55
- tagline ? /* @__PURE__ */ jsxRuntime.jsx("p", { className: "m-0 font-bold text-[9px] text-brand-primary-default uppercase leading-none", children: tagline }) : null
44
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "pointer-events-none absolute inset-0 select-none *:h-full *:w-full [&>img]:object-cover [&>video]:object-cover", children: background }),
45
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "pointer-events-none absolute inset-x-0 bottom-0 h-1/2 rounded-b-[inherit] bg-linear-to-t from-black/60 to-transparent" }),
46
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "pointer-events-none absolute inset-x-0 bottom-0 h-1/2 overflow-hidden rounded-b-[inherit] backdrop-blur-md [-webkit-mask-image:linear-gradient(to_top,black,transparent)] [mask-image:linear-gradient(to_top,black,transparent)]" }),
47
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "relative flex items-center justify-between gap-4 p-4", children: [
48
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex min-w-0 items-center gap-2", children: [
49
+ /* @__PURE__ */ jsxRuntime.jsx(
50
+ Avatar.Avatar,
51
+ {
52
+ size: 40,
53
+ src: avatar?.src,
54
+ alt: avatar?.alt ?? (typeof name === "string" ? name : void 0),
55
+ fallback: avatar?.fallback,
56
+ ...avatar
57
+ }
58
+ ),
59
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex min-w-0 flex-col", children: [
60
+ /* @__PURE__ */ jsxRuntime.jsx("p", { className: "typography-semibold-body-lg m-0 truncate text-white", children: name }),
61
+ tagline ? /* @__PURE__ */ jsxRuntime.jsx("p", { className: "typography-semibold-body-md m-0 truncate text-white/50", children: tagline }) : null
62
+ ] })
63
+ ] }),
64
+ action ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: "shrink-0", children: action }) : null
56
65
  ] })
57
66
  ]
58
67
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CreatorTile.cjs","sources":["../../../../src/components/CreatorTile/CreatorTile.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { cn } from \"../../utils/cn\";\n\n/** Width-to-height ratio preset for the tile. */\nexport type CreatorTileAspectRatio = \"tall\" | \"medium\" | \"short\";\n\nconst ASPECT_RATIO_CLASSES: Record<CreatorTileAspectRatio, string> = {\n tall: \"aspect-1/2\",\n medium: \"aspect-2/3\",\n short: \"aspect-4/5\",\n};\n\nexport interface CreatorTileProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Source URL of the creator's image. Rendered as the tile background. */\n imageSrc: string;\n /** Alt text for the creator image. Use an empty string for purely decorative imagery. */\n imageAlt?: string;\n /** Creator name shown as the prominent overlay heading. */\n name: React.ReactNode;\n /** Short tagline shown under the name in the brand accent color. */\n tagline?: React.ReactNode;\n /**\n * Width-to-height ratio preset.\n *\n * - `tall` – 1:2 narrow portrait\n * - `medium` – 2:3 classic poster (default)\n * - `short` – 4:5 closer to square\n *\n * @default \"medium\"\n */\n aspectRatio?: CreatorTileAspectRatio;\n}\n\n/**\n * A visual highlight tile showcasing a creator with an overlaid name and tagline.\n *\n * The tile renders a full-bleed image with a bottom gradient that ensures the\n * overlaid text remains legible regardless of the underlying photography.\n *\n * @example\n * ```tsx\n * <CreatorTile\n * imageSrc=\"https://example.com/creator.jpg\"\n * imageAlt=\"Portrait of Jane Doe\"\n * name=\"JANE DOE\"\n * tagline=\"GLOBAL MUSIC ICON\"\n * />\n * ```\n */\nexport const CreatorTile = React.forwardRef<HTMLDivElement, CreatorTileProps>(\n (\n { className, imageSrc, imageAlt = \"\", name, tagline, aspectRatio = \"medium\", ...props },\n ref,\n ) => {\n const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative isolate flex w-full flex-col justify-end overflow-hidden\",\n aspectClass,\n className,\n )}\n {...props}\n >\n <img\n src={imageSrc}\n alt={imageAlt}\n loading=\"lazy\"\n className=\"absolute inset-0 -z-10 h-full w-full object-cover\"\n />\n <div className=\"pointer-events-none absolute inset-0 -z-10 bg-linear-to-b from-64% from-transparent to-black/40\" />\n <div className=\"flex flex-col gap-1 px-6 pb-6\">\n <p className=\"m-0 font-black text-4xl text-white leading-none tracking-tight\">{name}</p>\n {tagline ? (\n <p className=\"m-0 font-bold text-[9px] text-brand-primary-default uppercase leading-none\">\n {tagline}\n </p>\n ) : null}\n </div>\n </div>\n );\n },\n);\n\nCreatorTile.displayName = \"CreatorTile\";\n"],"names":["React","jsxs","cn","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAMA,MAAM,uBAA+D;AAAA,EACnE,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,OAAO;AACT;AAuCO,MAAM,cAAcA,iBAAM;AAAA,EAC/B,CACE,EAAE,WAAW,UAAU,WAAW,IAAI,MAAM,SAAS,cAAc,UAAU,GAAG,MAAA,GAChF,QACG;AACH,UAAM,cAAc,qBAAqB,WAAW;AAEpD,WACEC,2BAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAWC,GAAAA;AAAAA,UACT;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,QAED,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAAC,2BAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,KAAK;AAAA,cACL,KAAK;AAAA,cACL,SAAQ;AAAA,cACR,WAAU;AAAA,YAAA;AAAA,UAAA;AAAA,UAEZA,2BAAAA,IAAC,OAAA,EAAI,WAAU,kGAAA,CAAkG;AAAA,UACjHF,2BAAAA,KAAC,OAAA,EAAI,WAAU,iCACb,UAAA;AAAA,YAAAE,2BAAAA,IAAC,KAAA,EAAE,WAAU,kEAAkE,UAAA,MAAK;AAAA,YACnF,UACCA,2BAAAA,IAAC,KAAA,EAAE,WAAU,8EACV,mBACH,IACE;AAAA,UAAA,EAAA,CACN;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;AAEA,YAAY,cAAc;;"}
1
+ {"version":3,"file":"CreatorTile.cjs","sources":["../../../../src/components/CreatorTile/CreatorTile.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { cn } from \"../../utils/cn\";\nimport { Avatar } from \"../Avatar/Avatar\";\n\n/** Width-to-height ratio preset for the tile. */\nexport type CreatorTileAspectRatio = \"tall\" | \"medium\" | \"short\";\n\nconst ASPECT_RATIO_CLASSES: Record<CreatorTileAspectRatio, string> = {\n tall: \"aspect-5/4\",\n medium: \"aspect-3/2\",\n short: \"aspect-9/5\",\n};\n\nexport interface CreatorTileProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Decorative background media rendered behind the creator content. */\n background: React.ReactNode;\n /** Creator display name shown as the prominent heading. */\n name: React.ReactNode;\n /** Optional secondary line shown under the name (e.g. handle or tagline). */\n tagline?: React.ReactNode;\n /** Avatar props forwarded to the inner {@link Avatar}. */\n avatar?: React.ComponentPropsWithoutRef<typeof Avatar>;\n /**\n * Action element rendered on the right of the profile row (e.g. a `Button`\n * for following the creator).\n */\n action?: React.ReactNode;\n /**\n * Width-to-height ratio preset.\n *\n * - `tall` – 1:2 narrow portrait\n * - `medium` – 361:200 landscape banner (default)\n * - `short` – 4:5 closer to square\n *\n * @default \"medium\"\n */\n aspectRatio?: CreatorTileAspectRatio;\n}\n\n/**\n * A visual highlight tile showcasing a creator with a full-bleed background\n * media and an overlaid profile row containing an avatar, name, optional\n * tagline and an action element.\n *\n * @example\n * ```tsx\n * <CreatorTile\n * background={<img src=\"/creator.jpg\" alt=\"\" />}\n * avatar={{ src: \"/avatar.jpg\", alt: \"Aitana Lopez\", fallback: \"AL\" }}\n * name=\"Aitana Lopez\"\n * tagline=\"@fit_aitana\"\n * action={<Button variant=\"primary\">Follow</Button>}\n * />\n * ```\n */\nexport const CreatorTile = React.forwardRef<HTMLDivElement, CreatorTileProps>(\n (\n { className, background, name, tagline, avatar, action, aspectRatio = \"medium\", ...props },\n ref,\n ) => {\n const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative isolate flex w-full flex-col justify-end overflow-hidden\",\n aspectClass,\n className,\n )}\n {...props}\n >\n <div className=\"pointer-events-none absolute inset-0 select-none *:h-full *:w-full [&>img]:object-cover [&>video]:object-cover\">\n {background}\n </div>\n <div className=\"pointer-events-none absolute inset-x-0 bottom-0 h-1/2 rounded-b-[inherit] bg-linear-to-t from-black/60 to-transparent\" />\n <div className=\"pointer-events-none absolute inset-x-0 bottom-0 h-1/2 overflow-hidden rounded-b-[inherit] backdrop-blur-md [-webkit-mask-image:linear-gradient(to_top,black,transparent)] [mask-image:linear-gradient(to_top,black,transparent)]\" />\n <div className=\"relative flex items-center justify-between gap-4 p-4\">\n <div className=\"flex min-w-0 items-center gap-2\">\n <Avatar\n size={40}\n src={avatar?.src}\n alt={avatar?.alt ?? (typeof name === \"string\" ? name : undefined)}\n fallback={avatar?.fallback}\n {...avatar}\n />\n <div className=\"flex min-w-0 flex-col\">\n <p className=\"typography-semibold-body-lg m-0 truncate text-white\">{name}</p>\n {tagline ? (\n <p className=\"typography-semibold-body-md m-0 truncate text-white/50\">{tagline}</p>\n ) : null}\n </div>\n </div>\n {action ? <div className=\"shrink-0\">{action}</div> : null}\n </div>\n </div>\n );\n },\n);\n\nCreatorTile.displayName = \"CreatorTile\";\n"],"names":["React","jsxs","cn","jsx","Avatar"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAM,uBAA+D;AAAA,EACnE,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,OAAO;AACT;AA4CO,MAAM,cAAcA,iBAAM;AAAA,EAC/B,CACE,EAAE,WAAW,YAAY,MAAM,SAAS,QAAQ,QAAQ,cAAc,UAAU,GAAG,MAAA,GACnF,QACG;AACH,UAAM,cAAc,qBAAqB,WAAW;AAEpD,WACEC,2BAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAWC,GAAAA;AAAAA,UACT;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,QAED,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAAC,2BAAAA,IAAC,OAAA,EAAI,WAAU,kHACZ,UAAA,YACH;AAAA,UACAA,2BAAAA,IAAC,OAAA,EAAI,WAAU,wHAAA,CAAwH;AAAA,UACvIA,2BAAAA,IAAC,OAAA,EAAI,WAAU,mOAAA,CAAmO;AAAA,UAClPF,2BAAAA,KAAC,OAAA,EAAI,WAAU,wDACb,UAAA;AAAA,YAAAA,2BAAAA,KAAC,OAAA,EAAI,WAAU,mCACb,UAAA;AAAA,cAAAE,2BAAAA;AAAAA,gBAACC,OAAAA;AAAAA,gBAAA;AAAA,kBACC,MAAM;AAAA,kBACN,KAAK,QAAQ;AAAA,kBACb,KAAK,QAAQ,QAAQ,OAAO,SAAS,WAAW,OAAO;AAAA,kBACvD,UAAU,QAAQ;AAAA,kBACjB,GAAG;AAAA,gBAAA;AAAA,cAAA;AAAA,cAENH,2BAAAA,KAAC,OAAA,EAAI,WAAU,yBACb,UAAA;AAAA,gBAAAE,2BAAAA,IAAC,KAAA,EAAE,WAAU,uDAAuD,UAAA,MAAK;AAAA,gBACxE,UACCA,2BAAAA,IAAC,KAAA,EAAE,WAAU,0DAA0D,mBAAQ,IAC7E;AAAA,cAAA,EAAA,CACN;AAAA,YAAA,GACF;AAAA,YACC,SAASA,2BAAAA,IAAC,OAAA,EAAI,WAAU,YAAY,kBAAO,IAAS;AAAA,UAAA,EAAA,CACvD;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;AAEA,YAAY,cAAc;;"}
@@ -2,13 +2,14 @@
2
2
  import { jsxs, jsx } from "react/jsx-runtime";
3
3
  import * as React from "react";
4
4
  import { cn } from "../../utils/cn.mjs";
5
+ import { Avatar } from "../Avatar/Avatar.mjs";
5
6
  const ASPECT_RATIO_CLASSES = {
6
- tall: "aspect-1/2",
7
- medium: "aspect-2/3",
8
- short: "aspect-4/5"
7
+ tall: "aspect-5/4",
8
+ medium: "aspect-3/2",
9
+ short: "aspect-9/5"
9
10
  };
10
11
  const CreatorTile = React.forwardRef(
11
- ({ className, imageSrc, imageAlt = "", name, tagline, aspectRatio = "medium", ...props }, ref) => {
12
+ ({ className, background, name, tagline, avatar, action, aspectRatio = "medium", ...props }, ref) => {
12
13
  const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];
13
14
  return /* @__PURE__ */ jsxs(
14
15
  "div",
@@ -21,19 +22,27 @@ const CreatorTile = React.forwardRef(
21
22
  ),
22
23
  ...props,
23
24
  children: [
24
- /* @__PURE__ */ jsx(
25
- "img",
26
- {
27
- src: imageSrc,
28
- alt: imageAlt,
29
- loading: "lazy",
30
- className: "absolute inset-0 -z-10 h-full w-full object-cover"
31
- }
32
- ),
33
- /* @__PURE__ */ jsx("div", { className: "pointer-events-none absolute inset-0 -z-10 bg-linear-to-b from-64% from-transparent to-black/40" }),
34
- /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-1 px-6 pb-6", children: [
35
- /* @__PURE__ */ jsx("p", { className: "m-0 font-black text-4xl text-white leading-none tracking-tight", children: name }),
36
- tagline ? /* @__PURE__ */ jsx("p", { className: "m-0 font-bold text-[9px] text-brand-primary-default uppercase leading-none", children: tagline }) : null
25
+ /* @__PURE__ */ jsx("div", { className: "pointer-events-none absolute inset-0 select-none *:h-full *:w-full [&>img]:object-cover [&>video]:object-cover", children: background }),
26
+ /* @__PURE__ */ jsx("div", { className: "pointer-events-none absolute inset-x-0 bottom-0 h-1/2 rounded-b-[inherit] bg-linear-to-t from-black/60 to-transparent" }),
27
+ /* @__PURE__ */ jsx("div", { className: "pointer-events-none absolute inset-x-0 bottom-0 h-1/2 overflow-hidden rounded-b-[inherit] backdrop-blur-md [-webkit-mask-image:linear-gradient(to_top,black,transparent)] [mask-image:linear-gradient(to_top,black,transparent)]" }),
28
+ /* @__PURE__ */ jsxs("div", { className: "relative flex items-center justify-between gap-4 p-4", children: [
29
+ /* @__PURE__ */ jsxs("div", { className: "flex min-w-0 items-center gap-2", children: [
30
+ /* @__PURE__ */ jsx(
31
+ Avatar,
32
+ {
33
+ size: 40,
34
+ src: avatar?.src,
35
+ alt: avatar?.alt ?? (typeof name === "string" ? name : void 0),
36
+ fallback: avatar?.fallback,
37
+ ...avatar
38
+ }
39
+ ),
40
+ /* @__PURE__ */ jsxs("div", { className: "flex min-w-0 flex-col", children: [
41
+ /* @__PURE__ */ jsx("p", { className: "typography-semibold-body-lg m-0 truncate text-white", children: name }),
42
+ tagline ? /* @__PURE__ */ jsx("p", { className: "typography-semibold-body-md m-0 truncate text-white/50", children: tagline }) : null
43
+ ] })
44
+ ] }),
45
+ action ? /* @__PURE__ */ jsx("div", { className: "shrink-0", children: action }) : null
37
46
  ] })
38
47
  ]
39
48
  }
@@ -1 +1 @@
1
- {"version":3,"file":"CreatorTile.mjs","sources":["../../../src/components/CreatorTile/CreatorTile.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { cn } from \"../../utils/cn\";\n\n/** Width-to-height ratio preset for the tile. */\nexport type CreatorTileAspectRatio = \"tall\" | \"medium\" | \"short\";\n\nconst ASPECT_RATIO_CLASSES: Record<CreatorTileAspectRatio, string> = {\n tall: \"aspect-1/2\",\n medium: \"aspect-2/3\",\n short: \"aspect-4/5\",\n};\n\nexport interface CreatorTileProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Source URL of the creator's image. Rendered as the tile background. */\n imageSrc: string;\n /** Alt text for the creator image. Use an empty string for purely decorative imagery. */\n imageAlt?: string;\n /** Creator name shown as the prominent overlay heading. */\n name: React.ReactNode;\n /** Short tagline shown under the name in the brand accent color. */\n tagline?: React.ReactNode;\n /**\n * Width-to-height ratio preset.\n *\n * - `tall` – 1:2 narrow portrait\n * - `medium` – 2:3 classic poster (default)\n * - `short` – 4:5 closer to square\n *\n * @default \"medium\"\n */\n aspectRatio?: CreatorTileAspectRatio;\n}\n\n/**\n * A visual highlight tile showcasing a creator with an overlaid name and tagline.\n *\n * The tile renders a full-bleed image with a bottom gradient that ensures the\n * overlaid text remains legible regardless of the underlying photography.\n *\n * @example\n * ```tsx\n * <CreatorTile\n * imageSrc=\"https://example.com/creator.jpg\"\n * imageAlt=\"Portrait of Jane Doe\"\n * name=\"JANE DOE\"\n * tagline=\"GLOBAL MUSIC ICON\"\n * />\n * ```\n */\nexport const CreatorTile = React.forwardRef<HTMLDivElement, CreatorTileProps>(\n (\n { className, imageSrc, imageAlt = \"\", name, tagline, aspectRatio = \"medium\", ...props },\n ref,\n ) => {\n const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative isolate flex w-full flex-col justify-end overflow-hidden\",\n aspectClass,\n className,\n )}\n {...props}\n >\n <img\n src={imageSrc}\n alt={imageAlt}\n loading=\"lazy\"\n className=\"absolute inset-0 -z-10 h-full w-full object-cover\"\n />\n <div className=\"pointer-events-none absolute inset-0 -z-10 bg-linear-to-b from-64% from-transparent to-black/40\" />\n <div className=\"flex flex-col gap-1 px-6 pb-6\">\n <p className=\"m-0 font-black text-4xl text-white leading-none tracking-tight\">{name}</p>\n {tagline ? (\n <p className=\"m-0 font-bold text-[9px] text-brand-primary-default uppercase leading-none\">\n {tagline}\n </p>\n ) : null}\n </div>\n </div>\n );\n },\n);\n\nCreatorTile.displayName = \"CreatorTile\";\n"],"names":[],"mappings":";;;;AAMA,MAAM,uBAA+D;AAAA,EACnE,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,OAAO;AACT;AAuCO,MAAM,cAAc,MAAM;AAAA,EAC/B,CACE,EAAE,WAAW,UAAU,WAAW,IAAI,MAAM,SAAS,cAAc,UAAU,GAAG,MAAA,GAChF,QACG;AACH,UAAM,cAAc,qBAAqB,WAAW;AAEpD,WACE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAW;AAAA,UACT;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,QAED,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAA;AAAA,YAAC;AAAA,YAAA;AAAA,cACC,KAAK;AAAA,cACL,KAAK;AAAA,cACL,SAAQ;AAAA,cACR,WAAU;AAAA,YAAA;AAAA,UAAA;AAAA,UAEZ,oBAAC,OAAA,EAAI,WAAU,kGAAA,CAAkG;AAAA,UACjH,qBAAC,OAAA,EAAI,WAAU,iCACb,UAAA;AAAA,YAAA,oBAAC,KAAA,EAAE,WAAU,kEAAkE,UAAA,MAAK;AAAA,YACnF,UACC,oBAAC,KAAA,EAAE,WAAU,8EACV,mBACH,IACE;AAAA,UAAA,EAAA,CACN;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;AAEA,YAAY,cAAc;"}
1
+ {"version":3,"file":"CreatorTile.mjs","sources":["../../../src/components/CreatorTile/CreatorTile.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { cn } from \"../../utils/cn\";\nimport { Avatar } from \"../Avatar/Avatar\";\n\n/** Width-to-height ratio preset for the tile. */\nexport type CreatorTileAspectRatio = \"tall\" | \"medium\" | \"short\";\n\nconst ASPECT_RATIO_CLASSES: Record<CreatorTileAspectRatio, string> = {\n tall: \"aspect-5/4\",\n medium: \"aspect-3/2\",\n short: \"aspect-9/5\",\n};\n\nexport interface CreatorTileProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Decorative background media rendered behind the creator content. */\n background: React.ReactNode;\n /** Creator display name shown as the prominent heading. */\n name: React.ReactNode;\n /** Optional secondary line shown under the name (e.g. handle or tagline). */\n tagline?: React.ReactNode;\n /** Avatar props forwarded to the inner {@link Avatar}. */\n avatar?: React.ComponentPropsWithoutRef<typeof Avatar>;\n /**\n * Action element rendered on the right of the profile row (e.g. a `Button`\n * for following the creator).\n */\n action?: React.ReactNode;\n /**\n * Width-to-height ratio preset.\n *\n * - `tall` – 1:2 narrow portrait\n * - `medium` – 361:200 landscape banner (default)\n * - `short` – 4:5 closer to square\n *\n * @default \"medium\"\n */\n aspectRatio?: CreatorTileAspectRatio;\n}\n\n/**\n * A visual highlight tile showcasing a creator with a full-bleed background\n * media and an overlaid profile row containing an avatar, name, optional\n * tagline and an action element.\n *\n * @example\n * ```tsx\n * <CreatorTile\n * background={<img src=\"/creator.jpg\" alt=\"\" />}\n * avatar={{ src: \"/avatar.jpg\", alt: \"Aitana Lopez\", fallback: \"AL\" }}\n * name=\"Aitana Lopez\"\n * tagline=\"@fit_aitana\"\n * action={<Button variant=\"primary\">Follow</Button>}\n * />\n * ```\n */\nexport const CreatorTile = React.forwardRef<HTMLDivElement, CreatorTileProps>(\n (\n { className, background, name, tagline, avatar, action, aspectRatio = \"medium\", ...props },\n ref,\n ) => {\n const aspectClass = ASPECT_RATIO_CLASSES[aspectRatio];\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative isolate flex w-full flex-col justify-end overflow-hidden\",\n aspectClass,\n className,\n )}\n {...props}\n >\n <div className=\"pointer-events-none absolute inset-0 select-none *:h-full *:w-full [&>img]:object-cover [&>video]:object-cover\">\n {background}\n </div>\n <div className=\"pointer-events-none absolute inset-x-0 bottom-0 h-1/2 rounded-b-[inherit] bg-linear-to-t from-black/60 to-transparent\" />\n <div className=\"pointer-events-none absolute inset-x-0 bottom-0 h-1/2 overflow-hidden rounded-b-[inherit] backdrop-blur-md [-webkit-mask-image:linear-gradient(to_top,black,transparent)] [mask-image:linear-gradient(to_top,black,transparent)]\" />\n <div className=\"relative flex items-center justify-between gap-4 p-4\">\n <div className=\"flex min-w-0 items-center gap-2\">\n <Avatar\n size={40}\n src={avatar?.src}\n alt={avatar?.alt ?? (typeof name === \"string\" ? name : undefined)}\n fallback={avatar?.fallback}\n {...avatar}\n />\n <div className=\"flex min-w-0 flex-col\">\n <p className=\"typography-semibold-body-lg m-0 truncate text-white\">{name}</p>\n {tagline ? (\n <p className=\"typography-semibold-body-md m-0 truncate text-white/50\">{tagline}</p>\n ) : null}\n </div>\n </div>\n {action ? <div className=\"shrink-0\">{action}</div> : null}\n </div>\n </div>\n );\n },\n);\n\nCreatorTile.displayName = \"CreatorTile\";\n"],"names":[],"mappings":";;;;;AAOA,MAAM,uBAA+D;AAAA,EACnE,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,OAAO;AACT;AA4CO,MAAM,cAAc,MAAM;AAAA,EAC/B,CACE,EAAE,WAAW,YAAY,MAAM,SAAS,QAAQ,QAAQ,cAAc,UAAU,GAAG,MAAA,GACnF,QACG;AACH,UAAM,cAAc,qBAAqB,WAAW;AAEpD,WACE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC;AAAA,QACA,WAAW;AAAA,UACT;AAAA,UACA;AAAA,UACA;AAAA,QAAA;AAAA,QAED,GAAG;AAAA,QAEJ,UAAA;AAAA,UAAA,oBAAC,OAAA,EAAI,WAAU,kHACZ,UAAA,YACH;AAAA,UACA,oBAAC,OAAA,EAAI,WAAU,wHAAA,CAAwH;AAAA,UACvI,oBAAC,OAAA,EAAI,WAAU,mOAAA,CAAmO;AAAA,UAClP,qBAAC,OAAA,EAAI,WAAU,wDACb,UAAA;AAAA,YAAA,qBAAC,OAAA,EAAI,WAAU,mCACb,UAAA;AAAA,cAAA;AAAA,gBAAC;AAAA,gBAAA;AAAA,kBACC,MAAM;AAAA,kBACN,KAAK,QAAQ;AAAA,kBACb,KAAK,QAAQ,QAAQ,OAAO,SAAS,WAAW,OAAO;AAAA,kBACvD,UAAU,QAAQ;AAAA,kBACjB,GAAG;AAAA,gBAAA;AAAA,cAAA;AAAA,cAEN,qBAAC,OAAA,EAAI,WAAU,yBACb,UAAA;AAAA,gBAAA,oBAAC,KAAA,EAAE,WAAU,uDAAuD,UAAA,MAAK;AAAA,gBACxE,UACC,oBAAC,KAAA,EAAE,WAAU,0DAA0D,mBAAQ,IAC7E;AAAA,cAAA,EAAA,CACN;AAAA,YAAA,GACF;AAAA,YACC,SAAS,oBAAC,OAAA,EAAI,WAAU,YAAY,kBAAO,IAAS;AAAA,UAAA,EAAA,CACvD;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;AAEA,YAAY,cAAc;"}
package/dist/index.d.ts CHANGED
@@ -1382,18 +1382,18 @@ export declare interface CreatorCoverProps extends Omit<React_2.HTMLAttributes<H
1382
1382
  export declare type CreatorCoverSlot = string | React_2.ReactNode;
1383
1383
 
1384
1384
  /**
1385
- * A visual highlight tile showcasing a creator with an overlaid name and tagline.
1386
- *
1387
- * The tile renders a full-bleed image with a bottom gradient that ensures the
1388
- * overlaid text remains legible regardless of the underlying photography.
1385
+ * A visual highlight tile showcasing a creator with a full-bleed background
1386
+ * media and an overlaid profile row containing an avatar, name, optional
1387
+ * tagline and an action element.
1389
1388
  *
1390
1389
  * @example
1391
1390
  * ```tsx
1392
1391
  * <CreatorTile
1393
- * imageSrc="https://example.com/creator.jpg"
1394
- * imageAlt="Portrait of Jane Doe"
1395
- * name="JANE DOE"
1396
- * tagline="GLOBAL MUSIC ICON"
1392
+ * background={<img src="/creator.jpg" alt="" />}
1393
+ * avatar={{ src: "/avatar.jpg", alt: "Aitana Lopez", fallback: "AL" }}
1394
+ * name="Aitana Lopez"
1395
+ * tagline="@fit_aitana"
1396
+ * action={<Button variant="primary">Follow</Button>}
1397
1397
  * />
1398
1398
  * ```
1399
1399
  */
@@ -1403,19 +1403,24 @@ export declare const CreatorTile: React_2.ForwardRefExoticComponent<CreatorTileP
1403
1403
  export declare type CreatorTileAspectRatio = "tall" | "medium" | "short";
1404
1404
 
1405
1405
  export declare interface CreatorTileProps extends React_2.HTMLAttributes<HTMLDivElement> {
1406
- /** Source URL of the creator's image. Rendered as the tile background. */
1407
- imageSrc: string;
1408
- /** Alt text for the creator image. Use an empty string for purely decorative imagery. */
1409
- imageAlt?: string;
1410
- /** Creator name shown as the prominent overlay heading. */
1406
+ /** Decorative background media rendered behind the creator content. */
1407
+ background: React_2.ReactNode;
1408
+ /** Creator display name shown as the prominent heading. */
1411
1409
  name: React_2.ReactNode;
1412
- /** Short tagline shown under the name in the brand accent color. */
1410
+ /** Optional secondary line shown under the name (e.g. handle or tagline). */
1413
1411
  tagline?: React_2.ReactNode;
1412
+ /** Avatar props forwarded to the inner {@link Avatar}. */
1413
+ avatar?: React_2.ComponentPropsWithoutRef<typeof Avatar>;
1414
+ /**
1415
+ * Action element rendered on the right of the profile row (e.g. a `Button`
1416
+ * for following the creator).
1417
+ */
1418
+ action?: React_2.ReactNode;
1414
1419
  /**
1415
1420
  * Width-to-height ratio preset.
1416
1421
  *
1417
1422
  * - `tall` – 1:2 narrow portrait
1418
- * - `medium` – 2:3 classic poster (default)
1423
+ * - `medium` – 361:200 landscape banner (default)
1419
1424
  * - `short` – 4:5 closer to square
1420
1425
  *
1421
1426
  * @default "medium"
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fanvue/ui",
3
- "version": "2.14.2",
3
+ "version": "2.14.3",
4
4
  "description": "React component library built with Tailwind CSS for Fanvue ecosystem",
5
5
  "publishConfig": {
6
6
  "registry": "https://registry.npmjs.org",