@jant/core 0.3.24 → 0.3.26

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 (277) hide show
  1. package/dist/app.js +101 -571
  2. package/dist/client.js +1 -0
  3. package/dist/db/schema.js +1 -1
  4. package/dist/i18n/locales/en.js +1 -1
  5. package/dist/i18n/locales/zh-Hans.js +1 -1
  6. package/dist/i18n/locales/zh-Hant.js +1 -1
  7. package/dist/index.js +3 -9
  8. package/dist/lib/avatar-upload.js +134 -0
  9. package/dist/lib/config.js +39 -0
  10. package/dist/lib/constants.js +10 -9
  11. package/dist/lib/favicon.js +102 -0
  12. package/dist/lib/image.js +13 -17
  13. package/dist/lib/media-helpers.js +2 -2
  14. package/dist/lib/nav-reorder.js +1 -1
  15. package/dist/lib/navigation.js +48 -3
  16. package/dist/lib/pagination.js +44 -0
  17. package/dist/lib/render.js +16 -11
  18. package/dist/lib/schemas.js +34 -3
  19. package/dist/lib/theme.js +4 -4
  20. package/dist/lib/timeline.js +24 -48
  21. package/dist/lib/timezones.js +388 -0
  22. package/dist/lib/view.js +3 -3
  23. package/dist/routes/api/collections.js +124 -0
  24. package/dist/routes/api/nav-items.js +104 -0
  25. package/dist/routes/api/pages.js +91 -0
  26. package/dist/routes/api/posts.js +3 -3
  27. package/dist/routes/api/search.js +2 -2
  28. package/dist/routes/api/settings.js +68 -0
  29. package/dist/routes/api/upload.js +3 -3
  30. package/dist/routes/auth/reset.js +221 -0
  31. package/dist/routes/auth/setup.js +194 -0
  32. package/dist/routes/auth/signin.js +176 -0
  33. package/dist/routes/compose.js +48 -0
  34. package/dist/routes/dash/collections.js +24 -416
  35. package/dist/routes/dash/index.js +1 -1
  36. package/dist/routes/dash/media.js +13 -393
  37. package/dist/routes/dash/pages.js +112 -86
  38. package/dist/routes/dash/posts.js +3 -5
  39. package/dist/routes/dash/redirects.js +20 -14
  40. package/dist/routes/dash/settings.js +213 -518
  41. package/dist/routes/feed/rss.js +4 -3
  42. package/dist/routes/feed/sitemap.js +5 -3
  43. package/dist/routes/pages/archive.js +3 -6
  44. package/dist/routes/pages/collection.js +3 -6
  45. package/dist/routes/pages/collections.js +28 -0
  46. package/dist/routes/pages/featured.js +36 -0
  47. package/dist/routes/pages/home.js +33 -49
  48. package/dist/routes/pages/latest.js +45 -0
  49. package/dist/routes/pages/page.js +29 -32
  50. package/dist/routes/pages/post.js +3 -6
  51. package/dist/routes/pages/search.js +3 -6
  52. package/dist/services/page.js +5 -1
  53. package/dist/services/post.js +45 -31
  54. package/dist/services/search.js +1 -1
  55. package/dist/types/bindings.js +3 -0
  56. package/dist/types/config.js +147 -0
  57. package/dist/types/constants.js +27 -0
  58. package/dist/types/entities.js +3 -0
  59. package/dist/types/operations.js +3 -0
  60. package/dist/types/props.js +3 -0
  61. package/dist/types/views.js +5 -0
  62. package/dist/types.js +8 -111
  63. package/dist/{theme → ui}/color-themes.js +33 -33
  64. package/dist/ui/compose/ComposeDialog.js +467 -0
  65. package/dist/ui/compose/ComposePrompt.js +55 -0
  66. package/dist/{theme/components/TypeBadge.js → ui/dash/FormatBadge.js} +1 -2
  67. package/dist/{theme/components → ui/dash}/PageForm.js +21 -15
  68. package/dist/{theme/components → ui/dash}/PostForm.js +22 -43
  69. package/dist/{theme/components → ui/dash}/PostList.js +6 -6
  70. package/dist/{theme/components/VisibilityBadge.js → ui/dash/StatusBadge.js} +1 -2
  71. package/dist/ui/dash/collections/CollectionForm.js +152 -0
  72. package/dist/ui/dash/collections/CollectionsListContent.js +68 -0
  73. package/dist/ui/dash/collections/ViewCollectionContent.js +96 -0
  74. package/dist/{theme/components → ui/dash}/index.js +3 -6
  75. package/dist/ui/dash/media/MediaListContent.js +166 -0
  76. package/dist/ui/dash/media/ViewMediaContent.js +212 -0
  77. package/dist/ui/dash/pages/LinkFormContent.js +130 -0
  78. package/dist/ui/dash/pages/UnifiedPagesContent.js +193 -0
  79. package/dist/ui/dash/settings/AccountContent.js +209 -0
  80. package/dist/ui/dash/settings/AppearanceContent.js +259 -0
  81. package/dist/ui/dash/settings/GeneralContent.js +536 -0
  82. package/dist/ui/dash/settings/SettingsNav.js +41 -0
  83. package/dist/{themes/threads/timeline → ui/feed}/LinkCard.js +6 -2
  84. package/dist/{themes/threads/timeline → ui/feed}/NoteCard.js +11 -6
  85. package/dist/{themes/threads/timeline → ui/feed}/QuoteCard.js +10 -6
  86. package/dist/{themes/threads/timeline → ui/feed}/ThreadPreview.js +7 -9
  87. package/dist/ui/feed/TimelineFeed.js +41 -0
  88. package/dist/ui/feed/TimelineItem.js +27 -0
  89. package/dist/ui/font-themes.js +36 -0
  90. package/dist/{theme → ui}/layouts/BaseLayout.js +34 -2
  91. package/dist/{theme → ui}/layouts/DashLayout.js +0 -8
  92. package/dist/ui/layouts/SiteLayout.js +169 -0
  93. package/dist/{themes/threads → ui}/pages/ArchivePage.js +16 -14
  94. package/dist/{themes/threads → ui}/pages/CollectionPage.js +6 -1
  95. package/dist/ui/pages/CollectionsPage.js +76 -0
  96. package/dist/ui/pages/FeaturedPage.js +24 -0
  97. package/dist/ui/pages/HomePage.js +24 -0
  98. package/dist/{themes/threads → ui}/pages/PostPage.js +13 -8
  99. package/dist/{themes/threads → ui}/pages/SearchPage.js +9 -7
  100. package/dist/{themes/threads → ui}/pages/SinglePage.js +3 -2
  101. package/dist/{theme/components → ui/shared}/MediaGallery.js +1 -1
  102. package/dist/{theme/components → ui/shared}/Pagination.js +41 -2
  103. package/dist/{theme/components → ui/shared}/ThreadView.js +2 -2
  104. package/dist/ui/shared/index.js +5 -0
  105. package/package.json +1 -9
  106. package/src/__tests__/helpers/db.ts +3 -0
  107. package/src/app.tsx +131 -561
  108. package/src/client.ts +1 -0
  109. package/src/db/migrations/0006_rename_slug_to_path.sql +5 -0
  110. package/src/db/migrations/meta/_journal.json +7 -0
  111. package/src/db/schema.ts +1 -1
  112. package/src/i18n/locales/en.po +477 -261
  113. package/src/i18n/locales/en.ts +1 -1
  114. package/src/i18n/locales/zh-Hans.po +477 -261
  115. package/src/i18n/locales/zh-Hans.ts +1 -1
  116. package/src/i18n/locales/zh-Hant.po +477 -261
  117. package/src/i18n/locales/zh-Hant.ts +1 -1
  118. package/src/index.ts +7 -36
  119. package/src/lib/__tests__/config.test.ts +192 -0
  120. package/src/lib/__tests__/favicon.test.ts +151 -0
  121. package/src/lib/__tests__/image.test.ts +2 -6
  122. package/src/lib/__tests__/schemas.test.ts +60 -19
  123. package/src/lib/__tests__/timeline.test.ts +45 -81
  124. package/src/lib/__tests__/timezones.test.ts +61 -0
  125. package/src/lib/__tests__/view.test.ts +15 -9
  126. package/src/lib/avatar-upload.ts +165 -0
  127. package/src/lib/config.ts +47 -0
  128. package/src/lib/constants.ts +19 -10
  129. package/src/lib/favicon.ts +115 -0
  130. package/src/lib/image.ts +13 -21
  131. package/src/lib/media-helpers.ts +2 -2
  132. package/src/lib/nav-reorder.ts +1 -1
  133. package/src/lib/navigation.ts +73 -4
  134. package/src/lib/pagination.ts +50 -0
  135. package/src/lib/render.tsx +22 -15
  136. package/src/lib/schemas.ts +47 -6
  137. package/src/lib/theme.ts +5 -5
  138. package/src/lib/timeline.ts +28 -57
  139. package/src/lib/timezones.ts +325 -0
  140. package/src/lib/view.ts +3 -3
  141. package/src/preset.css +2 -1
  142. package/src/routes/__tests__/compose.test.ts +199 -0
  143. package/src/routes/api/__tests__/collections.test.ts +249 -0
  144. package/src/routes/api/__tests__/nav-items.test.ts +222 -0
  145. package/src/routes/api/__tests__/pages.test.ts +218 -0
  146. package/src/routes/api/__tests__/settings.test.ts +132 -0
  147. package/src/routes/api/collections.ts +143 -0
  148. package/src/routes/api/nav-items.ts +115 -0
  149. package/src/routes/api/pages.ts +101 -0
  150. package/src/routes/api/posts.ts +3 -3
  151. package/src/routes/api/search.ts +2 -2
  152. package/src/routes/api/settings.ts +91 -0
  153. package/src/routes/api/upload.ts +2 -3
  154. package/src/routes/auth/reset.tsx +239 -0
  155. package/src/routes/auth/setup.tsx +189 -0
  156. package/src/routes/auth/signin.tsx +163 -0
  157. package/src/routes/compose.ts +63 -0
  158. package/src/routes/dash/__tests__/pages.test.ts +225 -0
  159. package/src/routes/dash/__tests__/settings-avatar.test.ts +89 -0
  160. package/src/routes/dash/collections.tsx +18 -367
  161. package/src/routes/dash/index.tsx +1 -1
  162. package/src/routes/dash/media.tsx +13 -415
  163. package/src/routes/dash/pages.tsx +131 -98
  164. package/src/routes/dash/posts.tsx +3 -7
  165. package/src/routes/dash/redirects.tsx +22 -16
  166. package/src/routes/dash/settings.tsx +265 -478
  167. package/src/routes/feed/__tests__/rss.test.ts +141 -0
  168. package/src/routes/feed/rss.ts +5 -3
  169. package/src/routes/feed/sitemap.ts +5 -3
  170. package/src/routes/pages/__tests__/collections.test.ts +94 -0
  171. package/src/routes/pages/__tests__/featured.test.ts +94 -0
  172. package/src/routes/pages/archive.tsx +2 -6
  173. package/src/routes/pages/collection.tsx +2 -6
  174. package/src/routes/pages/collections.tsx +36 -0
  175. package/src/routes/pages/featured.tsx +44 -0
  176. package/src/routes/pages/home.tsx +30 -53
  177. package/src/routes/pages/latest.tsx +59 -0
  178. package/src/routes/pages/page.tsx +28 -30
  179. package/src/routes/pages/post.tsx +2 -5
  180. package/src/routes/pages/search.tsx +2 -6
  181. package/src/services/__tests__/page.test.ts +106 -0
  182. package/src/services/__tests__/post.test.ts +114 -15
  183. package/src/services/page.ts +13 -1
  184. package/src/services/post.ts +58 -40
  185. package/src/services/search.ts +2 -2
  186. package/src/styles/components.css +0 -65
  187. package/src/styles/tokens.css +47 -0
  188. package/src/styles/ui.css +475 -0
  189. package/src/types/bindings.ts +30 -0
  190. package/src/types/config.ts +183 -0
  191. package/src/types/constants.ts +26 -0
  192. package/src/types/entities.ts +109 -0
  193. package/src/types/operations.ts +88 -0
  194. package/src/types/props.ts +115 -0
  195. package/src/types/views.ts +172 -0
  196. package/src/types.ts +8 -774
  197. package/src/ui/__tests__/font-themes.test.ts +34 -0
  198. package/src/{theme → ui}/color-themes.ts +34 -34
  199. package/src/ui/compose/ComposeDialog.tsx +414 -0
  200. package/src/ui/compose/ComposePrompt.tsx +55 -0
  201. package/src/{theme/components/TypeBadge.tsx → ui/dash/FormatBadge.tsx} +2 -3
  202. package/src/{theme/components → ui/dash}/PageForm.tsx +25 -19
  203. package/src/{theme/components → ui/dash}/PostForm.tsx +26 -45
  204. package/src/{theme/components → ui/dash}/PostList.tsx +7 -7
  205. package/src/{theme/components/VisibilityBadge.tsx → ui/dash/StatusBadge.tsx} +2 -3
  206. package/src/ui/dash/collections/CollectionForm.tsx +153 -0
  207. package/src/ui/dash/collections/CollectionsListContent.tsx +85 -0
  208. package/src/ui/dash/collections/ViewCollectionContent.tsx +92 -0
  209. package/src/ui/dash/index.ts +10 -0
  210. package/src/ui/dash/media/MediaListContent.tsx +201 -0
  211. package/src/ui/dash/media/ViewMediaContent.tsx +208 -0
  212. package/src/ui/dash/pages/LinkFormContent.tsx +119 -0
  213. package/src/ui/dash/pages/UnifiedPagesContent.tsx +203 -0
  214. package/src/ui/dash/settings/AccountContent.tsx +176 -0
  215. package/src/ui/dash/settings/AppearanceContent.tsx +254 -0
  216. package/src/ui/dash/settings/GeneralContent.tsx +533 -0
  217. package/src/ui/dash/settings/SettingsNav.tsx +56 -0
  218. package/src/{themes/threads/timeline → ui/feed}/LinkCard.tsx +9 -4
  219. package/src/{themes/threads/timeline → ui/feed}/NoteCard.tsx +13 -8
  220. package/src/{themes/threads/timeline → ui/feed}/QuoteCard.tsx +13 -8
  221. package/src/{themes/threads/timeline → ui/feed}/ThreadPreview.tsx +7 -8
  222. package/src/ui/feed/TimelineFeed.tsx +49 -0
  223. package/src/ui/feed/TimelineItem.tsx +45 -0
  224. package/src/ui/font-themes.ts +54 -0
  225. package/src/{theme → ui}/layouts/BaseLayout.tsx +28 -1
  226. package/src/{theme → ui}/layouts/DashLayout.tsx +0 -10
  227. package/src/ui/layouts/SiteLayout.tsx +164 -0
  228. package/src/{themes/threads → ui}/pages/ArchivePage.tsx +22 -17
  229. package/src/{themes/threads → ui}/pages/CollectionPage.tsx +14 -5
  230. package/src/ui/pages/CollectionsPage.tsx +73 -0
  231. package/src/ui/pages/FeaturedPage.tsx +31 -0
  232. package/src/{themes/threads → ui}/pages/HomePage.tsx +11 -15
  233. package/src/{themes/threads → ui}/pages/PostPage.tsx +23 -14
  234. package/src/{themes/threads → ui}/pages/SearchPage.tsx +13 -11
  235. package/src/{themes/threads → ui}/pages/SinglePage.tsx +4 -4
  236. package/src/{theme/components → ui/shared}/MediaGallery.tsx +1 -1
  237. package/src/{theme/components → ui/shared}/Pagination.tsx +67 -4
  238. package/src/{theme/components → ui/shared}/ThreadView.tsx +2 -2
  239. package/src/ui/shared/__tests__/pagination.test.ts +46 -0
  240. package/src/ui/shared/index.ts +12 -0
  241. package/bin/jant.js +0 -185
  242. package/dist/lib/theme-components.js +0 -46
  243. package/dist/routes/dash/navigation.js +0 -289
  244. package/dist/theme/index.js +0 -18
  245. package/dist/theme/layouts/index.js +0 -2
  246. package/dist/themes/threads/ThreadsSiteLayout.js +0 -172
  247. package/dist/themes/threads/index.js +0 -81
  248. package/dist/themes/threads/pages/HomePage.js +0 -25
  249. package/dist/themes/threads/timeline/TimelineFeed.js +0 -58
  250. package/dist/themes/threads/timeline/TimelineItem.js +0 -36
  251. package/dist/themes/threads/timeline/TimelineLoadMore.js +0 -23
  252. package/dist/themes/threads/timeline/groupByDate.js +0 -22
  253. package/dist/themes/threads/timeline/timelineMore.js +0 -107
  254. package/src/lib/__tests__/theme-components.test.ts +0 -105
  255. package/src/lib/theme-components.ts +0 -65
  256. package/src/routes/dash/navigation.tsx +0 -317
  257. package/src/theme/components/index.ts +0 -23
  258. package/src/theme/index.ts +0 -22
  259. package/src/theme/layouts/index.ts +0 -7
  260. package/src/themes/threads/ThreadsSiteLayout.tsx +0 -194
  261. package/src/themes/threads/index.ts +0 -100
  262. package/src/themes/threads/style.css +0 -336
  263. package/src/themes/threads/timeline/TimelineFeed.tsx +0 -62
  264. package/src/themes/threads/timeline/TimelineItem.tsx +0 -67
  265. package/src/themes/threads/timeline/TimelineLoadMore.tsx +0 -35
  266. package/src/themes/threads/timeline/groupByDate.ts +0 -30
  267. package/src/themes/threads/timeline/timelineMore.tsx +0 -130
  268. /package/dist/{theme/components → ui/dash}/ActionButtons.js +0 -0
  269. /package/dist/{theme/components → ui/dash}/CrudPageHeader.js +0 -0
  270. /package/dist/{theme/components → ui/dash}/DangerZone.js +0 -0
  271. /package/dist/{theme/components → ui/dash}/ListItemRow.js +0 -0
  272. /package/dist/{theme/components → ui/shared}/EmptyState.js +0 -0
  273. /package/src/{theme/components → ui/dash}/ActionButtons.tsx +0 -0
  274. /package/src/{theme/components → ui/dash}/CrudPageHeader.tsx +0 -0
  275. /package/src/{theme/components → ui/dash}/DangerZone.tsx +0 -0
  276. /package/src/{theme/components → ui/dash}/ListItemRow.tsx +0 -0
  277. /package/src/{theme/components → ui/shared}/EmptyState.tsx +0 -0
@@ -0,0 +1,209 @@
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
+ }
@@ -0,0 +1,259 @@
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
+ }