Merge branch 'fix/vision-preset-bug-fix-0729' into 'release/0.9.0'

Fix/vision preset bug fix 0729



See merge request !913094
This commit is contained in:
康为 2020-07-29 20:40:33 +08:00
commit 867f63aea8
5 changed files with 58 additions and 23 deletions

View File

@ -244,7 +244,7 @@ export class NodeChildren {
return this.children.some((child, index) => fn(child, index));
}
filter(fn: (item: Node, index: number) => item is Node) {
filter(fn: (item: Node, index: number) => any) {
return this.children.filter(fn);
}

View File

@ -793,11 +793,39 @@ export class Node<Schema extends NodeSchema = NodeSchema> {
* @deprecated
*/
getSuitablePlace(node: Node, ref: any): any {
// TODO:
if (this.isRoot()) {
if (this.isRoot() && this.children) {
const dropElement = this.children.filter((c: Node) => {
if (!c.isContainer()) {
return false;
}
const canDropIn = c.componentMeta?.prototype?.options?.canDropIn;
if (typeof canDropIn === 'function') {
return canDropIn(node);
} else if (typeof canDropIn === 'boolean'){
return canDropIn;
}
return true;
})[0];
if (dropElement) {
return { container: dropElement, ref };
}
return { container: this, ref };
}
return { container: this.parent, ref: this };
const canDropIn = this.componentMeta?.prototype?.options?.canDropIn;
if (this.isContainer()) {
if (canDropIn === undefined ||
(typeof canDropIn === 'boolean' && canDropIn) ||
(typeof canDropIn === 'function' && canDropIn(node))){
return { container: this, ref };
}
}
if (this.parent) {
return this.parent.getSuitablePlace(node, ref);
}
return null;
}
/**
* @deprecated
@ -813,9 +841,9 @@ export class Node<Schema extends NodeSchema = NodeSchema> {
* @deprecated
*/
registerAddon(key: string, exportData: () => any, isProp: boolean = false) {
if (this._addons[key]) {
throw new Error(`node addon ${key} exist`);
}
// if (this._addons[key]) {
// throw new Error(`node addon ${key} exist`);
// }
this._addons[key] = { exportData, isProp };
}

View File

@ -281,21 +281,24 @@ export function upgradePropConfig(config: OldPropConfig, collector: ConfigCollec
}
let initialFn = (slotName ? null : initial) || initialValue;
if (slotName && initialValue === true) {
initialFn = (value: any, defaultValue: any) => {
if (isJSSlot(value)) {
return {
title: slotTitle || title,
...value,
};
}
return {
type: 'JSSlot',
title: slotTitle || title,
value: initialChildren,
};
};
}
// 在 upgrade reducer 做了 JSBlock ——> JSSlot
// if (slotName && initialValue === true) {
// initialFn = (value: any, defaultValue: any) => {
// if (isJSSlot(value)) {
// return {
// title: slotTitle || title,
// name: slotName,
// ...value,
// };
// }
// return {
// type: 'JSSlot',
// title: slotTitle || title,
// name: slotName,
// value: initialChildren,
// };
// };
// }
if (!slotName) {
if (accessor) {
@ -401,6 +404,7 @@ export function upgradePropConfig(config: OldPropConfig, collector: ConfigCollec
return {
type: 'JSSlot',
title: slotTitle || title,
name: slotName,
value: value == null ? initialChildren : value,
};
},

View File

@ -51,5 +51,5 @@
"ts-node/register"
]
},
"homepage": "https://unpkg.alibaba-inc.com/@ali/lowcode-rax-simulator-renderer@0.8.35/build/index.html"
"homepage": "https://unpkg.alibaba-inc.com/@ali/lowcode-rax-simulator-renderer@0.8.36/build/index.html"
}

View File

@ -309,6 +309,8 @@ export default class BaseEngine extends PureComponent {
if (scopeKey && this.__compScopes[scopeKey]) {
props.__scope = this.__compScopes[scopeKey];
}
// FIXME key key
props.key = '';
if (schema.__ctx && schema.__ctx.lunaKey) {
if (!isFileSchema(schema)) {
engine && engine.props.onCompGetCtx(schema, self);
@ -317,6 +319,7 @@ export default class BaseEngine extends PureComponent {
} else if (typeof idx === 'number' && !props.key) {
props.key = idx;
}
props.__id = schema.id;
const renderComp = (props) => {
return engine.createElement(