@versini/sassysaint 8.83.0 → 8.83.1

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.
Files changed (25) hide show
  1. package/dist/chunks/{AboutChangelog.Dnae3ZET.js → AboutChangelog.mWn6DHnN.js} +3 -3
  2. package/dist/chunks/{AboutEntry.DaKcxQlb.js → AboutEntry.CF0h629q.js} +5 -5
  3. package/dist/chunks/{App.CfJzwyx5.js → App.ByR7hh4G.js} +17 -23
  4. package/dist/chunks/{Chart.CmXf5ahL.js → Chart.BOrnLtUH.js} +2 -2
  5. package/dist/chunks/{ChatBubbleAssistant.rQ0E9CSF.js → ChatBubbleAssistant.BbKm4kCr.js} +4 -4
  6. package/dist/chunks/{ChatBubbleUser.iSkDnxmM.js → ChatBubbleUser.CSd4FUFb.js} +3 -3
  7. package/dist/chunks/{ChatHistoryTable.3HSGoZd4.js → ChatHistoryTable.OhJzHZwR.js} +3 -3
  8. package/dist/chunks/{HistoryEntry.4IXWZ8qq.js → HistoryEntry.DuHoMXgy.js} +3 -3
  9. package/dist/chunks/{ProfileEntry.Chfyj-dQ.js → ProfileEntry.CTvtlf06.js} +2 -2
  10. package/dist/chunks/{SettingsEntry.SAurNjp0.js → SettingsEntry.W5dfrzDj.js} +3 -3
  11. package/dist/chunks/{UsageEntry.DPp3sbic.js → UsageEntry.BlC_GEWV.js} +3 -3
  12. package/dist/chunks/{UserMemoriesPanel.DiSRjoNR.js → UserMemoriesPanel.pk5CBYkd.js} +4 -4
  13. package/dist/chunks/{index.HO-K8Z3S.js → index.C4Kp9caJ.js} +1 -1
  14. package/dist/chunks/{index.CoVeibJJ.js → index.Dm0B1x9v.js} +1 -1
  15. package/dist/chunks/{index.B6gxiXab.js → index.DosDfPyo.js} +1 -1
  16. package/dist/chunks/{index.D4xbtPpm.js → index.Dq1H4UoP.js} +3 -3
  17. package/dist/chunks/{index.BQXkk0E7.js → index.DvwicTLq.js} +1 -1
  18. package/dist/chunks/{index.iKl0E1mP.js → index.LWfh_Nx0.js} +1 -1
  19. package/dist/chunks/{index.9ZW-D7id.js → index.X83cFhfe.js} +1 -1
  20. package/dist/chunks/{index.DNDgXAMw.js → index.eSkzK0sZ.js} +2 -2
  21. package/dist/chunks/{index.ZpurL-_2.js → index.xYO9MQ7q.js} +1 -1
  22. package/dist/chunks/{useMarkdown.D1WsA7gy.js → useMarkdown.Bxe6gfSy.js} +6 -6
  23. package/dist/components/SassySaint/SassySaint.js +1 -1
  24. package/dist/index.js +4 -4
  25. package/package.json +3 -3
@@ -1,8 +1,8 @@
1
1
  import { jsxs as s, jsx as r } from "react/jsx-runtime";
2
- import { useInViewport as c } from "./index.BQXkk0E7.js";
2
+ import { useInViewport as c } from "./index.DvwicTLq.js";
3
3
  import { useRef as n, useCallback as f, useLayoutEffect as u } from "react";
4
- import { ButtonScroll as p } from "./App.CfJzwyx5.js";
5
- import { useMarkdown as d } from "./useMarkdown.D1WsA7gy.js";
4
+ import { ButtonScroll as p } from "./App.ByR7hh4G.js";
5
+ import { useMarkdown as d } from "./useMarkdown.Bxe6gfSy.js";
6
6
  const x = ({ content: o }) => {
7
7
  const [l, t] = d(), { ref: i, inViewport: a } = c(), e = n(null), m = f(() => {
8
8
  e.current && e.current.scrollIntoView({
@@ -1,12 +1,12 @@
1
1
  import { jsxs as b, Fragment as l, jsx as e } from "react/jsx-runtime";
2
- import { Panel as g } from "./App.CfJzwyx5.js";
3
- import { useUniqueId as d, useServerCapabilities as A, useChangelogs as I, Card as t, renderDataAsList as c, CARDS as r, pluralize as B, isProbablyMobile as E, ABOUT_TITLE as S } from "./index.BQXkk0E7.js";
2
+ import { Panel as g } from "./App.ByR7hh4G.js";
3
+ import { useUniqueId as d, useServerCapabilities as A, useChangelogs as I, Card as t, renderDataAsList as c, CARDS as r, pluralize as B, isProbablyMobile as E, ABOUT_TITLE as S } from "./index.DvwicTLq.js";
4
4
  import O from "clsx";
5
5
  import { Suspense as C, lazy as U } from "react";
6
6
  const L = U(
7
7
  () => import(
8
8
  /* webpackChunkName: "LazyAboutChangelog" */
9
- "./AboutChangelog.Dnae3ZET.js"
9
+ "./AboutChangelog.mWn6DHnN.js"
10
10
  )
11
11
  ), N = () => {
12
12
  const s = d(), i = d(), { data: a, isSuccess: m } = A(), { data: T, isSuccess: h } = I(), u = a?.version || "", o = a?.models || [], p = a?.buildTime || "";
@@ -18,8 +18,8 @@ const L = U(
18
18
  className: "prose-dark dark:prose-lighter mb-4",
19
19
  noBorder: !0,
20
20
  children: c(s, {
21
- [r.ABOUT.VERSION]: "8.83.0",
22
- [r.ABOUT.BUILD_TIMESTAMP]: "11/13/2025 01:57 PM EST"
21
+ [r.ABOUT.VERSION]: "8.83.1",
22
+ [r.ABOUT.BUILD_TIMESTAMP]: "11/13/2025 02:21 PM EST"
23
23
  })
24
24
  }
25
25
  ),
@@ -1,5 +1,5 @@
1
1
  import { jsx as d, jsxs as A, Fragment as Ae } from "react/jsx-runtime";
2
- import { ACTION_SORT as oa, e as mt, ACTION_SEARCH as sa, ACTION_RESET_PROMPT as uo, ACTION_TOGGLE_PROMPT as po, useLocalStorage as ke, LOCAL_STORAGE_PREFIX as Me, LOCAL_STORAGE_CHAT_ID as fo, n as me, isDev as aa, isPWAMode as ho, isTauri as yt, useChat as ia, useClickOutside as ca, useInterval as la, useTheme as xe, ButtonIcon as Ie, IconAddLight as ua, DEFAULT_ICON_ACTION_SIZE as Ce, ChatContext as Ee, useUserPreferences as je, useHotkeys as Ur, isProbablyiPhone as $e, IconCloseLight as da, IconEditLight as pa, serverUrl as mo, useEntitlements as jr, IconClose as go, useHaptic as fa, L as Er, j as st, Button as on, LOCAL_STORAGE_PRIVATE_DISCLOSURE as ha, V as Ht, IconLockedLight as ma, IconUnlockedLight as ga, IconSelected as va, IconUnSelected as ya, IconNext as _a, PromptsContext as Fr, IconBookSparklesLight as ba, IconRewrite as wa, IconProofread as Ia, IconMagic as Ea, LOCAL_STORAGE_REASONING_DISCLOSURE as Ta, IconLightBulbLight as Sa, useSaveChat as ka, IconDownloadLight as Ca, TOAST_CHAT_SAVED as xa, IconSendLight as Aa, AppContext as St, HistoryContext as vo, useChatsHistory as Na, useUniqueId as Oa, PROMPT_EDITABLE_AREA_CLASSNAME as za, PROMPT_CLASSNAME as Pa, B as yo, ERROR_MESSAGE as Ra, _ as _t, CLIPBOARD_PROMPT as sn, INPUT_PLACEHOLDER_TEXT_MOBILE as an, INPUT_PLACEHOLDER_TEXT_ENTER as cn, INPUT_PLACEHOLDER_TEXT_CMD_ENTER as ln, isProbablyMobile as Tr, getHotkeyHandler as Ma, m as $a, FOOTER_DISCLAIMERS as un, useViewportSize as Za, useVisualViewportSize as Da, useResizeObserver as _o, isProbablyiPad as La, INPUT_BOTTOM_OFFSET_EXTRA as dn, INPUT_BOTTOM_OFFSET_IPHONE as Ua, INPUT_BOTTOM_OFFSET_IPAD as ja, INPUT_BOTTOM_OFFSET as bo, APP_SET_FOOTER_HEIGHT as Fa, FOOTER_TOP as Sr, FOOTER_BOTTOM as gt, APP_SET_FOOTER_POSITION as lr, getLayoutPaddingClass as kr, canEvaluateModels as pn, w as Ba, IconOpenAI as Va, q as Ha, IconAnthropic as Ga, E as Ja, IconGoogleGemini as Wa, K as Ya, x as qa, d as ur, setNewProvider as fn, TOAST_PROVIDER_CHANGED as hn, useQueryClient as Xa, LOG_OUT as mn, IconProfile as Ka, IconSliders as Qa, IconHistory as ei, IconEditUser as ti, IconChart as ri, IconInfo as ni, IconBack as oi, IconSettings as si, ee as wo, Q as gn, useInViewport as ai, useServerCapabilities as ii, getMessageContaintWrapperClass as ci, UI_FOOTER_BUFFER as Io, UI_BUTTON_SCROLL_BUFFER as li, Logo as ui, UI_DEFAULT_MAIN_HEIGHT as vn, k as di, appReducer as pi, applyOledMode as fi, APP_SET_OLED_MODE as hi, APP_SET_FULL_SCREEN as mi, APP_SET_THEME_MODE as gi, UI_DEFAULT_MAIN_HEIGHT_IPHONE as vi, APP_CLASSNAME as yi, f as yn, h as _i, LOCAL_STORAGE_SORT as bi, LOCAL_STORAGE_SEARCH as wi, LOCAL_STORAGE_OLED_MODE as Ii, LOCAL_STORAGE_FULL_SCREEN as Ei, LOCAL_STORAGE_SORT_TIMESTAMP as Ti, LOCAL_STORAGE_SORT_TOKEN_USAGE as Si, TOAST_CACHE_ENABLED as ki, TOAST_CACHE_DISABLED as Ci } from "./index.BQXkk0E7.js";
2
+ import { ACTION_SORT as oa, e as mt, ACTION_SEARCH as sa, ACTION_RESET_PROMPT as uo, ACTION_TOGGLE_PROMPT as po, useLocalStorage as ke, LOCAL_STORAGE_PREFIX as Me, LOCAL_STORAGE_CHAT_ID as fo, n as me, isDev as aa, isPWAMode as ho, isTauri as yt, useChat as ia, useClickOutside as ca, useInterval as la, useTheme as xe, ButtonIcon as Ie, IconAddLight as ua, DEFAULT_ICON_ACTION_SIZE as Ce, ChatContext as Ee, useUserPreferences as je, useHotkeys as Ur, isProbablyiPhone as $e, IconCloseLight as da, IconEditLight as pa, serverUrl as mo, useEntitlements as jr, IconClose as go, useHaptic as fa, L as Er, j as st, Button as on, LOCAL_STORAGE_PRIVATE_DISCLOSURE as ha, V as Ht, IconLockedLight as ma, IconUnlockedLight as ga, IconSelected as va, IconUnSelected as ya, IconNext as _a, PromptsContext as Fr, IconBookSparklesLight as ba, IconRewrite as wa, IconProofread as Ia, IconMagic as Ea, LOCAL_STORAGE_REASONING_DISCLOSURE as Ta, IconLightBulbLight as Sa, useSaveChat as ka, IconDownloadLight as Ca, TOAST_CHAT_SAVED as xa, IconSendLight as Aa, AppContext as St, HistoryContext as vo, useChatsHistory as Na, useUniqueId as Oa, PROMPT_EDITABLE_AREA_CLASSNAME as za, PROMPT_CLASSNAME as Pa, B as yo, ERROR_MESSAGE as Ra, _ as _t, CLIPBOARD_PROMPT as sn, INPUT_PLACEHOLDER_TEXT_MOBILE as an, INPUT_PLACEHOLDER_TEXT_ENTER as cn, INPUT_PLACEHOLDER_TEXT_CMD_ENTER as ln, isProbablyMobile as Tr, getHotkeyHandler as Ma, m as $a, FOOTER_DISCLAIMERS as un, useViewportSize as Za, useVisualViewportSize as Da, useResizeObserver as _o, isProbablyiPad as La, INPUT_BOTTOM_OFFSET_EXTRA as dn, INPUT_BOTTOM_OFFSET_IPHONE as Ua, INPUT_BOTTOM_OFFSET_IPAD as ja, INPUT_BOTTOM_OFFSET as bo, APP_SET_FOOTER_HEIGHT as Fa, FOOTER_TOP as Sr, FOOTER_BOTTOM as gt, APP_SET_FOOTER_POSITION as lr, getLayoutPaddingClass as kr, canEvaluateModels as pn, w as Ba, IconOpenAI as Va, q as Ha, IconAnthropic as Ga, E as Ja, IconGoogleGemini as Wa, K as Ya, x as qa, d as ur, setNewProvider as fn, TOAST_PROVIDER_CHANGED as hn, useQueryClient as Xa, LOG_OUT as mn, IconProfile as Ka, IconSliders as Qa, IconHistory as ei, IconEditUser as ti, IconChart as ri, IconInfo as ni, IconBack as oi, IconSettings as si, ee as wo, Q as gn, useInViewport as ai, useServerCapabilities as ii, getMessageContaintWrapperClass as ci, UI_FOOTER_BUFFER as Io, UI_BUTTON_SCROLL_BUFFER as li, Logo as ui, UI_DEFAULT_MAIN_HEIGHT as vn, k as di, appReducer as pi, applyOledMode as fi, APP_SET_OLED_MODE as hi, APP_SET_FULL_SCREEN as mi, APP_SET_THEME_MODE as gi, UI_DEFAULT_MAIN_HEIGHT_IPHONE as vi, APP_CLASSNAME as yi, f as yn, h as _i, LOCAL_STORAGE_SORT as bi, LOCAL_STORAGE_SEARCH as wi, LOCAL_STORAGE_OLED_MODE as Ii, LOCAL_STORAGE_FULL_SCREEN as Ei, LOCAL_STORAGE_SORT_TIMESTAMP as Ti, LOCAL_STORAGE_SORT_TOKEN_USAGE as Si, TOAST_CACHE_ENABLED as ki, TOAST_CACHE_DISABLED as Ci } from "./index.DvwicTLq.js";
3
3
  import Eo, { useRef as W, useCallback as q, useSyncExternalStore as dr, useEffect as $, useState as M, createContext as Br, useContext as X, forwardRef as Xe, cloneElement as xi, useId as To, useLayoutEffect as Vr, useMemo as we, Suspense as Gt, lazy as Oe, useReducer as zt } from "react";
4
4
  import O, { clsx as Ai } from "clsx";
5
5
  import { computePosition as Ni, offset as So, flip as ko, shift as Co, arrow as Oi, useMergeRefs as Hr, FloatingPortal as Cr, FloatingOverlay as zi, FloatingFocusManager as xr, useFloating as xo, useClick as Ao, useDismiss as No, useRole as Oo, useInteractions as zo, useFloatingParentNodeId as Po, FloatingTree as Pi, useListItem as Ro, useFloatingTree as Mo, useFloatingNodeId as Ri, autoUpdate as Mi, useHover as $i, safePolygon as Zi, useListNavigation as Di, useTypeahead as Li, FloatingNode as _n, FloatingList as bn } from "@floating-ui/react";
@@ -5700,7 +5700,7 @@ const Ds = async () => (yr || (yr = import(
5700
5700
  "./index.790ujKXR.js"
5701
5701
  )), yr), Ls = async () => (_r || (_r = import(
5702
5702
  /* webpackChunkName: "toast-utilities" */
5703
- "./index.BQXkk0E7.js"
5703
+ "./index.DvwicTLq.js"
5704
5704
  ).then((e) => e.utilities)), _r), Pf = async () => {
5705
5705
  try {
5706
5706
  await Promise.all([Ds(), Ls()]);
@@ -6943,13 +6943,7 @@ const mh = "av-toggle", gh = ({ narrow: e }) => O(
6943
6943
  },
6944
6944
  className: "text-sm",
6945
6945
  disabled: !(m && I) || n && o > 0,
6946
- children: n ? /* @__PURE__ */ d(
6947
- ma,
6948
- {
6949
- size: Ce,
6950
- className: l(c.PrivateChat)
6951
- }
6952
- ) : /* @__PURE__ */ d(
6946
+ children: n ? /* @__PURE__ */ d(ma, { size: Ce }) : /* @__PURE__ */ d(
6953
6947
  ga,
6954
6948
  {
6955
6949
  size: Ce,
@@ -8286,38 +8280,38 @@ const kh = ({ className: e, ...t }) => {
8286
8280
  }, Kh = Oe(
8287
8281
  () => import(
8288
8282
  /* webpackChunkName: "modal-chunk" */
8289
- "./ProfileEntry.Chfyj-dQ.js"
8283
+ "./ProfileEntry.CTvtlf06.js"
8290
8284
  ).then((e) => ({
8291
8285
  default: e.Profile
8292
8286
  }))
8293
8287
  ), Qh = Oe(
8294
8288
  () => import(
8295
8289
  /* webpackChunkName: "modal-chunk" */
8296
- "./SettingsEntry.SAurNjp0.js"
8290
+ "./SettingsEntry.W5dfrzDj.js"
8297
8291
  ).then((e) => ({
8298
8292
  default: e.SettingsPanel
8299
8293
  }))
8300
8294
  ), em = Oe(
8301
8295
  () => import(
8302
8296
  /* webpackChunkName: "modal-chunk" */
8303
- "./HistoryEntry.4IXWZ8qq.js"
8297
+ "./HistoryEntry.DuHoMXgy.js"
8304
8298
  ).then((e) => ({
8305
8299
  default: e.HistoryPanel
8306
8300
  }))
8307
8301
  ), tm = Oe(
8308
8302
  () => import(
8309
8303
  /* webpackChunkName: "modal-chunk" */
8310
- "./AboutEntry.DaKcxQlb.js"
8304
+ "./AboutEntry.CF0h629q.js"
8311
8305
  ).then((e) => ({ default: e.About }))
8312
8306
  ), rm = Oe(
8313
8307
  () => import(
8314
8308
  /* webpackChunkName: "modal-chunk" */
8315
- "./UsageEntry.DPp3sbic.js"
8309
+ "./UsageEntry.BlC_GEWV.js"
8316
8310
  ).then((e) => ({ default: e.Usage }))
8317
8311
  ), nm = Oe(
8318
8312
  () => import(
8319
8313
  /* webpackChunkName: "modal-chunk" */
8320
- "./UserMemoriesPanel.DiSRjoNR.js"
8314
+ "./UserMemoriesPanel.pk5CBYkd.js"
8321
8315
  ).then(
8322
8316
  (e) => ({ default: e.default })
8323
8317
  )
@@ -8367,23 +8361,23 @@ const kh = ({ className: e, ...t }) => {
8367
8361
  h || Promise.all([
8368
8362
  import(
8369
8363
  /* webpackChunkName: "modal-chunk" */
8370
- "./ProfileEntry.Chfyj-dQ.js"
8364
+ "./ProfileEntry.CTvtlf06.js"
8371
8365
  ),
8372
8366
  import(
8373
8367
  /* webpackChunkName: "modal-chunk" */
8374
- "./SettingsEntry.SAurNjp0.js"
8368
+ "./SettingsEntry.W5dfrzDj.js"
8375
8369
  ),
8376
8370
  import(
8377
8371
  /* webpackChunkName: "modal-chunk" */
8378
- "./HistoryEntry.4IXWZ8qq.js"
8372
+ "./HistoryEntry.DuHoMXgy.js"
8379
8373
  ),
8380
8374
  import(
8381
8375
  /* webpackChunkName: "modal-chunk" */
8382
- "./AboutEntry.DaKcxQlb.js"
8376
+ "./AboutEntry.CF0h629q.js"
8383
8377
  ),
8384
8378
  import(
8385
8379
  /* webpackChunkName: "modal-chunk" */
8386
- "./UsageEntry.DPp3sbic.js"
8380
+ "./UsageEntry.BlC_GEWV.js"
8387
8381
  )
8388
8382
  ]).finally(() => f(!0));
8389
8383
  }, [h]), m = q((U) => {
@@ -8653,18 +8647,18 @@ const co = "av-spinner", qs = ({ spinnerRef: e, mode: t = "system", type: r = "c
8653
8647
  ]
8654
8648
  });
8655
8649
  }, cm = Oe(
8656
- () => import("./index.HO-K8Z3S.js").then((e) => ({ default: e.Bubble }))
8650
+ () => import("./index.C4Kp9caJ.js").then((e) => ({ default: e.Bubble }))
8657
8651
  ), tn = (e) => /* @__PURE__ */ d(Gt, { fallback: /* @__PURE__ */ d("span", { className: "inline-block" }), children: /* @__PURE__ */ d(cm, { ...e }) });
8658
8652
  tn.displayName = "AsyncBubble";
8659
8653
  const lo = 1, lm = 150, um = Oe(
8660
8654
  () => import(
8661
8655
  /* webpackChunkName: "LazyMessageAssistant" */
8662
- "./ChatBubbleAssistant.rQ0E9CSF.js"
8656
+ "./ChatBubbleAssistant.BbKm4kCr.js"
8663
8657
  )
8664
8658
  ), dm = Oe(
8665
8659
  () => import(
8666
8660
  /* webpackChunkName: "LazyMessageUser" */
8667
- "./ChatBubbleUser.iSkDnxmM.js"
8661
+ "./ChatBubbleUser.CSd4FUFb.js"
8668
8662
  )
8669
8663
  ), pm = Eo.memo(
8670
8664
  ({
@@ -1,7 +1,7 @@
1
1
  import { jsx as Ap } from "react/jsx-runtime";
2
- import { getDefaultExportFromCjs as ln } from "./App.CfJzwyx5.js";
2
+ import { getDefaultExportFromCjs as ln } from "./App.ByR7hh4G.js";
3
3
  import Cp, { useState as Pp, useEffect as Op } from "react";
4
- import { TRIMESTERS as rn, TRIMESTERS_SHORT as Lp, isProbablyMobile as Ep } from "./index.BQXkk0E7.js";
4
+ import { TRIMESTERS as rn, TRIMESTERS_SHORT as Lp, isProbablyMobile as Ep } from "./index.DvwicTLq.js";
5
5
  var ls = { exports: {} }, Ip = ls.exports, on;
6
6
  function Dp() {
7
7
  return on || (on = 1, (function(we, he) {
@@ -1,10 +1,10 @@
1
1
  import { jsx as x } from "react/jsx-runtime";
2
- import { ChatContext as P, AppContext as R, n as y, useUserPreferences as L, convertCamelCaseToReadable as _, numberFormatter as v, pluralize as B, Q as G } from "./index.BQXkk0E7.js";
3
- import { BUBBLE_FOOTER_EMPTY as D } from "./index.HO-K8Z3S.js";
2
+ import { ChatContext as P, AppContext as R, n as y, useUserPreferences as L, convertCamelCaseToReadable as _, numberFormatter as v, pluralize as B, Q as G } from "./index.DvwicTLq.js";
3
+ import { BUBBLE_FOOTER_EMPTY as D } from "./index.C4Kp9caJ.js";
4
4
  import U from "clsx";
5
5
  import j, { useState as M, useRef as E, useEffect as F, useContext as S } from "react";
6
- import { AsyncBubble as k } from "./App.CfJzwyx5.js";
7
- import { useMarkdown as q } from "./useMarkdown.D1WsA7gy.js";
6
+ import { AsyncBubble as k } from "./App.ByR7hh4G.js";
7
+ import { useMarkdown as q } from "./useMarkdown.Bxe6gfSy.js";
8
8
  const I = 2, W = I * 1e3, b = "", V = (e) => e * (2 - e);
9
9
  function Y(e, n = !0) {
10
10
  const [a, d] = M(0), [i, p] = M(0), [t, C] = M(e), r = E(0), s = E(0);
@@ -1,8 +1,8 @@
1
1
  import { jsx as a, Fragment as h, jsxs as S } from "react/jsx-runtime";
2
- import { Button as C } from "./index.BQXkk0E7.js";
2
+ import { Button as C } from "./index.DvwicTLq.js";
3
3
  import { useState as _, useMemo as m, isValidElement as T, useEffect as b } from "react";
4
- import { AsyncBubble as w } from "./App.CfJzwyx5.js";
5
- import { useMarkdown as x } from "./useMarkdown.D1WsA7gy.js";
4
+ import { AsyncBubble as w } from "./App.ByR7hh4G.js";
5
+ import { useMarkdown as x } from "./useMarkdown.Bxe6gfSy.js";
6
6
  /*!
7
7
  @versini/ui-truncate v5.2.0
8
8
  © 2025 gizmette.com
@@ -1,7 +1,7 @@
1
1
  import { jsxs as c, jsx as e } from "react/jsx-runtime";
2
- import { f as x, h as u, INFINITE_SCROLL_THRESHOLD as v, CARDS as I, pluralize as f, ButtonIcon as i, IconRestore as U, IconStarInCircle as y, IconStarInCircleLight as D, IconDelete as z, numberFormatter as L, isProbablyMobile as _ } from "./index.BQXkk0E7.js";
3
- import { W as P, j as $, G as m, H as B, M as a, F as M } from "./index.ZpurL-_2.js";
4
- import { Tooltip as d } from "./App.CfJzwyx5.js";
2
+ import { f as x, h as u, INFINITE_SCROLL_THRESHOLD as v, CARDS as I, pluralize as f, ButtonIcon as i, IconRestore as U, IconStarInCircle as y, IconStarInCircleLight as D, IconDelete as z, numberFormatter as L, isProbablyMobile as _ } from "./index.DvwicTLq.js";
3
+ import { W as P, j as $, G as m, H as B, M as a, F as M } from "./index.xYO9MQ7q.js";
4
+ import { Tooltip as d } from "./App.ByR7hh4G.js";
5
5
  import h from "clsx";
6
6
  import { Fragment as W } from "react";
7
7
  const s = {
@@ -1,11 +1,11 @@
1
1
  import { jsxs as c, Fragment as $, jsx as t } from "react/jsx-runtime";
2
- import { n as P, INFINITE_SCROLL_LIMIT as G, INFINITE_SCROLL_THRESHOLD as ee, HistoryContext as V, ChatContext as te, useLocalStorage as f, LOCAL_STORAGE_PREFIX as y, LOCAL_STORAGE_SORT_TIMESTAMP as ae, e as h, LOCAL_STORAGE_SORT_TOKEN_USAGE as re, LOCAL_STORAGE_SORT as se, f as v, useDeleteChat as oe, useToggleFavoriteChat as ne, APP_CLASSNAME as ie, TOAST_CHAT_DELETED as ce, graphQLRequest as le, SERVICE_TYPES as de, ACTION_SORT as he, h as me, useChatsHistory as ue, useUserChatStats as Ce, LOCAL_STORAGE_SEARCH as Se, LOCAL_STORAGE_FAVORITES_ONLY as fe, HISTORY_TITLE as ye, Card as pe, TextInput as Te, debounce as ge, IconSearch as Ae, Button as Ee, ACTION_SEARCH as De } from "./index.BQXkk0E7.js";
3
- import { useAiChat as _e, ConfirmationPanel as Oe, LazyToastContainerWrapper as Le, showErrorToast as ve, CHAT_SET_STATUS as ke, Panel as Re, Toggle as Ie } from "./App.CfJzwyx5.js";
2
+ import { n as P, INFINITE_SCROLL_LIMIT as G, INFINITE_SCROLL_THRESHOLD as ee, HistoryContext as V, ChatContext as te, useLocalStorage as f, LOCAL_STORAGE_PREFIX as y, LOCAL_STORAGE_SORT_TIMESTAMP as ae, e as h, LOCAL_STORAGE_SORT_TOKEN_USAGE as re, LOCAL_STORAGE_SORT as se, f as v, useDeleteChat as oe, useToggleFavoriteChat as ne, APP_CLASSNAME as ie, TOAST_CHAT_DELETED as ce, graphQLRequest as le, SERVICE_TYPES as de, ACTION_SORT as he, h as me, useChatsHistory as ue, useUserChatStats as Ce, LOCAL_STORAGE_SEARCH as Se, LOCAL_STORAGE_FAVORITES_ONLY as fe, HISTORY_TITLE as ye, Card as pe, TextInput as Te, debounce as ge, IconSearch as Ae, Button as Ee, ACTION_SEARCH as De } from "./index.DvwicTLq.js";
3
+ import { useAiChat as _e, ConfirmationPanel as Oe, LazyToastContainerWrapper as Le, showErrorToast as ve, CHAT_SET_STATUS as ke, Panel as Re, Toggle as Ie } from "./App.ByR7hh4G.js";
4
4
  import { useRef as N, useState as H, useContext as w, useCallback as M, Suspense as be, lazy as xe, useEffect as Ne } from "react";
5
5
  const He = xe(
6
6
  () => import(
7
7
  /* webpackChunkName: "history-table" */
8
- "./ChatHistoryTable.3HSGoZd4.js"
8
+ "./ChatHistoryTable.OhJzHZwR.js"
9
9
  ).then((m) => ({ default: m.ChatHistoryTable }))
10
10
  ), we = ({
11
11
  filteredHistory: m,
@@ -1,6 +1,6 @@
1
1
  import { jsxs as t, Fragment as D, jsx as e } from "react/jsx-runtime";
2
- import { preloadToast as K, showSuccessToast as W, showErrorToast as Y, ConfirmationPanel as H, LazyToastContainerWrapper as $, Panel as V } from "./App.CfJzwyx5.js";
3
- import { n as q, useUniqueId as J, useUserPreferences as Q, useServerCapabilities as X, d as Z, setUserPlan as ee, Card as d, renderDataAsList as ae, CARDS as s, L as P, j as c, Button as se, it as ne, isTauri as re, ButtonIcon as te, IconPasskey as L, PROFILE_TITLE as le } from "./index.BQXkk0E7.js";
2
+ import { preloadToast as K, showSuccessToast as W, showErrorToast as Y, ConfirmationPanel as H, LazyToastContainerWrapper as $, Panel as V } from "./App.ByR7hh4G.js";
3
+ import { n as q, useUniqueId as J, useUserPreferences as Q, useServerCapabilities as X, d as Z, setUserPlan as ee, Card as d, renderDataAsList as ae, CARDS as s, L as P, j as c, Button as se, it as ne, isTauri as re, ButtonIcon as te, IconPasskey as L, PROFILE_TITLE as le } from "./index.DvwicTLq.js";
4
4
  import ie from "clsx";
5
5
  import { useState as m, useMemo as ce, useCallback as f } from "react";
6
6
  const oe = () => {
@@ -1,7 +1,7 @@
1
1
  import { jsxs as n, jsx as t } from "react/jsx-runtime";
2
- import { n as je, useEntitlements as Ve, AppContext as Fe, useUserPreferences as We, V as ie, useLocalStorage as de, LOCAL_STORAGE_OLED_MODE as $e, LOCAL_STORAGE_FULL_SCREEN as ze, k as ue, canEvaluateModels as He, Y as Ye, getCacheInfo as qe, isServiceWorkerEnabled as Ke, SETTINGS_TITLE as Qe, Card as E, CARDS as r, b as Je, Button as v, PROMPTS_DESCRIPTION as Xe, e_ as me, L as Ze, j as he, applyOledMode as Ee, APP_SET_OLED_MODE as fe, APP_SET_FULL_SCREEN as Se, getCurrentGeoLocation as et, graphQLRequest as pe, handleServiceWorkerToggle as tt, SERVICE_TYPES as ge } from "./index.BQXkk0E7.js";
3
- import { useCapability as be, Panel as ot, Toggle as l } from "./App.CfJzwyx5.js";
4
- import { TextArea as Te } from "./index.9ZW-D7id.js";
2
+ import { n as je, useEntitlements as Ve, AppContext as Fe, useUserPreferences as We, V as ie, useLocalStorage as de, LOCAL_STORAGE_OLED_MODE as $e, LOCAL_STORAGE_FULL_SCREEN as ze, k as ue, canEvaluateModels as He, Y as Ye, getCacheInfo as qe, isServiceWorkerEnabled as Ke, SETTINGS_TITLE as Qe, Card as E, CARDS as r, b as Je, Button as v, PROMPTS_DESCRIPTION as Xe, e_ as me, L as Ze, j as he, applyOledMode as Ee, APP_SET_OLED_MODE as fe, APP_SET_FULL_SCREEN as Se, getCurrentGeoLocation as et, graphQLRequest as pe, handleServiceWorkerToggle as tt, SERVICE_TYPES as ge } from "./index.DvwicTLq.js";
3
+ import { useCapability as be, Panel as ot, Toggle as l } from "./App.ByR7hh4G.js";
4
+ import { TextArea as Te } from "./index.X83cFhfe.js";
5
5
  import { useContext as at, useState as a, useMemo as st, useCallback as nt, useEffect as Ne } from "react";
6
6
  const ut = ({
7
7
  open: Ce,
@@ -1,13 +1,13 @@
1
1
  import { jsxs as l, jsx as e } from "react/jsx-runtime";
2
- import { n as f, useUniqueId as v, useUserChatStats as _, useChatsUsage as z, USAGE_TITLE as B, Card as g, renderDataAsList as P, CARDS as a, L as p, j as A, Button as i, pluralize as m } from "./index.BQXkk0E7.js";
3
- import { Panel as H } from "./App.CfJzwyx5.js";
2
+ import { n as f, useUniqueId as v, useUserChatStats as _, useChatsUsage as z, USAGE_TITLE as B, Card as g, renderDataAsList as P, CARDS as a, L as p, j as A, Button as i, pluralize as m } from "./index.DvwicTLq.js";
3
+ import { Panel as H } from "./App.ByR7hh4G.js";
4
4
  import { useState as C, Suspense as K, lazy as j } from "react";
5
5
  const s = [0, 3, 6, 9], n = {
6
6
  TOKEN: "token",
7
7
  MODEL: "model"
8
8
  }, w = j(() => import(
9
9
  /* webpackChunkName: "LazyChart" */
10
- "./Chart.CmXf5ahL.js"
10
+ "./Chart.BOrnLtUH.js"
11
11
  )), R = ({
12
12
  open: k,
13
13
  onOpenChange: E
@@ -1,10 +1,10 @@
1
1
  import { jsx as e, jsxs as r, Fragment as b } from "react/jsx-runtime";
2
- import { L as R, j as A, Button as M, n as Ne, useLocalStorage as K, LOCAL_STORAGE_PREFIX as Q, LOCAL_STORAGE_SORT_MEMORY_DIRECTION as we, e as l, LOCAL_STORAGE_SORT_MEMORY_COLUMN as ke, useUserMemories as Se, useExpiredMemories as Te, useDeleteMemory as ve, useDeleteAllActiveMemories as De, useDeleteAllExpiredMemories as Me, useUpdateMemory as Ee, useRestoreMemory as be, ButtonIcon as O, IconEdit as Re, IconDelete as Z, IconRestore as Ie } from "./index.BQXkk0E7.js";
3
- import { Panel as le, Toggle as _, ConfirmationPanel as ee, Tooltip as z } from "./App.CfJzwyx5.js";
4
- import { W as te, j as re, G as D, M as s, F as B, H as ie, D as ne } from "./index.ZpurL-_2.js";
2
+ import { L as R, j as A, Button as M, n as Ne, useLocalStorage as K, LOCAL_STORAGE_PREFIX as Q, LOCAL_STORAGE_SORT_MEMORY_DIRECTION as we, e as l, LOCAL_STORAGE_SORT_MEMORY_COLUMN as ke, useUserMemories as Se, useExpiredMemories as Te, useDeleteMemory as ve, useDeleteAllActiveMemories as De, useDeleteAllExpiredMemories as Me, useUpdateMemory as Ee, useRestoreMemory as be, ButtonIcon as O, IconEdit as Re, IconDelete as Z, IconRestore as Ie } from "./index.DvwicTLq.js";
3
+ import { Panel as le, Toggle as _, ConfirmationPanel as ee, Tooltip as z } from "./App.ByR7hh4G.js";
4
+ import { W as te, j as re, G as D, M as s, F as B, H as ie, D as ne } from "./index.xYO9MQ7q.js";
5
5
  import y from "clsx";
6
6
  import { useState as C, useEffect as Le, useRef as oe } from "react";
7
- import { TextArea as Oe } from "./index.9ZW-D7id.js";
7
+ import { TextArea as Oe } from "./index.X83cFhfe.js";
8
8
  const _e = ({
9
9
  open: N,
10
10
  onOpenChange: E,
@@ -1,5 +1,5 @@
1
1
  import { jsxs as h, jsx as l } from "react/jsx-runtime";
2
- import { ButtonIcon as E, IconCopied as C, IconCopy as I } from "./index.BQXkk0E7.js";
2
+ import { ButtonIcon as E, IconCopied as C, IconCopy as I } from "./index.DvwicTLq.js";
3
3
  import { useState as N, useEffect as $ } from "react";
4
4
  import t from "clsx";
5
5
  /*!
@@ -1,4 +1,4 @@
1
- import { convert as se, visitParents as Me, unicodeWhitespace as I, unicodePunctuation as N, normalizeIdentifier as _, classifyCharacter as W, visit as _e, toString as ce, EXIT as Oe, asciiAlphanumeric as Z, asciiAlpha as P, markdownLineEndingOrSpace as A, asciiControl as je, blankLine as Be, factorySpace as S, splice as q, resolveAll as We, markdownLineEnding as R, markdownSpace as T, combineExtensions as $e } from "./useMarkdown.D1WsA7gy.js";
1
+ import { convert as se, visitParents as Me, unicodeWhitespace as I, unicodePunctuation as N, normalizeIdentifier as _, classifyCharacter as W, visit as _e, toString as ce, EXIT as Oe, asciiAlphanumeric as Z, asciiAlpha as P, markdownLineEndingOrSpace as A, asciiControl as je, blankLine as Be, factorySpace as S, splice as q, resolveAll as We, markdownLineEnding as R, markdownSpace as T, combineExtensions as $e } from "./useMarkdown.Bxe6gfSy.js";
2
2
  import { longestStreak as qe } from "./index.Cyw5OC0t.js";
3
3
  function ne(e, n) {
4
4
  const t = String(e);
@@ -1,4 +1,4 @@
1
- import { factorySpace as M, markdownLineEnding as g } from "./useMarkdown.D1WsA7gy.js";
1
+ import { factorySpace as M, markdownLineEnding as g } from "./useMarkdown.Bxe6gfSy.js";
2
2
  import { longestStreak as q } from "./index.Cyw5OC0t.js";
3
3
  function b() {
4
4
  return {
@@ -1,6 +1,6 @@
1
- import { getDefaultExportFromCjs as kn } from "./App.CfJzwyx5.js";
2
- import { visit as In } from "./useMarkdown.D1WsA7gy.js";
3
- import { toText as Cn } from "./index.iKl0E1mP.js";
1
+ import { getDefaultExportFromCjs as kn } from "./App.ByR7hh4G.js";
2
+ import { visit as In } from "./useMarkdown.Bxe6gfSy.js";
3
+ import { toText as Cn } from "./index.LWfh_Nx0.js";
4
4
  function xn(e) {
5
5
  const t = e.regex, i = e.COMMENT("//", "$", { contains: [{ begin: /\\\n/ }] }), a = "decltype\\(auto\\)", r = "[a-zA-Z_]\\w*::", d = "(?!struct)(" + a + "|" + t.optional(r) + "[a-zA-Z_]\\w*" + t.optional("<[^<>]+>") + ")", c = {
6
6
  className: "type",
@@ -7852,7 +7852,7 @@ const Hr = {
7852
7852
  ] });
7853
7853
  }, kc = new URL(document.location.href).searchParams, Kr = !!kc.get("debug") || !1, Pc = on(() => import(
7854
7854
  /* webpackChunkName: "LazyApp" */
7855
- "./App.CfJzwyx5.js"
7855
+ "./App.ByR7hh4G.js"
7856
7856
  ).then((e) => e.App)), xc = new kn(), Vr = ({
7857
7857
  isComponent: e,
7858
7858
  headerHeight: t
@@ -1,4 +1,4 @@
1
- import { convert as E, convertElement as u } from "./useMarkdown.D1WsA7gy.js";
1
+ import { convert as E, convertElement as u } from "./useMarkdown.Bxe6gfSy.js";
2
2
  const f = (
3
3
  // Note: overloads like this are needed to support optional generics.
4
4
  /**
@@ -1,5 +1,5 @@
1
1
  import { jsxs as oe, jsx as h } from "react/jsx-runtime";
2
- import { useMergeRefs as ce, useResizeObserver as W, useUniqueId as ne, useUncontrolled as le, LiveRegion as ie } from "./index.BQXkk0E7.js";
2
+ import { useMergeRefs as ce, useResizeObserver as W, useUniqueId as ne, useUncontrolled as le, LiveRegion as ie } from "./index.DvwicTLq.js";
3
3
  import ue, { useRef as k, useState as I, useLayoutEffect as R } from "react";
4
4
  import o from "clsx";
5
5
  /*!
@@ -1,5 +1,5 @@
1
- import { find as Aa, parse as Ft, parse$1 as Ht, normalize as Pt, html as Ta, svg as Ba, visitParents as Na, SKIP as Da } from "./useMarkdown.D1WsA7gy.js";
2
- import { toText as Ca } from "./index.iKl0E1mP.js";
1
+ import { find as Aa, parse as Ft, parse$1 as Ht, normalize as Pt, html as Ta, svg as Ba, visitParents as Na, SKIP as Da } from "./useMarkdown.Bxe6gfSy.js";
2
+ import { toText as Ca } from "./index.LWfh_Nx0.js";
3
3
  const Gt = /[#.]/g;
4
4
  function qa(r, e) {
5
5
  const t = r || "", a = {};
@@ -1,5 +1,5 @@
1
1
  import { jsx as l, jsxs as y } from "react/jsx-runtime";
2
- import { ButtonSort_private as f, e as k } from "./index.BQXkk0E7.js";
2
+ import { ButtonSort_private as f, e as k } from "./index.DvwicTLq.js";
3
3
  import o from "clsx";
4
4
  import v, { useContext as b } from "react";
5
5
  /*!
@@ -1,8 +1,8 @@
1
1
  import * as le from "react/jsx-runtime";
2
2
  import { jsx as vt, jsxs as Tr } from "react/jsx-runtime";
3
- import { isTauri as Lr, ButtonCopy as zr, unObfuscate as _r, obfuscate as Mr } from "./index.BQXkk0E7.js";
3
+ import { isTauri as Lr, ButtonCopy as zr, unObfuscate as _r, obfuscate as Mr } from "./index.DvwicTLq.js";
4
4
  import { useCallback as Dt, useRef as vn, useState as Nr, useEffect as Rr } from "react";
5
- import { getDefaultExportFromCjs as Ft } from "./App.CfJzwyx5.js";
5
+ import { getDefaultExportFromCjs as Ft } from "./App.ByR7hh4G.js";
6
6
  const Ot = -1, ee = 0, Hn = 1, ne = 2, ze = 3, _e = 4, Me = 5, Ne = 6, Bt = 7, jt = 8, Qe = typeof self == "object" ? self : globalThis, vr = (n, e) => {
7
7
  const t = (i, l) => (n.set(l, i), i), r = (i) => {
8
8
  if (n.has(i))
@@ -7111,7 +7111,7 @@ class vu {
7111
7111
  if (!this.remarkGfm) {
7112
7112
  const { default: e } = await import(
7113
7113
  /* webpackChunkName: "md-remark" */
7114
- "./index.CoVeibJJ.js"
7114
+ "./index.Dm0B1x9v.js"
7115
7115
  );
7116
7116
  this.remarkGfm = e;
7117
7117
  }
@@ -7122,7 +7122,7 @@ class vu {
7122
7122
  ju("https://cdn.jsdelivr.net/npm/katex@latest/dist/katex.min.css");
7123
7123
  const { default: e } = await import(
7124
7124
  /* webpackChunkName: "md-rehype-katex" */
7125
- "./index.DNDgXAMw.js"
7125
+ "./index.eSkzK0sZ.js"
7126
7126
  );
7127
7127
  this.rehypeKatex = e;
7128
7128
  }
@@ -7132,7 +7132,7 @@ class vu {
7132
7132
  if (!this.remarkMath) {
7133
7133
  const { default: e } = await import(
7134
7134
  /* webpackChunkName: "md-remark" */
7135
- "./index.B6gxiXab.js"
7135
+ "./index.DosDfPyo.js"
7136
7136
  );
7137
7137
  this.remarkMath = e;
7138
7138
  }
@@ -7142,7 +7142,7 @@ class vu {
7142
7142
  if (!this.rehypeHighlight) {
7143
7143
  const { default: e } = await import(
7144
7144
  /* webpackChunkName: "md-rehype-highlight" */
7145
- "./index.D4xbtPpm.js"
7145
+ "./index.Dq1H4UoP.js"
7146
7146
  );
7147
7147
  this.rehypeHighlight = e;
7148
7148
  }
@@ -1,5 +1,5 @@
1
1
  import "react/jsx-runtime";
2
- import { SassySaint as a } from "../../chunks/index.BQXkk0E7.js";
2
+ import { SassySaint as a } from "../../chunks/index.DvwicTLq.js";
3
3
  export {
4
4
  a as SassySaint
5
5
  };
package/dist/index.js CHANGED
@@ -1,12 +1,12 @@
1
- import { SassySaint as r } from "./chunks/index.BQXkk0E7.js";
1
+ import { SassySaint as r } from "./chunks/index.DvwicTLq.js";
2
2
  /*!
3
- @sassysaint/client v8.83.0
3
+ @sassysaint/client v8.83.1
4
4
  © 2025 gizmette.com
5
5
  */
6
6
  try {
7
7
  window.__VERSINI_SASSY_GLOBAL__ || (window.__VERSINI_SASSY_GLOBAL__ = {
8
- version: "8.83.0",
9
- buildTime: "11/13/2025 01:57 PM EST",
8
+ version: "8.83.1",
9
+ buildTime: "11/13/2025 02:21 PM EST",
10
10
  license: "MIT"
11
11
  });
12
12
  } catch {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@versini/sassysaint",
3
- "version": "8.83.0",
3
+ "version": "8.83.1",
4
4
  "license": "MIT",
5
5
  "author": "Arno Versini",
6
6
  "publishConfig": {
@@ -33,7 +33,7 @@
33
33
  "react-dom": "^18.3.1 || ^19.0.0"
34
34
  },
35
35
  "devDependencies": {
36
- "@sassysaint/client": "8.83.0",
36
+ "@sassysaint/client": "8.83.1",
37
37
  "@tailwindcss/vite": "4.1.17",
38
38
  "@versini/ui-styles": "6.1.1"
39
39
  },
@@ -45,5 +45,5 @@
45
45
  "sideEffects": [
46
46
  "**/*.css"
47
47
  ],
48
- "gitHead": "f55c5fe855b1f04a6c0650e81a530819759c91d2"
48
+ "gitHead": "e03c43ecce9b9cc668c48d9de49dc35db1f0b287"
49
49
  }