@jant/core 0.3.27 → 0.3.28

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 (313) hide show
  1. package/dist/client/client.css +1 -0
  2. package/dist/client/client.js +31561 -0
  3. package/dist/index.js +15209 -15
  4. package/package.json +21 -15
  5. package/src/__tests__/helpers/app.ts +19 -3
  6. package/src/__tests__/helpers/db.ts +44 -0
  7. package/src/__tests__/helpers/lingui-core-macro-mock.ts +33 -0
  8. package/src/app.tsx +111 -174
  9. package/src/client.ts +13 -0
  10. package/src/db/migrations/0007_post_collections_m2m.sql +94 -0
  11. package/src/db/migrations/0008_add_collection_dividers.sql +8 -0
  12. package/src/db/migrations/0009_drop_collection_show_divider.sql +2 -0
  13. package/src/db/migrations/0010_add_performance_indexes.sql +16 -0
  14. package/src/db/schema.ts +24 -4
  15. package/src/i18n/locales/en.po +810 -385
  16. package/src/i18n/locales/en.ts +1 -1
  17. package/src/i18n/locales/zh-Hans.po +733 -522
  18. package/src/i18n/locales/zh-Hans.ts +1 -1
  19. package/src/i18n/locales/zh-Hant.po +733 -522
  20. package/src/i18n/locales/zh-Hant.ts +1 -1
  21. package/src/i18n/middleware.ts +7 -11
  22. package/src/index.ts +1 -1
  23. package/src/lib/__tests__/icons.test.ts +178 -0
  24. package/src/lib/__tests__/resolve-config.test.ts +184 -0
  25. package/src/lib/__tests__/schemas.test.ts +12 -6
  26. package/src/lib/__tests__/theme.test.ts +62 -0
  27. package/src/lib/__tests__/timezones.test.ts +1 -1
  28. package/src/lib/__tests__/url.test.ts +12 -0
  29. package/src/lib/__tests__/view.test.ts +1 -5
  30. package/src/lib/avatar-upload.ts +18 -10
  31. package/src/lib/collection-form-bridge.ts +52 -0
  32. package/src/lib/collections-reorder.ts +28 -0
  33. package/src/lib/compose-bridge.ts +251 -0
  34. package/src/lib/errors.ts +116 -0
  35. package/src/lib/excerpt.ts +1 -1
  36. package/src/lib/favicon.ts +3 -5
  37. package/src/lib/html.ts +22 -0
  38. package/src/lib/icon-catalog.ts +181 -0
  39. package/src/lib/icons.ts +202 -0
  40. package/src/lib/navigation.ts +18 -33
  41. package/src/lib/pagination.ts +3 -2
  42. package/src/lib/post-form-bridge.ts +136 -0
  43. package/src/lib/render.tsx +11 -4
  44. package/src/lib/resolve-config.ts +157 -0
  45. package/src/lib/schemas.ts +76 -12
  46. package/src/lib/settings-bridge.ts +139 -0
  47. package/src/lib/storage.ts +37 -16
  48. package/src/lib/theme.ts +5 -7
  49. package/src/lib/timeline.ts +4 -8
  50. package/src/lib/toast.ts +134 -0
  51. package/src/lib/upload.ts +71 -0
  52. package/src/lib/url.ts +9 -1
  53. package/src/lib/version.ts +16 -0
  54. package/src/lib/view.ts +9 -10
  55. package/src/middleware/__tests__/auth.test.ts +6 -28
  56. package/src/middleware/__tests__/onboarding.test.ts +1 -1
  57. package/src/middleware/auth.ts +6 -12
  58. package/src/middleware/config.ts +51 -0
  59. package/src/middleware/error-handler.ts +56 -0
  60. package/src/middleware/onboarding.ts +1 -1
  61. package/src/preset.css +6 -0
  62. package/src/routes/__tests__/compose.test.ts +104 -17
  63. package/src/routes/api/__tests__/collections.test.ts +93 -2
  64. package/src/routes/api/__tests__/posts.test.ts +2 -1
  65. package/src/routes/api/__tests__/settings.test.ts +1 -1
  66. package/src/routes/api/collections.ts +64 -68
  67. package/src/routes/api/nav-items.ts +21 -59
  68. package/src/routes/api/pages.ts +18 -46
  69. package/src/routes/api/posts.ts +64 -86
  70. package/src/routes/api/search.ts +6 -4
  71. package/src/routes/api/settings.ts +8 -24
  72. package/src/routes/api/upload.ts +55 -53
  73. package/src/routes/auth/__tests__/setup.test.ts +118 -0
  74. package/src/routes/auth/reset.tsx +17 -66
  75. package/src/routes/auth/setup.tsx +67 -11
  76. package/src/routes/auth/signin.tsx +44 -8
  77. package/src/routes/compose.tsx +194 -0
  78. package/src/routes/dash/__tests__/font-theme.test.ts +110 -0
  79. package/src/routes/dash/__tests__/pages.test.ts +2 -2
  80. package/src/routes/dash/__tests__/settings-avatar.test.ts +23 -12
  81. package/src/routes/dash/appearance.tsx +173 -0
  82. package/src/routes/dash/collections.tsx +80 -14
  83. package/src/routes/dash/index.tsx +12 -14
  84. package/src/routes/dash/media.tsx +46 -49
  85. package/src/routes/dash/pages.tsx +85 -37
  86. package/src/routes/dash/posts.tsx +60 -23
  87. package/src/routes/dash/redirects.tsx +43 -33
  88. package/src/routes/dash/settings.tsx +234 -214
  89. package/src/routes/feed/__tests__/rss.test.ts +7 -3
  90. package/src/routes/feed/rss.ts +11 -16
  91. package/src/routes/feed/sitemap.ts +15 -9
  92. package/src/routes/pages/__tests__/collections.test.ts +9 -8
  93. package/src/routes/pages/archive.tsx +2 -2
  94. package/src/routes/pages/collection.tsx +76 -9
  95. package/src/routes/pages/collections.tsx +3 -1
  96. package/src/routes/pages/featured.tsx +2 -2
  97. package/src/routes/pages/home.tsx +3 -3
  98. package/src/routes/pages/latest.tsx +2 -2
  99. package/src/routes/pages/page.tsx +2 -2
  100. package/src/routes/pages/post.tsx +2 -2
  101. package/src/routes/pages/search.tsx +2 -2
  102. package/src/services/__tests__/collection.test.ts +324 -34
  103. package/src/services/__tests__/media.test.ts +1 -1
  104. package/src/services/__tests__/page.test.ts +116 -1
  105. package/src/services/auth.ts +88 -0
  106. package/src/services/collection.ts +169 -30
  107. package/src/services/index.ts +8 -3
  108. package/src/services/media.ts +39 -12
  109. package/src/services/navigation.ts +17 -5
  110. package/src/services/page.ts +24 -4
  111. package/src/services/post.ts +87 -19
  112. package/src/services/search.ts +0 -1
  113. package/src/services/settings.ts +21 -13
  114. package/src/style.css +3 -0
  115. package/src/styles/components.css +42 -1
  116. package/src/styles/tokens.css +4 -0
  117. package/src/styles/ui.css +902 -73
  118. package/src/types/app-context.ts +25 -0
  119. package/src/types/bindings.ts +1 -0
  120. package/src/types/config.ts +60 -23
  121. package/src/types/entities.ts +12 -2
  122. package/src/types/lingui-react-macro.d.ts +3 -3
  123. package/src/types/operations.ts +2 -4
  124. package/src/types/views.ts +1 -3
  125. package/src/ui/__tests__/font-themes.test.ts +27 -8
  126. package/src/ui/color-themes.ts +1 -1
  127. package/src/ui/components/__tests__/jant-collection-form.test.ts +153 -0
  128. package/src/ui/components/__tests__/jant-compose-dialog.test.ts +512 -0
  129. package/src/ui/components/__tests__/jant-compose-editor.test.ts +272 -0
  130. package/src/ui/components/__tests__/jant-post-form.test.ts +172 -0
  131. package/src/ui/components/__tests__/jant-settings-avatar.test.ts +235 -0
  132. package/src/ui/components/__tests__/jant-settings-general.test.ts +319 -0
  133. package/src/ui/components/collection-types.ts +45 -0
  134. package/src/ui/components/compose-types.ts +75 -0
  135. package/src/ui/components/jant-collection-form.ts +512 -0
  136. package/src/ui/components/jant-compose-dialog.ts +494 -0
  137. package/src/ui/components/jant-compose-editor.ts +799 -0
  138. package/src/ui/components/jant-post-form.ts +290 -0
  139. package/src/ui/components/jant-settings-avatar.ts +231 -0
  140. package/src/ui/components/jant-settings-general.ts +436 -0
  141. package/src/ui/components/post-form-template.ts +260 -0
  142. package/src/ui/components/post-form-types.ts +87 -0
  143. package/src/ui/components/settings-types.ts +62 -0
  144. package/src/ui/compose/ComposeDialog.tsx +141 -385
  145. package/src/ui/compose/ComposePrompt.tsx +3 -3
  146. package/src/ui/dash/PostList.tsx +55 -61
  147. package/src/ui/dash/appearance/AdvancedContent.tsx +80 -0
  148. package/src/ui/dash/appearance/AppearanceNav.tsx +56 -0
  149. package/src/ui/dash/appearance/ColorThemeContent.tsx +129 -0
  150. package/src/ui/dash/appearance/FontThemeContent.tsx +98 -0
  151. package/src/ui/dash/collections/CollectionForm.tsx +130 -117
  152. package/src/ui/dash/collections/CollectionsListContent.tsx +102 -41
  153. package/src/ui/dash/collections/IconPickerGrid.tsx +50 -0
  154. package/src/ui/dash/collections/ViewCollectionContent.tsx +14 -3
  155. package/src/ui/dash/index.ts +1 -1
  156. package/src/ui/dash/posts/PostForm.tsx +248 -0
  157. package/src/ui/dash/settings/AccountContent.tsx +69 -80
  158. package/src/ui/dash/settings/GeneralContent.tsx +159 -478
  159. package/src/ui/dash/settings/SettingsNav.tsx +4 -4
  160. package/src/ui/font-themes.ts +115 -32
  161. package/src/ui/layouts/BaseLayout.tsx +49 -19
  162. package/src/ui/layouts/DashLayout.tsx +14 -9
  163. package/src/ui/layouts/SiteLayout.tsx +38 -23
  164. package/src/ui/pages/CollectionPage.tsx +12 -2
  165. package/src/ui/pages/CollectionsPage.tsx +27 -27
  166. package/src/ui/pages/HomePage.tsx +15 -6
  167. package/src/ui/pages/SearchPage.tsx +1 -2
  168. package/src/ui/shared/CollectionsSidebar.tsx +59 -0
  169. package/src/ui/shared/Pagination.tsx +2 -2
  170. package/dist/app.js +0 -267
  171. package/dist/auth.js +0 -39
  172. package/dist/client.js +0 -13
  173. package/dist/db/index.js +0 -10
  174. package/dist/db/schema.js +0 -224
  175. package/dist/i18n/Trans.js +0 -24
  176. package/dist/i18n/context.js +0 -58
  177. package/dist/i18n/detect.js +0 -26
  178. package/dist/i18n/i18n.js +0 -49
  179. package/dist/i18n/index.js +0 -44
  180. package/dist/i18n/locales/en.js +0 -1
  181. package/dist/i18n/locales/zh-Hans.js +0 -1
  182. package/dist/i18n/locales/zh-Hant.js +0 -1
  183. package/dist/i18n/locales.js +0 -13
  184. package/dist/i18n/middleware.js +0 -30
  185. package/dist/lib/avatar-upload.js +0 -134
  186. package/dist/lib/config.js +0 -143
  187. package/dist/lib/constants.js +0 -50
  188. package/dist/lib/excerpt.js +0 -76
  189. package/dist/lib/favicon.js +0 -102
  190. package/dist/lib/feed.js +0 -123
  191. package/dist/lib/image-processor.js +0 -187
  192. package/dist/lib/image.js +0 -97
  193. package/dist/lib/index.js +0 -7
  194. package/dist/lib/markdown.js +0 -83
  195. package/dist/lib/media-helpers.js +0 -49
  196. package/dist/lib/media-upload.js +0 -104
  197. package/dist/lib/nav-reorder.js +0 -27
  198. package/dist/lib/navigation.js +0 -79
  199. package/dist/lib/pagination.js +0 -44
  200. package/dist/lib/render.js +0 -53
  201. package/dist/lib/schemas.js +0 -174
  202. package/dist/lib/sqid.js +0 -72
  203. package/dist/lib/sse.js +0 -218
  204. package/dist/lib/storage.js +0 -164
  205. package/dist/lib/theme.js +0 -65
  206. package/dist/lib/time.js +0 -159
  207. package/dist/lib/timeline.js +0 -95
  208. package/dist/lib/timezones.js +0 -388
  209. package/dist/lib/url.js +0 -89
  210. package/dist/lib/view.js +0 -217
  211. package/dist/middleware/auth.js +0 -52
  212. package/dist/middleware/onboarding.js +0 -41
  213. package/dist/routes/api/collections.js +0 -124
  214. package/dist/routes/api/nav-items.js +0 -104
  215. package/dist/routes/api/pages.js +0 -91
  216. package/dist/routes/api/posts.js +0 -218
  217. package/dist/routes/api/search.js +0 -48
  218. package/dist/routes/api/settings.js +0 -68
  219. package/dist/routes/api/upload.js +0 -246
  220. package/dist/routes/auth/reset.js +0 -221
  221. package/dist/routes/auth/setup.js +0 -194
  222. package/dist/routes/auth/signin.js +0 -176
  223. package/dist/routes/compose.js +0 -48
  224. package/dist/routes/dash/collections.js +0 -115
  225. package/dist/routes/dash/index.js +0 -118
  226. package/dist/routes/dash/media.js +0 -106
  227. package/dist/routes/dash/pages.js +0 -294
  228. package/dist/routes/dash/posts.js +0 -244
  229. package/dist/routes/dash/redirects.js +0 -257
  230. package/dist/routes/dash/settings.js +0 -379
  231. package/dist/routes/feed/rss.js +0 -62
  232. package/dist/routes/feed/sitemap.js +0 -49
  233. package/dist/routes/pages/archive.js +0 -62
  234. package/dist/routes/pages/collection.js +0 -34
  235. package/dist/routes/pages/collections.js +0 -28
  236. package/dist/routes/pages/featured.js +0 -36
  237. package/dist/routes/pages/home.js +0 -64
  238. package/dist/routes/pages/latest.js +0 -45
  239. package/dist/routes/pages/page.js +0 -68
  240. package/dist/routes/pages/post.js +0 -44
  241. package/dist/routes/pages/search.js +0 -54
  242. package/dist/services/collection.js +0 -109
  243. package/dist/services/index.js +0 -24
  244. package/dist/services/media.js +0 -117
  245. package/dist/services/navigation.js +0 -91
  246. package/dist/services/page.js +0 -84
  247. package/dist/services/post.js +0 -229
  248. package/dist/services/redirect.js +0 -48
  249. package/dist/services/search.js +0 -67
  250. package/dist/services/settings.js +0 -68
  251. package/dist/types/bindings.js +0 -3
  252. package/dist/types/config.js +0 -147
  253. package/dist/types/constants.js +0 -27
  254. package/dist/types/entities.js +0 -3
  255. package/dist/types/lingui-react-macro.d.js +0 -9
  256. package/dist/types/operations.js +0 -3
  257. package/dist/types/props.js +0 -3
  258. package/dist/types/sortablejs.d.js +0 -5
  259. package/dist/types/views.js +0 -5
  260. package/dist/types.js +0 -11
  261. package/dist/ui/color-themes.js +0 -268
  262. package/dist/ui/compose/ComposeDialog.js +0 -467
  263. package/dist/ui/compose/ComposePrompt.js +0 -55
  264. package/dist/ui/dash/ActionButtons.js +0 -46
  265. package/dist/ui/dash/CrudPageHeader.js +0 -22
  266. package/dist/ui/dash/DangerZone.js +0 -36
  267. package/dist/ui/dash/FormatBadge.js +0 -27
  268. package/dist/ui/dash/ListItemRow.js +0 -21
  269. package/dist/ui/dash/PageForm.js +0 -195
  270. package/dist/ui/dash/PostForm.js +0 -395
  271. package/dist/ui/dash/PostList.js +0 -83
  272. package/dist/ui/dash/StatusBadge.js +0 -46
  273. package/dist/ui/dash/collections/CollectionForm.js +0 -152
  274. package/dist/ui/dash/collections/CollectionsListContent.js +0 -68
  275. package/dist/ui/dash/collections/ViewCollectionContent.js +0 -96
  276. package/dist/ui/dash/index.js +0 -10
  277. package/dist/ui/dash/media/MediaListContent.js +0 -166
  278. package/dist/ui/dash/media/ViewMediaContent.js +0 -212
  279. package/dist/ui/dash/pages/LinkFormContent.js +0 -130
  280. package/dist/ui/dash/pages/UnifiedPagesContent.js +0 -193
  281. package/dist/ui/dash/settings/AccountContent.js +0 -209
  282. package/dist/ui/dash/settings/AppearanceContent.js +0 -259
  283. package/dist/ui/dash/settings/GeneralContent.js +0 -536
  284. package/dist/ui/dash/settings/SettingsNav.js +0 -41
  285. package/dist/ui/feed/LinkCard.js +0 -72
  286. package/dist/ui/feed/NoteCard.js +0 -58
  287. package/dist/ui/feed/QuoteCard.js +0 -63
  288. package/dist/ui/feed/ThreadPreview.js +0 -48
  289. package/dist/ui/feed/TimelineFeed.js +0 -41
  290. package/dist/ui/feed/TimelineItem.js +0 -27
  291. package/dist/ui/font-themes.js +0 -36
  292. package/dist/ui/layouts/BaseLayout.js +0 -153
  293. package/dist/ui/layouts/DashLayout.js +0 -141
  294. package/dist/ui/layouts/SiteLayout.js +0 -169
  295. package/dist/ui/pages/ArchivePage.js +0 -143
  296. package/dist/ui/pages/CollectionPage.js +0 -70
  297. package/dist/ui/pages/CollectionsPage.js +0 -76
  298. package/dist/ui/pages/FeaturedPage.js +0 -24
  299. package/dist/ui/pages/HomePage.js +0 -24
  300. package/dist/ui/pages/PostPage.js +0 -55
  301. package/dist/ui/pages/SearchPage.js +0 -122
  302. package/dist/ui/pages/SinglePage.js +0 -23
  303. package/dist/ui/shared/EmptyState.js +0 -27
  304. package/dist/ui/shared/MediaGallery.js +0 -35
  305. package/dist/ui/shared/Pagination.js +0 -195
  306. package/dist/ui/shared/ThreadView.js +0 -108
  307. package/dist/ui/shared/index.js +0 -5
  308. package/dist/vendor/datastar.js +0 -1606
  309. package/src/lib/__tests__/config.test.ts +0 -192
  310. package/src/lib/config.ts +0 -167
  311. package/src/routes/compose.ts +0 -63
  312. package/src/ui/dash/PostForm.tsx +0 -360
  313. package/src/ui/dash/settings/AppearanceContent.tsx +0 -254
@@ -1,209 +0,0 @@
1
- /**
2
- * Account settings: profile + password change forms
3
- */ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "hono/jsx/jsx-runtime";
4
- import { useLingui as $_useLingui } from "@jant/core/i18n";
5
- import { SettingsNav } from "./SettingsNav.js";
6
- export function AccountContent({ userName }) {
7
- const { i18n: $__i18n, _: $__ } = $_useLingui();
8
- const profileSignals = JSON.stringify({
9
- userName
10
- }).replace(/</g, "\\u003c");
11
- return /*#__PURE__*/ _jsxs(_Fragment, {
12
- children: [
13
- /*#__PURE__*/ _jsx("h1", {
14
- class: "text-2xl font-semibold mb-2",
15
- children: $__i18n._({
16
- id: "Tz0i8g",
17
- message: "Settings"
18
- })
19
- }),
20
- /*#__PURE__*/ _jsx(SettingsNav, {
21
- currentTab: "account"
22
- }),
23
- /*#__PURE__*/ _jsxs("div", {
24
- class: "flex flex-col gap-6 max-w-lg",
25
- children: [
26
- /*#__PURE__*/ _jsxs("form", {
27
- "data-signals": profileSignals,
28
- "data-on:submit__prevent": "@post('/dash/settings/account')",
29
- "data-indicator": "_profileLoading",
30
- children: [
31
- /*#__PURE__*/ _jsxs("div", {
32
- class: "card",
33
- children: [
34
- /*#__PURE__*/ _jsx("header", {
35
- children: /*#__PURE__*/ _jsx("h2", {
36
- children: $__i18n._({
37
- id: "vERlcd",
38
- message: "Profile"
39
- })
40
- })
41
- }),
42
- /*#__PURE__*/ _jsx("section", {
43
- class: "flex flex-col gap-4",
44
- children: /*#__PURE__*/ _jsxs("div", {
45
- class: "field",
46
- children: [
47
- /*#__PURE__*/ _jsx("label", {
48
- class: "label",
49
- children: $__i18n._({
50
- id: "6YtxFj",
51
- message: "Name"
52
- })
53
- }),
54
- /*#__PURE__*/ _jsx("input", {
55
- type: "text",
56
- "data-bind": "userName",
57
- class: "input",
58
- required: true
59
- })
60
- ]
61
- })
62
- })
63
- ]
64
- }),
65
- /*#__PURE__*/ _jsxs("button", {
66
- type: "submit",
67
- class: "btn mt-4",
68
- "data-attr:disabled": "$_profileLoading",
69
- children: [
70
- /*#__PURE__*/ _jsx("svg", {
71
- "data-show": "$_profileLoading",
72
- style: "display:none",
73
- class: "animate-spin size-4",
74
- xmlns: "http://www.w3.org/2000/svg",
75
- viewBox: "0 0 24 24",
76
- fill: "none",
77
- stroke: "currentColor",
78
- "stroke-width": "2",
79
- "stroke-linecap": "round",
80
- "stroke-linejoin": "round",
81
- role: "status",
82
- children: /*#__PURE__*/ _jsx("path", {
83
- d: "M21 12a9 9 0 1 1-6.219-8.56"
84
- })
85
- }),
86
- $__i18n._({
87
- id: "ssqvZi",
88
- message: "Save Profile"
89
- })
90
- ]
91
- })
92
- ]
93
- }),
94
- /*#__PURE__*/ _jsxs("form", {
95
- "data-signals": "{currentPassword: '', newPassword: '', confirmPassword: ''}",
96
- "data-on:submit__prevent": "@post('/dash/settings/password')",
97
- "data-indicator": "_passwordLoading",
98
- children: [
99
- /*#__PURE__*/ _jsxs("div", {
100
- class: "card",
101
- children: [
102
- /*#__PURE__*/ _jsx("header", {
103
- children: /*#__PURE__*/ _jsx("h2", {
104
- children: $__i18n._({
105
- id: "VhMDMg",
106
- message: "Change Password"
107
- })
108
- })
109
- }),
110
- /*#__PURE__*/ _jsxs("section", {
111
- class: "flex flex-col gap-4",
112
- children: [
113
- /*#__PURE__*/ _jsxs("div", {
114
- class: "field",
115
- children: [
116
- /*#__PURE__*/ _jsx("label", {
117
- class: "label",
118
- children: $__i18n._({
119
- id: "DCKkhU",
120
- message: "Current Password"
121
- })
122
- }),
123
- /*#__PURE__*/ _jsx("input", {
124
- type: "password",
125
- "data-bind": "currentPassword",
126
- class: "input",
127
- required: true,
128
- autocomplete: "current-password"
129
- })
130
- ]
131
- }),
132
- /*#__PURE__*/ _jsxs("div", {
133
- class: "field",
134
- children: [
135
- /*#__PURE__*/ _jsx("label", {
136
- class: "label",
137
- children: $__i18n._({
138
- id: "7vhWI8",
139
- message: "New Password"
140
- })
141
- }),
142
- /*#__PURE__*/ _jsx("input", {
143
- type: "password",
144
- "data-bind": "newPassword",
145
- class: "input",
146
- required: true,
147
- minlength: 8,
148
- autocomplete: "new-password"
149
- })
150
- ]
151
- }),
152
- /*#__PURE__*/ _jsxs("div", {
153
- class: "field",
154
- children: [
155
- /*#__PURE__*/ _jsx("label", {
156
- class: "label",
157
- children: $__i18n._({
158
- id: "yjkELF",
159
- message: "Confirm New Password"
160
- })
161
- }),
162
- /*#__PURE__*/ _jsx("input", {
163
- type: "password",
164
- "data-bind": "confirmPassword",
165
- class: "input",
166
- required: true,
167
- minlength: 8,
168
- autocomplete: "new-password"
169
- })
170
- ]
171
- })
172
- ]
173
- })
174
- ]
175
- }),
176
- /*#__PURE__*/ _jsxs("button", {
177
- type: "submit",
178
- class: "btn mt-4",
179
- "data-attr:disabled": "$_passwordLoading",
180
- children: [
181
- /*#__PURE__*/ _jsx("svg", {
182
- "data-show": "$_passwordLoading",
183
- style: "display:none",
184
- class: "animate-spin size-4",
185
- xmlns: "http://www.w3.org/2000/svg",
186
- viewBox: "0 0 24 24",
187
- fill: "none",
188
- stroke: "currentColor",
189
- "stroke-width": "2",
190
- "stroke-linecap": "round",
191
- "stroke-linejoin": "round",
192
- role: "status",
193
- children: /*#__PURE__*/ _jsx("path", {
194
- d: "M21 12a9 9 0 1 1-6.219-8.56"
195
- })
196
- }),
197
- $__i18n._({
198
- id: "VhMDMg",
199
- message: "Change Password"
200
- })
201
- ]
202
- })
203
- ]
204
- })
205
- ]
206
- })
207
- ]
208
- });
209
- }
@@ -1,259 +0,0 @@
1
- /**
2
- * Appearance settings: color theme picker + custom CSS form
3
- */ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "hono/jsx/jsx-runtime";
4
- import { useLingui as $_useLingui } from "@jant/core/i18n";
5
- import { SettingsNav } from "./SettingsNav.js";
6
- function ThemeCard({ theme, selected }) {
7
- const expr = `$theme === '${theme.id}'`;
8
- const { preview } = theme;
9
- return /*#__PURE__*/ _jsx("label", {
10
- class: `block cursor-pointer rounded-lg border overflow-hidden transition-colors ${selected ? "border-primary" : "border-border"}`,
11
- "data-class:border-primary": expr,
12
- "data-class:border-border": `$theme !== '${theme.id}'`,
13
- children: /*#__PURE__*/ _jsxs("div", {
14
- class: "grid grid-cols-2",
15
- children: [
16
- /*#__PURE__*/ _jsxs("div", {
17
- class: "p-5",
18
- style: `background-color:${preview.lightBg};color:${preview.lightText}`,
19
- children: [
20
- /*#__PURE__*/ _jsx("input", {
21
- type: "radio",
22
- name: "theme",
23
- value: theme.id,
24
- "data-bind": "theme",
25
- checked: selected || undefined,
26
- class: "mb-1"
27
- }),
28
- /*#__PURE__*/ _jsx("h3", {
29
- class: "font-bold text-lg",
30
- children: theme.name
31
- }),
32
- /*#__PURE__*/ _jsxs("p", {
33
- class: "text-sm mt-2 leading-relaxed",
34
- children: [
35
- "This is the ",
36
- theme.name,
37
- " theme in light mode. Links",
38
- " ",
39
- /*#__PURE__*/ _jsx("a", {
40
- tabIndex: -1,
41
- class: "underline",
42
- style: `color:${preview.lightLink}`,
43
- children: "look like this"
44
- }),
45
- ". We'll show the correct light or dark mode based on your visitor's settings."
46
- ]
47
- })
48
- ]
49
- }),
50
- /*#__PURE__*/ _jsxs("div", {
51
- class: "p-5",
52
- style: `background-color:${preview.darkBg};color:${preview.darkText}`,
53
- children: [
54
- /*#__PURE__*/ _jsx("h3", {
55
- class: "font-bold text-lg",
56
- children: theme.name
57
- }),
58
- /*#__PURE__*/ _jsxs("p", {
59
- class: "text-sm mt-2 leading-relaxed",
60
- children: [
61
- "This is the ",
62
- theme.name,
63
- " theme in dark mode. Links",
64
- " ",
65
- /*#__PURE__*/ _jsx("a", {
66
- tabIndex: -1,
67
- class: "underline",
68
- style: `color:${preview.darkLink}`,
69
- children: "look like this"
70
- }),
71
- ". We'll show the correct light or dark mode based on your visitor's settings."
72
- ]
73
- })
74
- ]
75
- })
76
- ]
77
- })
78
- });
79
- }
80
- export function AppearanceContent({ themes, currentThemeId, fontThemes, currentFontThemeId, customCSS }) {
81
- const { i18n: $__i18n, _: $__ } = $_useLingui();
82
- const themeSignals = JSON.stringify({
83
- theme: currentThemeId
84
- }).replace(/</g, "\\u003c");
85
- const cssSignals = JSON.stringify({
86
- customCSS
87
- }).replace(/</g, "\\u003c");
88
- return /*#__PURE__*/ _jsxs(_Fragment, {
89
- children: [
90
- /*#__PURE__*/ _jsx("h1", {
91
- class: "text-2xl font-semibold mb-2",
92
- children: $__i18n._({
93
- id: "Tz0i8g",
94
- message: "Settings"
95
- })
96
- }),
97
- /*#__PURE__*/ _jsx(SettingsNav, {
98
- currentTab: "appearance"
99
- }),
100
- /*#__PURE__*/ _jsx("div", {
101
- "data-signals": themeSignals,
102
- "data-on:change": "@post('/dash/settings/appearance')",
103
- class: "max-w-3xl mb-8",
104
- children: /*#__PURE__*/ _jsxs("fieldset", {
105
- children: [
106
- /*#__PURE__*/ _jsx("legend", {
107
- class: "text-lg font-semibold",
108
- children: $__i18n._({
109
- id: "rFmBG3",
110
- message: "Color theme"
111
- })
112
- }),
113
- /*#__PURE__*/ _jsx("p", {
114
- class: "text-sm text-muted-foreground mb-4",
115
- children: $__i18n._({
116
- id: "07Epll",
117
- message: "This will theme both your site and your dashboard. All color themes support dark mode."
118
- })
119
- }),
120
- /*#__PURE__*/ _jsx("div", {
121
- class: "flex flex-col gap-4",
122
- children: themes.map((theme)=>/*#__PURE__*/ _jsx(ThemeCard, {
123
- theme: theme,
124
- selected: theme.id === currentThemeId
125
- }, theme.id))
126
- })
127
- ]
128
- })
129
- }),
130
- /*#__PURE__*/ _jsx("div", {
131
- "data-signals": JSON.stringify({
132
- fontTheme: currentFontThemeId
133
- }).replace(/</g, "\\u003c"),
134
- "data-on:change": "@post('/dash/settings/font-theme')",
135
- class: "max-w-3xl",
136
- children: /*#__PURE__*/ _jsxs("fieldset", {
137
- children: [
138
- /*#__PURE__*/ _jsx("legend", {
139
- class: "text-lg font-semibold",
140
- children: $__i18n._({
141
- id: "M2kIWU",
142
- message: "Font theme"
143
- })
144
- }),
145
- /*#__PURE__*/ _jsx("p", {
146
- class: "text-sm text-muted-foreground mb-4",
147
- children: $__i18n._({
148
- id: "3SAro+",
149
- message: "Choose a font for your site. All options use system fonts for fast loading."
150
- })
151
- }),
152
- /*#__PURE__*/ _jsx("div", {
153
- class: "flex flex-col gap-2",
154
- children: fontThemes.map((ft)=>/*#__PURE__*/ _jsxs("label", {
155
- class: `flex items-start gap-3 p-3 rounded-lg border cursor-pointer transition-colors ${ft.id === currentFontThemeId ? "border-primary" : "border-border"}`,
156
- "data-class:border-primary": `$fontTheme === '${ft.id}'`,
157
- "data-class:border-border": `$fontTheme !== '${ft.id}'`,
158
- children: [
159
- /*#__PURE__*/ _jsx("input", {
160
- type: "radio",
161
- name: "fontTheme",
162
- value: ft.id,
163
- "data-bind": "fontTheme",
164
- checked: ft.id === currentFontThemeId || undefined,
165
- class: "mt-1"
166
- }),
167
- /*#__PURE__*/ _jsxs("div", {
168
- children: [
169
- /*#__PURE__*/ _jsx("div", {
170
- class: "font-medium",
171
- children: ft.name
172
- }),
173
- /*#__PURE__*/ _jsx("div", {
174
- class: "text-sm text-muted-foreground",
175
- children: ft.description
176
- }),
177
- /*#__PURE__*/ _jsxs("div", {
178
- class: "mt-1 text-sm",
179
- style: `font-family:${ft.fontFamily}`,
180
- children: [
181
- "The quick brown fox jumps over the lazy dog.",
182
- " ",
183
- "敏捷的棕色狐狸跳过了懒狗。"
184
- ]
185
- })
186
- ]
187
- })
188
- ]
189
- }, ft.id))
190
- })
191
- ]
192
- })
193
- }),
194
- /*#__PURE__*/ _jsxs("form", {
195
- "data-signals": cssSignals,
196
- "data-on:submit__prevent": "@post('/dash/settings/custom-css')",
197
- "data-indicator": "_cssLoading",
198
- class: "max-w-3xl mt-8",
199
- children: [
200
- /*#__PURE__*/ _jsxs("fieldset", {
201
- children: [
202
- /*#__PURE__*/ _jsx("legend", {
203
- class: "text-lg font-semibold",
204
- children: $__i18n._({
205
- id: "9+vGLh",
206
- message: "Custom CSS"
207
- })
208
- }),
209
- /*#__PURE__*/ _jsx("p", {
210
- class: "text-sm text-muted-foreground mb-4",
211
- children: $__i18n._({
212
- id: "vmQmHx",
213
- message: "Add custom CSS to override any styles. Use data attributes like [data-page], [data-post], [data-format] to target specific elements."
214
- })
215
- }),
216
- /*#__PURE__*/ _jsx("textarea", {
217
- "data-bind": "customCSS",
218
- class: "textarea font-mono text-sm min-h-32",
219
- rows: 8,
220
- placeholder: $__i18n._({
221
- id: "wc+17X",
222
- message: "/* Your custom CSS here */"
223
- }),
224
- children: customCSS
225
- })
226
- ]
227
- }),
228
- /*#__PURE__*/ _jsxs("button", {
229
- type: "submit",
230
- class: "btn mt-4",
231
- "data-attr:disabled": "$_cssLoading",
232
- children: [
233
- /*#__PURE__*/ _jsx("svg", {
234
- "data-show": "$_cssLoading",
235
- style: "display:none",
236
- class: "animate-spin size-4",
237
- xmlns: "http://www.w3.org/2000/svg",
238
- viewBox: "0 0 24 24",
239
- fill: "none",
240
- stroke: "currentColor",
241
- "stroke-width": "2",
242
- "stroke-linecap": "round",
243
- "stroke-linejoin": "round",
244
- role: "status",
245
- children: /*#__PURE__*/ _jsx("path", {
246
- d: "M21 12a9 9 0 1 1-6.219-8.56"
247
- })
248
- }),
249
- $__i18n._({
250
- id: "NU2Fqi",
251
- message: "Save CSS"
252
- })
253
- ]
254
- })
255
- ]
256
- })
257
- ]
258
- });
259
- }