UNPKG

@feedspring/framer-google-reviews

Version:
150 lines (149 loc) 45.3 kB
import { p as J, a as x, b as t, f as y, d as H, e as F, s as Y, n as a, r as e, g as N, h as v, k as l, j as A, W as s, u as z, l as p, i as h } from "./Welcome-cce204c3.js"; import { ControlType as I } from "framer"; import { c as V, C as o } from "./Card-a0877d13.js"; import "react"; const O = { feedId: J, items: x, skip: t, fontSettings: { type: I.Object, title: "Font", controls: y }, cardSettings: { type: I.Object, title: "Card", controls: V }, averageRatingSettings: { type: I.Object, title: "Average Rating", controls: H }, avatarSettings: { type: I.Object, title: "Avatar", controls: F }, starsSettings: { type: I.Object, title: "Stars", controls: Y }, nameSettings: { type: I.Object, title: "Name", controls: a }, reviewSettings: { type: I.Object, title: "Review", controls: e }, dateSettings: { type: I.Object, title: "Date", controls: N }, separatorSettings: { type: I.Object, title: "Separator", controls: v }, bento: { type: I.Object, title: "Bento", controls: { columns: { type: I.Number, title: "Columns", defaultValue: 4, min: 1, max: 6, step: 1, displayStepper: !0 }, gap: { type: I.Number, title: "Gap", defaultValue: 16, min: 0, max: 48, step: 2, displayStepper: !0 } } }, card: { type: I.Object, title: "Card", controls: V } }, r = (g) => { if (!g.settings.feedId) return /* @__PURE__ */ A(s, {}); const { feed: b, items: W } = z(g.settings.feedId, g.settings.items, g.settings.skip); if (!b) return null; const R = g.settings.averageRatingSettings.visible && b.extra && b.extra.total, { columns: m, gap: i } = g.settings.bento, n = ((Z, c) => { const C = Array.from({ length: c }, () => []); return Z.forEach((G, d) => { const B = d % c, X = Math.floor(d / c); let u; c === 1 ? u = X % 2 === 0 ? "1" : "0.77" : u = (B % 2 === 0 ? X % 2 === 0 : X % 2 === 1) ? "1" : "0.77", C[B].push({ ...G, index: d, aspectRatio: u }); }), C; })(W || [], m); return /* @__PURE__ */ p(L, { family: g.settings.fontSettings.family, children: [ /* @__PURE__ */ A(U, { columns: m, gap: i, children: n.map((Z, c) => /* @__PURE__ */ A(w, { gap: i, children: Z.map((C, G) => /* @__PURE__ */ A(S, { aspectRatio: C.aspectRatio, children: /* @__PURE__ */ A(o, { review: C, extra: b.extra, cardSettings: g.settings.cardSettings, avatarSettings: { ...g.settings.avatarSettings, visible: C.aspectRatio != "1" }, starsSettings: g.settings.starsSettings, nameSettings: { ...g.settings.nameSettings, visible: C.aspectRatio != "1" }, reviewSettings: g.settings.reviewSettings, dateSettings: { ...g.settings.dateSettings, visible: C.aspectRatio != "1" }, separatorSettings: { ...g.settings.separatorSettings, visible: C.aspectRatio != "1" }, showGoogleLogo: C.aspectRatio != "1" }, C.id) }, G)) }, c)) }), R && /* @__PURE__ */ A(h, { total: b.extra.total, averageRating: b.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":"AAmOuD","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  propertyControlFeedItems,\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  card: Card.CardSettings\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: propertyControlFeedItems,\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  },\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,\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,\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,\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls,\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 4,\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  card: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls,\n  },\n}\n\ninterface Props {\n  settings: Settings\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 = (items: any[], numColumns: number) => {\n    const columnsArray = Array.from({ length: numColumns }, () => [] as any[])\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' : '0.77'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '0.77'\n      }\n\n      columnsArray[columnIndex].push({\n        ...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.id}\n                  review={item}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={{\n                    ...props.settings.avatarSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={{\n                    ...props.settings.nameSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={{\n                    ...props.settings.dateSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  separatorSettings={{\n                    ...props.settings.separatorSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  showGoogleLogo={item.aspectRatio != '1'}\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":"AA+OE","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  propertyControlFeedItems,\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  card: Card.CardSettings\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: propertyControlFeedItems,\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  },\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,\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,\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,\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls,\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 4,\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  card: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls,\n  },\n}\n\ninterface Props {\n  settings: Settings\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 = (items: any[], numColumns: number) => {\n    const columnsArray = Array.from({ length: numColumns }, () => [] as any[])\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' : '0.77'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '0.77'\n      }\n\n      columnsArray[columnIndex].push({\n        ...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.id}\n                  review={item}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={{\n                    ...props.settings.avatarSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={{\n                    ...props.settings.nameSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={{\n                    ...props.settings.dateSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  separatorSettings={{\n                    ...props.settings.separatorSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  showGoogleLogo={item.aspectRatio != '1'}\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: "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":"AAwPE","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  propertyControlFeedItems,\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  card: Card.CardSettings\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: propertyControlFeedItems,\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  },\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,\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,\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,\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls,\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 4,\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  card: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls,\n  },\n}\n\ninterface Props {\n  settings: Settings\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 = (items: any[], numColumns: number) => {\n    const columnsArray = Array.from({ length: numColumns }, () => [] as any[])\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' : '0.77'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '0.77'\n      }\n\n      columnsArray[columnIndex].push({\n        ...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.id}\n                  review={item}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={{\n                    ...props.settings.avatarSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={{\n                    ...props.settings.nameSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={{\n                    ...props.settings.dateSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  separatorSettings={{\n                    ...props.settings.separatorSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  showGoogleLogo={item.aspectRatio != '1'}\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: "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":"AAiQE","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  propertyControlFeedItems,\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  card: Card.CardSettings\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: propertyControlFeedItems,\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  },\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,\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,\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,\n  },\n  separatorSettings: {\n    type: ControlType.Object,\n    title: 'Separator',\n    controls: Separator.separatorPropertyControls,\n  },\n  bento: {\n    type: ControlType.Object,\n    title: 'Bento',\n    controls: {\n      columns: {\n        type: ControlType.Number,\n        title: 'Columns',\n        defaultValue: 4,\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  card: {\n    type: ControlType.Object,\n    title: 'Card',\n    controls: Card.cardPropertyControls,\n  },\n}\n\ninterface Props {\n  settings: Settings\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 = (items: any[], numColumns: number) => {\n    const columnsArray = Array.from({ length: numColumns }, () => [] as any[])\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' : '0.77'\n      } else {\n        const isSquare =\n          columnIndex % 2 === 0\n            ? itemIndexInColumn % 2 === 0\n            : itemIndexInColumn % 2 === 1\n\n        aspectRatio = isSquare ? '1' : '0.77'\n      }\n\n      columnsArray[columnIndex].push({\n        ...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.id}\n                  review={item}\n                  extra={feed.extra!}\n                  cardSettings={props.settings.cardSettings}\n                  avatarSettings={{\n                    ...props.settings.avatarSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  starsSettings={props.settings.starsSettings}\n                  nameSettings={{\n                    ...props.settings.nameSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  reviewSettings={props.settings.reviewSettings}\n                  dateSettings={{\n                    ...props.settings.dateSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  separatorSettings={{\n                    ...props.settings.separatorSettings,\n                    visible: item.aspectRatio != '1',\n                  }}\n                  showGoogleLogo={item.aspectRatio != '1'}\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, O as propertyControls };