bloko 0.0.46 → 0.0.48
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.
- package/dist/driver/api/nodes.d.ts +1 -1
- package/dist/driver/api/nodes.d.ts.map +1 -1
- package/dist/driver/api/nodes.js +1 -1
- package/dist/driver/api/nodes.js.map +1 -1
- package/dist/driver/crud/blocks.d.ts +9 -2
- package/dist/driver/crud/blocks.d.ts.map +1 -1
- package/dist/driver/crud/blocks.js +97 -8
- package/dist/driver/crud/blocks.js.map +1 -1
- package/dist/driver/crud/collections.d.ts +9 -2
- package/dist/driver/crud/collections.d.ts.map +1 -1
- package/dist/driver/crud/collections.js +78 -2
- package/dist/driver/crud/collections.js.map +1 -1
- package/dist/driver/crud/contents.d.ts +8 -2
- package/dist/driver/crud/contents.d.ts.map +1 -1
- package/dist/driver/crud/contents.js +68 -8
- package/dist/driver/crud/contents.js.map +1 -1
- package/dist/driver/crud/image-variants.d.ts +9 -2
- package/dist/driver/crud/image-variants.d.ts.map +1 -1
- package/dist/driver/crud/image-variants.js +107 -6
- package/dist/driver/crud/image-variants.js.map +1 -1
- package/dist/driver/crud/images.d.ts +9 -2
- package/dist/driver/crud/images.d.ts.map +1 -1
- package/dist/driver/crud/images.js +113 -8
- package/dist/driver/crud/images.js.map +1 -1
- package/dist/driver/crud/index.d.ts +87 -11
- package/dist/driver/crud/index.d.ts.map +1 -1
- package/dist/driver/crud/languages.d.ts +9 -2
- package/dist/driver/crud/languages.d.ts.map +1 -1
- package/dist/driver/crud/languages.js +74 -2
- package/dist/driver/crud/languages.js.map +1 -1
- package/dist/driver/crud/node-relation-types.d.ts +9 -2
- package/dist/driver/crud/node-relation-types.d.ts.map +1 -1
- package/dist/driver/crud/node-relation-types.js +88 -6
- package/dist/driver/crud/node-relation-types.js.map +1 -1
- package/dist/driver/crud/node-relations.d.ts +9 -2
- package/dist/driver/crud/node-relations.d.ts.map +1 -1
- package/dist/driver/crud/node-relations.js +82 -10
- package/dist/driver/crud/node-relations.js.map +1 -1
- package/dist/driver/crud/node-types.d.ts +9 -2
- package/dist/driver/crud/node-types.d.ts.map +1 -1
- package/dist/driver/crud/node-types.js +82 -2
- package/dist/driver/crud/node-types.js.map +1 -1
- package/dist/driver/crud/nodes.d.ts +9 -2
- package/dist/driver/crud/nodes.d.ts.map +1 -1
- package/dist/driver/crud/nodes.js +137 -18
- package/dist/driver/crud/nodes.js.map +1 -1
- package/dist/driver/crud/query-builder.d.ts +51 -0
- package/dist/driver/crud/query-builder.d.ts.map +1 -0
- package/dist/driver/crud/query-builder.js +353 -0
- package/dist/driver/crud/query-builder.js.map +1 -0
- package/dist/driver/crud/templates.d.ts +9 -2
- package/dist/driver/crud/templates.d.ts.map +1 -1
- package/dist/driver/crud/templates.js +88 -6
- package/dist/driver/crud/templates.js.map +1 -1
- package/dist/driver/types.d.ts +59 -0
- package/dist/driver/types.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -37,7 +37,7 @@ export declare function createNodesApi(crud: Crud): {
|
|
|
37
37
|
* Find a node by walking a slug path
|
|
38
38
|
* Returns the node with contents and breadcrumb trail
|
|
39
39
|
*/
|
|
40
|
-
findByPath(lang: string, slugPath: string[]
|
|
40
|
+
findByPath(lang: string, slugPath: string[]): Promise<FindByPathResult | null>;
|
|
41
41
|
/**
|
|
42
42
|
* Get a node by ID with its contents
|
|
43
43
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nodes.d.ts","sourceRoot":"","sources":["../../../src/driver/api/nodes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAG7C,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,QAAQ,EAAE,WAAW,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,gBAAgB,CAAC;IACvB,UAAU,EAAE,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAAE,CAAC,CAAC;CAC9G;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI;IAiDrC;;;OAGG;qBAEK,MAAM,YACF,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"nodes.d.ts","sourceRoot":"","sources":["../../../src/driver/api/nodes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAG7C,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,QAAQ,EAAE,WAAW,EAAE,CAAC;CACzB;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,QAAQ,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,gBAAgB,CAAC;IACvB,UAAU,EAAE,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;KAAE,CAAC,CAAC;CAC9G;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI;IAiDrC;;;OAGG;qBAEK,MAAM,YACF,MAAM,EAAE,GACjB,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;IA0BnC;;OAEG;iBACgB,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAM5D;;OAEG;0BAEa,MAAM,YACV;QAAE,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,GAC1C,OAAO,CAAC,QAAQ,EAAE,CAAC;IA4BtB;;OAEG;2BAC0B,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAKjE;;OAEG;4BAC2B,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAKlE;;;OAGG;4BAC2B,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;EAQ1E;AAED,MAAM,MAAM,QAAQ,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC"}
|
package/dist/driver/api/nodes.js
CHANGED
|
@@ -43,7 +43,7 @@ export function createNodesApi(crud) {
|
|
|
43
43
|
* Find a node by walking a slug path
|
|
44
44
|
* Returns the node with contents and breadcrumb trail
|
|
45
45
|
*/
|
|
46
|
-
async findByPath(lang, slugPath
|
|
46
|
+
async findByPath(lang, slugPath) {
|
|
47
47
|
const breadcrumb = [];
|
|
48
48
|
let parentId = null;
|
|
49
49
|
let node = null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nodes.js","sourceRoot":"","sources":["../../../src/driver/api/nodes.ts"],"names":[],"mappings":"AAmCA,MAAM,UAAU,cAAc,CAAC,IAAU;IACvC;;OAEG;IACH,KAAK,UAAU,aAAa,CAAC,MAAc;QACzC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAErC,wCAAwC;QACxC,MAAM,QAAQ,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAC3D,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAC9B,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAC7C,CAAC;QACF,MAAM,SAAS,GAAG,IAAI,GAAG,CACvB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAc,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CACjE,CAAC;QAEF,sBAAsB;QACtB,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC7B,MAAM,KAAK,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACtC,OAAO;gBACL,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,SAAS,EAAE,KAAK,EAAE,IAAI,IAAI,SAAS;gBACnC,UAAU,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE;gBAC9B,WAAW,EAAE,KAAK,EAAE,YAAY,IAAI,MAAM;gBAC1C,IAAI,EAAE,KAAK,EAAE,IAAI,IAAI,CAAC;gBACtB,KAAK,EAAE,CAAC,CAAC,KAAgC;aAC1C,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,2BAA2B;QAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED;;OAEG;IACH,KAAK,UAAU,kBAAkB,CAAC,IAAU;QAC1C,OAAO;YACL,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,EAAE;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,EAAE;YAC7B,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,EAAE;YACrB,QAAQ,EAAE,MAAM,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC;SACvC,CAAC;IACJ,CAAC;IAED,OAAO;QACL;;;WAGG;QACH,KAAK,CAAC,UAAU,CACd,IAAY,EACZ,QAAkB
|
|
1
|
+
{"version":3,"file":"nodes.js","sourceRoot":"","sources":["../../../src/driver/api/nodes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,20 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Block, BlockInsert, BlockUpdate } from '../types.js';
|
|
2
|
+
import type { Block, BlockInsert, BlockUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function blocks(db: DB): {
|
|
4
|
-
|
|
4
|
+
findMany(options?: QueryOptions<Block>): Promise<Block[]>;
|
|
5
|
+
findFirst(options: QueryOptions<Block>): Promise<Block | null>;
|
|
5
6
|
findById(id: string): Promise<Block | null>;
|
|
6
7
|
findByTemplate(templateId: string): Promise<Block[]>;
|
|
7
8
|
findByCode(templateId: string, code: string): Promise<Block | null>;
|
|
8
9
|
findChildren(parentId: string): Promise<Block[]>;
|
|
10
|
+
count(options?: CountOptions<Block>): Promise<number>;
|
|
9
11
|
create(data: BlockInsert): Promise<Block>;
|
|
10
12
|
update(id: string, data: BlockUpdate): Promise<Block | null>;
|
|
11
13
|
delete(id: string): Promise<boolean>;
|
|
14
|
+
upsert(data: BlockInsert, conflictKeys?: (keyof Block)[]): Promise<Block>;
|
|
15
|
+
deleteMany(where: WhereClause<Block>): Promise<number>;
|
|
16
|
+
createMany(data: BlockInsert[]): Promise<Block[]>;
|
|
17
|
+
updateMany(where: WhereClause<Block>, data: BlockUpdate): Promise<number>;
|
|
18
|
+
findAll(): Promise<Block[]>;
|
|
12
19
|
};
|
|
13
20
|
//# sourceMappingURL=blocks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blocks.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"blocks.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG5G,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE;uBAEA,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;uBAMtC,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;iBAKjD,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;+BAKhB,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;2BAI7B,MAAM,QAAQ,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;2BAI5C,MAAM,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;oBAIhC,YAAY,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAMxC,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC;eAQ9B,MAAM,QAAQ,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;eA4CjD,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;iBAKvB,WAAW,iBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,GAA2B,OAAO,CAAC,KAAK,CAAC;sBAiB9E,WAAW,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAOrC,WAAW,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;sBAmB/B,WAAW,CAAC,KAAK,CAAC,QAAQ,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC;eA0B9D,OAAO,CAAC,KAAK,EAAE,CAAC;EAIpC"}
|
|
@@ -1,24 +1,32 @@
|
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
1
2
|
export function blocks(db) {
|
|
2
3
|
return {
|
|
3
|
-
async
|
|
4
|
-
const
|
|
4
|
+
async findMany(options) {
|
|
5
|
+
const { sql, params } = buildSelectQuery('blocks', options, 'sort, code');
|
|
6
|
+
const result = await db.query(sql, params);
|
|
5
7
|
return result.rows;
|
|
6
8
|
},
|
|
9
|
+
async findFirst(options) {
|
|
10
|
+
const result = await this.findMany({ ...options, take: 1 });
|
|
11
|
+
return result[0] ?? null;
|
|
12
|
+
},
|
|
7
13
|
async findById(id) {
|
|
8
14
|
const result = await db.query('SELECT * FROM blocks WHERE id = $1', [id]);
|
|
9
15
|
return result.rows[0] ?? null;
|
|
10
16
|
},
|
|
11
17
|
async findByTemplate(templateId) {
|
|
12
|
-
|
|
13
|
-
return result.rows;
|
|
18
|
+
return this.findMany({ where: { _template: templateId } });
|
|
14
19
|
},
|
|
15
20
|
async findByCode(templateId, code) {
|
|
16
|
-
|
|
17
|
-
return result.rows[0] ?? null;
|
|
21
|
+
return this.findFirst({ where: { _template: templateId, code } });
|
|
18
22
|
},
|
|
19
23
|
async findChildren(parentId) {
|
|
20
|
-
|
|
21
|
-
|
|
24
|
+
return this.findMany({ where: { _parent: parentId } });
|
|
25
|
+
},
|
|
26
|
+
async count(options) {
|
|
27
|
+
const { sql, params } = buildCountQuery('blocks', options);
|
|
28
|
+
const result = await db.query(sql, params);
|
|
29
|
+
return parseInt(result.rows[0].count, 10);
|
|
22
30
|
},
|
|
23
31
|
async create(data) {
|
|
24
32
|
const result = await db.query('INSERT INTO blocks (_template, _parent, code, title, content_type, sort, notes) VALUES ($1, $2, $3, $4, $5, $6, $7) RETURNING *', [data._template, data._parent, data.code, data.title, data.content_type, data.sort, data.notes]);
|
|
@@ -66,6 +74,87 @@ export function blocks(db) {
|
|
|
66
74
|
const result = await db.query('DELETE FROM blocks WHERE id = $1', [id]);
|
|
67
75
|
return (result.rowCount ?? 0) > 0;
|
|
68
76
|
},
|
|
77
|
+
async upsert(data, conflictKeys = ['_template', 'code']) {
|
|
78
|
+
const columns = ['_template', '_parent', 'code', 'title', 'content_type', 'sort', 'notes'];
|
|
79
|
+
const values = [data._template, data._parent, data.code, data.title, data.content_type, data.sort, data.notes];
|
|
80
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
81
|
+
const updateColumns = columns.filter(col => !conflictKeys.includes(col));
|
|
82
|
+
const updateClauses = updateColumns.map(col => `${col} = EXCLUDED.${col}`);
|
|
83
|
+
let sql = `INSERT INTO blocks (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;
|
|
84
|
+
sql += ` ON CONFLICT (${conflictKeys.join(', ')})`;
|
|
85
|
+
sql += updateClauses.length > 0 ? ` DO UPDATE SET ${updateClauses.join(', ')}` : ' DO NOTHING';
|
|
86
|
+
sql += ' RETURNING *';
|
|
87
|
+
const result = await db.query(sql, values);
|
|
88
|
+
return result.rows[0];
|
|
89
|
+
},
|
|
90
|
+
async deleteMany(where) {
|
|
91
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
92
|
+
const sql = whereClause ? `DELETE FROM blocks WHERE ${whereClause}` : 'DELETE FROM blocks';
|
|
93
|
+
const result = await db.query(sql, params);
|
|
94
|
+
return result.rowCount ?? 0;
|
|
95
|
+
},
|
|
96
|
+
async createMany(data) {
|
|
97
|
+
if (data.length === 0)
|
|
98
|
+
return [];
|
|
99
|
+
const columns = ['_template', '_parent', 'code', 'title', 'content_type', 'sort', 'notes'];
|
|
100
|
+
const values = [];
|
|
101
|
+
const valueRows = [];
|
|
102
|
+
let idx = 1;
|
|
103
|
+
for (const record of data) {
|
|
104
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
105
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
106
|
+
values.push(record._template, record._parent, record.code, record.title, record.content_type, record.sort, record.notes);
|
|
107
|
+
}
|
|
108
|
+
const sql = `INSERT INTO blocks (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
109
|
+
const result = await db.query(sql, values);
|
|
110
|
+
return result.rows;
|
|
111
|
+
},
|
|
112
|
+
async updateMany(where, data) {
|
|
113
|
+
const setClauses = [];
|
|
114
|
+
const values = [];
|
|
115
|
+
let idx = 1;
|
|
116
|
+
if (data._template !== undefined) {
|
|
117
|
+
setClauses.push(`_template = $${idx++}`);
|
|
118
|
+
values.push(data._template);
|
|
119
|
+
}
|
|
120
|
+
if (data._parent !== undefined) {
|
|
121
|
+
setClauses.push(`_parent = $${idx++}`);
|
|
122
|
+
values.push(data._parent);
|
|
123
|
+
}
|
|
124
|
+
if (data.code !== undefined) {
|
|
125
|
+
setClauses.push(`code = $${idx++}`);
|
|
126
|
+
values.push(data.code);
|
|
127
|
+
}
|
|
128
|
+
if (data.title !== undefined) {
|
|
129
|
+
setClauses.push(`title = $${idx++}`);
|
|
130
|
+
values.push(data.title);
|
|
131
|
+
}
|
|
132
|
+
if (data.content_type !== undefined) {
|
|
133
|
+
setClauses.push(`content_type = $${idx++}`);
|
|
134
|
+
values.push(data.content_type);
|
|
135
|
+
}
|
|
136
|
+
if (data.sort !== undefined) {
|
|
137
|
+
setClauses.push(`sort = $${idx++}`);
|
|
138
|
+
values.push(data.sort);
|
|
139
|
+
}
|
|
140
|
+
if (data.notes !== undefined) {
|
|
141
|
+
setClauses.push(`notes = $${idx++}`);
|
|
142
|
+
values.push(data.notes);
|
|
143
|
+
}
|
|
144
|
+
if (setClauses.length === 0)
|
|
145
|
+
return 0;
|
|
146
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
147
|
+
values.push(...whereParams);
|
|
148
|
+
let sql = `UPDATE blocks SET ${setClauses.join(', ')}`;
|
|
149
|
+
if (whereClause)
|
|
150
|
+
sql += ` WHERE ${whereClause}`;
|
|
151
|
+
const result = await db.query(sql, values);
|
|
152
|
+
return result.rowCount ?? 0;
|
|
153
|
+
},
|
|
154
|
+
// Backward compatibility alias
|
|
155
|
+
async findAll() {
|
|
156
|
+
return this.findMany();
|
|
157
|
+
},
|
|
69
158
|
};
|
|
70
159
|
}
|
|
71
160
|
//# sourceMappingURL=blocks.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blocks.js","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"blocks.js","sourceRoot":"","sources":["../../../src/driver/crud/blocks.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,18 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Collection, CollectionInsert, CollectionUpdate } from '../types.js';
|
|
2
|
+
import type { Collection, CollectionInsert, CollectionUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function collections(db: DB): {
|
|
4
|
-
|
|
4
|
+
findMany(options?: QueryOptions<Collection>): Promise<Collection[]>;
|
|
5
|
+
findFirst(options: QueryOptions<Collection>): Promise<Collection | null>;
|
|
5
6
|
findById(id: string): Promise<Collection | null>;
|
|
6
7
|
findByCode(code: string): Promise<Collection | null>;
|
|
8
|
+
count(options?: CountOptions<Collection>): Promise<number>;
|
|
7
9
|
create(data: CollectionInsert): Promise<Collection>;
|
|
8
10
|
update(id: string, data: CollectionUpdate): Promise<Collection | null>;
|
|
9
11
|
delete(id: string): Promise<boolean>;
|
|
12
|
+
upsert(data: CollectionInsert, conflictKeys?: (keyof Collection)[]): Promise<Collection>;
|
|
13
|
+
deleteMany(where: WhereClause<Collection>): Promise<number>;
|
|
14
|
+
createMany(data: CollectionInsert[]): Promise<Collection[]>;
|
|
15
|
+
updateMany(where: WhereClause<Collection>, data: CollectionUpdate): Promise<number>;
|
|
16
|
+
findAll(): Promise<Collection[]>;
|
|
10
17
|
};
|
|
11
18
|
//# sourceMappingURL=collections.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collections.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"collections.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG3H,wBAAgB,WAAW,CAAC,EAAE,EAAE,EAAE;uBAEL,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;uBAMhD,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;iBAK3D,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;qBAK/B,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;oBAKpC,YAAY,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM7C,gBAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;eAiBxC,MAAM,QAAQ,gBAAgB,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;eA4B3D,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;iBAKvB,gBAAgB,iBAAgB,CAAC,MAAM,UAAU,CAAC,EAAE,GAAc,OAAO,CAAC,UAAU,CAAC;sBAiBhF,WAAW,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAO1C,gBAAgB,EAAE,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;sBAmBzC,WAAW,CAAC,UAAU,CAAC,QAAQ,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC;eA+BxE,OAAO,CAAC,UAAU,EAAE,CAAC;EAIzC"}
|
|
@@ -1,9 +1,15 @@
|
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
1
2
|
export function collections(db) {
|
|
2
3
|
return {
|
|
3
|
-
async
|
|
4
|
-
const
|
|
4
|
+
async findMany(options) {
|
|
5
|
+
const { sql, params } = buildSelectQuery('collections', options, 'sort, code');
|
|
6
|
+
const result = await db.query(sql, params);
|
|
5
7
|
return result.rows;
|
|
6
8
|
},
|
|
9
|
+
async findFirst(options) {
|
|
10
|
+
const result = await this.findMany({ ...options, take: 1 });
|
|
11
|
+
return result[0] ?? null;
|
|
12
|
+
},
|
|
7
13
|
async findById(id) {
|
|
8
14
|
const result = await db.query('SELECT * FROM collections WHERE id = $1', [id]);
|
|
9
15
|
return result.rows[0] ?? null;
|
|
@@ -12,6 +18,11 @@ export function collections(db) {
|
|
|
12
18
|
const result = await db.query('SELECT * FROM collections WHERE code = $1', [code]);
|
|
13
19
|
return result.rows[0] ?? null;
|
|
14
20
|
},
|
|
21
|
+
async count(options) {
|
|
22
|
+
const { sql, params } = buildCountQuery('collections', options);
|
|
23
|
+
const result = await db.query(sql, params);
|
|
24
|
+
return parseInt(result.rows[0].count, 10);
|
|
25
|
+
},
|
|
15
26
|
async create(data) {
|
|
16
27
|
// Auto-calculate sort if not provided
|
|
17
28
|
let sort = data.sort;
|
|
@@ -48,6 +59,71 @@ export function collections(db) {
|
|
|
48
59
|
const result = await db.query('DELETE FROM collections WHERE id = $1', [id]);
|
|
49
60
|
return (result.rowCount ?? 0) > 0;
|
|
50
61
|
},
|
|
62
|
+
async upsert(data, conflictKeys = ['code']) {
|
|
63
|
+
const columns = ['code', 'sort', 'notes'];
|
|
64
|
+
const values = [data.code, data.sort, data.notes];
|
|
65
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
66
|
+
const updateColumns = columns.filter(col => !conflictKeys.includes(col));
|
|
67
|
+
const updateClauses = updateColumns.map(col => `${col} = EXCLUDED.${col}`);
|
|
68
|
+
let sql = `INSERT INTO collections (${columns.join(', ')}) VALUES (${placeholders.join(', ')})`;
|
|
69
|
+
sql += ` ON CONFLICT (${conflictKeys.join(', ')})`;
|
|
70
|
+
sql += updateClauses.length > 0 ? ` DO UPDATE SET ${updateClauses.join(', ')}` : ' DO NOTHING';
|
|
71
|
+
sql += ' RETURNING *';
|
|
72
|
+
const result = await db.query(sql, values);
|
|
73
|
+
return result.rows[0];
|
|
74
|
+
},
|
|
75
|
+
async deleteMany(where) {
|
|
76
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
77
|
+
const sql = whereClause ? `DELETE FROM collections WHERE ${whereClause}` : 'DELETE FROM collections';
|
|
78
|
+
const result = await db.query(sql, params);
|
|
79
|
+
return result.rowCount ?? 0;
|
|
80
|
+
},
|
|
81
|
+
async createMany(data) {
|
|
82
|
+
if (data.length === 0)
|
|
83
|
+
return [];
|
|
84
|
+
const columns = ['code', 'sort', 'notes'];
|
|
85
|
+
const values = [];
|
|
86
|
+
const valueRows = [];
|
|
87
|
+
let idx = 1;
|
|
88
|
+
for (const record of data) {
|
|
89
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
90
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
91
|
+
values.push(record.code, record.sort, record.notes);
|
|
92
|
+
}
|
|
93
|
+
const sql = `INSERT INTO collections (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
94
|
+
const result = await db.query(sql, values);
|
|
95
|
+
return result.rows;
|
|
96
|
+
},
|
|
97
|
+
async updateMany(where, data) {
|
|
98
|
+
const setClauses = [];
|
|
99
|
+
const values = [];
|
|
100
|
+
let idx = 1;
|
|
101
|
+
if (data.code !== undefined) {
|
|
102
|
+
setClauses.push(`code = $${idx++}`);
|
|
103
|
+
values.push(data.code);
|
|
104
|
+
}
|
|
105
|
+
if (data.sort !== undefined) {
|
|
106
|
+
setClauses.push(`sort = $${idx++}`);
|
|
107
|
+
values.push(data.sort);
|
|
108
|
+
}
|
|
109
|
+
if (data.notes !== undefined) {
|
|
110
|
+
setClauses.push(`notes = $${idx++}`);
|
|
111
|
+
values.push(data.notes);
|
|
112
|
+
}
|
|
113
|
+
if (setClauses.length === 0)
|
|
114
|
+
return 0;
|
|
115
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
116
|
+
values.push(...whereParams);
|
|
117
|
+
let sql = `UPDATE collections SET ${setClauses.join(', ')}`;
|
|
118
|
+
if (whereClause)
|
|
119
|
+
sql += ` WHERE ${whereClause}`;
|
|
120
|
+
const result = await db.query(sql, values);
|
|
121
|
+
return result.rowCount ?? 0;
|
|
122
|
+
},
|
|
123
|
+
// Backward compatibility alias
|
|
124
|
+
async findAll() {
|
|
125
|
+
return this.findMany();
|
|
126
|
+
},
|
|
51
127
|
};
|
|
52
128
|
}
|
|
53
129
|
//# sourceMappingURL=collections.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collections.js","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"collections.js","sourceRoot":"","sources":["../../../src/driver/crud/collections.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { Content, ContentInsert, ContentUpdate } from '../types.js';
|
|
2
|
+
import type { Content, ContentInsert, ContentUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function contents(db: DB): {
|
|
4
|
-
|
|
4
|
+
findMany(options?: QueryOptions<Content>): Promise<Content[]>;
|
|
5
|
+
findFirst(options: QueryOptions<Content>): Promise<Content | null>;
|
|
5
6
|
findById(id: string): Promise<Content | null>;
|
|
6
7
|
findByNode(nodeId: string): Promise<Content[]>;
|
|
7
8
|
findByBlock(blockId: string): Promise<Content[]>;
|
|
8
9
|
findByNodeAndBlock(nodeId: string, blockId: string): Promise<Content | null>;
|
|
10
|
+
count(options?: CountOptions<Content>): Promise<number>;
|
|
9
11
|
create(data: ContentInsert): Promise<Content>;
|
|
10
12
|
upsert(data: ContentInsert): Promise<Content>;
|
|
11
13
|
update(id: string, data: ContentUpdate): Promise<Content | null>;
|
|
12
14
|
delete(id: string): Promise<boolean>;
|
|
13
15
|
deleteByNode(nodeId: string): Promise<number>;
|
|
16
|
+
deleteMany(where: WhereClause<Content>): Promise<number>;
|
|
17
|
+
createMany(data: ContentInsert[]): Promise<Content[]>;
|
|
18
|
+
updateMany(where: WhereClause<Content>, data: ContentUpdate): Promise<number>;
|
|
19
|
+
findAll(): Promise<Content[]>;
|
|
14
20
|
};
|
|
15
21
|
//# sourceMappingURL=contents.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contents.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"contents.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAGlH,wBAAgB,QAAQ,CAAC,EAAE,EAAE,EAAE;uBAEF,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;uBAM1C,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;iBAKrD,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;uBAK1B,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;yBAIzB,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;+BAIrB,MAAM,WAAW,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;oBAI5D,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM1C,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC;iBAQhC,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC;eAUlC,MAAM,QAAQ,aAAa,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;eA4BrD,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;yBAKf,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;sBAK3B,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAOvC,aAAa,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;sBAmBnC,WAAW,CAAC,OAAO,CAAC,QAAQ,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;eA+BlE,OAAO,CAAC,OAAO,EAAE,CAAC;EAItC"}
|
|
@@ -1,24 +1,32 @@
|
|
|
1
|
+
import { buildSelectQuery, buildCountQuery, buildWhereClause } from './query-builder.js';
|
|
1
2
|
export function contents(db) {
|
|
2
3
|
return {
|
|
3
|
-
async
|
|
4
|
-
const
|
|
4
|
+
async findMany(options) {
|
|
5
|
+
const { sql, params } = buildSelectQuery('contents', options, '');
|
|
6
|
+
const result = await db.query(sql, params);
|
|
5
7
|
return result.rows;
|
|
6
8
|
},
|
|
9
|
+
async findFirst(options) {
|
|
10
|
+
const result = await this.findMany({ ...options, take: 1 });
|
|
11
|
+
return result[0] ?? null;
|
|
12
|
+
},
|
|
7
13
|
async findById(id) {
|
|
8
14
|
const result = await db.query('SELECT * FROM contents WHERE id = $1', [id]);
|
|
9
15
|
return result.rows[0] ?? null;
|
|
10
16
|
},
|
|
11
17
|
async findByNode(nodeId) {
|
|
12
|
-
|
|
13
|
-
return result.rows;
|
|
18
|
+
return this.findMany({ where: { _node: nodeId } });
|
|
14
19
|
},
|
|
15
20
|
async findByBlock(blockId) {
|
|
16
|
-
|
|
17
|
-
return result.rows;
|
|
21
|
+
return this.findMany({ where: { _block: blockId } });
|
|
18
22
|
},
|
|
19
23
|
async findByNodeAndBlock(nodeId, blockId) {
|
|
20
|
-
|
|
21
|
-
|
|
24
|
+
return this.findFirst({ where: { _node: nodeId, _block: blockId } });
|
|
25
|
+
},
|
|
26
|
+
async count(options) {
|
|
27
|
+
const { sql, params } = buildCountQuery('contents', options);
|
|
28
|
+
const result = await db.query(sql, params);
|
|
29
|
+
return parseInt(result.rows[0].count, 10);
|
|
22
30
|
},
|
|
23
31
|
async create(data) {
|
|
24
32
|
const result = await db.query('INSERT INTO contents (_node, _block, value) VALUES ($1, $2, $3) RETURNING *', [data._node, data._block, JSON.stringify(data.value)]);
|
|
@@ -60,6 +68,58 @@ export function contents(db) {
|
|
|
60
68
|
const result = await db.query('DELETE FROM contents WHERE _node = $1', [nodeId]);
|
|
61
69
|
return result.rowCount ?? 0;
|
|
62
70
|
},
|
|
71
|
+
async deleteMany(where) {
|
|
72
|
+
const { sql: whereClause, params } = buildWhereClause(where, 1);
|
|
73
|
+
const sql = whereClause ? `DELETE FROM contents WHERE ${whereClause}` : 'DELETE FROM contents';
|
|
74
|
+
const result = await db.query(sql, params);
|
|
75
|
+
return result.rowCount ?? 0;
|
|
76
|
+
},
|
|
77
|
+
async createMany(data) {
|
|
78
|
+
if (data.length === 0)
|
|
79
|
+
return [];
|
|
80
|
+
const columns = ['_node', '_block', 'value'];
|
|
81
|
+
const values = [];
|
|
82
|
+
const valueRows = [];
|
|
83
|
+
let idx = 1;
|
|
84
|
+
for (const record of data) {
|
|
85
|
+
const placeholders = columns.map(() => `$${idx++}`);
|
|
86
|
+
valueRows.push(`(${placeholders.join(', ')})`);
|
|
87
|
+
values.push(record._node, record._block, JSON.stringify(record.value));
|
|
88
|
+
}
|
|
89
|
+
const sql = `INSERT INTO contents (${columns.join(', ')}) VALUES ${valueRows.join(', ')} RETURNING *`;
|
|
90
|
+
const result = await db.query(sql, values);
|
|
91
|
+
return result.rows;
|
|
92
|
+
},
|
|
93
|
+
async updateMany(where, data) {
|
|
94
|
+
const setClauses = [];
|
|
95
|
+
const values = [];
|
|
96
|
+
let idx = 1;
|
|
97
|
+
if (data._node !== undefined) {
|
|
98
|
+
setClauses.push(`_node = $${idx++}`);
|
|
99
|
+
values.push(data._node);
|
|
100
|
+
}
|
|
101
|
+
if (data._block !== undefined) {
|
|
102
|
+
setClauses.push(`_block = $${idx++}`);
|
|
103
|
+
values.push(data._block);
|
|
104
|
+
}
|
|
105
|
+
if (data.value !== undefined) {
|
|
106
|
+
setClauses.push(`value = $${idx++}`);
|
|
107
|
+
values.push(JSON.stringify(data.value));
|
|
108
|
+
}
|
|
109
|
+
if (setClauses.length === 0)
|
|
110
|
+
return 0;
|
|
111
|
+
const { sql: whereClause, params: whereParams } = buildWhereClause(where, idx);
|
|
112
|
+
values.push(...whereParams);
|
|
113
|
+
let sql = `UPDATE contents SET ${setClauses.join(', ')}`;
|
|
114
|
+
if (whereClause)
|
|
115
|
+
sql += ` WHERE ${whereClause}`;
|
|
116
|
+
const result = await db.query(sql, values);
|
|
117
|
+
return result.rowCount ?? 0;
|
|
118
|
+
},
|
|
119
|
+
// Backward compatibility alias
|
|
120
|
+
async findAll() {
|
|
121
|
+
return this.findMany();
|
|
122
|
+
},
|
|
63
123
|
};
|
|
64
124
|
}
|
|
65
125
|
//# sourceMappingURL=contents.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"contents.js","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"contents.js","sourceRoot":"","sources":["../../../src/driver/crud/contents.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import type { DB } from '../db.js';
|
|
2
|
-
import type { ImageVariant, ImageVariantInsert, ImageVariantUpdate } from '../types.js';
|
|
2
|
+
import type { ImageVariant, ImageVariantInsert, ImageVariantUpdate, QueryOptions, CountOptions, WhereClause } from '../types.js';
|
|
3
3
|
export declare function imageVariants(db: DB): {
|
|
4
|
-
|
|
4
|
+
findMany(options?: QueryOptions<ImageVariant>): Promise<ImageVariant[]>;
|
|
5
|
+
findFirst(options: QueryOptions<ImageVariant>): Promise<ImageVariant | null>;
|
|
5
6
|
findById(id: string): Promise<ImageVariant | null>;
|
|
6
7
|
findByImage(imageId: string): Promise<ImageVariant[]>;
|
|
7
8
|
findByS3Key(s3Key: string): Promise<ImageVariant | null>;
|
|
@@ -10,9 +11,15 @@ export declare function imageVariants(db: DB): {
|
|
|
10
11
|
* Uses COALESCE to match null values (which represent "auto" dimensions).
|
|
11
12
|
*/
|
|
12
13
|
findByParams(imageId: string, reqWidth: number | null, reqHeight: number | null, format: string, quality: number): Promise<ImageVariant | null>;
|
|
14
|
+
count(options?: CountOptions<ImageVariant>): Promise<number>;
|
|
13
15
|
create(data: ImageVariantInsert): Promise<ImageVariant>;
|
|
14
16
|
update(id: string, data: ImageVariantUpdate): Promise<ImageVariant | null>;
|
|
15
17
|
delete(id: string): Promise<boolean>;
|
|
16
18
|
deleteByImage(imageId: string): Promise<number>;
|
|
19
|
+
upsert(data: ImageVariantInsert, conflictKeys?: (keyof ImageVariant)[]): Promise<ImageVariant>;
|
|
20
|
+
deleteMany(where: WhereClause<ImageVariant>): Promise<number>;
|
|
21
|
+
createMany(data: ImageVariantInsert[]): Promise<ImageVariant[]>;
|
|
22
|
+
updateMany(where: WhereClause<ImageVariant>, data: ImageVariantUpdate): Promise<number>;
|
|
23
|
+
findAll(): Promise<ImageVariant[]>;
|
|
17
24
|
};
|
|
18
25
|
//# sourceMappingURL=image-variants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"image-variants.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"image-variants.d.ts","sourceRoot":"","sources":["../../../src/driver/crud/image-variants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,EAAE,YAAY,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAGjI,wBAAgB,aAAa,CAAC,EAAE,EAAE,EAAE;uBAEP,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;uBAMpD,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;iBAK/D,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;yBAK7B,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;uBAIlC,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;IAI9D;;;OAGG;0BAEQ,MAAM,YACL,MAAM,GAAG,IAAI,aACZ,MAAM,GAAG,IAAI,UAChB,MAAM,WACL,MAAM,GACd,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;oBAaT,YAAY,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;iBAM/C,kBAAkB,GAAG,OAAO,CAAC,YAAY,CAAC;eAsB5C,MAAM,QAAQ,kBAAkB,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;eAoD/D,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;2BAKb,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;iBAKlC,kBAAkB,iBAAgB,CAAC,MAAM,YAAY,CAAC,EAAE,GAAgB,OAAO,CAAC,YAAY,CAAC;sBAoBxF,WAAW,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;qBAO5C,kBAAkB,EAAE,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;sBAsB7C,WAAW,CAAC,YAAY,CAAC,QAAQ,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC;eA4B5E,OAAO,CAAC,YAAY,EAAE,CAAC;EAI3C"}
|