@ni/nimble-components 17.0.1 → 17.0.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/dist/all-components-bundle.js +3194 -216
- package/dist/all-components-bundle.js.map +1 -1
- package/dist/all-components-bundle.min.js +3022 -2714
- package/dist/all-components-bundle.min.js.map +1 -1
- package/dist/esm/all-components.d.ts +1 -0
- package/dist/esm/all-components.js +1 -0
- package/dist/esm/all-components.js.map +1 -1
- package/dist/esm/table/components/cell/index.d.ts +15 -3
- package/dist/esm/table/components/cell/index.js +32 -2
- package/dist/esm/table/components/cell/index.js.map +1 -1
- package/dist/esm/table/components/cell/styles.js +8 -1
- package/dist/esm/table/components/cell/styles.js.map +1 -1
- package/dist/esm/table/components/cell/template.d.ts +1 -1
- package/dist/esm/table/components/cell/template.js +2 -2
- package/dist/esm/table/components/cell/template.js.map +1 -1
- package/dist/esm/table/components/row/index.d.ts +7 -5
- package/dist/esm/table/components/row/index.js +20 -5
- package/dist/esm/table/components/row/index.js.map +1 -1
- package/dist/esm/table/components/row/styles.js +3 -5
- package/dist/esm/table/components/row/styles.js.map +1 -1
- package/dist/esm/table/components/row/template.d.ts +1 -1
- package/dist/esm/table/components/row/template.js +3 -1
- package/dist/esm/table/components/row/template.js.map +1 -1
- package/dist/esm/table/index.d.ts +2 -2
- package/dist/esm/table/index.js +3 -12
- package/dist/esm/table/index.js.map +1 -1
- package/dist/esm/table/template.js +14 -4
- package/dist/esm/table/template.js.map +1 -1
- package/dist/esm/table/types.d.ts +17 -1
- package/dist/esm/table-column/base/index.d.ts +31 -0
- package/dist/esm/table-column/base/index.js +7 -0
- package/dist/esm/table-column/base/index.js.map +1 -0
- package/dist/esm/table-column/base/styles.d.ts +1 -0
- package/dist/esm/table-column/base/styles.js +7 -0
- package/dist/esm/table-column/base/styles.js.map +1 -0
- package/dist/esm/table-column/base/template.d.ts +1 -0
- package/dist/esm/table-column/base/template.js +7 -0
- package/dist/esm/table-column/base/template.js.map +1 -0
- package/dist/esm/table-column/text/index.d.ts +18 -0
- package/dist/esm/table-column/text/index.js +40 -0
- package/dist/esm/table-column/text/index.js.map +1 -0
- package/dist/esm/table-column/text/styles.d.ts +1 -0
- package/dist/esm/table-column/text/styles.js +16 -0
- package/dist/esm/table-column/text/styles.js.map +1 -0
- package/dist/esm/table-column/text/template.d.ts +3 -0
- package/dist/esm/table-column/text/template.js +11 -0
- package/dist/esm/table-column/text/template.js.map +1 -0
- package/dist/esm/wafer-map/index.d.ts +9 -4
- package/dist/esm/wafer-map/index.js +8 -0
- package/dist/esm/wafer-map/index.js.map +1 -1
- package/dist/esm/wafer-map/modules/zoom-handler.d.ts +24 -0
- package/dist/esm/wafer-map/modules/zoom-handler.js +87 -0
- package/dist/esm/wafer-map/modules/zoom-handler.js.map +1 -0
- package/dist/esm/wafer-map/styles.js +15 -4
- package/dist/esm/wafer-map/styles.js.map +1 -1
- package/dist/esm/wafer-map/template.js +16 -14
- package/dist/esm/wafer-map/template.js.map +1 -1
- package/package.json +5 -1
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { html } from '@microsoft/fast-element';
|
|
2
|
+
export const cellTemplate = html `
|
|
3
|
+
<span
|
|
4
|
+
class="${x => (typeof x.cellRecord.value === 'string' ? '' : 'placeholder')}"
|
|
5
|
+
>
|
|
6
|
+
${x => (typeof x.cellRecord.value === 'string'
|
|
7
|
+
? x.cellRecord.value
|
|
8
|
+
: x.columnConfig.placeholder)}
|
|
9
|
+
</span>
|
|
10
|
+
`;
|
|
11
|
+
//# sourceMappingURL=template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../src/table-column/text/template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAI/C,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,CAE/B;;iBAEgB,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;;UAEzE,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,KAAK,QAAQ;IAC9C,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK;IACpB,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,WAAW,CAAC;;CAEpC,CAAC"}
|
|
@@ -22,14 +22,19 @@ export declare class WaferMap extends FoundationElement {
|
|
|
22
22
|
/**
|
|
23
23
|
* @internal
|
|
24
24
|
*/
|
|
25
|
-
|
|
25
|
+
readonly zoomContainer: HTMLElement;
|
|
26
|
+
/**
|
|
27
|
+
* @internal
|
|
28
|
+
*/
|
|
29
|
+
canvasSideLength?: number;
|
|
26
30
|
highlightedValues: string[];
|
|
27
31
|
dies: WaferMapDie[];
|
|
28
32
|
colorScale: WaferMapColorScale;
|
|
29
33
|
private renderQueued;
|
|
30
|
-
private dataManager
|
|
31
|
-
private renderer
|
|
32
|
-
private resizeObserver
|
|
34
|
+
private dataManager?;
|
|
35
|
+
private renderer?;
|
|
36
|
+
private resizeObserver?;
|
|
37
|
+
private zoomHandler?;
|
|
33
38
|
connectedCallback(): void;
|
|
34
39
|
disconnectedCallback(): void;
|
|
35
40
|
/**
|
|
@@ -6,6 +6,7 @@ import { styles } from './styles';
|
|
|
6
6
|
import { WaferMapColorScaleMode, WaferMapOrientation, WaferMapQuadrant } from './types';
|
|
7
7
|
import { DataManager } from './modules/data-manager';
|
|
8
8
|
import { RenderingModule } from './modules/rendering';
|
|
9
|
+
import { ZoomHandler } from './modules/zoom-handler';
|
|
9
10
|
/**
|
|
10
11
|
* A nimble-styled WaferMap
|
|
11
12
|
*/
|
|
@@ -37,10 +38,14 @@ export class WaferMap extends FoundationElement {
|
|
|
37
38
|
this.canvasSideLength = Math.min(height, width);
|
|
38
39
|
});
|
|
39
40
|
this.resizeObserver.observe(this);
|
|
41
|
+
this.canvas.addEventListener('wheel', event => event.preventDefault(), {
|
|
42
|
+
passive: false
|
|
43
|
+
});
|
|
40
44
|
this.queueRender();
|
|
41
45
|
}
|
|
42
46
|
disconnectedCallback() {
|
|
43
47
|
super.disconnectedCallback();
|
|
48
|
+
this.canvas.removeEventListener('wheel', event => event.preventDefault());
|
|
44
49
|
this.resizeObserver.unobserve(this);
|
|
45
50
|
}
|
|
46
51
|
/**
|
|
@@ -55,6 +60,8 @@ export class WaferMap extends FoundationElement {
|
|
|
55
60
|
this.renderer?.clearCanvas(this.canvasSideLength, this.canvasSideLength);
|
|
56
61
|
this.dataManager = new DataManager(this.dies, this.quadrant, { width: this.canvasSideLength, height: this.canvasSideLength }, this.colorScale, this.highlightedValues, this.colorScaleMode, this.dieLabelsHidden, this.dieLabelsSuffix, this.maxCharacters);
|
|
57
62
|
this.renderer = new RenderingModule(this.dataManager, this.canvas);
|
|
63
|
+
this.zoomHandler = new ZoomHandler(this.canvas, this.zoomContainer, this.dataManager, this.renderer, this.canvasSideLength);
|
|
64
|
+
this.zoomHandler.attachZoomBehavior();
|
|
58
65
|
this.renderer.drawWafer();
|
|
59
66
|
}
|
|
60
67
|
quadrantChanged() {
|
|
@@ -90,6 +97,7 @@ export class WaferMap extends FoundationElement {
|
|
|
90
97
|
this.canvas.width = this.canvasSideLength;
|
|
91
98
|
this.canvas.height = this.canvasSideLength;
|
|
92
99
|
}
|
|
100
|
+
this.zoomHandler?.resetTransform();
|
|
93
101
|
this.queueRender();
|
|
94
102
|
}
|
|
95
103
|
queueRender() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/wafer-map/index.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,IAAI,EACJ,GAAG,EACH,uBAAuB,EACvB,UAAU,EACb,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAEH,sBAAsB,EAEtB,mBAAmB,EACnB,gBAAgB,EACnB,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/wafer-map/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { DataManager } from './data-manager';
|
|
2
|
+
import type { RenderingModule } from './rendering';
|
|
3
|
+
/**
|
|
4
|
+
* ZoomHandler deals with user interactions and events like zooming
|
|
5
|
+
*/
|
|
6
|
+
export declare class ZoomHandler {
|
|
7
|
+
private readonly canvas;
|
|
8
|
+
private readonly zoomContainer;
|
|
9
|
+
private readonly dataManager;
|
|
10
|
+
private readonly renderingModule;
|
|
11
|
+
private readonly canvasLength;
|
|
12
|
+
private zoomTransform;
|
|
13
|
+
private readonly minScale;
|
|
14
|
+
private readonly minExtentPoint;
|
|
15
|
+
private readonly extentPadding;
|
|
16
|
+
private zoomBehavior;
|
|
17
|
+
constructor(canvas: HTMLCanvasElement, zoomContainer: HTMLElement, dataManager: DataManager, renderingModule: RenderingModule, canvasLength: number);
|
|
18
|
+
attachZoomBehavior(): void;
|
|
19
|
+
resetTransform(): void;
|
|
20
|
+
private createZoomBehavior;
|
|
21
|
+
private getZoomMax;
|
|
22
|
+
private clearCanvas;
|
|
23
|
+
private scaleCanvas;
|
|
24
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { select } from 'd3-selection';
|
|
2
|
+
import { zoom, zoomIdentity, zoomTransform } from 'd3-zoom';
|
|
3
|
+
/**
|
|
4
|
+
* ZoomHandler deals with user interactions and events like zooming
|
|
5
|
+
*/
|
|
6
|
+
export class ZoomHandler {
|
|
7
|
+
constructor(canvas, zoomContainer, dataManager, renderingModule, canvasLength) {
|
|
8
|
+
this.canvas = canvas;
|
|
9
|
+
this.zoomContainer = zoomContainer;
|
|
10
|
+
this.dataManager = dataManager;
|
|
11
|
+
this.renderingModule = renderingModule;
|
|
12
|
+
this.canvasLength = canvasLength;
|
|
13
|
+
this.zoomTransform = zoomIdentity;
|
|
14
|
+
this.minScale = 1.1;
|
|
15
|
+
this.minExtentPoint = [-100, -100];
|
|
16
|
+
this.extentPadding = 100;
|
|
17
|
+
}
|
|
18
|
+
attachZoomBehavior() {
|
|
19
|
+
this.zoomBehavior = this.createZoomBehavior();
|
|
20
|
+
this.zoomBehavior(select(this.canvas));
|
|
21
|
+
}
|
|
22
|
+
resetTransform() {
|
|
23
|
+
const canvasContext = this.canvas.getContext('2d');
|
|
24
|
+
if (canvasContext === null) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
this.zoomTransform = zoomIdentity;
|
|
28
|
+
this.clearCanvas(canvasContext, this.canvasLength, this.canvasLength);
|
|
29
|
+
this.scaleCanvas(canvasContext, zoomIdentity.x, zoomIdentity.y, zoomIdentity.k);
|
|
30
|
+
this.renderingModule.drawWafer();
|
|
31
|
+
this.zoomBehavior?.transform(select(this.canvas), zoomIdentity);
|
|
32
|
+
}
|
|
33
|
+
createZoomBehavior() {
|
|
34
|
+
const zoomBehavior = zoom()
|
|
35
|
+
.scaleExtent([
|
|
36
|
+
1.1,
|
|
37
|
+
this.getZoomMax(this.canvasLength * this.canvasLength, this.dataManager.containerDimensions.width
|
|
38
|
+
* this.dataManager.containerDimensions.height)
|
|
39
|
+
])
|
|
40
|
+
.translateExtent([
|
|
41
|
+
this.minExtentPoint,
|
|
42
|
+
[
|
|
43
|
+
this.canvasLength + this.extentPadding,
|
|
44
|
+
this.canvasLength + this.extentPadding
|
|
45
|
+
]
|
|
46
|
+
])
|
|
47
|
+
.filter((event) => {
|
|
48
|
+
const transform = zoomTransform(this.canvas);
|
|
49
|
+
return transform.k >= this.minScale || event.type === 'wheel';
|
|
50
|
+
})
|
|
51
|
+
.on('zoom', (event) => {
|
|
52
|
+
const transform = event.transform;
|
|
53
|
+
const canvasContext = this.canvas.getContext('2d');
|
|
54
|
+
if (canvasContext === null) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
canvasContext.save();
|
|
58
|
+
if (transform.k === this.minScale) {
|
|
59
|
+
this.zoomTransform = zoomIdentity;
|
|
60
|
+
this.clearCanvas(canvasContext, this.canvasLength, this.canvasLength);
|
|
61
|
+
this.scaleCanvas(canvasContext, zoomIdentity.x, zoomIdentity.y, zoomIdentity.k);
|
|
62
|
+
this.renderingModule.drawWafer();
|
|
63
|
+
zoomBehavior.transform(select(this.canvas), zoomIdentity);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
this.zoomTransform = transform;
|
|
67
|
+
this.clearCanvas(canvasContext, this.canvasLength * this.zoomTransform.k, this.canvasLength * this.zoomTransform.k);
|
|
68
|
+
this.scaleCanvas(canvasContext, transform.x, transform.y, transform.k);
|
|
69
|
+
this.renderingModule.drawWafer();
|
|
70
|
+
}
|
|
71
|
+
canvasContext.restore();
|
|
72
|
+
this.zoomContainer.setAttribute('transform', this.zoomTransform.toString());
|
|
73
|
+
});
|
|
74
|
+
return zoomBehavior;
|
|
75
|
+
}
|
|
76
|
+
getZoomMax(canvasArea, dataArea) {
|
|
77
|
+
return Math.ceil((dataArea / canvasArea) * 100);
|
|
78
|
+
}
|
|
79
|
+
clearCanvas(context, width, height) {
|
|
80
|
+
context.clearRect(0, 0, width, height);
|
|
81
|
+
}
|
|
82
|
+
scaleCanvas(context, x = 0, y = 0, scale = 1) {
|
|
83
|
+
context.translate(x, y);
|
|
84
|
+
context.scale(scale, scale);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=zoom-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"zoom-handler.js","sourceRoot":"","sources":["../../../../src/wafer-map/modules/zoom-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -22,19 +22,30 @@ export const styles = css `
|
|
|
22
22
|
position: absolute;
|
|
23
23
|
}
|
|
24
24
|
|
|
25
|
-
.
|
|
25
|
+
.circle-base {
|
|
26
|
+
width: 100%;
|
|
27
|
+
height: 100%;
|
|
28
|
+
position: absolute;
|
|
29
|
+
fill: white;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.notch {
|
|
33
|
+
transform-origin: center center;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.notch.top {
|
|
26
37
|
transform: rotate(-90deg);
|
|
27
38
|
}
|
|
28
39
|
|
|
29
|
-
.
|
|
40
|
+
.notch.right {
|
|
30
41
|
transform: rotate(0deg);
|
|
31
42
|
}
|
|
32
43
|
|
|
33
|
-
.
|
|
44
|
+
.notch.left {
|
|
34
45
|
transform: rotate(180deg);
|
|
35
46
|
}
|
|
36
47
|
|
|
37
|
-
.
|
|
48
|
+
.notch.bottom {
|
|
38
49
|
transform: rotate(90deg);
|
|
39
50
|
}
|
|
40
51
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/wafer-map/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAE3E,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/wafer-map/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAE3E,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wBAiED,WAAW;kBACjB,WAAW;;;;;;;;;;;;;;;;CAgB5B,CAAC"}
|
|
@@ -1,20 +1,22 @@
|
|
|
1
1
|
import { html, ref } from '@microsoft/fast-element';
|
|
2
2
|
export const template = html `
|
|
3
3
|
<div class="wafer-map-container">
|
|
4
|
-
<svg class="svg-root
|
|
5
|
-
<g class="zoom-container">
|
|
6
|
-
<
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
4
|
+
<svg class="svg-root">
|
|
5
|
+
<g class="zoom-container" ${ref('zoomContainer')}>
|
|
6
|
+
<g class="notch ${x => x.orientation}">
|
|
7
|
+
<svg
|
|
8
|
+
class="circle-base"
|
|
9
|
+
version="1.1"
|
|
10
|
+
x="0px"
|
|
11
|
+
y="0px"
|
|
12
|
+
viewBox="1 .45 20 21"
|
|
13
|
+
>
|
|
14
|
+
<path
|
|
15
|
+
class="circle-drawing-path"
|
|
16
|
+
d="m 21 12 a 10 10 330 1 1 0 -1.98 a 1 1 0 0 0 0 2"
|
|
17
|
+
/>
|
|
18
|
+
</svg>
|
|
19
|
+
</g>
|
|
18
20
|
</g>
|
|
19
21
|
</svg>
|
|
20
22
|
<div class="wafer-map-area">
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../src/wafer-map/template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAGpD,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAU
|
|
1
|
+
{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../src/wafer-map/template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAGpD,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAU;;;wCAGE,GAAG,CAAC,eAAe,CAAC;kCAC1B,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW;;;;;;;;;;;;;;;;;+CAiBL,GAAG,CAAC,QAAQ,CAAC;;;CAG3D,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ni/nimble-components",
|
|
3
|
-
"version": "17.0.
|
|
3
|
+
"version": "17.0.3",
|
|
4
4
|
"description": "Styled web components for the NI Nimble Design System",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"build": "npm run generate-icons && npm run build-components && npm run bundle-components && npm run generate-scss && npm run build-storybook",
|
|
@@ -54,6 +54,10 @@
|
|
|
54
54
|
"@tanstack/table-core": "^8.7.0",
|
|
55
55
|
"@types/d3": "^7.4.0",
|
|
56
56
|
"@types/d3-scale": "^4.0.2",
|
|
57
|
+
"@types/d3-zoom": "^3.0.0",
|
|
58
|
+
"@types/d3-selection": "^3.0.0",
|
|
59
|
+
"d3-selection": "^3.0.0",
|
|
60
|
+
"d3-zoom": "^3.0.0",
|
|
57
61
|
"d3-random": "^3.0.1",
|
|
58
62
|
"d3-scale": "^4.0.2",
|
|
59
63
|
"hex-rgb": "^5.0.0",
|