@yongdall/organization 0.4.0 → 0.4.3
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/hooks.yongdall.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as OrganizationType, t as Organization } from "./organization-
|
|
1
|
+
import { n as OrganizationType, t as Organization } from "./organization-CEkzOuGJ.mjs";
|
|
2
2
|
|
|
3
3
|
//#region plugins/organization/hooks.yongdall.mjs
|
|
4
4
|
/** @import { Hooks } from '@yongdall/core' */
|
package/index.d.mts
CHANGED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import * as
|
|
1
|
+
import * as imodel0 from "imodel";
|
|
2
2
|
import * as _yongdall_model0 from "@yongdall/model";
|
|
3
3
|
|
|
4
4
|
//#region plugins/organization/models/OrganizationType.d.mts
|
|
5
5
|
declare const OrganizationType: _yongdall_model0.ModelTable<{
|
|
6
|
-
id:
|
|
7
|
-
label:
|
|
8
|
-
description:
|
|
9
|
-
createdAt:
|
|
10
|
-
updatedAt:
|
|
6
|
+
id: imodel0.FieldDefine<"string", false, false>;
|
|
7
|
+
label: imodel0.FieldDefine<"string", false, false>;
|
|
8
|
+
description: imodel0.FieldDefine<"string", false, true>;
|
|
9
|
+
createdAt: imodel0.FieldDefine<"timestamp", false, false>;
|
|
10
|
+
updatedAt: imodel0.FieldDefine<"timestamp", false, false>;
|
|
11
11
|
}, "organizationType">;
|
|
12
12
|
//#endregion
|
|
13
13
|
//#region plugins/organization/models/Organization.d.mts
|
|
14
14
|
declare const Organization: _yongdall_model0.ModelTable<{
|
|
15
|
-
id:
|
|
16
|
-
label:
|
|
17
|
-
parentId:
|
|
18
|
-
typeId:
|
|
19
|
-
internal:
|
|
20
|
-
mainId:
|
|
21
|
-
description:
|
|
22
|
-
lft:
|
|
23
|
-
rgt:
|
|
24
|
-
createdAt:
|
|
25
|
-
updatedAt:
|
|
15
|
+
id: imodel0.FieldDefine<"uuid", false, false>;
|
|
16
|
+
label: imodel0.FieldDefine<"string", false, false>;
|
|
17
|
+
parentId: imodel0.FieldDefine<"uuid", false, true>;
|
|
18
|
+
typeId: imodel0.FieldDefine<"string", true, false>;
|
|
19
|
+
internal: imodel0.FieldDefine<"bool", false, false>;
|
|
20
|
+
mainId: imodel0.FieldDefine<"uuid", false, true>;
|
|
21
|
+
description: imodel0.FieldDefine<"text", false, true>;
|
|
22
|
+
lft: imodel0.FieldDefine<"i32", false, false>;
|
|
23
|
+
rgt: imodel0.FieldDefine<"i32", false, false>;
|
|
24
|
+
createdAt: imodel0.FieldDefine<"timestamp", false, false>;
|
|
25
|
+
updatedAt: imodel0.FieldDefine<"timestamp", false, false>;
|
|
26
26
|
}, "organization">;
|
|
27
27
|
//#endregion
|
|
28
28
|
export { Organization, OrganizationType };
|
package/index.mjs
CHANGED
|
@@ -82,10 +82,13 @@ const Organization = createModel("organization", {
|
|
|
82
82
|
}),
|
|
83
83
|
typeId: createField("string", {
|
|
84
84
|
size: 255,
|
|
85
|
+
array: true,
|
|
85
86
|
nullable: false,
|
|
86
87
|
label: "类型",
|
|
87
88
|
model: "organizationType",
|
|
88
|
-
|
|
89
|
+
source: { value: "id" },
|
|
90
|
+
renderer: "select",
|
|
91
|
+
default: [],
|
|
89
92
|
layout: { colSpan: 6 }
|
|
90
93
|
}),
|
|
91
94
|
internal: createField("bool", {
|
|
@@ -317,4 +320,4 @@ const Organization = createModel("organization", {
|
|
|
317
320
|
|
|
318
321
|
//#endregion
|
|
319
322
|
export { OrganizationType as n, Organization as t };
|
|
320
|
-
//# sourceMappingURL=organization-
|
|
323
|
+
//# sourceMappingURL=organization-CEkzOuGJ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"organization-CEkzOuGJ.mjs","names":[],"sources":["../../plugins/organization/models/OrganizationType.mjs","../../plugins/organization/models/Organization.mjs"],"sourcesContent":["import { createField, createModel, uuid, now } from '@yongdall/model';\n\nexport const OrganizationType = createModel('organizationType', {\n\tid: createField('string', { nullable: false, label: '标识', primary: 1 }),\n\tlabel: createField('string', { nullable: false, default: '', label: '名称' }),\n\tdescription: createField('string', { nullable: true, default: '', label: '描述' }),\n\tcreatedAt: createField('timestamp', { nullable: false, creating: now, label: '创建日期' }),\n\tupdatedAt: createField('timestamp', { nullable: false, updating: now, label: '最后更新日期' }),\n}, {\n\tlabel: '组织类型',\n\tlabelField: 'label',\n\tpermissions: [\n\t\t{permission: 'system:organization', fields: '*', authorizations: ['query', 'options', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{permission: 'organization', fields: '*', authorizations: ['query', 'options', 'read'] },\n\t],\n});\n","import { createField, createModel, uuid, now, Query, mergeHooks, Where } from '@yongdall/model';\nimport { useConnection } from '@yongdall/connection';\nimport { nestedSetTree, ServerError } from '@yongdall/core';\n\n// 定义模型\nexport const Organization = createModel('organization', {\n\tid: createField('uuid', { nullable: false, default: uuid, primary: 1, uncreatable: true, layout: { hidden: true } }),\n\tlabel: createField('string', { size: 255, nullable: false, default: '', label: '名称', layout: { colSpan: 6 } }),\n\tparentId: createField('uuid', { nullable: true, label: '上级组织', model: 'organization', renderer: 'document', layout: { colSpan: 6 } }),\n\ttypeId: createField('string', { size: 255, array: true, nullable: false, label: '类型', model: 'organizationType',source: {value: 'id'}, renderer: 'select', default: [], layout: { colSpan: 6 } }),\n\tinternal: createField('bool', { nullable: false, default: false, label: '是否为子组织', layout: { colSpan: 6 } }),\n\tmainId: createField('uuid', { nullable: true, label: '所属主体组织', model: 'organization', renderer: 'document', layout: { colSpan: 6 } }),\n\tdescription: createField('text', { nullable: true, label: '描述' }),\n\n\t// Nested Set 树结构字段,通常由 hook 自动维护,但需定义以便存储\n\tlft: createField('i32', { nullable: false, default: 0, label: 'LFT', layout: { hidden: true } }),\n\trgt: createField('i32', { nullable: false, default: 0, label: 'RGT', layout: { hidden: true } }),\n\n\tcreatedAt: createField('timestamp', { nullable: false, creating: now, label: '创建日期', layout: { hidden: true } }),\n\tupdatedAt: createField('timestamp', { nullable: false, updating: now, label: '最后更新日期', layout: { hidden: true } }),\n}, {\n\tlabel: '组织',\n\tlabelField: 'label',\n\tpermissions: [\n\t\t{ permission: 'system:organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: 'system:organization', fields: ['mainId', 'lft'], authorizations: ['options', 'query', 'read'] },\n\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'mainId', authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'mainId', authorizations: ['options', 'query', 'read'] },\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'parentId', authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'parentId', authorizations: ['options', 'query', 'read'] },\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'id', authorizations: ['options', 'query', 'read', 'create', 'update', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'id', authorizations: ['options', 'query', 'read'] },\n\t],\n\thooks: mergeHooks(nestedSetTree('parentId'), {\n\n\t\tasync beforeCreate(conn, Model, document) {\n\t\t\tdelete document.mainId;\n\n\t\t\tif (!document.internal) {\n\t\t\t\tconst parentId = document.parentId;\n\t\t\t\tif (!parentId) { return; }\n\t\t\t\tconst parent = await conn.first(new Query(Model).where('id', parentId));\n\t\t\t\tif (!parent) {\n\t\t\t\t\tdelete document.parentId;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tif (parent.internal) {\n\t\t\t\t\tthrow new ServerError('主体组织,只能作为其他主体组织的下级组织');\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst parentId = document.parentId;\n\t\t\tconst parent = parentId\n\t\t\t\t? await conn.first(new Query(Model).where('id', parentId))\n\t\t\t\t: null;\n\n\t\t\tif (!parent) {\n\t\t\t\tthrow new ServerError('请选择上级组织');\n\t\t\t}\n\n\t\t\tdocument.internal = true;\n\t\t\tdocument.mainId = (parent.internal && parent.mainId) || parent.id;\n\t\t},\n\t\tasync afterCreate(conn, Model, document) {\n\t\t\tif (document.mainId) { return; }\n\t\t\tconst id = document.id;\n\t\t\tif (!await conn.update(Model, { mainId: id }, Where.and('id', id), true)) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tdocument.mainId = id;\n\t\t},\n\n\t\tasync beforeUpdate(conn, Model, document, set) {\n\t\t\tdelete set.mainId;\n\n\t\t\tconst parentId = set.parentId;\n\t\t\t// 检查 parentId 是否真的改变\n\t\t\tif ((typeof parentId !== 'number' && typeof parentId !== 'string') || parentId === document.parentId) {\n\t\t\t\tdelete set.parentId;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (!parentId) {\n\t\t\t\tif (document.internal) {\n\t\t\t\t\tdelete set.parentId;\n\t\t\t\t} else {\n\t\t\t\t\tset.parentId = null;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (!document.internal) {\n\t\t\t\tconst parent = await conn.count(\n\t\t\t\t\tnew Query(Model)\n\t\t\t\t\t\t.where('id', parentId)\n\t\t\t\t\t\t.where('internal', false)\n\t\t\t\t);\n\t\t\t\tif (parent) { return; }\n\t\t\t\tthrow new ServerError('主体组织,只能作为其他主体组织的下级组织');\n\t\t\t}\n\n\t\t\tconst parent = await conn.count(\n\t\t\t\tnew Query(Model)\n\t\t\t\t.where('id', parentId)\n\t\t\t\t.where('mainId', document.mainId)\n\t\t\t);\n\t\t\t\tif (parent) { return; }\n\t\t\tthrow new ServerError('非主体组织,只能调整到同一主体组织下');\n\n\n\t\t}\n\t}),\n});\n\n// 静态方法转换为独立导出函数\n// 使用时需传入 connection 或直接使用模型引用\n/**\n * \n * @param {string?} id \n * @returns \n */\nexport async function getAncestors(id) {\n\tif (!id) return [];\n\tconst conn = useConnection('rdb');\n\tconst o = await conn.first(\n\t\tnew Query(Organization).select('lft', 'rgt').where('id', id)\n\t);\n\tif (!o) { return []; }\n\n\tconst { lft, rgt } = o;\n\tconst list = await conn.select(\n\t\tnew Query(Organization).select('id').where('lft', '<=', lft).where('rgt', '>=', rgt)\n\t);\n\treturn list.map(v => v.id);\n}\n\n/**\n * \n * @param {string?} id \n * @returns \n */\nexport async function getPosterity(id) {\n\tif (!id) return [];\n\tconst conn = useConnection('rdb');\n\tconst o = await conn.first(new Query(Organization).select('lft', 'rgt').where('id', id));\n\tif (!o) { return []; }\n\n\tconst { lft, rgt } = o;\n\tconst list = await conn.select(\n\t\tnew Query(Organization).select('id').where('lft', '>=', lft).where('rgt', '<=', rgt)\n\t);\n\treturn list.map(v => v.id);\n}\n\nexport default Organization;\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"organization-bygDRLDu.mjs","names":[],"sources":["../../plugins/organization/models/OrganizationType.mjs","../../plugins/organization/models/Organization.mjs"],"sourcesContent":["import { createField, createModel, uuid, now } from '@yongdall/model';\n\nexport const OrganizationType = createModel('organizationType', {\n\tid: createField('string', { nullable: false, label: '标识', primary: 1 }),\n\tlabel: createField('string', { nullable: false, default: '', label: '名称' }),\n\tdescription: createField('string', { nullable: true, default: '', label: '描述' }),\n\tcreatedAt: createField('timestamp', { nullable: false, creating: now, label: '创建日期' }),\n\tupdatedAt: createField('timestamp', { nullable: false, updating: now, label: '最后更新日期' }),\n}, {\n\tlabel: '组织类型',\n\tlabelField: 'label',\n\tpermissions: [\n\t\t{permission: 'system:organization', fields: '*', authorizations: ['query', 'options', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{permission: 'organization', fields: '*', authorizations: ['query', 'options', 'read'] },\n\t],\n});\n","import { createField, createModel, uuid, now, Query, mergeHooks, Where } from '@yongdall/model';\nimport { useConnection } from '@yongdall/connection';\nimport { nestedSetTree, ServerError } from '@yongdall/core';\n\n// 定义模型\nexport const Organization = createModel('organization', {\n\tid: createField('uuid', { nullable: false, default: uuid, primary: 1, uncreatable: true, layout: { hidden: true } }),\n\tlabel: createField('string', { size: 255, nullable: false, default: '', label: '名称', layout: { colSpan: 6 } }),\n\tparentId: createField('uuid', { nullable: true, label: '上级组织', model: 'organization', renderer: 'document', layout: { colSpan: 6 } }),\n\ttypeId: createField('string', { size: 255, nullable: false, label: '类型', model: 'organizationType', renderer: 'document', layout: { colSpan: 6 } }),\n\tinternal: createField('bool', { nullable: false, default: false, label: '是否为子组织', layout: { colSpan: 6 } }),\n\tmainId: createField('uuid', { nullable: true, label: '所属主体组织', model: 'organization', renderer: 'document', layout: { colSpan: 6 } }),\n\tdescription: createField('text', { nullable: true, label: '描述' }),\n\n\t// Nested Set 树结构字段,通常由 hook 自动维护,但需定义以便存储\n\tlft: createField('i32', { nullable: false, default: 0, label: 'LFT', layout: { hidden: true } }),\n\trgt: createField('i32', { nullable: false, default: 0, label: 'RGT', layout: { hidden: true } }),\n\n\tcreatedAt: createField('timestamp', { nullable: false, creating: now, label: '创建日期', layout: { hidden: true } }),\n\tupdatedAt: createField('timestamp', { nullable: false, updating: now, label: '最后更新日期', layout: { hidden: true } }),\n}, {\n\tlabel: '组织',\n\tlabelField: 'label',\n\tpermissions: [\n\t\t{ permission: 'system:organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: 'system:organization', fields: ['mainId', 'lft'], authorizations: ['options', 'query', 'read'] },\n\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'mainId', authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'mainId', authorizations: ['options', 'query', 'read'] },\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'parentId', authorizations: ['options', 'query', 'read', 'create', 'update', 'destroy', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'parentId', authorizations: ['options', 'query', 'read'] },\n\t\t{ permission: 'organization', fields: ['id', 'label', 'parentId', 'typeId', 'internal', 'description', 'createdAt', 'updatedAt'], organizationField: 'id', authorizations: ['options', 'query', 'read', 'create', 'update', 'add', 'remove'] },\n\t\t{ permission: '', fields: ['mainId', 'lft'], organizationField: 'id', authorizations: ['options', 'query', 'read'] },\n\t],\n\thooks: mergeHooks(nestedSetTree('parentId'), {\n\n\t\tasync beforeCreate(conn, Model, document) {\n\t\t\tdelete document.mainId;\n\n\t\t\tif (!document.internal) {\n\t\t\t\tconst parentId = document.parentId;\n\t\t\t\tif (!parentId) { return; }\n\t\t\t\tconst parent = await conn.first(new Query(Model).where('id', parentId));\n\t\t\t\tif (!parent) {\n\t\t\t\t\tdelete document.parentId;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tif (parent.internal) {\n\t\t\t\t\tthrow new ServerError('主体组织,只能作为其他主体组织的下级组织');\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst parentId = document.parentId;\n\t\t\tconst parent = parentId\n\t\t\t\t? await conn.first(new Query(Model).where('id', parentId))\n\t\t\t\t: null;\n\n\t\t\tif (!parent) {\n\t\t\t\tthrow new ServerError('请选择上级组织');\n\t\t\t}\n\n\t\t\tdocument.internal = true;\n\t\t\tdocument.mainId = (parent.internal && parent.mainId) || parent.id;\n\t\t},\n\t\tasync afterCreate(conn, Model, document) {\n\t\t\tif (document.mainId) { return; }\n\t\t\tconst id = document.id;\n\t\t\tif (!await conn.update(Model, { mainId: id }, Where.and('id', id), true)) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tdocument.mainId = id;\n\t\t},\n\n\t\tasync beforeUpdate(conn, Model, document, set) {\n\t\t\tdelete set.mainId;\n\n\t\t\tconst parentId = set.parentId;\n\t\t\t// 检查 parentId 是否真的改变\n\t\t\tif ((typeof parentId !== 'number' && typeof parentId !== 'string') || parentId === document.parentId) {\n\t\t\t\tdelete set.parentId;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (!parentId) {\n\t\t\t\tif (document.internal) {\n\t\t\t\t\tdelete set.parentId;\n\t\t\t\t} else {\n\t\t\t\t\tset.parentId = null;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (!document.internal) {\n\t\t\t\tconst parent = await conn.count(\n\t\t\t\t\tnew Query(Model)\n\t\t\t\t\t\t.where('id', parentId)\n\t\t\t\t\t\t.where('internal', false)\n\t\t\t\t);\n\t\t\t\tif (parent) { return; }\n\t\t\t\tthrow new ServerError('主体组织,只能作为其他主体组织的下级组织');\n\t\t\t}\n\n\t\t\tconst parent = await conn.count(\n\t\t\t\tnew Query(Model)\n\t\t\t\t.where('id', parentId)\n\t\t\t\t.where('mainId', document.mainId)\n\t\t\t);\n\t\t\t\tif (parent) { return; }\n\t\t\tthrow new ServerError('非主体组织,只能调整到同一主体组织下');\n\n\n\t\t}\n\t}),\n});\n\n// 静态方法转换为独立导出函数\n// 使用时需传入 connection 或直接使用模型引用\n/**\n * \n * @param {string?} id \n * @returns \n */\nexport async function getAncestors(id) {\n\tif (!id) return [];\n\tconst conn = useConnection('rdb');\n\tconst o = await conn.first(\n\t\tnew Query(Organization).select('lft', 'rgt').where('id', id)\n\t);\n\tif (!o) { return []; }\n\n\tconst { lft, rgt } = o;\n\tconst list = await conn.select(\n\t\tnew Query(Organization).select('id').where('lft', '<=', lft).where('rgt', '>=', rgt)\n\t);\n\treturn list.map(v => v.id);\n}\n\n/**\n * \n * @param {string?} id \n * @returns \n */\nexport async function getPosterity(id) {\n\tif (!id) return [];\n\tconst conn = useConnection('rdb');\n\tconst o = await conn.first(new Query(Organization).select('lft', 'rgt').where('id', id));\n\tif (!o) { return []; }\n\n\tconst { lft, rgt } = o;\n\tconst list = await conn.select(\n\t\tnew Query(Organization).select('id').where('lft', '>=', lft).where('rgt', '<=', rgt)\n\t);\n\treturn list.map(v => v.id);\n}\n\nexport default Organization;\n"],"mappings":"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"}
|