From 0cd3aed562c90648219fa885475075bca02222d1 Mon Sep 17 00:00:00 2001 From: Anton Vorobev Date: Mon, 25 Sep 2023 13:43:08 +0300 Subject: [PATCH] fix: show crosstool after longtouch --- .../components/cross_tool/cross-tool.model.ts | 1 + .../inputhandlers/hover-producer.component.ts | 14 +++++++------- 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/src/chart/components/cross_tool/cross-tool.model.ts b/src/chart/components/cross_tool/cross-tool.model.ts index e6da2b08..c54148ac 100644 --- a/src/chart/components/cross_tool/cross-tool.model.ts +++ b/src/chart/components/cross_tool/cross-tool.model.ts @@ -126,6 +126,7 @@ export class CrossToolModel extends ChartBaseElement { } else { this.currentHover.y = hover.y; } + this.currentHover.paneId = CHART_UUID; this.currentHoverSubject.next(this.currentHover); } } diff --git a/src/chart/inputhandlers/hover-producer.component.ts b/src/chart/inputhandlers/hover-producer.component.ts index f3a03410..bb72ad85 100644 --- a/src/chart/inputhandlers/hover-producer.component.ts +++ b/src/chart/inputhandlers/hover-producer.component.ts @@ -59,7 +59,7 @@ export class HoverProducerComponent extends ChartBaseElement { get hover(): Hover | null { return this.hoverSubject.getValue(); } - private longTouchActivated: boolean = false; + private longTouchActivatedSubject: BehaviorSubject = new BehaviorSubject(false); private hoverProducerParts: HoverProducerParts; xFormatter: DateTimeFormatter = () => ''; constructor( @@ -123,7 +123,7 @@ export class HoverProducerComponent extends ChartBaseElement { this.addRxSubscription(this.scale.xChanged.subscribe(() => this.fireLastCross())); this.addRxSubscription( this.canvasInputListener.observeTouchStart().subscribe(event => { - const x = event.touches[0].clientX; + const x = event.touches[0].clientX - this.canvasBoundsContainer.canvasOnPageLocation.x; const y = event.touches[0].clientY - this.canvasBoundsContainer.canvasOnPageLocation.y; const candle = this.chartModel.candleFromX(x, true); if (candle) { @@ -138,17 +138,18 @@ export class HoverProducerComponent extends ChartBaseElement { this.addRxSubscription( this.canvasInputListener.observeLongTouch(hitTest).subscribe(event => { this.paneManager.chartPanComponent.deactivatePanHandlers(); - this.longTouchActivated = true; - const x = event.touches[0].clientX; + this.longTouchActivatedSubject.next(true); + const x = event.touches[0].clientX - this.canvasBoundsContainer.canvasOnPageLocation.x; const y = event.touches[0].clientY - this.canvasBoundsContainer.canvasOnPageLocation.y; this.createAndFireHover([x, y, '']); + this.crossEventProducer.crossSubject.next([x, y, '']); }), ); this.addRxSubscription( this.canvasInputListener.observeTouchEndDocument().subscribe(() => { this.paneManager.chartPanComponent.activateChartPanHandlers(); - if (this.longTouchActivated) { - this.longTouchActivated = false; + if (this.longTouchActivatedSubject.getValue()) { + this.longTouchActivatedSubject.next(false); this.crossEventProducer.fireCrossClose(); } }), @@ -271,7 +272,6 @@ export class HoverProducerComponent extends ChartBaseElement { const candle = hover.candleHover?.visualCandle.candle; candle && this.chartModel.mainCandleSeries.setActiveCandle(candle); } - // const showCrossToolOverride = isMobile() ? this.longTouchActivated : showCrossTool; this.hoverSubject.next(hover); } else { this.crossEventProducer.fireCrossClose();