@things-factory/kpi 9.0.18 → 9.0.19

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 (134) hide show
  1. package/client/bootstrap.ts +8 -0
  2. package/client/pages/kpi/kpi-list-page.ts +91 -11
  3. package/client/pages/kpi-category/kpi-category-list-page.ts +80 -8
  4. package/client/pages/kpi-history/kpi-history-list-page.ts +1 -1
  5. package/client/pages/kpi-metric/kpi-metric-list-page.ts +31 -7
  6. package/client/pages/kpi-metric-value/kpi-metric-value-importer.ts +65 -0
  7. package/client/pages/kpi-metric-value/kpi-metric-value-list-page.ts +299 -0
  8. package/client/pages/{kpi-value/kpi-value-manual-entry-form.ts → kpi-metric-value/kpi-metric-value-manual-entry-form.ts} +18 -44
  9. package/client/pages/{kpi-value/kpi-value-manual-entry-page.ts → kpi-metric-value/kpi-metric-value-manual-entry-page.ts} +21 -21
  10. package/client/pages/kpi-value/kpi-value-list-page.ts +4 -6
  11. package/client/route.ts +6 -2
  12. package/dist-client/bootstrap.d.ts +2 -0
  13. package/dist-client/bootstrap.js +7 -0
  14. package/dist-client/bootstrap.js.map +1 -0
  15. package/dist-client/pages/kpi/kpi-list-page.d.ts +6 -0
  16. package/dist-client/pages/kpi/kpi-list-page.js +94 -11
  17. package/dist-client/pages/kpi/kpi-list-page.js.map +1 -1
  18. package/dist-client/pages/kpi-category/kpi-category-list-page.d.ts +5 -0
  19. package/dist-client/pages/kpi-category/kpi-category-list-page.js +83 -8
  20. package/dist-client/pages/kpi-category/kpi-category-list-page.js.map +1 -1
  21. package/dist-client/pages/kpi-history/kpi-history-list-page.js +1 -1
  22. package/dist-client/pages/kpi-history/kpi-history-list-page.js.map +1 -1
  23. package/dist-client/pages/kpi-metric/kpi-metric-list-page.js +29 -5
  24. package/dist-client/pages/kpi-metric/kpi-metric-list-page.js.map +1 -1
  25. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.d.ts +23 -0
  26. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.js +75 -0
  27. package/dist-client/pages/kpi-metric-value/kpi-metric-value-importer.js.map +1 -0
  28. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.d.ts +61 -0
  29. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.js +301 -0
  30. package/dist-client/pages/kpi-metric-value/kpi-metric-value-list-page.js.map +1 -0
  31. package/dist-client/pages/{kpi-value/kpi-value-manual-entry-form.d.ts → kpi-metric-value/kpi-metric-value-manual-entry-form.d.ts} +3 -5
  32. package/dist-client/pages/{kpi-value/kpi-value-manual-entry-form.js → kpi-metric-value/kpi-metric-value-manual-entry-form.js} +27 -56
  33. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-form.js.map +1 -0
  34. package/dist-client/pages/{kpi-value/kpi-value-manual-entry-page.d.ts → kpi-metric-value/kpi-metric-value-manual-entry-page.d.ts} +5 -5
  35. package/dist-client/pages/{kpi-value/kpi-value-manual-entry-page.js → kpi-metric-value/kpi-metric-value-manual-entry-page.js} +28 -28
  36. package/dist-client/pages/kpi-metric-value/kpi-metric-value-manual-entry-page.js.map +1 -0
  37. package/dist-client/pages/kpi-value/kpi-value-list-page.js +4 -6
  38. package/dist-client/pages/kpi-value/kpi-value-list-page.js.map +1 -1
  39. package/dist-client/route.d.ts +1 -1
  40. package/dist-client/route.js +5 -2
  41. package/dist-client/route.js.map +1 -1
  42. package/dist-client/tsconfig.tsbuildinfo +1 -1
  43. package/dist-server/service/index.d.ts +4 -2
  44. package/dist-server/service/index.js +6 -1
  45. package/dist-server/service/index.js.map +1 -1
  46. package/dist-server/service/kpi/aggregate-kpi.js +5 -7
  47. package/dist-server/service/kpi/aggregate-kpi.js.map +1 -1
  48. package/dist-server/service/kpi/kpi-history.d.ts +3 -1
  49. package/dist-server/service/kpi/kpi-history.js +10 -0
  50. package/dist-server/service/kpi/kpi-history.js.map +1 -1
  51. package/dist-server/service/kpi/kpi-mutation.js +1 -1
  52. package/dist-server/service/kpi/kpi-mutation.js.map +1 -1
  53. package/dist-server/service/kpi/kpi-type.d.ts +2 -0
  54. package/dist-server/service/kpi/kpi-type.js +8 -0
  55. package/dist-server/service/kpi/kpi-type.js.map +1 -1
  56. package/dist-server/service/kpi/kpi.d.ts +9 -0
  57. package/dist-server/service/kpi/kpi.js +23 -1
  58. package/dist-server/service/kpi/kpi.js.map +1 -1
  59. package/dist-server/service/kpi-category/kpi-category-mutation.js +0 -8
  60. package/dist-server/service/kpi-category/kpi-category-mutation.js.map +1 -1
  61. package/dist-server/service/kpi-category/kpi-category-type.d.ts +4 -2
  62. package/dist-server/service/kpi-category/kpi-category-type.js +16 -8
  63. package/dist-server/service/kpi-category/kpi-category-type.js.map +1 -1
  64. package/dist-server/service/kpi-category/kpi-category.d.ts +2 -2
  65. package/dist-server/service/kpi-category/kpi-category.js +8 -8
  66. package/dist-server/service/kpi-category/kpi-category.js.map +1 -1
  67. package/dist-server/service/kpi-metric/aggregate-kpi-metric.js +31 -74
  68. package/dist-server/service/kpi-metric/aggregate-kpi-metric.js.map +1 -1
  69. package/dist-server/service/kpi-metric/kpi-metric-mutation.d.ts +1 -1
  70. package/dist-server/service/kpi-metric/kpi-metric-mutation.js +15 -28
  71. package/dist-server/service/kpi-metric/kpi-metric-mutation.js.map +1 -1
  72. package/dist-server/service/kpi-metric/kpi-metric-type.d.ts +6 -4
  73. package/dist-server/service/kpi-metric/kpi-metric-type.js +20 -12
  74. package/dist-server/service/kpi-metric/kpi-metric-type.js.map +1 -1
  75. package/dist-server/service/kpi-metric/kpi-metric.d.ts +15 -2
  76. package/dist-server/service/kpi-metric/kpi-metric.js +34 -14
  77. package/dist-server/service/kpi-metric/kpi-metric.js.map +1 -1
  78. package/dist-server/service/kpi-metric-value/index.d.ts +6 -0
  79. package/dist-server/service/kpi-metric-value/index.js +10 -0
  80. package/dist-server/service/kpi-metric-value/index.js.map +1 -0
  81. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.d.ts +11 -0
  82. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.js +229 -0
  83. package/dist-server/service/kpi-metric-value/kpi-metric-value-mutation.js.map +1 -0
  84. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.d.ts +13 -0
  85. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.js +95 -0
  86. package/dist-server/service/kpi-metric-value/kpi-metric-value-query.js.map +1 -0
  87. package/dist-server/service/kpi-metric-value/kpi-metric-value-type.d.ts +26 -0
  88. package/dist-server/service/kpi-metric-value/kpi-metric-value-type.js +112 -0
  89. package/dist-server/service/kpi-metric-value/kpi-metric-value-type.js.map +1 -0
  90. package/dist-server/service/kpi-metric-value/kpi-metric-value.d.ts +23 -0
  91. package/dist-server/service/kpi-metric-value/kpi-metric-value.js +106 -0
  92. package/dist-server/service/kpi-metric-value/kpi-metric-value.js.map +1 -0
  93. package/dist-server/service/kpi-value/kpi-value-mutation.js +1 -2
  94. package/dist-server/service/kpi-value/kpi-value-mutation.js.map +1 -1
  95. package/dist-server/service/kpi-value/kpi-value-query.js +1 -1
  96. package/dist-server/service/kpi-value/kpi-value-query.js.map +1 -1
  97. package/dist-server/service/kpi-value/kpi-value-type.d.ts +2 -4
  98. package/dist-server/service/kpi-value/kpi-value-type.js +4 -18
  99. package/dist-server/service/kpi-value/kpi-value-type.js.map +1 -1
  100. package/dist-server/service/kpi-value/kpi-value.d.ts +3 -3
  101. package/dist-server/service/kpi-value/kpi-value.js +13 -14
  102. package/dist-server/service/kpi-value/kpi-value.js.map +1 -1
  103. package/dist-server/tsconfig.tsbuildinfo +1 -1
  104. package/package.json +3 -3
  105. package/server/service/index.ts +6 -1
  106. package/server/service/kpi/aggregate-kpi.ts +5 -8
  107. package/server/service/kpi/kpi-history.ts +9 -1
  108. package/server/service/kpi/kpi-mutation.ts +1 -1
  109. package/server/service/kpi/kpi-type.ts +6 -0
  110. package/server/service/kpi/kpi.ts +21 -0
  111. package/server/service/kpi-category/kpi-category-mutation.ts +0 -10
  112. package/server/service/kpi-category/kpi-category-type.ts +12 -6
  113. package/server/service/kpi-category/kpi-category.ts +6 -6
  114. package/server/service/kpi-metric/aggregate-kpi-metric.ts +29 -69
  115. package/server/service/kpi-metric/kpi-metric-mutation.ts +15 -26
  116. package/server/service/kpi-metric/kpi-metric-type.ts +17 -12
  117. package/server/service/kpi-metric/kpi-metric.ts +32 -11
  118. package/server/service/kpi-metric-value/index.ts +7 -0
  119. package/server/service/kpi-metric-value/kpi-metric-value-mutation.ts +215 -0
  120. package/server/service/kpi-metric-value/kpi-metric-value-query.ts +60 -0
  121. package/server/service/kpi-metric-value/kpi-metric-value-type.ts +82 -0
  122. package/server/service/kpi-metric-value/kpi-metric-value.ts +91 -0
  123. package/server/service/kpi-value/kpi-value-mutation.ts +1 -2
  124. package/server/service/kpi-value/kpi-value-query.ts +1 -1
  125. package/server/service/kpi-value/kpi-value-type.ts +4 -16
  126. package/server/service/kpi-value/kpi-value.ts +14 -14
  127. package/things-factory.config.js +5 -3
  128. package/translations/en.json +8 -1
  129. package/translations/ja.json +8 -1
  130. package/translations/ko.json +9 -2
  131. package/translations/ms.json +9 -2
  132. package/translations/zh.json +8 -1
  133. package/dist-client/pages/kpi-value/kpi-value-manual-entry-form.js.map +0 -1
  134. package/dist-client/pages/kpi-value/kpi-value-manual-entry-page.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  import { User } from '@things-factory/auth-base';
2
2
  import { Domain } from '@things-factory/shell';
3
- import { Kpi } from '../kpi/kpi';
3
+ import { Kpi, KpiPeriodType } from '../kpi/kpi';
4
4
  export declare enum KpiValueInputType {
5
5
  MANUAL = "MANUAL",
6
6
  AUTO = "AUTO"
@@ -14,11 +14,11 @@ export declare class KpiValue {
14
14
  version: number;
15
15
  valueDate: string;
16
16
  value: number;
17
- groupId?: string;
18
- groupType?: string;
17
+ group?: string;
19
18
  inputType?: KpiValueInputType;
20
19
  source?: string;
21
20
  meta?: any;
21
+ periodType: KpiPeriodType;
22
22
  createdAt?: Date;
23
23
  updatedAt?: Date;
24
24
  creator?: User;
@@ -56,8 +56,10 @@ tslib_1.__decorate([
56
56
  tslib_1.__metadata("design:type", Number)
57
57
  ], KpiValue.prototype, "version", void 0);
58
58
  tslib_1.__decorate([
59
- (0, typeorm_1.Column)({ type: 'date' }),
60
- (0, type_graphql_1.Field)({ description: 'Date or period for which this KPI value is recorded (e.g., day, month, quarter).' }),
59
+ (0, typeorm_1.Column)(),
60
+ (0, type_graphql_1.Field)({
61
+ description: 'Date or period for which this KPI value is recorded (e.g., day: YYYY-MM-DD, month: YYYY-MM, quarter: YYYY-Qn, range: YYYY-MM-DD~YYYY-MM-DD).'
62
+ }),
61
63
  tslib_1.__metadata("design:type", String)
62
64
  ], KpiValue.prototype, "valueDate", void 0);
63
65
  tslib_1.__decorate([
@@ -67,17 +69,9 @@ tslib_1.__decorate([
67
69
  ], KpiValue.prototype, "value", void 0);
68
70
  tslib_1.__decorate([
69
71
  (0, typeorm_1.Column)({ nullable: true }),
70
- (0, type_graphql_1.Field)({
71
- nullable: true,
72
- description: 'ID of the group (organization, department, project, etc.) this value is associated with.'
73
- }),
74
- tslib_1.__metadata("design:type", String)
75
- ], KpiValue.prototype, "groupId", void 0);
76
- tslib_1.__decorate([
77
- (0, typeorm_1.Column)({ nullable: true }),
78
- (0, type_graphql_1.Field)({ nullable: true, description: 'Type of the group (e.g., USER, DEPT, PROJECT) for this value.' }),
72
+ (0, type_graphql_1.Field)({ nullable: true, description: 'Group key for this value (organization, line, user, etc.)' }),
79
73
  tslib_1.__metadata("design:type", String)
80
- ], KpiValue.prototype, "groupType", void 0);
74
+ ], KpiValue.prototype, "group", void 0);
81
75
  tslib_1.__decorate([
82
76
  (0, typeorm_1.Column)({ nullable: true }),
83
77
  (0, type_graphql_1.Field)({
@@ -110,6 +104,11 @@ tslib_1.__decorate([
110
104
  }),
111
105
  tslib_1.__metadata("design:type", Object)
112
106
  ], KpiValue.prototype, "meta", void 0);
107
+ tslib_1.__decorate([
108
+ (0, typeorm_1.Column)({ default: 'DAY' }),
109
+ (0, type_graphql_1.Field)(type => kpi_1.KpiPeriodType, { description: 'Aggregation period type for this KPI value.' }),
110
+ tslib_1.__metadata("design:type", String)
111
+ ], KpiValue.prototype, "periodType", void 0);
113
112
  tslib_1.__decorate([
114
113
  (0, typeorm_1.CreateDateColumn)(),
115
114
  (0, type_graphql_1.Field)({ nullable: true, description: 'Timestamp when this KPI value record was created.' }),
@@ -142,8 +141,8 @@ tslib_1.__decorate([
142
141
  ], KpiValue.prototype, "updaterId", void 0);
143
142
  exports.KpiValue = KpiValue = tslib_1.__decorate([
144
143
  (0, typeorm_1.Entity)(),
145
- (0, typeorm_1.Index)('ix_kpi_value_latest', ['domain', 'kpi', 'valueDate', 'groupId', 'groupType', 'version'], { unique: true }),
146
- (0, typeorm_1.Index)('ix_kpi_value_latest_for_query', ['domain', 'kpi', 'valueDate', 'groupId', 'groupType'], { unique: false }),
144
+ (0, typeorm_1.Index)('ix_kpi_value_latest', ['domain', 'kpi', 'valueDate', 'group', 'version'], { unique: true }),
145
+ (0, typeorm_1.Index)('ix_kpi_value_latest_for_query', ['domain', 'kpi', 'valueDate', 'group'], { unique: false }),
147
146
  (0, type_graphql_1.ObjectType)({ description: 'Entity for KpiValue' })
148
147
  ], KpiValue);
149
148
  //# sourceMappingURL=kpi-value.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"kpi-value.js","sourceRoot":"","sources":["../../../server/service/kpi-value/kpi-value.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType, Float } from 'type-graphql'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, ScalarObject, json5Transformer } from '@things-factory/shell'\nimport { config } from '@things-factory/env'\nimport { Kpi } from '../kpi/kpi'\n\nconst ORMCONFIG = config.get('ormconfig', {})\nconst DATABASE_TYPE = ORMCONFIG.type\n\nexport enum KpiValueInputType {\n MANUAL = 'MANUAL',\n AUTO = 'AUTO'\n}\n\nregisterEnumType(KpiValueInputType, {\n name: 'KpiValueInputType',\n description: 'Type of the input (Manual or Auto)'\n})\n\n@Entity()\n@Index('ix_kpi_value_latest', ['domain', 'kpi', 'valueDate', 'groupId', 'groupType', 'version'], { unique: true })\n@Index('ix_kpi_value_latest_for_query', ['domain', 'kpi', 'valueDate', 'groupId', 'groupType'], { unique: false })\n@ObjectType({ description: 'Entity for KpiValue' })\nexport class KpiValue {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID, { description: 'Unique identifier for this KPI value record.' })\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field({ nullable: true, description: 'Domain (tenant) to which this KPI value belongs.' })\n domain?: Domain\n\n @RelationId((kpiValue: KpiValue) => kpiValue.domain)\n @Field({ nullable: true, description: 'ID of the domain (tenant) for this KPI value.' })\n domainId?: string\n\n @ManyToOne(() => Kpi)\n @Field(type => Kpi, {\n nullable: true,\n description: 'Reference to the KPI definition for which this value is calculated.'\n })\n kpi: Kpi\n\n @RelationId((kpiValue: KpiValue) => kpiValue.kpi)\n @Field({ description: 'ID of the referenced KPI.' })\n kpiId: string\n\n @Column('int')\n @Field(type => Int, { description: 'Version of the KPI definition at the time this value was calculated.' })\n version: number\n\n @Column({ type: 'date' })\n @Field({ description: 'Date or period for which this KPI value is recorded (e.g., day, month, quarter).' })\n valueDate: string\n\n @Column('float')\n @Field(type => Float, { description: 'The calculated numeric value for this KPI and period.' })\n value: number\n\n @Column({ nullable: true })\n @Field({\n nullable: true,\n description: 'ID of the group (organization, department, project, etc.) this value is associated with.'\n })\n groupId?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true, description: 'Type of the group (e.g., USER, DEPT, PROJECT) for this value.' })\n groupType?: string\n\n @Column({ nullable: true })\n @Field({\n nullable: true,\n description: 'Indicates whether this value was entered manually or generated automatically.'\n })\n inputType?: KpiValueInputType\n\n @Column({ nullable: true })\n @Field({ nullable: true, description: 'Source of the value (e.g., system, user, external integration).' })\n source?: string\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : DATABASE_TYPE == 'mssql'\n ? 'nvarchar'\n : 'varchar',\n length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined,\n transformer: json5Transformer\n })\n @Field(type => ScalarObject, {\n nullable: true,\n description:\n 'Extended or non-numeric information related to this KPI value, stored as JSON5. Can include grade, status, comments, or other metadata.'\n })\n meta?: any\n\n @CreateDateColumn()\n @Field({ nullable: true, description: 'Timestamp when this KPI value record was created.' })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true, description: 'Timestamp when this KPI value record was last updated.' })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true, description: 'User who created this KPI value record.' })\n creator?: User\n\n @RelationId((kpiValue: KpiValue) => kpiValue.creator)\n @Field({ nullable: true, description: 'ID of the user who created this KPI value record.' })\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true, description: 'User who last updated this KPI value record.' })\n updater?: User\n\n @RelationId((kpiValue: KpiValue) => kpiValue.updater)\n @Field({ nullable: true, description: 'ID of the user who last updated this KPI value record.' })\n updaterId?: string\n}\n"]}
1
+ {"version":3,"file":"kpi-value.js","sourceRoot":"","sources":["../../../server/service/kpi-value/kpi-value.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType, Float } from 'type-graphql'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, ScalarObject, json5Transformer } from '@things-factory/shell'\nimport { config } from '@things-factory/env'\nimport { Kpi, KpiPeriodType } from '../kpi/kpi'\n\nconst ORMCONFIG = config.get('ormconfig', {})\nconst DATABASE_TYPE = ORMCONFIG.type\n\nexport enum KpiValueInputType {\n MANUAL = 'MANUAL',\n AUTO = 'AUTO'\n}\n\nregisterEnumType(KpiValueInputType, {\n name: 'KpiValueInputType',\n description: 'Type of the input (Manual or Auto)'\n})\n\n@Entity()\n@Index('ix_kpi_value_latest', ['domain', 'kpi', 'valueDate', 'group', 'version'], { unique: true })\n@Index('ix_kpi_value_latest_for_query', ['domain', 'kpi', 'valueDate', 'group'], { unique: false })\n@ObjectType({ description: 'Entity for KpiValue' })\nexport class KpiValue {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID, { description: 'Unique identifier for this KPI value record.' })\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field({ nullable: true, description: 'Domain (tenant) to which this KPI value belongs.' })\n domain?: Domain\n\n @RelationId((kpiValue: KpiValue) => kpiValue.domain)\n @Field({ nullable: true, description: 'ID of the domain (tenant) for this KPI value.' })\n domainId?: string\n\n @ManyToOne(() => Kpi)\n @Field(type => Kpi, {\n nullable: true,\n description: 'Reference to the KPI definition for which this value is calculated.'\n })\n kpi: Kpi\n\n @RelationId((kpiValue: KpiValue) => kpiValue.kpi)\n @Field({ description: 'ID of the referenced KPI.' })\n kpiId: string\n\n @Column('int')\n @Field(type => Int, { description: 'Version of the KPI definition at the time this value was calculated.' })\n version: number\n\n @Column()\n @Field({\n description:\n 'Date or period for which this KPI value is recorded (e.g., day: YYYY-MM-DD, month: YYYY-MM, quarter: YYYY-Qn, range: YYYY-MM-DD~YYYY-MM-DD).'\n })\n valueDate: string\n\n @Column('float')\n @Field(type => Float, { description: 'The calculated numeric value for this KPI and period.' })\n value: number\n\n @Column({ nullable: true })\n @Field({ nullable: true, description: 'Group key for this value (organization, line, user, etc.)' })\n group?: string\n\n @Column({ nullable: true })\n @Field({\n nullable: true,\n description: 'Indicates whether this value was entered manually or generated automatically.'\n })\n inputType?: KpiValueInputType\n\n @Column({ nullable: true })\n @Field({ nullable: true, description: 'Source of the value (e.g., system, user, external integration).' })\n source?: string\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : DATABASE_TYPE == 'mssql'\n ? 'nvarchar'\n : 'varchar',\n length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined,\n transformer: json5Transformer\n })\n @Field(type => ScalarObject, {\n nullable: true,\n description:\n 'Extended or non-numeric information related to this KPI value, stored as JSON5. Can include grade, status, comments, or other metadata.'\n })\n meta?: any\n\n @Column({ default: 'DAY' })\n @Field(type => KpiPeriodType, { description: 'Aggregation period type for this KPI value.' })\n periodType: KpiPeriodType\n\n @CreateDateColumn()\n @Field({ nullable: true, description: 'Timestamp when this KPI value record was created.' })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true, description: 'Timestamp when this KPI value record was last updated.' })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true, description: 'User who created this KPI value record.' })\n creator?: User\n\n @RelationId((kpiValue: KpiValue) => kpiValue.creator)\n @Field({ nullable: true, description: 'ID of the user who created this KPI value record.' })\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true, description: 'User who last updated this KPI value record.' })\n updater?: User\n\n @RelationId((kpiValue: KpiValue) => kpiValue.updater)\n @Field({ nullable: true, description: 'ID of the user who last updated this KPI value record.' })\n updaterId?: string\n}\n"]}