@chrryai/chrry 1.7.5 → 1.7.6
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/index.js +368 -317
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +116 -65
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -3175,7 +3175,7 @@ var init_utils = __esm({
|
|
|
3175
3175
|
};
|
|
3176
3176
|
isFirefox = typeof navigator !== "undefined" && navigator?.userAgent?.includes("Firefox");
|
|
3177
3177
|
config = getSiteConfig(getClientHostname2());
|
|
3178
|
-
VERSION = config.version || "1.7.
|
|
3178
|
+
VERSION = config.version || "1.7.6";
|
|
3179
3179
|
getSlugFromPathname = (path) => {
|
|
3180
3180
|
return getAppAndStoreSlugs(path, {
|
|
3181
3181
|
defaultAppSlug: config.slug,
|
|
@@ -24688,7 +24688,7 @@ function DataProvider({ children, ...rest }) {
|
|
|
24688
24688
|
const [instructions, setInstructions] = (0, import_react21.useState)([]);
|
|
24689
24689
|
const [affiliateStats, setAffiliateStats] = (0, import_react21.useState)(null);
|
|
24690
24690
|
const [loadingAffiliateStats, setLoadingAffiliateStats] = (0, import_react21.useState)(false);
|
|
24691
|
-
const VERSION4 = "1.7.
|
|
24691
|
+
const VERSION4 = "1.7.6";
|
|
24692
24692
|
const [weather, setWeather] = useLocalStorage2("weather", user?.weather || guest?.weather || void 0);
|
|
24693
24693
|
const {
|
|
24694
24694
|
API_URL: API_URL2,
|
|
@@ -62631,18 +62631,19 @@ var init_EventModal = __esm({
|
|
|
62631
62631
|
{ value: "purple", label: t5("Purple"), color: COLORS.purple }
|
|
62632
62632
|
];
|
|
62633
62633
|
formatDateForInput = (date, isAllDay) => {
|
|
62634
|
-
|
|
62634
|
+
const dateObj = date instanceof Date ? date : new Date(date);
|
|
62635
|
+
if (isNaN(dateObj.getTime())) return "";
|
|
62635
62636
|
if (isAllDay) {
|
|
62636
|
-
const year =
|
|
62637
|
-
const month = String(
|
|
62638
|
-
const day = String(
|
|
62637
|
+
const year = dateObj.getFullYear();
|
|
62638
|
+
const month = String(dateObj.getMonth() + 1).padStart(2, "0");
|
|
62639
|
+
const day = String(dateObj.getDate()).padStart(2, "0");
|
|
62639
62640
|
return `${year}-${month}-${day}`;
|
|
62640
62641
|
} else {
|
|
62641
|
-
const year =
|
|
62642
|
-
const month = String(
|
|
62643
|
-
const day = String(
|
|
62644
|
-
const hours = String(
|
|
62645
|
-
const minutes = String(
|
|
62642
|
+
const year = dateObj.getFullYear();
|
|
62643
|
+
const month = String(dateObj.getMonth() + 1).padStart(2, "0");
|
|
62644
|
+
const day = String(dateObj.getDate()).padStart(2, "0");
|
|
62645
|
+
const hours = String(dateObj.getHours()).padStart(2, "0");
|
|
62646
|
+
const minutes = String(dateObj.getMinutes()).padStart(2, "0");
|
|
62646
62647
|
return `${year}-${month}-${day}T${hours}:${minutes}`;
|
|
62647
62648
|
}
|
|
62648
62649
|
};
|
|
@@ -62650,6 +62651,10 @@ var init_EventModal = __esm({
|
|
|
62650
62651
|
});
|
|
62651
62652
|
|
|
62652
62653
|
// Calendar.web.tsx
|
|
62654
|
+
var Calendar_web_exports = {};
|
|
62655
|
+
__export(Calendar_web_exports, {
|
|
62656
|
+
default: () => Calendar2
|
|
62657
|
+
});
|
|
62653
62658
|
function Calendar2({
|
|
62654
62659
|
onSelectEvent,
|
|
62655
62660
|
onSelectSlot,
|
|
@@ -62661,6 +62666,34 @@ function Calendar2({
|
|
|
62661
62666
|
className
|
|
62662
62667
|
}) {
|
|
62663
62668
|
const { actions } = useData();
|
|
62669
|
+
useHasHydrated();
|
|
62670
|
+
const [calendarEvents, setCalendarEvents] = (0, import_react90.useState)([]);
|
|
62671
|
+
const handleSelectEvent = (0, import_react90.useCallback)(
|
|
62672
|
+
(event, e) => {
|
|
62673
|
+
const fullEvent = calendarEvents.find((e2) => e2.id === event.id);
|
|
62674
|
+
setModalData({
|
|
62675
|
+
start: event.start || new Date(event.startTime),
|
|
62676
|
+
end: event.end || new Date(event.endTime),
|
|
62677
|
+
title: event.title,
|
|
62678
|
+
eventId: event.id,
|
|
62679
|
+
// Pass event ID for update
|
|
62680
|
+
description: fullEvent?.description,
|
|
62681
|
+
location: fullEvent?.location,
|
|
62682
|
+
color: fullEvent?.color,
|
|
62683
|
+
category: fullEvent?.category,
|
|
62684
|
+
isAllDay: fullEvent?.isAllDay,
|
|
62685
|
+
timezone: fullEvent?.timezone,
|
|
62686
|
+
attendees: fullEvent?.attendees,
|
|
62687
|
+
reminders: fullEvent?.reminders
|
|
62688
|
+
// recurrence: fullEvent?.recurrence,
|
|
62689
|
+
});
|
|
62690
|
+
setIsModalOpen(true);
|
|
62691
|
+
if (onSelectEvent) {
|
|
62692
|
+
onSelectEvent(event);
|
|
62693
|
+
}
|
|
62694
|
+
},
|
|
62695
|
+
[onSelectEvent, calendarEvents]
|
|
62696
|
+
);
|
|
62664
62697
|
const { t: t5 } = useAppContext();
|
|
62665
62698
|
const [date, setDate] = (0, import_react90.useState)(/* @__PURE__ */ new Date());
|
|
62666
62699
|
const {
|
|
@@ -62713,7 +62746,6 @@ function Calendar2({
|
|
|
62713
62746
|
return () => window.removeEventListener("popstate", handlePopState);
|
|
62714
62747
|
}, [defaultView]);
|
|
62715
62748
|
const hasCalendarScope = user?.hasCalendarScope;
|
|
62716
|
-
const [calendarEvents, setCalendarEvents] = (0, import_react90.useState)([]);
|
|
62717
62749
|
const [isGoogleConnected, setIsGoogleConnected] = (0, import_react90.useState)(!!hasCalendarScope);
|
|
62718
62750
|
const [isSyncing, setIsSyncing] = (0, import_react90.useState)(false);
|
|
62719
62751
|
const [calendarEventsStartDate, setCalendarEventsStartDate] = (0, import_react90.useState)(void 0);
|
|
@@ -62754,12 +62786,17 @@ function Calendar2({
|
|
|
62754
62786
|
calendarEvents.sort(
|
|
62755
62787
|
(a, b) => new Date(a.startTime).getTime() - new Date(b.startTime).getTime()
|
|
62756
62788
|
).forEach((calendarEvent) => {
|
|
62757
|
-
const dayKey = format(calendarEvent.startTime, "yyyy-MM-dd");
|
|
62789
|
+
const dayKey = format(new Date(calendarEvent.startTime), "yyyy-MM-dd");
|
|
62758
62790
|
if (!eventsByDay2[dayKey]) {
|
|
62759
62791
|
eventsByDay2[dayKey] = [];
|
|
62760
62792
|
}
|
|
62761
|
-
|
|
62762
|
-
|
|
62793
|
+
const transformedEvent = {
|
|
62794
|
+
...calendarEvent,
|
|
62795
|
+
start: new Date(calendarEvent.startTime),
|
|
62796
|
+
end: new Date(calendarEvent.endTime)
|
|
62797
|
+
};
|
|
62798
|
+
eventsByDay2[dayKey].push(transformedEvent);
|
|
62799
|
+
allEvents.push(transformedEvent);
|
|
62763
62800
|
});
|
|
62764
62801
|
const limitedEvents = [];
|
|
62765
62802
|
Object.values(eventsByDay2).forEach((dayEvents) => {
|
|
@@ -62804,32 +62841,6 @@ function Calendar2({
|
|
|
62804
62841
|
},
|
|
62805
62842
|
[onSelectSlot]
|
|
62806
62843
|
);
|
|
62807
|
-
const handleSelectEvent = (0, import_react90.useCallback)(
|
|
62808
|
-
(event, e) => {
|
|
62809
|
-
const fullEvent = calendarEvents.find((e2) => e2.id === event.id);
|
|
62810
|
-
setModalData({
|
|
62811
|
-
start: new Date(event.startTime),
|
|
62812
|
-
end: new Date(event.endTime),
|
|
62813
|
-
title: event.title,
|
|
62814
|
-
eventId: event.id,
|
|
62815
|
-
// Pass event ID for update
|
|
62816
|
-
description: fullEvent?.description,
|
|
62817
|
-
location: fullEvent?.location,
|
|
62818
|
-
color: fullEvent?.color,
|
|
62819
|
-
category: fullEvent?.category,
|
|
62820
|
-
isAllDay: fullEvent?.isAllDay,
|
|
62821
|
-
timezone: fullEvent?.timezone,
|
|
62822
|
-
attendees: fullEvent?.attendees,
|
|
62823
|
-
reminders: fullEvent?.reminders
|
|
62824
|
-
// recurrence: fullEvent?.recurrence,
|
|
62825
|
-
});
|
|
62826
|
-
setIsModalOpen(true);
|
|
62827
|
-
if (onSelectEvent) {
|
|
62828
|
-
onSelectEvent(event);
|
|
62829
|
-
}
|
|
62830
|
-
},
|
|
62831
|
-
[onSelectEvent, calendarEvents]
|
|
62832
|
-
);
|
|
62833
62844
|
const handleModalClose = (0, import_react90.useCallback)(() => {
|
|
62834
62845
|
setIsModalOpen(false);
|
|
62835
62846
|
setModalData(void 0);
|
|
@@ -63129,6 +63140,20 @@ function Calendar2({
|
|
|
63129
63140
|
return {};
|
|
63130
63141
|
}, []);
|
|
63131
63142
|
const hasHydrated = useHasHydrated();
|
|
63143
|
+
const DnDCalendar = (0, import_react90.useMemo)(() => {
|
|
63144
|
+
try {
|
|
63145
|
+
if (typeof withDragAndDrop === "function") {
|
|
63146
|
+
return withDragAndDrop(import_react_big_calendar2.Calendar);
|
|
63147
|
+
}
|
|
63148
|
+
console.warn(
|
|
63149
|
+
"withDragAndDrop is not a function, falling back to regular calendar"
|
|
63150
|
+
);
|
|
63151
|
+
return import_react_big_calendar2.Calendar;
|
|
63152
|
+
} catch (error) {
|
|
63153
|
+
console.error("Failed to create DnD calendar:", error);
|
|
63154
|
+
return import_react_big_calendar2.Calendar;
|
|
63155
|
+
}
|
|
63156
|
+
}, []);
|
|
63132
63157
|
if (!hasHydrated) return null;
|
|
63133
63158
|
return /* @__PURE__ */ import_react90.default.createElement(Skeleton, null, /* @__PURE__ */ import_react90.default.createElement(
|
|
63134
63159
|
"div",
|
|
@@ -63146,8 +63171,8 @@ function Calendar2({
|
|
|
63146
63171
|
localizer,
|
|
63147
63172
|
messages,
|
|
63148
63173
|
events: transformedEvents,
|
|
63149
|
-
startAccessor: (event) =>
|
|
63150
|
-
endAccessor: (event) =>
|
|
63174
|
+
startAccessor: (event) => event.start,
|
|
63175
|
+
endAccessor: (event) => event.end,
|
|
63151
63176
|
titleAccessor: "title",
|
|
63152
63177
|
allDayAccessor: (event) => event.isAllDay,
|
|
63153
63178
|
views: [import_react_big_calendar2.Views.MONTH, import_react_big_calendar2.Views.WEEK, import_react_big_calendar2.Views.DAY, import_react_big_calendar2.Views.AGENDA],
|
|
@@ -63252,7 +63277,7 @@ function Calendar2({
|
|
|
63252
63277
|
}
|
|
63253
63278
|
));
|
|
63254
63279
|
}
|
|
63255
|
-
var import_react_big_calendar, import_styles, import_react90, import_react_big_calendar2,
|
|
63280
|
+
var import_react_big_calendar, import_styles, import_react90, import_react_big_calendar2, DnDModule, import_swr7, import_react_big_calendar3, import_styles2, import_Calendar_module, import_clsx11, import_react_hot_toast22, withDragAndDrop, locales2, createLocalizer, CustomToolbar, EventComponent;
|
|
63256
63281
|
var init_Calendar_web = __esm({
|
|
63257
63282
|
"Calendar.web.tsx"() {
|
|
63258
63283
|
"use strict";
|
|
@@ -63261,7 +63286,7 @@ var init_Calendar_web = __esm({
|
|
|
63261
63286
|
import_styles = require("react-big-calendar/lib/addons/dragAndDrop/styles.css");
|
|
63262
63287
|
import_react90 = __toESM(require("react"));
|
|
63263
63288
|
import_react_big_calendar2 = require("react-big-calendar");
|
|
63264
|
-
|
|
63289
|
+
DnDModule = __toESM(require("react-big-calendar/lib/addons/dragAndDrop"));
|
|
63265
63290
|
init_date_fns();
|
|
63266
63291
|
import_swr7 = __toESM(require("swr"));
|
|
63267
63292
|
import_react_big_calendar3 = require("react-big-calendar");
|
|
@@ -63279,6 +63304,12 @@ var init_Calendar_web = __esm({
|
|
|
63279
63304
|
init_platform();
|
|
63280
63305
|
init_hooks();
|
|
63281
63306
|
init_useWebSocket();
|
|
63307
|
+
console.log("DnDModule:", DnDModule);
|
|
63308
|
+
console.log("DnDModule.default:", DnDModule.default);
|
|
63309
|
+
console.log("DnDModule keys:", Object.keys(DnDModule));
|
|
63310
|
+
withDragAndDrop = DnDModule.default || DnDModule;
|
|
63311
|
+
console.log("withDragAndDrop:", withDragAndDrop);
|
|
63312
|
+
console.log("typeof withDragAndDrop:", typeof withDragAndDrop);
|
|
63282
63313
|
locales2 = {
|
|
63283
63314
|
en: enUS,
|
|
63284
63315
|
de: de2,
|
|
@@ -63294,14 +63325,19 @@ var init_Calendar_web = __esm({
|
|
|
63294
63325
|
createLocalizer = (locale5) => {
|
|
63295
63326
|
const dateFnsLocale = locales2[locale5] || enUS;
|
|
63296
63327
|
return (0, import_react_big_calendar3.dateFnsLocalizer)({
|
|
63297
|
-
format: (date, formatStr) =>
|
|
63328
|
+
format: (date, formatStr) => {
|
|
63329
|
+
const dateObj = date instanceof Date ? date : new Date(date);
|
|
63330
|
+
return format(dateObj, formatStr, { locale: dateFnsLocale });
|
|
63331
|
+
},
|
|
63298
63332
|
parse: (str, formatStr) => parse(str, formatStr, /* @__PURE__ */ new Date(), { locale: dateFnsLocale }),
|
|
63299
|
-
startOfWeek: (date) =>
|
|
63333
|
+
startOfWeek: (date) => {
|
|
63334
|
+
const dateObj = date instanceof Date ? date : new Date(date);
|
|
63335
|
+
return startOfWeek(dateObj, { locale: dateFnsLocale });
|
|
63336
|
+
},
|
|
63300
63337
|
getDay,
|
|
63301
63338
|
locales: { [locale5]: dateFnsLocale }
|
|
63302
63339
|
});
|
|
63303
63340
|
};
|
|
63304
|
-
DnDCalendar = (0, import_dragAndDrop.default)(import_react_big_calendar2.Calendar);
|
|
63305
63341
|
CustomToolbar = (props) => {
|
|
63306
63342
|
const {
|
|
63307
63343
|
label,
|
|
@@ -63369,15 +63405,30 @@ var init_Calendar_web = __esm({
|
|
|
63369
63405
|
}
|
|
63370
63406
|
});
|
|
63371
63407
|
|
|
63408
|
+
// CalendarWrapper.tsx
|
|
63409
|
+
function CalendarWrapper(props) {
|
|
63410
|
+
return /* @__PURE__ */ React.createElement(import_react91.Suspense, { fallback: /* @__PURE__ */ React.createElement(Loading, null) }, /* @__PURE__ */ React.createElement(CalendarComponent, { ...props }));
|
|
63411
|
+
}
|
|
63412
|
+
var import_react91, CalendarComponent;
|
|
63413
|
+
var init_CalendarWrapper = __esm({
|
|
63414
|
+
"CalendarWrapper.tsx"() {
|
|
63415
|
+
"use strict";
|
|
63416
|
+
"use client";
|
|
63417
|
+
import_react91 = require("react");
|
|
63418
|
+
init_Loading();
|
|
63419
|
+
CalendarComponent = (0, import_react91.lazy)(() => Promise.resolve().then(() => (init_Calendar_web(), Calendar_web_exports)));
|
|
63420
|
+
}
|
|
63421
|
+
});
|
|
63422
|
+
|
|
63372
63423
|
// Calendar.tsx
|
|
63373
63424
|
var Calendar_exports = {};
|
|
63374
63425
|
__export(Calendar_exports, {
|
|
63375
|
-
default: () =>
|
|
63426
|
+
default: () => CalendarWrapper
|
|
63376
63427
|
});
|
|
63377
63428
|
var init_Calendar = __esm({
|
|
63378
63429
|
"Calendar.tsx"() {
|
|
63379
63430
|
"use strict";
|
|
63380
|
-
|
|
63431
|
+
init_CalendarWrapper();
|
|
63381
63432
|
}
|
|
63382
63433
|
});
|
|
63383
63434
|
|
|
@@ -63440,12 +63491,12 @@ function About() {
|
|
|
63440
63491
|
const styles4 = useWhyStyles();
|
|
63441
63492
|
const { utilities } = useStyles();
|
|
63442
63493
|
const { track } = useAuth();
|
|
63443
|
-
(0,
|
|
63494
|
+
(0, import_react92.useEffect)(() => {
|
|
63444
63495
|
track({
|
|
63445
63496
|
name: "about"
|
|
63446
63497
|
});
|
|
63447
63498
|
}, []);
|
|
63448
|
-
return /* @__PURE__ */
|
|
63499
|
+
return /* @__PURE__ */ import_react92.default.createElement(Skeleton, null, /* @__PURE__ */ import_react92.default.createElement(
|
|
63449
63500
|
Div,
|
|
63450
63501
|
{
|
|
63451
63502
|
style: {
|
|
@@ -63455,28 +63506,28 @@ function About() {
|
|
|
63455
63506
|
padding: "0 0px 20px 0px"
|
|
63456
63507
|
}
|
|
63457
63508
|
},
|
|
63458
|
-
/* @__PURE__ */
|
|
63509
|
+
/* @__PURE__ */ import_react92.default.createElement(H1, { style: { marginTop: 0 } }, /* @__PURE__ */ import_react92.default.createElement(
|
|
63459
63510
|
Button,
|
|
63460
63511
|
{
|
|
63461
63512
|
style: utilities.link.style,
|
|
63462
63513
|
onClick: () => router.push("/about")
|
|
63463
63514
|
},
|
|
63464
|
-
/* @__PURE__ */
|
|
63515
|
+
/* @__PURE__ */ import_react92.default.createElement(icons_exports.CircleArrowLeft, { color: "var(--accent-1)", size: 24 })
|
|
63465
63516
|
), " ", t5("why_vex")),
|
|
63466
|
-
/* @__PURE__ */
|
|
63467
|
-
siteConfig.mode === "vex" && /* @__PURE__ */
|
|
63468
|
-
/* @__PURE__ */
|
|
63517
|
+
/* @__PURE__ */ import_react92.default.createElement(Section, null, /* @__PURE__ */ import_react92.default.createElement(H2, null, "\u{1F970} ", t5("hero_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("hero_description"))),
|
|
63518
|
+
siteConfig.mode === "vex" && /* @__PURE__ */ import_react92.default.createElement(Section, null, /* @__PURE__ */ import_react92.default.createElement(H2, null, "\u{1F31F} ", t5("lifeos.revolution.title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("lifeos.revolution.intro1")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("lifeos.revolution.intro2")), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H4, null, "\u{1F3AF} ", t5("lifeos.unique.title")), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(P, null, /* @__PURE__ */ import_react92.default.createElement(Strong, null, t5("lifeos.unique.cross_app"))), /* @__PURE__ */ import_react92.default.createElement(P, null, /* @__PURE__ */ import_react92.default.createElement(Strong, null, t5("lifeos.unique.guest_first"))), /* @__PURE__ */ import_react92.default.createElement(P, null, /* @__PURE__ */ import_react92.default.createElement(Strong, null, t5("lifeos.unique.privacy"))), /* @__PURE__ */ import_react92.default.createElement(P, null, /* @__PURE__ */ import_react92.default.createElement(Strong, null, t5("lifeos.unique.ecosystem")))))),
|
|
63519
|
+
/* @__PURE__ */ import_react92.default.createElement(Section, null, /* @__PURE__ */ import_react92.default.createElement(H2, null, "\u{1F3C6} ", t5("unique_advantages_title")), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u2728 ", t5("character_profiling_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("character_profiling_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("custom_instructions_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("custom_instructions_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F9E0} ", t5("rag_artifacts_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("rag_artifacts_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F3A8} ", t5("personalized_suggestions_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("personalized_suggestions_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("thread_collaboration_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("thread_collaboration_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F50D} ", t5("user_discovery_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("user_discovery_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F9E9} ", t5("browser_extension_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("browser_extension_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("ai_debate_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("ai_debate_description"))), siteConfig.mode === "vex" && /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F31F} ", t5("LifeOS App Ecosystem")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5(
|
|
63469
63520
|
"Beyond chat, we're building specialized AI apps: Peach (social networking), Atlas (travel), Bloom (health & sustainability), and Vault (finance). Each app leverages your existing AI conversations to provide personalized experiences no competitor can offer."
|
|
63470
|
-
))), /* @__PURE__ */
|
|
63471
|
-
/* @__PURE__ */
|
|
63521
|
+
))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F381} ", t5("guest_subscriptions_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("guest_subscriptions_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F504} ", t5("frictionless_migration_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("frictionless_migration_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, "\u{1F49D} ", t5("gift_subscriptions_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("gift_subscriptions_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("cost_transparency_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("cost_transparency_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("privacy_focused_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("privacy_focused_desc"))))),
|
|
63522
|
+
/* @__PURE__ */ import_react92.default.createElement(Section, null, /* @__PURE__ */ import_react92.default.createElement(H2, null, t5("technical_excellence_title")), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("cost_effective_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("cost_effective_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("modern_architecture_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("modern_architecture_description"))), /* @__PURE__ */ import_react92.default.createElement(Div, null, /* @__PURE__ */ import_react92.default.createElement(H3, null, t5("multi_language_title")), /* @__PURE__ */ import_react92.default.createElement(P, null, t5("multi_language_description")))))
|
|
63472
63523
|
));
|
|
63473
63524
|
}
|
|
63474
|
-
var
|
|
63525
|
+
var import_react92;
|
|
63475
63526
|
var init_Why = __esm({
|
|
63476
63527
|
"Why.tsx"() {
|
|
63477
63528
|
"use strict";
|
|
63478
63529
|
"use client";
|
|
63479
|
-
|
|
63530
|
+
import_react92 = __toESM(require("react"));
|
|
63480
63531
|
init_Skeleton();
|
|
63481
63532
|
init_AppContext();
|
|
63482
63533
|
init_icons();
|
|
@@ -63624,12 +63675,12 @@ function Privacy() {
|
|
|
63624
63675
|
const styles4 = useAboutStyles();
|
|
63625
63676
|
const { router } = useNavigationContext();
|
|
63626
63677
|
const { isDrawerOpen } = useTheme2();
|
|
63627
|
-
(0,
|
|
63678
|
+
(0, import_react93.useEffect)(() => {
|
|
63628
63679
|
track({
|
|
63629
63680
|
name: "privacy"
|
|
63630
63681
|
});
|
|
63631
63682
|
}, []);
|
|
63632
|
-
return /* @__PURE__ */
|
|
63683
|
+
return /* @__PURE__ */ import_react93.default.createElement(Skeleton, null, /* @__PURE__ */ import_react93.default.createElement(
|
|
63633
63684
|
Div,
|
|
63634
63685
|
{
|
|
63635
63686
|
style: {
|
|
@@ -63638,24 +63689,24 @@ function Privacy() {
|
|
|
63638
63689
|
padding: "0 0px 20px 0px"
|
|
63639
63690
|
}
|
|
63640
63691
|
},
|
|
63641
|
-
/* @__PURE__ */
|
|
63642
|
-
/* @__PURE__ */
|
|
63643
|
-
/* @__PURE__ */
|
|
63644
|
-
/* @__PURE__ */
|
|
63645
|
-
/* @__PURE__ */
|
|
63646
|
-
/* @__PURE__ */
|
|
63647
|
-
/* @__PURE__ */
|
|
63648
|
-
/* @__PURE__ */
|
|
63649
|
-
/* @__PURE__ */
|
|
63650
|
-
/* @__PURE__ */
|
|
63692
|
+
/* @__PURE__ */ import_react93.default.createElement(H1, { style: { marginTop: 0 } }, /* @__PURE__ */ import_react93.default.createElement(Button, { className: "link", onClick: () => router.push("/about") }, /* @__PURE__ */ import_react93.default.createElement(icons_exports.CircleArrowLeft, { color: "var(--accent-1)", size: 24 })), " ", t5("Privacy Policy")),
|
|
63693
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.collection.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.collection.content"))),
|
|
63694
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.analytics.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.content2")), /* @__PURE__ */ import_react93.default.createElement(Div, null, /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.items.pageviews")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.items.features")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.items.performance")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.items.conversion"))), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.analytics.anonymized"))),
|
|
63695
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.chat.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.chat.content")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.chat.memory_note"))),
|
|
63696
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.character.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.character.content")), /* @__PURE__ */ import_react93.default.createElement(Div, null, /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.character.items.analysis")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.character.items.storage")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.character.items.sharing")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.character.items.control")))),
|
|
63697
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.memory.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.memory.content")), /* @__PURE__ */ import_react93.default.createElement(Div, null, /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.memory.items.extraction")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.memory.items.storage")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.memory.items.usage")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.memory.items.control")))),
|
|
63698
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.cookies.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.cookies.content"))),
|
|
63699
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.security.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.security.content"))),
|
|
63700
|
+
/* @__PURE__ */ import_react93.default.createElement(Section, null, /* @__PURE__ */ import_react93.default.createElement(H2, null, t5("privacy.changes.title")), /* @__PURE__ */ import_react93.default.createElement(P, null, t5("privacy.changes.content"))),
|
|
63701
|
+
/* @__PURE__ */ import_react93.default.createElement(Div, { style: styles4.lastUpdated.style }, /* @__PURE__ */ import_react93.default.createElement(Img, { src: `${FRONTEND_URL}/frog.png`, width: 24, height: 24 }), t5("privacy.last_updated", { date: "August 4, 2025" }))
|
|
63651
63702
|
));
|
|
63652
63703
|
}
|
|
63653
|
-
var
|
|
63704
|
+
var import_react93;
|
|
63654
63705
|
var init_Privacy = __esm({
|
|
63655
63706
|
"Privacy.tsx"() {
|
|
63656
63707
|
"use strict";
|
|
63657
63708
|
"use client";
|
|
63658
|
-
|
|
63709
|
+
import_react93 = __toESM(require("react"));
|
|
63659
63710
|
init_AppContext();
|
|
63660
63711
|
init_Skeleton();
|
|
63661
63712
|
init_icons();
|
|
@@ -63679,12 +63730,12 @@ function Terms() {
|
|
|
63679
63730
|
const styles4 = useAboutStyles();
|
|
63680
63731
|
const { utilities } = useStyles();
|
|
63681
63732
|
const { track } = useAuth();
|
|
63682
|
-
(0,
|
|
63733
|
+
(0, import_react94.useEffect)(() => {
|
|
63683
63734
|
track({
|
|
63684
63735
|
name: "terms"
|
|
63685
63736
|
});
|
|
63686
63737
|
}, []);
|
|
63687
|
-
return /* @__PURE__ */
|
|
63738
|
+
return /* @__PURE__ */ import_react94.default.createElement(Skeleton, null, /* @__PURE__ */ import_react94.default.createElement(
|
|
63688
63739
|
Div,
|
|
63689
63740
|
{
|
|
63690
63741
|
style: {
|
|
@@ -63693,30 +63744,30 @@ function Terms() {
|
|
|
63693
63744
|
padding: "0 0px 20px 0px"
|
|
63694
63745
|
}
|
|
63695
63746
|
},
|
|
63696
|
-
/* @__PURE__ */
|
|
63747
|
+
/* @__PURE__ */ import_react94.default.createElement(H1, { style: { marginTop: 0 } }, /* @__PURE__ */ import_react94.default.createElement(
|
|
63697
63748
|
Button,
|
|
63698
63749
|
{
|
|
63699
63750
|
className: "link",
|
|
63700
63751
|
style: utilities.link.style,
|
|
63701
63752
|
onClick: () => router.push("/about")
|
|
63702
63753
|
},
|
|
63703
|
-
/* @__PURE__ */
|
|
63754
|
+
/* @__PURE__ */ import_react94.default.createElement(icons_exports.CircleArrowLeft, { color: "var(--accent-1)", size: 24 })
|
|
63704
63755
|
), " ", t5("Terms of Use")),
|
|
63705
|
-
/* @__PURE__ */
|
|
63706
|
-
/* @__PURE__ */
|
|
63707
|
-
/* @__PURE__ */
|
|
63708
|
-
/* @__PURE__ */
|
|
63709
|
-
/* @__PURE__ */
|
|
63710
|
-
/* @__PURE__ */
|
|
63711
|
-
/* @__PURE__ */
|
|
63756
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.acceptance.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.acceptance.content"))),
|
|
63757
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.tracking.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.tracking.content2"))),
|
|
63758
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.agentic.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.agentic.content"))),
|
|
63759
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.pricing.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.pricing.content"))),
|
|
63760
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.liability.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.liability.content"))),
|
|
63761
|
+
/* @__PURE__ */ import_react94.default.createElement(Section, null, /* @__PURE__ */ import_react94.default.createElement(H2, null, t5("terms.changes.title")), /* @__PURE__ */ import_react94.default.createElement(P, null, t5("terms.changes.content"))),
|
|
63762
|
+
/* @__PURE__ */ import_react94.default.createElement(Div, { style: styles4.lastUpdated.style }, /* @__PURE__ */ import_react94.default.createElement(Img, { src: `${FRONTEND_URL}/frog.png`, width: 24, height: 24 }), t5("terms.last_updated", { date: "August 4, 2025" }))
|
|
63712
63763
|
));
|
|
63713
63764
|
}
|
|
63714
|
-
var
|
|
63765
|
+
var import_react94;
|
|
63715
63766
|
var init_Terms = __esm({
|
|
63716
63767
|
"Terms.tsx"() {
|
|
63717
63768
|
"use strict";
|
|
63718
63769
|
"use client";
|
|
63719
|
-
|
|
63770
|
+
import_react94 = __toESM(require("react"));
|
|
63720
63771
|
init_Skeleton();
|
|
63721
63772
|
init_AppContext();
|
|
63722
63773
|
init_icons();
|
|
@@ -63742,7 +63793,7 @@ function About2() {
|
|
|
63742
63793
|
const { router } = useNavigationContext();
|
|
63743
63794
|
const { isDrawerOpen, addHapticFeedback, isMobileDevice } = useTheme2();
|
|
63744
63795
|
const { captureException } = useError();
|
|
63745
|
-
(0,
|
|
63796
|
+
(0, import_react95.useEffect)(() => {
|
|
63746
63797
|
track({
|
|
63747
63798
|
name: "about"
|
|
63748
63799
|
});
|
|
@@ -63759,7 +63810,7 @@ function About2() {
|
|
|
63759
63810
|
ADDITIONAL_CREDITS: ADDITIONAL_CREDITS2,
|
|
63760
63811
|
CREDITS_PRICE: CREDITS_PRICE2
|
|
63761
63812
|
});
|
|
63762
|
-
return /* @__PURE__ */
|
|
63813
|
+
return /* @__PURE__ */ import_react95.default.createElement(Skeleton, null, /* @__PURE__ */ import_react95.default.createElement(
|
|
63763
63814
|
Div,
|
|
63764
63815
|
{
|
|
63765
63816
|
style: {
|
|
@@ -63768,15 +63819,15 @@ function About2() {
|
|
|
63768
63819
|
padding: "0 0px 20px 0px"
|
|
63769
63820
|
}
|
|
63770
63821
|
},
|
|
63771
|
-
/* @__PURE__ */
|
|
63822
|
+
/* @__PURE__ */ import_react95.default.createElement(H1, { style: { display: "flex", gap: 5, marginTop: 0 } }, /* @__PURE__ */ import_react95.default.createElement(
|
|
63772
63823
|
Button,
|
|
63773
63824
|
{
|
|
63774
63825
|
className: "link",
|
|
63775
63826
|
style: { ...utilities.link.style },
|
|
63776
63827
|
onClick: () => router.push("/")
|
|
63777
63828
|
},
|
|
63778
|
-
/* @__PURE__ */
|
|
63779
|
-
), /* @__PURE__ */
|
|
63829
|
+
/* @__PURE__ */ import_react95.default.createElement(icons_exports.CircleArrowLeft, { color: "var(--accent-1)", size: 24 })
|
|
63830
|
+
), /* @__PURE__ */ import_react95.default.createElement(
|
|
63780
63831
|
Span,
|
|
63781
63832
|
{
|
|
63782
63833
|
onClick: () => {
|
|
@@ -63787,7 +63838,7 @@ function About2() {
|
|
|
63787
63838
|
},
|
|
63788
63839
|
t5("About Vex")
|
|
63789
63840
|
)),
|
|
63790
|
-
/* @__PURE__ */
|
|
63841
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, { style: { marginBottom: 15 } }, /* @__PURE__ */ import_react95.default.createElement(P, null, /* @__PURE__ */ import_react95.default.createElement(
|
|
63791
63842
|
"a",
|
|
63792
63843
|
{
|
|
63793
63844
|
onClick: (e) => {
|
|
@@ -63801,7 +63852,7 @@ function About2() {
|
|
|
63801
63852
|
href: isStandalone2 ? void 0 : `${FRONTEND_URL2}/why`
|
|
63802
63853
|
},
|
|
63803
63854
|
t5("why_vex")
|
|
63804
|
-
), config2.mode === "vex" && /* @__PURE__ */
|
|
63855
|
+
), config2.mode === "vex" && /* @__PURE__ */ import_react95.default.createElement(import_react95.default.Fragment, null, ", ", /* @__PURE__ */ import_react95.default.createElement(
|
|
63805
63856
|
Anchor,
|
|
63806
63857
|
{
|
|
63807
63858
|
openInNewTab: true,
|
|
@@ -63816,7 +63867,7 @@ function About2() {
|
|
|
63816
63867
|
}
|
|
63817
63868
|
},
|
|
63818
63869
|
t5("Blog")
|
|
63819
|
-
)), ", ", /* @__PURE__ */
|
|
63870
|
+
)), ", ", /* @__PURE__ */ import_react95.default.createElement(
|
|
63820
63871
|
"a",
|
|
63821
63872
|
{
|
|
63822
63873
|
onClick: (e) => {
|
|
@@ -63830,7 +63881,7 @@ function About2() {
|
|
|
63830
63881
|
href: isStandalone2 ? void 0 : `${FRONTEND_URL2}/terms`
|
|
63831
63882
|
},
|
|
63832
63883
|
t5("Terms of Use")
|
|
63833
|
-
), ", ", /* @__PURE__ */
|
|
63884
|
+
), ", ", /* @__PURE__ */ import_react95.default.createElement(
|
|
63834
63885
|
"a",
|
|
63835
63886
|
{
|
|
63836
63887
|
onClick: (e) => {
|
|
@@ -63844,16 +63895,16 @@ function About2() {
|
|
|
63844
63895
|
href: isStandalone2 ? void 0 : `${FRONTEND_URL2}/privacy`
|
|
63845
63896
|
},
|
|
63846
63897
|
t5("Privacy Policy")
|
|
63847
|
-
), ", ", /* @__PURE__ */
|
|
63848
|
-
/* @__PURE__ */
|
|
63849
|
-
apps && apps.length > 0 && /* @__PURE__ */
|
|
63898
|
+
), ", ", /* @__PURE__ */ import_react95.default.createElement("a", { href: "https://x.com/askvexai" }, "@askvexAI"), ", ", /* @__PURE__ */ import_react95.default.createElement("a", { href: "mailto:iliyan@chrry.ai" }, "iliyan@chrry.ai"))),
|
|
63899
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(P, null, "\u{1F970} ", t5("about.intro")), /* @__PURE__ */ import_react95.default.createElement(P, { style: { marginTop: "1rem" } }, t5("about.intro2"))),
|
|
63900
|
+
apps && apps.length > 0 && /* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, null, config2.logo, " ", t5("Available Apps")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("Discover AI-powered apps from our store")), /* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.apps.style }, apps.map((app) => /* @__PURE__ */ import_react95.default.createElement(
|
|
63850
63901
|
Div,
|
|
63851
63902
|
{
|
|
63852
63903
|
key: app.id,
|
|
63853
63904
|
style: styles4.app.style,
|
|
63854
63905
|
onClick: () => setApp(app)
|
|
63855
63906
|
},
|
|
63856
|
-
/* @__PURE__ */
|
|
63907
|
+
/* @__PURE__ */ import_react95.default.createElement(
|
|
63857
63908
|
H4,
|
|
63858
63909
|
{
|
|
63859
63910
|
style: {
|
|
@@ -63864,15 +63915,15 @@ function About2() {
|
|
|
63864
63915
|
padding: 0
|
|
63865
63916
|
}
|
|
63866
63917
|
},
|
|
63867
|
-
/* @__PURE__ */
|
|
63918
|
+
/* @__PURE__ */ import_react95.default.createElement(Span, { style: { fontSize: 30 } }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { app, size: 30 })),
|
|
63868
63919
|
app.title || app.name
|
|
63869
63920
|
),
|
|
63870
|
-
/* @__PURE__ */
|
|
63921
|
+
/* @__PURE__ */ import_react95.default.createElement(P, { style: styles4.appDescription.style }, app.description || t5("No description available"))
|
|
63871
63922
|
)))),
|
|
63872
|
-
/* @__PURE__ */
|
|
63873
|
-
/* @__PURE__ */
|
|
63874
|
-
/* @__PURE__ */
|
|
63875
|
-
/* @__PURE__ */
|
|
63923
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, null, t5("about.approach.title")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.approach.content"))),
|
|
63924
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, null, t5("about.transparency.title")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.transparency.intro")), /* @__PURE__ */ import_react95.default.createElement(Div, null, /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.transparency.items.pricing")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.transparency.items.usage")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.transparency.items.communication")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.transparency.items.data")))),
|
|
63925
|
+
/* @__PURE__ */ import_react95.default.createElement(H2, { style: { fontSize: 28 } }, t5("All Plans")),
|
|
63926
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, { style: styles4.h2.style }, /* @__PURE__ */ import_react95.default.createElement(Logo, { size: 24 }), " ", t5("Free"), !user && /* @__PURE__ */ import_react95.default.createElement(
|
|
63876
63927
|
Button,
|
|
63877
63928
|
{
|
|
63878
63929
|
className: "inverted",
|
|
@@ -63892,11 +63943,11 @@ function About2() {
|
|
|
63892
63943
|
router.push("/about?signIn=register");
|
|
63893
63944
|
}
|
|
63894
63945
|
},
|
|
63895
|
-
/* @__PURE__ */
|
|
63946
|
+
/* @__PURE__ */ import_react95.default.createElement(icons_exports.UserRoundPlus, { size: 16 }),
|
|
63896
63947
|
" ",
|
|
63897
63948
|
t5("Register")
|
|
63898
|
-
)), memberFeatures.map((feature) => /* @__PURE__ */
|
|
63899
|
-
/* @__PURE__ */
|
|
63949
|
+
)), memberFeatures.map((feature) => /* @__PURE__ */ import_react95.default.createElement(Span, { key: feature.text }, " ", feature.emoji, " ", feature.text))),
|
|
63950
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, { style: styles4.h2.style }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { size: 24, icon: "chrry" }), " ", t5("Credits"), /* @__PURE__ */ import_react95.default.createElement(
|
|
63900
63951
|
Button,
|
|
63901
63952
|
{
|
|
63902
63953
|
onClick: () => {
|
|
@@ -63920,8 +63971,8 @@ function About2() {
|
|
|
63920
63971
|
credits: ADDITIONAL_CREDITS2,
|
|
63921
63972
|
price: `${CREDITS_PRICE2}.00`
|
|
63922
63973
|
})
|
|
63923
|
-
)), creditsFeatures.map((feature) => /* @__PURE__ */
|
|
63924
|
-
/* @__PURE__ */
|
|
63974
|
+
)), creditsFeatures.map((feature) => /* @__PURE__ */ import_react95.default.createElement(Span, { key: feature.text }, " ", feature.emoji, " ", feature.text))),
|
|
63975
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, { style: styles4.h2.style }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { size: 24, icon: "strawberry" }), " ", t5("Plus"), /* @__PURE__ */ import_react95.default.createElement(
|
|
63925
63976
|
Span,
|
|
63926
63977
|
{
|
|
63927
63978
|
title: t5("Most popular"),
|
|
@@ -63932,8 +63983,8 @@ function About2() {
|
|
|
63932
63983
|
verticalAlign: "middle"
|
|
63933
63984
|
}
|
|
63934
63985
|
},
|
|
63935
|
-
/* @__PURE__ */
|
|
63936
|
-
), /* @__PURE__ */
|
|
63986
|
+
/* @__PURE__ */ import_react95.default.createElement(icons_exports.BadgeCheck, { size: 20 })
|
|
63987
|
+
), /* @__PURE__ */ import_react95.default.createElement(
|
|
63937
63988
|
Button,
|
|
63938
63989
|
{
|
|
63939
63990
|
onClick: () => {
|
|
@@ -63957,8 +64008,8 @@ function About2() {
|
|
|
63957
64008
|
t5("{{price}}/month", {
|
|
63958
64009
|
price: PLUS_PRICE2
|
|
63959
64010
|
})
|
|
63960
|
-
)), plusFeatures.map((feature) => /* @__PURE__ */
|
|
63961
|
-
/* @__PURE__ */
|
|
64011
|
+
)), plusFeatures.map((feature) => /* @__PURE__ */ import_react95.default.createElement(Span, { key: feature.text }, " ", feature.emoji, " ", feature.text))),
|
|
64012
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, { style: styles4.h2.style }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { size: 24, icon: "raspberry" }), " ", t5("Pro"), /* @__PURE__ */ import_react95.default.createElement(
|
|
63962
64013
|
Button,
|
|
63963
64014
|
{
|
|
63964
64015
|
onClick: () => {
|
|
@@ -63982,22 +64033,22 @@ function About2() {
|
|
|
63982
64033
|
t5("{{price}}/month", {
|
|
63983
64034
|
price: PRO_PRICE2
|
|
63984
64035
|
})
|
|
63985
|
-
)), proFeatures.map((feature) => /* @__PURE__ */
|
|
63986
|
-
/* @__PURE__ */
|
|
64036
|
+
)), proFeatures.map((feature) => /* @__PURE__ */ import_react95.default.createElement(Span, { key: feature.text }, " ", feature.emoji, " ", feature.text))),
|
|
64037
|
+
/* @__PURE__ */ import_react95.default.createElement(Section, null, /* @__PURE__ */ import_react95.default.createElement(H2, null, t5("about.platforms.title")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.platforms.content")), /* @__PURE__ */ import_react95.default.createElement(Div, null, /* @__PURE__ */ import_react95.default.createElement(Div, null, /* @__PURE__ */ import_react95.default.createElement(H3, null, t5("about.platforms.web.title")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.platforms.web.content")), /* @__PURE__ */ import_react95.default.createElement(
|
|
63987
64038
|
Video_web_default,
|
|
63988
64039
|
{
|
|
63989
64040
|
style: styles4.video.style,
|
|
63990
64041
|
controls: true,
|
|
63991
64042
|
src: `https://7079yofdv0.ufs.sh/f/5ALK9G4mxClOL8j2AfbZ5dgLDCVo4JzBsXqI3MrF8KatARwv`
|
|
63992
64043
|
}
|
|
63993
|
-
)), /* @__PURE__ */
|
|
64044
|
+
)), /* @__PURE__ */ import_react95.default.createElement(Div, null, /* @__PURE__ */ import_react95.default.createElement(H3, null, t5("about.platforms.pwa.title")), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.platforms.pwa.content")), /* @__PURE__ */ import_react95.default.createElement(
|
|
63994
64045
|
Video_web_default,
|
|
63995
64046
|
{
|
|
63996
64047
|
style: styles4.video.style,
|
|
63997
64048
|
controls: true,
|
|
63998
64049
|
src: `https://7079yofdv0.ufs.sh/f/5ALK9G4mxClOTAEfNuXpQy4HJYn8fWo1mFVRaG7eqCiD3A5l`
|
|
63999
64050
|
}
|
|
64000
|
-
)), /* @__PURE__ */
|
|
64051
|
+
)), /* @__PURE__ */ import_react95.default.createElement(Div, null, /* @__PURE__ */ import_react95.default.createElement(H3, { style: { display: "flex" } }, t5("about.platforms.chrome.title"), " ", /* @__PURE__ */ import_react95.default.createElement(
|
|
64001
64052
|
Anchor,
|
|
64002
64053
|
{
|
|
64003
64054
|
target: "_blank",
|
|
@@ -64008,9 +64059,9 @@ function About2() {
|
|
|
64008
64059
|
},
|
|
64009
64060
|
href: "https://chromewebstore.google.com/detail/vex/odgdgbbddopmblglebfngmaebmnhegfc"
|
|
64010
64061
|
},
|
|
64011
|
-
/* @__PURE__ */
|
|
64062
|
+
/* @__PURE__ */ import_react95.default.createElement(import_fa7.FaChrome, { size: 18 }),
|
|
64012
64063
|
t5("Install")
|
|
64013
|
-
)), /* @__PURE__ */
|
|
64064
|
+
)), /* @__PURE__ */ import_react95.default.createElement(P, null, t5("about.platforms.chrome.content"), " "), /* @__PURE__ */ import_react95.default.createElement(
|
|
64014
64065
|
Video_web_default,
|
|
64015
64066
|
{
|
|
64016
64067
|
style: styles4.video.style,
|
|
@@ -64018,15 +64069,15 @@ function About2() {
|
|
|
64018
64069
|
src: `https://7079yofdv0.ufs.sh/f/5ALK9G4mxClOWTxc2Y6sD5zVU8hPgdAmWQy4qXa0KuL2HE7e`
|
|
64019
64070
|
}
|
|
64020
64071
|
)))),
|
|
64021
|
-
/* @__PURE__ */
|
|
64072
|
+
/* @__PURE__ */ import_react95.default.createElement(
|
|
64022
64073
|
Div,
|
|
64023
64074
|
{
|
|
64024
64075
|
style: {
|
|
64025
64076
|
...styles4.ossWrapper.style
|
|
64026
64077
|
}
|
|
64027
64078
|
},
|
|
64028
|
-
/* @__PURE__ */
|
|
64029
|
-
/* @__PURE__ */
|
|
64079
|
+
/* @__PURE__ */ import_react95.default.createElement(H2, null, t5("Open Source")),
|
|
64080
|
+
/* @__PURE__ */ import_react95.default.createElement(
|
|
64030
64081
|
Div,
|
|
64031
64082
|
{
|
|
64032
64083
|
style: {
|
|
@@ -64035,7 +64086,7 @@ function About2() {
|
|
|
64035
64086
|
...isMobileDevice ? void 0 : styles4.ossContainerDesktop.style
|
|
64036
64087
|
}
|
|
64037
64088
|
},
|
|
64038
|
-
/* @__PURE__ */
|
|
64089
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(import_si.SiTypescript, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64039
64090
|
Anchor,
|
|
64040
64091
|
{
|
|
64041
64092
|
href: "https://www.typescriptlang.org",
|
|
@@ -64045,7 +64096,7 @@ function About2() {
|
|
|
64045
64096
|
},
|
|
64046
64097
|
"TypeScript"
|
|
64047
64098
|
)),
|
|
64048
|
-
/* @__PURE__ */
|
|
64099
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(import_ri.RiNextjsFill, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64049
64100
|
Anchor,
|
|
64050
64101
|
{
|
|
64051
64102
|
href: "https://nextjs.org",
|
|
@@ -64055,7 +64106,7 @@ function About2() {
|
|
|
64055
64106
|
},
|
|
64056
64107
|
"Next.js"
|
|
64057
64108
|
)),
|
|
64058
|
-
/* @__PURE__ */
|
|
64109
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(import_bi.BiLogoPostgresql, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64059
64110
|
Anchor,
|
|
64060
64111
|
{
|
|
64061
64112
|
href: "https://www.postgresql.org",
|
|
@@ -64065,7 +64116,7 @@ function About2() {
|
|
|
64065
64116
|
},
|
|
64066
64117
|
"PostgreSQL"
|
|
64067
64118
|
)),
|
|
64068
|
-
/* @__PURE__ */
|
|
64119
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(icons_exports.DeepSeek, { color: COLORS.purple, size: 40 }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64069
64120
|
Anchor,
|
|
64070
64121
|
{
|
|
64071
64122
|
href: "https://www.deepseek.com",
|
|
@@ -64076,7 +64127,7 @@ function About2() {
|
|
|
64076
64127
|
"DeepSeek"
|
|
64077
64128
|
))
|
|
64078
64129
|
),
|
|
64079
|
-
/* @__PURE__ */
|
|
64130
|
+
/* @__PURE__ */ import_react95.default.createElement(
|
|
64080
64131
|
Div,
|
|
64081
64132
|
{
|
|
64082
64133
|
style: {
|
|
@@ -64084,7 +64135,7 @@ function About2() {
|
|
|
64084
64135
|
...isMobileDevice ? void 0 : styles4.ossContainerDesktop.style
|
|
64085
64136
|
}
|
|
64086
64137
|
},
|
|
64087
|
-
/* @__PURE__ */
|
|
64138
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(import_si.SiJest, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64088
64139
|
Anchor,
|
|
64089
64140
|
{
|
|
64090
64141
|
href: "https://jestjs.io",
|
|
@@ -64094,7 +64145,7 @@ function About2() {
|
|
|
64094
64145
|
},
|
|
64095
64146
|
"Jest"
|
|
64096
64147
|
)),
|
|
64097
|
-
/* @__PURE__ */
|
|
64148
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(import_si.SiCssmodules, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64098
64149
|
Anchor,
|
|
64099
64150
|
{
|
|
64100
64151
|
href: "https://github.com/css-modules/css-modules",
|
|
@@ -64104,7 +64155,7 @@ function About2() {
|
|
|
64104
64155
|
},
|
|
64105
64156
|
"CSS Modules"
|
|
64106
64157
|
)),
|
|
64107
|
-
/* @__PURE__ */
|
|
64158
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(icons_exports.Shell, { style: { width: 40, height: 40 } }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64108
64159
|
Anchor,
|
|
64109
64160
|
{
|
|
64110
64161
|
href: "https://lucide.dev",
|
|
@@ -64116,7 +64167,7 @@ function About2() {
|
|
|
64116
64167
|
))
|
|
64117
64168
|
)
|
|
64118
64169
|
),
|
|
64119
|
-
/* @__PURE__ */
|
|
64170
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.ossWrapper.style }, /* @__PURE__ */ import_react95.default.createElement(H2, null, t5("Team")), /* @__PURE__ */ import_react95.default.createElement(
|
|
64120
64171
|
Div,
|
|
64121
64172
|
{
|
|
64122
64173
|
style: {
|
|
@@ -64125,7 +64176,7 @@ function About2() {
|
|
|
64125
64176
|
...isMobileDevice ? void 0 : styles4.ossContainerDesktop.style
|
|
64126
64177
|
}
|
|
64127
64178
|
},
|
|
64128
|
-
/* @__PURE__ */
|
|
64179
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { icon: "spaceInvader", size: 40 }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64129
64180
|
Anchor,
|
|
64130
64181
|
{
|
|
64131
64182
|
href: "https://i.chrry.dev",
|
|
@@ -64134,7 +64185,7 @@ function About2() {
|
|
|
64134
64185
|
},
|
|
64135
64186
|
"iliyan@chrry.ai"
|
|
64136
64187
|
)),
|
|
64137
|
-
/* @__PURE__ */
|
|
64188
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.oss.style }, /* @__PURE__ */ import_react95.default.createElement(icons_exports.Claude, { color: COLORS.orange, size: 40 }), /* @__PURE__ */ import_react95.default.createElement(
|
|
64138
64189
|
Anchor,
|
|
64139
64190
|
{
|
|
64140
64191
|
href: "https://claude.ai",
|
|
@@ -64145,15 +64196,15 @@ function About2() {
|
|
|
64145
64196
|
"Claude"
|
|
64146
64197
|
))
|
|
64147
64198
|
)),
|
|
64148
|
-
/* @__PURE__ */
|
|
64199
|
+
/* @__PURE__ */ import_react95.default.createElement(Div, { style: styles4.lastUpdated.style }, /* @__PURE__ */ import_react95.default.createElement(ImageComponent, { src: `${FRONTEND_URL2}/hamster.png`, width: 24, height: 24 }), t5("about.last_updated", { date: "September 29, 2025" }))
|
|
64149
64200
|
));
|
|
64150
64201
|
}
|
|
64151
|
-
var
|
|
64202
|
+
var import_react95, import_ri, import_bi, import_si, import_fa7;
|
|
64152
64203
|
var init_About = __esm({
|
|
64153
64204
|
"about/About.tsx"() {
|
|
64154
64205
|
"use strict";
|
|
64155
64206
|
"use client";
|
|
64156
|
-
|
|
64207
|
+
import_react95 = __toESM(require("react"));
|
|
64157
64208
|
init_Skeleton();
|
|
64158
64209
|
init_AppContext();
|
|
64159
64210
|
init_utils();
|
|
@@ -64238,13 +64289,13 @@ function Search3({
|
|
|
64238
64289
|
const styles4 = useSearchStyles();
|
|
64239
64290
|
const { addParams } = useNavigationContext();
|
|
64240
64291
|
const searchParams = useSearchParams();
|
|
64241
|
-
const searchInputRef = (0,
|
|
64292
|
+
const searchInputRef = (0, import_react96.useRef)(null);
|
|
64242
64293
|
const pathname = usePathname();
|
|
64243
|
-
const [term, setTerm] = (0,
|
|
64294
|
+
const [term, setTerm] = (0, import_react96.useState)(
|
|
64244
64295
|
searchParams?.get(paramName)?.toString() || ""
|
|
64245
64296
|
);
|
|
64246
64297
|
const isFocus = props.isFocus ?? searchParams?.get("focus")?.toString() === "search";
|
|
64247
|
-
(0,
|
|
64298
|
+
(0, import_react96.useEffect)(() => {
|
|
64248
64299
|
if (isFocus) {
|
|
64249
64300
|
searchInputRef.current?.focus();
|
|
64250
64301
|
}
|
|
@@ -64257,7 +64308,7 @@ function Search3({
|
|
|
64257
64308
|
addParams({ [paramName]: search || "" });
|
|
64258
64309
|
import_nprogress2.default.done();
|
|
64259
64310
|
}, 600);
|
|
64260
|
-
return /* @__PURE__ */
|
|
64311
|
+
return /* @__PURE__ */ import_react96.default.createElement(Div, { style: { ...styles4.searchBoxWrapper.style, ...style } }, /* @__PURE__ */ import_react96.default.createElement(icons_exports.SearchIcon, { style: { ...styles4.searchIcon.style } }), /* @__PURE__ */ import_react96.default.createElement(
|
|
64261
64312
|
Input,
|
|
64262
64313
|
{
|
|
64263
64314
|
style: { ...styles4.search.style },
|
|
@@ -64274,12 +64325,12 @@ function Search3({
|
|
|
64274
64325
|
}
|
|
64275
64326
|
));
|
|
64276
64327
|
}
|
|
64277
|
-
var
|
|
64328
|
+
var import_react96, import_nprogress2, import_use_debounce;
|
|
64278
64329
|
var init_Search = __esm({
|
|
64279
64330
|
"Search.tsx"() {
|
|
64280
64331
|
"use strict";
|
|
64281
64332
|
"use client";
|
|
64282
|
-
|
|
64333
|
+
import_react96 = __toESM(require("react"));
|
|
64283
64334
|
import_nprogress2 = __toESM(require("nprogress"));
|
|
64284
64335
|
init_icons();
|
|
64285
64336
|
import_use_debounce = require("use-debounce");
|
|
@@ -64390,12 +64441,12 @@ var Threads_exports = {};
|
|
|
64390
64441
|
__export(Threads_exports, {
|
|
64391
64442
|
default: () => Threads_default
|
|
64392
64443
|
});
|
|
64393
|
-
var
|
|
64444
|
+
var import_react97, import_swr8, Threads, Threads_default;
|
|
64394
64445
|
var init_Threads = __esm({
|
|
64395
64446
|
"Threads.tsx"() {
|
|
64396
64447
|
"use strict";
|
|
64397
64448
|
"use client";
|
|
64398
|
-
|
|
64449
|
+
import_react97 = __toESM(require("react"));
|
|
64399
64450
|
init_AppContext();
|
|
64400
64451
|
init_Loading();
|
|
64401
64452
|
import_swr8 = __toESM(require("swr"));
|
|
@@ -64429,8 +64480,8 @@ var init_Threads = __esm({
|
|
|
64429
64480
|
userNameByUrl
|
|
64430
64481
|
} = useNavigationContext();
|
|
64431
64482
|
const { reduceMotion } = useTheme2();
|
|
64432
|
-
const [animationKey, setAnimationKey] = (0,
|
|
64433
|
-
(0,
|
|
64483
|
+
const [animationKey, setAnimationKey] = (0, import_react97.useState)(0);
|
|
64484
|
+
(0, import_react97.useEffect)(() => {
|
|
64434
64485
|
if (!reduceMotion) {
|
|
64435
64486
|
setAnimationKey((prev) => prev + 1);
|
|
64436
64487
|
}
|
|
@@ -64450,7 +64501,7 @@ var init_Threads = __esm({
|
|
|
64450
64501
|
const styles4 = useThreadsStyles();
|
|
64451
64502
|
const [sortByDate, setSortByDate] = useLocalStorage("sortByDate", true);
|
|
64452
64503
|
let userName = rest.userName || userNameByUrl;
|
|
64453
|
-
const [threads, setThreads] = (0,
|
|
64504
|
+
const [threads, setThreads] = (0, import_react97.useState)({
|
|
64454
64505
|
threads: [],
|
|
64455
64506
|
hasNextPage: false,
|
|
64456
64507
|
nextPage: null
|
|
@@ -64467,10 +64518,10 @@ var init_Threads = __esm({
|
|
|
64467
64518
|
router.push(pn);
|
|
64468
64519
|
}
|
|
64469
64520
|
};
|
|
64470
|
-
const [lastStarredId, setLastStarredId] = (0,
|
|
64521
|
+
const [lastStarredId, setLastStarredId] = (0, import_react97.useState)(null);
|
|
64471
64522
|
let sortedThreads = threads.threads;
|
|
64472
|
-
const threadRefs = (0,
|
|
64473
|
-
(0,
|
|
64523
|
+
const threadRefs = (0, import_react97.useRef)({});
|
|
64524
|
+
(0, import_react97.useEffect)(() => {
|
|
64474
64525
|
if (lastStarredId && threadRefs.current[lastStarredId]) {
|
|
64475
64526
|
threadRefs.current[lastStarredId]?.scrollIntoView({
|
|
64476
64527
|
behavior: "smooth",
|
|
@@ -64479,9 +64530,9 @@ var init_Threads = __esm({
|
|
|
64479
64530
|
setLastStarredId(null);
|
|
64480
64531
|
}
|
|
64481
64532
|
}, [sortedThreads, lastStarredId]);
|
|
64482
|
-
const [until, setUntil] = (0,
|
|
64483
|
-
const [search, setSearch] = (0,
|
|
64484
|
-
const [isLoading, setIsLoading] = (0,
|
|
64533
|
+
const [until, setUntil] = (0, import_react97.useState)(1);
|
|
64534
|
+
const [search, setSearch] = (0, import_react97.useState)("");
|
|
64535
|
+
const [isLoading, setIsLoading] = (0, import_react97.useState)(true);
|
|
64485
64536
|
const { actions } = useData();
|
|
64486
64537
|
const {
|
|
64487
64538
|
data: threadsData,
|
|
@@ -64505,24 +64556,24 @@ var init_Threads = __esm({
|
|
|
64505
64556
|
// revalidateOnMount: true,
|
|
64506
64557
|
}
|
|
64507
64558
|
);
|
|
64508
|
-
(0,
|
|
64559
|
+
(0, import_react97.useEffect)(() => {
|
|
64509
64560
|
if (token && until) {
|
|
64510
64561
|
refetch();
|
|
64511
64562
|
}
|
|
64512
64563
|
}, [token, until, sortByDate, collaborationStatus]);
|
|
64513
|
-
(0,
|
|
64564
|
+
(0, import_react97.useEffect)(() => {
|
|
64514
64565
|
if (error) {
|
|
64515
64566
|
setIsLoading(false);
|
|
64516
64567
|
}
|
|
64517
64568
|
}, [error]);
|
|
64518
|
-
const [isLoadingMore, setIsLoadingMore] = (0,
|
|
64519
|
-
(0,
|
|
64569
|
+
const [isLoadingMore, setIsLoadingMore] = (0, import_react97.useState)(false);
|
|
64570
|
+
(0, import_react97.useEffect)(() => {
|
|
64520
64571
|
if (threadsData && Array.isArray(threadsData.threads)) {
|
|
64521
64572
|
setThreads(threadsData);
|
|
64522
64573
|
setIsLoading(false);
|
|
64523
64574
|
}
|
|
64524
64575
|
}, [threadsData, user]);
|
|
64525
|
-
return /* @__PURE__ */
|
|
64576
|
+
return /* @__PURE__ */ import_react97.default.createElement(Skeleton, null, /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.threads.style } }, /* @__PURE__ */ import_react97.default.createElement(H2, { style: { ...styles4.threadsTitle.style } }, profile?.image ? /* @__PURE__ */ import_react97.default.createElement(
|
|
64526
64577
|
ImageComponent,
|
|
64527
64578
|
{
|
|
64528
64579
|
style: { ...styles4.profileImage.style },
|
|
@@ -64531,7 +64582,7 @@ var init_Threads = __esm({
|
|
|
64531
64582
|
height: 22,
|
|
64532
64583
|
alt: profile?.name || ""
|
|
64533
64584
|
}
|
|
64534
|
-
) : /* @__PURE__ */
|
|
64585
|
+
) : /* @__PURE__ */ import_react97.default.createElement(import_react97.default.Fragment, null, /* @__PURE__ */ import_react97.default.createElement(icons_exports.AtSign, { size: 22 })), profile?.name ?? t5("Threads"), baseApp && baseApp?.id !== app?.id && /* @__PURE__ */ import_react97.default.createElement(
|
|
64535
64586
|
"a",
|
|
64536
64587
|
{
|
|
64537
64588
|
style: {
|
|
@@ -64541,9 +64592,9 @@ var init_Threads = __esm({
|
|
|
64541
64592
|
},
|
|
64542
64593
|
href: getAppSlug2(baseApp)
|
|
64543
64594
|
},
|
|
64544
|
-
/* @__PURE__ */
|
|
64595
|
+
/* @__PURE__ */ import_react97.default.createElement(ImageComponent, { app: baseApp, size: 22 }),
|
|
64545
64596
|
t5("back to Vex").replace("Vex", baseApp?.name || "")
|
|
64546
|
-
)), /* @__PURE__ */
|
|
64597
|
+
)), /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.characterProfiles.style } }, (profile?.characterProfiles || []).slice(0, 3).map((characterProfile) => /* @__PURE__ */ import_react97.default.createElement(
|
|
64547
64598
|
"a",
|
|
64548
64599
|
{
|
|
64549
64600
|
key: characterProfile.id,
|
|
@@ -64554,7 +64605,7 @@ var init_Threads = __esm({
|
|
|
64554
64605
|
className: "button inverted xSmall",
|
|
64555
64606
|
href: `/u?similarTo=${characterProfile.id}`
|
|
64556
64607
|
},
|
|
64557
|
-
/* @__PURE__ */
|
|
64608
|
+
/* @__PURE__ */ import_react97.default.createElement(
|
|
64558
64609
|
icons_exports.Sparkles,
|
|
64559
64610
|
{
|
|
64560
64611
|
size: 16,
|
|
@@ -64563,7 +64614,7 @@ var init_Threads = __esm({
|
|
|
64563
64614
|
}
|
|
64564
64615
|
),
|
|
64565
64616
|
characterProfile.name
|
|
64566
|
-
))), /* @__PURE__ */
|
|
64617
|
+
))), /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.searchContainer.style } }, /* @__PURE__ */ import_react97.default.createElement(import_react97.default.Fragment, null, /* @__PURE__ */ import_react97.default.createElement(
|
|
64567
64618
|
Search3,
|
|
64568
64619
|
{
|
|
64569
64620
|
dataTestId: "threads-search",
|
|
@@ -64571,7 +64622,7 @@ var init_Threads = __esm({
|
|
|
64571
64622
|
scroll: false,
|
|
64572
64623
|
onChange: (search2) => setSearch(search2)
|
|
64573
64624
|
}
|
|
64574
|
-
), !isVisitor && /* @__PURE__ */
|
|
64625
|
+
), !isVisitor && /* @__PURE__ */ import_react97.default.createElement(import_react97.default.Fragment, null, /* @__PURE__ */ import_react97.default.createElement(
|
|
64575
64626
|
Button,
|
|
64576
64627
|
{
|
|
64577
64628
|
"data-testid": "threads-collaboration",
|
|
@@ -64582,14 +64633,14 @@ var init_Threads = __esm({
|
|
|
64582
64633
|
collaborationStatus === "pending" ? setCollaborationStatus(null) : setCollaborationStatus("pending");
|
|
64583
64634
|
}
|
|
64584
64635
|
},
|
|
64585
|
-
/* @__PURE__ */
|
|
64636
|
+
/* @__PURE__ */ import_react97.default.createElement(
|
|
64586
64637
|
icons_exports.BellDot,
|
|
64587
64638
|
{
|
|
64588
64639
|
color: collaborationStatus === "pending" ? "var(--accent-1)" : void 0,
|
|
64589
64640
|
size: 20
|
|
64590
64641
|
}
|
|
64591
64642
|
)
|
|
64592
|
-
), /* @__PURE__ */
|
|
64643
|
+
), /* @__PURE__ */ import_react97.default.createElement(
|
|
64593
64644
|
Button,
|
|
64594
64645
|
{
|
|
64595
64646
|
className: "inverted",
|
|
@@ -64601,14 +64652,14 @@ var init_Threads = __esm({
|
|
|
64601
64652
|
);
|
|
64602
64653
|
}
|
|
64603
64654
|
},
|
|
64604
|
-
/* @__PURE__ */
|
|
64655
|
+
/* @__PURE__ */ import_react97.default.createElement(
|
|
64605
64656
|
icons_exports.UsersRound,
|
|
64606
64657
|
{
|
|
64607
64658
|
color: collaborationStatus === "active" ? "var(--accent-1)" : void 0,
|
|
64608
64659
|
size: 20
|
|
64609
64660
|
}
|
|
64610
64661
|
)
|
|
64611
|
-
), /* @__PURE__ */
|
|
64662
|
+
), /* @__PURE__ */ import_react97.default.createElement(
|
|
64612
64663
|
Button,
|
|
64613
64664
|
{
|
|
64614
64665
|
"data-testid": `threads-sort-button-${sortByDate ? "date" : "star"}`,
|
|
@@ -64618,7 +64669,7 @@ var init_Threads = __esm({
|
|
|
64618
64669
|
setSortByDate(!sortByDate);
|
|
64619
64670
|
}
|
|
64620
64671
|
},
|
|
64621
|
-
!sortByDate ? /* @__PURE__ */
|
|
64672
|
+
!sortByDate ? /* @__PURE__ */ import_react97.default.createElement(icons_exports.CalendarIcon, { size: 20 }) : /* @__PURE__ */ import_react97.default.createElement(
|
|
64622
64673
|
icons_exports.StarIcon,
|
|
64623
64674
|
{
|
|
64624
64675
|
fill: "var(--accent-1)",
|
|
@@ -64626,13 +64677,13 @@ var init_Threads = __esm({
|
|
|
64626
64677
|
size: 20
|
|
64627
64678
|
}
|
|
64628
64679
|
)
|
|
64629
|
-
)))), isLoading && !isLoadingMore && !search ? /* @__PURE__ */
|
|
64680
|
+
)))), isLoading && !isLoadingMore && !search ? /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.loadingContainer.style } }, /* @__PURE__ */ import_react97.default.createElement(Loading, null)) : /* @__PURE__ */ import_react97.default.createElement(import_react97.default.Fragment, null, /* @__PURE__ */ import_react97.default.createElement(
|
|
64630
64681
|
Div,
|
|
64631
64682
|
{
|
|
64632
64683
|
"data-testid": "threads-container",
|
|
64633
64684
|
style: { ...styles4.threadsContainer.style }
|
|
64634
64685
|
},
|
|
64635
|
-
sortedThreads.map((thread2, index) => /* @__PURE__ */
|
|
64686
|
+
sortedThreads.map((thread2, index) => /* @__PURE__ */ import_react97.default.createElement(
|
|
64636
64687
|
MotiView,
|
|
64637
64688
|
{
|
|
64638
64689
|
key: `${thread2.id}-${animationKey}`,
|
|
@@ -64643,7 +64694,7 @@ var init_Threads = __esm({
|
|
|
64643
64694
|
delay: reduceMotion ? 0 : index * 50
|
|
64644
64695
|
}
|
|
64645
64696
|
},
|
|
64646
|
-
/* @__PURE__ */
|
|
64697
|
+
/* @__PURE__ */ import_react97.default.createElement(
|
|
64647
64698
|
Div,
|
|
64648
64699
|
{
|
|
64649
64700
|
"data-testid": "threads-item",
|
|
@@ -64652,7 +64703,7 @@ var init_Threads = __esm({
|
|
|
64652
64703
|
},
|
|
64653
64704
|
className: "threadsItem"
|
|
64654
64705
|
},
|
|
64655
|
-
/* @__PURE__ */
|
|
64706
|
+
/* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.threadItemTitle.style } }, !isVisitor && /* @__PURE__ */ import_react97.default.createElement(
|
|
64656
64707
|
EditThread,
|
|
64657
64708
|
{
|
|
64658
64709
|
refetch: async () => {
|
|
@@ -64663,7 +64714,7 @@ var init_Threads = __esm({
|
|
|
64663
64714
|
}
|
|
64664
64715
|
), (() => {
|
|
64665
64716
|
const url = `/threads/${thread2.id}`;
|
|
64666
|
-
return /* @__PURE__ */
|
|
64717
|
+
return /* @__PURE__ */ import_react97.default.createElement(
|
|
64667
64718
|
A,
|
|
64668
64719
|
{
|
|
64669
64720
|
"data-testid": "threads-item-title",
|
|
@@ -64679,7 +64730,7 @@ var init_Threads = __esm({
|
|
|
64679
64730
|
},
|
|
64680
64731
|
thread2.title
|
|
64681
64732
|
);
|
|
64682
|
-
})(), !isVisitor && /* @__PURE__ */
|
|
64733
|
+
})(), !isVisitor && /* @__PURE__ */ import_react97.default.createElement(
|
|
64683
64734
|
Bookmark,
|
|
64684
64735
|
{
|
|
64685
64736
|
dataTestId: "threads",
|
|
@@ -64689,12 +64740,12 @@ var init_Threads = __esm({
|
|
|
64689
64740
|
},
|
|
64690
64741
|
thread: thread2
|
|
64691
64742
|
}
|
|
64692
|
-
), /* @__PURE__ */
|
|
64693
|
-
/* @__PURE__ */
|
|
64743
|
+
), /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.right.style } }, /* @__PURE__ */ import_react97.default.createElement(Span, { style: { ...styles4.threadItemDate.style } }, timeAgo2(thread2.createdOn, language)), !isVisitor && /* @__PURE__ */ import_react97.default.createElement(Share3, { thread: thread2, size: 13 }))),
|
|
64744
|
+
/* @__PURE__ */ import_react97.default.createElement(Span, { style: { ...styles4.threadAiResponse.style } }, thread2.aiResponse)
|
|
64694
64745
|
)
|
|
64695
64746
|
)),
|
|
64696
|
-
threads?.threads?.length === 0 && /* @__PURE__ */
|
|
64697
|
-
threads?.hasNextPage && /* @__PURE__ */
|
|
64747
|
+
threads?.threads?.length === 0 && /* @__PURE__ */ import_react97.default.createElement(P, null, t5("Nothing here yet")),
|
|
64748
|
+
threads?.hasNextPage && /* @__PURE__ */ import_react97.default.createElement(Div, { style: { ...styles4.loadMoreButtonContainer.style } }, /* @__PURE__ */ import_react97.default.createElement(
|
|
64698
64749
|
Button,
|
|
64699
64750
|
{
|
|
64700
64751
|
onClick: () => {
|
|
@@ -64703,7 +64754,7 @@ var init_Threads = __esm({
|
|
|
64703
64754
|
},
|
|
64704
64755
|
style: { ...styles4.loadMoreButton.style }
|
|
64705
64756
|
},
|
|
64706
|
-
/* @__PURE__ */
|
|
64757
|
+
/* @__PURE__ */ import_react97.default.createElement(icons_exports.LoaderCircle, { size: 16 }),
|
|
64707
64758
|
t5("Load more")
|
|
64708
64759
|
))
|
|
64709
64760
|
))));
|
|
@@ -64744,12 +64795,12 @@ var init_Collaborate_styles = __esm({
|
|
|
64744
64795
|
});
|
|
64745
64796
|
|
|
64746
64797
|
// Collaborate.tsx
|
|
64747
|
-
var
|
|
64798
|
+
var import_react98, import_react_hot_toast23, Collaborate, Collaborate_default;
|
|
64748
64799
|
var init_Collaborate = __esm({
|
|
64749
64800
|
"Collaborate.tsx"() {
|
|
64750
64801
|
"use strict";
|
|
64751
64802
|
"use client";
|
|
64752
|
-
|
|
64803
|
+
import_react98 = __toESM(require("react"));
|
|
64753
64804
|
init_icons();
|
|
64754
64805
|
init_AppContext();
|
|
64755
64806
|
init_Modal();
|
|
@@ -64764,11 +64815,11 @@ var init_Collaborate = __esm({
|
|
|
64764
64815
|
const { token, user, API_URL: API_URL2, FRONTEND_URL: FRONTEND_URL2 } = useAuth();
|
|
64765
64816
|
const { t: t5 } = useAppContext();
|
|
64766
64817
|
const { addHapticFeedback } = useTheme2();
|
|
64767
|
-
const [isOpen, setIsOpen] = (0,
|
|
64768
|
-
const [content, setContent] = (0,
|
|
64818
|
+
const [isOpen, setIsOpen] = (0, import_react98.useState)(false);
|
|
64819
|
+
const [content, setContent] = (0, import_react98.useState)("");
|
|
64769
64820
|
const styles4 = useCollaborateStyles();
|
|
64770
|
-
const [isLoading, setIsLoading] = (0,
|
|
64771
|
-
return /* @__PURE__ */
|
|
64821
|
+
const [isLoading, setIsLoading] = (0, import_react98.useState)(false);
|
|
64822
|
+
return /* @__PURE__ */ import_react98.default.createElement(Div, null, /* @__PURE__ */ import_react98.default.createElement(
|
|
64772
64823
|
Button,
|
|
64773
64824
|
{
|
|
64774
64825
|
onClick: () => {
|
|
@@ -64787,21 +64838,21 @@ var init_Collaborate = __esm({
|
|
|
64787
64838
|
setIsOpen(true);
|
|
64788
64839
|
}
|
|
64789
64840
|
},
|
|
64790
|
-
/* @__PURE__ */
|
|
64841
|
+
/* @__PURE__ */ import_react98.default.createElement(icons_exports.UsersRound, { size: 18 }),
|
|
64791
64842
|
t5("Collaborate")
|
|
64792
|
-
), /* @__PURE__ */
|
|
64843
|
+
), /* @__PURE__ */ import_react98.default.createElement(
|
|
64793
64844
|
Modal,
|
|
64794
64845
|
{
|
|
64795
64846
|
style: styles4.modal.style,
|
|
64796
64847
|
hasCloseButton: true,
|
|
64797
64848
|
hideOnClickOutside: false,
|
|
64798
64849
|
isModalOpen: isOpen,
|
|
64799
|
-
title: /* @__PURE__ */
|
|
64850
|
+
title: /* @__PURE__ */ import_react98.default.createElement(import_react98.default.Fragment, null, /* @__PURE__ */ import_react98.default.createElement(import_react98.default.Fragment, null, /* @__PURE__ */ import_react98.default.createElement(icons_exports.UsersRound, { color: "var(--accent-6)", size: 24 }), /* @__PURE__ */ import_react98.default.createElement(Span, null, t5("Collaborate")))),
|
|
64800
64851
|
onToggle: (open) => {
|
|
64801
64852
|
setIsOpen(open);
|
|
64802
64853
|
}
|
|
64803
64854
|
},
|
|
64804
|
-
/* @__PURE__ */
|
|
64855
|
+
/* @__PURE__ */ import_react98.default.createElement(
|
|
64805
64856
|
TextArea,
|
|
64806
64857
|
{
|
|
64807
64858
|
disabled: false,
|
|
@@ -64822,7 +64873,7 @@ ${t5(`Describe what you'd like to collaborate on:`)}
|
|
|
64822
64873
|
${t5(`Share your vision and invite others to join the conversation!`)}`
|
|
64823
64874
|
}
|
|
64824
64875
|
),
|
|
64825
|
-
/* @__PURE__ */
|
|
64876
|
+
/* @__PURE__ */ import_react98.default.createElement(Div, { style: styles4.actions.style }, /* @__PURE__ */ import_react98.default.createElement(
|
|
64826
64877
|
Button,
|
|
64827
64878
|
{
|
|
64828
64879
|
disabled: isLoading || !content,
|
|
@@ -64886,7 +64937,7 @@ ${t5(`Share your vision and invite others to join the conversation!`)}`
|
|
|
64886
64937
|
}
|
|
64887
64938
|
}
|
|
64888
64939
|
},
|
|
64889
|
-
isLoading ? /* @__PURE__ */
|
|
64940
|
+
isLoading ? /* @__PURE__ */ import_react98.default.createElement(Loading, { size: 18 }) : /* @__PURE__ */ import_react98.default.createElement(import_react98.default.Fragment, null, /* @__PURE__ */ import_react98.default.createElement(icons_exports.Send, { size: 18 })),
|
|
64890
64941
|
t5("Send")
|
|
64891
64942
|
))
|
|
64892
64943
|
));
|
|
@@ -64989,12 +65040,12 @@ var Users_exports = {};
|
|
|
64989
65040
|
__export(Users_exports, {
|
|
64990
65041
|
default: () => Users_default
|
|
64991
65042
|
});
|
|
64992
|
-
var
|
|
65043
|
+
var import_react99, import_clsx12, import_swr9, import_react_hot_toast24, Users2, Users_default;
|
|
64993
65044
|
var init_Users = __esm({
|
|
64994
65045
|
"Users.tsx"() {
|
|
64995
65046
|
"use strict";
|
|
64996
65047
|
"use client";
|
|
64997
|
-
|
|
65048
|
+
import_react99 = __toESM(require("react"));
|
|
64998
65049
|
init_Skeleton();
|
|
64999
65050
|
import_clsx12 = __toESM(require("clsx"));
|
|
65000
65051
|
import_swr9 = __toESM(require("swr"));
|
|
@@ -65014,18 +65065,18 @@ var init_Users = __esm({
|
|
|
65014
65065
|
Users2 = ({ style }) => {
|
|
65015
65066
|
const styles4 = useUsersStyles();
|
|
65016
65067
|
const { utilities } = useStyles();
|
|
65017
|
-
const [until, setUntil] = (0,
|
|
65068
|
+
const [until, setUntil] = (0, import_react99.useState)(1);
|
|
65018
65069
|
const { token } = useAuth();
|
|
65019
65070
|
const { t: t5 } = useAppContext();
|
|
65020
65071
|
const { router, searchParams } = useNavigationContext();
|
|
65021
|
-
const [find, setFind] = (0,
|
|
65072
|
+
const [find, setFind] = (0, import_react99.useState)(searchParams?.get("find") || "");
|
|
65022
65073
|
const { router: historyRouter } = useWindowHistory();
|
|
65023
|
-
const [similarTo, setSimilarTo] = (0,
|
|
65074
|
+
const [similarTo, setSimilarTo] = (0, import_react99.useState)(
|
|
65024
65075
|
searchParams?.get("similarTo") || void 0
|
|
65025
65076
|
);
|
|
65026
|
-
const [hasNextPage, setHasNextPage] = (0,
|
|
65027
|
-
const [isLoadingMore, setIsLoadingMore] = (0,
|
|
65028
|
-
(0,
|
|
65077
|
+
const [hasNextPage, setHasNextPage] = (0, import_react99.useState)(false);
|
|
65078
|
+
const [isLoadingMore, setIsLoadingMore] = (0, import_react99.useState)(false);
|
|
65079
|
+
(0, import_react99.useEffect)(() => {
|
|
65029
65080
|
if (!searchParams) return;
|
|
65030
65081
|
const to = searchParams.get("similarTo");
|
|
65031
65082
|
if (to && to !== similarTo) {
|
|
@@ -65037,9 +65088,9 @@ var init_Users = __esm({
|
|
|
65037
65088
|
setFind(findParam);
|
|
65038
65089
|
}
|
|
65039
65090
|
}, [searchParams, similarTo, find]);
|
|
65040
|
-
const [selectedCharacterProfileId, setSelectedCharacterProfileId] = (0,
|
|
65091
|
+
const [selectedCharacterProfileId, setSelectedCharacterProfileId] = (0, import_react99.useState)(void 0);
|
|
65041
65092
|
const { actions } = useData();
|
|
65042
|
-
const [users, setUsers] = (0,
|
|
65093
|
+
const [users, setUsers] = (0, import_react99.useState)([]);
|
|
65043
65094
|
const { data: usersData, error } = (0, import_swr9.default)(
|
|
65044
65095
|
token ? ["users", until, find, similarTo] : null,
|
|
65045
65096
|
() => {
|
|
@@ -65051,8 +65102,8 @@ var init_Users = __esm({
|
|
|
65051
65102
|
});
|
|
65052
65103
|
}
|
|
65053
65104
|
);
|
|
65054
|
-
const [isLoading, setIsLoading] = (0,
|
|
65055
|
-
(0,
|
|
65105
|
+
const [isLoading, setIsLoading] = (0, import_react99.useState)(true);
|
|
65106
|
+
(0, import_react99.useEffect)(() => {
|
|
65056
65107
|
if (usersData) {
|
|
65057
65108
|
setIsLoading(false);
|
|
65058
65109
|
}
|
|
@@ -65061,13 +65112,13 @@ var init_Users = __esm({
|
|
|
65061
65112
|
setHasNextPage(usersData.users.hasNextPage);
|
|
65062
65113
|
}
|
|
65063
65114
|
}, [usersData]);
|
|
65064
|
-
(0,
|
|
65115
|
+
(0, import_react99.useEffect)(() => {
|
|
65065
65116
|
if (error) {
|
|
65066
65117
|
import_react_hot_toast24.default.error(error.message);
|
|
65067
65118
|
setIsLoading(false);
|
|
65068
65119
|
}
|
|
65069
65120
|
}, [error]);
|
|
65070
|
-
return /* @__PURE__ */
|
|
65121
|
+
return /* @__PURE__ */ import_react99.default.createElement(Skeleton, null, /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.users.style, ...style } }, /* @__PURE__ */ import_react99.default.createElement(H1, { style: { ...styles4.usersTitle.style } }, /* @__PURE__ */ import_react99.default.createElement(icons_exports.UsersRound, { size: 26 }), " ", t5("Users")), /* @__PURE__ */ import_react99.default.createElement(
|
|
65071
65122
|
Search3,
|
|
65072
65123
|
{
|
|
65073
65124
|
paramName: "find",
|
|
@@ -65086,7 +65137,7 @@ var init_Users = __esm({
|
|
|
65086
65137
|
router.push(url.pathname + url.search);
|
|
65087
65138
|
}
|
|
65088
65139
|
}
|
|
65089
|
-
), isLoading && !isLoadingMore && !find ? /* @__PURE__ */
|
|
65140
|
+
), isLoading && !isLoadingMore && !find ? /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.loadingContainer.style } }, /* @__PURE__ */ import_react99.default.createElement(Loading, null)) : /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.usersContainer.style } }, users?.length === 0 && /* @__PURE__ */ import_react99.default.createElement(P, null, t5("Nothing here yet")), users?.map((user) => /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.usersItem.style }, key: user.id }, /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.usersItemUser.style } }, /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.usersItemUserImage.style } }, user.image ? /* @__PURE__ */ import_react99.default.createElement(
|
|
65090
65141
|
Img,
|
|
65091
65142
|
{
|
|
65092
65143
|
src: user.image,
|
|
@@ -65095,7 +65146,7 @@ var init_Users = __esm({
|
|
|
65095
65146
|
height: 26,
|
|
65096
65147
|
style: { ...styles4.profileImage.style }
|
|
65097
65148
|
}
|
|
65098
|
-
) : /* @__PURE__ */
|
|
65149
|
+
) : /* @__PURE__ */ import_react99.default.createElement(icons_exports.CircleUserRound, { size: 26 }), /* @__PURE__ */ import_react99.default.createElement(
|
|
65099
65150
|
A,
|
|
65100
65151
|
{
|
|
65101
65152
|
onClick: (e) => {
|
|
@@ -65104,7 +65155,7 @@ var init_Users = __esm({
|
|
|
65104
65155
|
}
|
|
65105
65156
|
},
|
|
65106
65157
|
user.name
|
|
65107
|
-
)), /* @__PURE__ */
|
|
65158
|
+
)), /* @__PURE__ */ import_react99.default.createElement(Collaborate_default, { withUser: user })), /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.usersItemCharacterProfiles.style } }, (() => {
|
|
65108
65159
|
const characterProfile = user.characterProfiles.find(
|
|
65109
65160
|
(characterProfile2) => characterProfile2.id === selectedCharacterProfileId
|
|
65110
65161
|
) || user.characterProfiles?.[0];
|
|
@@ -65112,12 +65163,12 @@ var init_Users = __esm({
|
|
|
65112
65163
|
const currentIndex = user.characterProfiles.indexOf(characterProfile);
|
|
65113
65164
|
const nextCharacterProfile = user.characterProfiles[currentIndex + 1];
|
|
65114
65165
|
const previousCharacterProfile = user.characterProfiles[currentIndex - 1];
|
|
65115
|
-
return /* @__PURE__ */
|
|
65166
|
+
return /* @__PURE__ */ import_react99.default.createElement(import_react99.default.Fragment, null, /* @__PURE__ */ import_react99.default.createElement(
|
|
65116
65167
|
Div,
|
|
65117
65168
|
{
|
|
65118
65169
|
style: { ...styles4.usersItemCharacterProfile.style }
|
|
65119
65170
|
},
|
|
65120
|
-
/* @__PURE__ */
|
|
65171
|
+
/* @__PURE__ */ import_react99.default.createElement(
|
|
65121
65172
|
A,
|
|
65122
65173
|
{
|
|
65123
65174
|
key: characterProfile.id,
|
|
@@ -65134,7 +65185,7 @@ var init_Users = __esm({
|
|
|
65134
65185
|
},
|
|
65135
65186
|
href: `/u?similarTo=${characterProfile.id}`
|
|
65136
65187
|
},
|
|
65137
|
-
/* @__PURE__ */
|
|
65188
|
+
/* @__PURE__ */ import_react99.default.createElement(
|
|
65138
65189
|
icons_exports.Sparkles,
|
|
65139
65190
|
{
|
|
65140
65191
|
size: 16,
|
|
@@ -65144,7 +65195,7 @@ var init_Users = __esm({
|
|
|
65144
65195
|
),
|
|
65145
65196
|
characterProfile.name
|
|
65146
65197
|
),
|
|
65147
|
-
previousCharacterProfile && /* @__PURE__ */
|
|
65198
|
+
previousCharacterProfile && /* @__PURE__ */ import_react99.default.createElement(
|
|
65148
65199
|
Button,
|
|
65149
65200
|
{
|
|
65150
65201
|
className: "link",
|
|
@@ -65155,9 +65206,9 @@ var init_Users = __esm({
|
|
|
65155
65206
|
);
|
|
65156
65207
|
}
|
|
65157
65208
|
},
|
|
65158
|
-
/* @__PURE__ */
|
|
65209
|
+
/* @__PURE__ */ import_react99.default.createElement(icons_exports.ArrowLeft, { size: 18 })
|
|
65159
65210
|
),
|
|
65160
|
-
nextCharacterProfile && /* @__PURE__ */
|
|
65211
|
+
nextCharacterProfile && /* @__PURE__ */ import_react99.default.createElement(
|
|
65161
65212
|
Button,
|
|
65162
65213
|
{
|
|
65163
65214
|
className: "link",
|
|
@@ -65168,10 +65219,10 @@ var init_Users = __esm({
|
|
|
65168
65219
|
);
|
|
65169
65220
|
}
|
|
65170
65221
|
},
|
|
65171
|
-
/* @__PURE__ */
|
|
65222
|
+
/* @__PURE__ */ import_react99.default.createElement(icons_exports.ArrowRight, { size: 18 })
|
|
65172
65223
|
)
|
|
65173
|
-
), /* @__PURE__ */
|
|
65174
|
-
})())))), hasNextPage && /* @__PURE__ */
|
|
65224
|
+
), /* @__PURE__ */ import_react99.default.createElement(Div, { style: { ...styles4.tags.style } }, characterProfile.tags?.join(", ")));
|
|
65225
|
+
})())))), hasNextPage && /* @__PURE__ */ import_react99.default.createElement(
|
|
65175
65226
|
Div,
|
|
65176
65227
|
{
|
|
65177
65228
|
style: {
|
|
@@ -65179,7 +65230,7 @@ var init_Users = __esm({
|
|
|
65179
65230
|
...utilities.transparent.style
|
|
65180
65231
|
}
|
|
65181
65232
|
},
|
|
65182
|
-
/* @__PURE__ */
|
|
65233
|
+
/* @__PURE__ */ import_react99.default.createElement(
|
|
65183
65234
|
Button,
|
|
65184
65235
|
{
|
|
65185
65236
|
onClick: () => {
|
|
@@ -65189,7 +65240,7 @@ var init_Users = __esm({
|
|
|
65189
65240
|
style: { ...styles4.loadMoreButton },
|
|
65190
65241
|
className: "transparent"
|
|
65191
65242
|
},
|
|
65192
|
-
/* @__PURE__ */
|
|
65243
|
+
/* @__PURE__ */ import_react99.default.createElement(icons_exports.LoaderCircle, { size: 18 }),
|
|
65193
65244
|
t5("Load more")
|
|
65194
65245
|
)
|
|
65195
65246
|
)));
|
|
@@ -65423,7 +65474,7 @@ function Affiliate() {
|
|
|
65423
65474
|
const is = useHasHydrated();
|
|
65424
65475
|
const { addHapticFeedback } = useTheme2();
|
|
65425
65476
|
const { affiliateStats, refetchAffiliateData, loadingAffiliateStats } = useData();
|
|
65426
|
-
const [creating, setCreating] = (0,
|
|
65477
|
+
const [creating, setCreating] = (0, import_react100.useState)(false);
|
|
65427
65478
|
const createAffiliateLink = async () => {
|
|
65428
65479
|
addHapticFeedback();
|
|
65429
65480
|
if (!user) {
|
|
@@ -65451,7 +65502,7 @@ function Affiliate() {
|
|
|
65451
65502
|
const config2 = getSiteConfig();
|
|
65452
65503
|
const isChrryAI = config2.mode === "chrryAI";
|
|
65453
65504
|
if (!is) return null;
|
|
65454
|
-
return /* @__PURE__ */
|
|
65505
|
+
return /* @__PURE__ */ import_react100.default.createElement(Skeleton, null, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.affiliate.style }, /* @__PURE__ */ import_react100.default.createElement(Div, null, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.hero.style }, /* @__PURE__ */ import_react100.default.createElement(
|
|
65455
65506
|
ImageComponent,
|
|
65456
65507
|
{
|
|
65457
65508
|
showLoading: false,
|
|
@@ -65460,10 +65511,10 @@ function Affiliate() {
|
|
|
65460
65511
|
width: 50,
|
|
65461
65512
|
height: 50
|
|
65462
65513
|
}
|
|
65463
|
-
), /* @__PURE__ */
|
|
65514
|
+
), /* @__PURE__ */ import_react100.default.createElement(H1, { style: styles4.h1.style }, " ", t5("{{app}} Affiliate Program", { app: config2.name })), /* @__PURE__ */ import_react100.default.createElement(P, { style: styles4.subtitle.style }, t5(
|
|
65464
65515
|
"Earn {{commission}} commission by sharing {{app}} with your audience",
|
|
65465
65516
|
{ commission: "20%", app: config2.name }
|
|
65466
|
-
)), loadingAffiliateStats ? null : affiliateStats?.hasAffiliateLink && /* @__PURE__ */
|
|
65517
|
+
)), loadingAffiliateStats ? null : affiliateStats?.hasAffiliateLink && /* @__PURE__ */ import_react100.default.createElement(
|
|
65467
65518
|
Button,
|
|
65468
65519
|
{
|
|
65469
65520
|
className: "inverted",
|
|
@@ -65475,10 +65526,10 @@ function Affiliate() {
|
|
|
65475
65526
|
router.push("/affiliate/dashboard");
|
|
65476
65527
|
}
|
|
65477
65528
|
},
|
|
65478
|
-
/* @__PURE__ */
|
|
65529
|
+
/* @__PURE__ */ import_react100.default.createElement(icons_exports.TrendingUp, { size: 16 }),
|
|
65479
65530
|
" ",
|
|
65480
65531
|
t5("Go to Dashboard")
|
|
65481
|
-
)), /* @__PURE__ */
|
|
65532
|
+
)), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefits.style }, /* @__PURE__ */ import_react100.default.createElement(H2, { style: styles4.h2.style }, "\u{1F929} ", t5("Why Join?")), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefitGrid.style }, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefit.style }, /* @__PURE__ */ import_react100.default.createElement(icons_exports.Coins, { color: COLORS.blue, size: 32 }), /* @__PURE__ */ import_react100.default.createElement(H3, { style: styles4.h3.style }, " ", t5("20% Commission")), /* @__PURE__ */ import_react100.default.createElement(P, null, t5("Earn 20% recurring commission on all referrals"))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefit.style }, /* @__PURE__ */ import_react100.default.createElement(icons_exports.UserRoundPlus, { color: COLORS.orange, size: 32 }), /* @__PURE__ */ import_react100.default.createElement(H3, { style: styles4.h3.style }, " ", t5("30% Bonus Credits")), /* @__PURE__ */ import_react100.default.createElement(P, null, t5("Your referrals get 30% bonus credits on their purchase"))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefit.style }, /* @__PURE__ */ import_react100.default.createElement(icons_exports.TrendingUp, { color: COLORS.green, size: 32 }), /* @__PURE__ */ import_react100.default.createElement(H3, { style: styles4.h3.style }, " ", t5("Real-Time Dashboard")), /* @__PURE__ */ import_react100.default.createElement(P, null, t5("Track clicks, conversions, and earnings in real-time"))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.benefit.style }, /* @__PURE__ */ import_react100.default.createElement(icons_exports.MousePointerClick, { color: COLORS.violet, size: 32 }), /* @__PURE__ */ import_react100.default.createElement(H3, { style: styles4.h3.style }, " ", t5("30-Day Cookie")), /* @__PURE__ */ import_react100.default.createElement(P, null, t5("Get credit for conversions up to 30 days after click"))))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.earnings.style }, /* @__PURE__ */ import_react100.default.createElement(H2, { style: styles4.earningsh2.style }, "\u{1F4B0} ", t5("Potential Earnings")), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.earningsGrid.style }, /* @__PURE__ */ import_react100.default.createElement(
|
|
65482
65533
|
Div,
|
|
65483
65534
|
{
|
|
65484
65535
|
style: {
|
|
@@ -65486,17 +65537,17 @@ function Affiliate() {
|
|
|
65486
65537
|
...styles4.earningCardPlus.style
|
|
65487
65538
|
}
|
|
65488
65539
|
},
|
|
65489
|
-
/* @__PURE__ */
|
|
65490
|
-
/* @__PURE__ */
|
|
65491
|
-
/* @__PURE__ */
|
|
65492
|
-
/* @__PURE__ */
|
|
65540
|
+
/* @__PURE__ */ import_react100.default.createElement(ImageComponent, { icon: "strawberry", size: 40 }),
|
|
65541
|
+
/* @__PURE__ */ import_react100.default.createElement(H3, { style: styles4.earningCardh3.style }, " ", t5("Plus")),
|
|
65542
|
+
/* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.price.style }, t5("{{price}}/month", { price: "\u20AC9.99" })),
|
|
65543
|
+
/* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.commission.style }, /* @__PURE__ */ import_react100.default.createElement(Strong, null, t5("{{commission}}/month per subscriber", {
|
|
65493
65544
|
commission: "\u20AC1.99"
|
|
65494
65545
|
}))),
|
|
65495
|
-
/* @__PURE__ */
|
|
65546
|
+
/* @__PURE__ */ import_react100.default.createElement(P, { style: styles4.detail.style }, t5("{{commission}} of {{price}}/month recurring", {
|
|
65496
65547
|
commission: "20%",
|
|
65497
65548
|
price: "\u20AC9.99"
|
|
65498
65549
|
}))
|
|
65499
|
-
), /* @__PURE__ */
|
|
65550
|
+
), /* @__PURE__ */ import_react100.default.createElement(
|
|
65500
65551
|
Div,
|
|
65501
65552
|
{
|
|
65502
65553
|
style: {
|
|
@@ -65504,27 +65555,27 @@ function Affiliate() {
|
|
|
65504
65555
|
...styles4.earningCardPro.style
|
|
65505
65556
|
}
|
|
65506
65557
|
},
|
|
65507
|
-
/* @__PURE__ */
|
|
65508
|
-
/* @__PURE__ */
|
|
65509
|
-
/* @__PURE__ */
|
|
65510
|
-
/* @__PURE__ */
|
|
65558
|
+
/* @__PURE__ */ import_react100.default.createElement(ImageComponent, { icon: "raspberry", size: 40 }),
|
|
65559
|
+
/* @__PURE__ */ import_react100.default.createElement(H3, null, " ", t5("Pro")),
|
|
65560
|
+
/* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.price.style }, t5("{{price}}/month", { price: "\u20AC19.99" })),
|
|
65561
|
+
/* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.commission.style }, /* @__PURE__ */ import_react100.default.createElement(Strong, null, t5("{{commission}}/month per subscriber", {
|
|
65511
65562
|
commission: "\u20AC3.99"
|
|
65512
65563
|
}))),
|
|
65513
|
-
/* @__PURE__ */
|
|
65564
|
+
/* @__PURE__ */ import_react100.default.createElement(P, { style: styles4.detail.style }, t5("{{commission}} of {{price}}/month recurring", {
|
|
65514
65565
|
commission: "20%",
|
|
65515
65566
|
price: "\u20AC19.99"
|
|
65516
65567
|
}))
|
|
65517
|
-
)), /* @__PURE__ */
|
|
65568
|
+
)), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.example.style }, /* @__PURE__ */ import_react100.default.createElement(P, null, /* @__PURE__ */ import_react100.default.createElement(Strong, null, t5("Example"), ":"), " ", t5(
|
|
65518
65569
|
"Refer {{count}} Pro users = {{commission}}/month recurring",
|
|
65519
65570
|
{
|
|
65520
65571
|
count: 10,
|
|
65521
65572
|
commission: "\u20AC39.90"
|
|
65522
65573
|
}
|
|
65523
|
-
)))), /* @__PURE__ */
|
|
65574
|
+
)))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.howItWorks.style }, /* @__PURE__ */ import_react100.default.createElement(H2, null, " ", t5("How It Works")), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.steps.style }, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.step.style }, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.stepNumber.style }, "1"), /* @__PURE__ */ import_react100.default.createElement(H3, null, " ", t5("Get Your Link")), /* @__PURE__ */ import_react100.default.createElement(P, null, " ", t5("Create your unique affiliate link instantly"))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.step.style }, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.stepNumber.style }, "2"), /* @__PURE__ */ import_react100.default.createElement(H3, null, " ", t5("Share")), /* @__PURE__ */ import_react100.default.createElement(P, null, " ", t5(
|
|
65524
65575
|
"Share with your audience on social media, blog, or email"
|
|
65525
|
-
))), /* @__PURE__ */
|
|
65576
|
+
))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.step.style }, /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.stepNumber.style }, "3"), /* @__PURE__ */ import_react100.default.createElement(H3, null, " ", t5("Earn")), /* @__PURE__ */ import_react100.default.createElement(P, null, t5("Get {{commission}} commission when they subscribe", {
|
|
65526
65577
|
commission: "20%"
|
|
65527
|
-
}))))), /* @__PURE__ */
|
|
65578
|
+
}))))), /* @__PURE__ */ import_react100.default.createElement(Div, { style: styles4.cta.style }, !affiliateStats?.hasAffiliateLink && /* @__PURE__ */ import_react100.default.createElement(
|
|
65528
65579
|
Button,
|
|
65529
65580
|
{
|
|
65530
65581
|
className: "inverted",
|
|
@@ -65536,16 +65587,16 @@ function Affiliate() {
|
|
|
65536
65587
|
...styles4.joinButton.style
|
|
65537
65588
|
}
|
|
65538
65589
|
},
|
|
65539
|
-
/* @__PURE__ */
|
|
65590
|
+
/* @__PURE__ */ import_react100.default.createElement(icons_exports.SmilePlus, { size: 20 }),
|
|
65540
65591
|
creating ? t5("Creating...") : user ? t5("Join Affiliate Program") : t5("Sign In to Join")
|
|
65541
65592
|
)))));
|
|
65542
65593
|
}
|
|
65543
|
-
var
|
|
65594
|
+
var import_react100, import_react_hot_toast25;
|
|
65544
65595
|
var init_Affiliate = __esm({
|
|
65545
65596
|
"affiliate/Affiliate.tsx"() {
|
|
65546
65597
|
"use strict";
|
|
65547
65598
|
"use client";
|
|
65548
|
-
|
|
65599
|
+
import_react100 = __toESM(require("react"));
|
|
65549
65600
|
init_AppContext();
|
|
65550
65601
|
import_react_hot_toast25 = __toESM(require("react-hot-toast"));
|
|
65551
65602
|
init_icons();
|
|
@@ -65856,16 +65907,16 @@ function AffiliateDashboard() {
|
|
|
65856
65907
|
import_react_hot_toast26.default.success("Copied");
|
|
65857
65908
|
}
|
|
65858
65909
|
};
|
|
65859
|
-
(0,
|
|
65910
|
+
(0, import_react101.useEffect)(() => {
|
|
65860
65911
|
if (affiliateStats === null) {
|
|
65861
65912
|
router.push("/affiliate");
|
|
65862
65913
|
}
|
|
65863
65914
|
}, [affiliateStats]);
|
|
65864
65915
|
if (!affiliateStats) {
|
|
65865
|
-
return /* @__PURE__ */
|
|
65916
|
+
return /* @__PURE__ */ import_react101.default.createElement(Loading, null);
|
|
65866
65917
|
}
|
|
65867
65918
|
if (loadingAffiliateStats || affiliateStats && !affiliateStats?.hasAffiliateLink) {
|
|
65868
|
-
return /* @__PURE__ */
|
|
65919
|
+
return /* @__PURE__ */ import_react101.default.createElement(Loading, { fullScreen: true });
|
|
65869
65920
|
}
|
|
65870
65921
|
const copyShareText = () => {
|
|
65871
65922
|
navigator.clipboard.writeText(
|
|
@@ -65878,7 +65929,7 @@ ${affiliateStats.affiliateLink}`
|
|
|
65878
65929
|
);
|
|
65879
65930
|
import_react_hot_toast26.default.success(t5("Copied"));
|
|
65880
65931
|
};
|
|
65881
|
-
return /* @__PURE__ */
|
|
65932
|
+
return /* @__PURE__ */ import_react101.default.createElement(Skeleton, null, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.affiliate.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.dashboard.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.header.style }, /* @__PURE__ */ import_react101.default.createElement(H1, null, /* @__PURE__ */ import_react101.default.createElement(
|
|
65882
65933
|
Button,
|
|
65883
65934
|
{
|
|
65884
65935
|
className: "link",
|
|
@@ -65886,8 +65937,8 @@ ${affiliateStats.affiliateLink}`
|
|
|
65886
65937
|
router.push("/affiliate");
|
|
65887
65938
|
}
|
|
65888
65939
|
},
|
|
65889
|
-
/* @__PURE__ */
|
|
65890
|
-
), t5("Dashboard")), /* @__PURE__ */
|
|
65940
|
+
/* @__PURE__ */ import_react101.default.createElement(icons_exports.CircleArrowLeft, null)
|
|
65941
|
+
), t5("Dashboard")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.status.style }, /* @__PURE__ */ import_react101.default.createElement(
|
|
65891
65942
|
Span,
|
|
65892
65943
|
{
|
|
65893
65944
|
style: {
|
|
@@ -65896,7 +65947,7 @@ ${affiliateStats.affiliateLink}`
|
|
|
65896
65947
|
}
|
|
65897
65948
|
},
|
|
65898
65949
|
affiliateStats.stats?.status === "active" ? t5("Active") : t5("Inactive")
|
|
65899
|
-
))), /* @__PURE__ */
|
|
65950
|
+
))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.linkSection.style }, /* @__PURE__ */ import_react101.default.createElement(H2, { style: styles4.linkSectionH2.style }, "\u{1F929} ", t5("Your Affiliate Link")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.linkBox.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.Link, { color: COLORS.blue, size: 20 }), /* @__PURE__ */ import_react101.default.createElement(
|
|
65900
65951
|
"input",
|
|
65901
65952
|
{
|
|
65902
65953
|
id: "affiliateLink",
|
|
@@ -65905,16 +65956,16 @@ ${affiliateStats.affiliateLink}`
|
|
|
65905
65956
|
readOnly: true,
|
|
65906
65957
|
style: styles4.linkInput.style
|
|
65907
65958
|
}
|
|
65908
|
-
), /* @__PURE__ */
|
|
65959
|
+
), /* @__PURE__ */ import_react101.default.createElement(Button, { style: styles4.copyButton.style, onClick: copyLink }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.Copy, { size: 16 })), /* @__PURE__ */ import_react101.default.createElement(Button, { onClick: () => copyShareText() }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.Share, { size: 16 }), t5("Copy Post"))), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.linkHelp.style }, t5(
|
|
65909
65960
|
"Share this link to earn {{commission}} commission on all subscriptions!",
|
|
65910
65961
|
{ commission: "20%" }
|
|
65911
|
-
))), /* @__PURE__ */
|
|
65962
|
+
))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statsGrid.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statCard.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statIcon.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.MousePointerClick, { color: COLORS.violet, size: 32 })), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statContent.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statLabel.style }, t5("Clicks")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statValue.style }, affiliateStats.stats?.clicks || 0))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statCard.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statIcon.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.UserRoundPlus, { color: COLORS.orange, size: 32 })), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statContent.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statLabel.style }, t5("Conversions")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statValue.style }, affiliateStats.stats?.conversions || 0))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statCard.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statIcon.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.Coins, { color: COLORS.blue, size: 32 })), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statContent.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statLabel.style }, t5("Commission Earned")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statValue.style }, "\u20AC", ((affiliateStats.stats?.commissionEarned || 0) / 100).toFixed(2)))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statCard.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statIcon.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.TrendingUp, { color: COLORS.green, size: 32 })), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statContent.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statLabel.style }, t5("Commission Pending")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.statValue.style }, "\u20AC", ((affiliateStats.stats?.commissionPending || 0) / 100).toFixed(2))))), affiliateStats.stats && affiliateStats.stats.commissionPending >= 5e3 && /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.payoutSection.style }, affiliateStats.pendingPayout ? /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.pendingPayoutInfo.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.pendingBadge.style }, /* @__PURE__ */ import_react101.default.createElement(icons_exports.Clock, { size: 20 }), t5("Payout Pending")), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.pendingAmount.style }, "\u20AC", (affiliateStats.pendingPayout.amount / 100).toFixed(2)), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.pendingDate.style }, t5("Requested on {{date}}", {
|
|
65912
65963
|
date: new Date(
|
|
65913
65964
|
affiliateStats.pendingPayout.requestedOn
|
|
65914
65965
|
).toLocaleDateString()
|
|
65915
|
-
})), /* @__PURE__ */
|
|
65966
|
+
})), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.pendingNote.style }, t5(
|
|
65916
65967
|
"Your payout is being processed. You'll be notified once completed."
|
|
65917
|
-
))) : /* @__PURE__ */
|
|
65968
|
+
))) : /* @__PURE__ */ import_react101.default.createElement(import_react101.default.Fragment, null, /* @__PURE__ */ import_react101.default.createElement(
|
|
65918
65969
|
Button,
|
|
65919
65970
|
{
|
|
65920
65971
|
onClick: async () => {
|
|
@@ -65942,16 +65993,16 @@ ${affiliateStats.affiliateLink}`
|
|
|
65942
65993
|
}
|
|
65943
65994
|
}
|
|
65944
65995
|
},
|
|
65945
|
-
/* @__PURE__ */
|
|
65996
|
+
/* @__PURE__ */ import_react101.default.createElement(icons_exports.Coins, { size: 20 }),
|
|
65946
65997
|
t5("Request Payout"),
|
|
65947
65998
|
" (\u20AC",
|
|
65948
65999
|
((affiliateStats.stats.commissionPending || 0) / 100).toFixed(2),
|
|
65949
66000
|
")"
|
|
65950
|
-
), /* @__PURE__ */
|
|
66001
|
+
), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.payoutNote.style }, t5("Minimum payout: {{amount}}", { amount: "\u20AC50" })))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralsSection.style }, /* @__PURE__ */ import_react101.default.createElement(H2, { style: styles4.referralsSectionH2.style }, t5("Referrals")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralsGrid.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralStat.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralLabel.style }, t5("Total")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralValue.style }, affiliateStats.referrals?.total || 0)), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralStat.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralLabel.style }, t5("Pending")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralValue.style }, affiliateStats.referrals?.pending || 0)), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralStat.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralLabel.style }, t5("Converted")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralValue.style }, affiliateStats.referrals?.converted || 0)), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralStat.style }, /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralLabel.style }, t5("Paid")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.referralValue.style }, affiliateStats.referrals?.paid || 0)))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.info.style }, /* @__PURE__ */ import_react101.default.createElement(H3, { style: styles4.infoH3.style }, " ", t5("Program Details")), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.infoUl.style }, /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.infoUlLi.style }, t5("Commission Rate: {{rate}}", {
|
|
65951
66002
|
rate: affiliateStats.stats?.commissionRate
|
|
65952
|
-
}), "%"), /* @__PURE__ */
|
|
66003
|
+
}), "%"), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.infoUlLi.style }, t5("Referrals get {{bonus}} bonus credits on first purchase", {
|
|
65953
66004
|
bonus: "30%"
|
|
65954
|
-
})), /* @__PURE__ */
|
|
66005
|
+
})), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.infoUlLi.style }, t5("Cookie Duration {{duration}}", { duration: "30 days" })), /* @__PURE__ */ import_react101.default.createElement(P, { style: styles4.infoUlLi.style }, t5("Minimum Payout {{payout}}", { payout: "\u20AC50" })))), /* @__PURE__ */ import_react101.default.createElement(Div, { style: styles4.footer.style }, /* @__PURE__ */ import_react101.default.createElement(
|
|
65955
66006
|
"a",
|
|
65956
66007
|
{
|
|
65957
66008
|
href: `${FRONTEND_URL2}`,
|
|
@@ -65964,17 +66015,17 @@ ${affiliateStats.affiliateLink}`
|
|
|
65964
66015
|
setIsNewChat(true);
|
|
65965
66016
|
}
|
|
65966
66017
|
},
|
|
65967
|
-
/* @__PURE__ */
|
|
66018
|
+
/* @__PURE__ */ import_react101.default.createElement(Logo, { isVivid: true, size: 32 }),
|
|
65968
66019
|
" ",
|
|
65969
66020
|
"Vex"
|
|
65970
66021
|
)))));
|
|
65971
66022
|
}
|
|
65972
|
-
var
|
|
66023
|
+
var import_react101, import_react_hot_toast26, import_clsx13;
|
|
65973
66024
|
var init_AffiliateDashboard = __esm({
|
|
65974
66025
|
"affiliateDashboard/AffiliateDashboard.tsx"() {
|
|
65975
66026
|
"use strict";
|
|
65976
66027
|
"use client";
|
|
65977
|
-
|
|
66028
|
+
import_react101 = __toESM(require("react"));
|
|
65978
66029
|
init_AppContext();
|
|
65979
66030
|
import_react_hot_toast26 = __toESM(require("react-hot-toast"));
|
|
65980
66031
|
init_icons();
|
|
@@ -66004,12 +66055,12 @@ var init_affiliateDashboard = __esm({
|
|
|
66004
66055
|
});
|
|
66005
66056
|
|
|
66006
66057
|
// Hey.tsx
|
|
66007
|
-
var
|
|
66058
|
+
var import_react102, Store2, Calendar3, Why, Privacy2, Terms2, About3, Threads2, Users3, Affiliate2, AffiliateDashboard2, ROUTES, Hey;
|
|
66008
66059
|
var init_Hey = __esm({
|
|
66009
66060
|
"Hey.tsx"() {
|
|
66010
66061
|
"use strict";
|
|
66011
66062
|
"use client";
|
|
66012
|
-
|
|
66063
|
+
import_react102 = require("react");
|
|
66013
66064
|
init_Image();
|
|
66014
66065
|
init_AuthProvider();
|
|
66015
66066
|
init_NavigationProvider();
|
|
@@ -66020,16 +66071,16 @@ var init_Hey = __esm({
|
|
|
66020
66071
|
init_Thread();
|
|
66021
66072
|
init_Home();
|
|
66022
66073
|
init_providers();
|
|
66023
|
-
Store2 = (0,
|
|
66024
|
-
Calendar3 = (0,
|
|
66025
|
-
Why = (0,
|
|
66026
|
-
Privacy2 = (0,
|
|
66027
|
-
Terms2 = (0,
|
|
66028
|
-
About3 = (0,
|
|
66029
|
-
Threads2 = (0,
|
|
66030
|
-
Users3 = (0,
|
|
66031
|
-
Affiliate2 = (0,
|
|
66032
|
-
AffiliateDashboard2 = (0,
|
|
66074
|
+
Store2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Store(), Store_exports)));
|
|
66075
|
+
Calendar3 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Calendar(), Calendar_exports)));
|
|
66076
|
+
Why = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Why(), Why_exports)));
|
|
66077
|
+
Privacy2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Privacy(), Privacy_exports)));
|
|
66078
|
+
Terms2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Terms(), Terms_exports)));
|
|
66079
|
+
About3 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_about(), about_exports)));
|
|
66080
|
+
Threads2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Threads(), Threads_exports)));
|
|
66081
|
+
Users3 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_Users(), Users_exports)));
|
|
66082
|
+
Affiliate2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_affiliate(), affiliate_exports)));
|
|
66083
|
+
AffiliateDashboard2 = (0, import_react102.lazy)(() => Promise.resolve().then(() => (init_affiliateDashboard(), affiliateDashboard_exports)));
|
|
66033
66084
|
ROUTES = {
|
|
66034
66085
|
calendar: Calendar3,
|
|
66035
66086
|
why: Why,
|
|
@@ -66042,7 +66093,7 @@ var init_Hey = __esm({
|
|
|
66042
66093
|
"affiliate/dashboard": AffiliateDashboard2,
|
|
66043
66094
|
u: Users3
|
|
66044
66095
|
};
|
|
66045
|
-
Hey = (0,
|
|
66096
|
+
Hey = (0, import_react102.memo)(
|
|
66046
66097
|
function Hey2({
|
|
66047
66098
|
className,
|
|
66048
66099
|
children,
|
|
@@ -66052,7 +66103,7 @@ var init_Hey = __esm({
|
|
|
66052
66103
|
const { isExtension: isExtension2 } = usePlatform();
|
|
66053
66104
|
const styles4 = useSidebarStyles();
|
|
66054
66105
|
const [pathnameLocal, setPathnameLocal] = useLocalStorage2("pathname", isExtension2 ? pathname : void 0);
|
|
66055
|
-
(0,
|
|
66106
|
+
(0, import_react102.useEffect)(() => {
|
|
66056
66107
|
if (isExtension2) {
|
|
66057
66108
|
setPathnameLocal(pathname);
|
|
66058
66109
|
}
|
|
@@ -66071,9 +66122,9 @@ var init_Hey = __esm({
|
|
|
66071
66122
|
const RouteComponent = isStorePage ? Store2 : pathWithoutLocale && ROUTES[pathWithoutLocale] ? ROUTES[pathWithoutLocale] : lastPathSegment && ROUTES[lastPathSegment] ? ROUTES[lastPathSegment] : null;
|
|
66072
66123
|
const isClientRoute = isExtension2 || !isSSRRoute && (!!RouteComponent || threadId || pathname === "/" || pathname === "/api" || app || currentStore);
|
|
66073
66124
|
const isHydrated = useHasHydrated();
|
|
66074
|
-
const [isImageLoaded, setIsImageLoaded] = (0,
|
|
66075
|
-
const [minSplashTimeElapsed, setMinSplashTimeElapsed] = (0,
|
|
66076
|
-
(0,
|
|
66125
|
+
const [isImageLoaded, setIsImageLoaded] = (0, import_react102.useState)(false);
|
|
66126
|
+
const [minSplashTimeElapsed, setMinSplashTimeElapsed] = (0, import_react102.useState)(false);
|
|
66127
|
+
(0, import_react102.useEffect)(() => {
|
|
66077
66128
|
if (!isImageLoaded) return;
|
|
66078
66129
|
if (!app?.store?.apps?.length) return;
|
|
66079
66130
|
const timer = setTimeout(() => {
|
|
@@ -66081,7 +66132,7 @@ var init_Hey = __esm({
|
|
|
66081
66132
|
}, 1e3);
|
|
66082
66133
|
return () => clearTimeout(timer);
|
|
66083
66134
|
}, [isImageLoaded, app]);
|
|
66084
|
-
const getSplash = (0,
|
|
66135
|
+
const getSplash = (0, import_react102.useCallback)(
|
|
66085
66136
|
(isSplash2) => {
|
|
66086
66137
|
const splashStyle = styles4.splash;
|
|
66087
66138
|
const hiddenStyle = styles4.splashHidden;
|
|
@@ -66111,10 +66162,10 @@ var init_Hey = __esm({
|
|
|
66111
66162
|
[app, isSplash]
|
|
66112
66163
|
);
|
|
66113
66164
|
const splash = getSplash(isSplash);
|
|
66114
|
-
(0,
|
|
66165
|
+
(0, import_react102.useEffect)(() => {
|
|
66115
66166
|
isSplash && isImageLoaded && isHydrated && minSplashTimeElapsed && setIsSplash(!app?.store?.apps?.length);
|
|
66116
66167
|
}, [isImageLoaded, isHydrated, isSplash, minSplashTimeElapsed]);
|
|
66117
|
-
return /* @__PURE__ */ React.createElement(Div, null, /* @__PURE__ */ React.createElement(ErrorBoundary, null, !app ? /* @__PURE__ */ React.createElement(Div, { style: styles4.splash.style }, /* @__PURE__ */ React.createElement(ImageComponent, { logo: "blossom", showLoading: false, size: 64 })) : /* @__PURE__ */ React.createElement(React.Fragment, null, splash, /* @__PURE__ */ React.createElement(
|
|
66168
|
+
return /* @__PURE__ */ React.createElement(Div, null, /* @__PURE__ */ React.createElement(ErrorBoundary, null, !app ? /* @__PURE__ */ React.createElement(Div, { style: styles4.splash.style }, /* @__PURE__ */ React.createElement(ImageComponent, { logo: "blossom", showLoading: false, size: 64 })) : /* @__PURE__ */ React.createElement(React.Fragment, null, splash, /* @__PURE__ */ React.createElement(import_react102.Suspense, null, isClientRoute ? (
|
|
66118
66169
|
// Client-side routes: SWAP content
|
|
66119
66170
|
// Check thread detail FIRST before RouteComponent
|
|
66120
66171
|
threadId ? /* @__PURE__ */ React.createElement(Thread_default, { key: threadId }) : RouteComponent ? /* @__PURE__ */ React.createElement(RouteComponent, null) : /* @__PURE__ */ React.createElement(Home, null)
|
|
@@ -66363,7 +66414,7 @@ function AppProviders({
|
|
|
66363
66414
|
useExtensionIcon,
|
|
66364
66415
|
threads
|
|
66365
66416
|
}) {
|
|
66366
|
-
const [error, setError] = (0,
|
|
66417
|
+
const [error, setError] = (0, import_react103.useState)("");
|
|
66367
66418
|
const swrConfig = {
|
|
66368
66419
|
// Use persistent cache provider (IndexedDB on web, MMKV on native)
|
|
66369
66420
|
provider: swrCacheProvider_default,
|
|
@@ -66390,14 +66441,14 @@ function AppProviders({
|
|
|
66390
66441
|
setTimeout(() => revalidate({ retryCount }), 5e3);
|
|
66391
66442
|
}
|
|
66392
66443
|
};
|
|
66393
|
-
return /* @__PURE__ */
|
|
66444
|
+
return /* @__PURE__ */ import_react103.default.createElement(import_swr10.SWRConfig, { value: swrConfig }, /* @__PURE__ */ import_react103.default.createElement(
|
|
66394
66445
|
PlatformProvider,
|
|
66395
66446
|
{
|
|
66396
66447
|
viewPortWidth,
|
|
66397
66448
|
viewPortHeight,
|
|
66398
66449
|
session: session2
|
|
66399
66450
|
},
|
|
66400
|
-
/* @__PURE__ */
|
|
66451
|
+
/* @__PURE__ */ import_react103.default.createElement(ErrorProvider, null, /* @__PURE__ */ import_react103.default.createElement(ThemeProvider, { session: session2 }, /* @__PURE__ */ import_react103.default.createElement(
|
|
66401
66452
|
AuthProvider,
|
|
66402
66453
|
{
|
|
66403
66454
|
translations,
|
|
@@ -66413,11 +66464,11 @@ function AppProviders({
|
|
|
66413
66464
|
signOutContext,
|
|
66414
66465
|
session: session2
|
|
66415
66466
|
},
|
|
66416
|
-
/* @__PURE__ */
|
|
66467
|
+
/* @__PURE__ */ import_react103.default.createElement(DataProvider, null, /* @__PURE__ */ import_react103.default.createElement(AppProvider, null, /* @__PURE__ */ import_react103.default.createElement(ChatProvider, null, /* @__PURE__ */ import_react103.default.createElement(TimerContextProvider, null, /* @__PURE__ */ import_react103.default.createElement(NavigationProvider, null, /* @__PURE__ */ import_react103.default.createElement(AppContextProvider, null, /* @__PURE__ */ import_react103.default.createElement(StylesProvider, null, /* @__PURE__ */ import_react103.default.createElement(Hey, { useExtensionIcon }, children))))))))
|
|
66417
66468
|
)))
|
|
66418
66469
|
));
|
|
66419
66470
|
}
|
|
66420
|
-
var
|
|
66471
|
+
var import_react103, import_swr10;
|
|
66421
66472
|
var init_providers = __esm({
|
|
66422
66473
|
"context/providers/index.tsx"() {
|
|
66423
66474
|
"use strict";
|
|
@@ -66429,7 +66480,7 @@ var init_providers = __esm({
|
|
|
66429
66480
|
init_DataProvider();
|
|
66430
66481
|
init_AppProvider();
|
|
66431
66482
|
init_platform();
|
|
66432
|
-
|
|
66483
|
+
import_react103 = __toESM(require("react"));
|
|
66433
66484
|
init_platform();
|
|
66434
66485
|
init_ThemeContext();
|
|
66435
66486
|
init_StylesContext();
|
|
@@ -66452,7 +66503,7 @@ function useStoreMetadata(store) {
|
|
|
66452
66503
|
const { i18n: i18n2 } = (0, import_react_i18next9.useTranslation)();
|
|
66453
66504
|
const { baseApp, showFocus } = useAuth();
|
|
66454
66505
|
const currentDomain = baseApp?.store?.domain || (typeof window !== "undefined" ? `${window.location.protocol}//${window.location.host}` : "");
|
|
66455
|
-
(0,
|
|
66506
|
+
(0, import_react104.useEffect)(() => {
|
|
66456
66507
|
if (showFocus) return;
|
|
66457
66508
|
if (typeof document === "undefined" || !store) return;
|
|
66458
66509
|
const locale5 = i18n2.language || "en";
|
|
@@ -66522,7 +66573,7 @@ function useAppMetadata2() {
|
|
|
66522
66573
|
translations,
|
|
66523
66574
|
whiteLabel: storeApp
|
|
66524
66575
|
}) : void 0;
|
|
66525
|
-
(0,
|
|
66576
|
+
(0, import_react104.useEffect)(() => {
|
|
66526
66577
|
if (showFocus) return;
|
|
66527
66578
|
if (!metadata || !enabled) return;
|
|
66528
66579
|
if (metadata.title) {
|
|
@@ -66584,7 +66635,7 @@ function useThreadMetadata(thread2) {
|
|
|
66584
66635
|
currentDomain,
|
|
66585
66636
|
translations
|
|
66586
66637
|
}) : void 0;
|
|
66587
|
-
(0,
|
|
66638
|
+
(0, import_react104.useEffect)(() => {
|
|
66588
66639
|
if (!metadata || typeof document === "undefined") return;
|
|
66589
66640
|
if (metadata.title) {
|
|
66590
66641
|
document.title = metadata.title;
|
|
@@ -66650,11 +66701,11 @@ function updateOrCreateLink(rel, href, hreflang) {
|
|
|
66650
66701
|
}
|
|
66651
66702
|
linkTag.setAttribute("href", href);
|
|
66652
66703
|
}
|
|
66653
|
-
var
|
|
66704
|
+
var import_react104, import_react_i18next9;
|
|
66654
66705
|
var init_useMetadata = __esm({
|
|
66655
66706
|
"hooks/useMetadata.ts"() {
|
|
66656
66707
|
"use strict";
|
|
66657
|
-
|
|
66708
|
+
import_react104 = require("react");
|
|
66658
66709
|
import_react_i18next9 = require("react-i18next");
|
|
66659
66710
|
init_utils();
|
|
66660
66711
|
init_providers();
|
|
@@ -66664,12 +66715,12 @@ var init_useMetadata = __esm({
|
|
|
66664
66715
|
|
|
66665
66716
|
// hooks/useSyncedState.ts
|
|
66666
66717
|
function useSyncedState(computedValue, deps) {
|
|
66667
|
-
const [localValue, setLocalValue] = (0,
|
|
66668
|
-
const isFirstRender = (0,
|
|
66669
|
-
(0,
|
|
66718
|
+
const [localValue, setLocalValue] = (0, import_react105.useState)(computedValue);
|
|
66719
|
+
const isFirstRender = (0, import_react105.useRef)(true);
|
|
66720
|
+
(0, import_react105.useEffect)(() => {
|
|
66670
66721
|
setLocalValue(computedValue);
|
|
66671
66722
|
}, [...deps || []]);
|
|
66672
|
-
(0,
|
|
66723
|
+
(0, import_react105.useEffect)(() => {
|
|
66673
66724
|
setLocalValue(computedValue);
|
|
66674
66725
|
}, [...deps || []]);
|
|
66675
66726
|
return [localValue, setLocalValue];
|
|
@@ -66677,27 +66728,27 @@ function useSyncedState(computedValue, deps) {
|
|
|
66677
66728
|
function useComputedValue(computedValue) {
|
|
66678
66729
|
return computedValue;
|
|
66679
66730
|
}
|
|
66680
|
-
var
|
|
66731
|
+
var import_react105;
|
|
66681
66732
|
var init_useSyncedState = __esm({
|
|
66682
66733
|
"hooks/useSyncedState.ts"() {
|
|
66683
66734
|
"use strict";
|
|
66684
|
-
|
|
66735
|
+
import_react105 = require("react");
|
|
66685
66736
|
}
|
|
66686
66737
|
});
|
|
66687
66738
|
|
|
66688
66739
|
// hooks/index.ts
|
|
66689
66740
|
function useHasHydrated() {
|
|
66690
|
-
const [hydrated, setHydrated] = (0,
|
|
66691
|
-
(0,
|
|
66741
|
+
const [hydrated, setHydrated] = (0, import_react106.useState)(false);
|
|
66742
|
+
(0, import_react106.useEffect)(() => {
|
|
66692
66743
|
setHydrated(true);
|
|
66693
66744
|
}, []);
|
|
66694
66745
|
return hydrated;
|
|
66695
66746
|
}
|
|
66696
66747
|
function useCountdown(targetDate) {
|
|
66697
|
-
const [remaining, setRemaining] = (0,
|
|
66748
|
+
const [remaining, setRemaining] = (0, import_react106.useState)(
|
|
66698
66749
|
targetDate ? targetDate.getTime() - Date.now() : null
|
|
66699
66750
|
);
|
|
66700
|
-
(0,
|
|
66751
|
+
(0, import_react106.useEffect)(() => {
|
|
66701
66752
|
if (!targetDate) return;
|
|
66702
66753
|
const interval = setInterval(() => {
|
|
66703
66754
|
setRemaining(targetDate.getTime() - Date.now());
|
|
@@ -66707,11 +66758,11 @@ function useCountdown(targetDate) {
|
|
|
66707
66758
|
if (remaining !== null && remaining < 0) return 0;
|
|
66708
66759
|
return remaining;
|
|
66709
66760
|
}
|
|
66710
|
-
var
|
|
66761
|
+
var import_react106;
|
|
66711
66762
|
var init_hooks = __esm({
|
|
66712
66763
|
"hooks/index.ts"() {
|
|
66713
66764
|
"use strict";
|
|
66714
|
-
|
|
66765
|
+
import_react106 = require("react");
|
|
66715
66766
|
init_useLocalStorage();
|
|
66716
66767
|
init_useDeviceInfo();
|
|
66717
66768
|
init_usePWAInstall();
|
|
@@ -66866,7 +66917,7 @@ init_agentSchema();
|
|
|
66866
66917
|
init_appSchema();
|
|
66867
66918
|
|
|
66868
66919
|
// Sidebar.tsx
|
|
66869
|
-
var
|
|
66920
|
+
var import_react107 = __toESM(require("react"));
|
|
66870
66921
|
|
|
66871
66922
|
// Providers.tsx
|
|
66872
66923
|
init_i18n();
|
|
@@ -66884,11 +66935,11 @@ init_Hey();
|
|
|
66884
66935
|
function Sidebar({
|
|
66885
66936
|
useExtensionIcon
|
|
66886
66937
|
}) {
|
|
66887
|
-
return /* @__PURE__ */
|
|
66938
|
+
return /* @__PURE__ */ import_react107.default.createElement(Providers, null, /* @__PURE__ */ import_react107.default.createElement(Hey, { useExtensionIcon }));
|
|
66888
66939
|
}
|
|
66889
66940
|
|
|
66890
66941
|
// Chrry.tsx
|
|
66891
|
-
var
|
|
66942
|
+
var import_react108 = __toESM(require("react"));
|
|
66892
66943
|
init_providers();
|
|
66893
66944
|
if (typeof window !== "undefined") {
|
|
66894
66945
|
try {
|
|
@@ -66915,7 +66966,7 @@ function Chrry({
|
|
|
66915
66966
|
app,
|
|
66916
66967
|
pathname
|
|
66917
66968
|
}) {
|
|
66918
|
-
return /* @__PURE__ */
|
|
66969
|
+
return /* @__PURE__ */ import_react108.default.createElement(
|
|
66919
66970
|
AppProviders,
|
|
66920
66971
|
{
|
|
66921
66972
|
useExtensionIcon,
|
|
@@ -66941,17 +66992,17 @@ function Chrry({
|
|
|
66941
66992
|
init_Store();
|
|
66942
66993
|
|
|
66943
66994
|
// context/providers/HistoryRouterProvider.tsx
|
|
66944
|
-
var
|
|
66995
|
+
var import_react109 = require("react");
|
|
66945
66996
|
init_useWindowHistory();
|
|
66946
|
-
var HistoryRouterContext = (0,
|
|
66997
|
+
var HistoryRouterContext = (0, import_react109.createContext)(
|
|
66947
66998
|
null
|
|
66948
66999
|
);
|
|
66949
67000
|
function HistoryRouterProvider({
|
|
66950
67001
|
children
|
|
66951
67002
|
}) {
|
|
66952
|
-
const [state, setState] = (0,
|
|
66953
|
-
const [updateTrigger, setUpdateTrigger] = (0,
|
|
66954
|
-
(0,
|
|
67003
|
+
const [state, setState] = (0, import_react109.useState)(() => clientRouter.getState());
|
|
67004
|
+
const [updateTrigger, setUpdateTrigger] = (0, import_react109.useState)(0);
|
|
67005
|
+
(0, import_react109.useEffect)(() => {
|
|
66955
67006
|
const unsubscribe = clientRouter.subscribe(() => {
|
|
66956
67007
|
const newState = clientRouter.getState();
|
|
66957
67008
|
setState(newState);
|