{"version":3,"file":"index.d4aa8d5a.js","sources":["../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/styled.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/views/desktop/index.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/hook/useReviews.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/views/mobile/styled.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/views/mobile/components/review-item/index.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/views/mobile/components/modal-content/index.mjs","../../../../../../../node_modules/@babylon/ui-kit-common/esm/components/others/reviews/views/mobile/index.mjs"],"sourcesContent":["import { switchColor } from '@babylon/ui-kit-base/components/others/rating/styled';\nimport { FontMixin } from '@babylon/ui-kit-styles/common/mixins/helpers.styled';\nimport { Margin } from '@babylon/ui-kit-styles/common/mixins/logical.styled';\nimport styled from 'styled-components';\n\nconst ReviewsContainer = styled.div``;\nconst ReviewsScoreHeaderValueContent = styled.div`\n\t${Margin({ left: \"20px\" })}\n`;\nconst ReviewsScoreHeaderValueTitle = styled.p`\n\t${Margin({ bottom: \"8px\" })}\n\t${FontMixin({ weight: \"medium\", size: \"large\" })}\n\tcolor: ${({ theme, $value }) => switchColor($value, theme)};\n`;\nconst ReviewsScoreHeaderValueText = styled.p`\n\t${FontMixin({ size: \"medium\", weight: \"light\" })}\n\t${Margin({ all: \"0px\" })}\n\tcolor: ${({ theme }) => theme.colors.grays.dark};\n`;\nconst ReviewsList = styled.div``;\nconst ReviewsListItemAvatar = styled.div`\n\tposition: relative;\n`;\n\nexport { ReviewsContainer, ReviewsList, ReviewsListItemAvatar, ReviewsScoreHeaderValueContent, ReviewsScoreHeaderValueText, ReviewsScoreHeaderValueTitle };\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport { JsonLd } from '@babylon/ui-kit-base/components/others/json-ld';\nimport Title from '@babylon/ui-kit-base/components/text/title';\nimport ReviewsBase from '@babylon/ui-kit-structures/components/others/reviews-base';\nimport { ReviewsContainer } from '../../styled.mjs';\n\nconst DesktopReviews = (props) => {\n const { title, subtitle, pagination = {}, items, score } = props;\n return /* @__PURE__ */ jsxs(ReviewsContainer, { \"data-testid\": \"Reviews\", children: [\n /* @__PURE__ */ jsx(Title, { title, subTitle: subtitle, \"data-testid\": \"title\" }),\n /* @__PURE__ */ jsx(\n ReviewsBase,\n {\n score,\n config: props.config,\n ldjson: props.ldjson,\n pagination,\n items\n }\n ),\n props.ldjson && /* @__PURE__ */ jsx(JsonLd, { structuredData: props.ldjson })\n ] });\n};\n\nexport { DesktopReviews as default };\n","import contextBabylon from '@babylon/ui-kit-context';\nimport useIsDesktop from '@babylon/ui-kit-hooks/device/useIsDesktop';\nimport useLoading from '@babylon/ui-kit-searchers/hooks/useLoading';\nimport { getPaginationPage } from '@babylon/ui-kit-structures/components/others/reviews-base/service';\nimport { useContext, useState, useRef, useCallback, useEffect } from 'react';\n\nconst useReviews = (props) => {\n const { size, endpoint, reviews } = props;\n const { ApplicationName, LanguageValue } = useContext(contextBabylon);\n const [results, setResults] = useState(reviews ?? []);\n const [page, setPage] = useState(1);\n const callLock = useRef(false);\n const modalRef = useRef(null);\n const { isLoading, doFetchLoading } = useLoading([callLock], false);\n const isDesktop = useIsDesktop();\n const getData = useCallback(\n async (page2) => {\n const data = await doFetchLoading(\n callLock,\n async () => await getPaginationPage({\n code: endpoint?.code,\n type: endpoint?.type,\n size,\n page: page2,\n ApplicationName,\n LanguageValue,\n reviews: endpoint?.reviews\n })\n );\n if (data) {\n if (isDesktop) {\n setResults(data);\n } else {\n setResults([...results, ...data]);\n }\n }\n },\n [\n ApplicationName,\n LanguageValue,\n doFetchLoading,\n endpoint?.code,\n endpoint?.reviews,\n endpoint?.type,\n isDesktop,\n results,\n size\n ]\n );\n useEffect(() => {\n if (!isDesktop) {\n getData(page).catch(console.error);\n }\n }, []);\n const handleClickPagination = (page2) => getData(page2).catch(console.error);\n const handleScroll = () => {\n const element = modalRef.current;\n if (element && Math.round(element.scrollTop) + element.clientHeight >= element.scrollHeight - 3) {\n setPage(page + 1);\n getData(page + 1).catch(console.error);\n }\n };\n return { isLoading, results, handleClickPagination, modalRef, handleScroll, setPage };\n};\n\nexport { useReviews as default };\n","import Icon from '@babylon/ui-kit-base/components/icons/icon';\nimport { RatingHorizontalText, RatingHorizontalValue, switchColor } from '@babylon/ui-kit-base/components/others/rating/styled';\nimport { FlexMixin, FontMixin } from '@babylon/ui-kit-styles/common/mixins/helpers.styled';\nimport { BorderRadius, Margin, Size } from '@babylon/ui-kit-styles/common/mixins/logical.styled';\nimport styled from 'styled-components';\n\nconst ReviewsWrapper = styled.div`\n\tbackground-color: ${({ theme }) => theme.colors.white.base};\n`;\nconst ReviewsScoreWrapperMobile = styled.div`\n\t${BorderRadius({ topLeft: \"4px\", topRight: \"4px\" })}\n\t${FlexMixin({ align: \"center\", wrap: true, justify: \"space-between\" })}\n\tbackground-color: ${({ theme }) => theme.bodyBgColor};\n\tborder-top: 1px solid ${({ theme }) => theme.colors.grays.light};\n\tborder-bottom: 1px solid ${({ theme }) => theme.colors.grays.light};\n`;\nconst ReviewsScoreHeaderMobile = styled.div`\n\t${FlexMixin({ align: \"center\", justify: \"center\" })}\n\tmargin-bottom: 0px;\n\tborder: 0px;\n\twidth: 100%;\n\n\t& svg {\n\t\twidth: 83px;\n\t}\n`;\nconst ReviewsScoreBodyMobile = styled.div`\n\tmargin: 0 16px;\n\tpadding: 0;\n\tborder-top: 1px solid ${({ theme }) => theme.colors.grays.light};\n`;\nconst ReviewsScoreBodyListMobile = styled.ul`\n\t${FlexMixin({ align: \"center\", wrap: true, justify: \"flex-start\" })}\n\t${Margin({ all: \"0px\", bottom: \"18px\", top: \"10px\" })}\n\n\t& li {\n\t\tmax-width: none;\n\t}\n\n\t${RatingHorizontalText}:first-child, ${RatingHorizontalValue} {\n\t\tflex-basis: calc(45% - 8px);\n\t\tmax-width: calc(45% - 8px);\n\t\t${FontMixin({ size: \"medium\" })}\n\t}\n\t${RatingHorizontalText}:last-child {\n\t\tflex-basis: auto;\n\t}\n`;\nconst ReviewsListItem = styled.article`\n\t${FlexMixin({ align: \"center\", justify: \"space-between\", direction: \"column\" })}\n\tpadding: 16px 12px;\n\tbackground-color: ${({ theme }) => theme.colors.white.base};\n\tborder-bottom: 1px solid ${({ theme }) => theme.colors.grays.light};\n`;\nconst ReviewsListItemHeader = styled.div`\n\t${FlexMixin({ align: \"center\", justify: \"space-between\" })}\n\twidth: 100%;\n\tflex-basis: calc(20% - 8px);\n`;\nconst ReviewsHeaderContent = styled.div`\n\t${FontMixin({ size: \"medium\", height: \"base\" })}\n`;\nconst ReviewsListItemAvatarValue = styled.div`\n\tcolor: ${({ theme }) => theme.colors.white.base};\n\t${FontMixin({ size: \"base\", weight: \"bold\" })}\n\t${Margin({ all: \"0\" })}\n\t${Size({ height: \"32px\", width: \"32px\" })}\n\t${BorderRadius({ all: \"50%\" })}\n\t${FlexMixin({ align: \"center\", justify: \"center\" })}\n\tbackground-color: ${({ theme, $value }) => switchColor($value, theme)};\n`;\nconst ReviewsListItemContentDescription = styled.p`\n\t${FlexMixin({ align: \"center\", justify: \"flex-start\" })}\n\t${Margin({ all: \"0px\" })}\n\tcolor: ${({ theme }) => theme.colors.grays.darker};\n\t${FontMixin({ size: \"medium\", weight: \"light\" })}\n`;\nconst ReviewsListItemContentUser = styled(ReviewsListItemContentDescription)`\n\t${FontMixin({ size: \"base\", weight: \"medium\", height: \"base\" })}\n`;\nconst ReviewsListItemHeaderContentDescription = styled(ReviewsListItemContentDescription)`\n\t${FontMixin({ size: \"small\" })}\n\tcolor: ${({ theme }) => theme.colors.grays.base};\n`;\nconst ReviewsListItemBody = styled.div`\n\tflex-basis: calc(80% - 8px);\n\twidth: 100%;\n\t${Margin({ top: \"8px\" })}\n`;\nconst ReviewsItemListBodyContent = styled.div`\n\t${FontMixin({ size: \"medium\", height: \"base\" })}\n`;\nconst ReviewsItemText = styled(ReviewsListItemContentDescription)`\n\t&:not(:last-child) {\n\t\t${Margin({ bottom: \"12px\" })}\n\t}\n`;\nconst ReviewsItemTextIcon = styled.span`\n\t${Icon} {\n\t\tcolor: ${({ theme, $state }) => $state === \"negative\" ? theme.colors.grays.base : theme.colors.primary.lighter};\n\t\t${FontMixin({ size: \"large\" })}\n\t\t${Margin({ right: \"16px\" })}\n\t}\n`;\nconst ReviewsItemFooter = styled.div`\n\t${FlexMixin({ justify: \"center\" })}\n\twidth: 100%;\n\t${Margin({ top: \"16px\" })}\n`;\nconst Loader = styled.div`\n\tpadding: 16px;\n\n\t&::before {\n\t\tanimation: spinner 1s infinite linear;\n\t\tborder: 2px solid ${({ theme }) => theme.colors.grays.base};\n\t\tborder-left-color: rgba(0, 0, 0, 0);\n\t\t${BorderRadius({ all: \"50%\" })}\n\t\tcontent: \"\";\n\t\tdisplay: block;\n\t\theight: 50px;\n\t\twidth: 50px;\n\t\tz-index: 10;\n\t\tmargin: 0 auto;\n\t}\n`;\n\nexport { Loader, ReviewsHeaderContent, ReviewsItemFooter, ReviewsItemListBodyContent, ReviewsItemText, ReviewsItemTextIcon, ReviewsListItem, ReviewsListItemAvatarValue, ReviewsListItemBody, ReviewsListItemContentUser, ReviewsListItemHeader, ReviewsListItemHeaderContentDescription, ReviewsScoreBodyListMobile, ReviewsScoreBodyMobile, ReviewsScoreHeaderMobile, ReviewsScoreWrapperMobile, ReviewsWrapper };\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport Icon from '@babylon/ui-kit-base/components/icons/icon';\nimport { ReviewsListItemAvatar } from '../../../../styled.mjs';\nimport { ReviewsListItem, ReviewsListItemHeader, ReviewsHeaderContent, ReviewsListItemContentUser, ReviewsListItemHeaderContentDescription, ReviewsListItemAvatarValue, ReviewsListItemBody, ReviewsItemListBodyContent, ReviewsItemText, ReviewsItemTextIcon } from '../../styled.mjs';\n\nconst ReviewItem = (props) => {\n const { date, negative, positive, user, value } = props;\n return /* @__PURE__ */ jsxs(ReviewsListItem, { \"data-testid\": \"reviewItem\", children: [\n /* @__PURE__ */ jsxs(ReviewsListItemHeader, { children: [\n /* @__PURE__ */ jsxs(ReviewsHeaderContent, { children: [\n /* @__PURE__ */ jsx(ReviewsListItemContentUser, { children: user }),\n /* @__PURE__ */ jsx(ReviewsListItemHeaderContentDescription, { children: date })\n ] }),\n /* @__PURE__ */ jsx(ReviewsListItemAvatar, { children: /* @__PURE__ */ jsx(ReviewsListItemAvatarValue, { $value: value ?? 0, children: value }) })\n ] }),\n /* @__PURE__ */ jsx(ReviewsListItemBody, { children: /* @__PURE__ */ jsxs(ReviewsItemListBodyContent, { children: [\n /* @__PURE__ */ jsxs(ReviewsItemText, { children: [\n /* @__PURE__ */ jsx(ReviewsItemTextIcon, { $state: \"positive\", children: /* @__PURE__ */ jsx(Icon, { className: \"nico-thumbs-up\" }) }),\n /* @__PURE__ */ jsx(\"span\", { children: positive })\n ] }),\n /* @__PURE__ */ jsxs(ReviewsItemText, { children: [\n /* @__PURE__ */ jsx(ReviewsItemTextIcon, { $state: \"negative\", children: /* @__PURE__ */ jsx(Icon, { className: \"nico-thumbs-down\" }) }),\n /* @__PURE__ */ jsx(\"span\", { children: negative })\n ] })\n ] }) })\n ] });\n};\n\nexport { ReviewItem as default };\n","import { jsxs, Fragment, jsx } from 'react/jsx-runtime';\nimport { useEffect, createElement } from 'react';\nimport Rating from '@babylon/ui-kit-base/components/others/rating';\nimport InnerMarkdownHTML from '@babylon/ui-kit-base/components/text/inner-markdown-HTML';\nimport { genKey } from '@babylon/ui-kit-helpers/keys';\nimport { ReviewsScoreHeaderValueContent, ReviewsScoreHeaderValueTitle, ReviewsScoreHeaderValueText } from '../../../../styled.mjs';\nimport { Loader, ReviewsScoreWrapperMobile, ReviewsScoreHeaderMobile } from '../../styled.mjs';\nimport ReviewItem from '../review-item/index.mjs';\n\nconst ModalContent = (props) => {\n const { score, results, setPage, isLoading } = props;\n useEffect(() => {\n setPage(1);\n }, [setPage]);\n const renderScore = () => /* @__PURE__ */ jsx(ReviewsScoreWrapperMobile, { children: /* @__PURE__ */ jsxs(ReviewsScoreHeaderMobile, { children: [\n /* @__PURE__ */ jsx(Rating, { variant: \"circular\", value: score?.value }),\n /* @__PURE__ */ jsxs(ReviewsScoreHeaderValueContent, { children: [\n /* @__PURE__ */ jsx(ReviewsScoreHeaderValueTitle, { $value: score?.value, children: score?.title }),\n /* @__PURE__ */ jsx(ReviewsScoreHeaderValueText, { children: /* @__PURE__ */ jsx(InnerMarkdownHTML, { content: score?.description }) })\n ] })\n ] }) });\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n renderScore(),\n results.map((review) => /* @__PURE__ */ createElement(ReviewItem, { ...review, key: genKey(review.user + Math.random()) })),\n isLoading && /* @__PURE__ */ jsx(Loader, {})\n ] });\n};\n\nexport { ModalContent as default };\n","import { jsxs, jsx } from 'react/jsx-runtime';\nimport { Button } from '@babylon/ui-kit-base/components/buttons/button';\nimport { JsonLd } from '@babylon/ui-kit-base/components/others/json-ld';\nimport Title from '@babylon/ui-kit-base/components/text/title';\nimport Modal from '@babylon/ui-kit-structures/components/others/modal';\nimport ReviewsSummary from '@babylon/ui-kit-structures/components/others/reviews-summary';\nimport { useBoolean } from 'usehooks-ts';\nimport useReviews from '../../hook/useReviews.mjs';\nimport { ReviewsContainer, ReviewsList } from '../../styled.mjs';\nimport ModalContent from './components/modal-content/index.mjs';\nimport ReviewItem from './components/review-item/index.mjs';\nimport { ReviewsWrapper, ReviewsItemFooter } from './styled.mjs';\n\nconst MobileReviews = (props) => {\n const { value: isVisible, toggle: toggleVisibility } = useBoolean();\n const { title, subtitle, review, score, config } = props ?? {};\n const { literals, endpoints } = config ?? {};\n const { seeAllOpinions = \"\" } = literals ?? {};\n const { results, handleScroll, modalRef, setPage, isLoading } = useReviews({ endpoint: endpoints, size: 5 });\n const modalProps = {\n score,\n results,\n setPage,\n isLoading\n };\n return /* @__PURE__ */ jsxs(ReviewsContainer, { \"data-testid\": \"Reviews\", children: [\n /* @__PURE__ */ jsx(Title, { title, subTitle: subtitle, \"data-testid\": \"title\", tag: \"h3\" }),\n /* @__PURE__ */ jsxs(ReviewsWrapper, { children: [\n /* @__PURE__ */ jsx(ReviewsSummary, { literals, score }),\n /* @__PURE__ */ jsxs(ReviewsList, { children: [\n review && /* @__PURE__ */ jsx(ReviewItem, { ...review }),\n /* @__PURE__ */ jsxs(ReviewsItemFooter, { children: [\n /* @__PURE__ */ jsx(\n Button,\n {\n \"data-testid\": \"openModal\",\n onClick: toggleVisibility,\n variant: \"negative\",\n p: \"8px 16px\",\n size: \"small\",\n children: seeAllOpinions\n }\n ),\n /* @__PURE__ */ jsx(\n Modal,\n {\n content: /* @__PURE__ */ jsx(ModalContent, { ...modalProps }),\n header: title,\n visible: isVisible,\n hide: toggleVisibility,\n variant: \"fullScreen\",\n contentRef: modalRef,\n onScroll: handleScroll\n }\n )\n ] })\n ] })\n ] }),\n props.ldjson && /* @__PURE__ */ jsx(JsonLd, { structuredData: props.ldjson })\n ] });\n};\n\nexport { MobileReviews as default };\n"],"names":["ReviewsContainer","styled","ReviewsScoreHeaderValueContent","Margin","ReviewsScoreHeaderValueTitle","FontMixin","theme","$value","switchColor","ReviewsScoreHeaderValueText","ReviewsList","ReviewsListItemAvatar","DesktopReviews","props","title","subtitle","pagination","items","score","jsxs","jsx","Title","ReviewsBase","JsonLd","useReviews","size","endpoint","reviews","ApplicationName","LanguageValue","useContext","contextBabylon","results","setResults","useState","page","setPage","callLock","useRef","modalRef","isLoading","doFetchLoading","useLoading","isDesktop","useIsDesktop","getData","useCallback","page2","data","getPaginationPage","useEffect","element","ReviewsWrapper","ReviewsScoreWrapperMobile","BorderRadius","FlexMixin","ReviewsScoreHeaderMobile","RatingHorizontalText","RatingHorizontalValue","ReviewsListItem","ReviewsListItemHeader","ReviewsHeaderContent","ReviewsListItemAvatarValue","Size","ReviewsListItemContentDescription","ReviewsListItemContentUser","ReviewsListItemHeaderContentDescription","ReviewsListItemBody","ReviewsItemListBodyContent","ReviewsItemText","ReviewsItemTextIcon","Icon","$state","ReviewsItemFooter","Loader","ReviewItem","date","negative","positive","user","value","ModalContent","renderScore","Rating","InnerMarkdownHTML","Fragment","review","createElement","genKey","MobileReviews","isVisible","toggleVisibility","useBoolean","config","literals","endpoints","seeAllOpinions","handleScroll","modalProps","ReviewsSummary","Button","Modal"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6]}