/******/ (() => { // webpackBootstrap /******/ "use strict"; /******/ var __webpack_modules__ = ({ /***/ 5619: /***/ ((__unused_webpack_module, __unused_webpack___webpack_exports__, __webpack_require__) => { // EXTERNAL MODULE: ./node_modules/react/jsx-runtime.js var jsx_runtime = __webpack_require__(4848); // EXTERNAL MODULE: ./node_modules/react-dom/client.js var client = __webpack_require__(5338); // EXTERNAL MODULE: ./node_modules/recharts/es6/component/ResponsiveContainer.js + 2 modules var ResponsiveContainer = __webpack_require__(1012); // EXTERNAL MODULE: ./node_modules/recharts/es6/chart/PieChart.js + 44 modules var PieChart = __webpack_require__(9416); // EXTERNAL MODULE: ./node_modules/recharts/es6/polar/Pie.js + 63 modules var Pie = __webpack_require__(2012); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/heading/dist/Heading.esm.js var Heading_esm = __webpack_require__(1266); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/utils/formats.ts const parseIfString = (amount) => { if (typeof amount === 'string') { return parseInt(amount, 10) || 0; } return amount; }; const centsFromDollars = (amount) => { const amountDollars = parseFloat(`${amount}`) || 0; return Math.round(amountDollars * 100); }; const isValid = (token) => { return /^[-\$]?[\d\,]*\.?\d*$/.test(token); }; const dollarsFromCents = (amount, format = false) => { const amountCents = parseIfString(amount) / 100; return format ? amountCents.toFixed(2) : amountCents; }; const formatCents = (amount, { currency = '', showCents = true, showPositiveSign = false } = {}) => { const amountDollars = dollarsFromCents(amount); const chars = Math.round(amountDollars * 100) .toString() .replace('-', '') .split(''); const cents = chars.splice(-2, 2); const dollars = chars.map((t, i) => (chars.length - i) % 3 === 0 && i !== 0 ? `,${t}` : t); const positiveSign = showPositiveSign && amountDollars > 0 ? '+' : ''; const sign = amountDollars < 0 ? '-' : positiveSign; const dollarsString = dollars.length ? dollars.join('') : '0'; const centsString = cents.length === 2 ? cents.join('') : `0${cents.join('')}`; return `${sign}${currency}${dollarsString}${showCents ? `.${centsString}` : ''}`; }; const parseCents = (rawValue, fallback = NaN) => { const tokenString = rawValue || ''; const isNegative = tokenString.startsWith('-'); let dollars = parseFloat(tokenString.replace(/[^\d.]/g, '')); if (isNaN(dollars)) return fallback; const cents = centsFromDollars(dollars); return isNegative ? -cents : cents; }; // Constrain a value between a minimum and a maximum const clamp = (value, min = 0, max = 100) => { return Math.max(min, Math.min(max, value)); }; ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetPieChart.tsx const DEFAULT_CHART_DATA = { name: 'Default', value: 100, fill: '#D5D9DB' }; const BudgetPieChart = (props) => { const { data } = props; const totalAmount = data.reduce((sum, item) => sum + item.value, 0); const expenseData = totalAmount > 0 ? data : [DEFAULT_CHART_DATA]; return ((0,jsx_runtime.jsxs)("div", { className: "relative h-[268px] w-[268px] md:h-[300px] md:w-[300px] pointer-events-none", children: [(0,jsx_runtime.jsx)(ResponsiveContainer/* ResponsiveContainer */.u, { width: "100%", height: "100%", children: (0,jsx_runtime.jsx)(PieChart/* PieChart */.r, { children: (0,jsx_runtime.jsx)(Pie/* Pie */.Fq, { data: expenseData, dataKey: "value", innerRadius: 100, outerRadius: "100%", stroke: "" }) }) }), (0,jsx_runtime.jsxs)("div", { className: "absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 text-center", children: [(0,jsx_runtime.jsx)(Heading_esm/* default */.A, { level: "3", size: "small", className: "text-4 mb-4", color: "alternate", children: "Total Expenses" }), (0,jsx_runtime.jsx)("span", { className: "font-semibold text-5", children: formatCents(totalAmount, { currency: '$' }) })] })] })); }; /* harmony default export */ const CalculatorComponents_BudgetPieChart = (BudgetPieChart); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetDifference.tsx const BudgetDifference = ({ difference }) => { const isPositive = difference > 0; const isNegative = difference < 0; return ((0,jsx_runtime.jsxs)("div", { className: "w-full flex-col sm:flex-row flex items-center justify-between", children: [(0,jsx_runtime.jsx)(Heading_esm/* default */.A, { level: "2", size: "xsmall", className: "flex-1 text-[#69757A] whitespace-nowrap text-6", children: "Budget Difference" }), (0,jsx_runtime.jsx)("div", { className: `flex-1 flex-shrink-0 text-right font-semibold text-[24px] ${isPositive ? 'text-[#35BD59]' : isNegative ? 'text-[#E64B40]' : ''} md:min-w-[132px]`, "data-testid": "budget-difference", children: formatCents(difference, { currency: '$', showPositiveSign: true }) })] })); }; /* harmony default export */ const CalculatorComponents_BudgetDifference = (BudgetDifference); // EXTERNAL MODULE: ./node_modules/classnames/index.js var classnames = __webpack_require__(6942); var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetGroup.tsx const BudgetGroup = (props) => { return ((0,jsx_runtime.jsxs)("div", { className: classnames_default()('', props.className), children: [(0,jsx_runtime.jsx)(Heading_esm/* default */.A, { level: "2", size: "xsmall", className: "mb-1 text-[#69757A]", children: props.headingText }), (0,jsx_runtime.jsx)("div", { children: props.children })] })); }; /* harmony default export */ const CalculatorComponents_BudgetGroup = (BudgetGroup); // EXTERNAL MODULE: ./node_modules/react/index.js var react = __webpack_require__(6540); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/components/Indicator.tsx const Indicator = (props) => { const { className, color, ...otherProps } = props; return ((0,jsx_runtime.jsx)("div", { ...otherProps, style: color ? { backgroundColor: color } : undefined, className: classnames_default()('w-[8px] h-[8px] sm:w-[16px] sm:h-[16px] rounded-full mr-1', className), "data-testid": "indicator" })); }; /* harmony default export */ const components_Indicator = (Indicator); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/button/dist/Button.esm.js + 1 modules var Button_esm = __webpack_require__(9438); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/icons/dist/InformationOutlinedIcon.esm.js var InformationOutlinedIcon_esm = __webpack_require__(7173); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/icons/dist/DollarSignIcon.esm.js var DollarSignIcon_esm = __webpack_require__(3314); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/input/dist/Input.esm.js var Input_esm = __webpack_require__(7434); // EXTERNAL MODULE: ./node_modules/@ramsey-design-system/tooltip/dist/Tooltip.esm.js + 8 modules var Tooltip_esm = __webpack_require__(709); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetItem.tsx // RDS // Utils const BudgetItem = (props) => { const [count, setCount] = (0,react.useState)(0); const constrainedValue = clamp(props.value, 0, 99999999); const blurHandler = (e) => { if (!props.onBlur) return; const parsedValue = props.isCurrency ? parseCents(e.target.value, 0) : parseInt(e.target.value, 10) || 0; const updatedValue = clamp(parsedValue, 0, 99999999); props.onBlur(updatedValue); setCount(count + 1); }; return ((0,jsx_runtime.jsxs)("div", { className: "flex flex-wrap gap-md items-center py-1 border-t border-[#E8ECED]", children: [(0,jsx_runtime.jsxs)("label", { className: "flex-1 inline-flex truncate items-center w-full font-normal text-3 md:text-4", children: [props.color ? ((0,jsx_runtime.jsx)(components_Indicator, { color: props.color, className: "w-4 h-4 rounded-full bg-[#f2f2f2]" })) : null, (0,jsx_runtime.jsx)("span", { className: "truncate", children: props.label }), props.tooltipText ? ((0,jsx_runtime.jsxs)(Tooltip_esm/* default */.A, { children: [(0,jsx_runtime.jsx)(Tooltip_esm/* default */.A.Trigger, { children: (0,jsx_runtime.jsx)(Button_esm/* default */.A, { iconOnly: true, appearance: "subtle", size: "small", icon: InformationOutlinedIcon_esm/* InformationOutlinedIcon */.w, "aria-label": "Tooltip" }) }), (0,jsx_runtime.jsx)(Tooltip_esm/* default */.A.Content, { children: props.tooltipText })] })) : null] }), (0,jsx_runtime.jsx)(Input_esm/* default */.A, { maxLength: 10, className: "max-w-20 [&>input]:text-right", "data-testid": `budget_item_input_${props.itemKey}`, defaultValue: props.isCurrency ? formatCents(constrainedValue) : constrainedValue.toString(), icon: props.isCurrency ? DollarSignIcon_esm/* DollarSignIcon */.z : undefined, onBlur: blurHandler, size: "md", disabled: props.disabled }, `${props.isCurrency ? formatCents(constrainedValue) : constrainedValue}-${count}`)] })); }; /* harmony default export */ const CalculatorComponents_BudgetItem = (BudgetItem); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/constants.ts const BudgetItemColors = { budget: undefined, numberOfGuests: undefined, venue: '#0062B9', eventRentals: '#00B2F6', food: '#8EC638', beverage: '#F6A200', cake: '#EA3921', photographer: '#581845', videographer: '#900C3F', flowers: '#1200DD', decor: '#8B008B', entertainment: '#B300D0', dress: '#006990', groom: '#52741F', hair: '#FFE45E', rings: '#E3B409', planner: '#3BEBF5', officiant: '#003561', transportation: '#69757A', rehearsalDinner: '#ED3D9F', invitations: '#B3E65C', favors: '#D8C7FF', marriageLicense: '#EBF4FA', hotel: '#FA7C69', other: '#00B6C7', miscellaneous: '#000000' }; const BudgetItemLabels = { budget: 'Your Wedding Budget', numberOfGuests: 'Number of Guests', venue: 'Venue(s)', eventRentals: 'Event Rentals', food: 'Food/Catering', beverage: 'Alcohol and Beverage', cake: 'Wedding Cake', photographer: 'Photographer', videographer: 'Videographer', entertainment: 'Entertainment', decor: 'Lighting and Decor', flowers: 'Flowers', dress: 'Wedding Dress and Accessories', groom: "Groom's Attire", hair: 'Hair and Makeup', rings: 'Wedding Rings', planner: 'Wedding Planner', officiant: 'Officiant', transportation: 'Transportation', rehearsalDinner: 'Rehearsal Dinner', invitations: 'Invitations and Other Stationery', favors: 'Gifts and Favors', marriageLicense: 'Marriage License', hotel: 'Hotel Accommodations', other: 'Other', miscellaneous: 'Miscellaneous' }; /* eslint-disable */ const BudgetItemToolTipText = { budget: undefined, numberOfGuests: 'Enter the number of guests attending your wedding.', venue: 'Ceremony and reception', eventRentals: 'Tables, chairs, tents, dishes, linens, etc. (if not included with venue)', food: 'Divide this total by your number of guests to get the cost per person.', beverage: undefined, cake: undefined, photographer: undefined, videographer: undefined, flowers: 'Bouquets, boutonnieres, etc.', entertainment: 'DJ, band, ceremony musician, live painter, etc.', decor: 'Centerpieces, wedding arch, drapery, etc.', dress: undefined, groom: undefined, hair: undefined, rings: undefined, planner: undefined, officiant: undefined, transportation: 'To and from the venue', rehearsalDinner: undefined, invitations: 'Save the dates, formal invites, thank-you cards, etc.', favors: undefined, marriageLicense: undefined, hotel: undefined, other: 'Guestbook, ring-bearer pillow, signage, etc.', miscellaneous: 'Go ahead and plan for the unexpected wedding expenses that are bound to pop up.' }; ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/utils/calculatedFields.ts const EXPENSE_PERCENTAGES = { venue: 0.2, eventRentals: 0.04, food: 0.15, beverage: 0.05, cake: 0.02, photographer: 0.05, videographer: 0.04, flowers: 0.08, decor: 0.02, entertainment: 0.07, dress: 0.04, groom: 0.01, hair: 0.01, rings: 0.04, planner: 0.06, officiant: 0.01, transportation: 0.02, rehearsalDinner: 0.03, invitations: 0.01, favors: 0.01, marriageLicense: 0.005, hotel: 0.02, other: 0.01, miscellaneous: 0.005 }; const calculateExpenses = (budget, manualAdjustments, currentExpenses) => { const expenses = {}; let remainingBudget = budget; let remainingPercentage = 0; for (const [key, percentage] of Object.entries(EXPENSE_PERCENTAGES)) { if (manualAdjustments.has(key)) { expenses[key] = currentExpenses[key]; remainingBudget -= currentExpenses[key]; } else { remainingPercentage += percentage; } } for (const [key, percentage] of Object.entries(EXPENSE_PERCENTAGES)) { if (!manualAdjustments.has(key)) { expenses[key] = remainingBudget * (percentage / remainingPercentage); } } return expenses; }; ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/useBudgetData.ts const useBudgetData = () => { const [budgetValues, setBudgetValue] = (0,react.useState)({ income: { budget: 0, numberOfGuests: 100 }, expenses: { venue: 0, eventRentals: 0, food: 0, beverage: 0, cake: 0, photographer: 0, videographer: 0, flowers: 0, decor: 0, entertainment: 0, dress: 0, groom: 0, hair: 0, rings: 0, planner: 0, officiant: 0, transportation: 0, rehearsalDinner: 0, invitations: 0, favors: 0, marriageLicense: 0, hotel: 0, other: 0, miscellaneous: 0 } }); const [manualAdjustments, setManualAdjustments] = (0,react.useState)(new Set()); const updateBudgetItem = (itemType, itemKey) => (value) => { if (itemType === 'income' && itemKey === 'budget') { const calculatedExpenses = calculateExpenses(value, manualAdjustments, budgetValues.expenses); setBudgetValue({ income: { ...budgetValues.income, budget: value }, expenses: calculatedExpenses }); } else if (itemType === 'income' && itemKey === 'numberOfGuests') { setBudgetValue({ ...budgetValues, income: { ...budgetValues.income, numberOfGuests: value } }); } else { setManualAdjustments((prev) => new Set(prev).add(itemKey)); setBudgetValue({ ...budgetValues, [itemType]: { ...budgetValues[itemType], [itemKey]: value } }); } }; const getExpenses = () => { const totalExpenses = Object.values(budgetValues.expenses).reduce((total, current) => { return total + current; }, 0); return totalExpenses; }; const getDifference = () => { const { budget } = budgetValues.income; const totalExpenses = getExpenses(); const difference = budget - totalExpenses; return difference; }; const getChartData = () => { return Object.entries(budgetValues.expenses).map(([key, value]) => ({ name: BudgetItemLabels[key], value: value, fill: BudgetItemColors[key] })); }; return { budgetValues, updateBudgetItem, getExpenses, getDifference, getChartData }; }; /* harmony default export */ const WeddingBudgetCalculator_useBudgetData = (useBudgetData); ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/WeddingBudgetCalculator.tsx // Components // Utils function WeddingBudgetCalculator() { const { budgetValues, updateBudgetItem, getExpenses, getDifference, getChartData } = WeddingBudgetCalculator_useBudgetData(); return ((0,jsx_runtime.jsx)("div", { className: "flex border-box", children: (0,jsx_runtime.jsxs)("div", { className: "w-full max-w-full h-full flex flex-col p-2 md:p-6", children: [(0,jsx_runtime.jsxs)("div", { className: "w-full grid grid-cols-1 md:grid-cols-2 gap-2xl sm:mb-4", "data-testid": "top-section", children: [(0,jsx_runtime.jsx)("div", { className: "flex flex-col md:order-last", children: (0,jsx_runtime.jsx)("div", { className: "flex h-auto justify-center md:h-[300px] mb-2", children: (0,jsx_runtime.jsx)(CalculatorComponents_BudgetPieChart, { totalAmount: getExpenses(), data: getChartData() }) }) }), (0,jsx_runtime.jsxs)("div", { className: "flex flex-col justify-around", children: [(0,jsx_runtime.jsxs)(CalculatorComponents_BudgetGroup, { headingText: "Budget", className: "mb-2", children: [(0,jsx_runtime.jsx)(CalculatorComponents_BudgetItem, { itemKey: "budget", label: BudgetItemLabels['budget'], value: budgetValues.income.budget, onBlur: updateBudgetItem('income', 'budget'), color: BudgetItemColors['budget'], tooltipText: BudgetItemToolTipText['budget'], isCurrency: true }), (0,jsx_runtime.jsx)(CalculatorComponents_BudgetItem, { itemKey: "guests", label: BudgetItemLabels['numberOfGuests'], value: budgetValues.income.numberOfGuests, onBlur: updateBudgetItem('income', 'numberOfGuests'), color: BudgetItemColors['numberOfGuests'], tooltipText: BudgetItemToolTipText['numberOfGuests'], isCurrency: false }), (0,jsx_runtime.jsx)("div", { className: "flex box-border border-t border-[#E8ECED]" })] }), (0,jsx_runtime.jsx)("div", { className: "flex box-border mb-4", children: (0,jsx_runtime.jsx)(CalculatorComponents_BudgetDifference, { difference: getDifference() }) }), (0,jsx_runtime.jsx)("p", { className: "text-2 md:pt-2 md:mb-[-16px] md:text-2 text-[#4B4F54] bottom-0", children: "* The numbers below are just average amounts to guide you\u2014adjust them to fit your budget." })] })] }), (0,jsx_runtime.jsx)(CalculatorComponents_BudgetGroup, { headingText: "Expenses", className: "w-full flex flex-col pt-2 md:pt-0 mb-2", "data-testid": "bottom-section", children: (0,jsx_runtime.jsxs)("div", { className: "grid grid-cols-1 md:grid-cols-2 md:gap-2xl", children: [(0,jsx_runtime.jsx)("div", { children: Object.keys(EXPENSE_PERCENTAGES) .slice(0, Math.ceil(Object.keys(EXPENSE_PERCENTAGES).length / 2)) .map((key) => ((0,jsx_runtime.jsx)(CalculatorComponents_BudgetItem, { itemKey: key, label: BudgetItemLabels[key], value: budgetValues.expenses[key], onBlur: updateBudgetItem('expenses', key), color: BudgetItemColors[key], tooltipText: BudgetItemToolTipText[key], isCurrency: true }, key))) }), (0,jsx_runtime.jsx)("div", { children: Object.keys(EXPENSE_PERCENTAGES) .slice(Math.ceil(Object.keys(EXPENSE_PERCENTAGES).length / 2)) .map((key) => ((0,jsx_runtime.jsx)(CalculatorComponents_BudgetItem, { itemKey: key, label: BudgetItemLabels[key], value: budgetValues.expenses[key], onBlur: updateBudgetItem('expenses', key), color: BudgetItemColors[key], tooltipText: BudgetItemToolTipText[key], isCurrency: true }, key))) })] }) })] }) })); } ;// ./src/rplus-forms/modules/WeddingBudgetCalculator/index.tsx const rootElement = document.getElementById('wedding-budget-calculator-root'); if (rootElement) { (0,client.createRoot)(rootElement).render((0,jsx_runtime.jsx)(WeddingBudgetCalculator, {})); } /***/ }) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /******/ // expose the modules object (__webpack_modules__) /******/ __webpack_require__.m = __webpack_modules__; /******/ /************************************************************************/ /******/ /* webpack/runtime/chunk loaded */ /******/ (() => { /******/ var deferred = []; /******/ __webpack_require__.O = (result, chunkIds, fn, priority) => { /******/ if(chunkIds) { /******/ priority = priority || 0; /******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1]; /******/ deferred[i] = [chunkIds, fn, priority]; /******/ return; /******/ } /******/ var notFulfilled = Infinity; /******/ for (var i = 0; i < deferred.length; i++) { /******/ var [chunkIds, fn, priority] = deferred[i]; /******/ var fulfilled = true; /******/ for (var j = 0; j < chunkIds.length; j++) { /******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) { /******/ chunkIds.splice(j--, 1); /******/ } else { /******/ fulfilled = false; /******/ if(priority < notFulfilled) notFulfilled = priority; /******/ } /******/ } /******/ if(fulfilled) { /******/ deferred.splice(i--, 1) /******/ var r = fn(); /******/ if (r !== undefined) result = r; /******/ } /******/ } /******/ return result; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/create fake namespace object */ /******/ (() => { /******/ var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__); /******/ var leafPrototypes; /******/ // create a fake namespace object /******/ // mode & 1: value is a module id, require it /******/ // mode & 2: merge all properties of value into the ns /******/ // mode & 4: return value when already ns object /******/ // mode & 16: return value when it's Promise-like /******/ // mode & 8|1: behave like require /******/ __webpack_require__.t = function(value, mode) { /******/ if(mode & 1) value = this(value); /******/ if(mode & 8) return value; /******/ if(typeof value === 'object' && value) { /******/ if((mode & 4) && value.__esModule) return value; /******/ if((mode & 16) && typeof value.then === 'function') return value; /******/ } /******/ var ns = Object.create(null); /******/ __webpack_require__.r(ns); /******/ var def = {}; /******/ leafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)]; /******/ for(var current = mode & 2 && value; (typeof current == 'object' || typeof current == 'function') && !~leafPrototypes.indexOf(current); current = getProto(current)) { /******/ Object.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key]))); /******/ } /******/ def['default'] = () => (value); /******/ __webpack_require__.d(ns, def); /******/ return ns; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ (() => { /******/ // define __esModule on exports /******/ __webpack_require__.r = (exports) => { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/jsonp chunk loading */ /******/ (() => { /******/ // no baseURI /******/ /******/ // object to store loaded and loading chunks /******/ // undefined = chunk not loaded, null = chunk preloaded/prefetched /******/ // [resolve, reject, Promise] = chunk loading, 0 = chunk loaded /******/ var installedChunks = { /******/ 314: 0, /******/ 886: 0 /******/ }; /******/ /******/ // no chunk on demand loading /******/ /******/ // no prefetching /******/ /******/ // no preloaded /******/ /******/ // no HMR /******/ /******/ // no HMR manifest /******/ /******/ __webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0); /******/ /******/ // install a JSONP callback for chunk loading /******/ var webpackJsonpCallback = (parentChunkLoadingFunction, data) => { /******/ var [chunkIds, moreModules, runtime] = data; /******/ // add "moreModules" to the modules object, /******/ // then flag all "chunkIds" as loaded and fire callback /******/ var moduleId, chunkId, i = 0; /******/ if(chunkIds.some((id) => (installedChunks[id] !== 0))) { /******/ for(moduleId in moreModules) { /******/ if(__webpack_require__.o(moreModules, moduleId)) { /******/ __webpack_require__.m[moduleId] = moreModules[moduleId]; /******/ } /******/ } /******/ if(runtime) var result = runtime(__webpack_require__); /******/ } /******/ if(parentChunkLoadingFunction) parentChunkLoadingFunction(data); /******/ for(;i < chunkIds.length; i++) { /******/ chunkId = chunkIds[i]; /******/ if(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) { /******/ installedChunks[chunkId][0](); /******/ } /******/ installedChunks[chunkId] = 0; /******/ } /******/ return __webpack_require__.O(result); /******/ } /******/ /******/ var chunkLoadingGlobal = self["webpackChunkramsey_plus_forms"] = self["webpackChunkramsey_plus_forms"] || []; /******/ chunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0)); /******/ chunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal)); /******/ })(); /******/ /************************************************************************/ /******/ /******/ // startup /******/ // Load entry module and return exports /******/ // This entry module depends on other loaded chunks and execution need to be delayed /******/ var __webpack_exports__ = __webpack_require__.O(undefined, [279,86,886], () => (__webpack_require__(5619))) /******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__); /******/ /******/ })() ; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"wedding-budget-calculator.js","mappings":"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;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;UAEA;UACA;;;;;WCzBA;WACA;WACA;WACA;WACA,+BAA+B,wCAAwC;WACvE;WACA;WACA;WACA;WACA,iBAAiB,qBAAqB;WACtC;WACA;WACA,kBAAkB,qBAAqB;WACvC;WACA;WACA,KAAK;WACL;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,E;;;;;WC3BA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA,E;;;;;WCPA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,sDAAsD;WACtD,sCAAsC,mGAAmG;WACzI;WACA;WACA;WACA;WACA;WACA,E;;;;;WCzBA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA,E;;;;;WCPA,wF;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D,E;;;;;WCNA;;WAEA;WACA;WACA;WACA;WACA;WACA;WACA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;;WAEA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA;WACA,MAAM,qBAAqB;WAC3B;WACA;WACA;WACA;WACA;WACA;WACA;WACA;;WAEA;WACA;WACA,4G;;;;;UEjDA;UACA;UACA;UACA;UACA","sources":["webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/utils/formats.ts","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetPieChart.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetDifference.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetGroup.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/components/Indicator.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/CalculatorComponents/BudgetItem.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/constants.ts","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/utils/calculatedFields.ts","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/useBudgetData.ts","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/WeddingBudgetCalculator.tsx","webpack://ramsey-plus-forms/./src/rplus-forms/modules/WeddingBudgetCalculator/index.tsx","webpack://ramsey-plus-forms/webpack/bootstrap","webpack://ramsey-plus-forms/webpack/runtime/chunk loaded","webpack://ramsey-plus-forms/webpack/runtime/compat get default export","webpack://ramsey-plus-forms/webpack/runtime/create fake namespace object","webpack://ramsey-plus-forms/webpack/runtime/define property getters","webpack://ramsey-plus-forms/webpack/runtime/hasOwnProperty shorthand","webpack://ramsey-plus-forms/webpack/runtime/make namespace object","webpack://ramsey-plus-forms/webpack/runtime/jsonp chunk loading","webpack://ramsey-plus-forms/webpack/before-startup","webpack://ramsey-plus-forms/webpack/startup","webpack://ramsey-plus-forms/webpack/after-startup"],"sourcesContent":["export const parseIfString = (amount: string | number) => {\n  if (typeof amount === 'string') {\n    return parseInt(amount, 10) || 0;\n  }\n\n  return amount;\n};\n\nexport const centsFromDollars = (amount: string | number) => {\n  const amountDollars = parseFloat(`${amount}`) || 0;\n  return Math.round(amountDollars * 100);\n};\n\nexport const isValid = (token: string) => {\n  return /^[-\\$]?[\\d\\,]*\\.?\\d*$/.test(token);\n};\n\nexport const dollarsFromCents = (amount: string | number, format = false) => {\n  const amountCents = parseIfString(amount) / 100;\n  return format ? amountCents.toFixed(2) : amountCents;\n};\n\nexport const formatCents = (\n  amount: string | number,\n  { currency = '', showCents = true, showPositiveSign = false } = {}\n) => {\n  const amountDollars = dollarsFromCents(amount) as number;\n  const chars = Math.round(amountDollars * 100)\n    .toString()\n    .replace('-', '')\n    .split('');\n  const cents = chars.splice(-2, 2);\n\n  const dollars = chars.map((t, i) =>\n    (chars.length - i) % 3 === 0 && i !== 0 ? `,${t}` : t\n  );\n  const positiveSign = showPositiveSign && amountDollars > 0 ? '+' : '';\n  const sign = amountDollars < 0 ? '-' : positiveSign;\n\n  const dollarsString = dollars.length ? dollars.join('') : '0';\n  const centsString =\n    cents.length === 2 ? cents.join('') : `0${cents.join('')}`;\n\n  return `${sign}${currency}${dollarsString}${\n    showCents ? `.${centsString}` : ''\n  }`;\n};\n\nexport const parseCents = (rawValue: string, fallback = NaN) => {\n  const tokenString = rawValue || '';\n  const isNegative = tokenString.startsWith('-');\n  let dollars = parseFloat(tokenString.replace(/[^\\d.]/g, ''));\n  if (isNaN(dollars)) return fallback;\n\n  const cents = centsFromDollars(dollars);\n  return isNegative ? -cents : cents;\n};\n\n// Constrain a value between a minimum and a maximum\nexport const clamp = (value: number, min = 0, max = 100) => {\n  return Math.max(min, Math.min(max, value));\n};\n","import { PieChart, Pie, ResponsiveContainer } from 'recharts';\n\nimport Heading from '@ramsey-design-system/heading';\nimport { formatCents } from '../utils/formats';\n\ntype BudgetPieChartProps = {\n  totalAmount: number;\n  data: {\n    name: string;\n    value: number;\n    fill: string;\n  }[];\n};\n\nconst DEFAULT_CHART_DATA = {\n  name: 'Default',\n  value: 100,\n  fill: '#D5D9DB'\n};\n\nconst BudgetPieChart = (props: BudgetPieChartProps) => {\n  const { data } = props;\n  const totalAmount = data.reduce((sum, item) => sum + item.value, 0);\n  const expenseData = totalAmount > 0 ? data : [DEFAULT_CHART_DATA];\n\n  return (\n    <div className=\"relative h-[268px] w-[268px] md:h-[300px] md:w-[300px] pointer-events-none\">\n      <ResponsiveContainer width=\"100%\" height=\"100%\">\n        <PieChart>\n          <Pie\n            data={expenseData}\n            dataKey=\"value\"\n            innerRadius={100}\n            outerRadius=\"100%\"\n            stroke=\"\"\n          />\n        </PieChart>\n      </ResponsiveContainer>\n      <div className=\"absolute top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2 text-center\">\n        <Heading\n          level=\"3\"\n          size=\"small\"\n          className=\"text-4 mb-4\"\n          color=\"alternate\"\n        >\n          Total Expenses\n        </Heading>\n        <span className=\"font-semibold text-5\">\n          {formatCents(totalAmount, { currency: '$' })}\n        </span>\n      </div>\n    </div>\n  );\n};\n\nexport default BudgetPieChart;\n","import Heading from '@ramsey-design-system/heading';\nimport { formatCents } from '../utils/formats';\n\ntype BudgetDifferenceProps = {\n  difference: number;\n};\n\nconst BudgetDifference = ({ difference }: BudgetDifferenceProps) => {\n  const isPositive = difference > 0;\n  const isNegative = difference < 0;\n\n  return (\n    <div className=\"w-full flex-col sm:flex-row flex items-center justify-between\">\n      <Heading\n        level=\"2\"\n        size=\"xsmall\"\n        className=\"flex-1 text-[#69757A] whitespace-nowrap text-6\"\n      >\n        Budget Difference\n      </Heading>\n      <div\n        className={`flex-1 flex-shrink-0 text-right font-semibold text-[24px] ${\n          isPositive ? 'text-[#35BD59]' : isNegative ? 'text-[#E64B40]' : ''\n        } md:min-w-[132px]`}\n        data-testid=\"budget-difference\"\n      >\n        {formatCents(difference, { currency: '$', showPositiveSign: true })}\n      </div>\n    </div>\n  );\n};\n\nexport default BudgetDifference;\n","import Heading from '@ramsey-design-system/heading';\nimport classNames from 'classnames';\n\ntype BudgetGroupProps = {\n  headingText: string;\n  className?: string;\n} & React.ComponentProps<'div'>;\n\nconst BudgetGroup = (props: BudgetGroupProps) => {\n  return (\n    <div className={classNames('', props.className)}>\n      <Heading level=\"2\" size=\"xsmall\" className=\"mb-1 text-[#69757A]\">\n        {props.headingText}\n      </Heading>\n      <div>{props.children}</div>\n    </div>\n  );\n};\n\nexport default BudgetGroup;\n","import classNames from 'classnames';\n\ntype IndicatorProps = React.ComponentProps<'div'> & {\n  color?: string;\n};\n\nconst Indicator = (props: IndicatorProps) => {\n  const { className, color, ...otherProps } = props;\n  return (\n    <div\n      {...otherProps}\n      style={color ? { backgroundColor: color } : undefined}\n      className={classNames(\n        'w-[8px] h-[8px] sm:w-[16px] sm:h-[16px] rounded-full mr-1',\n        className\n      )}\n      data-testid=\"indicator\"\n    />\n  );\n};\nexport default Indicator;\n","import { useState } from 'react';\n\nimport Indicator from '../components/Indicator';\n\n// RDS\nimport Button from '@ramsey-design-system/button';\nimport {\n  InformationOutlinedIcon,\n  DollarSignIcon\n} from '@ramsey-design-system/icons';\nimport Input from '@ramsey-design-system/input';\nimport Tooltip from '@ramsey-design-system/tooltip';\n\n// Utils\nimport { clamp, formatCents, parseCents } from '../utils/formats';\n\ntype BudgetItemProps = {\n  itemKey: string;\n  label: string;\n  value: number;\n  onBlur?: (amount: number) => void;\n  color?: string;\n  tooltipText?: string;\n  isCurrency?: boolean;\n  disabled?: boolean;\n};\n\nconst BudgetItem = (props: BudgetItemProps) => {\n  const [count, setCount] = useState(0);\n  const constrainedValue = clamp(props.value, 0, 99999999);\n\n  const blurHandler = (e: React.FocusEvent<HTMLInputElement>) => {\n    if (!props.onBlur) return;\n\n    const parsedValue = props.isCurrency\n      ? parseCents(e.target.value, 0)\n      : parseInt(e.target.value, 10) || 0;\n    const updatedValue = clamp(parsedValue, 0, 99999999);\n    props.onBlur(updatedValue);\n    setCount(count + 1);\n  };\n\n  return (\n    <div className=\"flex flex-wrap gap-md items-center py-1 border-t border-[#E8ECED]\">\n      <label className=\"flex-1 inline-flex truncate items-center w-full font-normal text-3 md:text-4\">\n        {props.color ? (\n          <Indicator\n            color={props.color}\n            className=\"w-4 h-4 rounded-full bg-[#f2f2f2]\"\n          />\n        ) : null}\n        <span className=\"truncate\">{props.label}</span>\n        {props.tooltipText ? (\n          <Tooltip>\n            <Tooltip.Trigger>\n              <Button\n                iconOnly\n                appearance=\"subtle\"\n                size=\"small\"\n                icon={InformationOutlinedIcon}\n                aria-label=\"Tooltip\"\n              />\n            </Tooltip.Trigger>\n            <Tooltip.Content>{props.tooltipText}</Tooltip.Content>\n          </Tooltip>\n        ) : null}\n      </label>\n      <Input\n        maxLength={10}\n        className=\"max-w-20 [&>input]:text-right\"\n        data-testid={`budget_item_input_${props.itemKey}`} // Use itemKey dynamically\n        defaultValue={\n          props.isCurrency\n            ? formatCents(constrainedValue)\n            : constrainedValue.toString()\n        }\n        key={`${props.isCurrency ? formatCents(constrainedValue) : constrainedValue}-${count}`}\n        icon={props.isCurrency ? DollarSignIcon : undefined}\n        onBlur={blurHandler}\n        size=\"md\"\n        disabled={props.disabled}\n      />\n    </div>\n  );\n};\n\nexport default BudgetItem;\n","export const BudgetItemColors = {\n  budget: undefined,\n  numberOfGuests: undefined,\n  venue: '#0062B9',\n  eventRentals: '#00B2F6',\n  food: '#8EC638',\n  beverage: '#F6A200',\n  cake: '#EA3921',\n  photographer: '#581845',\n  videographer: '#900C3F',\n  flowers: '#1200DD',\n  decor: '#8B008B',\n  entertainment: '#B300D0',\n  dress: '#006990',\n  groom: '#52741F',\n  hair: '#FFE45E',\n  rings: '#E3B409',\n  planner: '#3BEBF5',\n  officiant: '#003561',\n  transportation: '#69757A',\n  rehearsalDinner: '#ED3D9F',\n  invitations: '#B3E65C',\n  favors: '#D8C7FF',\n  marriageLicense: '#EBF4FA',\n  hotel: '#FA7C69',\n  other: '#00B6C7',\n  miscellaneous: '#000000'\n};\n\nexport const BudgetItemLabels = {\n  budget: 'Your Wedding Budget',\n  numberOfGuests: 'Number of Guests',\n  venue: 'Venue(s)',\n  eventRentals: 'Event Rentals',\n  food: 'Food/Catering',\n  beverage: 'Alcohol and Beverage',\n  cake: 'Wedding Cake',\n  photographer: 'Photographer',\n  videographer: 'Videographer',\n  entertainment: 'Entertainment',\n  decor: 'Lighting and Decor',\n  flowers: 'Flowers',\n  dress: 'Wedding Dress and Accessories',\n  groom: \"Groom's Attire\",\n  hair: 'Hair and Makeup',\n  rings: 'Wedding Rings',\n  planner: 'Wedding Planner',\n  officiant: 'Officiant',\n  transportation: 'Transportation',\n  rehearsalDinner: 'Rehearsal Dinner',\n  invitations: 'Invitations and Other Stationery',\n  favors: 'Gifts and Favors',\n  marriageLicense: 'Marriage License',\n  hotel: 'Hotel Accommodations',\n  other: 'Other',\n  miscellaneous: 'Miscellaneous'\n};\n\n/* eslint-disable */\nexport const BudgetItemToolTipText = {\n  budget: undefined,\n  numberOfGuests: 'Enter the number of guests attending your wedding.',\n  venue: 'Ceremony and reception',\n  eventRentals:\n    'Tables, chairs, tents, dishes, linens, etc. (if not included with venue)',\n  food: 'Divide this total by your number of guests to get the cost per person.',\n  beverage: undefined,\n  cake: undefined,\n  photographer: undefined,\n  videographer: undefined,\n  flowers: 'Bouquets, boutonnieres, etc.',\n  entertainment: 'DJ, band, ceremony musician, live painter, etc.',\n  decor: 'Centerpieces, wedding arch, drapery, etc.',\n  dress: undefined,\n  groom: undefined,\n  hair: undefined,\n  rings: undefined,\n  planner: undefined,\n  officiant: undefined,\n  transportation: 'To and from the venue',\n  rehearsalDinner: undefined,\n  invitations: 'Save the dates, formal invites, thank-you cards, etc.',\n  favors: undefined,\n  marriageLicense: undefined,\n  hotel: undefined,\n  other: 'Guestbook, ring-bearer pillow, signage, etc.',\n  miscellaneous:\n    'Go ahead and plan for the unexpected wedding expenses that are bound to pop up.'\n};\n","import { BudgetValues } from '../types';\n\nexport const EXPENSE_PERCENTAGES: Record<\n  keyof BudgetValues['expenses'],\n  number\n> = {\n  venue: 0.2,\n  eventRentals: 0.04,\n  food: 0.15,\n  beverage: 0.05,\n  cake: 0.02,\n  photographer: 0.05,\n  videographer: 0.04,\n  flowers: 0.08,\n  decor: 0.02,\n  entertainment: 0.07,\n  dress: 0.04,\n  groom: 0.01,\n  hair: 0.01,\n  rings: 0.04,\n  planner: 0.06,\n  officiant: 0.01,\n  transportation: 0.02,\n  rehearsalDinner: 0.03,\n  invitations: 0.01,\n  favors: 0.01,\n  marriageLicense: 0.005,\n  hotel: 0.02,\n  other: 0.01,\n  miscellaneous: 0.005\n};\n\nexport const calculateExpenses = (\n  budget: number,\n  manualAdjustments: Set<string>,\n  currentExpenses: BudgetValues['expenses']\n): BudgetValues['expenses'] => {\n  const expenses: Partial<BudgetValues['expenses']> = {};\n  let remainingBudget = budget;\n  let remainingPercentage = 0;\n\n  for (const [key, percentage] of Object.entries(EXPENSE_PERCENTAGES)) {\n    if (manualAdjustments.has(key)) {\n      expenses[key as keyof BudgetValues['expenses']] =\n        currentExpenses[key as keyof BudgetValues['expenses']];\n      remainingBudget -= currentExpenses[key as keyof BudgetValues['expenses']];\n    } else {\n      remainingPercentage += percentage;\n    }\n  }\n\n  for (const [key, percentage] of Object.entries(EXPENSE_PERCENTAGES)) {\n    if (!manualAdjustments.has(key)) {\n      expenses[key as keyof BudgetValues['expenses']] =\n        remainingBudget * (percentage / remainingPercentage);\n    }\n  }\n\n  return expenses as BudgetValues['expenses'];\n};\n","import { useState } from 'react';\nimport { BudgetItemColors, BudgetItemLabels } from './constants';\nimport { BudgetExpenseId, BudgetValues } from './types';\nimport { calculateExpenses } from './utils/calculatedFields';\n\nconst useBudgetData = () => {\n  const [budgetValues, setBudgetValue] = useState<BudgetValues>({\n    income: {\n      budget: 0,\n      numberOfGuests: 100\n    },\n    expenses: {\n      venue: 0,\n      eventRentals: 0,\n      food: 0,\n      beverage: 0,\n      cake: 0,\n      photographer: 0,\n      videographer: 0,\n      flowers: 0,\n      decor: 0,\n      entertainment: 0,\n      dress: 0,\n      groom: 0,\n      hair: 0,\n      rings: 0,\n      planner: 0,\n      officiant: 0,\n      transportation: 0,\n      rehearsalDinner: 0,\n      invitations: 0,\n      favors: 0,\n      marriageLicense: 0,\n      hotel: 0,\n      other: 0,\n      miscellaneous: 0\n    }\n  });\n\n  const [manualAdjustments, setManualAdjustments] = useState<Set<string>>(\n    new Set()\n  );\n\n  const updateBudgetItem =\n    (itemType: 'income' | 'expenses', itemKey: string) => (value: number) => {\n      if (itemType === 'income' && itemKey === 'budget') {\n        const calculatedExpenses = calculateExpenses(\n          value,\n          manualAdjustments,\n          budgetValues.expenses\n        );\n\n        setBudgetValue({\n          income: {\n            ...budgetValues.income,\n            budget: value\n          },\n          expenses: calculatedExpenses\n        });\n      } else if (itemType === 'income' && itemKey === 'numberOfGuests') {\n        setBudgetValue({\n          ...budgetValues,\n          income: {\n            ...budgetValues.income,\n            numberOfGuests: value\n          }\n        });\n      } else {\n        setManualAdjustments((prev) => new Set(prev).add(itemKey));\n        setBudgetValue({\n          ...budgetValues,\n          [itemType]: {\n            ...budgetValues[itemType],\n            [itemKey]: value\n          }\n        });\n      }\n    };\n\n  const getExpenses = () => {\n    const totalExpenses = Object.values(budgetValues.expenses).reduce(\n      (total, current) => {\n        return total + current;\n      },\n      0\n    );\n\n    return totalExpenses;\n  };\n\n  const getDifference = () => {\n    const { budget } = budgetValues.income;\n    const totalExpenses = getExpenses();\n    const difference = budget - totalExpenses;\n    return difference;\n  };\n\n  const getChartData = () => {\n    return Object.entries(budgetValues.expenses).map(([key, value]) => ({\n      name: BudgetItemLabels[key as BudgetExpenseId],\n      value: value,\n      fill: BudgetItemColors[key as BudgetExpenseId]\n    }));\n  };\n\n  return {\n    budgetValues,\n    updateBudgetItem,\n    getExpenses,\n    getDifference,\n    getChartData\n  };\n};\n\nexport default useBudgetData;\n","// Components\nimport BudgetPieChart from './CalculatorComponents/BudgetPieChart';\nimport BudgetDifference from './CalculatorComponents/BudgetDifference';\nimport BudgetGroup from './CalculatorComponents/BudgetGroup';\nimport BudgetItem from './CalculatorComponents/BudgetItem';\n\n// Utils\nimport {\n  BudgetItemColors,\n  BudgetItemLabels,\n  BudgetItemToolTipText\n} from './constants';\nimport useBudgetData from './useBudgetData';\nimport { BudgetExpenseId } from './types';\nimport { EXPENSE_PERCENTAGES } from './utils/calculatedFields';\n\nexport default function WeddingBudgetCalculator() {\n  const {\n    budgetValues,\n    updateBudgetItem,\n    getExpenses,\n    getDifference,\n    getChartData\n  } = useBudgetData();\n\n  return (\n    <div className=\"flex border-box\">\n      <div className=\"w-full max-w-full h-full flex flex-col p-2 md:p-6\">\n        <div\n          className=\"w-full grid grid-cols-1 md:grid-cols-2 gap-2xl sm:mb-4\"\n          data-testid=\"top-section\"\n        >\n          <div className=\"flex flex-col md:order-last\">\n            <div className=\"flex h-auto justify-center md:h-[300px] mb-2\">\n              <BudgetPieChart\n                totalAmount={getExpenses()}\n                data={getChartData()}\n              />\n            </div>\n          </div>\n          <div className=\"flex flex-col justify-around\">\n            <BudgetGroup headingText=\"Budget\" className=\"mb-2\">\n              <BudgetItem\n                itemKey=\"budget\"\n                label={BudgetItemLabels['budget']}\n                value={budgetValues.income.budget}\n                onBlur={updateBudgetItem('income', 'budget')}\n                color={BudgetItemColors['budget']}\n                tooltipText={BudgetItemToolTipText['budget']}\n                isCurrency={true}\n              />\n              <BudgetItem\n                itemKey=\"guests\"\n                label={BudgetItemLabels['numberOfGuests']}\n                value={budgetValues.income.numberOfGuests}\n                onBlur={updateBudgetItem('income', 'numberOfGuests')}\n                color={BudgetItemColors['numberOfGuests']}\n                tooltipText={BudgetItemToolTipText['numberOfGuests']}\n                isCurrency={false}\n              />\n              <div className=\"flex box-border border-t border-[#E8ECED]\"></div>\n            </BudgetGroup>\n            <div className=\"flex box-border mb-4\">\n              <BudgetDifference difference={getDifference()} />\n            </div>\n            <p className=\"text-2 md:pt-2 md:mb-[-16px] md:text-2 text-[#4B4F54] bottom-0\">\n              * The numbers below are just average amounts to guide you—adjust\n              them to fit your budget.\n            </p>\n          </div>\n        </div>\n        <BudgetGroup\n          headingText=\"Expenses\"\n          className=\"w-full flex flex-col pt-2 md:pt-0 mb-2\"\n          data-testid=\"bottom-section\"\n        >\n          <div className=\"grid grid-cols-1 md:grid-cols-2 md:gap-2xl\">\n            <div>\n              {Object.keys(EXPENSE_PERCENTAGES)\n                .slice(\n                  0,\n                  Math.ceil(Object.keys(EXPENSE_PERCENTAGES).length / 2)\n                )\n                .map((key) => (\n                  <BudgetItem\n                    key={key}\n                    itemKey={key as BudgetExpenseId} // Pass key as itemKey\n                    label={BudgetItemLabels[key as BudgetExpenseId]}\n                    value={budgetValues.expenses[key as BudgetExpenseId]}\n                    onBlur={updateBudgetItem('expenses', key)}\n                    color={BudgetItemColors[key as BudgetExpenseId]}\n                    tooltipText={BudgetItemToolTipText[key as BudgetExpenseId]}\n                    isCurrency={true}\n                  />\n                ))}\n            </div>\n            <div>\n              {Object.keys(EXPENSE_PERCENTAGES)\n                .slice(Math.ceil(Object.keys(EXPENSE_PERCENTAGES).length / 2))\n                .map((key) => (\n                  <BudgetItem\n                    key={key}\n                    itemKey={key as BudgetExpenseId} // Pass key as itemKey\n                    label={BudgetItemLabels[key as BudgetExpenseId]}\n                    value={budgetValues.expenses[key as BudgetExpenseId]}\n                    onBlur={updateBudgetItem('expenses', key)}\n                    color={BudgetItemColors[key as BudgetExpenseId]}\n                    tooltipText={BudgetItemToolTipText[key as BudgetExpenseId]}\n                    isCurrency={true}\n                  />\n                ))}\n            </div>\n          </div>\n        </BudgetGroup>\n      </div>\n    </div>\n  );\n}\n","import { createRoot } from 'react-dom/client';\nimport '../../../css/global.css';\nimport WeddingBudgetCalculator from './WeddingBudgetCalculator';\n\nconst rootElement = document.getElementById('wedding-budget-calculator-root');\nif (rootElement) {\n  createRoot(rootElement).render(<WeddingBudgetCalculator />);\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","var deferred = [];\n__webpack_require__.O = (result, chunkIds, fn, priority) => {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; (typeof current == 'object' || typeof current == 'function') && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t314: 0,\n\t886: 0\n};\n\n// no chunk on demand loading\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n__webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\treturn __webpack_require__.O(result);\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkramsey_plus_forms\"] = self[\"webpackChunkramsey_plus_forms\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","","// startup\n// Load entry module and return exports\n// This entry module depends on other loaded chunks and execution need to be delayed\nvar __webpack_exports__ = __webpack_require__.O(undefined, [279,86,886], () => (__webpack_require__(5619)))\n__webpack_exports__ = __webpack_require__.O(__webpack_exports__);\n",""],"names":[],"ignoreList":[],"sourceRoot":""}