@akanjs/cli 0.0.38 → 0.0.39

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 (294) hide show
  1. package/index.js +1 -1
  2. package/package.json +1 -1
  3. package/assets/app/akan.config.ts.template +0 -5
  4. package/assets/app/app/[lang]/(__appName__)/(public)/forgotpassword/page.tsx.template +0 -16
  5. package/assets/app/app/[lang]/(__appName__)/(public)/page.tsx.template +0 -17
  6. package/assets/app/app/[lang]/(__appName__)/(public)/privacy/page.tsx.template +0 -10
  7. package/assets/app/app/[lang]/(__appName__)/(public)/signin/page.tsx.template +0 -19
  8. package/assets/app/app/[lang]/(__appName__)/(public)/termsofservice/page.tsx.template +0 -10
  9. package/assets/app/app/[lang]/(__appName__)/(user)/layout.tsx.template +0 -12
  10. package/assets/app/app/[lang]/(__appName__)/(user)/self/page.tsx.template +0 -29
  11. package/assets/app/app/[lang]/(__appName__)/layout.tsx.template +0 -21
  12. package/assets/app/app/[lang]/admin/layout.tsx.template +0 -22
  13. package/assets/app/app/[lang]/admin/page.tsx.template +0 -32
  14. package/assets/app/app/csr.tsx.template +0 -3
  15. package/assets/app/app/index.html.template +0 -13
  16. package/assets/app/app/layout.tsx.template +0 -7
  17. package/assets/app/app/robots.ts.template +0 -12
  18. package/assets/app/app/sitemap.ts.template +0 -8
  19. package/assets/app/base/baseLogic.ts.template +0 -7
  20. package/assets/app/base/index.ts.template +0 -1
  21. package/assets/app/capacitor.config.ts.template +0 -8
  22. package/assets/app/client.ts.template +0 -8
  23. package/assets/app/common/commonLogic.ts.template +0 -7
  24. package/assets/app/common/index.ts.template +0 -1
  25. package/assets/app/config.yaml.template +0 -19
  26. package/assets/app/env/env.client.ts.template +0 -10
  27. package/assets/app/env/env.client.type.ts.template +0 -7
  28. package/assets/app/env/env.server.ts.template +0 -10
  29. package/assets/app/jest.config.ts.template +0 -8
  30. package/assets/app/lib/___appName__/__appName__.constant.ts.template +0 -8
  31. package/assets/app/lib/___appName__/__appName__.dictionary.ts.template +0 -22
  32. package/assets/app/lib/___appName__/__appName__.document.ts.template +0 -6
  33. package/assets/app/lib/___appName__/__appName__.service.ts.template +0 -14
  34. package/assets/app/lib/___appName__/__appName__.store.ts.template +0 -8
  35. package/assets/app/lib/___appName__/_server.ts.template +0 -8
  36. package/assets/app/lib/cnst.ts.template +0 -4
  37. package/assets/app/lib/cnst_.ts.template +0 -38
  38. package/assets/app/lib/db.ts.template +0 -44
  39. package/assets/app/lib/dict.ts.template +0 -28
  40. package/assets/app/lib/fetch.ts.template +0 -18
  41. package/assets/app/lib/option.ts.template +0 -8
  42. package/assets/app/lib/setting/Setting.Template.tsx.template +0 -26
  43. package/assets/app/lib/setting/Setting.Unit.tsx.template +0 -7
  44. package/assets/app/lib/setting/Setting.Util.tsx.template +0 -3
  45. package/assets/app/lib/setting/Setting.View.tsx.template +0 -20
  46. package/assets/app/lib/setting/Setting.Zone.tsx.template +0 -49
  47. package/assets/app/lib/setting/_server.ts.template +0 -19
  48. package/assets/app/lib/setting/index.tsx.template +0 -30
  49. package/assets/app/lib/setting/setting.constant.ts.template +0 -17
  50. package/assets/app/lib/setting/setting.dictionary.ts.template +0 -18
  51. package/assets/app/lib/setting/setting.document.ts.template +0 -20
  52. package/assets/app/lib/setting/setting.service.ts.template +0 -12
  53. package/assets/app/lib/setting/setting.signal.ts.template +0 -6
  54. package/assets/app/lib/setting/setting.store.ts.template +0 -13
  55. package/assets/app/lib/sig.ts.template +0 -3
  56. package/assets/app/lib/srv.ts.template +0 -20
  57. package/assets/app/lib/st.ts.template +0 -6
  58. package/assets/app/lib/store.ts.template +0 -17
  59. package/assets/app/lib/summary/Summary.Template.tsx.template +0 -12
  60. package/assets/app/lib/summary/Summary.Unit.tsx.template +0 -7
  61. package/assets/app/lib/summary/Summary.Util.tsx.template +0 -2
  62. package/assets/app/lib/summary/Summary.View.tsx.template +0 -20
  63. package/assets/app/lib/summary/Summary.Zone.tsx.template +0 -31
  64. package/assets/app/lib/summary/_server.ts.template +0 -19
  65. package/assets/app/lib/summary/index.tsx.template +0 -36
  66. package/assets/app/lib/summary/summary.constant.ts.template +0 -16
  67. package/assets/app/lib/summary/summary.dictionary.ts.template +0 -21
  68. package/assets/app/lib/summary/summary.document.ts.template +0 -20
  69. package/assets/app/lib/summary/summary.service.ts.template +0 -26
  70. package/assets/app/lib/summary/summary.signal.ts.template +0 -6
  71. package/assets/app/lib/summary/summary.store.ts.template +0 -13
  72. package/assets/app/lib/usePage.ts.template +0 -5
  73. package/assets/app/lib/user/User.Template.tsx.template +0 -34
  74. package/assets/app/lib/user/User.Unit.tsx.template +0 -7
  75. package/assets/app/lib/user/User.Util.tsx.template +0 -63
  76. package/assets/app/lib/user/User.View.tsx.template +0 -35
  77. package/assets/app/lib/user/User.Zone.tsx.template +0 -43
  78. package/assets/app/lib/user/_server.ts.template +0 -19
  79. package/assets/app/lib/user/index.tsx.template +0 -30
  80. package/assets/app/lib/user/user.constant.ts.template +0 -31
  81. package/assets/app/lib/user/user.dictionary.ts.template +0 -24
  82. package/assets/app/lib/user/user.document.ts.template +0 -26
  83. package/assets/app/lib/user/user.service.ts.template +0 -14
  84. package/assets/app/lib/user/user.signal.spec.ts.template +0 -9
  85. package/assets/app/lib/user/user.signal.test.ts.template +0 -11
  86. package/assets/app/lib/user/user.signal.ts.template +0 -6
  87. package/assets/app/lib/user/user.store.ts.template +0 -11
  88. package/assets/app/main.ts.template +0 -12
  89. package/assets/app/middleware.ts.template +0 -4
  90. package/assets/app/nest/backendLogic.ts.template +0 -6
  91. package/assets/app/nest/index.ts.template +0 -1
  92. package/assets/app/next/frontendLogic.ts.template +0 -6
  93. package/assets/app/next/index.ts.template +0 -1
  94. package/assets/app/page.test.ts.template +0 -10
  95. package/assets/app/playwright.config.ts.template +0 -6
  96. package/assets/app/postcss.config.js.template +0 -10
  97. package/assets/app/public/favicon.ico +0 -0
  98. package/assets/app/public/icons/icon-128x128.png +0 -0
  99. package/assets/app/public/icons/icon-144x144.png +0 -0
  100. package/assets/app/public/icons/icon-152x152.png +0 -0
  101. package/assets/app/public/icons/icon-192x192.png +0 -0
  102. package/assets/app/public/icons/icon-256x256.png +0 -0
  103. package/assets/app/public/icons/icon-384x384.png +0 -0
  104. package/assets/app/public/icons/icon-48x48.png +0 -0
  105. package/assets/app/public/icons/icon-512x512.png +0 -0
  106. package/assets/app/public/icons/icon-72x72.png +0 -0
  107. package/assets/app/public/icons/icon-96x96.png +0 -0
  108. package/assets/app/public/logo.svg +0 -70
  109. package/assets/app/public/manifest.json.template +0 -67
  110. package/assets/app/server.ts.template +0 -30
  111. package/assets/app/tsconfig.json.template +0 -22
  112. package/assets/app/tsconfig.spec.json.template +0 -7
  113. package/assets/app/ui/Footer.tsx.template +0 -36
  114. package/assets/app/ui/MainHeader.tsx.template +0 -100
  115. package/assets/app/ui/index.ts.template +0 -2
  116. package/assets/assets/app/akan.config.ts.template +0 -5
  117. package/assets/assets/app/app/[lang]/(__appName__)/(public)/forgotpassword/page.tsx.template +0 -16
  118. package/assets/assets/app/app/[lang]/(__appName__)/(public)/page.tsx.template +0 -17
  119. package/assets/assets/app/app/[lang]/(__appName__)/(public)/privacy/page.tsx.template +0 -10
  120. package/assets/assets/app/app/[lang]/(__appName__)/(public)/signin/page.tsx.template +0 -19
  121. package/assets/assets/app/app/[lang]/(__appName__)/(public)/termsofservice/page.tsx.template +0 -10
  122. package/assets/assets/app/app/[lang]/(__appName__)/(user)/layout.tsx.template +0 -12
  123. package/assets/assets/app/app/[lang]/(__appName__)/(user)/self/page.tsx.template +0 -29
  124. package/assets/assets/app/app/[lang]/(__appName__)/layout.tsx.template +0 -21
  125. package/assets/assets/app/app/[lang]/admin/layout.tsx.template +0 -22
  126. package/assets/assets/app/app/[lang]/admin/page.tsx.template +0 -32
  127. package/assets/assets/app/app/csr.tsx.template +0 -3
  128. package/assets/assets/app/app/index.html.template +0 -13
  129. package/assets/assets/app/app/layout.tsx.template +0 -7
  130. package/assets/assets/app/app/robots.ts.template +0 -12
  131. package/assets/assets/app/app/sitemap.ts.template +0 -8
  132. package/assets/assets/app/base/baseLogic.ts.template +0 -7
  133. package/assets/assets/app/base/index.ts.template +0 -1
  134. package/assets/assets/app/capacitor.config.ts.template +0 -8
  135. package/assets/assets/app/client.ts.template +0 -8
  136. package/assets/assets/app/common/commonLogic.ts.template +0 -7
  137. package/assets/assets/app/common/index.ts.template +0 -1
  138. package/assets/assets/app/config.yaml.template +0 -19
  139. package/assets/assets/app/env/env.client.ts.template +0 -10
  140. package/assets/assets/app/env/env.client.type.ts.template +0 -7
  141. package/assets/assets/app/env/env.server.ts.template +0 -10
  142. package/assets/assets/app/jest.config.ts.template +0 -8
  143. package/assets/assets/app/lib/___appName__/__appName__.constant.ts.template +0 -8
  144. package/assets/assets/app/lib/___appName__/__appName__.dictionary.ts.template +0 -22
  145. package/assets/assets/app/lib/___appName__/__appName__.document.ts.template +0 -6
  146. package/assets/assets/app/lib/___appName__/__appName__.service.ts.template +0 -14
  147. package/assets/assets/app/lib/___appName__/__appName__.store.ts.template +0 -8
  148. package/assets/assets/app/lib/___appName__/_server.ts.template +0 -8
  149. package/assets/assets/app/lib/cnst.ts.template +0 -4
  150. package/assets/assets/app/lib/cnst_.ts.template +0 -38
  151. package/assets/assets/app/lib/db.ts.template +0 -44
  152. package/assets/assets/app/lib/dict.ts.template +0 -28
  153. package/assets/assets/app/lib/fetch.ts.template +0 -18
  154. package/assets/assets/app/lib/option.ts.template +0 -8
  155. package/assets/assets/app/lib/setting/Setting.Template.tsx.template +0 -26
  156. package/assets/assets/app/lib/setting/Setting.Unit.tsx.template +0 -7
  157. package/assets/assets/app/lib/setting/Setting.Util.tsx.template +0 -3
  158. package/assets/assets/app/lib/setting/Setting.View.tsx.template +0 -20
  159. package/assets/assets/app/lib/setting/Setting.Zone.tsx.template +0 -49
  160. package/assets/assets/app/lib/setting/_server.ts.template +0 -19
  161. package/assets/assets/app/lib/setting/index.tsx.template +0 -30
  162. package/assets/assets/app/lib/setting/setting.constant.ts.template +0 -17
  163. package/assets/assets/app/lib/setting/setting.dictionary.ts.template +0 -18
  164. package/assets/assets/app/lib/setting/setting.document.ts.template +0 -20
  165. package/assets/assets/app/lib/setting/setting.service.ts.template +0 -12
  166. package/assets/assets/app/lib/setting/setting.signal.ts.template +0 -6
  167. package/assets/assets/app/lib/setting/setting.store.ts.template +0 -13
  168. package/assets/assets/app/lib/sig.ts.template +0 -3
  169. package/assets/assets/app/lib/srv.ts.template +0 -20
  170. package/assets/assets/app/lib/st.ts.template +0 -6
  171. package/assets/assets/app/lib/store.ts.template +0 -17
  172. package/assets/assets/app/lib/summary/Summary.Template.tsx.template +0 -12
  173. package/assets/assets/app/lib/summary/Summary.Unit.tsx.template +0 -7
  174. package/assets/assets/app/lib/summary/Summary.Util.tsx.template +0 -2
  175. package/assets/assets/app/lib/summary/Summary.View.tsx.template +0 -20
  176. package/assets/assets/app/lib/summary/Summary.Zone.tsx.template +0 -31
  177. package/assets/assets/app/lib/summary/_server.ts.template +0 -19
  178. package/assets/assets/app/lib/summary/index.tsx.template +0 -36
  179. package/assets/assets/app/lib/summary/summary.constant.ts.template +0 -16
  180. package/assets/assets/app/lib/summary/summary.dictionary.ts.template +0 -21
  181. package/assets/assets/app/lib/summary/summary.document.ts.template +0 -20
  182. package/assets/assets/app/lib/summary/summary.service.ts.template +0 -26
  183. package/assets/assets/app/lib/summary/summary.signal.ts.template +0 -6
  184. package/assets/assets/app/lib/summary/summary.store.ts.template +0 -13
  185. package/assets/assets/app/lib/usePage.ts.template +0 -5
  186. package/assets/assets/app/lib/user/User.Template.tsx.template +0 -34
  187. package/assets/assets/app/lib/user/User.Unit.tsx.template +0 -7
  188. package/assets/assets/app/lib/user/User.Util.tsx.template +0 -63
  189. package/assets/assets/app/lib/user/User.View.tsx.template +0 -35
  190. package/assets/assets/app/lib/user/User.Zone.tsx.template +0 -43
  191. package/assets/assets/app/lib/user/_server.ts.template +0 -19
  192. package/assets/assets/app/lib/user/index.tsx.template +0 -30
  193. package/assets/assets/app/lib/user/user.constant.ts.template +0 -31
  194. package/assets/assets/app/lib/user/user.dictionary.ts.template +0 -24
  195. package/assets/assets/app/lib/user/user.document.ts.template +0 -26
  196. package/assets/assets/app/lib/user/user.service.ts.template +0 -14
  197. package/assets/assets/app/lib/user/user.signal.spec.ts.template +0 -9
  198. package/assets/assets/app/lib/user/user.signal.test.ts.template +0 -11
  199. package/assets/assets/app/lib/user/user.signal.ts.template +0 -6
  200. package/assets/assets/app/lib/user/user.store.ts.template +0 -11
  201. package/assets/assets/app/main.ts.template +0 -12
  202. package/assets/assets/app/middleware.ts.template +0 -4
  203. package/assets/assets/app/nest/backendLogic.ts.template +0 -6
  204. package/assets/assets/app/nest/index.ts.template +0 -1
  205. package/assets/assets/app/next/frontendLogic.ts.template +0 -6
  206. package/assets/assets/app/next/index.ts.template +0 -1
  207. package/assets/assets/app/page.test.ts.template +0 -10
  208. package/assets/assets/app/playwright.config.ts.template +0 -6
  209. package/assets/assets/app/postcss.config.js.template +0 -10
  210. package/assets/assets/app/public/favicon.ico +0 -0
  211. package/assets/assets/app/public/icons/icon-128x128.png +0 -0
  212. package/assets/assets/app/public/icons/icon-144x144.png +0 -0
  213. package/assets/assets/app/public/icons/icon-152x152.png +0 -0
  214. package/assets/assets/app/public/icons/icon-192x192.png +0 -0
  215. package/assets/assets/app/public/icons/icon-256x256.png +0 -0
  216. package/assets/assets/app/public/icons/icon-384x384.png +0 -0
  217. package/assets/assets/app/public/icons/icon-48x48.png +0 -0
  218. package/assets/assets/app/public/icons/icon-512x512.png +0 -0
  219. package/assets/assets/app/public/icons/icon-72x72.png +0 -0
  220. package/assets/assets/app/public/icons/icon-96x96.png +0 -0
  221. package/assets/assets/app/public/logo.svg +0 -70
  222. package/assets/assets/app/public/manifest.json.template +0 -67
  223. package/assets/assets/app/server.ts.template +0 -30
  224. package/assets/assets/app/tsconfig.json.template +0 -22
  225. package/assets/assets/app/tsconfig.spec.json.template +0 -7
  226. package/assets/assets/app/ui/Footer.tsx.template +0 -36
  227. package/assets/assets/app/ui/MainHeader.tsx.template +0 -100
  228. package/assets/assets/app/ui/index.ts.template +0 -2
  229. package/assets/assets/crudPages/[__model__Id]/edit/page.tsx.template +0 -42
  230. package/assets/assets/crudPages/[__model__Id]/page.tsx.template +0 -52
  231. package/assets/assets/crudPages/new/page.tsx.template +0 -39
  232. package/assets/assets/crudPages/page.tsx.template +0 -40
  233. package/assets/assets/lib/.gitignore.template +0 -15
  234. package/assets/assets/lib/jest.config.ts.template +0 -7
  235. package/assets/assets/lib/package.json.template +0 -5
  236. package/assets/assets/lib/project.json.template +0 -10
  237. package/assets/assets/lib/tsconfig.json.template +0 -11
  238. package/assets/assets/lib/tsconfig.spec.json.template +0 -7
  239. package/assets/assets/module/__Model__.Template.tsx.template +0 -23
  240. package/assets/assets/module/__Model__.Unit.tsx.template +0 -11
  241. package/assets/assets/module/__Model__.Util.tsx.template +0 -39
  242. package/assets/assets/module/__Model__.View.tsx.template +0 -17
  243. package/assets/assets/module/__Model__.Zone.tsx.template +0 -52
  244. package/assets/assets/module/__model__.constant.ts.template +0 -44
  245. package/assets/assets/module/__model__.dictionary.ts.template +0 -70
  246. package/assets/assets/module/__model__.document.ts.template +0 -25
  247. package/assets/assets/module/__model__.service.ts.template +0 -13
  248. package/assets/assets/module/__model__.signal.spec.ts.template +0 -11
  249. package/assets/assets/module/__model__.signal.test.ts.template +0 -20
  250. package/assets/assets/module/__model__.signal.ts.template +0 -30
  251. package/assets/assets/module/__model__.store.ts.template +0 -11
  252. package/assets/assets/module/_server.ts.template +0 -18
  253. package/assets/assets/module/index.tsx.template +0 -30
  254. package/assets/assets/pkg/tsconfig.json.template +0 -12
  255. package/assets/assets/workplace/.gitignore.template +0 -195
  256. package/assets/assets/workplace/.prettierignore.template +0 -10
  257. package/assets/assets/workplace/.prettierrc.json.template +0 -5
  258. package/assets/assets/workplace/.swcrc.template +0 -9
  259. package/assets/assets/workplace/README.md.template +0 -28
  260. package/assets/assets/workplace/eslint.config.js.template +0 -141
  261. package/assets/assets/workplace/tsconfig.json.template +0 -29
  262. package/assets/crudPages/[__model__Id]/edit/page.tsx.template +0 -42
  263. package/assets/crudPages/[__model__Id]/page.tsx.template +0 -52
  264. package/assets/crudPages/new/page.tsx.template +0 -39
  265. package/assets/crudPages/page.tsx.template +0 -40
  266. package/assets/lib/.gitignore.template +0 -15
  267. package/assets/lib/jest.config.ts.template +0 -7
  268. package/assets/lib/package.json.template +0 -5
  269. package/assets/lib/project.json.template +0 -10
  270. package/assets/lib/tsconfig.json.template +0 -11
  271. package/assets/lib/tsconfig.spec.json.template +0 -7
  272. package/assets/module/__Model__.Template.tsx.template +0 -23
  273. package/assets/module/__Model__.Unit.tsx.template +0 -11
  274. package/assets/module/__Model__.Util.tsx.template +0 -39
  275. package/assets/module/__Model__.View.tsx.template +0 -17
  276. package/assets/module/__Model__.Zone.tsx.template +0 -52
  277. package/assets/module/__model__.constant.ts.template +0 -44
  278. package/assets/module/__model__.dictionary.ts.template +0 -70
  279. package/assets/module/__model__.document.ts.template +0 -25
  280. package/assets/module/__model__.service.ts.template +0 -13
  281. package/assets/module/__model__.signal.spec.ts.template +0 -11
  282. package/assets/module/__model__.signal.test.ts.template +0 -20
  283. package/assets/module/__model__.signal.ts.template +0 -30
  284. package/assets/module/__model__.store.ts.template +0 -11
  285. package/assets/module/_server.ts.template +0 -18
  286. package/assets/module/index.tsx.template +0 -30
  287. package/assets/pkg/tsconfig.json.template +0 -12
  288. package/assets/workplace/.gitignore.template +0 -195
  289. package/assets/workplace/.prettierignore.template +0 -10
  290. package/assets/workplace/.prettierrc.json.template +0 -5
  291. package/assets/workplace/.swcrc.template +0 -9
  292. package/assets/workplace/README.md.template +0 -28
  293. package/assets/workplace/eslint.config.js.template +0 -141
  294. package/assets/workplace/tsconfig.json.template +0 -29
@@ -1,42 +0,0 @@
1
- import { AiOutlineTeam } from "react-icons/ai";
2
- import { Load } from "@shared/ui";
3
- import { fetch, usePage, <%= Model %> } from "<%= clientPath %>";
4
- import type { CsrConfig } from "@akanjs/client";
5
-
6
- interface PageProps {
7
- params: { <%= model %>Id: string };
8
- }
9
-
10
- export default function Page({ params }: PageProps) {
11
- const { l } = usePage();
12
- return (
13
- <Load.Page
14
- of={Page}
15
- loader={async () => {
16
- const { <%= model %>Id } = await params;
17
- const { <%= model %>, <%= model %>Edit } = await fetch.edit<%= Model %>(<%= model %>Id);
18
- return { <%= model %>, <%= model %>Edit } as const;
19
- }}
20
- render={({ <%= model %>, <%= model %>Edit }) => (
21
- <div className="container">
22
- <div className="flex justify-between m-4 mt-8">
23
- <div className="text-xl text-primary flex gap-2 items-center">
24
- <AiOutlineTeam /> {l("shared.updateModel", { model: l("<%= model %>.modelName") })}
25
- </div>
26
- </div>
27
- <Load.Edit
28
- className="flex flex-col items-center"
29
- sliceName="<%= model %>InPublic"
30
- edit={<%= model %>Edit}
31
- type="form"
32
- onCancel="back"
33
- onSubmit="/<%= model %>"
34
- >
35
- <<%= Model %>.Template.General />
36
- </Load.Edit>
37
- </div>
38
- )}
39
- />
40
- );
41
- }
42
- Page.csrConfig = { transition: "none" } satisfies CsrConfig;
@@ -1,52 +0,0 @@
1
- import { <%= Model %>, fetch, usePage } from "<%= clientPath %>";
2
- import { Link } from "@util/ui";
3
- import { Load } from "@shared/ui";
4
- import { getSelf } from "@akanjs/client";
5
- import { AiOutlineEdit } from "react-icons/ai";
6
- import type { CsrConfig } from "@akanjs/client";
7
-
8
- interface PageProps {
9
- params: { <%= model %>Id: string };
10
- }
11
-
12
- export async function generateMetadata({ params }: PageProps) {
13
- const { <%= model %>Id } = await params;
14
- const { <%= model %> } = await fetch.view<%= Model %>(<%= model %>Id);
15
- return {
16
- title: <%= model %>.id,
17
- description: <%= model %>.id,
18
- openGraph: {
19
- title: <%= model %>.id,
20
- description: <%= model %>.id,
21
- // images: <%= model %>.thumbnails.map((i) => i.url),
22
- },
23
- };
24
- }
25
- export default function Page({ params }: PageProps) {
26
- const { l } = usePage();
27
- const self = getSelf({ unauthorize: "/signin" });
28
- return (
29
- <Load.Page
30
- of={Page}
31
- loader={async () => {
32
- const { <%= model %>Id } = await params;
33
- const { <%= model %>, <%= model %>View } = await fetch.view<%= Model %>(<%= model %>Id);
34
- return { <%= model %>, <%= model %>View } as const;
35
- }}
36
- render={({ <%= model %>, <%= model %>View }) => (
37
- <div className="container flex flex-col gap-4">
38
- <div className="flex gap-4 font-bold text-lg items-center">
39
- <<%= Model %>.Zone.View view={<%= model %>View} />
40
- <Link href={`/<%= model %>/${<%= model %>.id}/edit`}>
41
- <button className="btn">
42
- <AiOutlineEdit />
43
- {l("shared.updateModel", { model: l("<%= model %>.modelName") })}
44
- </button>
45
- </Link>
46
- </div>
47
- </div>
48
- )}
49
- />
50
- );
51
- }
52
- Page.csrConfig = { transition: "none" } satisfies CsrConfig;
@@ -1,39 +0,0 @@
1
- import { AiOutlineTeam } from "react-icons/ai";
2
- import { Load } from "@shared/ui";
3
- import { cnst, fetch, usePage, <%= Model %> } from "<%= clientPath %>";
4
- import { getSelf } from "@akanjs/client";
5
- import type { CsrConfig } from "@akanjs/client";
6
-
7
- export default function Page() {
8
- const { l } = usePage();
9
- const self = getSelf({ unauthorize: "/signin" });
10
- return (
11
- <Load.Page
12
- of={Page}
13
- loader={async () => {
14
- const <%= model %>Form: Partial<cnst.<%= Model %>> = {};
15
- return { <%= model %>Form } as const;
16
- }}
17
- render={({ <%= model %>Form }) => (
18
- <div className="container">
19
- <div className="flex justify-between m-4 mt-8">
20
- <div className="text-xl text-primary flex gap-2 items-center">
21
- <AiOutlineTeam /> {l("shared.createModel", { model: l("<%= model %>.modelName") })}
22
- </div>
23
- </div>
24
- <Load.Edit
25
- className="flex flex-col items-center"
26
- sliceName="<%= model %>InPublic"
27
- edit={<%= model %>Form}
28
- type="form"
29
- onCancel="back"
30
- onSubmit="/<%= model %>"
31
- >
32
- <<%= Model %>.Template.General />
33
- </Load.Edit>
34
- </div>
35
- )}
36
- />
37
- );
38
- }
39
- Page.csrConfig = { transition: "none" } satisfies CsrConfig;
@@ -1,40 +0,0 @@
1
- import { <%= Model %>, fetch, usePage } from "<%= clientPath %>";
2
- import { Link } from "@util/ui";
3
- import { Load } from "@shared/ui";
4
- import { getSelf } from "@akanjs/client";
5
- import type { CsrConfig } from "@akanjs/client";
6
-
7
- export default function Page() {
8
- const { l } = usePage();
9
- const self = getSelf({ unauthorize: "/signin" });
10
- return (
11
- <Load.Page
12
- of={Page}
13
- loader={async () => {
14
- const { <%= model %>InitInPublic } = await fetch.init<%= Model %>InPublic();
15
- return { <%= model %>InitInPublic } as const;
16
- }}
17
- render={({ <%= model %>InitInPublic }) => (
18
- <div className="container flex flex-col gap-4">
19
- <div className="w-full mt-5 px-5 h-full ">
20
- <div>{l("<%= model %>.modelName")}</div>
21
- <div className="animate-fadeIn px-4 pt-4 flex gap-4 items-center">
22
- <div className="font-bold text-lg md:text-4xl"><%= Model %>s</div>
23
- <Link href={`/<%= model %>/new`}>
24
- <button className="btn">+ {l("shared.createModel", { model: l("<%= model %>.modelName") })}</button>
25
- </Link>
26
- </div>
27
- <div>{l("<%= model %>.modelDesc")}</div>
28
- <div className="flex px-6 mt-3 gap-4">
29
- <<%= Model %>.Zone.Card
30
- className="animate-fadeIn grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 2xl:grid-cols-5 justify-center gap-4 w-full"
31
- init={<%= model %>InitInPublic}
32
- />
33
- </div>
34
- </div>
35
- </div>
36
- )}
37
- />
38
- );
39
- }
40
- Page.csrConfig = { transition: "none" } satisfies CsrConfig;
@@ -1,15 +0,0 @@
1
- **/script.ts
2
- **/script*.ts
3
- **/.env
4
- **/env.client.debug.ts*
5
- **/env.client.develop.ts*
6
- **/env.client.main.ts*
7
- **/env.client.testing.ts*
8
- **/env.server.debug.ts*
9
- **/env.server.develop.ts*
10
- **/env.server.main.ts*
11
- **/env.server.testing.ts*
12
-
13
- # System Files
14
- .DS_Store
15
- Thumbs.db
@@ -1,7 +0,0 @@
1
- import "tsconfig-paths/register";
2
-
3
- import { withBase } from "@akanjs/test/src/jest.config.base";
4
-
5
- const config = withBase("platform");
6
-
7
- export default config;
@@ -1,5 +0,0 @@
1
- {
2
- "name": "@platform",
3
- "version": "0.0.1",
4
- "type": "commonjs"
5
- }
@@ -1,10 +0,0 @@
1
- {
2
- "name": "platform",
3
- "$schema": "../../node_modules/nx/schemas/project-schema.json",
4
- "sourceRoot": "libs/platform",
5
- "projectType": "library",
6
- "targets": {
7
- "test": { "executor": "@nx/jest:jest" },
8
- "lint": { "executor": "@nx/eslint:lint" }
9
- }
10
- }
@@ -1,11 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json",
3
- "compilerOptions": {
4
- "jsx": "preserve"
5
- },
6
- "references": [
7
- {
8
- "path": "./tsconfig.spec.json"
9
- }
10
- ]
11
- }
@@ -1,7 +0,0 @@
1
- {
2
- "extends": "./tsconfig.json",
3
- "compilerOptions": {
4
- "types": ["jest", "node"]
5
- },
6
- "include": ["jest.config.ts", "**/*.test.ts"]
7
- }
@@ -1,23 +0,0 @@
1
- "use client";
2
- import { cnst, st, usePage } from "<%= clientPath %>";
3
- import { Field } from "@shared/ui";
4
- import { Layout } from "@util/ui";
5
-
6
- interface <%= Model %>EditProps {
7
- <%= model %>Id?: string | null;
8
- }
9
-
10
- export const General = ({ <%= model %>Id = undefined }: <%= Model %>EditProps) => {
11
- const <%= model %>Form = st.use.<%= model %>Form();
12
- const { l } = usePage();
13
- return (
14
- <Layout.Template>
15
- <Field.Text
16
- label={l.field("<%= model %>", "id")}
17
- desc={l.desc("<%= model %>", "id")}
18
- value={<%= model %>Form.id}
19
- onChange={st.do.setIdOn<%= Model %>}
20
- />
21
- </Layout.Template>
22
- );
23
- };
@@ -1,11 +0,0 @@
1
- import { ModelProps } from "@akanjs/client";
2
- import { cnst, <%= Model %> } from "<%= clientPath %>";
3
- import { Link } from "@util/ui";
4
-
5
- export const Card = ({ <%= model %>, href }: ModelProps<"<%= model %>", cnst.Light<%= Model %>>) => {
6
- return (
7
- <Link href={href} className="animate-fadeIn w-full h-36 flex rounded-lg shadow-sm hover:shadow-lg duration-300">
8
- <div>{<%= model %>.id}</div>
9
- </Link>
10
- );
11
- };
@@ -1,39 +0,0 @@
1
- "use client";
2
- import { ModelDashboardProps, ModelInsightProps } from "@akanjs/client";
3
- import { getQueryMap } from "@akanjs/constant";
4
- import { cnst } from "<%= clientPath %>";
5
- import { Data } from "@shared/ui";
6
-
7
- export const Stat = ({
8
- className,
9
- summary,
10
- sliceName = "<%= model %>",
11
- queryMap = getQueryMap(cnst.<%= Model %>Summary),
12
- hidePresents,
13
- }: ModelDashboardProps<cnst.Summary>) => {
14
- return (
15
- <Data.Dashboard
16
- className={className}
17
- summary={summary}
18
- sliceName={sliceName}
19
- queryMap={queryMap}
20
- columns={["total<%= Model %>"]}
21
- hidePresents={hidePresents}
22
- />
23
- );
24
- };
25
-
26
- export const Insight = ({
27
- className,
28
- insight,
29
- sliceName = "<%= model %>",
30
- }: ModelInsightProps<cnst.<%= Model %>Insight>) => {
31
- return (
32
- <Data.Insight
33
- className={className}
34
- insight={insight}
35
- sliceName={sliceName}
36
- columns={["count"]}
37
- />
38
- );
39
- };
@@ -1,17 +0,0 @@
1
- import { clsx } from "@akanjs/client";
2
- import { cnst } from "<%= clientPath %>";
3
- import { Image } from "@util/ui";
4
-
5
- interface <%= Model %>ViewProps {
6
- className?: string;
7
- <%= model %>: cnst.<%= Model %>;
8
- self?: { id?: string } | null;
9
- }
10
-
11
- export const General = ({ className, <%= model %>, self }: <%= Model %>ViewProps) => {
12
- return (
13
- <div className={clsx(className, `animate-fadeIn w-full`)}>
14
- <div>{<%= model %>.id}</div>
15
- </div>
16
- );
17
- };
@@ -1,52 +0,0 @@
1
- "use client";
2
- import { Data, Load } from "@shared/ui";
3
- import { ModelsProps } from "@akanjs/client";
4
- import { cnst, <%= Model %> } from "<%= clientPath %>";
5
- import { ClientInit, ClientView, DefaultOf } from "@akanjs/signal";
6
-
7
- export const Admin = ({ sliceName = "<%= model %>", init, query }: ModelsProps<cnst.<%= Model %>>) => {
8
- return (
9
- <Data.ListContainer
10
- init={init}
11
- query={query}
12
- sliceName={sliceName}
13
- renderItem={<%= Model %>.Unit.Card}
14
- renderDashboard={<%= Model %>.Util.Stat}
15
- renderInsight={<%= Model %>.Util.Insight}
16
- renderTemplate={<%= Model %>.Template.General}
17
- renderTitle={(<%= model %>: DefaultOf<cnst.<%= Model %>>) => `<%= Model %> - ${<%= model %>.id ? <%= model %>.id : "New"}`}
18
- renderView={(<%= model %>: cnst.<%= Model %>) => <<%= Model %>.View.General <%= model %>={<%= model %>} />}
19
- columns={[
20
- "id",
21
- "status",
22
- "createdAt",
23
- "updatedAt",
24
- ]}
25
- actions={(<%= model %>: cnst.Light<%= Model %>, idx) => ["remove", "edit", "view"]}
26
- />
27
- );
28
- };
29
-
30
- interface CardProps {
31
- className?: string;
32
- init: ClientInit<"<%= model %>", cnst.Light<%= Model %>>;
33
- }
34
- export const Card = ({ className, init }: CardProps) => {
35
- return (
36
- <Load.Units
37
- className={className}
38
- init={init}
39
- renderItem={(<%= model %>: cnst.Light<%= Model %>) => (
40
- <<%= Model %>.Unit.Card key={<%= model %>.id} href={`/<%= model %>/${<%= model %>.id}`} <%= model %>={<%= model %>} />
41
- )}
42
- />
43
- );
44
- };
45
-
46
- interface ViewProps {
47
- className?: string;
48
- view: ClientView<"<%= model %>", cnst.<%= Model %>>;
49
- }
50
- export const View = ({ view }: ViewProps) => {
51
- return <Load.View view={view} renderView={(<%= model %>) => <<%= Model %>.View.General <%= model %>={<%= model %>} />} />;
52
- };
@@ -1,44 +0,0 @@
1
- import { enumOf, Int } from "@akanjs/base";
2
- import { Field, Filter, Model, sortOf, via } from "@akanjs/constant";
3
-
4
- export const <%= Model %>Status = enumOf(["active"] as const);
5
- export type <%= Model %>Status = enumOf<typeof <%= Model %>Status>;
6
-
7
- export const <%= Model %>Target = enumOf(["_blank", "_self"] as const);
8
- export type <%= Model %>Target = enumOf<typeof <%= Model %>Target>;
9
-
10
- @Model.Input("<%= Model %>Input")
11
- export class <%= Model %>Input {
12
- @Field.Prop(() => String, { nullable: true })
13
- field: string | null;
14
- }
15
-
16
- @Model.Object("<%= Model %>Object")
17
- export class <%= Model %>Object extends via(<%= Model %>Input) {
18
- @Field.Prop(() => String, { enum: <%= Model %>Status, default: "active" })
19
- status: <%= Model %>Status;
20
- }
21
-
22
- @Model.Light("Light<%= Model %>")
23
- export class Light<%= Model %> extends via(<%= Model %>Object, [
24
- "field",
25
- "status",
26
- ] as const) {}
27
-
28
- @Model.Full("<%= Model %>")
29
- export class <%= Model %> extends via(<%= Model %>Object, Light<%= Model %>) {}
30
-
31
- @Model.Insight("<%= Model %>Insight")
32
- export class <%= Model %>Insight {
33
- @Field.Prop(() => Int, { default: 0, accumulate: { $sum: 1 } })
34
- count: number;
35
- }
36
-
37
- @Model.Summary("<%= Model %>Summary")
38
- export class <%= Model %>Summary {
39
- @Field.Prop(() => Int, { min: 0, default: 0, query: {} })
40
- total<%= Model %>: number;
41
- }
42
-
43
- @Model.Filter("<%= Model %>Filter")
44
- export class <%= Model %>Filter extends sortOf(<%= Model %>, {}) {}
@@ -1,70 +0,0 @@
1
- import {
2
- baseTrans,
3
- getBaseSignalTrans,
4
- ModelDictionary,
5
- SignalDictionary,
6
- SummaryDictionary,
7
- } from "@akanjs/dictionary";
8
-
9
- import type { <%= Model %>, <%= Model %>Filter, <%= Model %>Insight, <%= Model %>Summary } from "./<%= model %>.constant";
10
- import type { <%= Model %>Signal } from "./<%= model %>.signal";
11
-
12
- const modelDictionary = {
13
- ...baseTrans,
14
- modelName: ["<%= Model %>", "<%= Model %>"],
15
- modelDesc: [
16
- "<%= Model %> description",
17
- "<%= Model %> 설명",
18
- ],
19
-
20
- // * ==================== Model ==================== * //
21
- field: ["Field", "필드"],
22
- "desc-field": ["Field", "필드"],
23
- // * ==================== Model ==================== * //
24
-
25
- // * ==================== Insight ==================== * //
26
- count: ["Count", "개수"],
27
- "desc-count": ["<%= Model %> count in current query settting", "현재 쿼리 설정에 맞는 배너 수"],
28
- // * ==================== Insight ==================== * //
29
-
30
- // * ==================== Filter ==================== * //
31
- // * ==================== Filter ==================== * //
32
-
33
- // * ==================== Etc ==================== * //
34
- "enum-status-active": ["Active", "활성"],
35
- "enumdesc-status-active": ["Active status", "활성 상태"],
36
- // * ==================== Etc ==================== * //
37
- } satisfies ModelDictionary<<%= Model %>, <%= Model %>Insight, <%= Model %>Filter>;
38
-
39
- export const <%= model %>SummaryDictionary = {
40
- // * ==================== Summary ==================== * //
41
- total<%= Model %>: ["Total<%= Model %>", "총 배너 수"],
42
- "desc-total<%= Model %>": ["Total <%= model %> count in the database", "데이터베이스에 저장된 총 배너 수"],
43
- // * ==================== Summary ==================== * //
44
- } satisfies SummaryDictionary<<%= Model %>Summary>;
45
-
46
- const signalDictionary = {
47
- ...getBaseSignalTrans("<%= model %>" as const),
48
- // * ==================== Endpoint ==================== * //
49
- "api-<%= model %>ListInPublic": ["<%= Model %> List In Public", "공개된 <%= Model %> 리스트"],
50
- "apidesc-<%= model %>ListInPublic": ["Get a list of public <%= model %>", "공개된 <%= Model %>의 리스트를 가져옵니다"],
51
- "arg-<%= model %>ListInPublic-statuses": ["Statuses", "상태"],
52
- "argdesc-<%= model %>ListInPublic-statuses": ["Statuses to filter", "필터링할 상태"],
53
- "arg-<%= model %>ListInPublic-skip": ["Skip", "건너뛰기"],
54
- "argdesc-<%= model %>ListInPublic-skip": ["Number of items to skip", "건너뛸 아이템 수"],
55
- "arg-<%= model %>ListInPublic-limit": ["Limit", "제한"],
56
- "argdesc-<%= model %>ListInPublic-limit": ["Maximum number of items to return", "반환할 최대 아이템 수"],
57
- "arg-<%= model %>ListInPublic-sort": ["Sort", "정렬"],
58
- "argdesc-<%= model %>ListInPublic-sort": ["Sort order of the items", "아이템의 정렬 순서"],
59
-
60
- "api-<%= model %>InsightInPublic": ["<%= Model %> Insight In Public", "공개된 <%= Model %> 인사이트"],
61
- "apidesc-<%= model %>InsightInPublic": [
62
- "Get insight data for public <%= model %>",
63
- "공개된 <%= Model %>에 대한 인사이트 데이터를 가져옵니다",
64
- ],
65
- "arg-<%= model %>InsightInPublic-statuses": ["Statuses", "상태"],
66
- "argdesc-<%= model %>InsightInPublic-statuses": ["Statuses to filter", "필터링할 상태"],
67
- // * ==================== Endpoint ==================== * //
68
- } satisfies SignalDictionary<<%= Model %>Signal, <%= Model %>>;
69
-
70
- export const <%= model %>Dictionary = { ...modelDictionary, ...signalDictionary };
@@ -1,25 +0,0 @@
1
- import { beyond, by, Database, into, type SchemaOf } from "@akanjs/document";
2
-
3
- import { cnst } from "../cnst";
4
-
5
- @Database.Input(() => cnst.<%= Model %>Input)
6
- export class <%= Model %>Input extends by(cnst.<%= Model %>Input) {}
7
-
8
- @Database.Document(() => cnst.<%= Model %>)
9
- export class <%= Model %> extends by(cnst.<%= Model %>) {}
10
-
11
- @Database.Model(() => cnst.<%= Model %>)
12
- export class <%= Model %>Model extends into(<%= Model %>, cnst.<%= model %>Cnst) {
13
- async getSummary(): Promise<cnst.<%= Model %>Summary> {
14
- return {
15
- ...(await this.getDefaultSummary()),
16
- };
17
- }
18
- }
19
-
20
- @Database.Middleware(() => cnst.<%= Model %>)
21
- export class <%= Model %>Middleware extends beyond(<%= Model %>Model, <%= Model %>) {
22
- onSchema(schema: SchemaOf<<%= Model %>Model, <%= Model %>>) {
23
- // schema.index({ status: 1 })
24
- }
25
- }
@@ -1,13 +0,0 @@
1
- import { DbService, Service } from "@akanjs/service";
2
-
3
- import { cnst } from "../cnst";
4
- import * as db from "../db";
5
-
6
- @Service("<%= Model %>Service")
7
- export class <%= Model %>Service extends DbService(db.<%= model %>Db) {
8
- async summarize(): Promise<cnst.<%= Model %>Summary> {
9
- return {
10
- ...(await this.<%= model %>Model.getSummary()),
11
- };
12
- }
13
- }
@@ -1,11 +0,0 @@
1
- import * as adminSpec from "@shared/lib/admin/admin.signal.spec";
2
- import * as userSpec from "<%= libPath %>/user/user.signal.spec";
3
- import { cnst } from "../cnst";
4
- import { fetch } from "../fetch";
5
- import { sampleOf } from "@akanjs/test";
6
-
7
- export const create<%= Model %> = async (adminAgent: userSpec.AdminAgent, userAgent: userSpec.UserAgent) => {
8
- const <%= model %>Input = sampleOf(cnst.<%= Model %>Input);
9
- const <%= model %> = await adminAgent.fetch.create<%= Model %>(<%= model %>Input);
10
- return <%= model %>;
11
- };
@@ -1,20 +0,0 @@
1
- import * as adminSpec from "@shared/lib/admin/admin.signal.spec";
2
- import * as userSpec from "<%= libPath %>/user/user.signal.spec";
3
- import * as <%= model %>Spec from "<%= libPath %>/<%= model %>/<%= model %>.signal.spec";
4
- import { cnst } from "../cnst";
5
- import { fetch } from "../fetch";
6
-
7
- describe("<%= Model %> Signal", () => {
8
- describe("<%= Model %> Service", () => {
9
- let adminAgent: userSpec.AdminAgent;
10
- let userAgent: userSpec.UserAgent;
11
- let <%= model %>: cnst.<%= Model %>;
12
- beforeAll(async () => {
13
- // adminAgent = await adminSpec.getAdminAgentWithInitialize();
14
- // userAgent = await userSpec.getUserAgentWithPhone();
15
- });
16
- it("can create <%= model %>", async () => {
17
- // <%= model %> = await <%= model %>Spec.create<%= Model %>(adminAgent, userAgent);
18
- });
19
- });
20
- });
@@ -1,30 +0,0 @@
1
- import { Int } from "@akanjs/base";
2
- import { SortOf } from "@akanjs/constant";
3
- import { Arg, DbSignal, Mutation, Query, resolve, Signal } from "@akanjs/signal";
4
-
5
- import { cnst, Srvs } from "../cnst";
6
-
7
- @Signal(() => cnst.<%= Model %>)
8
- export class <%= Model %>Signal extends DbSignal(cnst.<%= model %>Cnst, Srvs, {
9
- guards: { get: Query.Public, cru: Mutation.Public },
10
- }) {
11
- // * /////////////////////////////////////
12
- // * Public Slice
13
- @Query.Public(() => [cnst.<%= Model %>])
14
- async <%= model %>ListInPublic(
15
- @Arg.Query("statuses", () => [String], { nullable: true }) statuses: cnst.<%= Model %>Status[] | null,
16
- @Arg.Query("skip", () => Int, { nullable: true }) skip: number | null,
17
- @Arg.Query("limit", () => Int, { nullable: true }) limit: number | null,
18
- @Arg.Query("sort", () => String, { nullable: true }) sort: SortOf<cnst.<%= Model %>Filter> | null
19
- ) {
20
- const <%= models %> = await this.<%= model %>Service.listByStatuses(statuses, { skip, limit, sort });
21
- return resolve<cnst.<%= Model %>[]>(<%= models %>);
22
- }
23
- @Query.Public(() => cnst.<%= Model %>Insight)
24
- async <%= model %>InsightInPublic(@Arg.Query("statuses", () => [String], { nullable: true }) statuses: cnst.<%= Model %>Status[] | null) {
25
- const <%= model %>Insight = await this.<%= model %>Service.insightByStatuses(statuses);
26
- return resolve<cnst.<%= Model %>Insight>(<%= model %>Insight);
27
- }
28
- // * Public Slice
29
- // * /////////////////////////////////////
30
- }
@@ -1,11 +0,0 @@
1
- import { stateOf, Store } from "@akanjs/store";
2
-
3
- import { cnst } from "../cnst";
4
- import { fetch } from "../fetch";
5
-
6
- @Store(() => cnst.<%= Model %>)
7
- export class <%= Model %>Store extends stateOf(fetch.<%= model %>Gql, {
8
- // state
9
- }) {
10
- // action
11
- }
@@ -1,18 +0,0 @@
1
- import { databaseModuleOf } from "@akanjs/server";
2
-
3
- import * as db from "../db";
4
- import { <%= Model %>Service } from "./<%= model %>.service";
5
- import { <%= Model %>Signal } from "./<%= model %>.signal";
6
- import { allSrvs } from "../srv";
7
- import { cnst } from "../cnst";
8
-
9
- export const register<%= Model %>Module = () =>
10
- databaseModuleOf(
11
- {
12
- constant: cnst.<%= model %>Cnst,
13
- database: db.<%= model %>Db,
14
- signal: <%= Model %>Signal,
15
- service: <%= Model %>Service,
16
- },
17
- allSrvs
18
- );