@adam26davidson/char-matrix-react 0.0.1
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/char-matrix/src/Element/ContainerElement.d.ts +28 -0
- package/dist/char-matrix/src/Element/ContainerElement.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ContainerElement.js +128 -0
- package/dist/char-matrix/src/Element/ContainerElement.js.map +1 -0
- package/dist/char-matrix/src/Element/Element.d.ts +31 -0
- package/dist/char-matrix/src/Element/Element.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/Element.js +190 -0
- package/dist/char-matrix/src/Element/Element.js.map +1 -0
- package/dist/char-matrix/src/Element/ElementBase.d.ts +66 -0
- package/dist/char-matrix/src/Element/ElementBase.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ElementBase.js +167 -0
- package/dist/char-matrix/src/Element/ElementBase.js.map +1 -0
- package/dist/char-matrix/src/Element/ElementDrawing.d.ts +41 -0
- package/dist/char-matrix/src/Element/ElementDrawing.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ElementDrawing.js +232 -0
- package/dist/char-matrix/src/Element/ElementDrawing.js.map +1 -0
- package/dist/char-matrix/src/Element/ElementInteraction.d.ts +21 -0
- package/dist/char-matrix/src/Element/ElementInteraction.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ElementInteraction.js +110 -0
- package/dist/char-matrix/src/Element/ElementInteraction.js.map +1 -0
- package/dist/char-matrix/src/Element/ElementLayout.d.ts +25 -0
- package/dist/char-matrix/src/Element/ElementLayout.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ElementLayout.js +152 -0
- package/dist/char-matrix/src/Element/ElementLayout.js.map +1 -0
- package/dist/char-matrix/src/Element/ParentElement.d.ts +24 -0
- package/dist/char-matrix/src/Element/ParentElement.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/ParentElement.js +58 -0
- package/dist/char-matrix/src/Element/ParentElement.js.map +1 -0
- package/dist/char-matrix/src/Element/TextElement.d.ts +28 -0
- package/dist/char-matrix/src/Element/TextElement.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/TextElement.js +214 -0
- package/dist/char-matrix/src/Element/TextElement.js.map +1 -0
- package/dist/char-matrix/src/Element/TransitionSequence.d.ts +15 -0
- package/dist/char-matrix/src/Element/TransitionSequence.d.ts.map +1 -0
- package/dist/char-matrix/src/Element/TransitionSequence.js +113 -0
- package/dist/char-matrix/src/Element/TransitionSequence.js.map +1 -0
- package/dist/char-matrix/src/constants.d.ts +8 -0
- package/dist/char-matrix/src/constants.d.ts.map +1 -0
- package/dist/char-matrix/src/constants.js +8 -0
- package/dist/char-matrix/src/constants.js.map +1 -0
- package/dist/char-matrix/src/index.d.ts +22 -0
- package/dist/char-matrix/src/index.d.ts.map +1 -0
- package/dist/char-matrix/src/index.js +20 -0
- package/dist/char-matrix/src/index.js.map +1 -0
- package/dist/char-matrix/src/interfaces/ElementAnimationHandler.d.ts +29 -0
- package/dist/char-matrix/src/interfaces/ElementAnimationHandler.d.ts.map +1 -0
- package/dist/char-matrix/src/interfaces/ElementAnimationHandler.js +2 -0
- package/dist/char-matrix/src/interfaces/ElementAnimationHandler.js.map +1 -0
- package/dist/char-matrix/src/interfaces/RenderTarget.d.ts +17 -0
- package/dist/char-matrix/src/interfaces/RenderTarget.d.ts.map +1 -0
- package/dist/char-matrix/src/interfaces/RenderTarget.js +2 -0
- package/dist/char-matrix/src/interfaces/RenderTarget.js.map +1 -0
- package/dist/char-matrix/src/interfaces/SurfaceTransform.d.ts +16 -0
- package/dist/char-matrix/src/interfaces/SurfaceTransform.d.ts.map +1 -0
- package/dist/char-matrix/src/interfaces/SurfaceTransform.js +2 -0
- package/dist/char-matrix/src/interfaces/SurfaceTransform.js.map +1 -0
- package/dist/char-matrix/src/types/Axes.d.ts +5 -0
- package/dist/char-matrix/src/types/Axes.d.ts.map +1 -0
- package/dist/char-matrix/src/types/Axes.js +4 -0
- package/dist/char-matrix/src/types/Axes.js.map +1 -0
- package/dist/char-matrix/src/types/CharMatrix.d.ts +21 -0
- package/dist/char-matrix/src/types/CharMatrix.d.ts.map +1 -0
- package/dist/char-matrix/src/types/CharMatrix.js +89 -0
- package/dist/char-matrix/src/types/CharMatrix.js.map +1 -0
- package/dist/char-matrix/src/types/IntPoint.d.ts +21 -0
- package/dist/char-matrix/src/types/IntPoint.d.ts.map +1 -0
- package/dist/char-matrix/src/types/IntPoint.js +59 -0
- package/dist/char-matrix/src/types/IntPoint.js.map +1 -0
- package/dist/char-matrix/src/types/NormPoint.d.ts +10 -0
- package/dist/char-matrix/src/types/NormPoint.d.ts.map +1 -0
- package/dist/char-matrix/src/types/NormPoint.js +28 -0
- package/dist/char-matrix/src/types/NormPoint.js.map +1 -0
- package/dist/char-matrix/src/types/RealPoint.d.ts +21 -0
- package/dist/char-matrix/src/types/RealPoint.d.ts.map +1 -0
- package/dist/char-matrix/src/types/RealPoint.js +58 -0
- package/dist/char-matrix/src/types/RealPoint.js.map +1 -0
- package/dist/char-matrix/src/utils/Logging.d.ts +4 -0
- package/dist/char-matrix/src/utils/Logging.d.ts.map +1 -0
- package/dist/char-matrix/src/utils/Logging.js +8 -0
- package/dist/char-matrix/src/utils/Logging.js.map +1 -0
- package/dist/char-matrix/src/utils/MiscUtils.d.ts +7 -0
- package/dist/char-matrix/src/utils/MiscUtils.d.ts.map +1 -0
- package/dist/char-matrix/src/utils/MiscUtils.js +37 -0
- package/dist/char-matrix/src/utils/MiscUtils.js.map +1 -0
- package/dist/char-matrix/src/utils/Octant.d.ts +42 -0
- package/dist/char-matrix/src/utils/Octant.d.ts.map +1 -0
- package/dist/char-matrix/src/utils/Octant.js +98 -0
- package/dist/char-matrix/src/utils/Octant.js.map +1 -0
- package/dist/char-matrix-react/src/ReactComponentElement.d.ts +25 -0
- package/dist/char-matrix-react/src/ReactComponentElement.d.ts.map +1 -0
- package/dist/char-matrix-react/src/ReactComponentElement.js +66 -0
- package/dist/char-matrix-react/src/ReactComponentElement.js.map +1 -0
- package/dist/char-matrix-react/src/ReactNodeConfig.d.ts +12 -0
- package/dist/char-matrix-react/src/ReactNodeConfig.d.ts.map +1 -0
- package/dist/char-matrix-react/src/ReactNodeConfig.js +2 -0
- package/dist/char-matrix-react/src/ReactNodeConfig.js.map +1 -0
- package/dist/char-matrix-react/src/ReactRenderTarget.d.ts +10 -0
- package/dist/char-matrix-react/src/ReactRenderTarget.d.ts.map +1 -0
- package/dist/char-matrix-react/src/ReactRenderTarget.js +2 -0
- package/dist/char-matrix-react/src/ReactRenderTarget.js.map +1 -0
- package/dist/char-matrix-react/src/index.d.ts +5 -0
- package/dist/char-matrix-react/src/index.d.ts.map +1 -0
- package/dist/char-matrix-react/src/index.js +2 -0
- package/dist/char-matrix-react/src/index.js.map +1 -0
- package/package.json +35 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { IntPoint } from "../types/IntPoint";
|
|
2
|
+
import { ElementLayout } from "./ElementLayout";
|
|
3
|
+
import { ElementConfig } from "./ElementBase";
|
|
4
|
+
import { ElementAnimationHandler } from "../interfaces/ElementAnimationHandler";
|
|
5
|
+
export declare abstract class ElementDrawing extends ElementLayout {
|
|
6
|
+
protected scrollOffset: IntPoint;
|
|
7
|
+
protected fullContentOffset: IntPoint;
|
|
8
|
+
protected mustRedraw: boolean;
|
|
9
|
+
protected animationHandler: ElementAnimationHandler | null;
|
|
10
|
+
protected isDraggingScrollbar: boolean;
|
|
11
|
+
private dragStartY;
|
|
12
|
+
private dragStartScroll;
|
|
13
|
+
constructor(config: ElementConfig);
|
|
14
|
+
getScrollOffset: () => IntPoint;
|
|
15
|
+
protected drawChar(char: string, p: IntPoint, o?: IntPoint): void;
|
|
16
|
+
draw(offset: IntPoint): void;
|
|
17
|
+
protected abstract drawOwnContent(offset: IntPoint): void;
|
|
18
|
+
protected flagForRedraw(): void;
|
|
19
|
+
/**
|
|
20
|
+
* Apply a scroll delta (in character rows). Returns true if scroll was consumed.
|
|
21
|
+
*/
|
|
22
|
+
protected applyScroll(delta: number): boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Update showingScrollBar based on content vs viewable size.
|
|
25
|
+
* Called from reprocessContent in subclasses.
|
|
26
|
+
*/
|
|
27
|
+
protected updateScrollShowing(): void;
|
|
28
|
+
/** Check if a point (relative to element top-left) is on the scrollbar thumb */
|
|
29
|
+
protected isPointOnScrollbarThumb(px: number, py: number): boolean;
|
|
30
|
+
/** Start a scrollbar drag */
|
|
31
|
+
protected startScrollbarDrag(mouseY: number): void;
|
|
32
|
+
/** Update scroll position during drag */
|
|
33
|
+
protected updateScrollbarDrag(mouseY: number): void;
|
|
34
|
+
/** Stop scrollbar drag */
|
|
35
|
+
protected stopScrollbarDrag(): void;
|
|
36
|
+
private drawBackground;
|
|
37
|
+
private drawBorder;
|
|
38
|
+
private drawVerticalScrollBar;
|
|
39
|
+
protected onSizeChanged(_oldSize: IntPoint, _newSize: IntPoint): void;
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=ElementDrawing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementDrawing.d.ts","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementDrawing.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAc,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,uCAAuC,CAAC;AAGhF,8BAAsB,cAAe,SAAQ,aAAa;IACxD,SAAS,CAAC,YAAY,EAAE,QAAQ,CAAsB;IACtD,SAAS,CAAC,iBAAiB,EAAE,QAAQ,CAAsB;IAC3D,SAAS,CAAC,UAAU,EAAE,OAAO,CAAQ;IACrC,SAAS,CAAC,gBAAgB,EAAE,uBAAuB,GAAG,IAAI,CAAQ;IAGlE,SAAS,CAAC,mBAAmB,EAAE,OAAO,CAAS;IAC/C,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAa;gBAExB,MAAM,EAAE,aAAa;IAK1B,eAAe,iBAA2B;IAEjD,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,GAAE,QAAqB;IAQ/D,IAAI,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAoBnC,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAEzD,SAAS,CAAC,aAAa;IAKvB;;OAEG;IACH,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAiB7C;;;OAGG;IACH,SAAS,CAAC,mBAAmB;IAM7B,gFAAgF;IAChF,SAAS,CAAC,uBAAuB,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO;IAsBlE,6BAA6B;IAC7B,SAAS,CAAC,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAMlD,yCAAyC;IACzC,SAAS,CAAC,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAsBnD,0BAA0B;IAC1B,SAAS,CAAC,iBAAiB,IAAI,IAAI;IAInC,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,UAAU;IAuBlB,OAAO,CAAC,qBAAqB,CA+B3B;cAEiB,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;CAC/E"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { Y } from "../types/Axes";
|
|
2
|
+
import { IntPoint, ZERO_POINT } from "../types/IntPoint";
|
|
3
|
+
import { ElementLayout } from "./ElementLayout";
|
|
4
|
+
import { octantChar, OCTANT_ROW, OCTANT_RIGHT } from "../utils/Octant";
|
|
5
|
+
export class ElementDrawing extends ElementLayout {
|
|
6
|
+
constructor(config) {
|
|
7
|
+
super(config);
|
|
8
|
+
Object.defineProperty(this, "scrollOffset", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
configurable: true,
|
|
11
|
+
writable: true,
|
|
12
|
+
value: new IntPoint(0, 0)
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(this, "fullContentOffset", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
configurable: true,
|
|
17
|
+
writable: true,
|
|
18
|
+
value: new IntPoint(0, 0)
|
|
19
|
+
});
|
|
20
|
+
Object.defineProperty(this, "mustRedraw", {
|
|
21
|
+
enumerable: true,
|
|
22
|
+
configurable: true,
|
|
23
|
+
writable: true,
|
|
24
|
+
value: true
|
|
25
|
+
});
|
|
26
|
+
Object.defineProperty(this, "animationHandler", {
|
|
27
|
+
enumerable: true,
|
|
28
|
+
configurable: true,
|
|
29
|
+
writable: true,
|
|
30
|
+
value: null
|
|
31
|
+
});
|
|
32
|
+
// Scrollbar drag state
|
|
33
|
+
Object.defineProperty(this, "isDraggingScrollbar", {
|
|
34
|
+
enumerable: true,
|
|
35
|
+
configurable: true,
|
|
36
|
+
writable: true,
|
|
37
|
+
value: false
|
|
38
|
+
});
|
|
39
|
+
Object.defineProperty(this, "dragStartY", {
|
|
40
|
+
enumerable: true,
|
|
41
|
+
configurable: true,
|
|
42
|
+
writable: true,
|
|
43
|
+
value: 0
|
|
44
|
+
});
|
|
45
|
+
Object.defineProperty(this, "dragStartScroll", {
|
|
46
|
+
enumerable: true,
|
|
47
|
+
configurable: true,
|
|
48
|
+
writable: true,
|
|
49
|
+
value: 0
|
|
50
|
+
});
|
|
51
|
+
Object.defineProperty(this, "getScrollOffset", {
|
|
52
|
+
enumerable: true,
|
|
53
|
+
configurable: true,
|
|
54
|
+
writable: true,
|
|
55
|
+
value: () => this.scrollOffset
|
|
56
|
+
});
|
|
57
|
+
Object.defineProperty(this, "drawVerticalScrollBar", {
|
|
58
|
+
enumerable: true,
|
|
59
|
+
configurable: true,
|
|
60
|
+
writable: true,
|
|
61
|
+
value: (offset) => {
|
|
62
|
+
if (!this.showingScrollBar)
|
|
63
|
+
return;
|
|
64
|
+
const fullOffset = offset.add(this.getContentOffset());
|
|
65
|
+
const boundarySize = this.getTotalBoundarySize();
|
|
66
|
+
const scrollOffset = -1 * this.scrollOffset.getY();
|
|
67
|
+
const contentAreaSize = this.size.subtract(boundarySize);
|
|
68
|
+
const contentAreaHeight = contentAreaSize.getY();
|
|
69
|
+
const contentHeight = this.contentSize.getY();
|
|
70
|
+
// 4 sub-rows per character cell
|
|
71
|
+
const GAP = 1; // sub-rows of gap between thumb and track
|
|
72
|
+
const subRows = contentAreaHeight * 4;
|
|
73
|
+
const thumbSize = Math.max(4, Math.round((contentAreaHeight / contentHeight) * subRows));
|
|
74
|
+
const thumbStart = Math.round((scrollOffset / contentHeight) * subRows);
|
|
75
|
+
const thumbEnd = thumbStart + thumbSize;
|
|
76
|
+
const xOffset = contentAreaSize.getX() + this.padding.end.getX();
|
|
77
|
+
this.forEachAlongAxisInContentArea(Y, (i) => {
|
|
78
|
+
let bits = 0;
|
|
79
|
+
for (let r = 0; r < 4; r++) {
|
|
80
|
+
const sub = i * 4 + r;
|
|
81
|
+
if (sub >= thumbStart && sub < thumbEnd) {
|
|
82
|
+
bits |= OCTANT_ROW[r]; // thumb: both columns
|
|
83
|
+
}
|
|
84
|
+
else if (sub < thumbStart - GAP || sub >= thumbEnd + GAP) {
|
|
85
|
+
bits |= OCTANT_RIGHT[r]; // track: right column only
|
|
86
|
+
}
|
|
87
|
+
// else: gap — leave empty
|
|
88
|
+
}
|
|
89
|
+
const p = new IntPoint(xOffset, i);
|
|
90
|
+
this.drawChar(octantChar(bits), p, fullOffset);
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
this.scrollable = config.scrollable || false;
|
|
95
|
+
}
|
|
96
|
+
drawChar(char, p, o = ZERO_POINT) {
|
|
97
|
+
this.view.setContentLayerChar(char, p, o);
|
|
98
|
+
const hasAnimation = this.animationHandler?.hasActiveAnimation() ?? false;
|
|
99
|
+
if (!hasAnimation && this.stage !== "queued") {
|
|
100
|
+
this.view.setAnimationLayerChar(char, p, o);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
draw(offset) {
|
|
104
|
+
const fullOffset = offset.add(this.scrollOffset);
|
|
105
|
+
const fullContentOffset = offset.add(this.getContentOffset());
|
|
106
|
+
this.fullContentOffset = fullContentOffset;
|
|
107
|
+
if (this.mustRedraw) {
|
|
108
|
+
this.drawBackground(offset);
|
|
109
|
+
this.drawVerticalScrollBar(offset);
|
|
110
|
+
if (this.bordered) {
|
|
111
|
+
this.drawBorder(offset);
|
|
112
|
+
}
|
|
113
|
+
this.drawOwnContent(fullOffset);
|
|
114
|
+
}
|
|
115
|
+
this.children.forEach((child) => child.draw(fullOffset.add(child.getOffset())));
|
|
116
|
+
this.mustRedraw = false;
|
|
117
|
+
}
|
|
118
|
+
flagForRedraw() {
|
|
119
|
+
this.mustRedraw = true;
|
|
120
|
+
this.children.forEach((child) => child.flagForRedraw());
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Apply a scroll delta (in character rows). Returns true if scroll was consumed.
|
|
124
|
+
*/
|
|
125
|
+
applyScroll(delta) {
|
|
126
|
+
const contentAreaSize = this.size.subtract(this.getTotalBoundarySize());
|
|
127
|
+
const maxScroll = Math.max(0, this.contentSize.getY() - contentAreaSize.getY());
|
|
128
|
+
if (maxScroll === 0)
|
|
129
|
+
return false;
|
|
130
|
+
const currentScroll = -this.scrollOffset.getY();
|
|
131
|
+
const newScroll = Math.round(Math.max(0, Math.min(maxScroll, currentScroll + delta)));
|
|
132
|
+
if (newScroll === currentScroll)
|
|
133
|
+
return false;
|
|
134
|
+
this.scrollOffset.set(Y, -newScroll);
|
|
135
|
+
this.showingScrollBar = maxScroll > 0;
|
|
136
|
+
this.flagForRedraw();
|
|
137
|
+
return true;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Update showingScrollBar based on content vs viewable size.
|
|
141
|
+
* Called from reprocessContent in subclasses.
|
|
142
|
+
*/
|
|
143
|
+
updateScrollShowing() {
|
|
144
|
+
if (!this.scrollable)
|
|
145
|
+
return;
|
|
146
|
+
const contentAreaSize = this.size.subtract(this.getTotalBoundarySize());
|
|
147
|
+
this.showingScrollBar = this.contentSize.getY() > contentAreaSize.getY();
|
|
148
|
+
}
|
|
149
|
+
/** Check if a point (relative to element top-left) is on the scrollbar thumb */
|
|
150
|
+
isPointOnScrollbarThumb(px, py) {
|
|
151
|
+
if (!this.showingScrollBar)
|
|
152
|
+
return false;
|
|
153
|
+
const contentOffset = this.getContentOffset();
|
|
154
|
+
const boundarySize = this.getTotalBoundarySize();
|
|
155
|
+
const contentAreaSize = this.size.subtract(boundarySize);
|
|
156
|
+
const scrollbarX = contentOffset.getX() + contentAreaSize.getX() + this.padding.end.getX();
|
|
157
|
+
if (Math.floor(px) !== scrollbarX)
|
|
158
|
+
return false;
|
|
159
|
+
const scrollOffset = -this.scrollOffset.getY();
|
|
160
|
+
const contentAreaHeight = contentAreaSize.getY();
|
|
161
|
+
const contentHeight = this.contentSize.getY();
|
|
162
|
+
const subRows = contentAreaHeight * 4;
|
|
163
|
+
const thumbSize = Math.max(4, Math.round((contentAreaHeight / contentHeight) * subRows));
|
|
164
|
+
const thumbStart = Math.round((scrollOffset / contentHeight) * subRows);
|
|
165
|
+
const thumbEnd = thumbStart + thumbSize;
|
|
166
|
+
const subRow = (py - contentOffset.getY()) * 4;
|
|
167
|
+
return subRow >= thumbStart && subRow < thumbEnd;
|
|
168
|
+
}
|
|
169
|
+
/** Start a scrollbar drag */
|
|
170
|
+
startScrollbarDrag(mouseY) {
|
|
171
|
+
this.isDraggingScrollbar = true;
|
|
172
|
+
this.dragStartY = mouseY;
|
|
173
|
+
this.dragStartScroll = -this.scrollOffset.getY();
|
|
174
|
+
}
|
|
175
|
+
/** Update scroll position during drag */
|
|
176
|
+
updateScrollbarDrag(mouseY) {
|
|
177
|
+
if (!this.isDraggingScrollbar)
|
|
178
|
+
return;
|
|
179
|
+
const boundarySize = this.getTotalBoundarySize();
|
|
180
|
+
const contentAreaSize = this.size.subtract(boundarySize);
|
|
181
|
+
const contentAreaHeight = contentAreaSize.getY();
|
|
182
|
+
const contentHeight = this.contentSize.getY();
|
|
183
|
+
// Mouse delta in characters → scroll delta in content rows
|
|
184
|
+
const mouseDelta = mouseY - this.dragStartY;
|
|
185
|
+
const scrollDelta = mouseDelta * (contentHeight / contentAreaHeight);
|
|
186
|
+
const newScroll = Math.round(Math.max(0, Math.min(contentHeight - contentAreaHeight, this.dragStartScroll + scrollDelta)));
|
|
187
|
+
if (newScroll !== -this.scrollOffset.getY()) {
|
|
188
|
+
this.scrollOffset.set(Y, -newScroll);
|
|
189
|
+
this.showingScrollBar = true;
|
|
190
|
+
this.flagForRedraw();
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
/** Stop scrollbar drag */
|
|
194
|
+
stopScrollbarDrag() {
|
|
195
|
+
this.isDraggingScrollbar = false;
|
|
196
|
+
}
|
|
197
|
+
drawBackground(o) {
|
|
198
|
+
this.forEachVisiblePoint((p) => {
|
|
199
|
+
this.drawChar(this.backgroundChar, p, o);
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
drawBorder(o) {
|
|
203
|
+
const lastPoint = this.size.add(new IntPoint(-1, -1));
|
|
204
|
+
this.forEachVisiblePoint((p) => {
|
|
205
|
+
let char = "│";
|
|
206
|
+
if (p.equals(ZERO_POINT)) {
|
|
207
|
+
char = "╭";
|
|
208
|
+
}
|
|
209
|
+
else if (p.equals(lastPoint)) {
|
|
210
|
+
char = "╯";
|
|
211
|
+
}
|
|
212
|
+
else if (p.getX() === 0 && p.getY() === lastPoint.getY()) {
|
|
213
|
+
char = "╰";
|
|
214
|
+
}
|
|
215
|
+
else if (p.getX() === lastPoint.getX() && p.getY() === 0) {
|
|
216
|
+
char = "╮";
|
|
217
|
+
}
|
|
218
|
+
else if (p.getX() === 0 || p.getX() === lastPoint.getX()) {
|
|
219
|
+
char = "│";
|
|
220
|
+
}
|
|
221
|
+
else if (p.getY() === 0 || p.getY() === lastPoint.getY()) {
|
|
222
|
+
char = "─";
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
this.drawChar(char, p, o);
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
onSizeChanged(_oldSize, _newSize) { }
|
|
231
|
+
}
|
|
232
|
+
//# sourceMappingURL=ElementDrawing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementDrawing.js","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementDrawing.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { RealPoint } from "../types/RealPoint";
|
|
2
|
+
import { CursorType, ElementConfig } from "./ElementBase";
|
|
3
|
+
import { ElementDrawing } from "./ElementDrawing";
|
|
4
|
+
import { ElementAnimationHandler } from "../interfaces/ElementAnimationHandler";
|
|
5
|
+
export declare abstract class ElementInteraction extends ElementDrawing {
|
|
6
|
+
protected abstract handleMouseEnter(): void;
|
|
7
|
+
protected abstract handleMouseLeave(): void;
|
|
8
|
+
protected abstract handleClick(): void;
|
|
9
|
+
protected cursor: CursorType;
|
|
10
|
+
protected onclick: (() => void) | null;
|
|
11
|
+
protected mouseIsInside: boolean;
|
|
12
|
+
constructor(config: ElementConfig);
|
|
13
|
+
setOnClick(onClick: () => void): void;
|
|
14
|
+
getAnimationHandler(): ElementAnimationHandler | null;
|
|
15
|
+
handleMouseMove(p: RealPoint): boolean;
|
|
16
|
+
handleMouseDown(p: RealPoint): void;
|
|
17
|
+
handleMouseUp(p: RealPoint): void;
|
|
18
|
+
handleWheel(p: RealPoint, delta: number): boolean;
|
|
19
|
+
private pointIsInside;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=ElementInteraction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementInteraction.d.ts","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementInteraction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,uCAAuC,CAAC;AAEhF,8BAAsB,kBAAmB,SAAQ,cAAc;IAC7D,SAAS,CAAC,QAAQ,CAAC,gBAAgB,IAAI,IAAI;IAC3C,SAAS,CAAC,QAAQ,CAAC,gBAAgB,IAAI,IAAI;IAC3C,SAAS,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI;IAEtC,SAAS,CAAC,MAAM,EAAE,UAAU,CAAC;IAC7B,SAAS,CAAC,OAAO,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,IAAI,CAAQ;IAC9C,SAAS,CAAC,aAAa,EAAE,OAAO,CAAS;gBAE7B,MAAM,EAAE,aAAa;IAK1B,UAAU,CAAC,OAAO,EAAE,MAAM,IAAI,GAAG,IAAI;IAIrC,mBAAmB,IAAI,uBAAuB,GAAG,IAAI;IAIrD,eAAe,CAAC,CAAC,EAAE,SAAS,GAAG,OAAO;IAyCtC,eAAe,CAAC,CAAC,EAAE,SAAS,GAAG,IAAI;IAmBnC,aAAa,CAAC,CAAC,EAAE,SAAS,GAAG,IAAI;IASjC,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO;IAmBxD,OAAO,CAAC,aAAa;CAGtB"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { AXES } from "../types/Axes";
|
|
2
|
+
import { ElementDrawing } from "./ElementDrawing";
|
|
3
|
+
export class ElementInteraction extends ElementDrawing {
|
|
4
|
+
constructor(config) {
|
|
5
|
+
super(config);
|
|
6
|
+
Object.defineProperty(this, "cursor", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
configurable: true,
|
|
9
|
+
writable: true,
|
|
10
|
+
value: void 0
|
|
11
|
+
});
|
|
12
|
+
Object.defineProperty(this, "onclick", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
configurable: true,
|
|
15
|
+
writable: true,
|
|
16
|
+
value: null
|
|
17
|
+
});
|
|
18
|
+
Object.defineProperty(this, "mouseIsInside", {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
configurable: true,
|
|
21
|
+
writable: true,
|
|
22
|
+
value: false
|
|
23
|
+
});
|
|
24
|
+
this.cursor = config.cursor || "default";
|
|
25
|
+
}
|
|
26
|
+
setOnClick(onClick) {
|
|
27
|
+
this.onclick = onClick;
|
|
28
|
+
}
|
|
29
|
+
getAnimationHandler() {
|
|
30
|
+
return this.animationHandler;
|
|
31
|
+
}
|
|
32
|
+
handleMouseMove(p) {
|
|
33
|
+
// Handle scrollbar drag
|
|
34
|
+
if (this.isDraggingScrollbar) {
|
|
35
|
+
this.updateScrollbarDrag(p.getY());
|
|
36
|
+
return true;
|
|
37
|
+
}
|
|
38
|
+
let determiningMouse = false;
|
|
39
|
+
if (this.stage === "main" || this.stage === "entering") {
|
|
40
|
+
const pointIsInside = this.pointIsInside(p);
|
|
41
|
+
if (pointIsInside || this.mouseIsInside) {
|
|
42
|
+
let childrenDeterminingMouse = false;
|
|
43
|
+
this.children.forEach((c) => {
|
|
44
|
+
const childIsDeterminingMouse = c.handleMouseMove(p.subtract(c.getOffset()).subtract(this.scrollOffset));
|
|
45
|
+
if (childIsDeterminingMouse) {
|
|
46
|
+
childrenDeterminingMouse = true;
|
|
47
|
+
determiningMouse = true;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
if (!pointIsInside && this.stage !== "entering") {
|
|
51
|
+
this.animationHandler?.startAnimation("mouseExit", () => { });
|
|
52
|
+
this.mouseIsInside = false;
|
|
53
|
+
this.handleMouseLeave();
|
|
54
|
+
}
|
|
55
|
+
else if (!this.mouseIsInside && this.stage !== "entering") {
|
|
56
|
+
this.animationHandler?.startAnimation("mouseEnter", () => { });
|
|
57
|
+
this.mouseIsInside = true;
|
|
58
|
+
this.handleMouseEnter();
|
|
59
|
+
}
|
|
60
|
+
if (!childrenDeterminingMouse && pointIsInside) {
|
|
61
|
+
if (document.body.style.cursor !== this.cursor) {
|
|
62
|
+
document.body.style.cursor = this.cursor;
|
|
63
|
+
}
|
|
64
|
+
determiningMouse = true;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return determiningMouse;
|
|
69
|
+
}
|
|
70
|
+
handleMouseDown(p) {
|
|
71
|
+
if ((this.stage === "main" || this.stage === "entering") &&
|
|
72
|
+
this.pointIsInside(p)) {
|
|
73
|
+
// Check scrollbar thumb click before delegating to children
|
|
74
|
+
if (this.scrollable && this.isPointOnScrollbarThumb(p.getX(), p.getY())) {
|
|
75
|
+
this.startScrollbarDrag(p.getY());
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
this.onclick && this.onclick();
|
|
79
|
+
this.handleClick();
|
|
80
|
+
this.children.forEach((c) => c.handleMouseDown(p.subtract(c.getOffset()).subtract(this.scrollOffset)));
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
handleMouseUp(p) {
|
|
84
|
+
if (this.isDraggingScrollbar) {
|
|
85
|
+
this.stopScrollbarDrag();
|
|
86
|
+
}
|
|
87
|
+
this.children.forEach((c) => c.handleMouseUp(p.subtract(c.getOffset()).subtract(this.scrollOffset)));
|
|
88
|
+
}
|
|
89
|
+
handleWheel(p, delta) {
|
|
90
|
+
if (this.stage !== "main" && this.stage !== "entering")
|
|
91
|
+
return false;
|
|
92
|
+
if (!this.pointIsInside(p))
|
|
93
|
+
return false;
|
|
94
|
+
// Try children first (innermost scrollable element wins)
|
|
95
|
+
for (const child of this.children) {
|
|
96
|
+
if (child.handleWheel(p.subtract(child.getOffset()).subtract(this.scrollOffset), delta)) {
|
|
97
|
+
return true;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
// Handle locally if scrollable
|
|
101
|
+
if (this.scrollable) {
|
|
102
|
+
return this.applyScroll(delta);
|
|
103
|
+
}
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
pointIsInside(p) {
|
|
107
|
+
return AXES.every((a) => p.get(a) >= 0 && p.get(a) < this.size.get(a));
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=ElementInteraction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementInteraction.js","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementInteraction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Axis } from "../types/Axes";
|
|
2
|
+
import { IntPoint } from "../types/IntPoint";
|
|
3
|
+
import { ElementBase, ElementConfig } from "./ElementBase";
|
|
4
|
+
export declare abstract class ElementLayout extends ElementBase {
|
|
5
|
+
protected padding: {
|
|
6
|
+
start: IntPoint;
|
|
7
|
+
end: IntPoint;
|
|
8
|
+
};
|
|
9
|
+
protected bordered: boolean;
|
|
10
|
+
protected backgroundChar: string;
|
|
11
|
+
constructor(config: ElementConfig);
|
|
12
|
+
getHasBorder: () => boolean;
|
|
13
|
+
getBackgroundChar: () => string;
|
|
14
|
+
getContentEndOffset(): IntPoint;
|
|
15
|
+
getContentAreaSize(): IntPoint;
|
|
16
|
+
getTotalBoundarySize(): IntPoint;
|
|
17
|
+
getContentOffset(): IntPoint;
|
|
18
|
+
protected scrollable: boolean;
|
|
19
|
+
protected showingScrollBar: boolean;
|
|
20
|
+
protected forEachVisiblePointInContentArea(fn: (p: IntPoint) => void): void;
|
|
21
|
+
forEachAlongAxisInContentArea(a: Axis, fn: (i: number) => void): void;
|
|
22
|
+
forEachVisiblePoint(fn: (p: IntPoint) => void): void;
|
|
23
|
+
forEachVisibleAlongAxis(a: Axis, fn: (i: number) => void): void;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=ElementLayout.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementLayout.d.ts","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementLayout.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAK,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE3D,8BAAsB,aAAc,SAAQ,WAAW;IACrD,SAAS,CAAC,OAAO,EAAE;QACjB,KAAK,EAAE,QAAQ,CAAC;QAChB,GAAG,EAAE,QAAQ,CAAC;KACf,CAAC;IACF,SAAS,CAAC,QAAQ,EAAE,OAAO,CAAC;IAC5B,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;gBAErB,MAAM,EAAE,aAAa;IAiB1B,YAAY,gBAAuB;IACnC,iBAAiB,eAA6B;IAE9C,mBAAmB,IAAI,QAAQ;IAI/B,kBAAkB,IAAI,QAAQ;IAI9B,oBAAoB;IASpB,gBAAgB;IAMvB,SAAS,CAAC,UAAU,EAAE,OAAO,CAAS;IACtC,SAAS,CAAC,gBAAgB,EAAE,OAAO,CAAS;IAK5C,SAAS,CAAC,gCAAgC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,KAAK,IAAI;IA2B7D,6BAA6B,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI;IAoB9D,mBAAmB,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,KAAK,IAAI;IA2B7C,uBAAuB,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI;CAiBhE"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { DEFAULT_BACKGROUND_CHAR } from "../constants";
|
|
2
|
+
import { X } from "../types/Axes";
|
|
3
|
+
import { IntPoint } from "../types/IntPoint";
|
|
4
|
+
import { ElementBase } from "./ElementBase";
|
|
5
|
+
export class ElementLayout extends ElementBase {
|
|
6
|
+
constructor(config) {
|
|
7
|
+
super(config);
|
|
8
|
+
Object.defineProperty(this, "padding", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
configurable: true,
|
|
11
|
+
writable: true,
|
|
12
|
+
value: void 0
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(this, "bordered", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
configurable: true,
|
|
17
|
+
writable: true,
|
|
18
|
+
value: void 0
|
|
19
|
+
});
|
|
20
|
+
Object.defineProperty(this, "backgroundChar", {
|
|
21
|
+
enumerable: true,
|
|
22
|
+
configurable: true,
|
|
23
|
+
writable: true,
|
|
24
|
+
value: void 0
|
|
25
|
+
});
|
|
26
|
+
Object.defineProperty(this, "getHasBorder", {
|
|
27
|
+
enumerable: true,
|
|
28
|
+
configurable: true,
|
|
29
|
+
writable: true,
|
|
30
|
+
value: () => this.bordered
|
|
31
|
+
});
|
|
32
|
+
Object.defineProperty(this, "getBackgroundChar", {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
configurable: true,
|
|
35
|
+
writable: true,
|
|
36
|
+
value: () => this.backgroundChar
|
|
37
|
+
});
|
|
38
|
+
// --- Scroll state (managed here for boundary size calculation, DOM logic elsewhere) ---
|
|
39
|
+
Object.defineProperty(this, "scrollable", {
|
|
40
|
+
enumerable: true,
|
|
41
|
+
configurable: true,
|
|
42
|
+
writable: true,
|
|
43
|
+
value: false
|
|
44
|
+
});
|
|
45
|
+
Object.defineProperty(this, "showingScrollBar", {
|
|
46
|
+
enumerable: true,
|
|
47
|
+
configurable: true,
|
|
48
|
+
writable: true,
|
|
49
|
+
value: false
|
|
50
|
+
});
|
|
51
|
+
this.bordered = config.bordered || false;
|
|
52
|
+
this.backgroundChar = config.backgroundChar || DEFAULT_BACKGROUND_CHAR;
|
|
53
|
+
this.padding = {
|
|
54
|
+
start: new IntPoint(config.paddingLeft || config.paddingX || config.padding || 0, config.paddingTop || config.paddingY || config.padding || 0),
|
|
55
|
+
end: new IntPoint(config.paddingRight || config.paddingX || config.padding || 0, config.paddingBottom || config.paddingY || config.padding || 0),
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
getContentEndOffset() {
|
|
59
|
+
return this.size.subtract(this.padding.end);
|
|
60
|
+
}
|
|
61
|
+
getContentAreaSize() {
|
|
62
|
+
return this.size.subtract(this.getTotalBoundarySize());
|
|
63
|
+
}
|
|
64
|
+
getTotalBoundarySize() {
|
|
65
|
+
const b = this.bordered ? 2 : 0;
|
|
66
|
+
const withPadding = this.padding.start
|
|
67
|
+
.add(this.padding.end)
|
|
68
|
+
.add(new IntPoint(b, b));
|
|
69
|
+
if (this.showingScrollBar)
|
|
70
|
+
withPadding.set(X, withPadding.getX() + 1);
|
|
71
|
+
return withPadding;
|
|
72
|
+
}
|
|
73
|
+
getContentOffset() {
|
|
74
|
+
const b = this.bordered ? 1 : 0;
|
|
75
|
+
return this.padding.start.add(new IntPoint(b, b));
|
|
76
|
+
}
|
|
77
|
+
// --- Iteration helpers ---
|
|
78
|
+
// p is measured from the top left of content area
|
|
79
|
+
forEachVisiblePointInContentArea(fn) {
|
|
80
|
+
if (!this.parent)
|
|
81
|
+
return;
|
|
82
|
+
const p0FromParentContent = this.offset
|
|
83
|
+
.add(this.parent.getScrollOffset())
|
|
84
|
+
.add(this.getContentOffset())
|
|
85
|
+
.subtract(this.parent.getContentOffset());
|
|
86
|
+
const parentContentAreaSize = this.parent.getContentAreaSize();
|
|
87
|
+
const contentAreaSize = this.getContentAreaSize();
|
|
88
|
+
for (let y = 0; y < contentAreaSize.getY(); y++) {
|
|
89
|
+
if (y + p0FromParentContent.getY() < 0 ||
|
|
90
|
+
y + p0FromParentContent.getY() >= parentContentAreaSize.getY()) {
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
for (let x = 0; x < contentAreaSize.getX(); x++) {
|
|
94
|
+
if (x + p0FromParentContent.getX() < 0 ||
|
|
95
|
+
x + p0FromParentContent.getX() >= parentContentAreaSize.getX()) {
|
|
96
|
+
continue;
|
|
97
|
+
}
|
|
98
|
+
fn(new IntPoint(x, y));
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
forEachAlongAxisInContentArea(a, fn) {
|
|
103
|
+
if (!this.parent)
|
|
104
|
+
return;
|
|
105
|
+
const p0 = this.offset
|
|
106
|
+
.add(this.parent.getScrollOffset())
|
|
107
|
+
.add(this.getContentOffset())
|
|
108
|
+
.subtract(this.parent.getContentOffset());
|
|
109
|
+
const parentContentEnd = this.parent.getContentAreaSize();
|
|
110
|
+
const contentAreaSize = this.getContentAreaSize();
|
|
111
|
+
for (let i = 0; i < contentAreaSize.get(a) &&
|
|
112
|
+
i + p0.get(a) < parentContentEnd.get(a) &&
|
|
113
|
+
i + p0.get(a) >= 0; i++) {
|
|
114
|
+
fn(i);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
// p is measured from the top left of element
|
|
118
|
+
forEachVisiblePoint(fn) {
|
|
119
|
+
if (!this.parent)
|
|
120
|
+
return;
|
|
121
|
+
const p0 = this.offset
|
|
122
|
+
.add(this.parent.getScrollOffset())
|
|
123
|
+
.subtract(this.parent.getContentOffset());
|
|
124
|
+
const parentContentAreaSize = this.parent.getContentAreaSize();
|
|
125
|
+
for (let y = 0; y < this.size.getY() && y + p0.getY() < parentContentAreaSize.getY(); y++) {
|
|
126
|
+
if (y + p0.getY() < 0) {
|
|
127
|
+
continue;
|
|
128
|
+
}
|
|
129
|
+
for (let x = 0; x < this.size.getX() && x + p0.getX() < parentContentAreaSize.getX(); x++) {
|
|
130
|
+
if (x + p0.getX() < 0) {
|
|
131
|
+
continue;
|
|
132
|
+
}
|
|
133
|
+
fn(new IntPoint(x, y));
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
forEachVisibleAlongAxis(a, fn) {
|
|
138
|
+
if (!this.parent)
|
|
139
|
+
return;
|
|
140
|
+
const p0 = this.offset
|
|
141
|
+
.add(this.parent.getScrollOffset())
|
|
142
|
+
.subtract(this.parent.getContentOffset());
|
|
143
|
+
const parentCASize = this.parent.getContentAreaSize();
|
|
144
|
+
for (let i = 0; i < this.size.get(a) && i + p0.get(a) < parentCASize.get(a); i++) {
|
|
145
|
+
if (i + p0.get(a) < 0) {
|
|
146
|
+
continue;
|
|
147
|
+
}
|
|
148
|
+
fn(i);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=ElementLayout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ElementLayout.js","sourceRoot":"","sources":["../../../../../char-matrix/src/Element/ElementLayout.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { SizingMethod, Element } from "./Element";
|
|
2
|
+
import { Axis } from "../types/Axes";
|
|
3
|
+
import { IntPoint } from "../types/IntPoint";
|
|
4
|
+
export declare abstract class ParentElement {
|
|
5
|
+
protected children: Element[];
|
|
6
|
+
protected spacing: number;
|
|
7
|
+
abstract getSize(): IntPoint;
|
|
8
|
+
abstract getParent(): ParentElement | null;
|
|
9
|
+
abstract getScrollOffset(): IntPoint;
|
|
10
|
+
abstract handleChildResize(axis: Axis | null): void;
|
|
11
|
+
abstract getSizingMethod(): {
|
|
12
|
+
x: SizingMethod;
|
|
13
|
+
y: SizingMethod;
|
|
14
|
+
};
|
|
15
|
+
abstract getIsOnView(): boolean;
|
|
16
|
+
abstract getBackgroundChar(): string;
|
|
17
|
+
abstract getTotalBoundarySize(): IntPoint;
|
|
18
|
+
abstract getContentOffset(): IntPoint;
|
|
19
|
+
abstract getContentEndOffset(): IntPoint;
|
|
20
|
+
abstract getContentAreaSize(): IntPoint;
|
|
21
|
+
abstract getStage(): string;
|
|
22
|
+
protected resizeChildren(): void;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=ParentElement.d.ts.map
|