@feedspring/framer-google-reviews
Version:
143 lines (142 loc) • 44.5 kB
JavaScript
import { p as x, z as R, b as J, f as H, d as t, e as y, s as a, n as F, r as N, g as Y, h as v, l, j as A, W as e, u as s, m as z, i as p } from "./Welcome-8909f8da.js";
import { ControlType as I } from "framer";
import { c as h, C as o } from "./Card-38a3ddfb.js";
import "react";
const j = {
feedId: x,
items: R,
skip: J,
fontSettings: {
type: I.Object,
title: "Font",
controls: H
},
cardSettings: {
type: I.Object,
title: "Card",
controls: h({
disabledVisibleGoogleLogoControl: !0
})
},
averageRatingSettings: {
type: I.Object,
title: "Average Rating",
controls: t
},
avatarSettings: {
type: I.Object,
title: "Avatar",
controls: y({
disabledVisibleControl: !0
})
},
starsSettings: {
type: I.Object,
title: "Stars",
controls: a
},
nameSettings: {
type: I.Object,
title: "Name",
controls: F({
disabledVisibleControl: !0
})
},
reviewSettings: {
type: I.Object,
title: "Review",
controls: N
},
dateSettings: {
type: I.Object,
title: "Date",
controls: Y({
disabledVisibleControl: !0
})
},
separatorSettings: {
type: I.Object,
title: "Separator",
controls: v({
disabledVisibleControl: !0
})
},
bento: {
type: I.Object,
title: "Bento",
controls: {
columns: {
type: I.Number,
title: "Columns",
defaultValue: 2,
min: 1,
max: 6,
step: 1,
displayStepper: !0
},
gap: {
type: I.Number,
title: "Gap",
defaultValue: 16,
min: 0,
max: 48,
step: 2,
displayStepper: !0
}
}
}
}, r = (g) => {
if (!g.settings.feedId)
return /* @__PURE__ */ A(e, {});
const {
feed: c,
items: B
} = s(g.settings.feedId, g.settings.items, g.settings.skip);
if (!c)
return null;
const i = g.settings.averageRatingSettings.visible && c.extra && c.extra.total, {
columns: m,
gap: W
} = g.settings.bento, n = ((Z, C) => {
const b = Array.from({
length: C
}, () => []);
return Z.forEach((d, G) => {
const V = G % C, X = Math.floor(G / C);
let u;
C === 1 ? u = X % 2 === 0 ? "1" : "2/1" : u = (V % 2 === 0 ? X % 2 === 0 : X % 2 === 1) ? "1" : "2/1", b[V].push({
data: d,
index: G,
aspectRatio: u
});
}), b;
})(B || [], m);
return /* @__PURE__ */ z(L, { family: g.settings.fontSettings.family, children: [
/* @__PURE__ */ A(U, { columns: m, gap: W, children: n.map((Z, C) => /* @__PURE__ */ A(S, { gap: W, children: Z.map((b, d) => /* @__PURE__ */ A(w, { aspectRatio: b.aspectRatio, children: /* @__PURE__ */ A(o, { review: b.data, variant: b.aspectRatio === "1" ? "simple" : "basic", extra: c.extra, cardSettings: g.settings.cardSettings, avatarSettings: g.settings.avatarSettings, starsSettings: g.settings.starsSettings, nameSettings: g.settings.nameSettings, reviewSettings: g.settings.reviewSettings, dateSettings: g.settings.dateSettings, separatorSettings: g.settings.separatorSettings }, b.data.id) }, d)) }, C)) }),
i && /* @__PURE__ */ A(p, { total: c.extra.total, averageRating: c.extra.averageRating, settings: g.settings.averageRatingSettings })
] });
}, L = /* @__PURE__ */ l("section", process.env.NODE_ENV === "production" ? {
target: "e1uw91jr3"
} : {
target: "e1uw91jr3",
label: "BentoSection"
})("display:flex;flex-direction:column;align-items:center;width:100%;font-family:", (g) => g.family, ",sans-serif;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx"],"names":[],"mappings":"AAiOuD","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx","sourcesContent":["import React from 'react'\nimport styled from '@emotion/styled'\nimport { useFeedState } from '../hooks/useFeedState'\n\nimport {\n  PropertyControls,\n  ControlType,\n  propertyControlFeedId,\n  propertyGoogleReviewsBentoControlFeedItems,\n  propertyControlFeedSkip,\n} from '@feedspring/framer-helper'\n\nimport { Welcome } from '../components/Welcome'\nimport * as Card from '../components/basic-card/Card'\nimport * as AverageRating from '../components/AverageRating'\nimport * as Section from '../components/Section'\nimport * as Avatar from '../components/Avatar'\nimport * as Stars from '../components/Stars'\nimport * as Name from '../components/Name'\nimport * as Review from '../components/Review'\nimport * as Date from '../components/Date'\nimport * as Separator from '../components/Separator'\n\nexport interface Settings {\n  feedId: string\n  items: number\n  skip: number\n  fontSettings: Section.FontSettings\n  bento: BentoSettings\n  cardSettings: Card.CardSettings\n  averageRatingSettings: AverageRating.AverageRatingSettings\n  avatarSettings: Avatar.AvatarSettings\n  starsSettings: Stars.StarsSettings\n  nameSettings: Name.NameSettings\n  reviewSettings: Review.ReviewSettings\n  dateSettings: Date.DateSettings\n  separatorSettings: Separator.SeparatorSettings\n}\n\nexport interface BentoSettings {\n  columns: number\n  gap: number\n}\n\nexport const propertyControls: PropertyControls<Settings> = {\n  feedId: propertyControlFeedId,\n  items: propertyGoogleReviewsBentoControlFeedItems,\n  skip: propertyControlFeedSkip,\n  fontSettings: {\n    type: ControlType.Object,\n    title: 'Font',\n    controls: Section.fontPropertyControls,\n  },\n  cardSettings: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls({\n      disabledVisibleGoogleLogoControl: true,\n    }),\n  },\n  averageRatingSettings: {\n    type: ControlType.Object,\n    title: 'Average Rating',\n    controls: AverageRating.averageRatingPropertyControls,\n  },\n  avatarSettings: {\n    type: ControlType.Object,\n    title: 'Avatar',\n    controls: Avatar.avatarPropertyControls({ disabledVisibleControl: true }),\n  },\n  starsSettings: {\n    type: ControlType.Object,\n    title: 'Stars',\n    controls: Stars.starsPropertyControls,\n  },\n  nameSettings: {\n    type: ControlType.Object,\n    title: 'Name',\n    controls: Name.namePropertyControls({ disabledVisibleControl: true }),\n  },\n  reviewSettings: {\n    type: ControlType.Object,\n    title: 'Review',\n    controls: Review.reviewPropertyControls,\n  },\n  dateSettings: {\n    type: ControlType.Object,\n    title: 'Date',\n    controls: Date.datePropertyControls({ disabledVisibleControl: true }),\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls({\n      disabledVisibleControl: true,\n    }),\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 2,\n        min: 1,\n        max: 6,\n        step: 1,\n        displayStepper: true,\n      },\n      gap: {\n        type: ControlType.Number,\n        title: 'Gap',\n        defaultValue: 16,\n        min: 0,\n        max: 48,\n        step: 2,\n        displayStepper: true,\n      },\n    },\n  },\n}\n\ninterface Props {\n  settings: Settings\n}\n\ninterface ColumnItem<T> {\n  data: T\n  index: number\n  aspectRatio: string\n}\n\nexport const Component: React.FC<Props> = (props) => {\n  if (!props.settings.feedId) return <Welcome />\n\n  const { feed, items } = useFeedState(\n    props.settings.feedId,\n    props.settings.items,\n    props.settings.skip\n  )\n\n  if (!feed) return null\n\n  const isAverageRatingVisible =\n    props.settings.averageRatingSettings.visible &&\n    feed.extra &&\n    feed.extra.total\n\n  const { columns, gap } = props.settings.bento\n\n  const distributeItemsInColumns = <T extends object>(\n    items: T[],\n    numColumns: number\n  ) => {\n    const columnsArray: ColumnItem<T>[][] = Array.from(\n      { length: numColumns },\n      () => []\n    )\n\n    items.forEach((item, index) => {\n      const columnIndex = index % numColumns\n      const itemIndexInColumn = Math.floor(index / numColumns)\n\n      let aspectRatio: string\n\n      if (numColumns === 1) {\n        aspectRatio = itemIndexInColumn % 2 === 0 ? '1' : '2/1'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '2/1'\n      }\n\n      columnsArray[columnIndex].push({\n        data: item,\n        index,\n        aspectRatio,\n      })\n    })\n\n    return columnsArray\n  }\n\n  const distributedColumns = distributeItemsInColumns(items || [], columns)\n\n  return (\n    <BentoSection family={props.settings.fontSettings.family}>\n      <BentoContainer columns={columns} gap={gap}>\n        {distributedColumns.map((columnItems, columnIndex) => (\n          <BentoColumn key={columnIndex} gap={gap}>\n            {columnItems.map((item, itemIndex) => (\n              <BentoCard key={itemIndex} aspectRatio={item.aspectRatio}>\n                <Card.Component\n                  key={item.data.id}\n                  review={item.data}\n                  variant={item.aspectRatio === '1' ? 'simple' : 'basic'}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={props.settings.avatarSettings}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={props.settings.nameSettings}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={props.settings.dateSettings}\n                  separatorSettings={props.settings.separatorSettings}\n                />\n              </BentoCard>\n            ))}\n          </BentoColumn>\n        ))}\n      </BentoContainer>\n      {isAverageRatingVisible && (\n        <AverageRating.Component\n          total={feed.extra!.total}\n          averageRating={feed.extra!.averageRating}\n          settings={props.settings.averageRatingSettings}\n        />\n      )}\n    </BentoSection>\n  )\n}\n\nconst BentoSection = styled.section<{ family: string }>`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  width: 100%;\n\n  font-family: ${(p) => p.family}, sans-serif;\n`\n\nconst BentoContainer = styled.div<{\n  columns: number\n  gap: number\n}>`\n  width: 100%;\n  display: flex;\n  gap: ${(p) => p.gap}px;\n  align-items: flex-start;\n`\n\nconst BentoColumn = styled.div<{\n  gap: number\n}>`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  gap: ${(p) => p.gap}px;\n`\n\nconst BentoCard = styled.div<{\n  aspectRatio: string\n}>`\n  width: 100%;\n  aspect-ratio: ${(p) => p.aspectRatio};\n  display: flex;\n  flex-direction: column;\n\n  & > * {\n    flex: 1;\n    display: flex;\n    flex-direction: column;\n  }\n`\n"]} */")), U = /* @__PURE__ */ l("div", process.env.NODE_ENV === "production" ? {
target: "e1uw91jr2"
} : {
target: "e1uw91jr2",
label: "BentoContainer"
})("width:100%;display:flex;gap:", (g) => g.gap, "px;align-items:flex-start;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx"],"names":[],"mappings":"AA6OE","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx","sourcesContent":["import React from 'react'\nimport styled from '@emotion/styled'\nimport { useFeedState } from '../hooks/useFeedState'\n\nimport {\n  PropertyControls,\n  ControlType,\n  propertyControlFeedId,\n  propertyGoogleReviewsBentoControlFeedItems,\n  propertyControlFeedSkip,\n} from '@feedspring/framer-helper'\n\nimport { Welcome } from '../components/Welcome'\nimport * as Card from '../components/basic-card/Card'\nimport * as AverageRating from '../components/AverageRating'\nimport * as Section from '../components/Section'\nimport * as Avatar from '../components/Avatar'\nimport * as Stars from '../components/Stars'\nimport * as Name from '../components/Name'\nimport * as Review from '../components/Review'\nimport * as Date from '../components/Date'\nimport * as Separator from '../components/Separator'\n\nexport interface Settings {\n  feedId: string\n  items: number\n  skip: number\n  fontSettings: Section.FontSettings\n  bento: BentoSettings\n  cardSettings: Card.CardSettings\n  averageRatingSettings: AverageRating.AverageRatingSettings\n  avatarSettings: Avatar.AvatarSettings\n  starsSettings: Stars.StarsSettings\n  nameSettings: Name.NameSettings\n  reviewSettings: Review.ReviewSettings\n  dateSettings: Date.DateSettings\n  separatorSettings: Separator.SeparatorSettings\n}\n\nexport interface BentoSettings {\n  columns: number\n  gap: number\n}\n\nexport const propertyControls: PropertyControls<Settings> = {\n  feedId: propertyControlFeedId,\n  items: propertyGoogleReviewsBentoControlFeedItems,\n  skip: propertyControlFeedSkip,\n  fontSettings: {\n    type: ControlType.Object,\n    title: 'Font',\n    controls: Section.fontPropertyControls,\n  },\n  cardSettings: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls({\n      disabledVisibleGoogleLogoControl: true,\n    }),\n  },\n  averageRatingSettings: {\n    type: ControlType.Object,\n    title: 'Average Rating',\n    controls: AverageRating.averageRatingPropertyControls,\n  },\n  avatarSettings: {\n    type: ControlType.Object,\n    title: 'Avatar',\n    controls: Avatar.avatarPropertyControls({ disabledVisibleControl: true }),\n  },\n  starsSettings: {\n    type: ControlType.Object,\n    title: 'Stars',\n    controls: Stars.starsPropertyControls,\n  },\n  nameSettings: {\n    type: ControlType.Object,\n    title: 'Name',\n    controls: Name.namePropertyControls({ disabledVisibleControl: true }),\n  },\n  reviewSettings: {\n    type: ControlType.Object,\n    title: 'Review',\n    controls: Review.reviewPropertyControls,\n  },\n  dateSettings: {\n    type: ControlType.Object,\n    title: 'Date',\n    controls: Date.datePropertyControls({ disabledVisibleControl: true }),\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls({\n      disabledVisibleControl: true,\n    }),\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 2,\n        min: 1,\n        max: 6,\n        step: 1,\n        displayStepper: true,\n      },\n      gap: {\n        type: ControlType.Number,\n        title: 'Gap',\n        defaultValue: 16,\n        min: 0,\n        max: 48,\n        step: 2,\n        displayStepper: true,\n      },\n    },\n  },\n}\n\ninterface Props {\n  settings: Settings\n}\n\ninterface ColumnItem<T> {\n  data: T\n  index: number\n  aspectRatio: string\n}\n\nexport const Component: React.FC<Props> = (props) => {\n  if (!props.settings.feedId) return <Welcome />\n\n  const { feed, items } = useFeedState(\n    props.settings.feedId,\n    props.settings.items,\n    props.settings.skip\n  )\n\n  if (!feed) return null\n\n  const isAverageRatingVisible =\n    props.settings.averageRatingSettings.visible &&\n    feed.extra &&\n    feed.extra.total\n\n  const { columns, gap } = props.settings.bento\n\n  const distributeItemsInColumns = <T extends object>(\n    items: T[],\n    numColumns: number\n  ) => {\n    const columnsArray: ColumnItem<T>[][] = Array.from(\n      { length: numColumns },\n      () => []\n    )\n\n    items.forEach((item, index) => {\n      const columnIndex = index % numColumns\n      const itemIndexInColumn = Math.floor(index / numColumns)\n\n      let aspectRatio: string\n\n      if (numColumns === 1) {\n        aspectRatio = itemIndexInColumn % 2 === 0 ? '1' : '2/1'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '2/1'\n      }\n\n      columnsArray[columnIndex].push({\n        data: item,\n        index,\n        aspectRatio,\n      })\n    })\n\n    return columnsArray\n  }\n\n  const distributedColumns = distributeItemsInColumns(items || [], columns)\n\n  return (\n    <BentoSection family={props.settings.fontSettings.family}>\n      <BentoContainer columns={columns} gap={gap}>\n        {distributedColumns.map((columnItems, columnIndex) => (\n          <BentoColumn key={columnIndex} gap={gap}>\n            {columnItems.map((item, itemIndex) => (\n              <BentoCard key={itemIndex} aspectRatio={item.aspectRatio}>\n                <Card.Component\n                  key={item.data.id}\n                  review={item.data}\n                  variant={item.aspectRatio === '1' ? 'simple' : 'basic'}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={props.settings.avatarSettings}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={props.settings.nameSettings}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={props.settings.dateSettings}\n                  separatorSettings={props.settings.separatorSettings}\n                />\n              </BentoCard>\n            ))}\n          </BentoColumn>\n        ))}\n      </BentoContainer>\n      {isAverageRatingVisible && (\n        <AverageRating.Component\n          total={feed.extra!.total}\n          averageRating={feed.extra!.averageRating}\n          settings={props.settings.averageRatingSettings}\n        />\n      )}\n    </BentoSection>\n  )\n}\n\nconst BentoSection = styled.section<{ family: string }>`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  width: 100%;\n\n  font-family: ${(p) => p.family}, sans-serif;\n`\n\nconst BentoContainer = styled.div<{\n  columns: number\n  gap: number\n}>`\n  width: 100%;\n  display: flex;\n  gap: ${(p) => p.gap}px;\n  align-items: flex-start;\n`\n\nconst BentoColumn = styled.div<{\n  gap: number\n}>`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  gap: ${(p) => p.gap}px;\n`\n\nconst BentoCard = styled.div<{\n  aspectRatio: string\n}>`\n  width: 100%;\n  aspect-ratio: ${(p) => p.aspectRatio};\n  display: flex;\n  flex-direction: column;\n\n  & > * {\n    flex: 1;\n    display: flex;\n    flex-direction: column;\n  }\n`\n"]} */")), S = /* @__PURE__ */ l("div", process.env.NODE_ENV === "production" ? {
target: "e1uw91jr1"
} : {
target: "e1uw91jr1",
label: "BentoColumn"
})("flex:1;display:flex;flex-direction:column;gap:", (g) => g.gap, "px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx"],"names":[],"mappings":"AAsPE","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx","sourcesContent":["import React from 'react'\nimport styled from '@emotion/styled'\nimport { useFeedState } from '../hooks/useFeedState'\n\nimport {\n  PropertyControls,\n  ControlType,\n  propertyControlFeedId,\n  propertyGoogleReviewsBentoControlFeedItems,\n  propertyControlFeedSkip,\n} from '@feedspring/framer-helper'\n\nimport { Welcome } from '../components/Welcome'\nimport * as Card from '../components/basic-card/Card'\nimport * as AverageRating from '../components/AverageRating'\nimport * as Section from '../components/Section'\nimport * as Avatar from '../components/Avatar'\nimport * as Stars from '../components/Stars'\nimport * as Name from '../components/Name'\nimport * as Review from '../components/Review'\nimport * as Date from '../components/Date'\nimport * as Separator from '../components/Separator'\n\nexport interface Settings {\n  feedId: string\n  items: number\n  skip: number\n  fontSettings: Section.FontSettings\n  bento: BentoSettings\n  cardSettings: Card.CardSettings\n  averageRatingSettings: AverageRating.AverageRatingSettings\n  avatarSettings: Avatar.AvatarSettings\n  starsSettings: Stars.StarsSettings\n  nameSettings: Name.NameSettings\n  reviewSettings: Review.ReviewSettings\n  dateSettings: Date.DateSettings\n  separatorSettings: Separator.SeparatorSettings\n}\n\nexport interface BentoSettings {\n  columns: number\n  gap: number\n}\n\nexport const propertyControls: PropertyControls<Settings> = {\n  feedId: propertyControlFeedId,\n  items: propertyGoogleReviewsBentoControlFeedItems,\n  skip: propertyControlFeedSkip,\n  fontSettings: {\n    type: ControlType.Object,\n    title: 'Font',\n    controls: Section.fontPropertyControls,\n  },\n  cardSettings: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls({\n      disabledVisibleGoogleLogoControl: true,\n    }),\n  },\n  averageRatingSettings: {\n    type: ControlType.Object,\n    title: 'Average Rating',\n    controls: AverageRating.averageRatingPropertyControls,\n  },\n  avatarSettings: {\n    type: ControlType.Object,\n    title: 'Avatar',\n    controls: Avatar.avatarPropertyControls({ disabledVisibleControl: true }),\n  },\n  starsSettings: {\n    type: ControlType.Object,\n    title: 'Stars',\n    controls: Stars.starsPropertyControls,\n  },\n  nameSettings: {\n    type: ControlType.Object,\n    title: 'Name',\n    controls: Name.namePropertyControls({ disabledVisibleControl: true }),\n  },\n  reviewSettings: {\n    type: ControlType.Object,\n    title: 'Review',\n    controls: Review.reviewPropertyControls,\n  },\n  dateSettings: {\n    type: ControlType.Object,\n    title: 'Date',\n    controls: Date.datePropertyControls({ disabledVisibleControl: true }),\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls({\n      disabledVisibleControl: true,\n    }),\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 2,\n        min: 1,\n        max: 6,\n        step: 1,\n        displayStepper: true,\n      },\n      gap: {\n        type: ControlType.Number,\n        title: 'Gap',\n        defaultValue: 16,\n        min: 0,\n        max: 48,\n        step: 2,\n        displayStepper: true,\n      },\n    },\n  },\n}\n\ninterface Props {\n  settings: Settings\n}\n\ninterface ColumnItem<T> {\n  data: T\n  index: number\n  aspectRatio: string\n}\n\nexport const Component: React.FC<Props> = (props) => {\n  if (!props.settings.feedId) return <Welcome />\n\n  const { feed, items } = useFeedState(\n    props.settings.feedId,\n    props.settings.items,\n    props.settings.skip\n  )\n\n  if (!feed) return null\n\n  const isAverageRatingVisible =\n    props.settings.averageRatingSettings.visible &&\n    feed.extra &&\n    feed.extra.total\n\n  const { columns, gap } = props.settings.bento\n\n  const distributeItemsInColumns = <T extends object>(\n    items: T[],\n    numColumns: number\n  ) => {\n    const columnsArray: ColumnItem<T>[][] = Array.from(\n      { length: numColumns },\n      () => []\n    )\n\n    items.forEach((item, index) => {\n      const columnIndex = index % numColumns\n      const itemIndexInColumn = Math.floor(index / numColumns)\n\n      let aspectRatio: string\n\n      if (numColumns === 1) {\n        aspectRatio = itemIndexInColumn % 2 === 0 ? '1' : '2/1'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '2/1'\n      }\n\n      columnsArray[columnIndex].push({\n        data: item,\n        index,\n        aspectRatio,\n      })\n    })\n\n    return columnsArray\n  }\n\n  const distributedColumns = distributeItemsInColumns(items || [], columns)\n\n  return (\n    <BentoSection family={props.settings.fontSettings.family}>\n      <BentoContainer columns={columns} gap={gap}>\n        {distributedColumns.map((columnItems, columnIndex) => (\n          <BentoColumn key={columnIndex} gap={gap}>\n            {columnItems.map((item, itemIndex) => (\n              <BentoCard key={itemIndex} aspectRatio={item.aspectRatio}>\n                <Card.Component\n                  key={item.data.id}\n                  review={item.data}\n                  variant={item.aspectRatio === '1' ? 'simple' : 'basic'}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={props.settings.avatarSettings}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={props.settings.nameSettings}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={props.settings.dateSettings}\n                  separatorSettings={props.settings.separatorSettings}\n                />\n              </BentoCard>\n            ))}\n          </BentoColumn>\n        ))}\n      </BentoContainer>\n      {isAverageRatingVisible && (\n        <AverageRating.Component\n          total={feed.extra!.total}\n          averageRating={feed.extra!.averageRating}\n          settings={props.settings.averageRatingSettings}\n        />\n      )}\n    </BentoSection>\n  )\n}\n\nconst BentoSection = styled.section<{ family: string }>`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  width: 100%;\n\n  font-family: ${(p) => p.family}, sans-serif;\n`\n\nconst BentoContainer = styled.div<{\n  columns: number\n  gap: number\n}>`\n  width: 100%;\n  display: flex;\n  gap: ${(p) => p.gap}px;\n  align-items: flex-start;\n`\n\nconst BentoColumn = styled.div<{\n  gap: number\n}>`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  gap: ${(p) => p.gap}px;\n`\n\nconst BentoCard = styled.div<{\n  aspectRatio: string\n}>`\n  width: 100%;\n  aspect-ratio: ${(p) => p.aspectRatio};\n  display: flex;\n  flex-direction: column;\n\n  & > * {\n    flex: 1;\n    display: flex;\n    flex-direction: column;\n  }\n`\n"]} */")), w = /* @__PURE__ */ l("div", process.env.NODE_ENV === "production" ? {
target: "e1uw91jr0"
} : {
target: "e1uw91jr0",
label: "BentoCard"
})("width:100%;aspect-ratio:", (g) => g.aspectRatio, ";display:flex;flex-direction:column;&>*{flex:1;display:flex;flex-direction:column;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx"],"names":[],"mappings":"AA+PE","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/layouts/BentoGrid.tsx","sourcesContent":["import React from 'react'\nimport styled from '@emotion/styled'\nimport { useFeedState } from '../hooks/useFeedState'\n\nimport {\n  PropertyControls,\n  ControlType,\n  propertyControlFeedId,\n  propertyGoogleReviewsBentoControlFeedItems,\n  propertyControlFeedSkip,\n} from '@feedspring/framer-helper'\n\nimport { Welcome } from '../components/Welcome'\nimport * as Card from '../components/basic-card/Card'\nimport * as AverageRating from '../components/AverageRating'\nimport * as Section from '../components/Section'\nimport * as Avatar from '../components/Avatar'\nimport * as Stars from '../components/Stars'\nimport * as Name from '../components/Name'\nimport * as Review from '../components/Review'\nimport * as Date from '../components/Date'\nimport * as Separator from '../components/Separator'\n\nexport interface Settings {\n  feedId: string\n  items: number\n  skip: number\n  fontSettings: Section.FontSettings\n  bento: BentoSettings\n  cardSettings: Card.CardSettings\n  averageRatingSettings: AverageRating.AverageRatingSettings\n  avatarSettings: Avatar.AvatarSettings\n  starsSettings: Stars.StarsSettings\n  nameSettings: Name.NameSettings\n  reviewSettings: Review.ReviewSettings\n  dateSettings: Date.DateSettings\n  separatorSettings: Separator.SeparatorSettings\n}\n\nexport interface BentoSettings {\n  columns: number\n  gap: number\n}\n\nexport const propertyControls: PropertyControls<Settings> = {\n  feedId: propertyControlFeedId,\n  items: propertyGoogleReviewsBentoControlFeedItems,\n  skip: propertyControlFeedSkip,\n  fontSettings: {\n    type: ControlType.Object,\n    title: 'Font',\n    controls: Section.fontPropertyControls,\n  },\n  cardSettings: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls({\n      disabledVisibleGoogleLogoControl: true,\n    }),\n  },\n  averageRatingSettings: {\n    type: ControlType.Object,\n    title: 'Average Rating',\n    controls: AverageRating.averageRatingPropertyControls,\n  },\n  avatarSettings: {\n    type: ControlType.Object,\n    title: 'Avatar',\n    controls: Avatar.avatarPropertyControls({ disabledVisibleControl: true }),\n  },\n  starsSettings: {\n    type: ControlType.Object,\n    title: 'Stars',\n    controls: Stars.starsPropertyControls,\n  },\n  nameSettings: {\n    type: ControlType.Object,\n    title: 'Name',\n    controls: Name.namePropertyControls({ disabledVisibleControl: true }),\n  },\n  reviewSettings: {\n    type: ControlType.Object,\n    title: 'Review',\n    controls: Review.reviewPropertyControls,\n  },\n  dateSettings: {\n    type: ControlType.Object,\n    title: 'Date',\n    controls: Date.datePropertyControls({ disabledVisibleControl: true }),\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls({\n      disabledVisibleControl: true,\n    }),\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 2,\n        min: 1,\n        max: 6,\n        step: 1,\n        displayStepper: true,\n      },\n      gap: {\n        type: ControlType.Number,\n        title: 'Gap',\n        defaultValue: 16,\n        min: 0,\n        max: 48,\n        step: 2,\n        displayStepper: true,\n      },\n    },\n  },\n}\n\ninterface Props {\n  settings: Settings\n}\n\ninterface ColumnItem<T> {\n  data: T\n  index: number\n  aspectRatio: string\n}\n\nexport const Component: React.FC<Props> = (props) => {\n  if (!props.settings.feedId) return <Welcome />\n\n  const { feed, items } = useFeedState(\n    props.settings.feedId,\n    props.settings.items,\n    props.settings.skip\n  )\n\n  if (!feed) return null\n\n  const isAverageRatingVisible =\n    props.settings.averageRatingSettings.visible &&\n    feed.extra &&\n    feed.extra.total\n\n  const { columns, gap } = props.settings.bento\n\n  const distributeItemsInColumns = <T extends object>(\n    items: T[],\n    numColumns: number\n  ) => {\n    const columnsArray: ColumnItem<T>[][] = Array.from(\n      { length: numColumns },\n      () => []\n    )\n\n    items.forEach((item, index) => {\n      const columnIndex = index % numColumns\n      const itemIndexInColumn = Math.floor(index / numColumns)\n\n      let aspectRatio: string\n\n      if (numColumns === 1) {\n        aspectRatio = itemIndexInColumn % 2 === 0 ? '1' : '2/1'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '2/1'\n      }\n\n      columnsArray[columnIndex].push({\n        data: item,\n        index,\n        aspectRatio,\n      })\n    })\n\n    return columnsArray\n  }\n\n  const distributedColumns = distributeItemsInColumns(items || [], columns)\n\n  return (\n    <BentoSection family={props.settings.fontSettings.family}>\n      <BentoContainer columns={columns} gap={gap}>\n        {distributedColumns.map((columnItems, columnIndex) => (\n          <BentoColumn key={columnIndex} gap={gap}>\n            {columnItems.map((item, itemIndex) => (\n              <BentoCard key={itemIndex} aspectRatio={item.aspectRatio}>\n                <Card.Component\n                  key={item.data.id}\n                  review={item.data}\n                  variant={item.aspectRatio === '1' ? 'simple' : 'basic'}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={props.settings.avatarSettings}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={props.settings.nameSettings}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={props.settings.dateSettings}\n                  separatorSettings={props.settings.separatorSettings}\n                />\n              </BentoCard>\n            ))}\n          </BentoColumn>\n        ))}\n      </BentoContainer>\n      {isAverageRatingVisible && (\n        <AverageRating.Component\n          total={feed.extra!.total}\n          averageRating={feed.extra!.averageRating}\n          settings={props.settings.averageRatingSettings}\n        />\n      )}\n    </BentoSection>\n  )\n}\n\nconst BentoSection = styled.section<{ family: string }>`\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  width: 100%;\n\n  font-family: ${(p) => p.family}, sans-serif;\n`\n\nconst BentoContainer = styled.div<{\n  columns: number\n  gap: number\n}>`\n  width: 100%;\n  display: flex;\n  gap: ${(p) => p.gap}px;\n  align-items: flex-start;\n`\n\nconst BentoColumn = styled.div<{\n  gap: number\n}>`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  gap: ${(p) => p.gap}px;\n`\n\nconst BentoCard = styled.div<{\n  aspectRatio: string\n}>`\n  width: 100%;\n  aspect-ratio: ${(p) => p.aspectRatio};\n  display: flex;\n  flex-direction: column;\n\n  & > * {\n    flex: 1;\n    display: flex;\n    flex-direction: column;\n  }\n`\n"]} */"));
export {
r as Component,
j as propertyControls
};