nextjs-cms 0.9.35 → 0.9.37

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 (114) hide show
  1. package/dist/api/actions/pages.d.ts +3 -3
  2. package/dist/api/trpc/root.d.ts +3 -3
  3. package/dist/api/trpc/routers/navigation.d.ts +3 -3
  4. package/dist/api/trpc/server.d.ts +9 -9
  5. package/dist/cli/lib/update-sections.d.ts.map +1 -1
  6. package/dist/cli/lib/update-sections.js +43 -10
  7. package/dist/core/config/config-loader.d.ts +2 -2
  8. package/dist/core/fields/date-range.d.ts +4 -4
  9. package/dist/core/fields/slug.d.ts +55 -3
  10. package/dist/core/fields/slug.d.ts.map +1 -1
  11. package/dist/core/fields/slug.js +56 -2
  12. package/dist/core/sections/category.d.ts +4 -4
  13. package/dist/core/sections/hasItems.d.ts +4 -4
  14. package/dist/core/sections/section.d.ts +3 -3
  15. package/dist/core/sections/simple.d.ts +4 -4
  16. package/dist/core/submit/ItemEditSubmit.js +5 -5
  17. package/dist/translations/base/en.d.ts +3 -0
  18. package/dist/translations/base/en.d.ts.map +1 -1
  19. package/dist/translations/base/en.js +3 -0
  20. package/dist/translations/client.d.ts +40 -4
  21. package/dist/translations/client.d.ts.map +1 -1
  22. package/dist/translations/server.d.ts +40 -4
  23. package/dist/translations/server.d.ts.map +1 -1
  24. package/package.json +6 -3
  25. package/dist/api/axios/axiosInstance.d.ts +0 -2
  26. package/dist/api/axios/axiosInstance.d.ts.map +0 -1
  27. package/dist/api/axios/axiosInstance.js +0 -8
  28. package/dist/api/client.d.ts +0 -30
  29. package/dist/api/client.d.ts.map +0 -1
  30. package/dist/api/client.js +0 -82
  31. package/dist/api/index.d.ts +0 -2
  32. package/dist/api/index.d.ts.map +0 -1
  33. package/dist/api/index.js +0 -0
  34. package/dist/api/lib/serverActions.d.ts +0 -338
  35. package/dist/api/lib/serverActions.d.ts.map +0 -1
  36. package/dist/api/lib/serverActions.js +0 -1517
  37. package/dist/api/root.d.ts +0 -19
  38. package/dist/api/root.d.ts.map +0 -1
  39. package/dist/api/root.js +0 -50
  40. package/dist/api/routers/accountSettings.d.ts +0 -66
  41. package/dist/api/routers/accountSettings.d.ts.map +0 -1
  42. package/dist/api/routers/accountSettings.js +0 -202
  43. package/dist/api/routers/admins.d.ts +0 -112
  44. package/dist/api/routers/admins.d.ts.map +0 -1
  45. package/dist/api/routers/admins.js +0 -323
  46. package/dist/api/routers/auth.d.ts +0 -54
  47. package/dist/api/routers/auth.d.ts.map +0 -1
  48. package/dist/api/routers/auth.js +0 -50
  49. package/dist/api/routers/categorySection.d.ts +0 -105
  50. package/dist/api/routers/categorySection.d.ts.map +0 -1
  51. package/dist/api/routers/categorySection.js +0 -49
  52. package/dist/api/routers/config.d.ts +0 -48
  53. package/dist/api/routers/config.d.ts.map +0 -1
  54. package/dist/api/routers/config.js +0 -18
  55. package/dist/api/routers/cpanel.d.ts +0 -82
  56. package/dist/api/routers/cpanel.d.ts.map +0 -1
  57. package/dist/api/routers/cpanel.js +0 -216
  58. package/dist/api/routers/fields.d.ts +0 -35
  59. package/dist/api/routers/fields.d.ts.map +0 -1
  60. package/dist/api/routers/fields.js +0 -81
  61. package/dist/api/routers/files.d.ts +0 -34
  62. package/dist/api/routers/files.d.ts.map +0 -1
  63. package/dist/api/routers/files.js +0 -14
  64. package/dist/api/routers/gallery.d.ts +0 -35
  65. package/dist/api/routers/gallery.d.ts.map +0 -1
  66. package/dist/api/routers/gallery.js +0 -92
  67. package/dist/api/routers/hasItemsSection.d.ts +0 -194
  68. package/dist/api/routers/hasItemsSection.d.ts.map +0 -1
  69. package/dist/api/routers/hasItemsSection.js +0 -86
  70. package/dist/api/routers/logs.d.ts +0 -59
  71. package/dist/api/routers/logs.d.ts.map +0 -1
  72. package/dist/api/routers/logs.js +0 -76
  73. package/dist/api/routers/navigation.d.ts +0 -50
  74. package/dist/api/routers/navigation.d.ts.map +0 -1
  75. package/dist/api/routers/navigation.js +0 -11
  76. package/dist/api/routers/simpleSection.d.ts +0 -93
  77. package/dist/api/routers/simpleSection.d.ts.map +0 -1
  78. package/dist/api/routers/simpleSection.js +0 -54
  79. package/dist/api/server.d.ts +0 -2748
  80. package/dist/api/server.d.ts.map +0 -1
  81. package/dist/api/server.js +0 -100
  82. package/dist/api/trpc/error-logging.d.ts +0 -14
  83. package/dist/api/trpc/error-logging.d.ts.map +0 -1
  84. package/dist/api/trpc/error-logging.js +0 -75
  85. package/dist/api/trpc.d.ts +0 -111
  86. package/dist/api/trpc.d.ts.map +0 -1
  87. package/dist/api/trpc.js +0 -99
  88. package/dist/api/utils/async-caller-proxy.d.ts +0 -2
  89. package/dist/api/utils/async-caller-proxy.d.ts.map +0 -1
  90. package/dist/api/utils/async-caller-proxy.js +0 -36
  91. package/dist/api/utils/lazy-caller-proxy.d.ts +0 -2
  92. package/dist/api/utils/lazy-caller-proxy.d.ts.map +0 -1
  93. package/dist/api/utils/lazy-caller-proxy.js +0 -36
  94. package/dist/api/utils/router-types.d.ts +0 -7
  95. package/dist/api/utils/router-types.d.ts.map +0 -1
  96. package/dist/api/utils/router-types.js +0 -0
  97. package/dist/auth/axios/axiosInstance.d.ts +0 -2
  98. package/dist/auth/axios/axiosInstance.d.ts.map +0 -1
  99. package/dist/auth/axios/axiosInstance.js +0 -8
  100. package/dist/auth/hooks/useAxiosPrivate.d.ts +0 -5
  101. package/dist/auth/hooks/useAxiosPrivate.d.ts.map +0 -1
  102. package/dist/auth/hooks/useAxiosPrivate.js +0 -74
  103. package/dist/auth/trpc.d.ts +0 -6
  104. package/dist/auth/trpc.d.ts.map +0 -1
  105. package/dist/auth/trpc.js +0 -81
  106. package/dist/plugins/manifest.d.ts +0 -28
  107. package/dist/plugins/manifest.d.ts.map +0 -1
  108. package/dist/plugins/manifest.js +0 -83
  109. package/dist/plugins/registry.d.ts +0 -22
  110. package/dist/plugins/registry.d.ts.map +0 -1
  111. package/dist/plugins/registry.js +0 -25
  112. package/dist/utils/log.d.ts +0 -18
  113. package/dist/utils/log.d.ts.map +0 -1
  114. package/dist/utils/log.js +0 -28
@@ -1,194 +0,0 @@
1
- import * as z from 'zod';
2
- export declare const hasItemsSectionRouter: import("@trpc/server").TRPCBuiltRouter<{
3
- ctx: {
4
- headers: Headers;
5
- db: import("drizzle-orm/mysql2").MySql2Database<typeof import("../../db/schema.js")> & {
6
- $client: import("mysql2/promise").Pool;
7
- };
8
- session: import("../../index.js").Session | null;
9
- };
10
- meta: object;
11
- errorShape: {
12
- data: {
13
- zodError: z.core.$ZodFlattenedError<unknown, string> | null;
14
- code: import("@trpc/server").TRPC_ERROR_CODE_KEY;
15
- httpStatus: number;
16
- path?: string;
17
- stack?: string;
18
- };
19
- message: string;
20
- code: import("@trpc/server").TRPC_ERROR_CODE_NUMBER;
21
- };
22
- transformer: true;
23
- }, import("@trpc/server").TRPCDecorateCreateRouterOptions<{
24
- listItems: import("@trpc/server").TRPCQueryProcedure<{
25
- input: {
26
- sectionName: string;
27
- page?: number | undefined;
28
- q?: string | undefined;
29
- };
30
- output: {
31
- error: {
32
- message: string;
33
- };
34
- section?: undefined;
35
- items?: undefined;
36
- totalCount?: undefined;
37
- } | {
38
- section: {
39
- hasSearch: boolean;
40
- name: string;
41
- title: string;
42
- };
43
- items: (Record<string, any> | {
44
- id: string | number;
45
- headingTitle: string;
46
- coverPhoto: string | null;
47
- createdAt: string;
48
- createdBy: string;
49
- permission: number;
50
- })[];
51
- totalCount: any;
52
- error?: undefined;
53
- };
54
- meta: object;
55
- }>;
56
- newItem: import("@trpc/server").TRPCQueryProcedure<{
57
- input: {
58
- sectionName: string;
59
- };
60
- output: {
61
- error: {
62
- message: any;
63
- };
64
- section?: undefined;
65
- inputGroups?: undefined;
66
- defaultLocale?: undefined;
67
- } | {
68
- section: {
69
- name: string;
70
- title: {
71
- section: string;
72
- singular: string;
73
- plural: string;
74
- };
75
- gallery: import("../../index.js").SectionGallery | undefined;
76
- variants: import("../../core/types/index.js").Variant[] | undefined;
77
- configFile: string;
78
- };
79
- inputGroups: {
80
- groupId: number;
81
- groupTitle: string;
82
- groupOrder: number;
83
- inputs: {
84
- type: import("../../core/types/index.js").FieldType;
85
- name: string;
86
- label: string;
87
- required: boolean;
88
- localized?: boolean;
89
- conditionalFields: import("../../core/types/index.js").ConditionalField[];
90
- readonly: boolean;
91
- defaultValue: any;
92
- value: any;
93
- }[];
94
- }[] | undefined;
95
- defaultLocale: {
96
- code: string;
97
- label: string;
98
- rtl?: boolean;
99
- } | null;
100
- error?: undefined;
101
- };
102
- meta: object;
103
- }>;
104
- editItem: import("@trpc/server").TRPCQueryProcedure<{
105
- input: {
106
- sectionName: string;
107
- sectionItemId: string | number;
108
- locale?: string | undefined;
109
- };
110
- output: {
111
- section: {
112
- name: string;
113
- title: {
114
- section: string;
115
- singular: string;
116
- plural: string;
117
- };
118
- gallery: import("../../index.js").SectionGallery | undefined;
119
- variants: import("../../core/types/index.js").Variant[] | undefined;
120
- configFile: string;
121
- };
122
- inputGroups: {
123
- groupId: number;
124
- groupTitle: string;
125
- groupOrder: number;
126
- inputs: {
127
- type: import("../../core/types/index.js").FieldType;
128
- name: string;
129
- label: string;
130
- required: boolean;
131
- localized?: boolean;
132
- conditionalFields: import("../../core/types/index.js").ConditionalField[];
133
- readonly: boolean;
134
- defaultValue: any;
135
- value: any;
136
- }[];
137
- }[] | undefined;
138
- gallery: {
139
- referenceId: string;
140
- photo: string;
141
- meta: any;
142
- locale?: string;
143
- }[];
144
- localization: {
145
- defaultLocale: {
146
- code: string;
147
- label: string;
148
- rtl?: boolean;
149
- };
150
- currentLocale: {
151
- code: string;
152
- label: string;
153
- rtl?: boolean;
154
- };
155
- existingTranslations: string[];
156
- locales: {
157
- code: string;
158
- label: string;
159
- rtl?: boolean;
160
- }[];
161
- localeSwitcherEnabled: boolean;
162
- developerNoteEnabled: boolean;
163
- } | null;
164
- error?: undefined;
165
- } | {
166
- error: {
167
- message: any;
168
- };
169
- section?: undefined;
170
- inputGroups?: undefined;
171
- gallery?: undefined;
172
- localization?: undefined;
173
- };
174
- meta: object;
175
- }>;
176
- deleteItem: import("@trpc/server").TRPCMutationProcedure<{
177
- input: {
178
- sectionName: string;
179
- sectionItemId: string | number;
180
- };
181
- output: boolean;
182
- meta: object;
183
- }>;
184
- deleteLocaleTranslation: import("@trpc/server").TRPCMutationProcedure<{
185
- input: {
186
- sectionName: string;
187
- sectionItemId: string | number;
188
- locale: string;
189
- };
190
- output: boolean;
191
- meta: object;
192
- }>;
193
- }>>;
194
- //# sourceMappingURL=hasItemsSection.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hasItemsSection.d.ts","sourceRoot":"","sources":["../../../src/api/routers/hasItemsSection.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,CAAC,MAAM,KAAK,CAAA;AAcxB,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBAwG+53C,CAAC;;;;;uBAAyE,CAAC;;;;;;uBAA8G,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GADzn4C,CAAA"}
@@ -1,86 +0,0 @@
1
- import { privateProcedure, router } from '../trpc.js';
2
- import * as z from 'zod';
3
- import { createEditPage, createNewPage, deleteLocaleTranslation, deleteSectionItem, getBrowsePage, } from '../lib/serverActions.js';
4
- import { getRequestMetadataFromHeaders } from '../../logging/index.js';
5
- import { TRPCError } from '@trpc/server';
6
- import { getCMSConfig } from '../../core/config/index.js';
7
- import { resolveLocale } from '../../core/localization/index.js';
8
- import getString from '../../translations/index.js';
9
- export const hasItemsSectionRouter = router({
10
- listItems: privateProcedure
11
- .input(z.object({
12
- sectionName: z.string(),
13
- page: z.number().optional(),
14
- q: z.string().optional(),
15
- }))
16
- .query(async ({ ctx, input }) => {
17
- return await getBrowsePage(ctx.session, input.sectionName, input.page, input.q);
18
- }),
19
- newItem: privateProcedure
20
- .input(z.object({
21
- sectionName: z.string(),
22
- }))
23
- .query(async ({ ctx, input }) => {
24
- return await createNewPage(ctx.session, input.sectionName);
25
- }),
26
- editItem: privateProcedure
27
- .input(z.object({
28
- sectionName: z.string(),
29
- sectionItemId: z.number().or(z.string()),
30
- locale: z.string().optional(),
31
- }))
32
- .query(async ({ ctx, input }) => {
33
- return await createEditPage(ctx.session, input.sectionName, input.sectionItemId, input.locale);
34
- }),
35
- deleteItem: privateProcedure
36
- .input(z.object({ sectionName: z.string(), sectionItemId: z.number().or(z.string()) }))
37
- .mutation(async ({ ctx, input }) => {
38
- const requestMetadata = getRequestMetadataFromHeaders(ctx.headers);
39
- const result = await deleteSectionItem(ctx.session, input.sectionName, input.sectionItemId, undefined, requestMetadata);
40
- if (result && typeof result === 'object' && 'error' in result) {
41
- const message = result.error?.message ?? 'Failed to delete section item';
42
- throw new TRPCError({
43
- code: 'BAD_REQUEST',
44
- message,
45
- });
46
- }
47
- return result;
48
- }),
49
- deleteLocaleTranslation: privateProcedure
50
- .input(z.object({
51
- sectionName: z.string(),
52
- sectionItemId: z.number().or(z.string()),
53
- locale: z.string(),
54
- }))
55
- .mutation(async ({ ctx, input }) => {
56
- const cmsConfig = await getCMSConfig();
57
- const localeResult = resolveLocale({
58
- localization: cmsConfig.localization,
59
- locale: input.locale,
60
- });
61
- if (!localeResult.resolvedLocale) {
62
- if (localeResult.localizationEnabled === false) {
63
- throw new TRPCError({
64
- code: 'BAD_REQUEST',
65
- message: getString('localizationNotEnabledForSection', ctx.session.user.language),
66
- });
67
- }
68
- throw new TRPCError({
69
- code: 'BAD_REQUEST',
70
- message: getString('invalidLocale', ctx.session.user.language, {
71
- locale: input.locale,
72
- locales: localeResult.availableLocales.map((l) => l.code).join(', '),
73
- }),
74
- });
75
- }
76
- const result = await deleteLocaleTranslation(ctx.session, input.sectionName, input.sectionItemId, localeResult.resolvedLocale.code);
77
- if (result && typeof result === 'object' && 'error' in result) {
78
- const message = result.error?.message ?? 'Failed to delete locale translation';
79
- throw new TRPCError({
80
- code: 'BAD_REQUEST',
81
- message,
82
- });
83
- }
84
- return result;
85
- }),
86
- });
@@ -1,59 +0,0 @@
1
- import * as z from 'zod';
2
- export declare const logsRouter: import("@trpc/server").TRPCBuiltRouter<{
3
- ctx: {
4
- headers: Headers;
5
- db: import("drizzle-orm/mysql2").MySql2Database<typeof import("../../db/schema.js")> & {
6
- $client: import("mysql2/promise").Pool;
7
- };
8
- session: import("../../index.js").Session | null;
9
- };
10
- meta: object;
11
- errorShape: {
12
- data: {
13
- zodError: z.core.$ZodFlattenedError<unknown, string> | null;
14
- code: import("@trpc/server").TRPC_ERROR_CODE_KEY;
15
- httpStatus: number;
16
- path?: string;
17
- stack?: string;
18
- };
19
- message: string;
20
- code: import("@trpc/server").TRPC_ERROR_CODE_NUMBER;
21
- };
22
- transformer: true;
23
- }, import("@trpc/server").TRPCDecorateCreateRouterOptions<{
24
- list: import("@trpc/server").TRPCQueryProcedure<{
25
- input: {
26
- limit?: number | undefined;
27
- offset?: number | undefined;
28
- eventType?: string | undefined;
29
- actorId?: string | undefined;
30
- sectionName?: string | undefined;
31
- entityType?: string | undefined;
32
- entityId?: string | undefined;
33
- from?: string | undefined;
34
- to?: string | undefined;
35
- } | undefined;
36
- output: {
37
- items: {
38
- id: number;
39
- eventType: string;
40
- actorId: string | null;
41
- actorUsername: string | null;
42
- entityType: string | null;
43
- entityId: string | null;
44
- entityLabel: string | null;
45
- sectionName: string | null;
46
- metadata: string | null;
47
- ipAddress: string | null;
48
- userAgent: string | null;
49
- source: string | null;
50
- createdAt: Date;
51
- }[];
52
- total: number;
53
- limit: number;
54
- offset: number;
55
- };
56
- meta: object;
57
- }>;
58
- }>>;
59
- //# sourceMappingURL=logs.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../src/api/routers/logs.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,CAAC,MAAM,KAAK,CAAA;AAqBxB,eAAO,MAAM,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8DrB,CAAA"}
@@ -1,76 +0,0 @@
1
- import { TRPCError } from '@trpc/server';
2
- import { and, desc, eq, gte, lte, sql } from 'drizzle-orm';
3
- import * as z from 'zod';
4
- import { db } from '../../db/client.js';
5
- import { LogsTable } from '../../db/schema.js';
6
- import { isAccessAllowed } from '../lib/serverActions.js';
7
- import { privateProcedure, router } from '../trpc.js';
8
- import getString from '../../translations/index.js';
9
- const listInputSchema = z
10
- .object({
11
- limit: z.number().min(1).max(200).optional(),
12
- offset: z.number().min(0).optional(),
13
- eventType: z.string().optional(),
14
- actorId: z.string().optional(),
15
- sectionName: z.string().optional(),
16
- entityType: z.string().optional(),
17
- entityId: z.string().optional(),
18
- from: z.string().datetime().optional(),
19
- to: z.string().datetime().optional(),
20
- })
21
- .optional();
22
- export const logsRouter = router({
23
- list: privateProcedure.input(listInputSchema).query(async ({ ctx, input }) => {
24
- const accessAllowed = await isAccessAllowed({
25
- sectionName: 'log',
26
- userId: ctx.session.user.id,
27
- });
28
- if (!accessAllowed) {
29
- throw new TRPCError({
30
- code: 'NOT_FOUND',
31
- message: getString('sectionNotFound', ctx.session.user.language),
32
- });
33
- }
34
- const limit = input?.limit ?? 50;
35
- const offset = input?.offset ?? 0;
36
- const conditions = [];
37
- if (input?.eventType) {
38
- conditions.push(eq(LogsTable.eventType, input.eventType));
39
- }
40
- if (input?.actorId) {
41
- conditions.push(eq(LogsTable.actorId, input.actorId));
42
- }
43
- if (input?.sectionName) {
44
- conditions.push(eq(LogsTable.sectionName, input.sectionName));
45
- }
46
- if (input?.entityType) {
47
- conditions.push(eq(LogsTable.entityType, input.entityType));
48
- }
49
- if (input?.entityId) {
50
- conditions.push(eq(LogsTable.entityId, input.entityId));
51
- }
52
- if (input?.from) {
53
- conditions.push(gte(LogsTable.createdAt, new Date(input.from)));
54
- }
55
- if (input?.to) {
56
- conditions.push(lte(LogsTable.createdAt, new Date(input.to)));
57
- }
58
- const whereClause = conditions.length > 0 ? and(...conditions) : undefined;
59
- let listQuery = db.select().from(LogsTable).$dynamic();
60
- let countQuery = db.select({ count: sql `count(*)` }).from(LogsTable).$dynamic();
61
- if (whereClause) {
62
- listQuery = listQuery.where(whereClause);
63
- countQuery = countQuery.where(whereClause);
64
- }
65
- const [rows, totalRows] = await Promise.all([
66
- listQuery.orderBy(desc(LogsTable.createdAt)).limit(limit).offset(offset),
67
- countQuery,
68
- ]);
69
- return {
70
- items: rows,
71
- total: totalRows[0]?.count ?? 0,
72
- limit,
73
- offset,
74
- };
75
- }),
76
- });