Skip to content

Commit

Permalink
fix: fix issue with inversify error when nobind
Browse files Browse the repository at this point in the history
  • Loading branch information
neuqzxy committed Jan 27, 2025
1 parent 763f0d4 commit ca990d7
Show file tree
Hide file tree
Showing 9 changed files with 108 additions and 10 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"changes": [
{
"packageName": "@visactor/vrender-core",
"comment": "fix: fix issue with inversify error when nobind",
"type": "none"
}
],
"packageName": "@visactor/vrender-core"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"changes": [
{
"packageName": "@visactor/vrender-kits",
"comment": "fix: fix issue with inversify error when nobind",
"type": "none"
}
],
"packageName": "@visactor/vrender-kits"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"changes": [
{
"packageName": "@visactor/vrender",
"comment": "fix: fix issue with inversify error when nobind",
"type": "none"
}
],
"packageName": "@visactor/vrender"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { Metadata } from '../meta-data';
import { OPTIONAL_TAG } from '../metadata_keys';
import { createTaggedDecorator } from './inject_base';

function optional() {
return createTaggedDecorator(new Metadata(OPTIONAL_TAG, true));
}

export { optional };
18 changes: 10 additions & 8 deletions packages/vrender-core/src/common/inversify/container.ts
Original file line number Diff line number Diff line change
Expand Up @@ -200,16 +200,18 @@ export class Container {
serviceIdentifier: injectIdentifier,
constructorArgsMetadata
};
const bindings = this._bindingDictionary.get(injectIdentifier).filter(b => {
const bindings = (this._bindingDictionary.get(injectIdentifier) || []).filter(b => {
return b.constraint(target as any);
});
const request = {
injectIdentifier,
metadata: constructorArgsMetadata,
bindings
};

arr.push(request);
if (bindings.length) {
const request = {
injectIdentifier,
metadata: constructorArgsMetadata,
bindings: bindings
};

arr.push(request);
}
}

return arr;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import { findNextGraphic, foreach } from '../../../common/sort';
import { ContributionProvider } from '../../../common/contribution-provider';
import { DefaultAttribute } from '../../../graphic/config';
import type { IAABBBounds, IBounds, IMatrix } from '@visactor/vutils';
import { Bounds, Logger, getRectIntersect, isRectIntersect } from '@visactor/vutils';
import { Bounds, Logger, getRectIntersect, isArray, isRectIntersect } from '@visactor/vutils';
import { container } from '../../../container';
import { GraphicRender, IncrementalDrawContribution } from './symbol';
import { DrawItemInterceptor } from './draw-interceptor';
Expand Down Expand Up @@ -66,6 +66,9 @@ export class DefaultDrawContribution implements IDrawContribution {
this.backupDirtyBounds = new Bounds();
this.global = application.global;
this.layerService = application.layerService;
if (!isArray(this.contributions)) {
this.contributions = [this.contributions];
}
this.init();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import type {
} from '@visactor/vrender-core';

export abstract class PickerBase {
canvasRenderer!: IGraphicRender;
canvasRenderer?: IGraphicRender;

contains(graphic: IGraphic, point: IPoint, params?: IPickParams): boolean {
if (!graphic.AABBBounds.containsPoint(point)) {
Expand All @@ -21,6 +21,9 @@ export abstract class PickerBase {
if (graphic.attribute.pickMode === 'imprecise') {
return true;
}
if (!this.canvasRenderer) {
return true;
}

const { pickContext } = params ?? {};
if (!pickContext) {
Expand Down
47 changes: 47 additions & 0 deletions packages/vrender/__tests__/browser/src/pages/anxu-picker.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { createStage, createRect, IGraphic, container } from '@visactor/vrender-core';
import { loadBrowserEnv, loadMathPicker, registerRect } from '@visactor/vrender-kits';

registerRect();
loadBrowserEnv(container);
loadMathPicker(container);

// container.load(roughModule);
export const page = () => {
const graphics: IGraphic[] = [];
// graphics.push(
// createRect({
// x: 100,
// y: 100,
// width: 20,
// height: 100,
// fill: colorPools[10],
// stroke: [colorPools[0], colorPools[0], colorPools[0], colorPools[0]],
// cornerRadius: 10,
// lineWidth: 5
// })
// );

const rect = createRect({
x: 20,
y: 20,
width: 101.55555555555556,
height: 30,
cornerRadius: -4,
background:
'',
fill: 'rgba(0,0,0,0.3)',
backgroundMode: 'repeat-x',
boundsPadding: [2, 2, 2, 2],
pickMode: 'imprecise'
});

rect.addEventListener('click', () => {
console.log('click');
});

const stage = createStage({
canvas: 'main',
autoRender: true
});
stage.defaultLayer.add(rect);
};
4 changes: 4 additions & 0 deletions packages/vrender/__tests__/browser/src/pages/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ export const pages = [
name: '性能测试',
path: 'performance-test'
},
{
name: '按需加载',
path: 'anxu-picker'
},
{
name: '基础事件测试',
path: 'interactive-test'
Expand Down

0 comments on commit ca990d7

Please sign in to comment.