| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075 |
- /**
- * @license Highstock JS v8.0.0 (2019-12-10)
- *
- * Advanced Highstock tools
- *
- * (c) 2010-2019 Highsoft AS
- * Author: Torstein Honsi
- *
- * License: www.highcharts.com/license
- */
- 'use strict';
- (function (factory) {
- if (typeof module === 'object' && module.exports) {
- factory['default'] = factory;
- module.exports = factory;
- } else if (typeof define === 'function' && define.amd) {
- define('highcharts/modules/stock-tools', ['highcharts', 'highcharts/modules/stock'], function (Highcharts) {
- factory(Highcharts);
- factory.Highcharts = Highcharts;
- return factory;
- });
- } else {
- factory(typeof Highcharts !== 'undefined' ? Highcharts : undefined);
- }
- }(function (Highcharts) {
- var _modules = Highcharts ? Highcharts._modules : {};
- function _registerModule(obj, path, args, fn) {
- if (!obj.hasOwnProperty(path)) {
- obj[path] = fn.apply(null, args);
- }
- }
- _registerModule(_modules, 'modules/stock-tools-bindings.js', [_modules['parts/Globals.js'], _modules['parts/Utilities.js']], function (H, U) {
- /**
- *
- * Events generator for Stock tools
- *
- * (c) 2009-2019 Paweł Fus
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- /**
- * A config object for bindings in Stock Tools module.
- *
- * @interface Highcharts.StockToolsBindingsObject
- */ /**
- * ClassName of the element for a binding.
- * @name Highcharts.StockToolsBindingsObject#className
- * @type {string|undefined}
- */ /**
- * Last event to be fired after last step event.
- * @name Highcharts.StockToolsBindingsObject#end
- * @type {Function|undefined}
- */ /**
- * Initial event, fired on a button click.
- * @name Highcharts.StockToolsBindingsObject#init
- * @type {Function|undefined}
- */ /**
- * Event fired on first click on a chart.
- * @name Highcharts.StockToolsBindingsObject#start
- * @type {Function|undefined}
- */ /**
- * Last event to be fired after last step event. Array of step events to be
- * called sequentially after each user click.
- * @name Highcharts.StockToolsBindingsObject#steps
- * @type {Array<Function>|undefined}
- */
- var correctFloat = U.correctFloat, defined = U.defined, extend = U.extend, isNumber = U.isNumber, pick = U.pick;
- var fireEvent = H.fireEvent, merge = H.merge, bindingsUtils = H.NavigationBindings.prototype.utils, PREFIX = 'highcharts-';
- /* eslint-disable no-invalid-this */
- /**
- * Generates function which will add a flag series using modal in GUI.
- * Method fires an event "showPopup" with config:
- * `{type, options, callback}`.
- *
- * Example: NavigationBindings.utils.addFlagFromForm('url(...)') - will
- * generate function that shows modal in GUI.
- *
- * @private
- * @function bindingsUtils.addFlagFromForm
- *
- * @param {string} type
- * Type of flag series, e.g. "squarepin"
- *
- * @return {Function}
- * Callback to be used in `start` callback
- */
- bindingsUtils.addFlagFromForm = function (type) {
- return function (e) {
- var navigation = this, chart = navigation.chart, toolbar = chart.stockTools, getFieldType = bindingsUtils.getFieldType, point = bindingsUtils.attractToPoint(e, chart), pointConfig = {
- x: point.x,
- y: point.y
- }, seriesOptions = {
- type: 'flags',
- onSeries: point.series.id,
- shape: type,
- data: [pointConfig],
- point: {
- events: {
- click: function () {
- var point = this, options = point.options;
- fireEvent(navigation, 'showPopup', {
- point: point,
- formType: 'annotation-toolbar',
- options: {
- langKey: 'flags',
- type: 'flags',
- title: [
- options.title,
- getFieldType(options.title)
- ],
- name: [
- options.name,
- getFieldType(options.name)
- ]
- },
- onSubmit: function (updated) {
- if (updated.actionType === 'remove') {
- point.remove();
- }
- else {
- point.update(navigation.fieldsToOptions(updated.fields, {}));
- }
- }
- });
- }
- }
- }
- };
- if (!toolbar || !toolbar.guiEnabled) {
- chart.addSeries(seriesOptions);
- }
- fireEvent(navigation, 'showPopup', {
- formType: 'flag',
- // Enabled options:
- options: {
- langKey: 'flags',
- type: 'flags',
- title: ['A', getFieldType('A')],
- name: ['Flag A', getFieldType('Flag A')]
- },
- // Callback on submit:
- onSubmit: function (data) {
- navigation.fieldsToOptions(data.fields, seriesOptions.data[0]);
- chart.addSeries(seriesOptions);
- }
- });
- };
- };
- bindingsUtils.manageIndicators = function (data) {
- var navigation = this, chart = navigation.chart, seriesConfig = {
- linkedTo: data.linkedTo,
- type: data.type
- }, indicatorsWithVolume = [
- 'ad',
- 'cmf',
- 'mfi',
- 'vbp',
- 'vwap'
- ], indicatorsWithAxes = [
- 'ad',
- 'atr',
- 'cci',
- 'cmf',
- 'macd',
- 'mfi',
- 'roc',
- 'rsi',
- 'ao',
- 'aroon',
- 'aroonoscillator',
- 'trix',
- 'apo',
- 'dpo',
- 'ppo',
- 'natr',
- 'williamsr',
- 'stochastic',
- 'slowstochastic',
- 'linearRegression',
- 'linearRegressionSlope',
- 'linearRegressionIntercept',
- 'linearRegressionAngle'
- ], yAxis, series;
- if (data.actionType === 'edit') {
- navigation.fieldsToOptions(data.fields, seriesConfig);
- series = chart.get(data.seriesId);
- if (series) {
- series.update(seriesConfig, false);
- }
- }
- else if (data.actionType === 'remove') {
- series = chart.get(data.seriesId);
- if (series) {
- yAxis = series.yAxis;
- if (series.linkedSeries) {
- series.linkedSeries.forEach(function (linkedSeries) {
- linkedSeries.remove(false);
- });
- }
- series.remove(false);
- if (indicatorsWithAxes.indexOf(series.type) >= 0) {
- yAxis.remove(false);
- navigation.resizeYAxes();
- }
- }
- }
- else {
- seriesConfig.id = H.uniqueKey();
- navigation.fieldsToOptions(data.fields, seriesConfig);
- if (indicatorsWithAxes.indexOf(data.type) >= 0) {
- yAxis = chart.addAxis({
- id: H.uniqueKey(),
- offset: 0,
- opposite: true,
- title: {
- text: ''
- },
- tickPixelInterval: 40,
- showLastLabel: false,
- labels: {
- align: 'left',
- y: -2
- }
- }, false, false);
- seriesConfig.yAxis = yAxis.options.id;
- navigation.resizeYAxes();
- }
- else {
- seriesConfig.yAxis = chart.get(data.linkedTo).options.yAxis;
- }
- if (indicatorsWithVolume.indexOf(data.type) >= 0) {
- seriesConfig.params.volumeSeriesID = chart.series.filter(function (series) {
- return series.options.type === 'column';
- })[0].options.id;
- }
- chart.addSeries(seriesConfig, false);
- }
- fireEvent(navigation, 'deselectButton', {
- button: navigation.selectedButtonElement
- });
- chart.redraw();
- };
- /**
- * Update height for an annotation. Height is calculated as a difference
- * between last point in `typeOptions` and current position. It's a value,
- * not pixels height.
- *
- * @private
- * @function bindingsUtils.updateHeight
- *
- * @param {global.Event} e
- * normalized browser event
- *
- * @param {Highcharts.Annotation} annotation
- * Annotation to be updated
- *
- * @return {void}
- */
- bindingsUtils.updateHeight = function (e, annotation) {
- annotation.update({
- typeOptions: {
- height: this.chart.pointer.getCoordinates(e).yAxis[0].value -
- annotation.options.typeOptions.points[1].y
- }
- });
- };
- // @todo
- // Consider using getHoverData(), but always kdTree (columns?)
- bindingsUtils.attractToPoint = function (e, chart) {
- var coords = chart.pointer.getCoordinates(e), x = coords.xAxis[0].value, y = coords.yAxis[0].value, distX = Number.MAX_VALUE, closestPoint;
- chart.series.forEach(function (series) {
- series.points.forEach(function (point) {
- if (point && distX > Math.abs(point.x - x)) {
- distX = Math.abs(point.x - x);
- closestPoint = point;
- }
- });
- });
- return {
- x: closestPoint.x,
- y: closestPoint.y,
- below: y < closestPoint.y,
- series: closestPoint.series,
- xAxis: closestPoint.series.xAxis.index || 0,
- yAxis: closestPoint.series.yAxis.index || 0
- };
- };
- /**
- * Shorthand to check if given yAxis comes from navigator.
- *
- * @private
- * @function bindingsUtils.isNotNavigatorYAxis
- *
- * @param {Highcharts.Axis} axis
- * Axis to check.
- *
- * @return {boolean}
- * True, if axis comes from navigator.
- */
- bindingsUtils.isNotNavigatorYAxis = function (axis) {
- return axis.userOptions.className !== PREFIX + 'navigator-yaxis';
- };
- /**
- * Update each point after specified index, most of the annotations use
- * this. For example crooked line: logic behind updating each point is the
- * same, only index changes when adding an annotation.
- *
- * Example: NavigationBindings.utils.updateNthPoint(1) - will generate
- * function that updates all consecutive points except point with index=0.
- *
- * @private
- * @function bindingsUtils.updateNthPoint
- *
- * @param {number} startIndex
- * Index from each point should udpated
- *
- * @return {Function}
- * Callback to be used in steps array
- */
- bindingsUtils.updateNthPoint = function (startIndex) {
- return function (e, annotation) {
- var options = annotation.options.typeOptions, coords = this.chart.pointer.getCoordinates(e), x = coords.xAxis[0].value, y = coords.yAxis[0].value;
- options.points.forEach(function (point, index) {
- if (index >= startIndex) {
- point.x = x;
- point.y = y;
- }
- });
- annotation.update({
- typeOptions: {
- points: options.points
- }
- });
- };
- };
- // Extends NavigationBindigs to support indicators and resizers:
- extend(H.NavigationBindings.prototype, {
- /* eslint-disable valid-jsdoc */
- /**
- * Get current positions for all yAxes. If new axis does not have position,
- * returned is default height and last available top place.
- *
- * @private
- * @function Highcharts.NavigationBindings#getYAxisPositions
- *
- * @param {Array<Highcharts.Axis>} yAxes
- * Array of yAxes available in the chart.
- *
- * @param {number} plotHeight
- * Available height in the chart.
- *
- * @param {number} defaultHeight
- * Default height in percents.
- *
- * @return {Array}
- * An array of calculated positions in percentages.
- * Format: `{top: Number, height: Number}`
- */
- getYAxisPositions: function (yAxes, plotHeight, defaultHeight) {
- var positions, allAxesHeight = 0;
- /** @private */
- function isPercentage(prop) {
- return defined(prop) && !isNumber(prop) && prop.match('%');
- }
- positions = yAxes.map(function (yAxis) {
- var height = isPercentage(yAxis.options.height) ?
- parseFloat(yAxis.options.height) / 100 :
- yAxis.height / plotHeight, top = isPercentage(yAxis.options.top) ?
- parseFloat(yAxis.options.top) / 100 :
- correctFloat(yAxis.top - yAxis.chart.plotTop) / plotHeight;
- // New yAxis does not contain "height" info yet
- if (!isNumber(height)) {
- height = defaultHeight / 100;
- }
- allAxesHeight = correctFloat(allAxesHeight + height);
- return {
- height: height * 100,
- top: top * 100
- };
- });
- positions.allAxesHeight = allAxesHeight;
- return positions;
- },
- /**
- * Get current resize options for each yAxis. Note that each resize is
- * linked to the next axis, except the last one which shouldn't affect
- * axes in the navigator. Because indicator can be removed with it's yAxis
- * in the middle of yAxis array, we need to bind closest yAxes back.
- *
- * @private
- * @function Highcharts.NavigationBindings#getYAxisResizers
- *
- * @param {Array<Highcharts.Axis>} yAxes
- * Array of yAxes available in the chart
- *
- * @return {Array<object>}
- * An array of resizer options.
- * Format: `{enabled: Boolean, controlledAxis: { next: [String]}}`
- */
- getYAxisResizers: function (yAxes) {
- var resizers = [];
- yAxes.forEach(function (yAxis, index) {
- var nextYAxis = yAxes[index + 1];
- // We have next axis, bind them:
- if (nextYAxis) {
- resizers[index] = {
- enabled: true,
- controlledAxis: {
- next: [
- pick(nextYAxis.options.id, nextYAxis.options.index)
- ]
- }
- };
- }
- else {
- // Remove binding:
- resizers[index] = {
- enabled: false
- };
- }
- });
- return resizers;
- },
- /**
- * Resize all yAxes (except navigator) to fit the plotting height. Method
- * checks if new axis is added, then shrinks other main axis up to 5 panes.
- * If added is more thatn 5 panes, it rescales all other axes to fit new
- * yAxis.
- *
- * If axis is removed, and we have more than 5 panes, rescales all other
- * axes. If chart has less than 5 panes, first pane receives all extra
- * space.
- *
- * @private
- * @function Highcharts.NavigationBindings#resizeYAxes
- * @param {number} defaultHeight
- * Default height for yAxis
- * @return {void}
- */
- resizeYAxes: function (defaultHeight) {
- defaultHeight = defaultHeight || 20; // in %, but as a number
- var chart = this.chart,
- // Only non-navigator axes
- yAxes = chart.yAxis.filter(this.utils.isNotNavigatorYAxis), plotHeight = chart.plotHeight, allAxesLength = yAxes.length,
- // Gather current heights (in %)
- positions = this.getYAxisPositions(yAxes, plotHeight, defaultHeight), resizers = this.getYAxisResizers(yAxes), allAxesHeight = positions.allAxesHeight, changedSpace = defaultHeight;
- // More than 100%
- if (allAxesHeight > 1) {
- // Simple case, add new panes up to 5
- if (allAxesLength < 6) {
- // Added axis, decrease first pane's height:
- positions[0].height = correctFloat(positions[0].height - changedSpace);
- // And update all other "top" positions:
- positions = this.recalculateYAxisPositions(positions, changedSpace);
- }
- else {
- // We have more panes, rescale all others to gain some space,
- // This is new height for upcoming yAxis:
- defaultHeight = 100 / allAxesLength;
- // This is how much we need to take from each other yAxis:
- changedSpace = defaultHeight / (allAxesLength - 1);
- // Now update all positions:
- positions = this.recalculateYAxisPositions(positions, changedSpace, true, -1);
- }
- // Set last position manually:
- positions[allAxesLength - 1] = {
- top: correctFloat(100 - defaultHeight),
- height: defaultHeight
- };
- }
- else {
- // Less than 100%
- changedSpace = correctFloat(1 - allAxesHeight) * 100;
- // Simple case, return first pane it's space:
- if (allAxesLength < 5) {
- positions[0].height = correctFloat(positions[0].height + changedSpace);
- positions = this.recalculateYAxisPositions(positions, changedSpace);
- }
- else {
- // There were more panes, return to each pane a bit of space:
- changedSpace /= allAxesLength;
- // Removed axis, add extra space to the first pane:
- // And update all other positions:
- positions = this.recalculateYAxisPositions(positions, changedSpace, true, 1);
- }
- }
- positions.forEach(function (position, index) {
- // if (index === 0) debugger;
- yAxes[index].update({
- height: position.height + '%',
- top: position.top + '%',
- resize: resizers[index]
- }, false);
- });
- },
- /**
- * Utility to modify calculated positions according to the remaining/needed
- * space. Later, these positions are used in `yAxis.update({ top, height })`
- *
- * @private
- * @function Highcharts.NavigationBindings#recalculateYAxisPositions
- * @param {Array<Highcharts.Dictionary<number>>} positions
- * Default positions of all yAxes.
- * @param {number} changedSpace
- * How much space should be added or removed.
- * @param {boolean} modifyHeight
- * Update only `top` or both `top` and `height`.
- * @param {number} adder
- * `-1` or `1`, to determine whether we should add or remove space.
- *
- * @return {Array<object>}
- * Modified positions,
- */
- recalculateYAxisPositions: function (positions, changedSpace, modifyHeight, adder) {
- positions.forEach(function (position, index) {
- var prevPosition = positions[index - 1];
- position.top = !prevPosition ? 0 :
- correctFloat(prevPosition.height + prevPosition.top);
- if (modifyHeight) {
- position.height = correctFloat(position.height + adder * changedSpace);
- }
- });
- return positions;
- }
- /* eslint-enable valid-jsdoc */
- });
- /**
- * @type {Highcharts.Dictionary<Highcharts.StockToolsBindingsObject>|*}
- * @since 7.0.0
- * @optionparent navigation.bindings
- */
- var stockToolsBindings = {
- // Line type annotations:
- /**
- * A segment annotation bindings. Includes `start` and one event in `steps`
- * array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-segment", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- segment: {
- /** @ignore*/
- className: 'highcharts-segment',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'segment',
- type: 'crookedLine',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.segment.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A segment with an arrow annotation bindings. Includes `start` and one
- * event in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-arrow-segment", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- arrowSegment: {
- /** @ignore*/
- className: 'highcharts-arrow-segment',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'arrowSegment',
- type: 'crookedLine',
- typeOptions: {
- line: {
- markerEnd: 'arrow'
- },
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.arrowSegment.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A ray annotation bindings. Includes `start` and one event in `steps`
- * array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-ray", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- ray: {
- /** @ignore*/
- className: 'highcharts-ray',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'ray',
- type: 'crookedLine',
- typeOptions: {
- type: 'ray',
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.ray.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A ray with an arrow annotation bindings. Includes `start` and one event
- * in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-arrow-ray", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- arrowRay: {
- /** @ignore*/
- className: 'highcharts-arrow-ray',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'arrowRay',
- type: 'infinityLine',
- typeOptions: {
- type: 'ray',
- line: {
- markerEnd: 'arrow'
- },
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.arrowRay.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A line annotation. Includes `start` and one event in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-infinity-line", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- infinityLine: {
- /** @ignore*/
- className: 'highcharts-infinity-line',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'infinityLine',
- type: 'infinityLine',
- typeOptions: {
- type: 'line',
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.infinityLine.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A line with arrow annotation. Includes `start` and one event in `steps`
- * array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-arrow-infinity-line", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- arrowInfinityLine: {
- /** @ignore*/
- className: 'highcharts-arrow-infinity-line',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'arrowInfinityLine',
- type: 'infinityLine',
- typeOptions: {
- type: 'line',
- line: {
- markerEnd: 'arrow'
- },
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.arrowInfinityLine.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1)
- ]
- },
- /**
- * A horizontal line annotation. Includes `start` event.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-horizontal-line", "start": function() {}, "annotationsOptions": {}}
- */
- horizontalLine: {
- /** @ignore*/
- className: 'highcharts-horizontal-line',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'horizontalLine',
- type: 'infinityLine',
- draggable: 'y',
- typeOptions: {
- type: 'horizontalLine',
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.horizontalLine.annotationsOptions);
- this.chart.addAnnotation(options);
- }
- },
- /**
- * A vertical line annotation. Includes `start` event.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-vertical-line", "start": function() {}, "annotationsOptions": {}}
- */
- verticalLine: {
- /** @ignore*/
- className: 'highcharts-vertical-line',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'verticalLine',
- type: 'infinityLine',
- draggable: 'x',
- typeOptions: {
- type: 'verticalLine',
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.verticalLine.annotationsOptions);
- this.chart.addAnnotation(options);
- }
- },
- /**
- * Crooked line (three points) annotation bindings. Includes `start` and two
- * events in `steps` (for second and third points in crooked line) array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-crooked3", "start": function() {}, "steps": [function() {}, function() {}], "annotationsOptions": {}}
- */
- // Crooked Line type annotations:
- crooked3: {
- /** @ignore*/
- className: 'highcharts-crooked3',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'crooked3',
- type: 'crookedLine',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.crooked3.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateNthPoint(2)
- ]
- },
- /**
- * Crooked line (five points) annotation bindings. Includes `start` and four
- * events in `steps` (for all consequent points in crooked line) array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-crooked3", "start": function() {}, "steps": [function() {}, function() {}, function() {}, function() {}], "annotationsOptions": {}}
- */
- crooked5: {
- /** @ignore*/
- className: 'highcharts-crooked5',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'crookedLine',
- type: 'crookedLine',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.crooked5.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateNthPoint(2),
- bindingsUtils.updateNthPoint(3),
- bindingsUtils.updateNthPoint(4)
- ]
- },
- /**
- * Elliott wave (three points) annotation bindings. Includes `start` and two
- * events in `steps` (for second and third points) array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-elliott3", "start": function() {}, "steps": [function() {}, function() {}], "annotationsOptions": {}}
- */
- elliott3: {
- /** @ignore*/
- className: 'highcharts-elliott3',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'elliott3',
- type: 'elliottWave',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.elliott3.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateNthPoint(2),
- bindingsUtils.updateNthPoint(3)
- ]
- },
- /**
- * Elliott wave (five points) annotation bindings. Includes `start` and four
- * event in `steps` (for all consequent points in Elliott wave) array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-elliott3", "start": function() {}, "steps": [function() {}, function() {}, function() {}, function() {}], "annotationsOptions": {}}
- */
- elliott5: {
- /** @ignore*/
- className: 'highcharts-elliott5',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'elliott5',
- type: 'elliottWave',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.elliott5.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateNthPoint(2),
- bindingsUtils.updateNthPoint(3),
- bindingsUtils.updateNthPoint(4),
- bindingsUtils.updateNthPoint(5)
- ]
- },
- /**
- * A measure (x-dimension) annotation bindings. Includes `start` and one
- * event in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-measure-x", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- measureX: {
- /** @ignore*/
- className: 'highcharts-measure-x',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'measure',
- type: 'measure',
- typeOptions: {
- selectType: 'x',
- point: {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value,
- xAxis: 0,
- yAxis: 0
- },
- crosshairX: {
- strokeWidth: 1,
- stroke: '#000000'
- },
- crosshairY: {
- enabled: false,
- strokeWidth: 0,
- stroke: '#000000'
- },
- background: {
- width: 0,
- height: 0,
- strokeWidth: 0,
- stroke: '#ffffff'
- }
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.measureX.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateRectSize
- ]
- },
- /**
- * A measure (y-dimension) annotation bindings. Includes `start` and one
- * event in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-measure-y", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- measureY: {
- /** @ignore*/
- className: 'highcharts-measure-y',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'measure',
- type: 'measure',
- typeOptions: {
- selectType: 'y',
- point: {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value,
- xAxis: 0,
- yAxis: 0
- },
- crosshairX: {
- enabled: false,
- strokeWidth: 0,
- stroke: '#000000'
- },
- crosshairY: {
- strokeWidth: 1,
- stroke: '#000000'
- },
- background: {
- width: 0,
- height: 0,
- strokeWidth: 0,
- stroke: '#ffffff'
- }
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.measureY.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateRectSize
- ]
- },
- /**
- * A measure (xy-dimension) annotation bindings. Includes `start` and one
- * event in `steps` array.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-measure-xy", "start": function() {}, "steps": [function() {}], "annotationsOptions": {}}
- */
- measureXY: {
- /** @ignore*/
- className: 'highcharts-measure-xy',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'measure',
- type: 'measure',
- typeOptions: {
- selectType: 'xy',
- point: {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value,
- xAxis: 0,
- yAxis: 0
- },
- background: {
- width: 0,
- height: 0,
- strokeWidth: 10
- },
- crosshairX: {
- strokeWidth: 1,
- stroke: '#000000'
- },
- crosshairY: {
- strokeWidth: 1,
- stroke: '#000000'
- }
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.measureXY.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateRectSize
- ]
- },
- // Advanced type annotations:
- /**
- * A fibonacci annotation bindings. Includes `start` and two events in
- * `steps` array (updates second point, then height).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-fibonacci", "start": function() {}, "steps": [function() {}, function() {}], "annotationsOptions": {}}
- */
- fibonacci: {
- /** @ignore*/
- className: 'highcharts-fibonacci',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'fibonacci',
- type: 'fibonacci',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- },
- labelOptions: {
- style: {
- color: '#666666'
- }
- }
- }, navigation.annotationsOptions, navigation.bindings.fibonacci.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateHeight
- ]
- },
- /**
- * A parallel channel (tunnel) annotation bindings. Includes `start` and
- * two events in `steps` array (updates second point, then height).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-parallel-channel", "start": function() {}, "steps": [function() {}, function() {}], "annotationsOptions": {}}
- */
- parallelChannel: {
- /** @ignore*/
- className: 'highcharts-parallel-channel',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'parallelChannel',
- type: 'tunnel',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }]
- }
- }, navigation.annotationsOptions, navigation.bindings.parallelChannel.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateHeight
- ]
- },
- /**
- * An Andrew's pitchfork annotation bindings. Includes `start` and two
- * events in `steps` array (sets second and third control points).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-pitchfork", "start": function() {}, "steps": [function() {}, function() {}], "annotationsOptions": {}}
- */
- pitchfork: {
- /** @ignore*/
- className: 'highcharts-pitchfork',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var coords = this.chart.pointer.getCoordinates(e), navigation = this.chart.options.navigation, options = merge({
- langKey: 'pitchfork',
- type: 'pitchfork',
- typeOptions: {
- points: [{
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value,
- controlPoint: {
- style: {
- fill: 'red'
- }
- }
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }, {
- x: coords.xAxis[0].value,
- y: coords.yAxis[0].value
- }],
- innerBackground: {
- fill: 'rgba(100, 170, 255, 0.8)'
- }
- },
- shapeOptions: {
- strokeWidth: 2
- }
- }, navigation.annotationsOptions, navigation.bindings.pitchfork.annotationsOptions);
- return this.chart.addAnnotation(options);
- },
- /** @ignore*/
- steps: [
- bindingsUtils.updateNthPoint(1),
- bindingsUtils.updateNthPoint(2)
- ]
- },
- // Labels with arrow and auto increments
- /**
- * A vertical counter annotation bindings. Includes `start` event. On click,
- * finds the closest point and marks it with a numeric annotation -
- * incrementing counter on each add.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-vertical-counter", "start": function() {}, "annotationsOptions": {}}
- */
- verticalCounter: {
- /** @ignore*/
- className: 'highcharts-vertical-counter',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var closestPoint = bindingsUtils.attractToPoint(e, this.chart), navigation = this.chart.options.navigation, verticalCounter = !defined(this.verticalCounter) ? 0 :
- this.verticalCounter, options = merge({
- langKey: 'verticalCounter',
- type: 'verticalLine',
- typeOptions: {
- point: {
- x: closestPoint.x,
- y: closestPoint.y,
- xAxis: closestPoint.xAxis,
- yAxis: closestPoint.yAxis
- },
- label: {
- offset: closestPoint.below ? 40 : -40,
- text: verticalCounter.toString()
- }
- },
- labelOptions: {
- style: {
- color: '#666666',
- fontSize: '11px'
- }
- },
- shapeOptions: {
- stroke: 'rgba(0, 0, 0, 0.75)',
- strokeWidth: 1
- }
- }, navigation.annotationsOptions, navigation.bindings.verticalCounter.annotationsOptions), annotation;
- annotation = this.chart.addAnnotation(options);
- verticalCounter++;
- annotation.options.events.click.call(annotation, {});
- }
- },
- /**
- * A vertical arrow annotation bindings. Includes `start` event. On click,
- * finds the closest point and marks it with an arrow and a label with
- * value.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-vertical-label", "start": function() {}, "annotationsOptions": {}}
- */
- verticalLabel: {
- /** @ignore*/
- className: 'highcharts-vertical-label',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var closestPoint = bindingsUtils.attractToPoint(e, this.chart), navigation = this.chart.options.navigation, options = merge({
- langKey: 'verticalLabel',
- type: 'verticalLine',
- typeOptions: {
- point: {
- x: closestPoint.x,
- y: closestPoint.y,
- xAxis: closestPoint.xAxis,
- yAxis: closestPoint.yAxis
- },
- label: {
- offset: closestPoint.below ? 40 : -40
- }
- },
- labelOptions: {
- style: {
- color: '#666666',
- fontSize: '11px'
- }
- },
- shapeOptions: {
- stroke: 'rgba(0, 0, 0, 0.75)',
- strokeWidth: 1
- }
- }, navigation.annotationsOptions, navigation.bindings.verticalLabel.annotationsOptions), annotation;
- annotation = this.chart.addAnnotation(options);
- annotation.options.events.click.call(annotation, {});
- }
- },
- /**
- * A vertical arrow annotation bindings. Includes `start` event. On click,
- * finds the closest point and marks it with an arrow. Green arrow when
- * pointing from above, red when pointing from below the point.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-vertical-arrow", "start": function() {}, "annotationsOptions": {}}
- */
- verticalArrow: {
- /** @ignore*/
- className: 'highcharts-vertical-arrow',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- start: function (e) {
- var closestPoint = bindingsUtils.attractToPoint(e, this.chart), navigation = this.chart.options.navigation, options = merge({
- langKey: 'verticalArrow',
- type: 'verticalLine',
- typeOptions: {
- point: {
- x: closestPoint.x,
- y: closestPoint.y,
- xAxis: closestPoint.xAxis,
- yAxis: closestPoint.yAxis
- },
- label: {
- offset: closestPoint.below ? 40 : -40,
- format: ' '
- },
- connector: {
- fill: 'none',
- stroke: closestPoint.below ? 'red' : 'green'
- }
- },
- shapeOptions: {
- stroke: 'rgba(0, 0, 0, 0.75)',
- strokeWidth: 1
- }
- }, navigation.annotationsOptions, navigation.bindings.verticalArrow.annotationsOptions), annotation;
- annotation = this.chart.addAnnotation(options);
- annotation.options.events.click.call(annotation, {});
- }
- },
- // Flag types:
- /**
- * A flag series bindings. Includes `start` event. On click, finds the
- * closest point and marks it with a flag with `'circlepin'` shape.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-flag-circlepin", "start": function() {}}
- */
- flagCirclepin: {
- /** @ignore*/
- className: 'highcharts-flag-circlepin',
- /** @ignore*/
- start: bindingsUtils
- .addFlagFromForm('circlepin')
- },
- /**
- * A flag series bindings. Includes `start` event. On click, finds the
- * closest point and marks it with a flag with `'diamondpin'` shape.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-flag-diamondpin", "start": function() {}}
- */
- flagDiamondpin: {
- /** @ignore*/
- className: 'highcharts-flag-diamondpin',
- /** @ignore*/
- start: bindingsUtils
- .addFlagFromForm('flag')
- },
- /**
- * A flag series bindings. Includes `start` event.
- * On click, finds the closest point and marks it with a flag with
- * `'squarepin'` shape.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-flag-squarepin", "start": function() {}}
- */
- flagSquarepin: {
- /** @ignore*/
- className: 'highcharts-flag-squarepin',
- /** @ignore*/
- start: bindingsUtils
- .addFlagFromForm('squarepin')
- },
- /**
- * A flag series bindings. Includes `start` event.
- * On click, finds the closest point and marks it with a flag without pin
- * shape.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-flag-simplepin", "start": function() {}}
- */
- flagSimplepin: {
- /** @ignore*/
- className: 'highcharts-flag-simplepin',
- /** @ignore*/
- start: bindingsUtils
- .addFlagFromForm('nopin')
- },
- // Other tools:
- /**
- * Enables zooming in xAxis on a chart. Includes `start` event which
- * changes [chart.zoomType](#chart.zoomType).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-zoom-x", "init": function() {}}
- */
- zoomX: {
- /** @ignore*/
- className: 'highcharts-zoom-x',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.update({
- chart: {
- zoomType: 'x'
- }
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Enables zooming in yAxis on a chart. Includes `start` event which
- * changes [chart.zoomType](#chart.zoomType).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-zoom-y", "init": function() {}}
- */
- zoomY: {
- /** @ignore*/
- className: 'highcharts-zoom-y',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.update({
- chart: {
- zoomType: 'y'
- }
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Enables zooming in xAxis and yAxis on a chart. Includes `start` event
- * which changes [chart.zoomType](#chart.zoomType).
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-zoom-xy", "init": function() {}}
- */
- zoomXY: {
- /** @ignore*/
- className: 'highcharts-zoom-xy',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.update({
- chart: {
- zoomType: 'xy'
- }
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Changes main series to `'line'` type.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-series-type-line", "init": function() {}}
- */
- seriesTypeLine: {
- /** @ignore*/
- className: 'highcharts-series-type-line',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.series[0].update({
- type: 'line',
- useOhlcData: true
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Changes main series to `'ohlc'` type.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-series-type-ohlc", "init": function() {}}
- */
- seriesTypeOhlc: {
- /** @ignore*/
- className: 'highcharts-series-type-ohlc',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.series[0].update({
- type: 'ohlc'
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Changes main series to `'candlestick'` type.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-series-type-candlestick", "init": function() {}}
- */
- seriesTypeCandlestick: {
- /** @ignore*/
- className: 'highcharts-series-type-candlestick',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- this.chart.series[0].update({
- type: 'candlestick'
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Displays chart in fullscreen.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-full-screen", "init": function() {}}
- */
- fullScreen: {
- /** @ignore*/
- className: 'highcharts-full-screen',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- var chart = this.chart;
- chart.fullScreen = new H.FullScreen(chart.container);
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Hides/shows two price indicators:
- * - last price in the dataset
- * - last price in the selected range
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-current-price-indicator", "init": function() {}}
- */
- currentPriceIndicator: {
- /** @ignore*/
- className: 'highcharts-current-price-indicator',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- var chart = this.chart, series = chart.series[0], options = series.options, lastVisiblePrice = options.lastVisiblePrice &&
- options.lastVisiblePrice.enabled, lastPrice = options.lastPrice && options.lastPrice.enabled, gui = chart.stockTools, iconsURL = gui.getIconsURL();
- if (gui && gui.guiEnabled) {
- if (lastPrice) {
- button.firstChild.style['background-image'] =
- 'url("' + iconsURL +
- 'current-price-show.svg")';
- }
- else {
- button.firstChild.style['background-image'] =
- 'url("' + iconsURL +
- 'current-price-hide.svg")';
- }
- }
- series.update({
- // line
- lastPrice: {
- enabled: !lastPrice,
- color: 'red'
- },
- // label
- lastVisiblePrice: {
- enabled: !lastVisiblePrice,
- label: {
- enabled: true
- }
- }
- });
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Indicators bindings. Includes `init` event to show a popup.
- *
- * Note: In order to show base series from the chart in the popup's
- * dropdown each series requires
- * [series.id](https://api.highcharts.com/highstock/series.line.id) to be
- * defined.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-indicators", "init": function() {}}
- */
- indicators: {
- /** @ignore*/
- className: 'highcharts-indicators',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function () {
- var navigation = this;
- fireEvent(navigation, 'showPopup', {
- formType: 'indicators',
- options: {},
- // Callback on submit:
- onSubmit: function (data) {
- navigation.utils.manageIndicators.call(navigation, data);
- }
- });
- }
- },
- /**
- * Hides/shows all annotations on a chart.
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-toggle-annotations", "init": function() {}}
- */
- toggleAnnotations: {
- /** @ignore*/
- className: 'highcharts-toggle-annotations',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- var chart = this.chart, gui = chart.stockTools, iconsURL = gui.getIconsURL();
- this.toggledAnnotations = !this.toggledAnnotations;
- (chart.annotations || []).forEach(function (annotation) {
- annotation.setVisibility(!this.toggledAnnotations);
- }, this);
- if (gui && gui.guiEnabled) {
- if (this.toggledAnnotations) {
- button.firstChild.style['background-image'] =
- 'url("' + iconsURL +
- 'annotations-hidden.svg")';
- }
- else {
- button.firstChild.style['background-image'] =
- 'url("' + iconsURL +
- 'annotations-visible.svg")';
- }
- }
- fireEvent(this, 'deselectButton', { button: button });
- }
- },
- /**
- * Save a chart in localStorage under `highcharts-chart` key.
- * Stored items:
- * - annotations
- * - indicators (with yAxes)
- * - flags
- *
- * @type {Highcharts.StockToolsBindingsObject}
- * @product highstock
- * @default {"className": "highcharts-save-chart", "init": function() {}}
- */
- saveChart: {
- /** @ignore*/
- className: 'highcharts-save-chart',
- // eslint-disable-next-line valid-jsdoc
- /** @ignore*/
- init: function (button) {
- var navigation = this, chart = navigation.chart, annotations = [], indicators = [], flags = [], yAxes = [];
- chart.annotations.forEach(function (annotation, index) {
- annotations[index] = annotation.userOptions;
- });
- chart.series.forEach(function (series) {
- if (series instanceof H.seriesTypes.sma) {
- indicators.push(series.userOptions);
- }
- else if (series.type === 'flags') {
- flags.push(series.userOptions);
- }
- });
- chart.yAxis.forEach(function (yAxis) {
- if (navigation.utils.isNotNavigatorYAxis(yAxis)) {
- yAxes.push(yAxis.options);
- }
- });
- H.win.localStorage.setItem(PREFIX + 'chart', JSON.stringify({
- annotations: annotations,
- indicators: indicators,
- flags: flags,
- yAxes: yAxes
- }));
- fireEvent(this, 'deselectButton', { button: button });
- }
- }
- };
- H.setOptions({
- navigation: {
- bindings: stockToolsBindings
- }
- });
- });
- _registerModule(_modules, 'modules/stock-tools-gui.js', [_modules['parts/Globals.js'], _modules['parts/Utilities.js']], function (H, U) {
- /* *
- *
- * GUI generator for Stock tools
- *
- * (c) 2009-2017 Sebastian Bochan
- *
- * License: www.highcharts.com/license
- *
- * !!!!!!! SOURCE GETS TRANSPILED BY TYPESCRIPT. EDIT TS FILE ONLY. !!!!!!!
- *
- * */
- var extend = U.extend, isArray = U.isArray, pick = U.pick;
- var addEvent = H.addEvent, createElement = H.createElement, fireEvent = H.fireEvent, getStyle = H.getStyle, merge = H.merge, css = H.css, win = H.win, DIV = 'div', SPAN = 'span', UL = 'ul', LI = 'li', PREFIX = 'highcharts-', activeClass = PREFIX + 'active';
- H.setOptions({
- /**
- * @optionparent lang
- */
- lang: {
- /**
- * Configure the stockTools GUI titles(hints) in the chart. Requires
- * the `stock-tools.js` module to be loaded.
- *
- * @product highstock
- * @since 7.0.0
- */
- stockTools: {
- gui: {
- // Main buttons:
- simpleShapes: 'Simple shapes',
- lines: 'Lines',
- crookedLines: 'Crooked lines',
- measure: 'Measure',
- advanced: 'Advanced',
- toggleAnnotations: 'Toggle annotations',
- verticalLabels: 'Vertical labels',
- flags: 'Flags',
- zoomChange: 'Zoom change',
- typeChange: 'Type change',
- saveChart: 'Save chart',
- indicators: 'Indicators',
- currentPriceIndicator: 'Current Price Indicators',
- // Other features:
- zoomX: 'Zoom X',
- zoomY: 'Zoom Y',
- zoomXY: 'Zooom XY',
- fullScreen: 'Fullscreen',
- typeOHLC: 'OHLC',
- typeLine: 'Line',
- typeCandlestick: 'Candlestick',
- // Basic shapes:
- circle: 'Circle',
- label: 'Label',
- rectangle: 'Rectangle',
- // Flags:
- flagCirclepin: 'Flag circle',
- flagDiamondpin: 'Flag diamond',
- flagSquarepin: 'Flag square',
- flagSimplepin: 'Flag simple',
- // Measures:
- measureXY: 'Measure XY',
- measureX: 'Measure X',
- measureY: 'Measure Y',
- // Segment, ray and line:
- segment: 'Segment',
- arrowSegment: 'Arrow segment',
- ray: 'Ray',
- arrowRay: 'Arrow ray',
- line: 'Line',
- arrowLine: 'Arrow line',
- horizontalLine: 'Horizontal line',
- verticalLine: 'Vertical line',
- infinityLine: 'Infinity line',
- // Crooked lines:
- crooked3: 'Crooked 3 line',
- crooked5: 'Crooked 5 line',
- elliott3: 'Elliott 3 line',
- elliott5: 'Elliott 5 line',
- // Counters:
- verticalCounter: 'Vertical counter',
- verticalLabel: 'Vertical label',
- verticalArrow: 'Vertical arrow',
- // Advanced:
- fibonacci: 'Fibonacci',
- pitchfork: 'Pitchfork',
- parallelChannel: 'Parallel channel'
- }
- },
- navigation: {
- popup: {
- // Annotations:
- circle: 'Circle',
- rectangle: 'Rectangle',
- label: 'Label',
- segment: 'Segment',
- arrowSegment: 'Arrow segment',
- ray: 'Ray',
- arrowRay: 'Arrow ray',
- line: 'Line',
- arrowLine: 'Arrow line',
- horizontalLine: 'Horizontal line',
- verticalLine: 'Vertical line',
- crooked3: 'Crooked 3 line',
- crooked5: 'Crooked 5 line',
- elliott3: 'Elliott 3 line',
- elliott5: 'Elliott 5 line',
- verticalCounter: 'Vertical counter',
- verticalLabel: 'Vertical label',
- verticalArrow: 'Vertical arrow',
- fibonacci: 'Fibonacci',
- pitchfork: 'Pitchfork',
- parallelChannel: 'Parallel channel',
- infinityLine: 'Infinity line',
- measure: 'Measure',
- measureXY: 'Measure XY',
- measureX: 'Measure X',
- measureY: 'Measure Y',
- // Flags:
- flags: 'Flags',
- // GUI elements:
- addButton: 'add',
- saveButton: 'save',
- editButton: 'edit',
- removeButton: 'remove',
- series: 'Series',
- volume: 'Volume',
- connector: 'Connector',
- // Field names:
- innerBackground: 'Inner background',
- outerBackground: 'Outer background',
- crosshairX: 'Crosshair X',
- crosshairY: 'Crosshair Y',
- tunnel: 'Tunnel',
- background: 'Background'
- }
- }
- },
- /**
- * Configure the stockTools gui strings in the chart. Requires the
- * [stockTools module]() to be loaded. For a description of the module
- * and information on its features, see [Highcharts StockTools]().
- *
- * @product highstock
- *
- * @sample stock/demo/stock-tools-gui Stock Tools GUI
- *
- * @sample stock/demo/stock-tools-custom-gui Stock Tools customized GUI
- *
- * @since 7.0.0
- * @optionparent stockTools
- */
- stockTools: {
- /**
- * Definitions of buttons in Stock Tools GUI.
- */
- gui: {
- /**
- * Path where Highcharts will look for icons. Change this to use
- * icons from a different server.
- *
- * Since 7.1.3 use [iconsURL](#navigation.iconsURL) for popup and
- * stock tools.
- *
- * @deprecated
- * @apioption stockTools.gui.iconsURL
- *
- */
- /**
- * Enable or disable the stockTools gui.
- */
- enabled: true,
- /**
- * A CSS class name to apply to the stocktools' div,
- * allowing unique CSS styling for each chart.
- */
- className: 'highcharts-bindings-wrapper',
- /**
- * A CSS class name to apply to the container of buttons,
- * allowing unique CSS styling for each chart.
- */
- toolbarClassName: 'stocktools-toolbar',
- /**
- * A collection of strings pointing to config options for the
- * toolbar items. Each name refers to unique key from definitions
- * object.
- *
- * @default [
- * 'indicators',
- * 'separator',
- * 'simpleShapes',
- * 'lines',
- * 'crookedLines',
- * 'measure',
- * 'advanced',
- * 'toggleAnnotations',
- * 'separator',
- * 'verticalLabels',
- * 'flags',
- * 'separator',
- * 'zoomChange',
- * 'fullScreen',
- * 'typeChange',
- * 'separator',
- * 'currentPriceIndicator',
- * 'saveChart'
- * ]
- */
- buttons: [
- 'indicators',
- 'separator',
- 'simpleShapes',
- 'lines',
- 'crookedLines',
- 'measure',
- 'advanced',
- 'toggleAnnotations',
- 'separator',
- 'verticalLabels',
- 'flags',
- 'separator',
- 'zoomChange',
- 'fullScreen',
- 'typeChange',
- 'separator',
- 'currentPriceIndicator',
- 'saveChart'
- ],
- /**
- * An options object of the buttons definitions. Each name refers to
- * unique key from buttons array.
- */
- definitions: {
- separator: {
- /**
- * A predefined background symbol for the button.
- */
- symbol: 'separator.svg'
- },
- simpleShapes: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'label',
- * 'circle',
- * 'rectangle'
- * ]
- *
- */
- items: [
- 'label',
- 'circle',
- 'rectangle'
- ],
- circle: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- *
- */
- symbol: 'circle.svg'
- },
- rectangle: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- *
- */
- symbol: 'rectangle.svg'
- },
- label: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- *
- */
- symbol: 'label.svg'
- }
- },
- flags: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'flagCirclepin',
- * 'flagDiamondpin',
- * 'flagSquarepin',
- * 'flagSimplepin'
- * ]
- *
- */
- items: [
- 'flagCirclepin',
- 'flagDiamondpin',
- 'flagSquarepin',
- 'flagSimplepin'
- ],
- flagSimplepin: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- *
- */
- symbol: 'flag-basic.svg'
- },
- flagDiamondpin: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- *
- */
- symbol: 'flag-diamond.svg'
- },
- flagSquarepin: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'flag-trapeze.svg'
- },
- flagCirclepin: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'flag-elipse.svg'
- }
- },
- lines: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'segment',
- * 'arrowSegment',
- * 'ray',
- * 'arrowRay',
- * 'line',
- * 'arrowLine',
- * 'horizontalLine',
- * 'verticalLine'
- * ]
- */
- items: [
- 'segment',
- 'arrowSegment',
- 'ray',
- 'arrowRay',
- 'line',
- 'arrowLine',
- 'horizontalLine',
- 'verticalLine'
- ],
- segment: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'segment.svg'
- },
- arrowSegment: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'arrow-segment.svg'
- },
- ray: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'ray.svg'
- },
- arrowRay: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'arrow-ray.svg'
- },
- line: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'line.svg'
- },
- arrowLine: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'arrow-line.svg'
- },
- verticalLine: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'vertical-line.svg'
- },
- horizontalLine: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'horizontal-line.svg'
- }
- },
- crookedLines: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'elliott3',
- * 'elliott5',
- * 'crooked3',
- * 'crooked5'
- * ]
- *
- */
- items: [
- 'elliott3',
- 'elliott5',
- 'crooked3',
- 'crooked5'
- ],
- crooked3: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'crooked-3.svg'
- },
- crooked5: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'crooked-5.svg'
- },
- elliott3: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'elliott-3.svg'
- },
- elliott5: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'elliott-5.svg'
- }
- },
- verticalLabels: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'verticalCounter',
- * 'verticalLabel',
- * 'verticalArrow'
- * ]
- */
- items: [
- 'verticalCounter',
- 'verticalLabel',
- 'verticalArrow'
- ],
- verticalCounter: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'vertical-counter.svg'
- },
- verticalLabel: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'vertical-label.svg'
- },
- verticalArrow: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'vertical-arrow.svg'
- }
- },
- advanced: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'fibonacci',
- * 'pitchfork',
- * 'parallelChannel'
- * ]
- */
- items: [
- 'fibonacci',
- 'pitchfork',
- 'parallelChannel'
- ],
- pitchfork: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'pitchfork.svg'
- },
- fibonacci: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'fibonacci.svg'
- },
- parallelChannel: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'parallel-channel.svg'
- }
- },
- measure: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'measureXY',
- * 'measureX',
- * 'measureY'
- * ]
- */
- items: [
- 'measureXY',
- 'measureX',
- 'measureY'
- ],
- measureX: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'measure-x.svg'
- },
- measureY: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'measure-y.svg'
- },
- measureXY: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'measure-xy.svg'
- }
- },
- toggleAnnotations: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'annotations-visible.svg'
- },
- currentPriceIndicator: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'current-price-show.svg'
- },
- indicators: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'indicators.svg'
- },
- zoomChange: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'zoomX',
- * 'zoomY',
- * 'zoomXY'
- * ]
- */
- items: [
- 'zoomX',
- 'zoomY',
- 'zoomXY'
- ],
- zoomX: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'zoom-x.svg'
- },
- zoomY: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'zoom-y.svg'
- },
- zoomXY: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'zoom-xy.svg'
- }
- },
- typeChange: {
- /**
- * A collection of strings pointing to config options for
- * the items.
- *
- * @type {array}
- * @default [
- * 'typeOHLC',
- * 'typeLine',
- * 'typeCandlestick'
- * ]
- */
- items: [
- 'typeOHLC',
- 'typeLine',
- 'typeCandlestick'
- ],
- typeOHLC: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'series-ohlc.svg'
- },
- typeLine: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'series-line.svg'
- },
- typeCandlestick: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'series-candlestick.svg'
- }
- },
- fullScreen: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'fullscreen.svg'
- },
- saveChart: {
- /**
- * A predefined background symbol for the button.
- *
- * @type {string}
- */
- symbol: 'save-chart.svg'
- }
- }
- }
- }
- });
- /* eslint-disable no-invalid-this, valid-jsdoc */
- // Run HTML generator
- addEvent(H.Chart, 'afterGetContainer', function () {
- this.setStockTools();
- });
- addEvent(H.Chart, 'getMargins', function () {
- var listWrapper = this.stockTools && this.stockTools.listWrapper, offsetWidth = listWrapper && ((listWrapper.startWidth +
- H.getStyle(listWrapper, 'padding-left') +
- H.getStyle(listWrapper, 'padding-right')) || listWrapper.offsetWidth);
- if (offsetWidth && offsetWidth < this.plotWidth) {
- this.plotLeft += offsetWidth;
- }
- });
- addEvent(H.Chart, 'destroy', function () {
- if (this.stockTools) {
- this.stockTools.destroy();
- }
- });
- addEvent(H.Chart, 'redraw', function () {
- if (this.stockTools && this.stockTools.guiEnabled) {
- this.stockTools.redraw();
- }
- });
- /**
- * Toolbar Class
- * @private
- * @constructor
- * @param {Object} - options of toolbar
- * @param {Chart} - Reference to chart
- */
- H.Toolbar = function (options, langOptions, chart) {
- this.chart = chart;
- this.options = options;
- this.lang = langOptions;
- // set url for icons.
- this.iconsURL = this.getIconsURL();
- this.guiEnabled = options.enabled;
- this.visible = pick(options.visible, true);
- this.placed = pick(options.placed, false);
- // General events collection which should be removed upon destroy/update:
- this.eventsToUnbind = [];
- if (this.guiEnabled) {
- this.createHTML();
- this.init();
- this.showHideNavigatorion();
- }
- fireEvent(this, 'afterInit');
- };
- extend(H.Chart.prototype, {
- /**
- * Verify if Toolbar should be added.
- * @private
- * @param {Highcharts.StockToolsOptions} - chart options
- * @return {void}
- */
- setStockTools: function (options) {
- var chartOptions = this.options, lang = chartOptions.lang, guiOptions = merge(chartOptions.stockTools && chartOptions.stockTools.gui, options && options.gui), langOptions = lang.stockTools && lang.stockTools.gui;
- this.stockTools = new H.Toolbar(guiOptions, langOptions, this);
- if (this.stockTools.guiEnabled) {
- this.isDirtyBox = true;
- }
- }
- });
- H.Toolbar.prototype = {
- /**
- * Initialize the toolbar. Create buttons and submenu for each option
- * defined in `stockTools.gui`.
- * @private
- */
- init: function () {
- var _self = this, lang = this.lang, guiOptions = this.options, toolbar = this.toolbar, addSubmenu = _self.addSubmenu, buttons = guiOptions.buttons, defs = guiOptions.definitions, allButtons = toolbar.childNodes, inIframe = this.inIframe(), button;
- // create buttons
- buttons.forEach(function (btnName) {
- button = _self.addButton(toolbar, defs, btnName, lang);
- if (inIframe && btnName === 'fullScreen') {
- button.buttonWrapper.className +=
- ' ' + PREFIX + 'disabled-btn';
- }
- _self.eventsToUnbind.push(addEvent(button.buttonWrapper, 'click', function () {
- _self.eraseActiveButtons(allButtons, button.buttonWrapper);
- }));
- if (isArray(defs[btnName].items)) {
- // create submenu buttons
- addSubmenu.call(_self, button, defs[btnName]);
- }
- });
- },
- /**
- * Create submenu (list of buttons) for the option. In example main button
- * is Line, in submenu will be buttons with types of lines.
- * @private
- * @param {Highcharts.Dictionary<Highcharts.HTMLDOMElement>}
- * button which has submenu
- * @param {Highcharts.StockToolsGuiDefinitionsButtonsOptions}
- * list of all buttons
- */
- addSubmenu: function (parentBtn, button) {
- var _self = this, submenuArrow = parentBtn.submenuArrow, buttonWrapper = parentBtn.buttonWrapper, buttonWidth = getStyle(buttonWrapper, 'width'), wrapper = this.wrapper, menuWrapper = this.listWrapper, allButtons = this.toolbar.childNodes, topMargin = 0, submenuWrapper;
- // create submenu container
- this.submenu = submenuWrapper = createElement(UL, {
- className: PREFIX + 'submenu-wrapper'
- }, null, buttonWrapper);
- // create submenu buttons and select the first one
- this.addSubmenuItems(buttonWrapper, button);
- // show / hide submenu
- _self.eventsToUnbind.push(addEvent(submenuArrow, 'click', function (e) {
- e.stopPropagation();
- // Erase active class on all other buttons
- _self.eraseActiveButtons(allButtons, buttonWrapper);
- // hide menu
- if (buttonWrapper.className.indexOf(PREFIX + 'current') >= 0) {
- menuWrapper.style.width =
- menuWrapper.startWidth + 'px';
- buttonWrapper.classList.remove(PREFIX + 'current');
- submenuWrapper.style.display = 'none';
- }
- else {
- // show menu
- // to calculate height of element
- submenuWrapper.style.display = 'block';
- topMargin = submenuWrapper.offsetHeight -
- buttonWrapper.offsetHeight - 3;
- // calculate position of submenu in the box
- // if submenu is inside, reset top margin
- if (
- // cut on the bottom
- !(submenuWrapper.offsetHeight +
- buttonWrapper.offsetTop >
- wrapper.offsetHeight &&
- // cut on the top
- buttonWrapper.offsetTop > topMargin)) {
- topMargin = 0;
- }
- // apply calculated styles
- css(submenuWrapper, {
- top: -topMargin + 'px',
- left: buttonWidth + 3 + 'px'
- });
- buttonWrapper.className += ' ' + PREFIX + 'current';
- menuWrapper.startWidth = wrapper.offsetWidth;
- menuWrapper.style.width = menuWrapper.startWidth +
- H.getStyle(menuWrapper, 'padding-left') +
- submenuWrapper.offsetWidth + 3 + 'px';
- }
- }));
- },
- /**
- * Create buttons in submenu
- * @private
- * @param {Highcharts.HTMLDOMElement}
- * button where submenu is placed
- * @param {Highcharts.StockToolsGuiDefinitionsButtonsOptions}
- * list of all buttons options
- *
- */
- addSubmenuItems: function (buttonWrapper, button) {
- var _self = this, submenuWrapper = this.submenu, lang = this.lang, menuWrapper = this.listWrapper, items = button.items, firstSubmenuItem, submenuBtn;
- // add items to submenu
- items.forEach(function (btnName) {
- // add buttons to submenu
- submenuBtn = _self.addButton(submenuWrapper, button, btnName, lang);
- _self.eventsToUnbind.push(addEvent(submenuBtn.mainButton, 'click', function () {
- _self.switchSymbol(this, buttonWrapper, true);
- menuWrapper.style.width =
- menuWrapper.startWidth + 'px';
- submenuWrapper.style.display = 'none';
- }));
- });
- // select first submenu item
- firstSubmenuItem = submenuWrapper
- .querySelectorAll('li > .' + PREFIX + 'menu-item-btn')[0];
- // replace current symbol, in main button, with submenu's button style
- _self.switchSymbol(firstSubmenuItem, false);
- },
- /*
- * Erase active class on all other buttons.
- *
- * @param {Array} - Array of HTML buttons
- * @param {HTMLDOMElement} - Current HTML button
- *
- */
- eraseActiveButtons: function (buttons, currentButton, submenuItems) {
- [].forEach.call(buttons, function (btn) {
- if (btn !== currentButton) {
- btn.classList.remove(PREFIX + 'current');
- btn.classList.remove(PREFIX + 'active');
- submenuItems =
- btn.querySelectorAll('.' + PREFIX + 'submenu-wrapper');
- // hide submenu
- if (submenuItems.length > 0) {
- submenuItems[0].style.display = 'none';
- }
- }
- });
- },
- /**
- * Create single button. Consist of HTML elements `li`, `span`, and (if
- * exists) submenu container.
- * @private
- * @param {HTMLDOMElement} - HTML reference, where button should be added
- * @param {Object} - all options, by btnName refer to particular button
- * @param {String} - name of functionality mapped for specific class
- * @param {Object} - All titles, by btnName refer to particular button
- * @return {Object} - references to all created HTML elements
- */
- addButton: function (target, options, btnName, lang) {
- var btnOptions = options[btnName], items = btnOptions.items, classMapping = H.Toolbar.prototype.classMapping, userClassName = btnOptions.className || '', mainButton, submenuArrow, buttonWrapper;
- // main button wrapper
- buttonWrapper = createElement(LI, {
- className: pick(classMapping[btnName], '') + ' ' + userClassName,
- title: lang[btnName] || btnName
- }, null, target);
- // single button
- mainButton = createElement(SPAN, {
- className: PREFIX + 'menu-item-btn'
- }, null, buttonWrapper);
- // submenu
- if (items && items.length) {
- // arrow is a hook to show / hide submenu
- submenuArrow = createElement(SPAN, {
- className: PREFIX + 'submenu-item-arrow ' +
- PREFIX + 'arrow-right'
- }, null, buttonWrapper);
- submenuArrow.style['background-image'] = 'url(' +
- this.iconsURL + 'arrow-bottom.svg)';
- }
- else {
- mainButton.style['background-image'] = 'url(' +
- this.iconsURL + btnOptions.symbol + ')';
- }
- return {
- buttonWrapper: buttonWrapper,
- mainButton: mainButton,
- submenuArrow: submenuArrow
- };
- },
- /*
- * Create navigation's HTML elements: container and arrows.
- *
- */
- addNavigation: function () {
- var stockToolbar = this, wrapper = stockToolbar.wrapper;
- // arrow wrapper
- stockToolbar.arrowWrapper = createElement(DIV, {
- className: PREFIX + 'arrow-wrapper'
- });
- stockToolbar.arrowUp = createElement(DIV, {
- className: PREFIX + 'arrow-up'
- }, null, stockToolbar.arrowWrapper);
- stockToolbar.arrowUp.style['background-image'] =
- 'url(' + this.iconsURL + 'arrow-right.svg)';
- stockToolbar.arrowDown = createElement(DIV, {
- className: PREFIX + 'arrow-down'
- }, null, stockToolbar.arrowWrapper);
- stockToolbar.arrowDown.style['background-image'] =
- 'url(' + this.iconsURL + 'arrow-right.svg)';
- wrapper.insertBefore(stockToolbar.arrowWrapper, wrapper.childNodes[0]);
- // attach scroll events
- stockToolbar.scrollButtons();
- },
- /*
- * Add events to navigation (two arrows) which allows user to scroll
- * top/down GUI buttons, if container's height is not enough.
- *
- */
- scrollButtons: function () {
- var targetY = 0, _self = this, wrapper = _self.wrapper, toolbar = _self.toolbar, step = 0.1 * wrapper.offsetHeight; // 0.1 = 10%
- _self.eventsToUnbind.push(addEvent(_self.arrowUp, 'click', function () {
- if (targetY > 0) {
- targetY -= step;
- toolbar.style['margin-top'] = -targetY + 'px';
- }
- }));
- _self.eventsToUnbind.push(addEvent(_self.arrowDown, 'click', function () {
- if (wrapper.offsetHeight + targetY <=
- toolbar.offsetHeight + step) {
- targetY += step;
- toolbar.style['margin-top'] = -targetY + 'px';
- }
- }));
- },
- /*
- * Create stockTools HTML main elements.
- *
- */
- createHTML: function () {
- var stockToolbar = this, chart = stockToolbar.chart, guiOptions = stockToolbar.options, container = chart.container, navigation = chart.options.navigation, bindingsClassName = navigation && navigation.bindingsClassName, listWrapper, toolbar, wrapper;
- // create main container
- stockToolbar.wrapper = wrapper = createElement(DIV, {
- className: PREFIX + 'stocktools-wrapper ' +
- guiOptions.className + ' ' + bindingsClassName
- });
- container.parentNode.insertBefore(wrapper, container);
- // toolbar
- stockToolbar.toolbar = toolbar = createElement(UL, {
- className: PREFIX + 'stocktools-toolbar ' +
- guiOptions.toolbarClassName
- });
- // add container for list of buttons
- stockToolbar.listWrapper = listWrapper = createElement(DIV, {
- className: PREFIX + 'menu-wrapper'
- });
- wrapper.insertBefore(listWrapper, wrapper.childNodes[0]);
- listWrapper.insertBefore(toolbar, listWrapper.childNodes[0]);
- stockToolbar.showHideToolbar();
- // add navigation which allows user to scroll down / top GUI buttons
- stockToolbar.addNavigation();
- },
- /**
- * Function called in redraw verifies if the navigation should be visible.
- * @private
- */
- showHideNavigatorion: function () {
- // arrows
- // 50px space for arrows
- if (this.visible &&
- this.toolbar.offsetHeight > (this.wrapper.offsetHeight - 50)) {
- this.arrowWrapper.style.display = 'block';
- }
- else {
- // reset margin if whole toolbar is visible
- this.toolbar.style.marginTop = '0px';
- // hide arrows
- this.arrowWrapper.style.display = 'none';
- }
- },
- /**
- * Create button which shows or hides GUI toolbar.
- * @private
- */
- showHideToolbar: function () {
- var stockToolbar = this, chart = this.chart, wrapper = stockToolbar.wrapper, toolbar = this.listWrapper, submenu = this.submenu, visible = this.visible, showhideBtn;
- // Show hide toolbar
- this.showhideBtn = showhideBtn = createElement(DIV, {
- className: PREFIX + 'toggle-toolbar ' + PREFIX + 'arrow-left'
- }, null, wrapper);
- showhideBtn.style['background-image'] =
- 'url(' + this.iconsURL + 'arrow-right.svg)';
- if (!visible) {
- // hide
- if (submenu) {
- submenu.style.display = 'none';
- }
- showhideBtn.style.left = '0px';
- stockToolbar.visible = visible = false;
- toolbar.classList.add(PREFIX + 'hide');
- showhideBtn.classList.toggle(PREFIX + 'arrow-right');
- wrapper.style.height = showhideBtn.offsetHeight + 'px';
- }
- else {
- wrapper.style.height = '100%';
- showhideBtn.style.top = H.getStyle(toolbar, 'padding-top') + 'px';
- showhideBtn.style.left = (wrapper.offsetWidth +
- H.getStyle(toolbar, 'padding-left')) + 'px';
- }
- // Toggle menu
- stockToolbar.eventsToUnbind.push(addEvent(showhideBtn, 'click', function () {
- chart.update({
- stockTools: {
- gui: {
- visible: !visible,
- placed: true
- }
- }
- });
- }));
- },
- /*
- * In main GUI button, replace icon and class with submenu button's
- * class / symbol.
- *
- * @param {HTMLDOMElement} - submenu button
- * @param {Boolean} - true or false
- *
- */
- switchSymbol: function (button, redraw) {
- var buttonWrapper = button.parentNode, buttonWrapperClass = buttonWrapper.classList.value,
- // main button in first level og GUI
- mainNavButton = buttonWrapper.parentNode.parentNode;
- // set class
- mainNavButton.className = '';
- if (buttonWrapperClass) {
- mainNavButton.classList.add(buttonWrapperClass.trim());
- }
- // set icon
- mainNavButton
- .querySelectorAll('.' + PREFIX + 'menu-item-btn')[0]
- .style['background-image'] =
- button.style['background-image'];
- // set active class
- if (redraw) {
- this.selectButton(mainNavButton);
- }
- },
- /*
- * Set select state (active class) on button.
- *
- * @param {HTMLDOMElement} - button
- *
- */
- selectButton: function (button) {
- if (button.className.indexOf(activeClass) >= 0) {
- button.classList.remove(activeClass);
- }
- else {
- button.classList.add(activeClass);
- }
- },
- /*
- * Remove active class from all buttons except defined.
- *
- * @param {HTMLDOMElement} - button which should not be deactivated
- *
- */
- unselectAllButtons: function (button) {
- var activeButtons = button.parentNode
- .querySelectorAll('.' + activeClass);
- [].forEach.call(activeButtons, function (activeBtn) {
- if (activeBtn !== button) {
- activeBtn.classList.remove(activeClass);
- }
- });
- },
- /*
- * Verify if chart is in iframe.
- *
- * @return {Object} - elements translations.
- */
- inIframe: function () {
- try {
- return win.self !== win.top;
- }
- catch (e) {
- return true;
- }
- },
- /*
- * Update GUI with given options.
- *
- * @param {Object} - general options for Stock Tools
- */
- update: function (options) {
- merge(true, this.chart.options.stockTools, options);
- this.destroy();
- this.chart.setStockTools(options);
- // If Stock Tools are updated, then bindings should be updated too:
- if (this.chart.navigationBindings) {
- this.chart.navigationBindings.update();
- }
- },
- /**
- * Destroy all HTML GUI elements.
- * @private
- */
- destroy: function () {
- var stockToolsDiv = this.wrapper, parent = stockToolsDiv && stockToolsDiv.parentNode;
- this.eventsToUnbind.forEach(function (unbinder) {
- unbinder();
- });
- // Remove the empty element
- if (parent) {
- parent.removeChild(stockToolsDiv);
- }
- // redraw
- this.chart.isDirtyBox = true;
- this.chart.redraw();
- },
- /**
- * Redraw, GUI requires to verify if the navigation should be visible.
- * @private
- */
- redraw: function () {
- this.showHideNavigatorion();
- },
- getIconsURL: function () {
- return this.chart.options.navigation.iconsURL ||
- this.options.iconsURL ||
- 'https://code.highcharts.com/8.0.0/gfx/stock-icons/';
- },
- /**
- * Mapping JSON fields to CSS classes.
- * @private
- */
- classMapping: {
- circle: PREFIX + 'circle-annotation',
- rectangle: PREFIX + 'rectangle-annotation',
- label: PREFIX + 'label-annotation',
- segment: PREFIX + 'segment',
- arrowSegment: PREFIX + 'arrow-segment',
- ray: PREFIX + 'ray',
- arrowRay: PREFIX + 'arrow-ray',
- line: PREFIX + 'infinity-line',
- arrowLine: PREFIX + 'arrow-infinity-line',
- verticalLine: PREFIX + 'vertical-line',
- horizontalLine: PREFIX + 'horizontal-line',
- crooked3: PREFIX + 'crooked3',
- crooked5: PREFIX + 'crooked5',
- elliott3: PREFIX + 'elliott3',
- elliott5: PREFIX + 'elliott5',
- pitchfork: PREFIX + 'pitchfork',
- fibonacci: PREFIX + 'fibonacci',
- parallelChannel: PREFIX + 'parallel-channel',
- measureX: PREFIX + 'measure-x',
- measureY: PREFIX + 'measure-y',
- measureXY: PREFIX + 'measure-xy',
- verticalCounter: PREFIX + 'vertical-counter',
- verticalLabel: PREFIX + 'vertical-label',
- verticalArrow: PREFIX + 'vertical-arrow',
- currentPriceIndicator: PREFIX + 'current-price-indicator',
- indicators: PREFIX + 'indicators',
- flagCirclepin: PREFIX + 'flag-circlepin',
- flagDiamondpin: PREFIX + 'flag-diamondpin',
- flagSquarepin: PREFIX + 'flag-squarepin',
- flagSimplepin: PREFIX + 'flag-simplepin',
- zoomX: PREFIX + 'zoom-x',
- zoomY: PREFIX + 'zoom-y',
- zoomXY: PREFIX + 'zoom-xy',
- typeLine: PREFIX + 'series-type-line',
- typeOHLC: PREFIX + 'series-type-ohlc',
- typeCandlestick: PREFIX + 'series-type-candlestick',
- fullScreen: PREFIX + 'full-screen',
- toggleAnnotations: PREFIX + 'toggle-annotations',
- saveChart: PREFIX + 'save-chart',
- separator: PREFIX + 'separator'
- }
- };
- // Comunication with bindings:
- addEvent(H.NavigationBindings, 'selectButton', function (event) {
- var button = event.button, className = PREFIX + 'submenu-wrapper', gui = this.chart.stockTools;
- if (gui && gui.guiEnabled) {
- // Unslect other active buttons
- gui.unselectAllButtons(event.button);
- // If clicked on a submenu, select state for it's parent
- if (button.parentNode.className.indexOf(className) >= 0) {
- button = button.parentNode.parentNode;
- }
- // Set active class on the current button
- gui.selectButton(button);
- }
- });
- addEvent(H.NavigationBindings, 'deselectButton', function (event) {
- var button = event.button, className = PREFIX + 'submenu-wrapper', gui = this.chart.stockTools;
- if (gui && gui.guiEnabled) {
- // If deselecting a button from a submenu, select state for it's parent
- if (button.parentNode.className.indexOf(className) >= 0) {
- button = button.parentNode.parentNode;
- }
- gui.selectButton(button);
- }
- });
- });
- _registerModule(_modules, 'masters/modules/stock-tools.src.js', [], function () {
- });
- }));
|