@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.
Files changed (58) hide show
  1. package/dist/all-components-bundle.js +3194 -216
  2. package/dist/all-components-bundle.js.map +1 -1
  3. package/dist/all-components-bundle.min.js +3022 -2714
  4. package/dist/all-components-bundle.min.js.map +1 -1
  5. package/dist/esm/all-components.d.ts +1 -0
  6. package/dist/esm/all-components.js +1 -0
  7. package/dist/esm/all-components.js.map +1 -1
  8. package/dist/esm/table/components/cell/index.d.ts +15 -3
  9. package/dist/esm/table/components/cell/index.js +32 -2
  10. package/dist/esm/table/components/cell/index.js.map +1 -1
  11. package/dist/esm/table/components/cell/styles.js +8 -1
  12. package/dist/esm/table/components/cell/styles.js.map +1 -1
  13. package/dist/esm/table/components/cell/template.d.ts +1 -1
  14. package/dist/esm/table/components/cell/template.js +2 -2
  15. package/dist/esm/table/components/cell/template.js.map +1 -1
  16. package/dist/esm/table/components/row/index.d.ts +7 -5
  17. package/dist/esm/table/components/row/index.js +20 -5
  18. package/dist/esm/table/components/row/index.js.map +1 -1
  19. package/dist/esm/table/components/row/styles.js +3 -5
  20. package/dist/esm/table/components/row/styles.js.map +1 -1
  21. package/dist/esm/table/components/row/template.d.ts +1 -1
  22. package/dist/esm/table/components/row/template.js +3 -1
  23. package/dist/esm/table/components/row/template.js.map +1 -1
  24. package/dist/esm/table/index.d.ts +2 -2
  25. package/dist/esm/table/index.js +3 -12
  26. package/dist/esm/table/index.js.map +1 -1
  27. package/dist/esm/table/template.js +14 -4
  28. package/dist/esm/table/template.js.map +1 -1
  29. package/dist/esm/table/types.d.ts +17 -1
  30. package/dist/esm/table-column/base/index.d.ts +31 -0
  31. package/dist/esm/table-column/base/index.js +7 -0
  32. package/dist/esm/table-column/base/index.js.map +1 -0
  33. package/dist/esm/table-column/base/styles.d.ts +1 -0
  34. package/dist/esm/table-column/base/styles.js +7 -0
  35. package/dist/esm/table-column/base/styles.js.map +1 -0
  36. package/dist/esm/table-column/base/template.d.ts +1 -0
  37. package/dist/esm/table-column/base/template.js +7 -0
  38. package/dist/esm/table-column/base/template.js.map +1 -0
  39. package/dist/esm/table-column/text/index.d.ts +18 -0
  40. package/dist/esm/table-column/text/index.js +40 -0
  41. package/dist/esm/table-column/text/index.js.map +1 -0
  42. package/dist/esm/table-column/text/styles.d.ts +1 -0
  43. package/dist/esm/table-column/text/styles.js +16 -0
  44. package/dist/esm/table-column/text/styles.js.map +1 -0
  45. package/dist/esm/table-column/text/template.d.ts +3 -0
  46. package/dist/esm/table-column/text/template.js +11 -0
  47. package/dist/esm/table-column/text/template.js.map +1 -0
  48. package/dist/esm/wafer-map/index.d.ts +9 -4
  49. package/dist/esm/wafer-map/index.js +8 -0
  50. package/dist/esm/wafer-map/index.js.map +1 -1
  51. package/dist/esm/wafer-map/modules/zoom-handler.d.ts +24 -0
  52. package/dist/esm/wafer-map/modules/zoom-handler.js +87 -0
  53. package/dist/esm/wafer-map/modules/zoom-handler.js.map +1 -0
  54. package/dist/esm/wafer-map/styles.js +15 -4
  55. package/dist/esm/wafer-map/styles.js.map +1 -1
  56. package/dist/esm/wafer-map/template.js +16 -14
  57. package/dist/esm/wafer-map/template.js.map +1 -1
  58. 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
- canvasSideLength: number | undefined;
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":"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"}
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;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAQrD;;GAEG;AACH,MAAM,OAAO,QAAS,SAAQ,iBAAiB;IAA/C;;QAEW,aAAQ,GAAqB,gBAAgB,CAAC,OAAO,CAAC;QAGtD,gBAAW,GAAwB,mBAAmB,CAAC,GAAG,CAAC;QAM3D,kBAAa,GAAG,CAAC,CAAC;QAMlB,oBAAe,GAAG,KAAK,CAAC;QAKxB,oBAAe,GAAG,EAAE,CAAC;QAKrB,mBAAc,GAA2B,sBAAsB,CAAC,MAAM,CAAC;QAgB3D,sBAAiB,GAAa,EAAE,CAAC;QACjC,SAAI,GAAkB,EAAE,CAAC;QACzB,eAAU,GAAuB;YAChD,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,EAAE;SACb,CAAC;QAEM,iBAAY,GAAG,KAAK,CAAC;IA2HjC,CAAC;IAtHmB,iBAAiB;QAC7B,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,OAAO,CAAC,EAAE;YAC/C,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,KAAK,KAAK,SAAS,EAAE;gBACrB,OAAO;aACV;YACD,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,WAAW,CAAC;YAC5C,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,cAAc,EAAE,EAAE;YACnE,OAAO,EAAE,KAAK;SACjB,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEe,oBAAoB;QAChC,KAAK,CAAC,oBAAoB,EAAE,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC;QAC1E,IAAI,CAAC,cAAe,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAED;;OAEG;IACI,MAAM;QACT,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IACI,IAAI,CAAC,gBAAgB,KAAK,SAAS;eAChC,IAAI,CAAC,gBAAgB,KAAK,CAAC,EAChC;YACE,OAAO;SACV;QACD,IAAI,CAAC,QAAQ,EAAE,WAAW,CACtB,IAAI,CAAC,gBAAgB,EACrB,IAAI,CAAC,gBAAgB,CACxB,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,WAAW,CAC9B,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,QAAQ,EACb,EAAE,KAAK,EAAE,IAAI,CAAC,gBAAgB,EAAE,MAAM,EAAE,IAAI,CAAC,gBAAgB,EAAE,EAC/D,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,iBAAiB,EACtB,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,aAAa,CACrB,CAAC;QACF,IAAI,CAAC,QAAQ,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACnE,IAAI,CAAC,WAAW,GAAG,IAAI,WAAW,CAC9B,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,gBAAgB,CACxB,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,kBAAkB,EAAE,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;IAC9B,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,oBAAoB;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,sBAAsB;QAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,sBAAsB;QAC1B,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,qBAAqB;QACzB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,wBAAwB;QAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,uBAAuB;QAC3B,IACI,IAAI,CAAC,gBAAgB,KAAK,SAAS;eAChC,IAAI,CAAC,gBAAgB,KAAK,CAAC,EAChC;YACE,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC;YAC1C,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC;SAC9C;QACD,IAAI,CAAC,WAAW,EAAE,cAAc,EAAE,CAAC;QACnC,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE;YACnC,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,GAAG,CAAC,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;SACxC;IACL,CAAC;CACJ;AA3KG;IADC,IAAI;0CACwD;AAG7D;IADC,IAAI;6CAC6D;AAMlE;IAJC,IAAI,CAAC;QACF,SAAS,EAAE,gBAAgB;QAC3B,SAAS,EAAE,uBAAuB;KACrC,CAAC;+CACuB;AAMzB;IAJC,IAAI,CAAC;QACF,SAAS,EAAE,mBAAmB;QAC9B,IAAI,EAAE,SAAS;KAClB,CAAC;iDAC6B;AAK/B;IAHC,IAAI,CAAC;QACF,SAAS,EAAE,mBAAmB;KACjC,CAAC;iDAC0B;AAK5B;IAHC,IAAI,CAAC;QACF,SAAS,EAAE,kBAAkB;KAChC,CAAC;gDAC4E;AAelE;IAAX,UAAU;kDAAkC;AACjC;IAAX,UAAU;mDAAyC;AACxC;IAAX,UAAU;sCAAiC;AAChC;IAAX,UAAU;4CAGT;AA+HN,MAAM,cAAc,GAAG,QAAQ,CAAC,OAAO,CAAC;IACpC,QAAQ,EAAE,WAAW;IACrB,QAAQ;IACR,MAAM;CACT,CAAC,CAAC;AAEH,YAAY,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC,CAAC"}
@@ -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
- .svg-root.top {
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
- .svg-root.right {
40
+ .notch.right {
30
41
  transform: rotate(0deg);
31
42
  }
32
43
 
33
- .svg-root.left {
44
+ .notch.left {
34
45
  transform: rotate(180deg);
35
46
  }
36
47
 
37
- .svg-root.bottom {
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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wBAsDD,WAAW;kBACjB,WAAW;;;;;;;;;;;;;;;;CAgB5B,CAAC"}
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 ${x => x.orientation}">
5
- <g class="zoom-container">
6
- <svg
7
- class="circle-base"
8
- version="1.1"
9
- x="0px"
10
- y="0px"
11
- viewBox="1 .45 20 21"
12
- >
13
- <path
14
- class="circle-drawing-path"
15
- d="m 21 12 a 10 10 330 1 1 0 -1.98 a 1 1 0 0 0 0 2"
16
- />
17
- </svg>
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;;+BAEP,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW;;;;;;;;;;;;;;;;;+CAiBF,GAAG,CAAC,QAAQ,CAAC;;;CAG3D,CAAC"}
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.1",
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",