From ff396ff38f2cbdbbe6202eabeaab5548319c3f2d Mon Sep 17 00:00:00 2001 From: Mark Silverwood <3482679+SlicedSilver@users.noreply.github.com> Date: Mon, 16 Dec 2024 13:11:19 +0000 Subject: [PATCH] improve check for crosshair label visibility on the price scale --- .size-limit.js | 8 ++++---- src/gui/price-axis-widget.ts | 12 ++++++++++-- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/.size-limit.js b/.size-limit.js index f5f4eb4504..f7763abbdf 100644 --- a/.size-limit.js +++ b/.size-limit.js @@ -4,21 +4,21 @@ module.exports = [ { name: 'CJS', path: 'dist/lightweight-charts.production.cjs', - limit: '49.29 KB', + limit: '49.32 KB', }, { name: 'ESM', path: 'dist/lightweight-charts.production.mjs', - limit: '49.22 KB', + limit: '49.25 KB', }, { name: 'Standalone-ESM', path: 'dist/lightweight-charts.standalone.production.mjs', - limit: '50.94 KB', + limit: '50.97 KB', }, { name: 'Standalone', path: 'dist/lightweight-charts.standalone.production.js', - limit: '50.98 KB', + limit: '51.00 KB', }, ]; diff --git a/src/gui/price-axis-widget.ts b/src/gui/price-axis-widget.ts index e1029564dc..c08b275538 100644 --- a/src/gui/price-axis-widget.ts +++ b/src/gui/price-axis-widget.ts @@ -16,7 +16,7 @@ import { makeFont } from '../helpers/make-font'; import { ChartOptionsInternalBase } from '../model/chart-model'; import { Coordinate } from '../model/coordinate'; -import { CrosshairMode } from '../model/crosshair'; +import { CrosshairMode, CrosshairOptions } from '../model/crosshair'; import { IDataSource } from '../model/idata-source'; import { InvalidationLevel } from '../model/invalidate-mask'; import { IPriceDataSource } from '../model/iprice-data-source'; @@ -119,6 +119,10 @@ function recalculateOverlapping( } } +function priceScaleCrosshairLabelVisible(crosshair: CrosshairOptions): boolean { + return crosshair.mode !== CrosshairMode.Hidden && crosshair.horzLine.visible && crosshair.horzLine.labelVisible; +} + export class PriceAxisWidget implements IDestroyable { private readonly _pane: PaneWidget; private readonly _options: Readonly; @@ -273,7 +277,11 @@ export class PriceAxisWidget implements IDestroyable { } const firstValue = this._priceScale.firstValue(); - if (firstValue !== null && this._size !== null && this._options.crosshair.mode !== CrosshairMode.Hidden) { + if ( + firstValue !== null && + this._size !== null && + priceScaleCrosshairLabelVisible(this._options.crosshair) + ) { const topValue = this._priceScale.coordinateToPrice(1 as Coordinate, firstValue); const bottomValue = this._priceScale.coordinateToPrice(this._size.height - 2 as Coordinate, firstValue);