@mikro-orm/core 7.0.0-dev.145 → 7.0.0-dev.147
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/metadata/MetadataDiscovery.js +6 -5
- package/package.json +1 -1
- package/typings.d.ts +2 -2
- package/utils/Utils.js +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EntityMetadata, } from '../typings.js';
|
|
2
|
-
import { Utils } from '../utils/Utils.js';
|
|
2
|
+
import { compareArrays, Utils } from '../utils/Utils.js';
|
|
3
3
|
import { MetadataValidator } from './MetadataValidator.js';
|
|
4
4
|
import { MetadataProvider } from './MetadataProvider.js';
|
|
5
5
|
import { MetadataStorage } from './MetadataStorage.js';
|
|
@@ -932,7 +932,8 @@ export class MetadataDiscovery {
|
|
|
932
932
|
let i = 1;
|
|
933
933
|
Object.values(meta.properties).forEach(prop => {
|
|
934
934
|
const newProp = { ...prop };
|
|
935
|
-
|
|
935
|
+
const rootProp = meta.root.properties[prop.name];
|
|
936
|
+
if (rootProp && (rootProp.type !== prop.type || (rootProp.fieldNames && prop.fieldNames && !compareArrays(rootProp.fieldNames, prop.fieldNames)))) {
|
|
936
937
|
const name = newProp.name;
|
|
937
938
|
this.initFieldName(newProp, newProp.object);
|
|
938
939
|
newProp.name = name + '_' + (i++);
|
|
@@ -943,11 +944,11 @@ export class MetadataDiscovery {
|
|
|
943
944
|
newProp.inherited = true;
|
|
944
945
|
return;
|
|
945
946
|
}
|
|
946
|
-
if (prop.enum && prop.items &&
|
|
947
|
-
newProp.items = Utils.unique([...
|
|
947
|
+
if (prop.enum && prop.items && rootProp?.items) {
|
|
948
|
+
newProp.items = Utils.unique([...rootProp.items, ...prop.items]);
|
|
948
949
|
}
|
|
949
950
|
newProp.nullable = true;
|
|
950
|
-
newProp.inherited = !
|
|
951
|
+
newProp.inherited = !rootProp;
|
|
951
952
|
meta.root.addProperty(newProp);
|
|
952
953
|
});
|
|
953
954
|
meta.tableName = meta.root.tableName;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mikro-orm/core",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "7.0.0-dev.
|
|
4
|
+
"version": "7.0.0-dev.147",
|
|
5
5
|
"description": "TypeScript ORM for Node.js based on Data Mapper, Unit of Work and Identity Map patterns. Supports MongoDB, MySQL, PostgreSQL and SQLite databases as well as usage with vanilla JavaScript.",
|
|
6
6
|
"exports": {
|
|
7
7
|
"./package.json": "./package.json",
|
package/typings.d.ts
CHANGED
|
@@ -745,13 +745,13 @@ export type PopulateOptions<T> = {
|
|
|
745
745
|
type Loadable<T extends object> = Collection<T, any> | Reference<T> | Ref<T> | readonly T[];
|
|
746
746
|
type ExtractType<T> = T extends Loadable<infer U> ? U : T;
|
|
747
747
|
type ExtractStringKeys<T> = {
|
|
748
|
-
[K in keyof T]
|
|
748
|
+
[K in keyof T]-?: CleanKeys<T, K>;
|
|
749
749
|
}[keyof T] & {};
|
|
750
750
|
type StringKeys<T, E extends string = never> = T extends Collection<any, any> ? ExtractStringKeys<ExtractType<T>> | E : T extends Reference<any> ? ExtractStringKeys<ExtractType<T>> | E : T extends object ? ExtractStringKeys<ExtractType<T>> | E : never;
|
|
751
751
|
type GetStringKey<T, K extends StringKeys<T, string>, E extends string> = K extends keyof T ? ExtractType<T[K]> : (K extends E ? keyof T : never);
|
|
752
752
|
type Prev = [never, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
|
|
753
753
|
type CollectionKeys<T> = T extends object ? {
|
|
754
|
-
[K in keyof T]
|
|
754
|
+
[K in keyof T]-?: T[K] extends Collection<any> ? IsAny<T[K]> extends true ? never : K & string : never;
|
|
755
755
|
}[keyof T] & {} : never;
|
|
756
756
|
export type AutoPath<O, P extends string | boolean, E extends string = never, D extends Prev[number] = 9> = P extends boolean ? P : [D] extends [never] ? never : P extends any ? P extends string ? (P & `${string}.` extends never ? P : P & `${string}.`) extends infer Q ? Q extends `${infer A}.${infer B}` ? A extends StringKeys<O, E> ? `${A}.${AutoPath<NonNullable<GetStringKey<O, A, E>>, B, E, Prev[D]>}` : never : Q extends StringKeys<O, E> ? (NonNullable<GetStringKey<O, Q, E>> extends unknown ? Exclude<P, `${string}.`> : never) | (StringKeys<NonNullable<GetStringKey<O, Q, E>>, E> extends never ? never : `${Q & string}.`) : StringKeys<O, E> | `${CollectionKeys<O>}:ref` : never : never : never;
|
|
757
757
|
export type UnboxArray<T> = T extends any[] ? ArrayElement<T> : T;
|
package/utils/Utils.js
CHANGED
|
@@ -123,7 +123,7 @@ export function parseJsonSafe(value) {
|
|
|
123
123
|
}
|
|
124
124
|
export class Utils {
|
|
125
125
|
static PK_SEPARATOR = '~~~';
|
|
126
|
-
static #ORM_VERSION = '7.0.0-dev.
|
|
126
|
+
static #ORM_VERSION = '7.0.0-dev.147';
|
|
127
127
|
/**
|
|
128
128
|
* Checks if the argument is instance of `Object`. Returns false for arrays.
|
|
129
129
|
*/
|