ghost 5.116.1 → 5.116.2

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 (91) hide show
  1. package/components/{tryghost-api-framework-5.116.1.tgz → tryghost-api-framework-5.116.2.tgz} +0 -0
  2. package/components/tryghost-constants-5.116.2.tgz +0 -0
  3. package/components/tryghost-custom-fonts-5.116.2.tgz +0 -0
  4. package/components/{tryghost-custom-theme-settings-service-5.116.1.tgz → tryghost-custom-theme-settings-service-5.116.2.tgz} +0 -0
  5. package/components/tryghost-domain-events-5.116.2.tgz +0 -0
  6. package/components/tryghost-donations-5.116.2.tgz +0 -0
  7. package/components/{tryghost-email-addresses-5.116.1.tgz → tryghost-email-addresses-5.116.2.tgz} +0 -0
  8. package/components/{tryghost-email-service-5.116.1.tgz → tryghost-email-service-5.116.2.tgz} +0 -0
  9. package/components/{tryghost-email-suppression-list-5.116.1.tgz → tryghost-email-suppression-list-5.116.2.tgz} +0 -0
  10. package/components/tryghost-html-to-plaintext-5.116.2.tgz +0 -0
  11. package/components/tryghost-i18n-5.116.2.tgz +0 -0
  12. package/components/{tryghost-job-manager-5.116.1.tgz → tryghost-job-manager-5.116.2.tgz} +0 -0
  13. package/components/{tryghost-link-replacer-5.116.1.tgz → tryghost-link-replacer-5.116.2.tgz} +0 -0
  14. package/components/{tryghost-magic-link-5.116.1.tgz → tryghost-magic-link-5.116.2.tgz} +0 -0
  15. package/components/{tryghost-member-attribution-5.116.1.tgz → tryghost-member-attribution-5.116.2.tgz} +0 -0
  16. package/components/{tryghost-member-events-5.116.1.tgz → tryghost-member-events-5.116.2.tgz} +0 -0
  17. package/components/{tryghost-members-api-5.116.1.tgz → tryghost-members-api-5.116.2.tgz} +0 -0
  18. package/components/{tryghost-members-csv-5.116.1.tgz → tryghost-members-csv-5.116.2.tgz} +0 -0
  19. package/components/{tryghost-members-offers-5.116.1.tgz → tryghost-members-offers-5.116.2.tgz} +0 -0
  20. package/components/tryghost-milestones-5.116.2.tgz +0 -0
  21. package/components/{tryghost-mw-error-handler-5.116.1.tgz → tryghost-mw-error-handler-5.116.2.tgz} +0 -0
  22. package/components/tryghost-mw-vhost-5.116.2.tgz +0 -0
  23. package/components/{tryghost-post-events-5.116.1.tgz → tryghost-post-events-5.116.2.tgz} +0 -0
  24. package/components/tryghost-post-revisions-5.116.2.tgz +0 -0
  25. package/components/{tryghost-posts-service-5.116.1.tgz → tryghost-posts-service-5.116.2.tgz} +0 -0
  26. package/components/tryghost-prometheus-metrics-5.116.2.tgz +0 -0
  27. package/components/{tryghost-security-5.116.1.tgz → tryghost-security-5.116.2.tgz} +0 -0
  28. package/components/{tryghost-tiers-5.116.1.tgz → tryghost-tiers-5.116.2.tgz} +0 -0
  29. package/components/tryghost-webmentions-5.116.2.tgz +0 -0
  30. package/content/themes/casper/LICENSE +1 -1
  31. package/content/themes/casper/README.md +1 -1
  32. package/content/themes/source/LICENSE +1 -1
  33. package/content/themes/source/README.md +1 -1
  34. package/content/themes/source/assets/built/screen.css +1 -1
  35. package/content/themes/source/assets/built/screen.css.map +1 -1
  36. package/content/themes/source/assets/css/screen.css +11 -6
  37. package/content/themes/source/partials/feature-image.hbs +2 -2
  38. package/core/built/admin/assets/admin-x-activitypub/admin-x-activitypub.js +9776 -11013
  39. package/core/built/admin/assets/admin-x-demo/admin-x-demo.js +2 -2
  40. package/core/built/admin/assets/admin-x-demo/{index-a9601514.mjs → index-09325f38.mjs} +4 -4
  41. package/core/built/admin/assets/admin-x-demo/{modals-c1789d04.mjs → modals-1a9ae8b7.mjs} +2 -2
  42. package/core/built/admin/assets/admin-x-settings/{CodeEditorView-e9c9deb8.mjs → CodeEditorView-550846e0.mjs} +2 -2
  43. package/core/built/admin/assets/admin-x-settings/admin-x-settings.js +2 -2
  44. package/core/built/admin/assets/admin-x-settings/{index-f744cab7.mjs → index-4ce2fcd1.mjs} +78 -77
  45. package/core/built/admin/assets/admin-x-settings/{index-84580c3a.mjs → index-f3cb3f4d.mjs} +2 -2
  46. package/core/built/admin/assets/admin-x-settings/{modals-d9ca60c5.mjs → modals-6bc20529.mjs} +8 -8
  47. package/core/built/admin/assets/{chunk.524.cb72a86e19c9ffd6172e.js → chunk.524.578de86e5014b911b05a.js} +5 -5
  48. package/core/built/admin/assets/{chunk.582.4f4d38ffe79fbdbd26f7.js → chunk.582.21bf3e37b5d84ac4b58a.js} +9 -9
  49. package/core/built/admin/assets/{chunk.713.e9027c0cc3c56110f5da.js → chunk.713.761d11035fe0bf3e557c.js} +2 -2
  50. package/core/built/admin/assets/{ghost-03b64c086f3c60cabc85fe7a7e2b640a.js → ghost-868c537d5c02ca65323d0122596a67ec.js} +57 -55
  51. package/core/built/admin/assets/posts/posts.js +5185 -5096
  52. package/core/built/admin/assets/stats/stats.js +6630 -6541
  53. package/core/built/admin/assets/{vendor-72026232b36d97babc6320917c16c321.js → vendor-8e3ee8261528bb429cfe78ce79a4a82a.js} +5 -5
  54. package/core/built/admin/index.html +5 -5
  55. package/core/frontend/helpers/ghost_head.js +9 -5
  56. package/core/frontend/public/ghost-stats.js +41 -74
  57. package/core/server/data/tinybird/datasources/_mv_hits.datasource +23 -0
  58. package/core/server/data/tinybird/datasources/analytics_events.datasource +14 -0
  59. package/core/server/data/tinybird/endpoints/api_kpis.pipe +161 -0
  60. package/core/server/data/tinybird/endpoints/api_top_browsers.pipe +52 -0
  61. package/core/server/data/tinybird/endpoints/api_top_devices.pipe +51 -0
  62. package/core/server/data/tinybird/endpoints/api_top_locations.pipe +51 -0
  63. package/core/server/data/tinybird/endpoints/api_top_os.pipe +51 -0
  64. package/core/server/data/tinybird/endpoints/api_top_pages.pipe +52 -0
  65. package/core/server/data/tinybird/endpoints/api_top_sources.pipe +24 -0
  66. package/core/server/data/tinybird/fixtures/analytics_events.ndjson +31 -0
  67. package/core/server/data/tinybird/pipes/filtered_sessions.pipe +42 -0
  68. package/core/server/data/tinybird/pipes/mv_hits.pipe +89 -0
  69. package/core/server/data/tinybird/pipes/mv_session_data.pipe +28 -0
  70. package/core/server/data/tinybird/readme.md +47 -0
  71. package/core/server/data/tinybird/tests/api_kpis.yaml +207 -0
  72. package/core/server/data/tinybird/tests/api_top_browsers.yaml +89 -0
  73. package/core/server/data/tinybird/tests/api_top_devices.yaml +69 -0
  74. package/core/server/data/tinybird/tests/api_top_locations.yaml +95 -0
  75. package/core/server/data/tinybird/tests/api_top_os.yaml +73 -0
  76. package/core/server/data/tinybird/tests/api_top_pages.yaml +86 -0
  77. package/core/server/data/tinybird/tests/api_top_sources.yaml +118 -0
  78. package/package.json +59 -59
  79. package/yarn.lock +37 -56
  80. package/components/tryghost-constants-5.116.1.tgz +0 -0
  81. package/components/tryghost-custom-fonts-5.116.1.tgz +0 -0
  82. package/components/tryghost-domain-events-5.116.1.tgz +0 -0
  83. package/components/tryghost-donations-5.116.1.tgz +0 -0
  84. package/components/tryghost-html-to-plaintext-5.116.1.tgz +0 -0
  85. package/components/tryghost-i18n-5.116.1.tgz +0 -0
  86. package/components/tryghost-milestones-5.116.1.tgz +0 -0
  87. package/components/tryghost-mw-vhost-5.116.1.tgz +0 -0
  88. package/components/tryghost-post-revisions-5.116.1.tgz +0 -0
  89. package/components/tryghost-prometheus-metrics-5.116.1.tgz +0 -0
  90. package/components/tryghost-webmentions-5.116.1.tgz +0 -0
  91. /package/core/built/admin/assets/{chunk.713.e9027c0cc3c56110f5da.js.LICENSE.txt → chunk.713.761d11035fe0bf3e557c.js.LICENSE.txt} +0 -0
@@ -2176,7 +2176,7 @@ const at = ({ className: e }) => (e || (e = "border-grey-200 dark:border-grey-80
2176
2176
  o,
2177
2177
  n
2178
2178
  ), /* @__PURE__ */ c.jsx("span", { className: n, ...r, children: e });
2179
- }, T5 = R.lazy(() => import("./CodeEditorView-e9c9deb8.mjs")), Bd = U(function(t, n) {
2179
+ }, T5 = R.lazy(() => import("./CodeEditorView-550846e0.mjs")), Bd = U(function(t, n) {
2180
2180
  return /* @__PURE__ */ c.jsx(Rf, { fallback: null, children: /* @__PURE__ */ c.jsx(T5, { ...t, ref: n }) });
2181
2181
  }), h1 = (e) => /* @__PURE__ */ p("svg", { xmlns: "http://www.w3.org/2000/svg", fill: "none", viewBox: "0 0 14 14", height: 16, width: 16, ...e }, /* @__PURE__ */ p("g", { id: "user-single-neutral--close-geometric-human-person-single-up-user" }, /* @__PURE__ */ p("path", { id: "Union", fill: "currentColor", fillRule: "evenodd", d: "M10.5 3.5C10.5 5.433 8.93295 7 6.99995 7C5.06695 7 3.49995 5.433 3.49995 3.5C3.49995 1.567 5.06695 0 6.99995 0C8.93295 0 10.5 1.567 10.5 3.5ZM0.320435 13.4C1.21244 10.56 3.86563 8.50003 6.99996 8.50003C10.1343 8.50003 12.7875 10.56 13.6795 13.4C13.7751 13.7044 13.537 14 13.2179 14H0.781996C0.462883 14 0.224811 13.7044 0.320435 13.4Z", clipRule: "evenodd" }))), k5 = "", z5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
2182
2182
  __proto__: null,
@@ -4040,11 +4040,11 @@ const wl = $M, W1 = nx, R1 = rx, Ye = ({
4040
4040
  "relative order-2 flex w-full items-center",
4041
4041
  n && !r && "mt-1.5"
4042
4042
  ), D = !A && T(
4043
- "absolute inset-0 rounded-lg border text-grey-300 transition-colors peer-hover:bg-grey-100 peer-focus:border-green peer-focus:bg-white peer-focus:shadow-[0_0_0_2px_rgba(48,207,67,.25)] dark:peer-hover:bg-grey-925 dark:peer-focus:bg-grey-950",
4043
+ "dark:peer-hover:bg-grey-925 dark:peer-focus:bg-grey-950 absolute inset-0 rounded-lg border text-grey-300 transition-colors peer-hover:bg-grey-100 peer-focus:border-green peer-focus:bg-white peer-focus:shadow-[0_0_0_2px_rgba(48,207,67,.25)]",
4044
4044
  i ? "border-red bg-white dark:bg-grey-925" : "border-transparent bg-grey-150 dark:bg-grey-900",
4045
- y && "bg-grey-50 peer-hover:bg-grey-50 dark:bg-grey-950 dark:peer-hover:bg-grey-950"
4045
+ y && "dark:peer-hover:bg-grey-950 bg-grey-50 peer-hover:bg-grey-50 dark:bg-grey-950"
4046
4046
  ), S = !A && T(
4047
- "peer z-[1] order-2 h-9 w-full bg-transparent px-3 py-1.5 text-sm placeholder:text-grey-500 dark:placeholder:text-grey-700 md:h-[38px] md:py-2 md:text-md",
4047
+ "peer z-[1] order-2 h-9 w-full bg-transparent px-3 py-1.5 text-sm placeholder:text-grey-500 md:h-[38px] md:py-2 md:text-md dark:placeholder:text-grey-700",
4048
4048
  y ? "cursor-not-allowed text-grey-600 opacity-60 dark:text-grey-800" : "dark:text-white",
4049
4049
  a ? "w-0 grow rounded-l-lg" : "rounded-lg",
4050
4050
  m
@@ -4157,7 +4157,7 @@ const wl = $M, W1 = nx, R1 = rx, Ye = ({
4157
4157
  r === "lg" && "mt-12"
4158
4158
  )), t && (l = T(
4159
4159
  l,
4160
- "rounded-sm border border-grey-200 p-4 dark:border-grey-900 md:p-7"
4160
+ "rounded-sm border border-grey-200 p-4 md:p-7 dark:border-grey-900"
4161
4161
  ));
4162
4162
  const u = T(
4163
4163
  t ? "mb-3" : "mb-4"
@@ -11981,7 +11981,7 @@ var S2 = function(t) {
11981
11981
  if (!I)
11982
11982
  return null;
11983
11983
  var B = function(se, _) {
11984
- var ne = se.type, $ = se.data, te = se.isDisabled, ye = se.isSelected, Ne = se.label, ee = se.value, Se = v === $, le = te ? void 0 : function() {
11984
+ var ne = se.type, $ = se.data, te = se.isDisabled, ye = se.isSelected, De = se.label, ee = se.value, Se = v === $, le = te ? void 0 : function() {
11985
11985
  return o.onOptionHover($);
11986
11986
  }, xe = te ? void 0 : function() {
11987
11987
  return o.selectOption($);
@@ -12001,7 +12001,7 @@ var S2 = function(t) {
12001
12001
  isDisabled: te,
12002
12002
  isSelected: ye,
12003
12003
  key: He,
12004
- label: Ne,
12004
+ label: De,
12005
12005
  type: ne,
12006
12006
  value: ee,
12007
12007
  isFocused: Se,
@@ -12066,8 +12066,8 @@ var S2 = function(t) {
12066
12066
  lockEnabled: C
12067
12067
  }, function(te) {
12068
12068
  return /* @__PURE__ */ p(u, X({}, h, {
12069
- innerRef: function(Ne) {
12070
- o.getMenuListRef(Ne), te(Ne);
12069
+ innerRef: function(De) {
12070
+ o.getMenuListRef(De), te(De);
12071
12071
  },
12072
12072
  innerProps: {
12073
12073
  role: "listbox",
@@ -12214,8 +12214,8 @@ var t6 = /* @__PURE__ */ U(function(e, t) {
12214
12214
  function L2(e) {
12215
12215
  var t = e.defaultOptions, n = t === void 0 ? !1 : t, r = e.cacheOptions, o = r === void 0 ? !1 : r, i = e.loadOptions;
12216
12216
  e.options;
12217
- var s = e.isLoading, a = s === void 0 ? !1 : s, l = e.onInputChange, u = e.filterOption, d = u === void 0 ? null : u, f = Bt(e, n6), g = f.inputValue, m = H(void 0), h = H(!1), v = P(Array.isArray(n) ? n : void 0), b = Fe(v, 2), A = b[0], y = b[1], x = P(typeof g < "u" ? g : ""), M = Fe(x, 2), j = M[0], w = M[1], I = P(n === !0), N = Fe(I, 2), D = N[0], S = N[1], C = P(void 0), E = Fe(C, 2), k = E[0], O = E[1], W = P([]), B = Fe(W, 2), Y = B[0], K = B[1], he = P(!1), Ie = Fe(he, 2), Ce = Ie[0], q = Ie[1], se = P({}), _ = Fe(se, 2), ne = _[0], $ = _[1], te = P(void 0), ye = Fe(te, 2), Ne = ye[0], ee = ye[1], Se = P(void 0), le = Fe(Se, 2), xe = le[0], He = le[1];
12218
- o !== xe && ($({}), He(o)), n !== Ne && (y(Array.isArray(n) ? n : void 0), ee(n)), L(function() {
12217
+ var s = e.isLoading, a = s === void 0 ? !1 : s, l = e.onInputChange, u = e.filterOption, d = u === void 0 ? null : u, f = Bt(e, n6), g = f.inputValue, m = H(void 0), h = H(!1), v = P(Array.isArray(n) ? n : void 0), b = Fe(v, 2), A = b[0], y = b[1], x = P(typeof g < "u" ? g : ""), M = Fe(x, 2), j = M[0], w = M[1], I = P(n === !0), N = Fe(I, 2), D = N[0], S = N[1], C = P(void 0), E = Fe(C, 2), k = E[0], O = E[1], W = P([]), B = Fe(W, 2), Y = B[0], K = B[1], he = P(!1), Ie = Fe(he, 2), Ce = Ie[0], q = Ie[1], se = P({}), _ = Fe(se, 2), ne = _[0], $ = _[1], te = P(void 0), ye = Fe(te, 2), De = ye[0], ee = ye[1], Se = P(void 0), le = Fe(Se, 2), xe = le[0], He = le[1];
12218
+ o !== xe && ($({}), He(o)), n !== De && (y(Array.isArray(n) ? n : void 0), ee(n)), L(function() {
12219
12219
  return h.current = !0, function() {
12220
12220
  h.current = !1;
12221
12221
  };
@@ -12419,7 +12419,7 @@ function E2(e) {
12419
12419
  const t = re(p6);
12420
12420
  return e || t || "ltr";
12421
12421
  }
12422
- const m6 = ({ clearBg: e, ...t }) => /* @__PURE__ */ c.jsx(Fr.DropdownIndicator, { ...t, children: /* @__PURE__ */ c.jsx("div", { className: `absolute top-1/2 mt-[-5px] block h-2 w-2 rotate-45 border-[1px] border-l-0 border-t-0 border-grey-900 content-[''] dark:border-grey-400 ${e ? "right-2" : "right-[14px]"} ` }) }), v6 = (e) => /* @__PURE__ */ c.jsx(Fr.ClearIndicator, { ...e, children: /* @__PURE__ */ c.jsx(ve, { className: "mr-2", name: "close", size: "xs" }) }), h6 = ({ children: e, ...t }) => /* @__PURE__ */ c.jsxs(Fr.Option, { ...t, children: [
12422
+ const m6 = ({ clearBg: e, ...t }) => /* @__PURE__ */ c.jsx(Fr.DropdownIndicator, { ...t, children: /* @__PURE__ */ c.jsx("div", { className: `absolute top-1/2 mt-[-5px] block size-2 rotate-45 border-[1px] border-l-0 border-t-0 border-grey-900 content-[''] dark:border-grey-400 ${e ? "right-2" : "right-[14px]"} ` }) }), v6 = (e) => /* @__PURE__ */ c.jsx(Fr.ClearIndicator, { ...e, children: /* @__PURE__ */ c.jsx(ve, { className: "mr-2", name: "close", size: "xs" }) }), h6 = ({ children: e, ...t }) => /* @__PURE__ */ c.jsxs(Fr.Option, { ...t, children: [
12423
12423
  /* @__PURE__ */ c.jsxs("span", { className: t.isSelected ? "relative flex w-full items-center justify-between gap-2" : "", "data-testid": "select-option", "data-value": t.data.value, children: [
12424
12424
  e,
12425
12425
  t.isSelected && /* @__PURE__ */ c.jsx("span", { children: /* @__PURE__ */ c.jsx(ve, { name: "check", size: 14 }) })
@@ -12473,7 +12473,7 @@ const m6 = ({ clearBg: e, ...t }) => /* @__PURE__ */ c.jsx(Fr.DropdownIndicator,
12473
12473
  const D = {
12474
12474
  control: T(
12475
12475
  h == null ? void 0 : h.control,
12476
- "h-9 min-h-[36px] w-full appearance-none rounded-lg border outline-none dark:text-white md:h-[38px] md:min-h-[38px]",
12476
+ "h-9 min-h-[36px] w-full appearance-none rounded-lg border outline-none md:h-[38px] md:min-h-[38px] dark:text-white",
12477
12477
  r === "xs" ? "py-0 pr-2 text-xs" : "py-1 pr-4",
12478
12478
  d ? "" : "bg-grey-150 px-3 dark:bg-grey-900",
12479
12479
  l ? "border-red" : `border-transparent ${!d && "hover:bg-grey-100 dark:hover:bg-grey-925"}`,
@@ -13322,7 +13322,7 @@ const U2 = "bg-[rgba(98,109,121,0.2)] backdrop-blur-[3px]", Vr = U(({
13322
13322
  q,
13323
13323
  (e === "full" || e === "bleed" || r === "full" || typeof r == "number") && "grow"
13324
13324
  );
13325
- const Ne = (le) => {
13325
+ const De = (le) => {
13326
13326
  le.target === le.currentTarget && I && se();
13327
13327
  }, ee = {};
13328
13328
  typeof n == "number" ? (ee.width = "100%", ee.maxWidth = n + "px") : n === "full" ? _ = T(
@@ -13339,7 +13339,7 @@ const U2 = "bg-[rgba(98,109,121,0.2)] backdrop-blur-[3px]", Vr = U(({
13339
13339
  return u ? Se = u : u === !1 ? q += " pb-0 " : Se = /* @__PURE__ */ c.jsxs("div", { className: ye, children: [
13340
13340
  /* @__PURE__ */ c.jsx("div", { children: f && /* @__PURE__ */ c.jsx(J, { ...f }) }),
13341
13341
  /* @__PURE__ */ c.jsx("div", { className: "flex gap-3", children: /* @__PURE__ */ c.jsx(No, { buttons: Ce }) })
13342
- ] }), Se = N ? /* @__PURE__ */ c.jsx(V6, { height: 84, children: Se }) : /* @__PURE__ */ c.jsx(c.Fragment, { children: Se }), /* @__PURE__ */ c.jsxs("div", { className: ne, id: "modal-backdrop", onMouseDown: Ne, children: [
13342
+ ] }), Se = N ? /* @__PURE__ */ c.jsx(V6, { height: 84, children: Se }) : /* @__PURE__ */ c.jsx(c.Fragment, { children: Se }), /* @__PURE__ */ c.jsxs("div", { className: ne, id: "modal-backdrop", onMouseDown: De, children: [
13343
13343
  /* @__PURE__ */ c.jsx("div", { className: T(
13344
13344
  "pointer-events-none fixed inset-0 z-0",
13345
13345
  w && !k && U2,
@@ -14842,7 +14842,7 @@ var jp = "PopperAnchor", Np = U(
14842
14842
  Np.displayName = jp;
14843
14843
  var sd = "PopperContent", [uC, dC] = xp(sd), Dp = U(
14844
14844
  (e, t) => {
14845
- var te, ye, Ne, ee, Se, le;
14845
+ var te, ye, De, ee, Se, le;
14846
14846
  const {
14847
14847
  __scopePopper: n,
14848
14848
  side: r = "bottom",
@@ -14897,7 +14897,7 @@ var sd = "PopperContent", [uC, dC] = xp(sd), Dp = U(
14897
14897
  Nt(() => {
14898
14898
  Y && (Ce == null || Ce());
14899
14899
  }, [Y, Ce]);
14900
- const q = (te = K.arrow) == null ? void 0 : te.x, se = (ye = K.arrow) == null ? void 0 : ye.y, _ = ((Ne = K.arrow) == null ? void 0 : Ne.centerOffset) !== 0, [ne, $] = P();
14900
+ const q = (te = K.arrow) == null ? void 0 : te.x, se = (ye = K.arrow) == null ? void 0 : ye.y, _ = ((De = K.arrow) == null ? void 0 : De.centerOffset) !== 0, [ne, $] = P();
14901
14901
  return Nt(() => {
14902
14902
  A && $(window.getComputedStyle(A).zIndex);
14903
14903
  }, [A]), /* @__PURE__ */ c.jsx(
@@ -17911,14 +17911,14 @@ const OP = /* @__PURE__ */ bu(function(t) {
17911
17911
  dragging: w,
17912
17912
  dependencies: [D.x, D.y],
17913
17913
  config: q.droppable
17914
- }), $ = mP(N, I), te = Z(() => Y ? gs(Y) : null, [Y]), ye = Na(), Ne = bP($, q.draggable.measure);
17914
+ }), $ = mP(N, I), te = Z(() => Y ? gs(Y) : null, [Y]), ye = Na(), De = bP($, q.draggable.measure);
17915
17915
  EP({
17916
17916
  activeNode: I ? N.get(I) : null,
17917
17917
  config: ye.layoutShiftCompensation,
17918
- initialRect: Ne,
17918
+ initialRect: De,
17919
17919
  measure: q.draggable.measure
17920
17920
  });
17921
- const ee = ff($, q.draggable.measure, Ne), Se = ff($ ? $.parentElement : null), le = H({
17921
+ const ee = ff($, q.draggable.measure, De), Se = ff($ ? $.parentElement : null), le = H({
17922
17922
  activatorEvent: null,
17923
17923
  active: null,
17924
17924
  activeNode: $,
@@ -18914,8 +18914,8 @@ function pL(e) {
18914
18914
  items: d,
18915
18915
  activeIndex: g,
18916
18916
  overIndex: b
18917
- }) : M, Ne = C == null ? void 0 : C.id, ee = H({
18918
- activeId: Ne,
18917
+ }) : M, De = C == null ? void 0 : C.id, ee = H({
18918
+ activeId: De,
18919
18919
  items: d,
18920
18920
  newIndex: ye,
18921
18921
  containerId: f
@@ -18941,17 +18941,17 @@ function pL(e) {
18941
18941
  return L(() => {
18942
18942
  q && ee.current.newIndex !== ye && (ee.current.newIndex = ye), f !== ee.current.containerId && (ee.current.containerId = f), d !== ee.current.items && (ee.current.items = d);
18943
18943
  }, [q, ye, f, d]), L(() => {
18944
- if (Ne === ee.current.activeId)
18944
+ if (De === ee.current.activeId)
18945
18945
  return;
18946
- if (Ne && !ee.current.activeId) {
18947
- ee.current.activeId = Ne;
18946
+ if (De && !ee.current.activeId) {
18947
+ ee.current.activeId = De;
18948
18948
  return;
18949
18949
  }
18950
18950
  const tt = setTimeout(() => {
18951
- ee.current.activeId = Ne;
18951
+ ee.current.activeId = De;
18952
18952
  }, 50);
18953
18953
  return () => clearTimeout(tt);
18954
- }, [Ne]), {
18954
+ }, [De]), {
18955
18955
  active: C,
18956
18956
  activeIndex: g,
18957
18957
  attributes: O,
@@ -20377,8 +20377,8 @@ const Fm = oe(void 0), HT = ({ children: e }) => {
20377
20377
  config: r.data.config,
20378
20378
  currentUser: o.data
20379
20379
  }, children: e });
20380
- }, De = () => re(Fm), Vm = (e) => {
20381
- const { config: t } = De();
20380
+ }, Ne = () => re(Fm), Vm = (e) => {
20381
+ const { config: t } = Ne();
20382
20382
  return t.labs[e] || !1;
20383
20383
  }, Ym = (e, t) => (n, r) => {
20384
20384
  if (!r)
@@ -20521,7 +20521,7 @@ function Dr(e) {
20521
20521
  return Qm(e) || Jm(e);
20522
20522
  }
20523
20523
  const RT = () => {
20524
- const { isDirty: e } = ws(), { currentUser: t } = De(), n = Vm("ActivityPub"), r = () => {
20524
+ const { isDirty: e } = ws(), { currentUser: t } = Ne(), n = Vm("ActivityPub"), r = () => {
20525
20525
  window.location.hash = n && Dr(t) ? "/activitypub" : "/dashboard";
20526
20526
  };
20527
20527
  return /* @__PURE__ */ c.jsx(J, { className: "text-grey-700 hover:!text-grey-900", "data-testid": "exit-settings", icon: "close", id: "done-button", label: "", link: !0, title: "Close (ESC)", onClick: () => Do(e, r) });
@@ -20619,7 +20619,7 @@ const RT = () => {
20619
20619
  okProps: x
20620
20620
  };
20621
20621
  }, et = ({ savingDelay: e, onValidate: t } = {}) => {
20622
- const n = H(null), { siteData: r, settings: o } = De(), { mutateAsync: i } = Yo(), s = $e(), [a, l] = P(!1), { formState: u, saveState: d, handleSave: f, updateForm: g, setFormState: m, reset: h, validate: v, errors: b, clearError: A, okProps: y } = Km({
20622
+ const n = H(null), { siteData: r, settings: o } = Ne(), { mutateAsync: i } = Yo(), s = $e(), [a, l] = P(!1), { formState: u, saveState: d, handleSave: f, updateForm: g, setFormState: m, reset: h, validate: v, errors: b, clearError: A, okProps: y } = Km({
20623
20623
  initialState: o || [],
20624
20624
  savingDelay: e,
20625
20625
  onSave: async () => {
@@ -21081,7 +21081,7 @@ const $m = oe({
21081
21081
  );
21082
21082
  }, fk = ge(dk, "History"), gk = "";
21083
21083
  function yd() {
21084
- const { config: e, settings: t } = De(), [n] = je(t, ["pintura"]), [r, o] = P(!1), [i, s] = P(!1), [a, l] = P(!1), u = H(!1), [d] = je(t, ["pintura_js_url"]), [f] = je(t, ["pintura_css_url"]);
21084
+ const { config: e, settings: t } = Ne(), [n] = je(t, ["pintura"]), [r, o] = P(!1), [i, s] = P(!1), [a, l] = P(!1), u = H(!1), [d] = je(t, ["pintura_js_url"]), [f] = je(t, ["pintura_css_url"]);
21085
21085
  let g = n && r && i || !1;
21086
21086
  const m = e == null ? void 0 : e.pintura;
21087
21087
  L(() => {
@@ -21286,9 +21286,9 @@ const pk = (e) => /* @__PURE__ */ p("svg", { width: 100, height: 100, viewBox: "
21286
21286
  );
21287
21287
  }, Mk = () => {
21288
21288
  var d, f, g;
21289
- const { config: e } = De(), { updateRoute: t } = ie(), n = (m) => {
21289
+ const { config: e } = Ne(), { updateRoute: t } = ie(), n = (m) => {
21290
21290
  t(m);
21291
- }, r = (g = (f = (d = e.hostSettings) == null ? void 0 : d.limits) == null ? void 0 : f.customIntegrations) == null ? void 0 : g.disabled, o = yd(), { settings: i } = De(), [s, a, l, u] = je(i, [
21291
+ }, r = (g = (f = (d = e.hostSettings) == null ? void 0 : d.limits) == null ? void 0 : f.customIntegrations) == null ? void 0 : g.disabled, o = yd(), { settings: i } = Ne(), [s, a, l, u] = je(i, [
21292
21292
  "unsplash",
21293
21293
  "firstpromoter",
21294
21294
  "slack_url",
@@ -21425,7 +21425,7 @@ const pk = (e) => /* @__PURE__ */ p("svg", { width: 100, height: 100, viewBox: "
21425
21425
  {
21426
21426
  customButtons: s,
21427
21427
  customHeader: /* @__PURE__ */ c.jsxs("div", { className: "sm:-mt-5 md:-mt-7", children: [
21428
- /* @__PURE__ */ c.jsx("div", { className: "-mx-5 overflow-hidden rounded-t-xl border-b border-grey-200 dark:border-grey-800 md:-mx-7", children: /* @__PURE__ */ c.jsx("img", { className: "h-full w-full", src: gk }) }),
21428
+ /* @__PURE__ */ c.jsx("div", { className: "-mx-5 overflow-hidden rounded-t-xl border-b border-grey-200 md:-mx-7 dark:border-grey-800", children: /* @__PURE__ */ c.jsx("img", { className: "h-full w-full", src: gk }) }),
21429
21429
  /* @__PURE__ */ c.jsxs("div", { className: " z-10 mt-6 flex items-start justify-between", children: [
21430
21430
  /* @__PURE__ */ c.jsx(qn, { description: "Make Ghost work with apps and tools.", title: "Integrations" }),
21431
21431
  /* @__PURE__ */ c.jsx(J, { className: "mt-[-5px] inline-flex h-7 cursor-pointer items-center justify-center whitespace-nowrap rounded px-3 text-sm font-semibold text-grey-900 transition hover:bg-grey-200 dark:text-white dark:hover:bg-grey-900 [&:hover]:text-black", color: "clear", label: "Add custom integration", link: !0, onClick: () => {
@@ -21446,7 +21446,7 @@ function jk(e, t = {}) {
21446
21446
  }, window.plausible(e, { props: t }), window.posthog && window.posthog.capture(e, t);
21447
21447
  }
21448
21448
  const fo = ({ label: e, flag: t }) => {
21449
- const { settings: n } = De(), r = JSON.parse(hs(n, "labs") || "{}"), { mutateAsync: o } = Yo(), i = Zr(), s = $e();
21449
+ const { settings: n } = Ne(), r = JSON.parse(hs(n, "labs") || "{}"), { mutateAsync: o } = Yo(), i = Zr(), s = $e();
21450
21450
  return /* @__PURE__ */ c.jsx($t, { checked: r[t], label: e, labelClasses: "sr-only", name: `feature-${t}`, onChange: async () => {
21451
21451
  const a = !r[t];
21452
21452
  try {
@@ -21557,9 +21557,10 @@ const fo = ({ label: e, flag: t }) => {
21557
21557
  return t.append("routes", e), t;
21558
21558
  }
21559
21559
  }), Lk = () => bd("/settings/routes/yaml/"), Tk = () => {
21560
- const { mutateAsync: e } = Ck(), { mutateAsync: t } = Pk(), n = $e(), [r, o] = P(!1), [i, s] = P(!1);
21560
+ var u;
21561
+ const { mutateAsync: e } = Ck(), { mutateAsync: t } = Pk(), n = $e(), [r, o] = P(!1), [i, s] = P(!1), { config: a } = Ne(), l = !!((u = a.hostSettings) != null && u.siteId);
21561
21562
  return /* @__PURE__ */ c.jsxs(Yr, { titleSeparator: !1, children: [
21562
- /* @__PURE__ */ c.jsx(
21563
+ l && /* @__PURE__ */ c.jsx(
21563
21564
  Zn,
21564
21565
  {
21565
21566
  action: /* @__PURE__ */ c.jsx(fo, { flag: "ActivityPub" }),
@@ -21605,14 +21606,14 @@ const fo = ({ label: e, flag: t }) => {
21605
21606
  Fi,
21606
21607
  {
21607
21608
  id: "upload-redirects",
21608
- onUpload: async (a) => {
21609
+ onUpload: async (d) => {
21609
21610
  try {
21610
- o(!0), await e(a), wt({
21611
+ o(!0), await e(d), wt({
21611
21612
  title: "Redirects uploaded",
21612
21613
  type: "success"
21613
21614
  });
21614
- } catch (l) {
21615
- n(l);
21615
+ } catch (f) {
21616
+ n(f);
21616
21617
  } finally {
21617
21618
  o(!1);
21618
21619
  }
@@ -21639,14 +21640,14 @@ const fo = ({ label: e, flag: t }) => {
21639
21640
  Fi,
21640
21641
  {
21641
21642
  id: "upload-routes",
21642
- onUpload: async (a) => {
21643
+ onUpload: async (d) => {
21643
21644
  try {
21644
- s(!0), await t(a), wt({
21645
+ s(!0), await t(d), wt({
21645
21646
  type: "success",
21646
21647
  title: "Routes uploaded"
21647
21648
  });
21648
- } catch (l) {
21649
- n(l);
21649
+ } catch (f) {
21650
+ n(f);
21650
21651
  } finally {
21651
21652
  s(!1);
21652
21653
  }
@@ -21662,7 +21663,7 @@ const fo = ({ label: e, flag: t }) => {
21662
21663
  )
21663
21664
  ] });
21664
21665
  }, kk = "", zk = ({ keywords: e }) => {
21665
- const [t, n] = P("labs-beta-features"), [r, o] = P(!1), { config: i } = De(), s = [
21666
+ const [t, n] = P("labs-beta-features"), [r, o] = P(!1), { config: i } = Ne(), s = [
21666
21667
  {
21667
21668
  id: "labs-beta-features",
21668
21669
  title: "Beta features",
@@ -22101,7 +22102,7 @@ const _k = ({ keywords: e }) => {
22101
22102
  }
22102
22103
  );
22103
22104
  }, $k = ge(_k, "Default recipients"), ez = ({ keywords: e }) => {
22104
- const { settings: t } = De(), { mutateAsync: n } = Yo(), { updateRoute: r } = ie(), o = $e(), [i, s] = je(t, ["editor_default_email_recipients", "members_signup_access"]), a = s === "none", l = async (d) => {
22105
+ const { settings: t } = Ne(), { mutateAsync: n } = Yo(), { updateRoute: r } = ie(), o = $e(), [i, s] = je(t, ["editor_default_email_recipients", "members_signup_access"]), a = s === "none", l = async (d) => {
22105
22106
  const f = [
22106
22107
  { key: "editor_default_email_recipients", value: d.target.checked ? "visibility" : "disabled" }
22107
22108
  ];
@@ -22482,7 +22483,7 @@ const _k = ({ keywords: e }) => {
22482
22483
  defaultRecipients: ["newsletters", "default recipients", "emails"],
22483
22484
  mailgun: ["mailgun", "emails", "newsletters"]
22484
22485
  }, uz = () => {
22485
- const { settings: e, config: t } = De(), [n] = je(e, ["editor_default_email_recipients"]);
22486
+ const { settings: e, config: t } = Ne(), [n] = je(e, ["editor_default_email_recipients"]);
22486
22487
  return /* @__PURE__ */ c.jsxs($r, { keywords: Object.values(St).flat(), title: "Email newsletter", children: [
22487
22488
  /* @__PURE__ */ c.jsx(tz, { keywords: St.enableNewsletters }),
22488
22489
  n !== "disabled" && /* @__PURE__ */ c.jsxs(c.Fragment, { children: [
@@ -22608,7 +22609,7 @@ const _k = ({ keywords: e }) => {
22608
22609
  }
22609
22610
  );
22610
22611
  }, fz = ge(dz, "Facebook card"), gz = ({ keywords: e }) => {
22611
- const { siteData: t } = De(), {
22612
+ const { siteData: t } = Ne(), {
22612
22613
  localSettings: n,
22613
22614
  isEditing: r,
22614
22615
  saveState: o,
@@ -22699,7 +22700,7 @@ const _k = ({ keywords: e }) => {
22699
22700
  url: r
22700
22701
  }) => {
22701
22702
  const o = r == null ? void 0 : r.replace(/\/$/, ""), i = o == null ? void 0 : o.replace(/^https?:\/\//, "").replace(/\/?$/, "");
22702
- return /* @__PURE__ */ c.jsx("div", { children: /* @__PURE__ */ c.jsx("div", { className: "-mx-5 -mb-5 overflow-hidden rounded-b-xl bg-grey-50 px-5 pt-5 dark:bg-grey-950 md:-mx-7 md:-mb-7 md:px-7 md:pt-7", children: /* @__PURE__ */ c.jsxs("div", { className: "rounded-t-sm bg-white px-5 py-3 shadow-lg dark:bg-grey-975", children: [
22703
+ return /* @__PURE__ */ c.jsx("div", { children: /* @__PURE__ */ c.jsx("div", { className: "-mx-5 -mb-5 overflow-hidden rounded-b-xl bg-grey-50 px-5 pt-5 md:-mx-7 md:-mb-7 md:px-7 md:pt-7 dark:bg-grey-950", children: /* @__PURE__ */ c.jsxs("div", { className: "rounded-t-sm bg-white px-5 py-3 shadow-lg dark:bg-grey-975", children: [
22703
22704
  /* @__PURE__ */ c.jsxs("div", { className: "mt-3 flex items-center", children: [
22704
22705
  /* @__PURE__ */ c.jsx("div", { className: "basis-", children: /* @__PURE__ */ c.jsx(cT, { className: "mr-7 h-7" }) }),
22705
22706
  /* @__PURE__ */ c.jsx("div", { className: "grow", children: /* @__PURE__ */ c.jsx("div", { className: "flex w-full items-center justify-end rounded-full bg-white p-3 px-4 shadow dark:bg-grey-900", children: /* @__PURE__ */ c.jsx(ve, { className: "stroke-[2px] text-blue-600", name: "magnifying-glass", size: "sm" }) }) })
@@ -24157,7 +24158,7 @@ var NE = vu.exports;
24157
24158
  Object.defineProperty(t, "__esModule", {
24158
24159
  value: !0
24159
24160
  });
24160
- var n = xd, r = G(n), o = iv, i = G(o), s = yz, a = G(s), l = Mz, u = G(l), d = xz, f = G(d), g = Iz, m = G(g), h = wz, v = G(h), b = av, A = G(b), y = jz, x = G(y), M = Nz, j = G(M), w = lv, I = G(w), N = wd, D = G(N), S = Dz, C = G(S), E = Cz, k = G(E), O = Sz, W = G(O), B = Pz, Y = G(B), K = Lz, he = G(K), Ie = Tz, Ce = G(Ie), q = kz, se = G(q), _ = eo, ne = G(_), $ = to, te = G($), ye = Xz, Ne = G(ye), ee = Fz, Se = G(ee), le = Vz, xe = G(le), He = Yz, tt = G(He), At = Qz, fn = G(At), yt = Jz, Je = G(yt), we = cv, gn = G(we), Wt = qz, $o = G(Wt), ei = Kz, Aa = G(ei), ya = _z, pn = G(ya), mn = $z, kn = G(mn), ti = eE, Rt = G(ti), ni = tE, Ma = G(ni), xa = nE, ri = G(xa), Ia = sv, oi = G(Ia), wa = rE, ja = G(wa), Na = oE, Ze = G(Na), it = iE, st = G(it), Ut = sE, ct = G(Ut), ft = aE, Mt = G(ft), vn = lE, gt = G(vn), zn = cE, En = G(zn), sr = uE, ar = G(sr), ii = dE, On = G(ii), Hn = fE, ro = G(Hn), jv = gE, Nv = G(jv), Dv = Ko, Cv = G(Dv), Sv = bE, Pv = G(Sv), Lv = AE, Tv = G(Lv), kv = uv, zv = G(kv), Ev = dv, Ov = G(Ev), Hv = yE, Zv = G(Hv), Bv = ME, Wv = G(Bv), Rv = xE, Uv = G(Rv), Gv = IE, Xv = G(Gv), Fv = wE, Vv = G(Fv), Yv = fv, Qv = G(Yv), Jv = jE, qv = G(Jv), Kv = NE, _v = G(Kv), $v = Id, eh = G($v);
24161
+ var n = xd, r = G(n), o = iv, i = G(o), s = yz, a = G(s), l = Mz, u = G(l), d = xz, f = G(d), g = Iz, m = G(g), h = wz, v = G(h), b = av, A = G(b), y = jz, x = G(y), M = Nz, j = G(M), w = lv, I = G(w), N = wd, D = G(N), S = Dz, C = G(S), E = Cz, k = G(E), O = Sz, W = G(O), B = Pz, Y = G(B), K = Lz, he = G(K), Ie = Tz, Ce = G(Ie), q = kz, se = G(q), _ = eo, ne = G(_), $ = to, te = G($), ye = Xz, De = G(ye), ee = Fz, Se = G(ee), le = Vz, xe = G(le), He = Yz, tt = G(He), At = Qz, fn = G(At), yt = Jz, Je = G(yt), we = cv, gn = G(we), Wt = qz, $o = G(Wt), ei = Kz, Aa = G(ei), ya = _z, pn = G(ya), mn = $z, kn = G(mn), ti = eE, Rt = G(ti), ni = tE, Ma = G(ni), xa = nE, ri = G(xa), Ia = sv, oi = G(Ia), wa = rE, ja = G(wa), Na = oE, Ze = G(Na), it = iE, st = G(it), Ut = sE, ct = G(Ut), ft = aE, Mt = G(ft), vn = lE, gt = G(vn), zn = cE, En = G(zn), sr = uE, ar = G(sr), ii = dE, On = G(ii), Hn = fE, ro = G(Hn), jv = gE, Nv = G(jv), Dv = Ko, Cv = G(Dv), Sv = bE, Pv = G(Sv), Lv = AE, Tv = G(Lv), kv = uv, zv = G(kv), Ev = dv, Ov = G(Ev), Hv = yE, Zv = G(Hv), Bv = ME, Wv = G(Bv), Rv = xE, Uv = G(Rv), Gv = IE, Xv = G(Gv), Fv = wE, Vv = G(Fv), Yv = fv, Qv = G(Yv), Jv = jE, qv = G(Jv), Kv = NE, _v = G(Kv), $v = Id, eh = G($v);
24161
24162
  function G(si) {
24162
24163
  return si && si.__esModule ? si : { default: si };
24163
24164
  }
@@ -24184,7 +24185,7 @@ var NE = vu.exports;
24184
24185
  isAscii: se.default,
24185
24186
  isFullWidth: ne.default,
24186
24187
  isHalfWidth: te.default,
24187
- isVariableWidth: Ne.default,
24188
+ isVariableWidth: De.default,
24188
24189
  isMultibyte: Se.default,
24189
24190
  isSurrogatePair: xe.default,
24190
24191
  isInt: tt.default,
@@ -24918,7 +24919,7 @@ function YE(e) {
24918
24919
  return Bi(e, "Owner")[0];
24919
24920
  }
24920
24921
  const QE = () => {
24921
- const { currentUser: e } = De(), { data: { users: t, meta: n, isEnd: r } = { users: [] }, isLoading: o, fetchNextPage: i } = BT(), { data: { invites: s } = { invites: [] }, isLoading: a } = RE(), { data: { roles: l } = {}, isLoading: u } = FE(), d = Z(() => YE(t), [t]), f = Z(() => Bi(t, "Administrator"), [t]), g = Z(() => VE(t, ["Editor", "Super Editor"]), [t]), m = Z(() => Bi(t, "Author"), [t]), h = Z(() => Bi(t, "Contributor"), [t]), v = Z(() => s.map((b) => {
24922
+ const { currentUser: e } = Ne(), { data: { users: t, meta: n, isEnd: r } = { users: [] }, isLoading: o, fetchNextPage: i } = BT(), { data: { invites: s } = { invites: [] }, isLoading: a } = RE(), { data: { roles: l } = {}, isLoading: u } = FE(), d = Z(() => YE(t), [t]), f = Z(() => Bi(t, "Administrator"), [t]), g = Z(() => VE(t, ["Editor", "Super Editor"]), [t]), m = Z(() => Bi(t, "Author"), [t]), h = Z(() => Bi(t, "Contributor"), [t]), v = Z(() => s.map((b) => {
24922
24923
  let A = l == null ? void 0 : l.find((y) => b.role_id === y.id);
24923
24924
  return {
24924
24925
  ...b,
@@ -24940,7 +24941,7 @@ const QE = () => {
24940
24941
  fetchNextPage: i
24941
24942
  };
24942
24943
  }, JE = ({ user: e }) => {
24943
- const { updateRoute: t } = ie(), { currentUser: n } = De(), r = () => {
24944
+ const { updateRoute: t } = ie(), { currentUser: n } = Ne(), r = () => {
24944
24945
  Dr(n) && t({ route: `staff/${e.slug}` });
24945
24946
  };
24946
24947
  return e ? /* @__PURE__ */ c.jsxs("div", { className: T("group flex gap-3", Dr(n) && "cursor-pointer"), "data-testid": "owner-user", onClick: r, children: [
@@ -24957,7 +24958,7 @@ const QE = () => {
24957
24958
  ] })
24958
24959
  ] }) : null;
24959
24960
  }, Di = ({ users: e, groupname: t }) => {
24960
- const { updateRoute: n } = ie(), { currentUser: r } = De(), o = (i) => {
24961
+ const { updateRoute: n } = ie(), { currentUser: r } = Ne(), o = (i) => {
24961
24962
  n({ route: `staff/${i.slug}` });
24962
24963
  };
24963
24964
  return !e || !e.length ? /* @__PURE__ */ c.jsxs(or, { icon: "single-user-block", children: [
@@ -25067,7 +25068,7 @@ const QE = () => {
25067
25068
  invites: u,
25068
25069
  hasNextPage: d,
25069
25070
  fetchNextPage: f
25070
- } = QE(), { updateRoute: g } = ie(), { currentUser: m } = De(), h = () => {
25071
+ } = QE(), { updateRoute: g } = ie(), { currentUser: m } = Ne(), h = () => {
25071
25072
  g("staff/invite");
25072
25073
  }, v = /* @__PURE__ */ c.jsx(J, { className: "mt-[-5px]", color: "clear", label: "Invite people", size: "sm", linkWithPadding: !0, onClick: () => {
25073
25074
  h();
@@ -25108,7 +25109,7 @@ const QE = () => {
25108
25109
  contents: /* @__PURE__ */ c.jsx(KE, { users: u }),
25109
25110
  counter: u.length ? u.length : void 0
25110
25111
  }
25111
- ], { settings: w } = De(), I = hs(w, "require_email_mfa") || !1, N = JSON.parse(hs(w, "labs") || "{}"), { mutateAsync: D } = Yo(), S = $e();
25112
+ ], { settings: w } = Ne(), I = hs(w, "require_email_mfa") || !1, N = JSON.parse(hs(w, "labs") || "{}"), { mutateAsync: D } = Yo(), S = $e();
25112
25113
  return /* @__PURE__ */ c.jsxs(
25113
25114
  ce,
25114
25115
  {
@@ -25479,7 +25480,7 @@ const ba = "OffersResponseType", mv = dt({
25479
25480
  updatedPriceWithCurrency: f
25480
25481
  };
25481
25482
  }, bv = ({ offerCode: e }) => {
25482
- const [t, n] = P(!1), { siteData: r } = De(), o = (i) => {
25483
+ const [t, n] = P(!1), { siteData: r } = Ne(), o = (i) => {
25483
25484
  i == null || i.stopPropagation();
25484
25485
  const s = `${ET(r)}${e}`;
25485
25486
  navigator.clipboard.writeText(s), n(!0), setTimeout(() => n(!1), 2e3);
@@ -25670,7 +25671,7 @@ const ba = "OffersResponseType", mv = dt({
25670
25671
  );
25671
25672
  }, lO = ({ offerTitle: e, tier: t, cadence: n, redemptions: r, type: o, amount: i, currency: s, offerId: a, offerCode: l, goToOfferEdit: u }) => {
25672
25673
  const { discountOffer: d } = hv(o, i, n, s || "USD", t);
25673
- return /* @__PURE__ */ c.jsxs("div", { className: "group flex h-full cursor-pointer flex-col justify-between gap-4 break-words rounded-sm border border-transparent bg-grey-100 p-5 transition-all hover:border-grey-100 hover:bg-grey-75 hover:shadow-sm dark:bg-grey-950 dark:hover:border-grey-800 min-[900px]:min-h-[187px]", onClick: () => u(a), children: [
25674
+ return /* @__PURE__ */ c.jsxs("div", { className: "group flex h-full cursor-pointer flex-col justify-between gap-4 break-words rounded-sm border border-transparent bg-grey-100 p-5 transition-all hover:border-grey-100 hover:bg-grey-75 hover:shadow-sm min-[900px]:min-h-[187px] dark:bg-grey-950 dark:hover:border-grey-800", onClick: () => u(a), children: [
25674
25675
  /* @__PURE__ */ c.jsx("span", { className: "text-[1.65rem] font-bold leading-tight tracking-tight text-black dark:text-white", children: e }),
25675
25676
  /* @__PURE__ */ c.jsxs("div", { className: "flex flex-col", children: [
25676
25677
  /* @__PURE__ */ c.jsx("span", { className: "text-sm font-semibold uppercase", children: d }),
@@ -25689,7 +25690,7 @@ const ba = "OffersResponseType", mv = dt({
25689
25690
  ] })
25690
25691
  ] });
25691
25692
  }, cO = ({ keywords: e }) => {
25692
- const { updateRoute: t } = ie(), { settings: n, config: r } = De(), { data: { offers: o = [] } = {} } = mv(), { data: { tiers: i } = {} } = ha(), s = pv(i || []), a = o.map((b) => ({ ...b, tier: s.find((A) => A.id === b.tier.id) })).filter((b) => b.status === "active" && !!b.tier);
25693
+ const { updateRoute: t } = ie(), { settings: n, config: r } = Ne(), { data: { offers: o = [] } = {} } = mv(), { data: { tiers: i } = {} } = ha(), s = pv(i || []), a = o.map((b) => ({ ...b, tier: s.find((A) => A.id === b.tier.id) })).filter((b) => b.status === "active" && !!b.tier);
25693
25694
  a.sort((b, A) => {
25694
25695
  const y = b.created_at ? new Date(b.created_at) : /* @__PURE__ */ new Date(0);
25695
25696
  return (A.created_at ? new Date(A.created_at) : /* @__PURE__ */ new Date(0)).getTime() - y.getTime();
@@ -25754,7 +25755,7 @@ const ba = "OffersResponseType", mv = dt({
25754
25755
  if (!o)
25755
25756
  return /* @__PURE__ */ c.jsx("div", { className: "relative h-6 w-6 shrink-0 rounded-sm" });
25756
25757
  const a = r ? "This is a Ghost site that supports one-click subscribe" : "";
25757
- return /* @__PURE__ */ c.jsxs("div", { className: "relative h-6 w-6 shrink-0 rounded-sm dark:group-hover/table-row:bg-grey-950", title: a, children: [
25758
+ return /* @__PURE__ */ c.jsxs("div", { className: "dark:group-hover/table-row:bg-grey-950 relative h-6 w-6 shrink-0 rounded-sm", title: a, children: [
25758
25759
  /* @__PURE__ */ c.jsx("img", { alt: e, className: "h-6 w-6 rounded-sm", src: o, onError: s }),
25759
25760
  r && /* @__PURE__ */ c.jsx("img", { alt: "Ghost Logo", className: "absolute bottom-[-3px] right-[-3px] h-[14px] w-[14px]", src: dO })
25760
25761
  ] });
@@ -26259,7 +26260,7 @@ const ba = "OffersResponseType", mv = dt({
26259
26260
  recommendations: ["growth", "recommendations", "recommend", "blogroll"],
26260
26261
  offers: ["growth", "offers", "discounts", "coupons", "promotions"]
26261
26262
  }, PO = () => {
26262
- const { config: e, settings: t } = De(), n = Nr(t || [], e || {});
26263
+ const { config: e, settings: t } = Ne(), n = Nr(t || [], e || {});
26263
26264
  return /* @__PURE__ */ c.jsxs($r, { keywords: Object.values(Pt).flat(), title: "Growth", children: [
26264
26265
  /* @__PURE__ */ c.jsx(NO, { keywords: Pt.recommendations }),
26265
26266
  /* @__PURE__ */ c.jsx(eO, { keywords: Pt.embedSignupForm }),
@@ -26544,7 +26545,7 @@ const ba = "OffersResponseType", mv = dt({
26544
26545
  }
26545
26546
  );
26546
26547
  }, EO = ge(zO, "Analytics"), OO = ({ keywords: e }) => {
26547
- const { updateRoute: t } = ie(), { settings: n } = De(), [r] = je(n, ["members_signup_access"]), o = () => {
26548
+ const { updateRoute: t } = ie(), { settings: n } = Ne(), [r] = je(n, ["members_signup_access"]), o = () => {
26548
26549
  t("portal/edit");
26549
26550
  };
26550
26551
  return /* @__PURE__ */ c.jsx(
@@ -26614,7 +26615,7 @@ const ba = "OffersResponseType", mv = dt({
26614
26615
  ] }) })
26615
26616
  ] });
26616
26617
  }, xv = T(
26617
- "group/tiercard flex cursor-pointer flex-col items-start justify-between gap-4 self-stretch rounded-sm border border-transparent bg-grey-100 p-4 transition-all hover:border-grey-100 hover:bg-grey-75 hover:shadow-sm dark:bg-grey-950 dark:hover:border-grey-800 min-[900px]:min-h-[200px]"
26618
+ "group/tiercard flex cursor-pointer flex-col items-start justify-between gap-4 self-stretch rounded-sm border border-transparent bg-grey-100 p-4 transition-all hover:border-grey-100 hover:bg-grey-75 hover:shadow-sm min-[900px]:min-h-[200px] dark:bg-grey-950 dark:hover:border-grey-800"
26618
26619
  ), WO = ({ tier: e }) => {
26619
26620
  const { updateRoute: t } = ie(), n = (e == null ? void 0 : e.currency) || "USD", r = n ? Po(n) : "$";
26620
26621
  return /* @__PURE__ */ c.jsx("div", { className: xv, "data-testid": "tier-card", "data-tier": e.slug, children: /* @__PURE__ */ c.jsxs("div", { className: "w-full grow", onClick: () => {
@@ -26656,7 +26657,7 @@ const ba = "OffersResponseType", mv = dt({
26656
26657
  /* @__PURE__ */ c.jsx("span", { className: "inline-flex h-2 w-2 rounded-full bg-green transition-all group-hover:bg-[#625BF6]" }),
26657
26658
  /* @__PURE__ */ c.jsx("span", { className: "ml-2", children: "Connected to Stripe" })
26658
26659
  ] })), RO = ({ keywords: e }) => {
26659
- const [t, n] = P("active-tiers"), { settings: r, config: o } = De(), { data: { tiers: i, meta: s, isEnd: a } = {}, fetchNextPage: l } = ha(), u = tO(i || []), d = nO(i || []), { updateRoute: f } = ie(), g = () => {
26660
+ const [t, n] = P("active-tiers"), { settings: r, config: o } = Ne(), { data: { tiers: i, meta: s, isEnd: a } = {}, fetchNextPage: l } = ha(), u = tO(i || []), d = nO(i || []), { updateRoute: f } = ie(), g = () => {
26660
26661
  f("stripe-connect");
26661
26662
  }, m = (b) => [...b].sort((A, y) => (A.monthly_price ?? 0) - (y.monthly_price ?? 0)), h = [
26662
26663
  {
@@ -26929,7 +26930,7 @@ const JO = ({ keywords: e }) => {
26929
26930
  (A = s.current) == null || A.removeEventListener("keydown", v);
26930
26931
  };
26931
26932
  }, [e]);
26932
- const { settings: l, config: u } = De(), [d] = je(l, ["editor_default_email_recipients"]), f = Nr(l || [], u || {}), g = (v) => {
26933
+ const { settings: l, config: u } = Ne(), [d] = je(l, ["editor_default_email_recipients"]), f = Nr(l || [], u || {}), g = (v) => {
26933
26934
  v && (t(""), o(!1), i(v.currentTarget.id));
26934
26935
  }, m = (v) => {
26935
26936
  var b;
@@ -26938,13 +26939,13 @@ const JO = ({ keywords: e }) => {
26938
26939
  "hidden pt-10 tablet:!visible tablet:!block"
26939
26940
  );
26940
26941
  return /* @__PURE__ */ c.jsxs("div", { className: "ml-auto flex w-full flex-col pt-0 tablet:max-w-[240px]", "data-testid": "sidebar", children: [
26941
- /* @__PURE__ */ c.jsx("div", { className: "sticky top-0 flex content-stretch items-end dark:bg-grey-975 tablet:h-20 tablet:bg-grey-50 dark:tablet:bg-[#101114] xl:h-20", children: /* @__PURE__ */ c.jsxs("div", { className: "relative w-full", children: [
26942
+ /* @__PURE__ */ c.jsx("div", { className: "sticky top-0 flex content-stretch items-end tablet:h-20 tablet:bg-grey-50 xl:h-20 dark:bg-grey-975 dark:tablet:bg-[#101114]", children: /* @__PURE__ */ c.jsxs("div", { className: "relative w-full", children: [
26942
26943
  /* @__PURE__ */ c.jsx(ve, { className: "absolute left-3 top-3 z-10", colorClass: "text-grey-500", name: "magnifying-glass", size: "sm" }),
26943
26944
  /* @__PURE__ */ c.jsx(
26944
26945
  Ye,
26945
26946
  {
26946
26947
  autoComplete: "off",
26947
- className: "mr-12 flex h-10 w-full items-center rounded-lg border border-transparent bg-white px-[33px] py-1.5 text-[14px] shadow-[0_0_1px_rgba(21,23,26,0.25),0_1px_3px_rgba(0,0,0,0.03),0_8px_10px_-12px_rgba(0,0,0,.1)] transition-colors hover:shadow-sm focus:border-green focus:bg-white focus:shadow-[0_0_0_2px_rgba(48,207,67,0.25)] focus:outline-2 dark:border-transparent dark:bg-grey-925 dark:text-white dark:placeholder:text-grey-800 dark:focus:border-green dark:focus:bg-grey-950 tablet:mr-0",
26948
+ className: "mr-12 flex h-10 w-full items-center rounded-lg border border-transparent bg-white px-[33px] py-1.5 text-[14px] shadow-[0_0_1px_rgba(21,23,26,0.25),0_1px_3px_rgba(0,0,0,0.03),0_8px_10px_-12px_rgba(0,0,0,.1)] transition-colors hover:shadow-sm focus:border-green focus:bg-white focus:shadow-[0_0_0_2px_rgba(48,207,67,0.25)] focus:outline-2 tablet:mr-0 dark:border-transparent dark:bg-grey-925 dark:text-white dark:placeholder:text-grey-800 dark:focus:border-green dark:focus:bg-grey-950",
26948
26949
  containerClassName: "w-100",
26949
26950
  inputRef: s,
26950
26951
  placeholder: "Search settings",
@@ -26959,7 +26960,7 @@ const JO = ({ keywords: e }) => {
26959
26960
  e ? /* @__PURE__ */ c.jsx(J, { className: "absolute right-14 top-3 p-1 tablet:right-3", icon: "close", iconColorClass: "text-grey-700 !w-[10px] !h-[10px]", size: "sm", unstyled: !0, onClick: () => {
26960
26961
  var v;
26961
26962
  t(""), (v = s.current) == null || v.focus();
26962
- } }) : /* @__PURE__ */ c.jsx("div", { className: "absolute -right-1/2 top-[9px] hidden rounded border border-grey-400 bg-white px-1.5 py-0.5 text-2xs font-semibold uppercase tracking-wider text-grey-600 shadow-[0px_1px_#CED4D9] dark:border-grey-800 dark:bg-grey-900 dark:text-grey-500 dark:shadow-[0px_1px_#626D79] tablet:!visible tablet:right-3 tablet:!block", children: "/" })
26963
+ } }) : /* @__PURE__ */ c.jsx("div", { className: "absolute -right-1/2 top-[9px] hidden rounded border border-grey-400 bg-white px-1.5 py-0.5 text-2xs font-semibold uppercase tracking-wider text-grey-600 shadow-[0px_1px_#CED4D9] tablet:!visible tablet:right-3 tablet:!block dark:border-grey-800 dark:bg-grey-900 dark:text-grey-500 dark:shadow-[0px_1px_#626D79]", children: "/" })
26963
26964
  ] }) }),
26964
26965
  /* @__PURE__ */ c.jsxs("nav", { className: h, id: "admin-x-settings-sidebar", children: [
26965
26966
  r && /* @__PURE__ */ c.jsxs("div", { className: "ml-2 text-base text-grey-700", children: [
@@ -27024,9 +27025,9 @@ const JO = ({ keywords: e }) => {
27024
27025
  ] });
27025
27026
  }, Bf = ({ children: e }) => /* @__PURE__ */ c.jsxs(c.Fragment, { children: [
27026
27027
  /* @__PURE__ */ c.jsx("div", { className: "fixed right-0 top-2 z-50 flex justify-end bg-transparent p-8 tablet:fixed tablet:top-0 tablet:px-8", id: "done-button-container", children: /* @__PURE__ */ c.jsx(RT, {}) }),
27027
- /* @__PURE__ */ c.jsx("div", { className: "w-full dark:bg-grey-975 tablet:fixed tablet:left-0 tablet:top-0 tablet:flex tablet:h-full", id: "admin-x-settings-content", children: e })
27028
+ /* @__PURE__ */ c.jsx("div", { className: "w-full tablet:fixed tablet:left-0 tablet:top-0 tablet:flex tablet:h-full dark:bg-grey-975", id: "admin-x-settings-content", children: e })
27028
27029
  ] }), sH = () => {
27029
- const { currentUser: e } = De(), { route: t, updateRoute: n, loadingModal: r } = ie(), { isDirty: o } = ws(), i = Vm("ActivityPub"), s = (a) => {
27030
+ const { currentUser: e } = Ne(), { route: t, updateRoute: n, loadingModal: r } = ie(), { isDirty: o } = ws(), i = Vm("ActivityPub"), s = (a) => {
27030
27031
  window.location.hash = a;
27031
27032
  };
27032
27033
  return L(() => {
@@ -27047,8 +27048,8 @@ const JO = ({ keywords: e }) => {
27047
27048
  /* @__PURE__ */ c.jsx(gv, { highlight: !1, keywords: [] })
27048
27049
  ] }) }) : /* @__PURE__ */ c.jsxs(Bf, { children: [
27049
27050
  r && /* @__PURE__ */ c.jsx("div", { className: `fixed inset-0 z-40 h-[calc(100vh-55px)] w-[100vw] tablet:h-[100vh] ${U2}` }),
27050
- /* @__PURE__ */ c.jsx("div", { className: "no-scrollbar fixed inset-x-0 top-0 z-[35] flex-1 basis-[320px] bg-white p-8 dark:bg-grey-975 tablet:relative tablet:inset-x-auto tablet:top-auto tablet:h-full tablet:overflow-y-scroll tablet:bg-grey-50 tablet:py-0 dark:tablet:bg-[#101114]", id: "admin-x-settings-sidebar-scroller", children: /* @__PURE__ */ c.jsx("div", { className: "relative w-full", children: /* @__PURE__ */ c.jsx(iH, {}) }) }),
27051
- /* @__PURE__ */ c.jsx("div", { className: "relative h-full flex-1 overflow-y-scroll bg-white pt-12 dark:bg-grey-975 tablet:basis-[800px] dark:tablet:bg-black", id: "admin-x-settings-scroller", children: /* @__PURE__ */ c.jsx(rH, {}) })
27051
+ /* @__PURE__ */ c.jsx("div", { className: "no-scrollbar fixed inset-x-0 top-0 z-[35] flex-1 basis-[320px] bg-white p-8 tablet:relative tablet:inset-x-auto tablet:top-auto tablet:h-full tablet:overflow-y-scroll tablet:bg-grey-50 tablet:py-0 dark:bg-grey-975 dark:tablet:bg-[#101114]", id: "admin-x-settings-sidebar-scroller", children: /* @__PURE__ */ c.jsx("div", { className: "relative w-full", children: /* @__PURE__ */ c.jsx(iH, {}) }) }),
27052
+ /* @__PURE__ */ c.jsx("div", { className: "relative h-full flex-1 overflow-y-scroll bg-white pt-12 tablet:basis-[800px] dark:bg-grey-975 dark:tablet:bg-black", id: "admin-x-settings-scroller", children: /* @__PURE__ */ c.jsx(rH, {}) })
27052
27053
  ] }) : null;
27053
27054
  }, aH = {
27054
27055
  "design/change-theme": "DesignAndThemeModal",
@@ -27082,7 +27083,7 @@ const JO = ({ keywords: e }) => {
27082
27083
  "offers/edit/:id": "OffersContainerModal",
27083
27084
  "offers/new": "OffersContainerModal",
27084
27085
  about: "AboutModal"
27085
- }, lH = () => import("./modals-d9ca60c5.mjs"), cH = () => {
27086
+ }, lH = () => import("./modals-6bc20529.mjs"), cH = () => {
27086
27087
  const { updateNavigatedSection: e, scrollToSection: t } = pa(), { route: n } = ie();
27087
27088
  return JT((r, o) => {
27088
27089
  r === o && t(r.split("/")[0]);
@@ -27123,7 +27124,7 @@ export {
27123
27124
  md as W,
27124
27125
  rh as X,
27125
27126
  ie as Y,
27126
- De as Z,
27127
+ Ne as Z,
27127
27128
  kH as _,
27128
27129
  Z as a,
27129
27130
  Fr as a$,
@@ -27301,4 +27302,4 @@ export {
27301
27302
  Un as y,
27302
27303
  Eo as z
27303
27304
  };
27304
- //# sourceMappingURL=index-f744cab7.mjs.map
27305
+ //# sourceMappingURL=index-4ce2fcd1.mjs.map