arky-sdk 0.3.84 → 0.3.85

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/utils.js CHANGED
@@ -660,6 +660,162 @@ function validateRequired(value, fieldName = "This field") {
660
660
  return { isValid: true };
661
661
  }
662
662
 
663
- export { ERROR_CODES, ERROR_CONSTANTS, categorify, convertServerErrorToRequestError, convertToMajor, convertToMinor, createPaymentForCheckout, errors, extractBlockValues, fetchSvgContent, findTimeZone, formatBlockValue, formatCurrencyAmount, formatDate, formatMinor, formatPayment, getBlockFromArray, getBlockLabel, getBlockObjectValues, getBlockTextValue, getBlockValue, getBlockValues, getCurrencyFromMarket, getCurrencySymbol, getErrorMessage, getImageUrl, getMarketPrice, getPriceAmount, getSvgContentForAstro, humanize, injectSvgIntoElement, isErrorCode, prepareBlocksForSubmission, slugify, transformErrors, translateMap, tzGroups, validateEmail, validatePhoneNumber, validateRequired, validateVerificationCode };
663
+ // src/utils/time.ts
664
+ function formatTime(ts, tz) {
665
+ return new Date(ts * 1e3).toLocaleTimeString([], {
666
+ hour: "2-digit",
667
+ minute: "2-digit",
668
+ timeZone: tz
669
+ });
670
+ }
671
+ function formatSlotTime(from, to, tz) {
672
+ return `${formatTime(from, tz)} \u2013 ${formatTime(to, tz)}`;
673
+ }
674
+ function getTzOffset(date, tz) {
675
+ const utc = new Date(date.toLocaleString("en-US", { timeZone: "UTC" }));
676
+ const local = new Date(date.toLocaleString("en-US", { timeZone: tz }));
677
+ return (utc.getTime() - local.getTime()) / 6e4;
678
+ }
679
+ function toUtcTimestamp(year, month, day, mins, tz) {
680
+ const midnight = new Date(Date.UTC(year, month - 1, day));
681
+ const offset = getTzOffset(midnight, tz);
682
+ return Math.floor(midnight.getTime() / 1e3) + (mins + offset) * 60;
683
+ }
684
+ function formatDateDisplay(dateStr, tz) {
685
+ if (!dateStr) return "";
686
+ const date = /* @__PURE__ */ new Date(dateStr + "T00:00:00");
687
+ return date.toLocaleDateString("en-US", {
688
+ weekday: "short",
689
+ month: "short",
690
+ day: "numeric",
691
+ timeZone: tz
692
+ });
693
+ }
694
+ function getIsoDate(date, tz) {
695
+ return date.toLocaleDateString("en-CA", { timeZone: tz });
696
+ }
697
+ function parseIsoDate(isoDate) {
698
+ const [year, month, day] = isoDate.split("-").map(Number);
699
+ return { year, month, day };
700
+ }
701
+
702
+ // src/utils/slots.ts
703
+ function getTotalDuration(durations) {
704
+ return durations.reduce((sum, d) => sum + d.duration, 0);
705
+ }
706
+ function isBlocked(from, to, timeline, limit) {
707
+ const before = timeline.filter((p) => p.timestamp <= from).sort((a, b) => b.timestamp - a.timestamp);
708
+ if (before.length > 0 && before[0].concurrent >= limit) return true;
709
+ for (const p of timeline) {
710
+ if (p.timestamp >= from && p.timestamp < to && p.concurrent >= limit) {
711
+ return true;
712
+ }
713
+ }
714
+ return false;
715
+ }
716
+ function getWorkingHoursForDate(wt, date, tz) {
717
+ if (!wt) return [];
718
+ const dayName = date.toLocaleDateString("en-US", { weekday: "long", timeZone: tz }).toLowerCase();
719
+ const m = date.getMonth() + 1;
720
+ const d = date.getDate();
721
+ const ts = Math.floor(date.getTime() / 1e3);
722
+ const specific = wt.specificDates?.find((s) => s.date === ts);
723
+ if (specific) return specific.workingHours || [];
724
+ const outcast = wt.outcastDates?.find((o) => o.month === m && o.day === d);
725
+ if (outcast) return outcast.workingHours || [];
726
+ return wt.workingDays?.find((w) => w.day === dayName)?.workingHours || [];
727
+ }
728
+ function computeSlotsForDate(opts) {
729
+ const { providers, date, durations, timezone, slotInterval } = opts;
730
+ const total = getTotalDuration(durations);
731
+ const interval = slotInterval || total;
732
+ const slots = [];
733
+ const nowTs = Math.floor(Date.now() / 1e3);
734
+ const today = /* @__PURE__ */ new Date();
735
+ today.setHours(0, 0, 0, 0);
736
+ if (date < today) return [];
737
+ const [year, month, day] = date.toLocaleDateString("en-CA", { timeZone: timezone }).split("-").map(Number);
738
+ for (const provider of providers) {
739
+ const workingHours = getWorkingHoursForDate(provider.workingTime, date, timezone);
740
+ for (const wh of workingHours) {
741
+ for (let m = wh.from; m + total <= wh.to; m += interval) {
742
+ const from = toUtcTimestamp(year, month, day, m, timezone);
743
+ const to = from + total * 60;
744
+ if (from < nowTs) continue;
745
+ if (!isBlocked(from, to, provider.timeline, provider.concurrentLimit)) {
746
+ slots.push({ from, to, providerId: provider.id });
747
+ }
748
+ }
749
+ }
750
+ }
751
+ return slots.sort((a, b) => a.from - b.from);
752
+ }
753
+ function hasAvailableSlots(opts) {
754
+ return computeSlotsForDate(opts).length > 0;
755
+ }
756
+ function buildCalendar(opts) {
757
+ const {
758
+ currentMonth,
759
+ selectedDate,
760
+ startDate,
761
+ endDate,
762
+ providers,
763
+ selectedProvider,
764
+ durations,
765
+ timezone,
766
+ isMultiDay
767
+ } = opts;
768
+ const year = currentMonth.getFullYear();
769
+ const month = currentMonth.getMonth();
770
+ const first = new Date(year, month, 1);
771
+ const last = new Date(year, month + 1, 0);
772
+ const today = /* @__PURE__ */ new Date();
773
+ today.setHours(0, 0, 0, 0);
774
+ const cells = [];
775
+ const pad = (first.getDay() + 6) % 7;
776
+ for (let i = 0; i < pad; i++) {
777
+ cells.push({
778
+ date: /* @__PURE__ */ new Date(0),
779
+ iso: "",
780
+ available: false,
781
+ isSelected: false,
782
+ isInRange: false,
783
+ isToday: false,
784
+ blank: true
785
+ });
786
+ }
787
+ const activeProviders = selectedProvider ? providers.filter((p) => p.id === selectedProvider.id) : providers;
788
+ for (let d = 1; d <= last.getDate(); d++) {
789
+ const date = new Date(year, month, d);
790
+ const iso = `${year}-${String(month + 1).padStart(2, "0")}-${String(d).padStart(2, "0")}`;
791
+ const available = activeProviders.length > 0 && hasAvailableSlots({ providers: activeProviders, date, durations, timezone });
792
+ const isToday = date.getTime() === today.getTime();
793
+ let isSelected = false;
794
+ let isInRange = false;
795
+ if (isMultiDay) {
796
+ isSelected = iso === startDate || iso === endDate;
797
+ if (startDate && endDate) {
798
+ isInRange = iso > startDate && iso < endDate;
799
+ }
800
+ } else {
801
+ isSelected = iso === selectedDate;
802
+ }
803
+ cells.push({
804
+ date,
805
+ iso,
806
+ available,
807
+ isSelected,
808
+ isInRange,
809
+ isToday,
810
+ blank: false
811
+ });
812
+ }
813
+ return cells;
814
+ }
815
+ function getMonthYear(date) {
816
+ return date.toLocaleDateString("en-US", { month: "long", year: "numeric" });
817
+ }
818
+
819
+ export { ERROR_CODES, ERROR_CONSTANTS, buildCalendar, categorify, computeSlotsForDate, convertServerErrorToRequestError, convertToMajor, convertToMinor, createPaymentForCheckout, errors, extractBlockValues, fetchSvgContent, findTimeZone, formatBlockValue, formatCurrencyAmount, formatDate, formatDateDisplay, formatMinor, formatPayment, formatSlotTime, formatTime, getBlockFromArray, getBlockLabel, getBlockObjectValues, getBlockTextValue, getBlockValue, getBlockValues, getCurrencyFromMarket, getCurrencySymbol, getErrorMessage, getImageUrl, getIsoDate, getMarketPrice, getMonthYear, getPriceAmount, getSvgContentForAstro, getTotalDuration, getTzOffset, getWorkingHoursForDate, hasAvailableSlots, humanize, injectSvgIntoElement, isBlocked, isErrorCode, parseIsoDate, prepareBlocksForSubmission, slugify, toUtcTimestamp, transformErrors, translateMap, tzGroups, validateEmail, validatePhoneNumber, validateRequired, validateVerificationCode };
664
820
  //# sourceMappingURL=utils.js.map
665
821
  //# sourceMappingURL=utils.js.map
package/dist/utils.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/utils/blocks.ts","../src/utils/errors.ts","../src/utils/currency.ts","../src/utils/price.ts","../src/utils/svg.ts","../src/utils/text.ts","../src/utils/timezone.ts","../src/utils/validation.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["// Block utilities (extracted from index.ts)\n\nexport interface Block {\n id: string;\n key: string;\n type: string;\n properties: any;\n value: any;\n}\n\nexport interface Collection {\n id: string;\n blocks: Block[];\n}\n\nexport interface CollectionEntry {\n id: string;\n collection_id: string;\n blocks: Block[];\n}\n\nexport function getBlockLabel(block: any, locale: string = \"en\"): string {\n if (!block) return \"\";\n\n if (block.properties?.label) {\n if (typeof block.properties.label === \"object\") {\n return (\n block.properties.label[locale] ||\n block.properties.label.en ||\n Object.values(block.properties.label)[0] ||\n \"\"\n );\n }\n if (typeof block.properties.label === \"string\") {\n return block.properties.label;\n }\n }\n\n // Convert key to readable format\n return (\n block.key\n ?.replace(/_/g, \" \")\n .replace(/\\b\\w/g, (l: string) => l.toUpperCase()) || \"\"\n );\n}\n\nexport function formatBlockValue(block: any): string {\n if (!block || block.value === null || block.value === undefined) {\n return \"\";\n }\n\n switch (block.type) {\n case \"BOOLEAN\":\n return block.value ? \"Yes\" : \"No\";\n case \"NUMBER\":\n // Handle date/datetime variants\n if (\n block.properties?.variant === \"DATE\" ||\n block.properties?.variant === \"DATE_TIME\"\n ) {\n try {\n return new Date(block.value).toLocaleDateString();\n } catch (e) {\n return String(block.value);\n }\n }\n return String(block.value);\n case \"RELATIONSHIP\":\n if (Array.isArray(block.value) && block.value.length > 0) {\n const firstValue = block.value[0];\n if (firstValue && firstValue.mimeType) {\n return firstValue.name || firstValue.id || \"Media\";\n }\n return firstValue.title || firstValue.name || firstValue.id || \"Entry\";\n }\n return String(block.value);\n default:\n return String(block.value);\n }\n}\n\nexport function prepareBlocksForSubmission(formData: any): any[] {\n const preparedBlocks = [];\n\n Object.keys(formData).forEach((key) => {\n if (formData[key] !== null && formData[key] !== undefined) {\n preparedBlocks.push({\n key,\n value: [formData[key]],\n });\n }\n });\n\n return preparedBlocks;\n}\n\nexport function extractBlockValues(blocks: any[]): Record<string, any> {\n const values: Record<string, any> = {};\n\n blocks.forEach((block) => {\n if (block.value && block.value.length > 0) {\n values[block.key] = block.value[0];\n } else {\n values[block.key] = null;\n }\n });\n\n return values;\n}\n\n// Extract localized text value from a block, handling multilingual content\nexport function getBlockTextValue(block: any, locale: string = \"en\"): string {\n if (!block || !block.value || block.value.length === 0) return \"\";\n\n const firstValue = block.value[0];\n\n // Handle multilingual object\n if (typeof firstValue === \"object\" && firstValue !== null) {\n // Try specified locale first, then 'en', then first available language\n if (firstValue[locale]) return firstValue[locale];\n if (firstValue.en) return firstValue.en;\n const values = Object.values(firstValue);\n return String(values[0] || \"\");\n }\n\n // Handle simple string\n return String(firstValue);\n}\n\n// Legacy functions for backward compatibility\nexport const getBlockValue = (entry: any, blockKey: string) => {\n if (!entry || !entry.blocks) return null;\n\n const block = entry.blocks.find((f: any) => f.key === blockKey);\n\n if (!block || !block.value || block.value.length === 0) return null;\n\n return block.value[0];\n};\n\nexport const getBlockValues = (entry: any, blockKey: string) => {\n if (!entry || !entry.blocks) return null;\n\n const block = entry.blocks.find((f: any) => f.key === blockKey);\n\n if (!block || !block.value || block.value.length === 0) return null;\n\n return block.value;\n};\n\nfunction unwrapBlock(block: any, locale: string) {\n if (!block?.type || block.value === undefined) return block;\n\n // Nested objects / lists → recurse for every child\n if (block.type === \"BLOCK\") {\n return block.value.map((obj: Record<string, any>) => {\n const parsed: Record<string, any> = {};\n for (const [k, v] of Object.entries(obj)) {\n parsed[k] = unwrapBlock(v, locale);\n }\n return parsed;\n });\n }\n\n // Primitive leaves (text/number/boolean/media …)\n const isLocalized = block.type === \"TEXT\";\n const isList =\n block.properties?.ui === \"list\" ||\n (block.properties?.maxValues ?? 1) > 1 ||\n block.value.length > 1;\n\n if (isList) {\n return isLocalized\n ? block.value.map((v: Record<string, any>) => v[locale] || v[\"en\"])\n : [...block.value];\n }\n\n return isLocalized\n ? block.value[0][locale] || block.value[0][\"en\"]\n : block.value[0];\n}\n\nexport const getBlockObjectValues = (\n entry: any,\n blockKey: string,\n locale = \"en\"\n) => {\n if (!entry) {\n return [];\n }\n\n const values = getBlockValues(entry, blockKey); // top‑level list\n\n const parsed = values.map((obj: Record<string, any>) => {\n const res = obj.value.reduce((acc: any, current: any) => {\n acc[current.key] = unwrapBlock(current, locale);\n\n return acc;\n }, {});\n\n return res;\n });\n\n return parsed;\n};\n\nexport const getBlockFromArray = (\n entry: any,\n blockKey: string,\n locale = \"en\"\n) => {\n if (!entry) {\n return [];\n }\n\n const values = getBlockValues(entry, blockKey); // top‑level list\n\n return values.reduce((acc: any, current: any) => {\n acc[current.key] = unwrapBlock(current, locale);\n return acc;\n });\n};\n\nexport const getImageUrl = (imageBlock: any, isBlock = true) => {\n if (!imageBlock) return null;\n\n if (\n imageBlock.type === \"RELATIONSHIP_MEDIA\" &&\n Array.isArray(imageBlock.value)\n ) {\n const mediaValue = imageBlock.value[0];\n if (mediaValue && mediaValue.mimeType) {\n // Handle media with resolutions structure\n if (\n mediaValue.resolutions &&\n mediaValue.resolutions.original &&\n mediaValue.resolutions.original.url\n ) {\n return mediaValue.resolutions.original.url;\n }\n\n // Handle direct URL on media\n if (mediaValue.url) {\n return mediaValue.url;\n }\n }\n return null;\n }\n\n if (isBlock) {\n if (typeof imageBlock === \"string\") {\n return imageBlock;\n }\n\n if (imageBlock.url) {\n return imageBlock.url;\n }\n }\n\n if (\n imageBlock.resolutions &&\n imageBlock.resolutions.original &&\n imageBlock.resolutions.original.url\n ) {\n return imageBlock.resolutions.original.url;\n }\n\n return null;\n};\n\nexport const translateMap = (\n labels: any,\n lang: string,\n fallback = \"unknown\"\n) => {\n let parsedLang = \"en\";\n\n if (lang === \"sr\") {\n parsedLang = \"bih\";\n }\n\n if (!labels) {\n return fallback;\n }\n\n const label = labels[parsedLang];\n if (!label) {\n return fallback;\n }\n\n return label;\n};\n","// Error handling utilities (combined from errorCodes.ts and errorHelpers.ts)\n\n// Comprehensive error code system with both numeric codes and named constants\nexport const ERROR_CODES = {\n // General errors\n \"GENERAL.001\": \"GENERAL.BAD_REQUEST\",\n \"GENERAL.002\": \"GENERAL.VALIDATION_ERROR\",\n \"GENERAL.003\": \"GENERAL.FORBIDDEN_ERROR\",\n \"GENERAL.004\": \"GENERAL.INTERNAL_SERVER_ERROR\",\n \"GENERAL.005\": \"GENERAL.UNAUTHORIZED\",\n \"GENERAL.006\": \"GENERAL.UNAUTHENTICATED\",\n\n // Google/OAuth errors\n \"GOOGLE.001\": \"GOOGLE.INVALID_ORIGIN_URI\",\n \"GOOGLE.002\": \"GOOGLE.INVALID_REDIRECT_URI\",\n \"GOOGLE.003\": \"GOOGLE.FAILED_TO_CALL_API\",\n \"GOOGLE.004\": \"GOOGLE.FAILED_LOGIN\",\n \"GOOGLE.005\": \"GOOGLE.FAILED_LOGOUT\",\n \"GOOGLE.006\": \"GOOGLE.FAILED_REFRESH_TOKEN\",\n \"GOOGLE.007\": \"GOOGLE.INVALID_PROVIDER_PASSED\",\n\n // User errors\n \"USER.001\": \"USER.NOT_FOUND\",\n \"USER.002\": \"USER.FAILED_TO_CREATE\",\n \"USER.003\": \"USER.FAILED_TO_UPDATE\",\n \"USER.004\": \"USER.FAILED_TO_DELETE\",\n \"USER.005\": \"USER.EMAIL_EXISTS\",\n \"USER.006\": \"USER.FAILED_TO_GET_UPLOAD_URL\",\n\n // Business errors\n \"BUSINESS.001\": \"BUSINESS.NOT_FOUND\",\n \"BUSINESS.002\": \"BUSINESS.FAILED_TO_CREATE\",\n \"BUSINESS.003\": \"BUSINESS.FAILED_TO_UPDATE\",\n \"BUSINESS.004\": \"BUSINESS.FAILED_TO_DELETE\",\n \"BUSINESS.005\": \"BUSINESS.FAILED_TO_GET_UPLOAD_URL\",\n \"BUSINESS.006\": \"BUSINESS.NAME_REQUIRED\",\n \"BUSINESS.007\": \"BUSINESS.BUSINESS_ID_REQUIRED\",\n \"BUSINESS.010\": \"BUSINESS.DESCRIPTION_REQUIRED\",\n \"BUSINESS.011\": \"BUSINESS.SLUG_INVALID\",\n\n // Provider errors\n \"PROVIDER.001\": \"PROVIDER.NOT_FOUND\",\n \"PROVIDER.002\": \"PROVIDER.FAILED_TO_CREATE\",\n \"PROVIDER.003\": \"PROVIDER.FAILED_TO_UPDATE\",\n \"PROVIDER.004\": \"PROVIDER.FAILED_TO_DELETE\",\n \"PROVIDER.005\": \"PROVIDER.FAILED_TO_GET_UPLOAD_URL\",\n \"PROVIDER.006\": \"PROVIDER.NAME_REQUIRED\",\n \"PROVIDER.007\": \"PROVIDER.BUSINESS_ID_REQUIRED\",\n \"PROVIDER.008\": \"PROVIDER.DESCRIPTION_REQUIRED\",\n};\n\n// Named error constants for direct access\nexport const ERROR_CONSTANTS = {\n GENERAL: {\n BAD_REQUEST: \"GENERAL.BAD_REQUEST\",\n VALIDATION_ERROR: \"GENERAL.VALIDATION_ERROR\",\n FORBIDDEN_ERROR: \"GENERAL.FORBIDDEN_ERROR\",\n INTERNAL_SERVER_ERROR: \"GENERAL.INTERNAL_SERVER_ERROR\",\n UNAUTHORIZED: \"GENERAL.UNAUTHORIZED\",\n UNAUTHENTICATED: \"GENERAL.UNAUTHENTICATED\",\n },\n USER: {\n NOT_FOUND: \"USER.NOT_FOUND\",\n FAILED_TO_CREATE: \"USER.FAILED_TO_CREATE\",\n FAILED_TO_UPDATE: \"USER.FAILED_TO_UPDATE\",\n FAILED_TO_DELETE: \"USER.FAILED_TO_DELETE\",\n EMAIL_EXISTS: \"USER.EMAIL_EXISTS\",\n FAILED_TO_GET_UPLOAD_URL: \"USER.FAILED_TO_GET_UPLOAD_URL\",\n },\n BUSINESS: {\n NOT_FOUND: \"BUSINESS.NOT_FOUND\",\n FAILED_TO_CREATE: \"BUSINESS.FAILED_TO_CREATE\",\n FAILED_TO_UPDATE: \"BUSINESS.FAILED_TO_UPDATE\",\n FAILED_TO_DELETE: \"BUSINESS.FAILED_TO_DELETE\",\n FAILED_TO_GET_UPLOAD_URL: \"BUSINESS.FAILED_TO_GET_UPLOAD_URL\",\n NAME_REQUIRED: \"BUSINESS.NAME_REQUIRED\",\n BUSINESS_ID_REQUIRED: \"BUSINESS.BUSINESS_ID_REQUIRED\",\n DESCRIPTION_REQUIRED: \"BUSINESS.DESCRIPTION_REQUIRED\",\n SLUG_INVALID: \"BUSINESS.SLUG_INVALID\",\n },\n};\n\nexport type ServerError = {\n message: string;\n error: string;\n statusCode: number;\n validationErrors: {\n field: string;\n error: string;\n }[];\n};\n\nexport type ValidationError = {\n field: string;\n error: string;\n};\n\nexport type RequestError = {\n validationErrors: ValidationError[];\n};\n\n// Utility functions for error handling\nexport function getErrorMessage(code: string): string {\n return ERROR_CODES[code as keyof typeof ERROR_CODES] || code;\n}\n\nexport function isErrorCode(code: string): boolean {\n return code in ERROR_CODES;\n}\n\nexport const transformErrors = (zodError: any): ValidationError[] => {\n const customErrors: ValidationError[] = [];\n\n if (!zodError.issues) return customErrors;\n\n zodError.issues.forEach((issue: any) => {\n const field = issue.path.join(\".\");\n const error = issue.message;\n\n if (\n !customErrors.some(\n (customError) =>\n customError.field === field && customError.error === error\n )\n ) {\n customErrors.push({ field, error });\n }\n });\n\n return customErrors;\n};\n\nexport const convertServerErrorToRequestError = (\n serverError: ServerError,\n renameRules?: { [key: string]: string }\n): RequestError => {\n return {\n ...serverError,\n validationErrors: serverError.validationErrors.map((validationError) => {\n const field =\n renameRules && renameRules[validationError.field]\n ? renameRules[validationError.field]\n : validationError.field;\n\n return {\n field: field,\n error: validationError.error || \"GENERAL.VALIDATION_ERROR\",\n };\n }),\n };\n};\n\n// Export for backward compatibility\nexport const errors = ERROR_CONSTANTS;\nexport default ERROR_CODES;\n","/**\n * Maps currency codes to their display symbols\n */\nexport function getCurrencySymbol(currency: string): string {\n const currencySymbols: Record<string, string> = {\n USD: '$',\n EUR: '€',\n GBP: '£',\n CAD: 'C$',\n AUD: 'A$',\n JPY: '¥',\n CHF: 'CHF',\n SEK: 'kr',\n NOK: 'kr',\n DKK: 'kr',\n PLN: 'zł',\n CZK: 'Kč',\n HUF: 'Ft',\n RON: 'lei',\n BGN: 'лв',\n HRK: 'kn',\n RSD: 'дин',\n BAM: 'KM',\n MKD: 'ден',\n ALL: 'L',\n TRY: '₺',\n RUB: '₽',\n UAH: '₴',\n BYN: 'Br',\n CNY: '¥',\n INR: '₹',\n KRW: '₩',\n THB: '฿',\n VND: '₫',\n SGD: 'S$',\n MYR: 'RM',\n IDR: 'Rp',\n PHP: '₱',\n BRL: 'R$',\n ARS: '$',\n CLP: '$',\n COP: '$',\n PEN: 'S/',\n MXN: '$',\n ZAR: 'R',\n EGP: 'E£',\n NGN: '₦',\n KES: 'KSh',\n GHS: '₵',\n MAD: 'DH',\n TND: 'د.ت',\n DZD: 'د.ج',\n LYD: 'ل.د',\n AED: 'د.إ',\n SAR: 'ر.س',\n QAR: 'ر.ق',\n KWD: 'د.ك',\n BHD: 'ب.د',\n OMR: 'ر.ع',\n JOD: 'د.أ',\n LBP: 'ل.ل',\n SYP: 'ل.س',\n IQD: 'ع.د',\n IRR: '﷼',\n AFN: '؋',\n PKR: '₨',\n LKR: '₨',\n NPR: '₨',\n BDT: '৳',\n MMK: 'K',\n LAK: '₭',\n KHR: '៛',\n MNT: '₮',\n KZT: '₸',\n UZS: 'лв',\n KGS: 'лв',\n TJS: 'SM',\n TMT: 'T',\n AZN: '₼',\n GEL: '₾',\n AMD: '֏',\n BYR: 'p.',\n MDL: 'L'\n };\n\n return currencySymbols[currency.toUpperCase()] || currency;\n}\n\n/**\n * List of currencies where the symbol appears after the amount\n */\nexport const SYMBOL_AFTER_CURRENCIES = ['SEK', 'NOK', 'DKK', 'PLN', 'CZK', 'HUF', 'RON', 'BGN', 'HRK'];\n\n/**\n * Check if currency symbol should be placed after the amount\n */\nexport function isSymbolAfterCurrency(currency: string): boolean {\n return SYMBOL_AFTER_CURRENCIES.includes(currency.toUpperCase());\n}","// Price formatting utilities - Centralized currency and price operations\nimport type { Payment, PaymentMethodType, Price } from '../types';\nimport { getCurrencySymbol, isSymbolAfterCurrency } from './currency';\n\nconst MARKET_CURRENCIES = {\n 'US': 'USD',\n 'EU': 'EUR',\n 'UK': 'GBP',\n 'CA': 'CAD',\n 'AU': 'AUD'\n} as const;\n\n// Convert minor units (cents) to major units (dollars)\nexport function convertToMajor(minorAmount: number): number {\n return (minorAmount ?? 0) / 100;\n}\n\n// Convert major units to minor units\nexport function convertToMinor(majorAmount: number): number {\n return Math.round((majorAmount ?? 0) * 100);\n}\n\n// Get currency from market ID\nexport function getCurrencyFromMarket(marketId: string): string {\n return MARKET_CURRENCIES[marketId as keyof typeof MARKET_CURRENCIES] || 'USD';\n}\n\n// Format currency amount with symbol (locale-aware positioning)\nexport function formatCurrencyAmount(\n amount: number,\n currency: string,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n customSymbol?: string;\n } = {}\n): string {\n const { showSymbols = true, decimalPlaces = 2, customSymbol } = options;\n const roundedAmount = amount.toFixed(decimalPlaces);\n\n if (!showSymbols) {\n return `${roundedAmount} ${currency}`;\n }\n\n const symbol = customSymbol || getCurrencySymbol(currency);\n\n // Use locale-specific symbol positioning\n if (isSymbolAfterCurrency(currency)) {\n return `${roundedAmount} ${symbol}`;\n }\n\n return `${symbol}${roundedAmount}`;\n}\n\n// Format minor units with currency\nexport function formatMinor(\n amountMinor: number,\n currency: string,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n customSymbol?: string;\n } = {}\n): string {\n const major = convertToMajor(amountMinor);\n return formatCurrencyAmount(major, currency, options);\n}\n\n// Format Payment structure for display\nexport function formatPayment(\n payment: Payment,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n showBreakdown?: boolean;\n } = {}\n): string {\n if (!payment) return '';\n\n const { showSymbols = true, decimalPlaces = 2, showBreakdown = false } = options;\n\n if (showBreakdown) {\n const subtotal = formatMinor(payment.subtotal, payment.currency, { showSymbols, decimalPlaces });\n const discount = (payment.discount ?? 0) > 0 ? formatMinor(payment.discount, payment.currency, { showSymbols, decimalPlaces }) : null;\n const taxAmount = payment.tax?.amount ?? 0;\n const tax = taxAmount > 0 ? formatMinor(taxAmount, payment.currency, { showSymbols, decimalPlaces }) : null;\n const total = formatMinor(payment.total, payment.currency, { showSymbols, decimalPlaces });\n\n let result = `Subtotal: ${subtotal}`;\n if (discount) result += `, Discount: -${discount}`;\n if (tax) result += `, Tax: ${tax}`;\n result += `, Total: ${total}`;\n return result;\n }\n\n return formatMinor(payment.total, payment.currency, { showSymbols, decimalPlaces });\n}\n\n// Format market-based prices (from product variants)\nexport function getMarketPrice(\n prices: Price[],\n marketId: string,\n businessMarkets?: any[],\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n showCompareAt?: boolean;\n fallbackMarket?: string;\n } = {}\n): string {\n if (!prices || prices.length === 0) return '';\n\n const {\n showSymbols = true,\n decimalPlaces = 2,\n showCompareAt = true,\n fallbackMarket,\n } = options;\n\n // Find price for the specific market\n let price = prices.find(p => p.market === marketId);\n\n // Fallback to fallback market (if provided) or first available\n if (!price && fallbackMarket) {\n price = prices.find(p => p.market === fallbackMarket);\n }\n if (!price) {\n price = prices[0];\n }\n\n if (!price) return '';\n\n let currency: string;\n let symbol: string;\n\n // If we have business markets, use the currency directly from market data\n if (businessMarkets) {\n const marketData = businessMarkets.find(m => m.id === price.market || m.code === price.market);\n if (marketData?.currency) {\n currency = marketData.currency;\n symbol = getCurrencySymbol(currency);\n } else {\n currency = getCurrencyFromMarket(price.market);\n symbol = getCurrencySymbol(currency);\n }\n } else {\n currency = getCurrencyFromMarket(price.market);\n symbol = getCurrencySymbol(currency);\n }\n\n // Format price with custom symbol\n const formattedPrice = formatMinor(price.amount ?? 0, currency, {\n showSymbols,\n decimalPlaces,\n customSymbol: symbol\n });\n\n // Add compare-at price if available\n if (showCompareAt && price.compareAt && price.compareAt > (price.amount ?? 0)) {\n const formattedCompareAt = formatMinor(price.compareAt, currency, {\n showSymbols,\n decimalPlaces,\n customSymbol: symbol\n });\n return `${formattedPrice} was ${formattedCompareAt}`;\n }\n\n return formattedPrice;\n}\n\n// Get price amount from market-based prices (for calculations)\nexport function getPriceAmount(prices: Price[], marketId: string, fallbackMarket?: string): number {\n if (!prices || prices.length === 0) return 0;\n\n let price = prices.find(p => p.market === marketId);\n if (!price && fallbackMarket) {\n price = prices.find(p => p.market === fallbackMarket);\n }\n if (!price) {\n price = prices[0];\n }\n\n // Amounts are stored in minor units (e.g., cents)\n return price?.amount || 0;\n}\n\n// Create Payment structure for checkout (all amounts in minor units)\nexport function createPaymentForCheckout(\n subtotalMinor: number,\n marketId: string,\n currency: string,\n paymentMethod: any,\n options: {\n discount?: number;\n taxAmount?: number;\n taxRateBps?: number;\n promoCode?: {\n id: string;\n code: string;\n type: string;\n value: number;\n };\n } = {}\n): Payment {\n const { discount = 0, taxAmount = 0, taxRateBps = 0, promoCode } = options;\n const total = subtotalMinor - discount + taxAmount;\n\n return {\n currency,\n market: marketId,\n subtotal: subtotalMinor,\n shipping: 0,\n discount,\n total,\n type: paymentMethod,\n ...(taxAmount > 0 && {\n tax: {\n amount: taxAmount,\n rateBps: taxRateBps,\n lines: [],\n },\n }),\n ...(promoCode && { promoCode }),\n };\n}\n","import { getImageUrl } from \"./blocks\";\n\nexport async function fetchSvgContent(mediaObject: any): Promise<string | null> {\n\tif (!mediaObject) return null;\n\n\tconst svgUrl = getImageUrl(mediaObject, false);\n\n\ttry {\n\t\tconst response = await fetch(svgUrl);\n\n\t\tif (!response.ok) {\n\t\t\tconsole.error(`Failed to fetch SVG: ${response.status} ${response.statusText}`);\n\t\t\treturn null;\n\t\t}\n\n\t\tconst svgContent = await response.text();\n\t\treturn svgContent;\n\t} catch (error) {\n\t\tconsole.error(\"Error fetching SVG:\", error);\n\t\treturn null;\n\t}\n}\n\n/**\n * Server-side helper for Astro components to fetch SVG content during SSR\n *\n * @param mediaObject The media object from the CMS\n * @returns The SVG content as a string, or empty string on failure\n */\nexport async function getSvgContentForAstro(mediaObject: any): Promise<string> {\n\ttry {\n\t\tconst svgContent = await fetchSvgContent(mediaObject);\n\t\treturn svgContent || \"\";\n\t} catch (error) {\n\t\tconsole.error(\"Error getting SVG content for Astro:\", error);\n\t\treturn \"\";\n\t}\n}\n\n/**\n * Client-side helper to fetch and inject SVG content into DOM elements\n *\n * @param mediaObject The media object from the CMS\n * @param targetElement The DOM element to inject the SVG into\n * @param className Optional CSS class to add to the SVG\n */\nexport async function injectSvgIntoElement(\n\tmediaObject: any,\n\ttargetElement: HTMLElement,\n\tclassName?: string,\n): Promise<void> {\n\tif (!targetElement) return;\n\n\ttry {\n\t\tconst svgContent = await fetchSvgContent(mediaObject);\n\n\t\tif (svgContent) {\n\t\t\ttargetElement.innerHTML = svgContent;\n\n\t\t\t// Add class if provided\n\t\t\tif (className) {\n\t\t\t\tconst svgElement = targetElement.querySelector(\"svg\");\n\t\t\t\tif (svgElement) {\n\t\t\t\t\tsvgElement.classList.add(...className.split(\" \"));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} catch (error) {\n\t\tconsole.error(\"Error injecting SVG:\", error);\n\t}\n}","// Define locales inline since we don't have @lib/i18n in SDK\nconst locales = ['en', 'sr-latn'] as const;\nconst localeMap: Record<typeof locales[number], string> = {\n\t'en': 'en-US',\n\t'sr-latn': 'sr-RS'\n};\n\n/**\n * * returns \"slugified\" text.\n * @param text: string - text to slugify\n */\nexport function slugify(text: string): string {\n\treturn text\n\t\t.toString()\n\t\t.toLowerCase() // convert to lowercase\n\t\t.replace(/\\s+/g, \"-\") // replace spaces with -\n\t\t.replace(/[^\\w-]+/g, \"\") // remove all non-word chars\n\t\t.replace(/--+/g, \"-\") // replace multiple dashes with single dash\n\t\t.replace(/^-+/, \"\") // trim dash from start of text\n\t\t.replace(/-+$/, \"\"); // trim dash from end of text\n}\n\n/**\n * * returns \"humanized\" text. runs slugify() and then replaces - with space and upper case first letter of every word, and lower case the rest\n * @param text: string - text to humanize\n */\nexport function humanize(text: string): string {\n\tconst slugifiedText = slugify(text);\n\treturn (\n\t\tslugifiedText\n\t\t\t.replace(/-/g, \" \") // replace \"-\" with space\n\t\t\t// .toLowerCase();\n\t\t\t.replace(\n\t\t\t\t// upper case first letter of every word, and lower case the rest\n\t\t\t\t/\\w\\S*/g,\n\t\t\t\t(w) => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase(),\n\t\t\t)\n\t);\n}\n\n// --------------------------------------------------------\n/**\n * * returns \"categorified\" text. runs slugify() and then replaces - with space and upper cases everything\n * @param text: string - text to categorify\n * @returns string - categorified text\n */\nexport function categorify(text: string): string {\n\tconst slugifiedText = slugify(text);\n\treturn slugifiedText\n\t\t.replace(/-/g, \" \") // replace \"-\" with space\n\t\t.toUpperCase();\n}\n\n// --------------------------------------------------------\n/**\n * * returns a nicely formatted string of the date passed\n * @param date: string | number | Date - date to format\n * @param locale: string - locale to format the date in\n * @returns string - formatted date\n */\nexport function formatDate(date: string | number | Date, locale: (typeof locales)[number]): string {\n\tlet localeString = \"en-US\";\n\n\tif (locales.includes(locale)) {\n\t\tlocaleString = localeMap[locale];\n\t}\n\n\treturn new Date(date).toLocaleDateString(localeString, {\n\t\ttimeZone: \"UTC\",\n\t\tyear: \"numeric\",\n\t\tmonth: \"short\",\n\t\tday: \"numeric\",\n\t});\n}","// Timezone utilities (moved from Reservation folder)\n\nexport const tzGroups = [\n {\n label: \"US\",\n zones: [\n { label: \"Eastern Time\", value: \"America/New_York\" },\n { label: \"Central Time\", value: \"America/Chicago\" },\n { label: \"Mountain Time\", value: \"America/Denver\" },\n { label: \"Pacific Time\", value: \"America/Los_Angeles\" },\n ],\n },\n {\n label: \"Europe\",\n zones: [\n { label: \"London\", value: \"Europe/London\" },\n { label: \"Paris\", value: \"Europe/Paris\" },\n { label: \"Berlin\", value: \"Europe/Berlin\" },\n { label: \"Rome\", value: \"Europe/Rome\" },\n ],\n },\n {\n label: \"Asia\",\n zones: [\n { label: \"Tokyo\", value: \"Asia/Tokyo\" },\n { label: \"Shanghai\", value: \"Asia/Shanghai\" },\n { label: \"Mumbai\", value: \"Asia/Kolkata\" },\n { label: \"Dubai\", value: \"Asia/Dubai\" },\n ],\n },\n];\n\nexport function findTimeZone(groups: typeof tzGroups): string {\n try {\n const detected = Intl.DateTimeFormat().resolvedOptions().timeZone;\n \n // Check if detected timezone is in our list\n for (const group of groups) {\n for (const zone of group.zones) {\n if (zone.value === detected) {\n return detected;\n }\n }\n }\n \n // Fallback to UTC if not found\n return \"UTC\";\n } catch (e) {\n // Fallback to UTC if detection fails\n return \"UTC\";\n }\n}","// Validation utilities\n\nexport interface ValidationResult {\n isValid: boolean;\n error?: string;\n}\n\n// Phone number validation\nexport function validatePhoneNumber(phone: string): ValidationResult {\n if (!phone) {\n return { isValid: false, error: 'Phone number is required' };\n }\n \n const cleaned = phone.replace(/\\D/g, '');\n \n if (cleaned.length < 8) {\n return { isValid: false, error: 'Phone number is too short' };\n }\n \n if (cleaned.length > 15) {\n return { isValid: false, error: 'Phone number is too long' };\n }\n \n return { isValid: true };\n}\n\n// Email validation\nexport function validateEmail(email: string): ValidationResult {\n if (!email) {\n return { isValid: false, error: 'Email is required' };\n }\n \n const emailRegex = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\n \n if (!emailRegex.test(email)) {\n return { isValid: false, error: 'Please enter a valid email address' };\n }\n \n return { isValid: true };\n}\n\n// Verification code validation (4-digit codes)\nexport function validateVerificationCode(code: string): ValidationResult {\n if (!code) {\n return { isValid: false, error: 'Verification code is required' };\n }\n \n const cleaned = code.replace(/\\D/g, '');\n \n if (cleaned.length !== 4) {\n return { isValid: false, error: 'Please enter a 4-digit verification code' };\n }\n \n return { isValid: true };\n}\n\n// Generic required field validation\nexport function validateRequired(value: any, fieldName: string = 'This field'): ValidationResult {\n if (value === null || value === undefined || value === '') {\n return { isValid: false, error: `${fieldName} is required` };\n }\n \n return { isValid: true };\n}"]}
1
+ {"version":3,"sources":["../src/utils/blocks.ts","../src/utils/errors.ts","../src/utils/currency.ts","../src/utils/price.ts","../src/utils/svg.ts","../src/utils/text.ts","../src/utils/timezone.ts","../src/utils/validation.ts","../src/utils/time.ts","../src/utils/slots.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["// Block utilities (extracted from index.ts)\n\nexport interface Block {\n id: string;\n key: string;\n type: string;\n properties: any;\n value: any;\n}\n\nexport interface Collection {\n id: string;\n blocks: Block[];\n}\n\nexport interface CollectionEntry {\n id: string;\n collection_id: string;\n blocks: Block[];\n}\n\nexport function getBlockLabel(block: any, locale: string = \"en\"): string {\n if (!block) return \"\";\n\n if (block.properties?.label) {\n if (typeof block.properties.label === \"object\") {\n return (\n block.properties.label[locale] ||\n block.properties.label.en ||\n Object.values(block.properties.label)[0] ||\n \"\"\n );\n }\n if (typeof block.properties.label === \"string\") {\n return block.properties.label;\n }\n }\n\n // Convert key to readable format\n return (\n block.key\n ?.replace(/_/g, \" \")\n .replace(/\\b\\w/g, (l: string) => l.toUpperCase()) || \"\"\n );\n}\n\nexport function formatBlockValue(block: any): string {\n if (!block || block.value === null || block.value === undefined) {\n return \"\";\n }\n\n switch (block.type) {\n case \"BOOLEAN\":\n return block.value ? \"Yes\" : \"No\";\n case \"NUMBER\":\n // Handle date/datetime variants\n if (\n block.properties?.variant === \"DATE\" ||\n block.properties?.variant === \"DATE_TIME\"\n ) {\n try {\n return new Date(block.value).toLocaleDateString();\n } catch (e) {\n return String(block.value);\n }\n }\n return String(block.value);\n case \"RELATIONSHIP\":\n if (Array.isArray(block.value) && block.value.length > 0) {\n const firstValue = block.value[0];\n if (firstValue && firstValue.mimeType) {\n return firstValue.name || firstValue.id || \"Media\";\n }\n return firstValue.title || firstValue.name || firstValue.id || \"Entry\";\n }\n return String(block.value);\n default:\n return String(block.value);\n }\n}\n\nexport function prepareBlocksForSubmission(formData: any): any[] {\n const preparedBlocks = [];\n\n Object.keys(formData).forEach((key) => {\n if (formData[key] !== null && formData[key] !== undefined) {\n preparedBlocks.push({\n key,\n value: [formData[key]],\n });\n }\n });\n\n return preparedBlocks;\n}\n\nexport function extractBlockValues(blocks: any[]): Record<string, any> {\n const values: Record<string, any> = {};\n\n blocks.forEach((block) => {\n if (block.value && block.value.length > 0) {\n values[block.key] = block.value[0];\n } else {\n values[block.key] = null;\n }\n });\n\n return values;\n}\n\n// Extract localized text value from a block, handling multilingual content\nexport function getBlockTextValue(block: any, locale: string = \"en\"): string {\n if (!block || !block.value || block.value.length === 0) return \"\";\n\n const firstValue = block.value[0];\n\n // Handle multilingual object\n if (typeof firstValue === \"object\" && firstValue !== null) {\n // Try specified locale first, then 'en', then first available language\n if (firstValue[locale]) return firstValue[locale];\n if (firstValue.en) return firstValue.en;\n const values = Object.values(firstValue);\n return String(values[0] || \"\");\n }\n\n // Handle simple string\n return String(firstValue);\n}\n\n// Legacy functions for backward compatibility\nexport const getBlockValue = (entry: any, blockKey: string) => {\n if (!entry || !entry.blocks) return null;\n\n const block = entry.blocks.find((f: any) => f.key === blockKey);\n\n if (!block || !block.value || block.value.length === 0) return null;\n\n return block.value[0];\n};\n\nexport const getBlockValues = (entry: any, blockKey: string) => {\n if (!entry || !entry.blocks) return null;\n\n const block = entry.blocks.find((f: any) => f.key === blockKey);\n\n if (!block || !block.value || block.value.length === 0) return null;\n\n return block.value;\n};\n\nfunction unwrapBlock(block: any, locale: string) {\n if (!block?.type || block.value === undefined) return block;\n\n // Nested objects / lists → recurse for every child\n if (block.type === \"BLOCK\") {\n return block.value.map((obj: Record<string, any>) => {\n const parsed: Record<string, any> = {};\n for (const [k, v] of Object.entries(obj)) {\n parsed[k] = unwrapBlock(v, locale);\n }\n return parsed;\n });\n }\n\n // Primitive leaves (text/number/boolean/media …)\n const isLocalized = block.type === \"TEXT\";\n const isList =\n block.properties?.ui === \"list\" ||\n (block.properties?.maxValues ?? 1) > 1 ||\n block.value.length > 1;\n\n if (isList) {\n return isLocalized\n ? block.value.map((v: Record<string, any>) => v[locale] || v[\"en\"])\n : [...block.value];\n }\n\n return isLocalized\n ? block.value[0][locale] || block.value[0][\"en\"]\n : block.value[0];\n}\n\nexport const getBlockObjectValues = (\n entry: any,\n blockKey: string,\n locale = \"en\"\n) => {\n if (!entry) {\n return [];\n }\n\n const values = getBlockValues(entry, blockKey); // top‑level list\n\n const parsed = values.map((obj: Record<string, any>) => {\n const res = obj.value.reduce((acc: any, current: any) => {\n acc[current.key] = unwrapBlock(current, locale);\n\n return acc;\n }, {});\n\n return res;\n });\n\n return parsed;\n};\n\nexport const getBlockFromArray = (\n entry: any,\n blockKey: string,\n locale = \"en\"\n) => {\n if (!entry) {\n return [];\n }\n\n const values = getBlockValues(entry, blockKey); // top‑level list\n\n return values.reduce((acc: any, current: any) => {\n acc[current.key] = unwrapBlock(current, locale);\n return acc;\n });\n};\n\nexport const getImageUrl = (imageBlock: any, isBlock = true) => {\n if (!imageBlock) return null;\n\n if (\n imageBlock.type === \"RELATIONSHIP_MEDIA\" &&\n Array.isArray(imageBlock.value)\n ) {\n const mediaValue = imageBlock.value[0];\n if (mediaValue && mediaValue.mimeType) {\n // Handle media with resolutions structure\n if (\n mediaValue.resolutions &&\n mediaValue.resolutions.original &&\n mediaValue.resolutions.original.url\n ) {\n return mediaValue.resolutions.original.url;\n }\n\n // Handle direct URL on media\n if (mediaValue.url) {\n return mediaValue.url;\n }\n }\n return null;\n }\n\n if (isBlock) {\n if (typeof imageBlock === \"string\") {\n return imageBlock;\n }\n\n if (imageBlock.url) {\n return imageBlock.url;\n }\n }\n\n if (\n imageBlock.resolutions &&\n imageBlock.resolutions.original &&\n imageBlock.resolutions.original.url\n ) {\n return imageBlock.resolutions.original.url;\n }\n\n return null;\n};\n\nexport const translateMap = (\n labels: any,\n lang: string,\n fallback = \"unknown\"\n) => {\n let parsedLang = \"en\";\n\n if (lang === \"sr\") {\n parsedLang = \"bih\";\n }\n\n if (!labels) {\n return fallback;\n }\n\n const label = labels[parsedLang];\n if (!label) {\n return fallback;\n }\n\n return label;\n};\n","// Error handling utilities (combined from errorCodes.ts and errorHelpers.ts)\n\n// Comprehensive error code system with both numeric codes and named constants\nexport const ERROR_CODES = {\n // General errors\n \"GENERAL.001\": \"GENERAL.BAD_REQUEST\",\n \"GENERAL.002\": \"GENERAL.VALIDATION_ERROR\",\n \"GENERAL.003\": \"GENERAL.FORBIDDEN_ERROR\",\n \"GENERAL.004\": \"GENERAL.INTERNAL_SERVER_ERROR\",\n \"GENERAL.005\": \"GENERAL.UNAUTHORIZED\",\n \"GENERAL.006\": \"GENERAL.UNAUTHENTICATED\",\n\n // Google/OAuth errors\n \"GOOGLE.001\": \"GOOGLE.INVALID_ORIGIN_URI\",\n \"GOOGLE.002\": \"GOOGLE.INVALID_REDIRECT_URI\",\n \"GOOGLE.003\": \"GOOGLE.FAILED_TO_CALL_API\",\n \"GOOGLE.004\": \"GOOGLE.FAILED_LOGIN\",\n \"GOOGLE.005\": \"GOOGLE.FAILED_LOGOUT\",\n \"GOOGLE.006\": \"GOOGLE.FAILED_REFRESH_TOKEN\",\n \"GOOGLE.007\": \"GOOGLE.INVALID_PROVIDER_PASSED\",\n\n // User errors\n \"USER.001\": \"USER.NOT_FOUND\",\n \"USER.002\": \"USER.FAILED_TO_CREATE\",\n \"USER.003\": \"USER.FAILED_TO_UPDATE\",\n \"USER.004\": \"USER.FAILED_TO_DELETE\",\n \"USER.005\": \"USER.EMAIL_EXISTS\",\n \"USER.006\": \"USER.FAILED_TO_GET_UPLOAD_URL\",\n\n // Business errors\n \"BUSINESS.001\": \"BUSINESS.NOT_FOUND\",\n \"BUSINESS.002\": \"BUSINESS.FAILED_TO_CREATE\",\n \"BUSINESS.003\": \"BUSINESS.FAILED_TO_UPDATE\",\n \"BUSINESS.004\": \"BUSINESS.FAILED_TO_DELETE\",\n \"BUSINESS.005\": \"BUSINESS.FAILED_TO_GET_UPLOAD_URL\",\n \"BUSINESS.006\": \"BUSINESS.NAME_REQUIRED\",\n \"BUSINESS.007\": \"BUSINESS.BUSINESS_ID_REQUIRED\",\n \"BUSINESS.010\": \"BUSINESS.DESCRIPTION_REQUIRED\",\n \"BUSINESS.011\": \"BUSINESS.SLUG_INVALID\",\n\n // Provider errors\n \"PROVIDER.001\": \"PROVIDER.NOT_FOUND\",\n \"PROVIDER.002\": \"PROVIDER.FAILED_TO_CREATE\",\n \"PROVIDER.003\": \"PROVIDER.FAILED_TO_UPDATE\",\n \"PROVIDER.004\": \"PROVIDER.FAILED_TO_DELETE\",\n \"PROVIDER.005\": \"PROVIDER.FAILED_TO_GET_UPLOAD_URL\",\n \"PROVIDER.006\": \"PROVIDER.NAME_REQUIRED\",\n \"PROVIDER.007\": \"PROVIDER.BUSINESS_ID_REQUIRED\",\n \"PROVIDER.008\": \"PROVIDER.DESCRIPTION_REQUIRED\",\n};\n\n// Named error constants for direct access\nexport const ERROR_CONSTANTS = {\n GENERAL: {\n BAD_REQUEST: \"GENERAL.BAD_REQUEST\",\n VALIDATION_ERROR: \"GENERAL.VALIDATION_ERROR\",\n FORBIDDEN_ERROR: \"GENERAL.FORBIDDEN_ERROR\",\n INTERNAL_SERVER_ERROR: \"GENERAL.INTERNAL_SERVER_ERROR\",\n UNAUTHORIZED: \"GENERAL.UNAUTHORIZED\",\n UNAUTHENTICATED: \"GENERAL.UNAUTHENTICATED\",\n },\n USER: {\n NOT_FOUND: \"USER.NOT_FOUND\",\n FAILED_TO_CREATE: \"USER.FAILED_TO_CREATE\",\n FAILED_TO_UPDATE: \"USER.FAILED_TO_UPDATE\",\n FAILED_TO_DELETE: \"USER.FAILED_TO_DELETE\",\n EMAIL_EXISTS: \"USER.EMAIL_EXISTS\",\n FAILED_TO_GET_UPLOAD_URL: \"USER.FAILED_TO_GET_UPLOAD_URL\",\n },\n BUSINESS: {\n NOT_FOUND: \"BUSINESS.NOT_FOUND\",\n FAILED_TO_CREATE: \"BUSINESS.FAILED_TO_CREATE\",\n FAILED_TO_UPDATE: \"BUSINESS.FAILED_TO_UPDATE\",\n FAILED_TO_DELETE: \"BUSINESS.FAILED_TO_DELETE\",\n FAILED_TO_GET_UPLOAD_URL: \"BUSINESS.FAILED_TO_GET_UPLOAD_URL\",\n NAME_REQUIRED: \"BUSINESS.NAME_REQUIRED\",\n BUSINESS_ID_REQUIRED: \"BUSINESS.BUSINESS_ID_REQUIRED\",\n DESCRIPTION_REQUIRED: \"BUSINESS.DESCRIPTION_REQUIRED\",\n SLUG_INVALID: \"BUSINESS.SLUG_INVALID\",\n },\n};\n\nexport type ServerError = {\n message: string;\n error: string;\n statusCode: number;\n validationErrors: {\n field: string;\n error: string;\n }[];\n};\n\nexport type ValidationError = {\n field: string;\n error: string;\n};\n\nexport type RequestError = {\n validationErrors: ValidationError[];\n};\n\n// Utility functions for error handling\nexport function getErrorMessage(code: string): string {\n return ERROR_CODES[code as keyof typeof ERROR_CODES] || code;\n}\n\nexport function isErrorCode(code: string): boolean {\n return code in ERROR_CODES;\n}\n\nexport const transformErrors = (zodError: any): ValidationError[] => {\n const customErrors: ValidationError[] = [];\n\n if (!zodError.issues) return customErrors;\n\n zodError.issues.forEach((issue: any) => {\n const field = issue.path.join(\".\");\n const error = issue.message;\n\n if (\n !customErrors.some(\n (customError) =>\n customError.field === field && customError.error === error\n )\n ) {\n customErrors.push({ field, error });\n }\n });\n\n return customErrors;\n};\n\nexport const convertServerErrorToRequestError = (\n serverError: ServerError,\n renameRules?: { [key: string]: string }\n): RequestError => {\n return {\n ...serverError,\n validationErrors: serverError.validationErrors.map((validationError) => {\n const field =\n renameRules && renameRules[validationError.field]\n ? renameRules[validationError.field]\n : validationError.field;\n\n return {\n field: field,\n error: validationError.error || \"GENERAL.VALIDATION_ERROR\",\n };\n }),\n };\n};\n\n// Export for backward compatibility\nexport const errors = ERROR_CONSTANTS;\nexport default ERROR_CODES;\n","/**\n * Maps currency codes to their display symbols\n */\nexport function getCurrencySymbol(currency: string): string {\n const currencySymbols: Record<string, string> = {\n USD: '$',\n EUR: '€',\n GBP: '£',\n CAD: 'C$',\n AUD: 'A$',\n JPY: '¥',\n CHF: 'CHF',\n SEK: 'kr',\n NOK: 'kr',\n DKK: 'kr',\n PLN: 'zł',\n CZK: 'Kč',\n HUF: 'Ft',\n RON: 'lei',\n BGN: 'лв',\n HRK: 'kn',\n RSD: 'дин',\n BAM: 'KM',\n MKD: 'ден',\n ALL: 'L',\n TRY: '₺',\n RUB: '₽',\n UAH: '₴',\n BYN: 'Br',\n CNY: '¥',\n INR: '₹',\n KRW: '₩',\n THB: '฿',\n VND: '₫',\n SGD: 'S$',\n MYR: 'RM',\n IDR: 'Rp',\n PHP: '₱',\n BRL: 'R$',\n ARS: '$',\n CLP: '$',\n COP: '$',\n PEN: 'S/',\n MXN: '$',\n ZAR: 'R',\n EGP: 'E£',\n NGN: '₦',\n KES: 'KSh',\n GHS: '₵',\n MAD: 'DH',\n TND: 'د.ت',\n DZD: 'د.ج',\n LYD: 'ل.د',\n AED: 'د.إ',\n SAR: 'ر.س',\n QAR: 'ر.ق',\n KWD: 'د.ك',\n BHD: 'ب.د',\n OMR: 'ر.ع',\n JOD: 'د.أ',\n LBP: 'ل.ل',\n SYP: 'ل.س',\n IQD: 'ع.د',\n IRR: '﷼',\n AFN: '؋',\n PKR: '₨',\n LKR: '₨',\n NPR: '₨',\n BDT: '৳',\n MMK: 'K',\n LAK: '₭',\n KHR: '៛',\n MNT: '₮',\n KZT: '₸',\n UZS: 'лв',\n KGS: 'лв',\n TJS: 'SM',\n TMT: 'T',\n AZN: '₼',\n GEL: '₾',\n AMD: '֏',\n BYR: 'p.',\n MDL: 'L'\n };\n\n return currencySymbols[currency.toUpperCase()] || currency;\n}\n\n/**\n * List of currencies where the symbol appears after the amount\n */\nexport const SYMBOL_AFTER_CURRENCIES = ['SEK', 'NOK', 'DKK', 'PLN', 'CZK', 'HUF', 'RON', 'BGN', 'HRK'];\n\n/**\n * Check if currency symbol should be placed after the amount\n */\nexport function isSymbolAfterCurrency(currency: string): boolean {\n return SYMBOL_AFTER_CURRENCIES.includes(currency.toUpperCase());\n}","// Price formatting utilities - Centralized currency and price operations\nimport type { Payment, PaymentMethodType, Price } from '../types';\nimport { getCurrencySymbol, isSymbolAfterCurrency } from './currency';\n\nconst MARKET_CURRENCIES = {\n 'US': 'USD',\n 'EU': 'EUR',\n 'UK': 'GBP',\n 'CA': 'CAD',\n 'AU': 'AUD'\n} as const;\n\n// Convert minor units (cents) to major units (dollars)\nexport function convertToMajor(minorAmount: number): number {\n return (minorAmount ?? 0) / 100;\n}\n\n// Convert major units to minor units\nexport function convertToMinor(majorAmount: number): number {\n return Math.round((majorAmount ?? 0) * 100);\n}\n\n// Get currency from market ID\nexport function getCurrencyFromMarket(marketId: string): string {\n return MARKET_CURRENCIES[marketId as keyof typeof MARKET_CURRENCIES] || 'USD';\n}\n\n// Format currency amount with symbol (locale-aware positioning)\nexport function formatCurrencyAmount(\n amount: number,\n currency: string,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n customSymbol?: string;\n } = {}\n): string {\n const { showSymbols = true, decimalPlaces = 2, customSymbol } = options;\n const roundedAmount = amount.toFixed(decimalPlaces);\n\n if (!showSymbols) {\n return `${roundedAmount} ${currency}`;\n }\n\n const symbol = customSymbol || getCurrencySymbol(currency);\n\n // Use locale-specific symbol positioning\n if (isSymbolAfterCurrency(currency)) {\n return `${roundedAmount} ${symbol}`;\n }\n\n return `${symbol}${roundedAmount}`;\n}\n\n// Format minor units with currency\nexport function formatMinor(\n amountMinor: number,\n currency: string,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n customSymbol?: string;\n } = {}\n): string {\n const major = convertToMajor(amountMinor);\n return formatCurrencyAmount(major, currency, options);\n}\n\n// Format Payment structure for display\nexport function formatPayment(\n payment: Payment,\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n showBreakdown?: boolean;\n } = {}\n): string {\n if (!payment) return '';\n\n const { showSymbols = true, decimalPlaces = 2, showBreakdown = false } = options;\n\n if (showBreakdown) {\n const subtotal = formatMinor(payment.subtotal, payment.currency, { showSymbols, decimalPlaces });\n const discount = (payment.discount ?? 0) > 0 ? formatMinor(payment.discount, payment.currency, { showSymbols, decimalPlaces }) : null;\n const taxAmount = payment.tax?.amount ?? 0;\n const tax = taxAmount > 0 ? formatMinor(taxAmount, payment.currency, { showSymbols, decimalPlaces }) : null;\n const total = formatMinor(payment.total, payment.currency, { showSymbols, decimalPlaces });\n\n let result = `Subtotal: ${subtotal}`;\n if (discount) result += `, Discount: -${discount}`;\n if (tax) result += `, Tax: ${tax}`;\n result += `, Total: ${total}`;\n return result;\n }\n\n return formatMinor(payment.total, payment.currency, { showSymbols, decimalPlaces });\n}\n\n// Format market-based prices (from product variants)\nexport function getMarketPrice(\n prices: Price[],\n marketId: string,\n businessMarkets?: any[],\n options: {\n showSymbols?: boolean;\n decimalPlaces?: number;\n showCompareAt?: boolean;\n fallbackMarket?: string;\n } = {}\n): string {\n if (!prices || prices.length === 0) return '';\n\n const {\n showSymbols = true,\n decimalPlaces = 2,\n showCompareAt = true,\n fallbackMarket,\n } = options;\n\n // Find price for the specific market\n let price = prices.find(p => p.market === marketId);\n\n // Fallback to fallback market (if provided) or first available\n if (!price && fallbackMarket) {\n price = prices.find(p => p.market === fallbackMarket);\n }\n if (!price) {\n price = prices[0];\n }\n\n if (!price) return '';\n\n let currency: string;\n let symbol: string;\n\n // If we have business markets, use the currency directly from market data\n if (businessMarkets) {\n const marketData = businessMarkets.find(m => m.id === price.market || m.code === price.market);\n if (marketData?.currency) {\n currency = marketData.currency;\n symbol = getCurrencySymbol(currency);\n } else {\n currency = getCurrencyFromMarket(price.market);\n symbol = getCurrencySymbol(currency);\n }\n } else {\n currency = getCurrencyFromMarket(price.market);\n symbol = getCurrencySymbol(currency);\n }\n\n // Format price with custom symbol\n const formattedPrice = formatMinor(price.amount ?? 0, currency, {\n showSymbols,\n decimalPlaces,\n customSymbol: symbol\n });\n\n // Add compare-at price if available\n if (showCompareAt && price.compareAt && price.compareAt > (price.amount ?? 0)) {\n const formattedCompareAt = formatMinor(price.compareAt, currency, {\n showSymbols,\n decimalPlaces,\n customSymbol: symbol\n });\n return `${formattedPrice} was ${formattedCompareAt}`;\n }\n\n return formattedPrice;\n}\n\n// Get price amount from market-based prices (for calculations)\nexport function getPriceAmount(prices: Price[], marketId: string, fallbackMarket?: string): number {\n if (!prices || prices.length === 0) return 0;\n\n let price = prices.find(p => p.market === marketId);\n if (!price && fallbackMarket) {\n price = prices.find(p => p.market === fallbackMarket);\n }\n if (!price) {\n price = prices[0];\n }\n\n // Amounts are stored in minor units (e.g., cents)\n return price?.amount || 0;\n}\n\n// Create Payment structure for checkout (all amounts in minor units)\nexport function createPaymentForCheckout(\n subtotalMinor: number,\n marketId: string,\n currency: string,\n paymentMethod: any,\n options: {\n discount?: number;\n taxAmount?: number;\n taxRateBps?: number;\n promoCode?: {\n id: string;\n code: string;\n type: string;\n value: number;\n };\n } = {}\n): Payment {\n const { discount = 0, taxAmount = 0, taxRateBps = 0, promoCode } = options;\n const total = subtotalMinor - discount + taxAmount;\n\n return {\n currency,\n market: marketId,\n subtotal: subtotalMinor,\n shipping: 0,\n discount,\n total,\n type: paymentMethod,\n ...(taxAmount > 0 && {\n tax: {\n amount: taxAmount,\n rateBps: taxRateBps,\n lines: [],\n },\n }),\n ...(promoCode && { promoCode }),\n };\n}\n","import { getImageUrl } from \"./blocks\";\n\nexport async function fetchSvgContent(mediaObject: any): Promise<string | null> {\n\tif (!mediaObject) return null;\n\n\tconst svgUrl = getImageUrl(mediaObject, false);\n\n\ttry {\n\t\tconst response = await fetch(svgUrl);\n\n\t\tif (!response.ok) {\n\t\t\tconsole.error(`Failed to fetch SVG: ${response.status} ${response.statusText}`);\n\t\t\treturn null;\n\t\t}\n\n\t\tconst svgContent = await response.text();\n\t\treturn svgContent;\n\t} catch (error) {\n\t\tconsole.error(\"Error fetching SVG:\", error);\n\t\treturn null;\n\t}\n}\n\n/**\n * Server-side helper for Astro components to fetch SVG content during SSR\n *\n * @param mediaObject The media object from the CMS\n * @returns The SVG content as a string, or empty string on failure\n */\nexport async function getSvgContentForAstro(mediaObject: any): Promise<string> {\n\ttry {\n\t\tconst svgContent = await fetchSvgContent(mediaObject);\n\t\treturn svgContent || \"\";\n\t} catch (error) {\n\t\tconsole.error(\"Error getting SVG content for Astro:\", error);\n\t\treturn \"\";\n\t}\n}\n\n/**\n * Client-side helper to fetch and inject SVG content into DOM elements\n *\n * @param mediaObject The media object from the CMS\n * @param targetElement The DOM element to inject the SVG into\n * @param className Optional CSS class to add to the SVG\n */\nexport async function injectSvgIntoElement(\n\tmediaObject: any,\n\ttargetElement: HTMLElement,\n\tclassName?: string,\n): Promise<void> {\n\tif (!targetElement) return;\n\n\ttry {\n\t\tconst svgContent = await fetchSvgContent(mediaObject);\n\n\t\tif (svgContent) {\n\t\t\ttargetElement.innerHTML = svgContent;\n\n\t\t\t// Add class if provided\n\t\t\tif (className) {\n\t\t\t\tconst svgElement = targetElement.querySelector(\"svg\");\n\t\t\t\tif (svgElement) {\n\t\t\t\t\tsvgElement.classList.add(...className.split(\" \"));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} catch (error) {\n\t\tconsole.error(\"Error injecting SVG:\", error);\n\t}\n}","// Define locales inline since we don't have @lib/i18n in SDK\nconst locales = ['en', 'sr-latn'] as const;\nconst localeMap: Record<typeof locales[number], string> = {\n\t'en': 'en-US',\n\t'sr-latn': 'sr-RS'\n};\n\n/**\n * * returns \"slugified\" text.\n * @param text: string - text to slugify\n */\nexport function slugify(text: string): string {\n\treturn text\n\t\t.toString()\n\t\t.toLowerCase() // convert to lowercase\n\t\t.replace(/\\s+/g, \"-\") // replace spaces with -\n\t\t.replace(/[^\\w-]+/g, \"\") // remove all non-word chars\n\t\t.replace(/--+/g, \"-\") // replace multiple dashes with single dash\n\t\t.replace(/^-+/, \"\") // trim dash from start of text\n\t\t.replace(/-+$/, \"\"); // trim dash from end of text\n}\n\n/**\n * * returns \"humanized\" text. runs slugify() and then replaces - with space and upper case first letter of every word, and lower case the rest\n * @param text: string - text to humanize\n */\nexport function humanize(text: string): string {\n\tconst slugifiedText = slugify(text);\n\treturn (\n\t\tslugifiedText\n\t\t\t.replace(/-/g, \" \") // replace \"-\" with space\n\t\t\t// .toLowerCase();\n\t\t\t.replace(\n\t\t\t\t// upper case first letter of every word, and lower case the rest\n\t\t\t\t/\\w\\S*/g,\n\t\t\t\t(w) => w.charAt(0).toUpperCase() + w.slice(1).toLowerCase(),\n\t\t\t)\n\t);\n}\n\n// --------------------------------------------------------\n/**\n * * returns \"categorified\" text. runs slugify() and then replaces - with space and upper cases everything\n * @param text: string - text to categorify\n * @returns string - categorified text\n */\nexport function categorify(text: string): string {\n\tconst slugifiedText = slugify(text);\n\treturn slugifiedText\n\t\t.replace(/-/g, \" \") // replace \"-\" with space\n\t\t.toUpperCase();\n}\n\n// --------------------------------------------------------\n/**\n * * returns a nicely formatted string of the date passed\n * @param date: string | number | Date - date to format\n * @param locale: string - locale to format the date in\n * @returns string - formatted date\n */\nexport function formatDate(date: string | number | Date, locale: (typeof locales)[number]): string {\n\tlet localeString = \"en-US\";\n\n\tif (locales.includes(locale)) {\n\t\tlocaleString = localeMap[locale];\n\t}\n\n\treturn new Date(date).toLocaleDateString(localeString, {\n\t\ttimeZone: \"UTC\",\n\t\tyear: \"numeric\",\n\t\tmonth: \"short\",\n\t\tday: \"numeric\",\n\t});\n}","// Timezone utilities (moved from Reservation folder)\n\nexport const tzGroups = [\n {\n label: \"US\",\n zones: [\n { label: \"Eastern Time\", value: \"America/New_York\" },\n { label: \"Central Time\", value: \"America/Chicago\" },\n { label: \"Mountain Time\", value: \"America/Denver\" },\n { label: \"Pacific Time\", value: \"America/Los_Angeles\" },\n ],\n },\n {\n label: \"Europe\",\n zones: [\n { label: \"London\", value: \"Europe/London\" },\n { label: \"Paris\", value: \"Europe/Paris\" },\n { label: \"Berlin\", value: \"Europe/Berlin\" },\n { label: \"Rome\", value: \"Europe/Rome\" },\n ],\n },\n {\n label: \"Asia\",\n zones: [\n { label: \"Tokyo\", value: \"Asia/Tokyo\" },\n { label: \"Shanghai\", value: \"Asia/Shanghai\" },\n { label: \"Mumbai\", value: \"Asia/Kolkata\" },\n { label: \"Dubai\", value: \"Asia/Dubai\" },\n ],\n },\n];\n\nexport function findTimeZone(groups: typeof tzGroups): string {\n try {\n const detected = Intl.DateTimeFormat().resolvedOptions().timeZone;\n \n // Check if detected timezone is in our list\n for (const group of groups) {\n for (const zone of group.zones) {\n if (zone.value === detected) {\n return detected;\n }\n }\n }\n \n // Fallback to UTC if not found\n return \"UTC\";\n } catch (e) {\n // Fallback to UTC if detection fails\n return \"UTC\";\n }\n}","// Validation utilities\n\nexport interface ValidationResult {\n isValid: boolean;\n error?: string;\n}\n\n// Phone number validation\nexport function validatePhoneNumber(phone: string): ValidationResult {\n if (!phone) {\n return { isValid: false, error: 'Phone number is required' };\n }\n \n const cleaned = phone.replace(/\\D/g, '');\n \n if (cleaned.length < 8) {\n return { isValid: false, error: 'Phone number is too short' };\n }\n \n if (cleaned.length > 15) {\n return { isValid: false, error: 'Phone number is too long' };\n }\n \n return { isValid: true };\n}\n\n// Email validation\nexport function validateEmail(email: string): ValidationResult {\n if (!email) {\n return { isValid: false, error: 'Email is required' };\n }\n \n const emailRegex = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\n \n if (!emailRegex.test(email)) {\n return { isValid: false, error: 'Please enter a valid email address' };\n }\n \n return { isValid: true };\n}\n\n// Verification code validation (4-digit codes)\nexport function validateVerificationCode(code: string): ValidationResult {\n if (!code) {\n return { isValid: false, error: 'Verification code is required' };\n }\n \n const cleaned = code.replace(/\\D/g, '');\n \n if (cleaned.length !== 4) {\n return { isValid: false, error: 'Please enter a 4-digit verification code' };\n }\n \n return { isValid: true };\n}\n\n// Generic required field validation\nexport function validateRequired(value: any, fieldName: string = 'This field'): ValidationResult {\n if (value === null || value === undefined || value === '') {\n return { isValid: false, error: `${fieldName} is required` };\n }\n \n return { isValid: true };\n}","// Time formatting utilities for reservations\r\n\r\n/**\r\n * Format a Unix timestamp to a localized time string\r\n */\r\nexport function formatTime(ts: number, tz: string): string {\r\n return new Date(ts * 1000).toLocaleTimeString([], {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n timeZone: tz,\r\n });\r\n}\r\n\r\n/**\r\n * Format a slot time range (from-to) as a string\r\n */\r\nexport function formatSlotTime(from: number, to: number, tz: string): string {\r\n return `${formatTime(from, tz)} – ${formatTime(to, tz)}`;\r\n}\r\n\r\n/**\r\n * Get the timezone offset in minutes for a given date and timezone\r\n */\r\nexport function getTzOffset(date: Date, tz: string): number {\r\n const utc = new Date(date.toLocaleString(\"en-US\", { timeZone: \"UTC\" }));\r\n const local = new Date(date.toLocaleString(\"en-US\", { timeZone: tz }));\r\n return (utc.getTime() - local.getTime()) / 60000;\r\n}\r\n\r\n/**\r\n * Convert local time components to a UTC Unix timestamp\r\n */\r\nexport function toUtcTimestamp(\r\n year: number,\r\n month: number,\r\n day: number,\r\n mins: number,\r\n tz: string\r\n): number {\r\n const midnight = new Date(Date.UTC(year, month - 1, day));\r\n const offset = getTzOffset(midnight, tz);\r\n return Math.floor(midnight.getTime() / 1000) + (mins + offset) * 60;\r\n}\r\n\r\n/**\r\n * Format a date for display (e.g., \"Mon, Jan 15\")\r\n */\r\nexport function formatDateDisplay(dateStr: string | null, tz?: string): string {\r\n if (!dateStr) return \"\";\r\n const date = new Date(dateStr + \"T00:00:00\");\r\n return date.toLocaleDateString(\"en-US\", {\r\n weekday: \"short\",\r\n month: \"short\",\r\n day: \"numeric\",\r\n timeZone: tz,\r\n });\r\n}\r\n\r\n/**\r\n * Get ISO date string (YYYY-MM-DD) for a date in a specific timezone\r\n */\r\nexport function getIsoDate(date: Date, tz: string): string {\r\n return date.toLocaleDateString(\"en-CA\", { timeZone: tz });\r\n}\r\n\r\n/**\r\n * Parse ISO date string components\r\n */\r\nexport function parseIsoDate(isoDate: string): { year: number; month: number; day: number } {\r\n const [year, month, day] = isoDate.split(\"-\").map(Number);\r\n return { year, month, day };\r\n}\r\n","// Slot computation utilities for reservations\r\n\r\nimport { toUtcTimestamp } from \"./time\";\r\n\r\n// ============================================================================\r\n// Types\r\n// ============================================================================\r\n\r\nexport interface ServiceDuration {\r\n duration: number;\r\n isPause?: boolean;\r\n}\r\n\r\nexport interface WorkingHours {\r\n from: number;\r\n to: number;\r\n}\r\n\r\nexport interface WorkingDay {\r\n day: string;\r\n workingHours: WorkingHours[];\r\n}\r\n\r\nexport interface SpecificDate {\r\n date: number;\r\n workingHours: WorkingHours[];\r\n}\r\n\r\nexport interface OutcastDate {\r\n month: number;\r\n day: number;\r\n workingHours: WorkingHours[];\r\n}\r\n\r\nexport interface WorkingTime {\r\n workingDays?: WorkingDay[];\r\n specificDates?: SpecificDate[];\r\n outcastDates?: OutcastDate[];\r\n}\r\n\r\nexport interface TimelinePoint {\r\n timestamp: number;\r\n concurrent: number;\r\n}\r\n\r\nexport interface ProviderWithTimeline {\r\n id: string;\r\n workingTime?: WorkingTime;\r\n timeline: TimelinePoint[];\r\n concurrentLimit: number;\r\n}\r\n\r\nexport interface AvailableSlot {\r\n from: number;\r\n to: number;\r\n providerId: string;\r\n}\r\n\r\nexport interface ComputeSlotsOptions {\r\n providers: ProviderWithTimeline[];\r\n date: Date;\r\n durations: ServiceDuration[];\r\n timezone: string;\r\n slotInterval?: number;\r\n}\r\n\r\n// ============================================================================\r\n// Helper Functions\r\n// ============================================================================\r\n\r\n/**\r\n * Calculate total duration from an array of service durations\r\n */\r\nexport function getTotalDuration(durations: ServiceDuration[]): number {\r\n return durations.reduce((sum, d) => sum + d.duration, 0);\r\n}\r\n\r\n/**\r\n * Check if a time slot is blocked by existing reservations\r\n */\r\nexport function isBlocked(\r\n from: number,\r\n to: number,\r\n timeline: TimelinePoint[],\r\n limit: number\r\n): boolean {\r\n // Check concurrent bookings at slot start\r\n const before = timeline\r\n .filter((p) => p.timestamp <= from)\r\n .sort((a, b) => b.timestamp - a.timestamp);\r\n if (before.length > 0 && before[0].concurrent >= limit) return true;\r\n\r\n // Check concurrent bookings during the slot\r\n for (const p of timeline) {\r\n if (p.timestamp >= from && p.timestamp < to && p.concurrent >= limit) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n}\r\n\r\n/**\r\n * Get working hours for a specific date, considering:\r\n * 1. Specific dates (exact date overrides)\r\n * 2. Outcast dates (recurring monthly overrides)\r\n * 3. Working days (regular weekly schedule)\r\n */\r\nexport function getWorkingHoursForDate(\r\n wt: WorkingTime | undefined,\r\n date: Date,\r\n tz: string\r\n): WorkingHours[] {\r\n if (!wt) return [];\r\n\r\n const dayName = date\r\n .toLocaleDateString(\"en-US\", { weekday: \"long\", timeZone: tz })\r\n .toLowerCase();\r\n const m = date.getMonth() + 1;\r\n const d = date.getDate();\r\n const ts = Math.floor(date.getTime() / 1000);\r\n\r\n // Check specific dates first (highest priority)\r\n const specific = wt.specificDates?.find((s) => s.date === ts);\r\n if (specific) return specific.workingHours || [];\r\n\r\n // Check outcast dates (recurring monthly)\r\n const outcast = wt.outcastDates?.find((o) => o.month === m && o.day === d);\r\n if (outcast) return outcast.workingHours || [];\r\n\r\n // Fall back to regular working days\r\n return wt.workingDays?.find((w) => w.day === dayName)?.workingHours || [];\r\n}\r\n\r\n// ============================================================================\r\n// Main Slot Computation\r\n// ============================================================================\r\n\r\n/**\r\n * Compute all available slots for a given date\r\n */\r\nexport function computeSlotsForDate(opts: ComputeSlotsOptions): AvailableSlot[] {\r\n const { providers, date, durations, timezone, slotInterval } = opts;\r\n\r\n const total = getTotalDuration(durations);\r\n const interval = slotInterval || total;\r\n const slots: AvailableSlot[] = [];\r\n const nowTs = Math.floor(Date.now() / 1000);\r\n\r\n // Don't compute slots for past dates\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n if (date < today) return [];\r\n\r\n // Get date components in the target timezone\r\n const [year, month, day] = date\r\n .toLocaleDateString(\"en-CA\", { timeZone: timezone })\r\n .split(\"-\")\r\n .map(Number);\r\n\r\n for (const provider of providers) {\r\n const workingHours = getWorkingHoursForDate(provider.workingTime, date, timezone);\r\n\r\n for (const wh of workingHours) {\r\n // Generate slots at intervals within working hours\r\n for (let m = wh.from; m + total <= wh.to; m += interval) {\r\n const from = toUtcTimestamp(year, month, day, m, timezone);\r\n const to = from + total * 60;\r\n\r\n // Skip past slots\r\n if (from < nowTs) continue;\r\n\r\n // Check if slot is available\r\n if (!isBlocked(from, to, provider.timeline, provider.concurrentLimit)) {\r\n slots.push({ from, to, providerId: provider.id });\r\n }\r\n }\r\n }\r\n }\r\n\r\n return slots.sort((a, b) => a.from - b.from);\r\n}\r\n\r\n/**\r\n * Check if a date has any available slots\r\n */\r\nexport function hasAvailableSlots(opts: ComputeSlotsOptions): boolean {\r\n return computeSlotsForDate(opts).length > 0;\r\n}\r\n\r\n// ============================================================================\r\n// Calendar Building\r\n// ============================================================================\r\n\r\nexport interface CalendarDay {\r\n date: Date;\r\n iso: string;\r\n available: boolean;\r\n isSelected: boolean;\r\n isInRange: boolean;\r\n isToday: boolean;\r\n blank: boolean;\r\n}\r\n\r\nexport interface BuildCalendarOptions {\r\n currentMonth: Date;\r\n selectedDate: string | null;\r\n startDate: string | null;\r\n endDate: string | null;\r\n providers: ProviderWithTimeline[];\r\n selectedProvider: ProviderWithTimeline | null;\r\n durations: ServiceDuration[];\r\n timezone: string;\r\n isMultiDay: boolean;\r\n}\r\n\r\n/**\r\n * Build a calendar grid for a month with availability info\r\n */\r\nexport function buildCalendar(opts: BuildCalendarOptions): CalendarDay[] {\r\n const {\r\n currentMonth,\r\n selectedDate,\r\n startDate,\r\n endDate,\r\n providers,\r\n selectedProvider,\r\n durations,\r\n timezone,\r\n isMultiDay,\r\n } = opts;\r\n\r\n const year = currentMonth.getFullYear();\r\n const month = currentMonth.getMonth();\r\n const first = new Date(year, month, 1);\r\n const last = new Date(year, month + 1, 0);\r\n const today = new Date();\r\n today.setHours(0, 0, 0, 0);\r\n\r\n const cells: CalendarDay[] = [];\r\n\r\n // Pad start of month (Monday = 0)\r\n const pad = (first.getDay() + 6) % 7;\r\n for (let i = 0; i < pad; i++) {\r\n cells.push({\r\n date: new Date(0),\r\n iso: \"\",\r\n available: false,\r\n isSelected: false,\r\n isInRange: false,\r\n isToday: false,\r\n blank: true,\r\n });\r\n }\r\n\r\n // Filter providers if one is selected\r\n const activeProviders = selectedProvider\r\n ? providers.filter((p) => p.id === selectedProvider.id)\r\n : providers;\r\n\r\n // Build days\r\n for (let d = 1; d <= last.getDate(); d++) {\r\n const date = new Date(year, month, d);\r\n const iso = `${year}-${String(month + 1).padStart(2, \"0\")}-${String(d).padStart(2, \"0\")}`;\r\n\r\n const available =\r\n activeProviders.length > 0 &&\r\n hasAvailableSlots({ providers: activeProviders, date, durations, timezone });\r\n\r\n const isToday = date.getTime() === today.getTime();\r\n\r\n let isSelected = false;\r\n let isInRange = false;\r\n\r\n if (isMultiDay) {\r\n isSelected = iso === startDate || iso === endDate;\r\n if (startDate && endDate) {\r\n isInRange = iso > startDate && iso < endDate;\r\n }\r\n } else {\r\n isSelected = iso === selectedDate;\r\n }\r\n\r\n cells.push({\r\n date,\r\n iso,\r\n available,\r\n isSelected,\r\n isInRange,\r\n isToday,\r\n blank: false,\r\n });\r\n }\r\n\r\n return cells;\r\n}\r\n\r\n/**\r\n * Get month and year display string\r\n */\r\nexport function getMonthYear(date: Date): string {\r\n return date.toLocaleDateString(\"en-US\", { month: \"long\", year: \"numeric\" });\r\n}\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "arky-sdk",
3
- "version": "0.3.84",
3
+ "version": "0.3.85",
4
4
  "description": "Official TypeScript SDK for Arky - All-in-one business platform",
5
5
  "type": "module",
6
6
  "main": "./dist/index.cjs",
@@ -1,133 +0,0 @@
1
- import { Price, Payment } from './types.cjs';
2
-
3
- interface Block {
4
- id: string;
5
- key: string;
6
- type: string;
7
- properties: any;
8
- value: any;
9
- }
10
- interface Collection {
11
- id: string;
12
- blocks: Block[];
13
- }
14
- interface CollectionEntry {
15
- id: string;
16
- collection_id: string;
17
- blocks: Block[];
18
- }
19
- declare function getBlockLabel(block: any, locale?: string): string;
20
- declare function formatBlockValue(block: any): string;
21
- declare function prepareBlocksForSubmission(formData: any): any[];
22
- declare function extractBlockValues(blocks: any[]): Record<string, any>;
23
- declare function getBlockTextValue(block: any, locale?: string): string;
24
- declare const getBlockValue: (entry: any, blockKey: string) => any;
25
- declare const getBlockValues: (entry: any, blockKey: string) => any;
26
- declare const getBlockObjectValues: (entry: any, blockKey: string, locale?: string) => any;
27
- declare const getBlockFromArray: (entry: any, blockKey: string, locale?: string) => any;
28
- declare const getImageUrl: (imageBlock: any, isBlock?: boolean) => any;
29
- declare const translateMap: (labels: any, lang: string, fallback?: string) => any;
30
-
31
- declare function convertToMajor(minorAmount: number): number;
32
- declare function convertToMinor(majorAmount: number): number;
33
- declare function getCurrencyFromMarket(marketId: string): string;
34
- declare function formatCurrencyAmount(amount: number, currency: string, options?: {
35
- showSymbols?: boolean;
36
- decimalPlaces?: number;
37
- customSymbol?: string;
38
- }): string;
39
- declare function formatMinor(amountMinor: number, currency: string, options?: {
40
- showSymbols?: boolean;
41
- decimalPlaces?: number;
42
- customSymbol?: string;
43
- }): string;
44
- declare function formatPayment(payment: Payment, options?: {
45
- showSymbols?: boolean;
46
- decimalPlaces?: number;
47
- showBreakdown?: boolean;
48
- }): string;
49
- declare function getMarketPrice(prices: Price[], marketId: string, businessMarkets?: any[], options?: {
50
- showSymbols?: boolean;
51
- decimalPlaces?: number;
52
- showCompareAt?: boolean;
53
- fallbackMarket?: string;
54
- }): string;
55
- declare function getPriceAmount(prices: Price[], marketId: string, fallbackMarket?: string): number;
56
- declare function createPaymentForCheckout(subtotalMinor: number, marketId: string, currency: string, paymentMethod: any, options?: {
57
- discount?: number;
58
- taxAmount?: number;
59
- taxRateBps?: number;
60
- promoCode?: {
61
- id: string;
62
- code: string;
63
- type: string;
64
- value: number;
65
- };
66
- }): Payment;
67
-
68
- /**
69
- * Maps currency codes to their display symbols
70
- */
71
- declare function getCurrencySymbol(currency: string): string;
72
-
73
- interface ValidationResult {
74
- isValid: boolean;
75
- error?: string;
76
- }
77
- declare function validatePhoneNumber(phone: string): ValidationResult;
78
- declare function validateEmail(email: string): ValidationResult;
79
- declare function validateVerificationCode(code: string): ValidationResult;
80
- declare function validateRequired(value: any, fieldName?: string): ValidationResult;
81
-
82
- declare const tzGroups: {
83
- label: string;
84
- zones: {
85
- label: string;
86
- value: string;
87
- }[];
88
- }[];
89
- declare function findTimeZone(groups: typeof tzGroups): string;
90
-
91
- declare const locales: readonly ["en", "sr-latn"];
92
- /**
93
- * * returns "slugified" text.
94
- * @param text: string - text to slugify
95
- */
96
- declare function slugify(text: string): string;
97
- /**
98
- * * returns "humanized" text. runs slugify() and then replaces - with space and upper case first letter of every word, and lower case the rest
99
- * @param text: string - text to humanize
100
- */
101
- declare function humanize(text: string): string;
102
- /**
103
- * * returns "categorified" text. runs slugify() and then replaces - with space and upper cases everything
104
- * @param text: string - text to categorify
105
- * @returns string - categorified text
106
- */
107
- declare function categorify(text: string): string;
108
- /**
109
- * * returns a nicely formatted string of the date passed
110
- * @param date: string | number | Date - date to format
111
- * @param locale: string - locale to format the date in
112
- * @returns string - formatted date
113
- */
114
- declare function formatDate(date: string | number | Date, locale: (typeof locales)[number]): string;
115
-
116
- declare function fetchSvgContent(mediaObject: any): Promise<string | null>;
117
- /**
118
- * Server-side helper for Astro components to fetch SVG content during SSR
119
- *
120
- * @param mediaObject The media object from the CMS
121
- * @returns The SVG content as a string, or empty string on failure
122
- */
123
- declare function getSvgContentForAstro(mediaObject: any): Promise<string>;
124
- /**
125
- * Client-side helper to fetch and inject SVG content into DOM elements
126
- *
127
- * @param mediaObject The media object from the CMS
128
- * @param targetElement The DOM element to inject the SVG into
129
- * @param className Optional CSS class to add to the SVG
130
- */
131
- declare function injectSvgIntoElement(mediaObject: any, targetElement: HTMLElement, className?: string): Promise<void>;
132
-
133
- export { translateMap as A, type Block as B, type Collection as C, convertToMajor as D, convertToMinor as E, getCurrencyFromMarket as F, formatCurrencyAmount as G, tzGroups as H, validateEmail as I, validateVerificationCode as J, validateRequired as K, type ValidationResult as V, getBlockTextValue as a, getMarketPrice as b, getPriceAmount as c, formatPayment as d, extractBlockValues as e, formatBlockValue as f, getBlockLabel as g, formatMinor as h, createPaymentForCheckout as i, getCurrencySymbol as j, findTimeZone as k, humanize as l, categorify as m, formatDate as n, getSvgContentForAstro as o, prepareBlocksForSubmission as p, fetchSvgContent as q, injectSvgIntoElement as r, slugify as s, type CollectionEntry as t, getBlockValue as u, validatePhoneNumber as v, getBlockValues as w, getBlockObjectValues as x, getBlockFromArray as y, getImageUrl as z };