{"version":3,"file":"static/js/2aa88f733ffac019c422.bundle.js","mappings":"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","sources":["webpack://@msdyn365-commerce-partners/fabrikam/./lib/ratings-histogram/module-registration.js?bc1d","webpack://@msdyn365-commerce-partners/fabrikam/./src/modules/fabrikam/views/ratings-histogram.view.tsx?6e01","webpack://@msdyn365-commerce-partners/fabrikam/./src/actions/ratings-reviews-state-data-action.ts?26cd","webpack://@msdyn365-commerce-partners/fabrikam/./src/modules/ratings-histogram/component/components.tsx?f324","webpack://@msdyn365-commerce-partners/fabrikam/./src/modules/ratings-histogram/ratings-histogram.tsx?f6bc","webpack://@msdyn365-commerce-partners/fabrikam/./src/modules/ratings-histogram/ratings-histogram.view.tsx?5bff","webpack://@msdyn365-commerce-partners/fabrikam/./src/modules/adventureworks/views/ratings-histogram.view.tsx?bb5b","webpack://@msdyn365-commerce-partners/fabrikam/external var \"React\"?0d3b","webpack://@msdyn365-commerce-partners/fabrikam/external var \"ReactDOM\"?853b"],"sourcesContent":["const binding = { modules: {}, dataActions: {} };\n\n const registerActionId = (actionPath) => {\n if (binding.dataActions[actionPath] &&\n binding.dataActions[actionPath].default &&\n binding.dataActions[actionPath].default.prototype &&\n binding.dataActions[actionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[actionPath].default.prototype.id] = binding.dataActions[actionPath];\n } else {\n Object.keys(binding.dataActions[actionPath] || {}).forEach(exportName => {\n if (binding.dataActions[actionPath][exportName] &&\n binding.dataActions[actionPath][exportName].prototype &&\n binding.dataActions[actionPath][exportName].prototype.Action) {\n binding.dataActions[binding.dataActions[actionPath][exportName].prototype.id] = binding.dataActions[actionPath][exportName];\n }\n })\n }\n };\n\n const registerSanitizedActionPath = (sanitizedActionPath, dataAction) => {\n if (process.env.NODE_ENV === 'development') {\n if (!dataAction.default) {\n throw new Error('Data action path does not have a default export');\n }\n if (!(dataAction.default.prototype.id && binding.dataActions[dataAction.default.prototype.id]) || !binding.dataActions[sanitizedActionPath]) {\n binding.dataActions[sanitizedActionPath] = dataAction;\n }\n } else {\n binding.dataActions[sanitizedActionPath] = dataAction;\n if (!binding.dataActions[sanitizedActionPath].default) {\n throw new Error('Data action path ' + sanitizedActionPath + ' does not have a default export');\n }\n binding.dataActions[sanitizedActionPath].default.prototype.RegistrationId = sanitizedActionPath;\n if (binding.dataActions[sanitizedActionPath].default.prototype.id) {\n binding.dataActions[binding.dataActions[sanitizedActionPath].default.prototype.id] = sanitizedActionPath;\n }\n }\n };\n \n\n (binding.modules['ratings-histogram'] = {\n c: () => require('@msdyn365-commerce-modules/ratings-reviews/dist/lib/modules/ratings-histogram/ratings-histogram'),\n $type: 'contentModule',\n da: [{name:'ratingsReviewsState', path:'@msdyn365-commerce-modules/ratings-reviews/dist/lib/actions/ratings-reviews-state-data-action', runOn: 1},{name:'ratingsSummary', path:'@msdyn365-commerce-modules/retail-actions/dist/lib/get-ratings-summary', runOn: 0}],\n \n iNM: true,\n ns: '@msdyn365-commerce-modules',\n n: 'ratings-histogram',\n p: 'ratings-reviews',\n \n pdp: '',\n \n \n md: 'node_modules/@msdyn365-commerce-modules/ratings-reviews/dist/lib/modules/ratings-histogram'\n });\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/ratings-reviews/dist/lib/actions/ratings-reviews-state-data-action';\n let dataAction = require('@msdyn365-commerce-modules/ratings-reviews/dist/lib/actions/ratings-reviews-state-data-action');\n registerSanitizedActionPath(sanitizedActionPath, dataAction);\n }\n \n\n {\n const sanitizedActionPath = '@msdyn365-commerce-modules/retail-actions/dist/lib/get-ratings-summary';\n let dataAction = require('@msdyn365-commerce-modules/retail-actions/dist/lib/get-ratings-summary');\n registerSanitizedActionPath(sanitizedActionPath, dataAction);\n }\n \n\n \n window.__bindings__ = window.__bindings__ || {};\n window.__bindings__.modules = {\n ...window.__bindings__.modules || {},\n ...binding.modules\n };\n \n window.__bindings__.dataActions = {\n ...window.__bindings__.dataActions || {},\n ...binding.dataActions\n };\n export const viewDictionary = {};\n viewDictionary['@msdyn365-commerce-modules|fabrikam-design-kit|modules|fabrikam|views|ratings-histogram'] = {\n c: () => require('@msdyn365-commerce-modules/fabrikam-design-kit/dist/lib/modules/fabrikam/views/ratings-histogram.view.js'),\n cn: '@msdyn365-commerce-modules-fabrikam-design-kit-ratings-histogram'\n };\nviewDictionary['@msdyn365-commerce-modules|ratings-reviews|modules|ratings-histogram|ratings-histogram'] = {\n c: () => require('@msdyn365-commerce-modules/ratings-reviews/dist/lib/modules/ratings-histogram/ratings-histogram.view.js'),\n cn: '@msdyn365-commerce-modules-ratings-reviews-ratings-histogram'\n };\nviewDictionary['@msdyn365-commerce-theme|adventureworks-theme-kit|modules|adventureworks|views|ratings-histogram'] = {\n c: () => require('@msdyn365-commerce-theme/adventureworks-theme-kit/dist/lib/modules/adventureworks/views/ratings-histogram.view.js'),\n cn: '@msdyn365-commerce-theme-adventureworks-theme-kit-ratings-histogram'\n };\nwindow.__bindings__ = window.__bindings__ || {};\nwindow.__bindings__.viewDictionary = {\n ...window.__bindings__.viewDictionary || {},\n ...viewDictionary\n };","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { IHistogramItemViewProps, IRatingsHistogramViewProps } from '@msdyn365-commerce-modules/ratings-reviews';\nimport { Module, Node } from '@msdyn365-commerce-modules/utilities';\nimport * as React from 'react';\n\nconst RatingsHistogramView: React.FC = props => {\n const { heading, histogramItems, histogramProps, moduleProps } = props;\n return (\n \n {heading}\n \n {histogramItems.map(item => {\n return histogramItem(item);\n })}\n \n \n );\n};\n\nconst histogramItem = (props: IHistogramItemViewProps) => {\n return (\n \n {props.starLabel}\n {props.bar}\n {props.percentage}\n \n );\n};\n\nexport default RatingsHistogramView;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { createObservableDataAction, IAction, IActionInput } from '@msdyn365-commerce/core';\nimport { GenericInput, getGenericAction } from '@msdyn365-commerce-modules/retail-actions';\n\nexport interface IRatingsReviewsState {\n filterKey: string;\n}\n\nexport function createRatingsReviewsStateInput(result: IRatingsReviewsState): GenericInput {\n return new GenericInput('ratingsReviewsState', result, 'ratingsReviewsStateInput');\n}\n\nconst createInternalRatingsReviewsStateInput = (): IActionInput => {\n return createRatingsReviewsStateInput({ filterKey: '1;2;3;4;5' });\n};\n\nexport const getGenericActionDataAction = createObservableDataAction({\n action: >getGenericAction,\n input: createInternalRatingsReviewsStateInput\n});\n\nexport default getGenericActionDataAction;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { RatingsSummary } from '@msdyn365-commerce/commerce-entities';\nimport { format, INodeProps, Progress } from '@msdyn365-commerce-modules/utilities';\nimport React from 'react';\n\nexport interface IHistogramItemsProps {\n ratingsSummary: RatingsSummary;\n resources: IHistogramItemsResources;\n locale: string;\n onClick(stars: number): void;\n}\n\nexport interface IHistogramItemsResources {\n barItemAriaLabel: string;\n}\n\nexport interface IHistogramItemViewProps {\n starLabel: React.ReactElement;\n bar: React.ReactElement;\n percentage: React.ReactElement;\n buttonProps: INodeProps;\n}\n\n/**\n * CartLineItems component.\n */\n\nexport const HistogramItems = (props: IHistogramItemsProps): IHistogramItemViewProps[] => {\n const { ratingsSummary } = props;\n const totalRatingsCount: number = ratingsSummary.totalRatingsCount || 0;\n if (totalRatingsCount === 0) {\n return [];\n }\n return [\n renderItem(props, 5, ratingsSummary.star5Count, totalRatingsCount),\n renderItem(props, 4, ratingsSummary.star4Count, totalRatingsCount),\n renderItem(props, 3, ratingsSummary.star3Count, totalRatingsCount),\n renderItem(props, 2, ratingsSummary.star2Count, totalRatingsCount),\n renderItem(props, 1, ratingsSummary.star1Count, totalRatingsCount)\n ];\n};\n\nconst renderItem = (props: IHistogramItemsProps, stars: number, count?: number, totalCount?: number): IHistogramItemViewProps => {\n count = count || 0;\n totalCount = totalCount || 0;\n const percentage = totalCount === 0 ? 0 : count / totalCount;\n const formattedPercent = new Intl.NumberFormat(props.locale, { style: 'percent' }).format(percentage);\n const ariaLabel = format(props.resources.barItemAriaLabel, stars, formattedPercent);\n\n return {\n starLabel: (\n \n ),\n percentage: (\n \n ),\n bar: ,\n buttonProps: {\n tag: 'button',\n className: 'ms-ratings-histogram__item',\n onClick: () => {\n props.onClick(stars);\n }\n }\n };\n};\n\nexport const AverageRatingNumber: React.FC<{ summary: RatingsSummary }> = (props: { summary: RatingsSummary }) => {\n return (\n

\n {props.summary.averageRating}\n {` `}/ 5\n

\n );\n};\n\nexport const TotalReviews: React.FC<{ summary: RatingsSummary }> = (props: { summary: RatingsSummary }) => {\n return

{props.summary.totalRatingsCount}

;\n};\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { RatingComponent } from '@msdyn365-commerce/components';\nimport * as Msdyn365 from '@msdyn365-commerce/core';\nimport { format, IModuleProps, INodeProps } from '@msdyn365-commerce-modules/utilities';\nimport classname from 'classnames';\nimport { observer } from 'mobx-react';\nimport * as React from 'react';\n\nimport { createRatingsReviewsStateInput } from '../../actions/ratings-reviews-state-data-action';\nimport { AverageRatingNumber, HistogramItems, IHistogramItemViewProps, TotalReviews } from './component/components';\nimport { IRatingsHistogramData } from './ratings-histogram.data';\nimport { IRatingsHistogramProps } from './ratings-histogram.props.autogenerated';\n\nexport interface IRatingsHistogramViewProps extends IRatingsHistogramProps {\n className: string;\n histogramItems: IHistogramItemViewProps[];\n moduleProps: IModuleProps;\n heading: React.ReactNode;\n averageRating: React.ReactNode;\n averageNumber: React.ReactNode;\n totalReviews: React.ReactNode;\n histogramProps: INodeProps;\n ratingsSummaryProps: INodeProps;\n callbacks: IRatingsHistogramCallbacks;\n}\n\nexport interface IRatingsHistogramCallbacks {\n selectFilterBy(stars: number): void;\n}\n\n/**\n * RatingsHistogram component.\n * @extends {React.Component>}\n */\n@observer\nclass RatingsHistogram extends React.PureComponent> {\n constructor(props: IRatingsHistogramProps) {\n super(props);\n this.selectFilterBy = this.selectFilterBy.bind(this);\n }\n\n public render(): JSX.Element | null {\n const { resources } = this.props;\n const { className, heading } = this.props.config;\n const {\n ratingsSummary: { result: ratingsSummary }\n } = this.props.data;\n const ratingCount = ratingsSummary && ratingsSummary.totalRatingsCount ? `${ratingsSummary.totalRatingsCount}` : '0';\n\n const completeClass = classname('ms-ratings-histogram', className);\n const viewProps: IRatingsHistogramViewProps = {\n ...this.props,\n className: completeClass,\n callbacks: {\n selectFilterBy: this.selectFilterBy\n },\n moduleProps: {\n moduleProps: this.props,\n className: completeClass\n },\n histogramItems: ratingsSummary\n ? HistogramItems({\n ratingsSummary,\n resources: { ...resources },\n locale: this.props.context.request.locale,\n onClick: this.selectFilterBy\n })\n : [],\n averageRating: ratingsSummary && (\n \n ),\n averageNumber: ratingsSummary && ,\n totalReviews: ratingsSummary && ,\n ratingsSummaryProps: { className: 'ms-ratings-histogram__summary' },\n heading: heading && (\n \n ),\n histogramProps: { className: 'ms-ratings-histogram__histogram' }\n };\n\n return this.props.renderView(viewProps) as React.ReactElement;\n }\n\n public handleHeadingChange = (event: Msdyn365.ContentEditableEvent) => (this.props.config.heading!.text = event.target.value);\n\n public selectFilterBy(stars: number): void {\n const filterKey = `${stars}`;\n this.props.context.actionContext.update(createRatingsReviewsStateInput({ filterKey }), { filterKey });\n }\n}\n\nexport default RatingsHistogram;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { Module, Node } from '@msdyn365-commerce-modules/utilities';\nimport * as React from 'react';\n\nimport { IHistogramItemViewProps } from './component/components';\nimport { IRatingsHistogramViewProps } from './ratings-histogram';\n\nconst RatingsHistogramView: React.FC = props => {\n const { heading, histogramItems, histogramProps, moduleProps } = props;\n\n return (\n \n {heading}\n \n {histogramItems.map(item => {\n return histogramItem(item);\n })}\n \n \n );\n};\n\nconst histogramItem = (props: IHistogramItemViewProps) => {\n return (\n \n {props.starLabel}\n {props.bar}\n {props.percentage}\n \n );\n};\n\nexport default RatingsHistogramView;\n","/*!\n * Copyright (c) Microsoft Corporation.\n * All rights reserved. See LICENSE in the project root for license information.\n */\n\nimport { RatingComponent } from '@msdyn365-commerce/components';\nimport { ICoreContext } from '@msdyn365-commerce/core';\nimport { IHistogramItemViewProps, IRatingsHistogramData, IRatingsHistogramViewProps } from '@msdyn365-commerce-modules/ratings-reviews';\nimport { format, Module, Node } from '@msdyn365-commerce-modules/utilities';\nimport * as React from 'react';\n\nimport { IRatingsHistogramProps, IRatingsHistogramResources } from '../definition-extensions/ratings-histogram.ext.props.autogenerated';\n\n/**\n * Histogram item.\n * @param props - Histogram Item ViewProps.\n * @returns Histogram Item node.\n */\nconst histogramItem = (props: IHistogramItemViewProps) => {\n return (\n \n {props.starLabel}\n {props.bar}\n \n );\n};\n\n/**\n * Average ratings.\n * @param data - Props data.\n * @param context - Histogram Item ViewProps.\n * @param typeName - Histogram Item ViewProps.\n * @param componentId - Histogram Item ViewProps.\n * @param resources - Module resource strings.\n * @returns Average ratings.\n */\nconst averageRating = (\n data: IRatingsHistogramData,\n context: ICoreContext,\n typeName: string,\n componentId: string,\n resources: IRatingsHistogramResources\n) => {\n const defaultAverageRating: number = 0;\n const reviewsCount = data.ratingsSummary.result?.reviewsCount ?? defaultAverageRating;\n const reviewsCountString = resources.numberOfReviewsString\n ? format(resources.numberOfReviewsString, reviewsCount)\n : `${reviewsCount} reviews`;\n\n return (\n
\n
{data.ratingsSummary.result?.averageRating}
\n
\n \n
\n
{reviewsCountString}
\n
\n );\n};\n\n/**\n * Histogram view.\n * @param props - Ratings HistogramV iewProps.\n * @returns Histogram view module.\n */\nconst RatingsHistogramView: React.FC> = props => {\n const { heading, histogramItems, histogramProps, moduleProps, data, resources } = props;\n const context = props.context;\n const typeName = props.typeName;\n const moduleId = props.id;\n\n return (\n \n {heading}\n
\n {averageRating(data, context, typeName, moduleId, resources)}\n \n {histogramItems.map(item => {\n return histogramItem(item);\n })}\n \n
\n
\n );\n};\n\nexport default RatingsHistogramView;\n","module.exports = React;","module.exports = ReactDOM;"],"names":["binding","modules","dataActions","registerSanitizedActionPath","sanitizedActionPath","dataAction","default","Error","prototype","RegistrationId","id","c","require","$type","da","name","path","runOn","iNM","ns","n","p","pdp","md","window","__bindings__","_objectSpread","viewDictionary","cn","histogramItem","props","React","Node","Object","assign","buttonProps","starLabel","bar","percentage","heading","histogramItems","histogramProps","moduleProps","Module","map","item","createRatingsReviewsStateInput","result","GenericInput","getGenericActionDataAction","createObservableDataAction","action","getGenericAction","input","createInternalRatingsReviewsStateInput","filterKey","HistogramItems","ratingsSummary","totalRatingsCount","renderItem","star5Count","star4Count","star3Count","star2Count","star1Count","stars","count","totalCount","formattedPercent","Intl","NumberFormat","locale","style","format","ariaLabel","resources","barItemAriaLabel","className","Progress","value","max","tag","onClick","AverageRatingNumber","summary","averageRating","TotalReviews","RatingsHistogram","constructor","super","handleHeadingChange","event","this","config","text","target","selectFilterBy","bind","render","data","ratingCount","completeClass","classname","viewProps","callbacks","context","request","RatingComponent","avgRating","averageRatingAriaLabel","readOnly","hideCount","typeName","averageNumber","totalReviews","ratingsSummaryProps","Msdyn365","editProps","onEdit","requestContext","renderView","actionContext","update","__decorate","observer","moduleId","componentId","_data$ratingsSummary$","_data$ratingsSummary$2","_data$ratingsSummary$3","_data$ratingsSummary$4","_data$ratingsSummary$5","_data$ratingsSummary$6","reviewsCount","reviewsCountString","numberOfReviewsString","module","exports","ReactDOM"],"sourceRoot":""}