Скроллбар Highcharts стрелка вверх выдает ошибку при клике - PullRequest
0 голосов
/ 14 марта 2019

Если щелкнуть стрелку вверх на графике диапазона высоких диаграмм с полосой прокрутки на оси YAXIS (есть также на оси XAxis, но она не выдает ошибку, когда я использую ее кнопку со стрелкой), возвращается ошибка

Uncaught TypeError: Cannot read property 'call' of undefined
at SVGGElement.<anonymous> (highcharts.src.js:5182)

Пока что я не нашел в Интернете ничего конкретного об этой ошибке, но если я это сделаю, я обновлю этот билет

Может ли это быть как-то связано с наличием полосы прокрутки X и Y?Я не планирую использовать кнопку вообще, так как мы внедрили прослушиватель для трекпада / руля - есть ли способ полного удаления кнопки со стрелкой (вместо того, чтобы сделать ее прозрачной, которую я в настоящее время реализовал, которая включает в себя неприглядное наведениене может избавиться от)

Если вы можете мне помочь A) Удалить / полностью скрыть кнопку B) прослушать щелчок и выбросить событие, чтобы избежать этой ошибки или C) исправить любую причинуэта ошибка ... я был бы очень признателен

{
    'chart': {
      'renderTo': graphId,
      'type': 'xrange',
      'zoomType': 'xy',
      'panning': true,
      'panKey': 'shift',
      'marginRight': 40,
      'marginLeft': 150,
      'resetZoomButton': {
        'position': {
          'x': -150,
          'y': -10
        }
      }
    },
    'exporting': {
      'enabled': true,
      'buttons': {
        'enabled': true,
        'contextButton': {
          'enabled': false
        },
        'resetScopeButton': {
          'y': -10,
          'x': -25,
          'symbolX': 20,
          'symbolY': 20,
          'enabled': true,
          'onclick': context['LiAnalytics']['resetScopeButton'],
          'symbol': 'url(../images/refresh.png)'
        },
        'hourButton': {
          'enabled': true,
          'text': 'H',
          'y': -10,
          'x': -50,
          'onclick': context['LiAnalytics']['hourButton']
        },
        'dayButton': {
          'text': 'D',
          'y': -10,
          'x': -75,
          'enabled': endTS - startTS > 86400000,
          'onclick': context['LiAnalytics']['dayButton']
        },
        'weekButton': {
          'text': 'W',
          'y': -10,
          'x': -100,
          'enabled': endTS - startTS >= 604800000,
          'onclick': context['LiAnalytics']['weekButton']
        },
        'monthButton': {
          'text': 'M',
          'y': -10,
          'x': -125,
          'enabled': endTS - startTS >= 2419000000,
          'onclick': context['LiAnalytics']['monthButton']
        }
      }
    },
    'legend': {
      'enabled': false
    },
    'xAxis': {
      'type': 'datetime',
      'dateTimeLabelFormats': {
        ...
      },
      'events': {
        'setExtremes': new js.JsFunction.withThis(_handleRedraw)
      },
      'min': (endTS - startTS) > initialZoom ? endTS - initialZoom : startTS,
      'max': endTS,
      'scrollbar': {
        'enabled': true,
        'showFull': false,
        'barBackgroundColor': '#ccc',
        'barBorderRadius': 7,
        'barBorderWidth': 0,
        'buttonBorderWidth': 0,
        'buttonArrowColor': 'transparent',
        'buttonBackgroundColor': 'transparent',
        'rifleColor': 'transparent',
        'trackBackgroundColor': '#F3F3F3',
        'trackBorderColor': 'transparent',
        'height': 10,
        'minWidth': 25
      }
    },
    'yAxis': {
      'categories': agents,
      'min': 0,
      'max': agents.length < maxY ? agents.length - 1 : maxY,
      'scrollbar': { /* Why you throw err on click ? */
        'enabled': true,
        'showFull': false,
        'barBackgroundColor': '#ccc',
        'barBorderRadius': 7,
        'barBorderWidth': 0,
        'buttonBorderWidth': 0,
        'buttonArrowColor': 'transparent', /* Remove entirely ? */
        'buttonBackgroundColor': 'transparent',
        'rifleColor': 'transparent',
        'trackBackgroundColor': '#F3F3F3',
        'trackBorderColor': 'transparent',
        'height': 10,
        'minWidth': 25
      },
      'reversed': true,
      'tickmarkPlacement': 'on',
      'gridLineColor': 'transparent'
    },
    'plotOptions': {
      'series': {
        'animation': {
          'duration': 2000
        },
        'point': {
          'events': { /* can i do something similar for scrollbar? */
            'mouseOver': new js.JsFunction.withThis(_mouseOver),
            'mouseOut': new js.JsFunction.withThis(_mouseOut)
          }
        },
        'pointWidth': 20,
        'pointPlacement': 0,
        'minPointLength': 10,
        'borderRadius': 0
      }
    },
    'series': series,
    'tooltip': {
      ...
    }
  }

(C) Блок текущего кода

(function() {
    //internal functions
    function stopEvent(e) {
        if (e) {
            if (e.preventDefault) {
                e.preventDefault();
            }
            if (e.stopPropagation) {
                e.stopPropagation();
            }
            e.cancelBubble = true;
        }
    }
    /* Wrap allows us to override the behavior of render while not interrupting the normal rendering procedure */
    Highcharts.wrap(Highcharts.Chart.prototype, 'render', function(proceed) {
        var chart = this;

        proceed.call(chart);
        /* When a chart has a scrollbar and is xrange our PM/UX has requested the touchpad be abled to control the scrollbar */
        if (chart.options['chart']['type'] === "xrange" && chart.options['yAxis'][0]['scrollbar']['enabled']) {
            // Add the mousewheel event
            Highcharts.addEvent(chart.container, document.onmousewheel === undefined ? 'DOMMouseScroll' : 'mousewheel', function (event) {

                var delta, diff, extr, newMax, newMin, step, axis = chart.yAxis[0];
                e = chart.pointer.normalize(event);
                // Firefox uses e.detail, WebKit and IE uses wheelDelta
                delta = e.detail || -(e.wheelDelta / 120);
                delta = delta < 0 ? 1 : -1;
                /* Up or Down */
                if (chart.isInsidePlot(e.chartX - chart.plotLeft, e.chartY - chart.plotTop)) {
                    extr = axis.getExtremes();
                    if (extr.dataMax !== extr.dataMin) {
                        diff = extr.max - extr.min;
                        step = diff / 5;
                        /* move by fifths */
                        step = step > 1 ? Math.ceil(step) : 1;
                        /* Min step is 1, Move by whole numbers */
                        step = step * delta;
                        /* Up/Down */
                        if (step > 0) {
                            /* UP */
                            if (extr.max + step > extr.dataMax) {
                                newMax = extr.dataMax;
                                newMin = extr.dataMax - diff;
                                /* Enforce window not getting too small */
                            } else {
                                newMin = extr.min + step;
                                newMax = extr.max + step;
                            }
                        } else {
                            /* DOWN */
                            if (extr.min + step < 0) {
                                newMin = 0;
                                newMax = diff;
                            } else {
                                newMin = extr.min + step;
                                newMax = extr.max + step;
                            }
                        }
                        axis.setExtremes(newMin, newMax, true, false);
                    }
                }
                stopEvent(event);
                return false;
            });
        }
    });

    Highcharts.Scrollbar.prototype.addEvents = function() {
        var chart = this;

        var buttonsOrder = chart.options.inverted ? [1, 0] : [0, 1],
            buttons = chart.scrollbarButtons,
            bar = chart.scrollbarGroup.element,
            track = chart.track.element,
            mouseDownHandler = chart.mouseDownHandler,
            mouseMoveHandler = chart.mouseMoveHandler,
            mouseUpHandler = chart.mouseUpHandler,
            _events;

        // Mouse events
        _events = [
            /*    [buttons[buttonsOrder[0]].element, 'click', this.buttonToMinClick],
                  [buttons[buttonsOrder[1]].element, 'click', this.buttonToMaxClick], */
            [track, 'click', this.trackClick],
            [bar, 'mousedown', mouseDownHandler],
            [bar.ownerDocument, 'mousemove', mouseMoveHandler],
            [bar.ownerDocument, 'mouseup', mouseUpHandler]
        ];

        // Touch events
        if (Highcharts.hasTouch) {
            _events.push(
                [bar, 'touchstart', mouseDownHandler], [bar.ownerDocument, 'touchmove', mouseMoveHandler], [bar.ownerDocument, 'touchend', mouseUpHandler]
            );
        }

        // Add them all
        _events.forEach(function(args) {
            Highcharts.addEvent.apply(null, args);
        });
        chart._events = _events;
    };
}());

РЕДАКТИРОВАТЬ: удалены старые детали

1 Ответ

0 голосов
/ 03 апреля 2019

Это было вызвано попыткой отключить контекстную кнопку по отдельности, в то время как другие пользовательские кнопки были включены. Контекстная кнопка висела как фантомная кнопка, которая была наложена на стрелку прокрутки вверх, вызывая ошибочный диагноз во время отладки.

Решением, с которым я в конечном итоге столкнулся, было изменение ориентации контекстной кнопки путем переопределения символа / символа X с символом (для центрирования символа в области кнопок) / поведения при нажатии

перенаправлен по щелчку на поведение resetScope, над которым я работал переопределить символ гамбургера с помощью png, сохраненного / выбранного UX

...