@feedspring/framer-google-reviews
Version:
150 lines • 56.5 kB
JavaScript
import { l as c, m as C, j as g, o as d, y as i, x as u, w as m, q as y, t as B, v as x } from "./Welcome-8909f8da.js";
import { ControlType as A } from "framer";
function b() {
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
}
const M = (I) => ({
link: {
type: A.Boolean,
defaultValue: !0
},
background: {
type: A.Color,
defaultValue: "#FFFFFF"
},
borderColor: {
type: A.Color,
defaultValue: "#E5E5E5"
},
borderSize: {
type: A.Number,
defaultValue: 1,
min: 0,
max: 10,
step: 1,
displayStepper: !0
},
radius: {
type: A.Number,
defaultValue: 24,
min: 0,
max: 50,
step: 1,
displayStepper: !0
},
gap: {
type: A.Number,
defaultValue: 24,
min: 0,
max: 100,
step: 1,
displayStepper: !0
},
padding: {
type: A.Number,
defaultValue: 24,
min: 0,
max: 100,
step: 1,
displayStepper: !0
},
showGoogleLogo: {
type: A.Boolean,
defaultValue: !0,
hidden: () => (I == null ? void 0 : I.disabledVisibleGoogleLogoControl) ?? !1
}
}), F = (I) => {
var l, Z;
const G = ((l = I.extra.location) == null ? void 0 : l.placeId) || ((Z = I.review.location) == null ? void 0 : Z.placeId), X = I.variant ?? "simple";
return /* @__PURE__ */ C(W, { ...I.cardSettings, children: [
G && I.cardSettings.link && /* @__PURE__ */ g(d, { placeId: G }),
I.starsSettings.visible && /* @__PURE__ */ g(i, { value: I.review.rating.number, settings: I.starsSettings }),
/* @__PURE__ */ g(u, { value: I.review.comment, settings: I.reviewSettings, center: !1 }),
/* @__PURE__ */ C(Y, { children: [
X === "simple" && /* @__PURE__ */ g(m, { settings: I.separatorSettings }),
/* @__PURE__ */ C(V, { children: [
X === "simple" && /* @__PURE__ */ C(R, { children: [
/* @__PURE__ */ g(y, { src: I.review.author.photoUrl, settings: I.avatarSettings }),
/* @__PURE__ */ C(N, { children: [
/* @__PURE__ */ g(B, { value: I.review.author.name, settings: I.nameSettings }),
/* @__PURE__ */ g(x, { value: I.review.createdAt, settings: I.dateSettings })
] })
] }),
I.showGoogleLogo && /* @__PURE__ */ g(n, { children: /* @__PURE__ */ C("svg", { width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", children: [
/* @__PURE__ */ g("path", { d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z", fill: "#4285F4" }),
/* @__PURE__ */ g("path", { d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z", fill: "#34A853" }),
/* @__PURE__ */ g("path", { d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z", fill: "#FBBC05" }),
/* @__PURE__ */ g("path", { d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z", fill: "#EA4335" })
] }) })
] })
] })
] });
}, W = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm85"
} : {
target: "e6u6mm85",
label: "Container"
})("display:flex;position:relative;flex-direction:column;row-gap:", (I) => I.gap, "px;border-radius:", (I) => I.radius, "px;border:", (I) => I.borderSize, "px solid ", (I) => I.borderColor, ";background:", (I) => I.background, ";padding:", (I) => I.padding, "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/components/basic-card/Card.tsx"],"names":[],"mappings":"AAiL0C","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { GoogleReview, GoogleReviewsExtra } from '@feedspring/common/src/types'\n\nimport { CardLink } from '../CardLink'\nimport * as Stars from '../Stars'\nimport * as Avatar from '../Avatar'\nimport * as Date from '../Date'\nimport * as Name from '../Name'\nimport * as Review from '../Review'\nimport * as Separator from '../Separator'\nimport {\n  ControlType,\n  ObjectPropertyControlsWithOptions,\n} from '@feedspring/framer-helper'\n\nexport type CardVariant = 'basic' | 'simple'\n\ninterface Props {\n  review: GoogleReview\n  extra: GoogleReviewsExtra\n  cardSettings: CardSettings\n  reviewSettings: Review.ReviewSettings\n  starsSettings: Stars.StarsSettings\n  dateSettings: Date.DateSettings\n  nameSettings: Name.NameSettings\n  avatarSettings: Avatar.AvatarSettings\n  separatorSettings: Separator.SeparatorSettings\n  showGoogleLogo?: boolean\n  variant?: CardVariant\n}\n\nexport interface CardSettings {\n  link: boolean\n  background: string\n  borderColor: string\n  borderSize: number\n  radius: number\n\n  gap: number\n  padding: number\n}\n\ninterface PropertyControlsOptions {\n  disabledVisibleGoogleLogoControl: boolean\n}\n\nexport const cardPropertyControls: ObjectPropertyControlsWithOptions<\n  CardSettings,\n  PropertyControlsOptions\n> = (options) => ({\n  link: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n  },\n  background: {\n    type: ControlType.Color,\n    defaultValue: '#FFFFFF',\n  },\n  borderColor: {\n    type: ControlType.Color,\n    defaultValue: '#E5E5E5',\n  },\n  borderSize: {\n    type: ControlType.Number,\n    defaultValue: 1,\n    min: 0,\n    max: 10,\n    step: 1,\n    displayStepper: true,\n  },\n  radius: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 50,\n    step: 1,\n    displayStepper: true,\n  },\n  gap: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  padding: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  showGoogleLogo: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n    hidden: () => options?.disabledVisibleGoogleLogoControl ?? false,\n  },\n})\n\nexport const Component: React.FC<Props> = (props) => {\n  const placeId =\n    props.extra.location?.placeId || props.review.location?.placeId\n  const variant = props.variant ?? 'simple'\n\n  return (\n    <Container {...props.cardSettings}>\n      {placeId && props.cardSettings.link && <CardLink placeId={placeId} />}\n\n      {props.starsSettings.visible && (\n        <Stars.Component\n          value={props.review.rating.number}\n          settings={props.starsSettings}\n        />\n      )}\n      <Review.Component\n        value={props.review.comment}\n        settings={props.reviewSettings}\n        center={false}\n      />\n\n      <Footer>\n        {variant === 'simple' && (\n          <Separator.Component settings={props.separatorSettings} />\n        )}\n\n        <BottomSection>\n          {variant === 'simple' && (\n            <AuthorInfo>\n              <Avatar.Component\n                src={props.review.author.photoUrl}\n                settings={props.avatarSettings}\n              />\n\n              <Info>\n                <Name.Component\n                  value={props.review.author.name}\n                  settings={props.nameSettings}\n                />\n\n                <Date.Component\n                  value={props.review.createdAt}\n                  settings={props.dateSettings}\n                />\n              </Info>\n            </AuthorInfo>\n          )}\n\n          {props.showGoogleLogo && (\n            <GoogleLogo>\n              <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <path\n                  d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n                  fill=\"#4285F4\"\n                />\n                <path\n                  d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n                  fill=\"#34A853\"\n                />\n                <path\n                  d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n                  fill=\"#FBBC05\"\n                />\n                <path\n                  d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n                  fill=\"#EA4335\"\n                />\n              </svg>\n            </GoogleLogo>\n          )}\n        </BottomSection>\n      </Footer>\n    </Container>\n  )\n}\n\nconst Container = styled.div<CardSettings>`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  row-gap: ${(p) => p.gap}px;\n  border-radius: ${(p) => p.radius}px;\n  border: ${(p) => p.borderSize}px solid ${(p) => p.borderColor};\n  background: ${(p) => p.background};\n  padding: ${(p) => p.padding}px;\n`\n\nconst Info = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  row-gap: 8px;\n`\n\nconst BottomSection = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n`\n\nconst AuthorInfo = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 12px;\n`\n\nconst GoogleLogo = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  background: white;\n  border: 1px solid #e5e5e5;\n`\n\nconst Footer = styled.div`\n  margin-top: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 24px;\n`\n"]} */")), N = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm84"
} : {
target: "e6u6mm84",
label: "Info"
})(process.env.NODE_ENV === "production" ? {
name: "1hr97ur",
styles: "display:flex;flex-direction:column;align-items:flex-start;row-gap:8px"
} : {
name: "1hr97ur",
styles: "display:flex;flex-direction:column;align-items:flex-start;row-gap:8px",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx"],"names":[],"mappings":"AA4LuB","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { GoogleReview, GoogleReviewsExtra } from '@feedspring/common/src/types'\n\nimport { CardLink } from '../CardLink'\nimport * as Stars from '../Stars'\nimport * as Avatar from '../Avatar'\nimport * as Date from '../Date'\nimport * as Name from '../Name'\nimport * as Review from '../Review'\nimport * as Separator from '../Separator'\nimport {\n  ControlType,\n  ObjectPropertyControlsWithOptions,\n} from '@feedspring/framer-helper'\n\nexport type CardVariant = 'basic' | 'simple'\n\ninterface Props {\n  review: GoogleReview\n  extra: GoogleReviewsExtra\n  cardSettings: CardSettings\n  reviewSettings: Review.ReviewSettings\n  starsSettings: Stars.StarsSettings\n  dateSettings: Date.DateSettings\n  nameSettings: Name.NameSettings\n  avatarSettings: Avatar.AvatarSettings\n  separatorSettings: Separator.SeparatorSettings\n  showGoogleLogo?: boolean\n  variant?: CardVariant\n}\n\nexport interface CardSettings {\n  link: boolean\n  background: string\n  borderColor: string\n  borderSize: number\n  radius: number\n\n  gap: number\n  padding: number\n}\n\ninterface PropertyControlsOptions {\n  disabledVisibleGoogleLogoControl: boolean\n}\n\nexport const cardPropertyControls: ObjectPropertyControlsWithOptions<\n  CardSettings,\n  PropertyControlsOptions\n> = (options) => ({\n  link: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n  },\n  background: {\n    type: ControlType.Color,\n    defaultValue: '#FFFFFF',\n  },\n  borderColor: {\n    type: ControlType.Color,\n    defaultValue: '#E5E5E5',\n  },\n  borderSize: {\n    type: ControlType.Number,\n    defaultValue: 1,\n    min: 0,\n    max: 10,\n    step: 1,\n    displayStepper: true,\n  },\n  radius: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 50,\n    step: 1,\n    displayStepper: true,\n  },\n  gap: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  padding: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  showGoogleLogo: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n    hidden: () => options?.disabledVisibleGoogleLogoControl ?? false,\n  },\n})\n\nexport const Component: React.FC<Props> = (props) => {\n  const placeId =\n    props.extra.location?.placeId || props.review.location?.placeId\n  const variant = props.variant ?? 'simple'\n\n  return (\n    <Container {...props.cardSettings}>\n      {placeId && props.cardSettings.link && <CardLink placeId={placeId} />}\n\n      {props.starsSettings.visible && (\n        <Stars.Component\n          value={props.review.rating.number}\n          settings={props.starsSettings}\n        />\n      )}\n      <Review.Component\n        value={props.review.comment}\n        settings={props.reviewSettings}\n        center={false}\n      />\n\n      <Footer>\n        {variant === 'simple' && (\n          <Separator.Component settings={props.separatorSettings} />\n        )}\n\n        <BottomSection>\n          {variant === 'simple' && (\n            <AuthorInfo>\n              <Avatar.Component\n                src={props.review.author.photoUrl}\n                settings={props.avatarSettings}\n              />\n\n              <Info>\n                <Name.Component\n                  value={props.review.author.name}\n                  settings={props.nameSettings}\n                />\n\n                <Date.Component\n                  value={props.review.createdAt}\n                  settings={props.dateSettings}\n                />\n              </Info>\n            </AuthorInfo>\n          )}\n\n          {props.showGoogleLogo && (\n            <GoogleLogo>\n              <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <path\n                  d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n                  fill=\"#4285F4\"\n                />\n                <path\n                  d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n                  fill=\"#34A853\"\n                />\n                <path\n                  d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n                  fill=\"#FBBC05\"\n                />\n                <path\n                  d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n                  fill=\"#EA4335\"\n                />\n              </svg>\n            </GoogleLogo>\n          )}\n        </BottomSection>\n      </Footer>\n    </Container>\n  )\n}\n\nconst Container = styled.div<CardSettings>`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  row-gap: ${(p) => p.gap}px;\n  border-radius: ${(p) => p.radius}px;\n  border: ${(p) => p.borderSize}px solid ${(p) => p.borderColor};\n  background: ${(p) => p.background};\n  padding: ${(p) => p.padding}px;\n`\n\nconst Info = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  row-gap: 8px;\n`\n\nconst BottomSection = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n`\n\nconst AuthorInfo = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 12px;\n`\n\nconst GoogleLogo = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  background: white;\n  border: 1px solid #e5e5e5;\n`\n\nconst Footer = styled.div`\n  margin-top: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 24px;\n`\n"]} */",
toString: b
}), V = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm83"
} : {
target: "e6u6mm83",
label: "BottomSection"
})(process.env.NODE_ENV === "production" ? {
name: "1ks9uvr",
styles: "display:flex;justify-content:space-between;align-items:center;width:100%"
} : {
name: "1ks9uvr",
styles: "display:flex;justify-content:space-between;align-items:center;width:100%",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx"],"names":[],"mappings":"AAmMgC","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { GoogleReview, GoogleReviewsExtra } from '@feedspring/common/src/types'\n\nimport { CardLink } from '../CardLink'\nimport * as Stars from '../Stars'\nimport * as Avatar from '../Avatar'\nimport * as Date from '../Date'\nimport * as Name from '../Name'\nimport * as Review from '../Review'\nimport * as Separator from '../Separator'\nimport {\n  ControlType,\n  ObjectPropertyControlsWithOptions,\n} from '@feedspring/framer-helper'\n\nexport type CardVariant = 'basic' | 'simple'\n\ninterface Props {\n  review: GoogleReview\n  extra: GoogleReviewsExtra\n  cardSettings: CardSettings\n  reviewSettings: Review.ReviewSettings\n  starsSettings: Stars.StarsSettings\n  dateSettings: Date.DateSettings\n  nameSettings: Name.NameSettings\n  avatarSettings: Avatar.AvatarSettings\n  separatorSettings: Separator.SeparatorSettings\n  showGoogleLogo?: boolean\n  variant?: CardVariant\n}\n\nexport interface CardSettings {\n  link: boolean\n  background: string\n  borderColor: string\n  borderSize: number\n  radius: number\n\n  gap: number\n  padding: number\n}\n\ninterface PropertyControlsOptions {\n  disabledVisibleGoogleLogoControl: boolean\n}\n\nexport const cardPropertyControls: ObjectPropertyControlsWithOptions<\n  CardSettings,\n  PropertyControlsOptions\n> = (options) => ({\n  link: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n  },\n  background: {\n    type: ControlType.Color,\n    defaultValue: '#FFFFFF',\n  },\n  borderColor: {\n    type: ControlType.Color,\n    defaultValue: '#E5E5E5',\n  },\n  borderSize: {\n    type: ControlType.Number,\n    defaultValue: 1,\n    min: 0,\n    max: 10,\n    step: 1,\n    displayStepper: true,\n  },\n  radius: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 50,\n    step: 1,\n    displayStepper: true,\n  },\n  gap: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  padding: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  showGoogleLogo: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n    hidden: () => options?.disabledVisibleGoogleLogoControl ?? false,\n  },\n})\n\nexport const Component: React.FC<Props> = (props) => {\n  const placeId =\n    props.extra.location?.placeId || props.review.location?.placeId\n  const variant = props.variant ?? 'simple'\n\n  return (\n    <Container {...props.cardSettings}>\n      {placeId && props.cardSettings.link && <CardLink placeId={placeId} />}\n\n      {props.starsSettings.visible && (\n        <Stars.Component\n          value={props.review.rating.number}\n          settings={props.starsSettings}\n        />\n      )}\n      <Review.Component\n        value={props.review.comment}\n        settings={props.reviewSettings}\n        center={false}\n      />\n\n      <Footer>\n        {variant === 'simple' && (\n          <Separator.Component settings={props.separatorSettings} />\n        )}\n\n        <BottomSection>\n          {variant === 'simple' && (\n            <AuthorInfo>\n              <Avatar.Component\n                src={props.review.author.photoUrl}\n                settings={props.avatarSettings}\n              />\n\n              <Info>\n                <Name.Component\n                  value={props.review.author.name}\n                  settings={props.nameSettings}\n                />\n\n                <Date.Component\n                  value={props.review.createdAt}\n                  settings={props.dateSettings}\n                />\n              </Info>\n            </AuthorInfo>\n          )}\n\n          {props.showGoogleLogo && (\n            <GoogleLogo>\n              <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <path\n                  d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n                  fill=\"#4285F4\"\n                />\n                <path\n                  d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n                  fill=\"#34A853\"\n                />\n                <path\n                  d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n                  fill=\"#FBBC05\"\n                />\n                <path\n                  d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n                  fill=\"#EA4335\"\n                />\n              </svg>\n            </GoogleLogo>\n          )}\n        </BottomSection>\n      </Footer>\n    </Container>\n  )\n}\n\nconst Container = styled.div<CardSettings>`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  row-gap: ${(p) => p.gap}px;\n  border-radius: ${(p) => p.radius}px;\n  border: ${(p) => p.borderSize}px solid ${(p) => p.borderColor};\n  background: ${(p) => p.background};\n  padding: ${(p) => p.padding}px;\n`\n\nconst Info = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  row-gap: 8px;\n`\n\nconst BottomSection = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n`\n\nconst AuthorInfo = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 12px;\n`\n\nconst GoogleLogo = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  background: white;\n  border: 1px solid #e5e5e5;\n`\n\nconst Footer = styled.div`\n  margin-top: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 24px;\n`\n"]} */",
toString: b
}), R = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm82"
} : {
target: "e6u6mm82",
label: "AuthorInfo"
})(process.env.NODE_ENV === "production" ? {
name: "uh5xjc",
styles: "display:flex;align-items:center;gap:12px"
} : {
name: "uh5xjc",
styles: "display:flex;align-items:center;gap:12px",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx"],"names":[],"mappings":"AA0M6B","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { GoogleReview, GoogleReviewsExtra } from '@feedspring/common/src/types'\n\nimport { CardLink } from '../CardLink'\nimport * as Stars from '../Stars'\nimport * as Avatar from '../Avatar'\nimport * as Date from '../Date'\nimport * as Name from '../Name'\nimport * as Review from '../Review'\nimport * as Separator from '../Separator'\nimport {\n  ControlType,\n  ObjectPropertyControlsWithOptions,\n} from '@feedspring/framer-helper'\n\nexport type CardVariant = 'basic' | 'simple'\n\ninterface Props {\n  review: GoogleReview\n  extra: GoogleReviewsExtra\n  cardSettings: CardSettings\n  reviewSettings: Review.ReviewSettings\n  starsSettings: Stars.StarsSettings\n  dateSettings: Date.DateSettings\n  nameSettings: Name.NameSettings\n  avatarSettings: Avatar.AvatarSettings\n  separatorSettings: Separator.SeparatorSettings\n  showGoogleLogo?: boolean\n  variant?: CardVariant\n}\n\nexport interface CardSettings {\n  link: boolean\n  background: string\n  borderColor: string\n  borderSize: number\n  radius: number\n\n  gap: number\n  padding: number\n}\n\ninterface PropertyControlsOptions {\n  disabledVisibleGoogleLogoControl: boolean\n}\n\nexport const cardPropertyControls: ObjectPropertyControlsWithOptions<\n  CardSettings,\n  PropertyControlsOptions\n> = (options) => ({\n  link: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n  },\n  background: {\n    type: ControlType.Color,\n    defaultValue: '#FFFFFF',\n  },\n  borderColor: {\n    type: ControlType.Color,\n    defaultValue: '#E5E5E5',\n  },\n  borderSize: {\n    type: ControlType.Number,\n    defaultValue: 1,\n    min: 0,\n    max: 10,\n    step: 1,\n    displayStepper: true,\n  },\n  radius: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 50,\n    step: 1,\n    displayStepper: true,\n  },\n  gap: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  padding: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  showGoogleLogo: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n    hidden: () => options?.disabledVisibleGoogleLogoControl ?? false,\n  },\n})\n\nexport const Component: React.FC<Props> = (props) => {\n  const placeId =\n    props.extra.location?.placeId || props.review.location?.placeId\n  const variant = props.variant ?? 'simple'\n\n  return (\n    <Container {...props.cardSettings}>\n      {placeId && props.cardSettings.link && <CardLink placeId={placeId} />}\n\n      {props.starsSettings.visible && (\n        <Stars.Component\n          value={props.review.rating.number}\n          settings={props.starsSettings}\n        />\n      )}\n      <Review.Component\n        value={props.review.comment}\n        settings={props.reviewSettings}\n        center={false}\n      />\n\n      <Footer>\n        {variant === 'simple' && (\n          <Separator.Component settings={props.separatorSettings} />\n        )}\n\n        <BottomSection>\n          {variant === 'simple' && (\n            <AuthorInfo>\n              <Avatar.Component\n                src={props.review.author.photoUrl}\n                settings={props.avatarSettings}\n              />\n\n              <Info>\n                <Name.Component\n                  value={props.review.author.name}\n                  settings={props.nameSettings}\n                />\n\n                <Date.Component\n                  value={props.review.createdAt}\n                  settings={props.dateSettings}\n                />\n              </Info>\n            </AuthorInfo>\n          )}\n\n          {props.showGoogleLogo && (\n            <GoogleLogo>\n              <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <path\n                  d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n                  fill=\"#4285F4\"\n                />\n                <path\n                  d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n                  fill=\"#34A853\"\n                />\n                <path\n                  d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n                  fill=\"#FBBC05\"\n                />\n                <path\n                  d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n                  fill=\"#EA4335\"\n                />\n              </svg>\n            </GoogleLogo>\n          )}\n        </BottomSection>\n      </Footer>\n    </Container>\n  )\n}\n\nconst Container = styled.div<CardSettings>`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  row-gap: ${(p) => p.gap}px;\n  border-radius: ${(p) => p.radius}px;\n  border: ${(p) => p.borderSize}px solid ${(p) => p.borderColor};\n  background: ${(p) => p.background};\n  padding: ${(p) => p.padding}px;\n`\n\nconst Info = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  row-gap: 8px;\n`\n\nconst BottomSection = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n`\n\nconst AuthorInfo = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 12px;\n`\n\nconst GoogleLogo = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  background: white;\n  border: 1px solid #e5e5e5;\n`\n\nconst Footer = styled.div`\n  margin-top: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 24px;\n`\n"]} */",
toString: b
}), n = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm81"
} : {
target: "e6u6mm81",
label: "GoogleLogo"
})(process.env.NODE_ENV === "production" ? {
name: "4rj1c7",
styles: "display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:white;border:1px solid #e5e5e5"
} : {
name: "4rj1c7",
styles: "display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:white;border:1px solid #e5e5e5",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx"],"names":[],"mappings":"AAgN6B","file":"/home/runner/work/feedspring-scripts/feedspring-scripts/apps/framer-google-reviews/src/lib/components/basic-card/Card.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { GoogleReview, GoogleReviewsExtra } from '@feedspring/common/src/types'\n\nimport { CardLink } from '../CardLink'\nimport * as Stars from '../Stars'\nimport * as Avatar from '../Avatar'\nimport * as Date from '../Date'\nimport * as Name from '../Name'\nimport * as Review from '../Review'\nimport * as Separator from '../Separator'\nimport {\n  ControlType,\n  ObjectPropertyControlsWithOptions,\n} from '@feedspring/framer-helper'\n\nexport type CardVariant = 'basic' | 'simple'\n\ninterface Props {\n  review: GoogleReview\n  extra: GoogleReviewsExtra\n  cardSettings: CardSettings\n  reviewSettings: Review.ReviewSettings\n  starsSettings: Stars.StarsSettings\n  dateSettings: Date.DateSettings\n  nameSettings: Name.NameSettings\n  avatarSettings: Avatar.AvatarSettings\n  separatorSettings: Separator.SeparatorSettings\n  showGoogleLogo?: boolean\n  variant?: CardVariant\n}\n\nexport interface CardSettings {\n  link: boolean\n  background: string\n  borderColor: string\n  borderSize: number\n  radius: number\n\n  gap: number\n  padding: number\n}\n\ninterface PropertyControlsOptions {\n  disabledVisibleGoogleLogoControl: boolean\n}\n\nexport const cardPropertyControls: ObjectPropertyControlsWithOptions<\n  CardSettings,\n  PropertyControlsOptions\n> = (options) => ({\n  link: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n  },\n  background: {\n    type: ControlType.Color,\n    defaultValue: '#FFFFFF',\n  },\n  borderColor: {\n    type: ControlType.Color,\n    defaultValue: '#E5E5E5',\n  },\n  borderSize: {\n    type: ControlType.Number,\n    defaultValue: 1,\n    min: 0,\n    max: 10,\n    step: 1,\n    displayStepper: true,\n  },\n  radius: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 50,\n    step: 1,\n    displayStepper: true,\n  },\n  gap: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  padding: {\n    type: ControlType.Number,\n    defaultValue: 24,\n    min: 0,\n    max: 100,\n    step: 1,\n    displayStepper: true,\n  },\n  showGoogleLogo: {\n    type: ControlType.Boolean,\n    defaultValue: true,\n    hidden: () => options?.disabledVisibleGoogleLogoControl ?? false,\n  },\n})\n\nexport const Component: React.FC<Props> = (props) => {\n  const placeId =\n    props.extra.location?.placeId || props.review.location?.placeId\n  const variant = props.variant ?? 'simple'\n\n  return (\n    <Container {...props.cardSettings}>\n      {placeId && props.cardSettings.link && <CardLink placeId={placeId} />}\n\n      {props.starsSettings.visible && (\n        <Stars.Component\n          value={props.review.rating.number}\n          settings={props.starsSettings}\n        />\n      )}\n      <Review.Component\n        value={props.review.comment}\n        settings={props.reviewSettings}\n        center={false}\n      />\n\n      <Footer>\n        {variant === 'simple' && (\n          <Separator.Component settings={props.separatorSettings} />\n        )}\n\n        <BottomSection>\n          {variant === 'simple' && (\n            <AuthorInfo>\n              <Avatar.Component\n                src={props.review.author.photoUrl}\n                settings={props.avatarSettings}\n              />\n\n              <Info>\n                <Name.Component\n                  value={props.review.author.name}\n                  settings={props.nameSettings}\n                />\n\n                <Date.Component\n                  value={props.review.createdAt}\n                  settings={props.dateSettings}\n                />\n              </Info>\n            </AuthorInfo>\n          )}\n\n          {props.showGoogleLogo && (\n            <GoogleLogo>\n              <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n                <path\n                  d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n                  fill=\"#4285F4\"\n                />\n                <path\n                  d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n                  fill=\"#34A853\"\n                />\n                <path\n                  d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n                  fill=\"#FBBC05\"\n                />\n                <path\n                  d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n                  fill=\"#EA4335\"\n                />\n              </svg>\n            </GoogleLogo>\n          )}\n        </BottomSection>\n      </Footer>\n    </Container>\n  )\n}\n\nconst Container = styled.div<CardSettings>`\n  display: flex;\n  position: relative;\n  flex-direction: column;\n  row-gap: ${(p) => p.gap}px;\n  border-radius: ${(p) => p.radius}px;\n  border: ${(p) => p.borderSize}px solid ${(p) => p.borderColor};\n  background: ${(p) => p.background};\n  padding: ${(p) => p.padding}px;\n`\n\nconst Info = styled.div`\n  display: flex;\n  flex-direction: column;\n  align-items: flex-start;\n  row-gap: 8px;\n`\n\nconst BottomSection = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n`\n\nconst AuthorInfo = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 12px;\n`\n\nconst GoogleLogo = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  background: white;\n  border: 1px solid #e5e5e5;\n`\n\nconst Footer = styled.div`\n  margin-top: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 24px;\n`\n"]} */",
toString: b
}), Y = /* @__PURE__ */ c("div", process.env.NODE_ENV === "production" ? {
target: "e6u6mm80"
} : {
target: "e6u6mm80",
label: "Footer"
})(process.env.NODE_ENV === "production" ? {
name: "1raljbx",
styles: "margin-top:auto;display:flex;flex-direction:column;gap:24px"
} : {
name: "1raljbx",
styles: "margin-top:auto;display:flex;flex-direction:column;gap:24px",
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL2ZlZWRzcHJpbmctc2NyaXB0cy9mZWVkc3ByaW5nLXNjcmlwdHMvYXBwcy9mcmFtZXItZ29vZ2xlLXJldmlld3Mvc3JjL2xpYi9jb21wb25lbnRzL2Jhc2ljLWNhcmQvQ2FyZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMk55QiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay9mZWVkc3ByaW5nLXNjcmlwdHMvZmVlZHNwcmluZy1zY3JpcHRzL2FwcHMvZnJhbWVyLWdvb2dsZS1yZXZpZXdzL3NyYy9saWIvY29tcG9uZW50cy9iYXNpYy1jYXJkL0NhcmQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBHb29nbGVSZXZpZXcsIEdvb2dsZVJldmlld3NFeHRyYSB9IGZyb20gJ0BmZWVkc3ByaW5nL2NvbW1vbi9zcmMvdHlwZXMnXG5cbmltcG9ydCB7IENhcmRMaW5rIH0gZnJvbSAnLi4vQ2FyZExpbmsnXG5pbXBvcnQgKiBhcyBTdGFycyBmcm9tICcuLi9TdGFycydcbmltcG9ydCAqIGFzIEF2YXRhciBmcm9tICcuLi9BdmF0YXInXG5pbXBvcnQgKiBhcyBEYXRlIGZyb20gJy4uL0RhdGUnXG5pbXBvcnQgKiBhcyBOYW1lIGZyb20gJy4uL05hbWUnXG5pbXBvcnQgKiBhcyBSZXZpZXcgZnJvbSAnLi4vUmV2aWV3J1xuaW1wb3J0ICogYXMgU2VwYXJhdG9yIGZyb20gJy4uL1NlcGFyYXRvcidcbmltcG9ydCB7XG4gIENvbnRyb2xUeXBlLFxuICBPYmplY3RQcm9wZXJ0eUNvbnRyb2xzV2l0aE9wdGlvbnMsXG59IGZyb20gJ0BmZWVkc3ByaW5nL2ZyYW1lci1oZWxwZXInXG5cbmV4cG9ydCB0eXBlIENhcmRWYXJpYW50ID0gJ2Jhc2ljJyB8ICdzaW1wbGUnXG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIHJldmlldzogR29vZ2xlUmV2aWV3XG4gIGV4dHJhOiBHb29nbGVSZXZpZXdzRXh0cmFcbiAgY2FyZFNldHRpbmdzOiBDYXJkU2V0dGluZ3NcbiAgcmV2aWV3U2V0dGluZ3M6IFJldmlldy5SZXZpZXdTZXR0aW5nc1xuICBzdGFyc1NldHRpbmdzOiBTdGFycy5TdGFyc1NldHRpbmdzXG4gIGRhdGVTZXR0aW5nczogRGF0ZS5EYXRlU2V0dGluZ3NcbiAgbmFtZVNldHRpbmdzOiBOYW1lLk5hbWVTZXR0aW5nc1xuICBhdmF0YXJTZXR0aW5nczogQXZhdGFyLkF2YXRhclNldHRpbmdzXG4gIHNlcGFyYXRvclNldHRpbmdzOiBTZXBhcmF0b3IuU2VwYXJhdG9yU2V0dGluZ3NcbiAgc2hvd0dvb2dsZUxvZ28/OiBib29sZWFuXG4gIHZhcmlhbnQ/OiBDYXJkVmFyaWFudFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENhcmRTZXR0aW5ncyB7XG4gIGxpbms6IGJvb2xlYW5cbiAgYmFja2dyb3VuZDogc3RyaW5nXG4gIGJvcmRlckNvbG9yOiBzdHJpbmdcbiAgYm9yZGVyU2l6ZTogbnVtYmVyXG4gIHJhZGl1czogbnVtYmVyXG5cbiAgZ2FwOiBudW1iZXJcbiAgcGFkZGluZzogbnVtYmVyXG59