(window.webpackJsonp = window.webpackJsonp || []).push([
['restricted-toolset'],
{
'+KIV': function (e, t) {
e.exports =
'';
},
'1Tx8': function (e, t, n) {
e.exports = {
button: 'button-YsN2vRuA',
withText: 'withText-JhQdRoPu',
withoutText: 'withoutText-f6SoijeW',
};
},
'1uoO': function (e, t) {
e.exports =
'';
},
'23di': function (e, t, n) {
e.exports = {
wrap: 'wrap-3OynVXTx',
titleWrap: 'titleWrap-yVINuOIC',
indicators: 'indicators-CRJ2i71K',
title: 'title-Iod5hZQV',
icon: 'icon-3bTRbX0U',
text: 'text-2BJe_3ce',
titleTabletSmall: 'titleTabletSmall-23pyY8Xw',
labelRow: 'labelRow-2Vs9IqnP',
label: 'label-1LxfyrID',
};
},
'2xRE': function (e, t) {
e.exports =
'';
},
'3j+J': function (e, t, n) {
e.exports = {
wrapper: 'wrapper-24zqYyK4',
labelRow: 'labelRow-1iPG3dcw',
label: 'label-2LqksoTK',
labelHint: 'labelHint-3H3QjpAE',
labelOn: 'labelOn-1_CJ0mp2',
};
},
'4hTN': function (e, t, n) {
e.exports = { value: 'value-DWZXOdoK', selected: 'selected-2V87KUXm' };
},
'4pMH': function (e, t, n) {},
'5ijr': function (e) {
e.exports = JSON.parse(
'{"switcherWrapper":"switcherWrapper-1wFH-_jm","size-small":"size-small-1gT-kZYO","size-large":"size-large-MOSirnj_","intent-select":"intent-select-2kut8F29","switcherThumbWrapper":"switcherThumbWrapper-2u191lDO","input":"input-J7QIcTTo","switcherTrack":"switcherTrack-2XruDVTa","intent-default":"intent-default-3soo5rvS","switcherThumb":"switcherThumb-2yuEucci","focus":"focus-uZMRkCO0"}',
);
},
'8RO/': function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return i;
}),
n.d(t, 'b', function () {
return o;
});
var a = n('3ClC');
function i(e, t) {
return {
indicators: e
.orderedDataSources(!0)
.filter(function (e) {
return Object(a.isStudy)(e) && !Object(a.isESDStudy)(e);
})
.map(function (e) {
return {
id: e.metaInfo().id,
description: e.title(!0, void 0, !0),
};
}),
interval: t,
};
}
function o(e) {
var t = new Map();
return (
e.forEach(function (e) {
var n = t.get(e.id) || [e.description, 0],
a = n[0],
i = n[1];
t.set(e.id, [a, i + 1]);
}),
Array.from(t.values())
.map(function (e) {
var t = e[0],
n = e[1];
return t + (n > 1 ? ' x ' + n : '');
})
.join(', ')
);
}
},
'8d0Q': function (e, t, n) {
'use strict';
n.d(t, 'b', function () {
return i;
}),
n.d(t, 'a', function () {
return o;
});
var a = n('q1tI');
function i() {
var e = Object(a.useState)(!1),
t = e[0],
n = e[1];
return [
t,
{
onMouseOver: function (e) {
o(e) && n(!0);
},
onMouseOut: function (e) {
o(e) && n(!1);
},
},
];
}
function o(e) {
return !e.currentTarget.contains(e.relatedTarget);
}
},
'9NBK': function (e, t, n) {
e.exports = { item: 'item-b8AKccvl', round: 'round-2UQxqNA1' };
},
ASyk: function (e, t, n) {
e.exports = {
'tablet-normal-breakpoint': 'screen and (max-width: 768px)',
'small-height-breakpoint': 'screen and (max-height: 360px)',
'tablet-small-breakpoint': 'screen and (max-width: 419px)',
};
},
CX26: function (e, t, n) {
e.exports = {
form: 'form-2itceCqS',
interacting: 'interacting-3joY26dg',
input: 'input-z46tLQgj',
menu: 'menu-35lWsSKr',
add: 'add-1NrfSAvb',
hovered: 'hovered-1nwOcWv8',
hover: 'hover-2JY1kj4n',
wrap: 'wrap-1oB2WI2R',
};
},
EvtC: function (e, t, n) {
e.exports = { button: 'button-2-lC3gh4' };
},
FO3N: function (e, t) {
e.exports =
'';
},
FzLb: function (e, t, n) {
'use strict';
Object.defineProperty(t, '__esModule', { value: !0 }),
n('mrSG').__exportStar(n('j3s+'), t);
},
G2sT: function (e, t) {
e.exports =
'';
},
GgvM: function (e, t) {
e.exports =
'';
},
HBiQ: function (e, t, n) {
e.exports = {
button: 'button-1IIz2ju4',
first: 'first-bfrNico9',
last: 'last-3h-LFsOr',
};
},
HD8h: function (e, t, n) {
e.exports = {
item: 'item-184T8X5A',
label: 'label-20cSBx98',
labelRow: 'labelRow-2fmEJqjl',
toolbox: 'toolbox-2H0D5bLi',
};
},
Jtxf: function (e, t) {
e.exports =
'';
},
MB0Y: function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return h;
}),
n.d(t, 'b', function () {
return d;
});
var a = n('mrSG'),
i = n('q1tI'),
o = n.n(i),
r = n('TSYQ'),
s = n.n(r),
l = n('FzLb'),
c = n('QpNh'),
u = n('OP2o'),
h = u;
function d(e) {
var t = e.className,
n = e.checked,
i = e.id,
r = e.label,
h = e.labelDescription,
d = e.value,
v = e.preventLabelHighlight,
m = e.reference,
p = e.switchReference,
f = e.theme,
b = void 0 === f ? u : f,
g = s()(b.label, n && !v && b.labelOn),
_ = s()(t, b.wrapper, n && b.wrapperWithOnLabel);
return o.a.createElement(
'label',
{ className: _, htmlFor: i, ref: m },
o.a.createElement(
'div',
{ className: b.labelRow },
o.a.createElement('div', { className: g }, r),
h && o.a.createElement('div', { className: b.labelHint }, h),
),
o.a.createElement(
l.Switch,
Object(a.__assign)(
{
className: b.switch,
reference: p,
checked: n,
onChange: function (t) {
var n = t.target.checked;
void 0 !== e.onChange && e.onChange(n);
},
value: d,
tabIndex: -1,
id: i,
},
Object(c.a)(e),
),
),
);
}
},
OP2o: function (e, t, n) {
e.exports = {
wrapper: 'wrapper-3Sj-FzgR',
hovered: 'hovered-1G0yygIe',
labelRow: 'labelRow-3h7cSJ_L',
label: 'label-3iLxp29M',
labelHint: 'labelHint-3qxeiVfa',
labelOn: 'labelOn-10QGwv2n',
};
},
Oy6E: function (e, t, n) {
e.exports = { spinnerWrap: 'spinnerWrap-EgWaITv6' };
},
RGo6: function (e, t, n) {
e.exports = {
opened: 'opened-GQFVkrpV',
hover: 'hover-1s0KqpdE',
autoSaveWrapper: 'autoSaveWrapper-1MJY41zr',
sharingWrapper: 'sharingWrapper-2a3BKnuf',
button: 'button-X9fdkr3t',
buttonSmallPadding: 'buttonSmallPadding-3OtdkF4f',
hintPlaceHolder: 'hintPlaceHolder-3xGrUHN7',
smallHintPlaceHolder: 'smallHintPlaceHolder-3ftZG2PP',
popupItemRowTabletSmall: 'popupItemRowTabletSmall-3IpexBN9',
};
},
RYBj: function (e, t) {
e.exports =
'';
},
'S+Ii': function (e, t, n) {
e.exports = {
buttonUndo: 'buttonUndo-342XpPC1',
buttonRedo: 'buttonRedo-3o_XdU_J',
};
},
S0BX: function (e, t, n) {
e.exports = {
dropdown: 'dropdown-3caJUCGx',
label: 'label-3vchy5zS',
smallWidthTitle: 'smallWidthTitle-2IQL6W7f',
smallWidthMenuItem: 'smallWidthMenuItem-1ZGyfGnk',
smallWidthWrapper: 'smallWidthWrapper-DpXp8jNn',
};
},
SchQ: function (e, t, n) {
e.exports = {
button: 'button-1EU5-JL7',
isDisabled: 'isDisabled-1RjJSnJ7',
text: 'text-1HWeUAzA',
};
},
To8B: function (e, t) {
e.exports =
'';
},
UJ4t: function (e, t, n) {
e.exports = { wrap: 'wrap-18oKCBRc' };
},
VgwI: function (e, t) {
e.exports =
'';
},
X7WP: function (e, t, n) {
e.exports = {
wrap: 'wrap-CUt4Mg1V',
inner: 'inner-32OP7ejC',
actions: 'actions-1cGPn1dW',
hover: 'hover-3dmVjFov',
input: 'input-3lfOzLDc',
isExpanded: 'isExpanded-1pdStI5Z',
mobileButton: 'mobileButton-19PXAUYw',
};
},
XWsk: function (e, t) {
e.exports =
'';
},
XfUw: function (e, t) {
e.exports =
'';
},
YEs3: function (e, t, n) {
e.exports = { button: 'button-1F3Go35E', menu: 'menu-16FRUKka' };
},
aVq2: function (e, t, n) {
e.exports = {
button: 'button-1XkSWU32',
first: 'first-2UbSFGzF',
last: 'last-1rdUnwE6',
menu: 'menu-1fA401bY',
dropdown: 'dropdown-1zOBoqnG',
menuContent: 'menuContent-1vyIDg3J',
section: 'section-1p7gLxC9',
};
},
dhVi: function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return r;
});
var a = n('nPPD'),
i = n('v1bN'),
o = n('HD8h'),
r = Object(a.a)(i, o);
},
fD7T: function (e, t) {
e.exports =
'';
},
fESK: function (e, t, n) {
e.exports = {
labelRow: 'labelRow-1loM6nbt',
toolbox: 'toolbox-3y2qhvbG',
description: 'description-UeULl1bt',
descriptionTabletSmall: 'descriptionTabletSmall-iXl7OFTS',
item: 'item-GOMwFObW',
titleItem: 'titleItem-3OGNprLt',
titleItemTabletSmall: 'titleItemTabletSmall-HWAlNL6k',
itemTabletSmall: 'itemTabletSmall-3fytMoGU',
itemLabelTabletSmall: 'itemLabelTabletSmall-3VG7Qvey',
wrap: 'wrap-3ulNVWio',
hovered: 'hovered-tcAOA2o_',
};
},
fEjm: function (e, t, n) {
e.exports = {
favorite: 'favorite-2V8VHwKe',
active: 'active-3pQAvYvT',
checked: 'checked-2bhy04CF',
};
},
fioS: function (e, t, n) {
e.exports = {
summary: 'summary-3_6tmh1R',
hovered: 'hovered-1yGmee-_',
caret: 'caret-1v4NzWzm',
};
},
gla1: function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return i;
});
var a = n('q1tI'),
i = function () {
return Object(a.useReducer)(function (e, t) {
return e + 1;
}, 0)[1];
};
},
'i/MG': function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return u;
});
var a = n('mrSG'),
i = (n('YFKU'), n('q1tI')),
o = n('TSYQ'),
r = n('Iivm'),
s = n('To8B'),
l = n('kXJy'),
c = { remove: window.t('Remove') };
function u(e) {
var t = e.className,
n = e.isActive,
u = e.onClick,
h = e.title,
d = e.hidden,
v = e['data-name'],
m = void 0 === v ? 'remove-button' : v,
p = Object(a.__rest)(e, [
'className',
'isActive',
'onClick',
'title',
'hidden',
'data-name',
]);
return i.createElement(
r.Icon,
Object(a.__assign)({}, p, {
'data-name': m,
className: o(
l.button,
'apply-common-tooltip',
n && l.active,
d && l.hidden,
t,
),
icon: s,
onClick: u,
title: h || c.remove,
}),
);
}
},
'j3s+': function (e, t, n) {
'use strict';
Object.defineProperty(t, '__esModule', { value: !0 });
var a = n('mrSG'),
i = n('q1tI'),
o = n('TSYQ'),
r = n('5ijr');
function s(e) {
var t = e.className,
n = void 0 === t ? '' : t,
a = e.intent,
i = void 0 === a ? 'default' : a,
s = e.size,
l = void 0 === s ? 'small' : s,
c = e.disabled;
return o(n, r.switcherWrapper, r['size-' + l], !c && r['intent-' + i]);
}
n('4pMH');
var l = (function (e) {
function t() {
return (null !== e && e.apply(this, arguments)) || this;
}
return (
a.__extends(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.reference,
n =
(e.size,
e.intent,
a.__rest(e, ['reference', 'size', 'intent'])),
l = o(r.input, -1 !== this.props.tabIndex && r.focus);
return i.createElement(
'div',
{ className: s(this.props) },
i.createElement(
'input',
a.__assign({}, n, { type: 'checkbox', className: l, ref: t }),
),
i.createElement(
'div',
{ className: r.switcherThumbWrapper },
i.createElement('div', { className: r.switcherTrack }),
i.createElement('div', { className: r.switcherThumb }),
),
);
}),
t
);
})(i.PureComponent);
t.Switch = l;
},
jKyl: function (e, t) {
e.exports =
'';
},
kXJy: function (e, t, n) {
e.exports = {
button: 'button-1scLo53s',
active: 'active-2T0ofIIp',
hidden: 'hidden-2GRQzIQ1',
};
},
'koZ+': function (e, t) {
e.exports =
'';
},
lAXe: function (e, t) {
e.exports =
'';
},
miV2: function (e, t, n) {
'use strict';
n.r(t);
var a,
i = n('Kxc7'),
o = n('mrSG'),
r = n('q1tI'),
s = n.n(r),
l = n('17x9'),
c = n('dfhE'),
u = n('G2sT'),
h = n('Jtxf'),
d = n('pqsj'),
v = n('1uoO'),
m = n('FO3N'),
p = n('t2Sj'),
f = n('fD7T'),
b = n('VgwI'),
g =
(((a = {})[3] = u),
(a[0] = h),
(a[1] = d),
(a[8] = v),
(a[9] = m),
(a[2] = p),
(a[10] = f),
(a[12] = b),
a);
var _,
C = n('pr86'),
w = n('Iivm'),
S = n('N5tr'),
y = n('82wv'),
k = n('TSYQ'),
x = n.n(k),
O = n('UJ4t'),
M = (function (e) {
function t() {
return (null !== e && e.apply(this, arguments)) || this;
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.children,
n = e.className,
a = Object(o.__rest)(e, ['children', 'className']);
return r.createElement(
'div',
Object(o.__assign)({ className: k(n, O.wrap) }, a),
t,
);
}),
t
);
})(r.PureComponent),
E = n('tU7i'),
j = n('QpNh'),
T = n('HBiQ'),
I = (function (e) {
function t() {
var t = (null !== e && e.apply(this, arguments)) || this;
return (
(t._handleClick = function () {
var e = t.props,
n = e.onClick,
a = e.onClickArg;
n && n(a);
}),
t
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e,
t = this.props,
n = t.isFirst,
a = t.isLast,
i = t.hint,
s = t.text,
l = t.icon,
c = t.isActive,
u = t.isDisabled,
h = t.className,
d = Object(j.a)(this.props);
return r.createElement(
E.b,
Object(o.__assign)({}, d, {
icon: l,
text: s,
title: i,
isDisabled: u,
isActive: c,
isGrouped: !0,
onClick: this._handleClick,
className: k(
h,
T.button,
((e = {}), (e[T.first] = n), (e[T.last] = a), e),
),
}),
);
}),
t
);
})(r.PureComponent),
A = n('KKsp'),
z = n('/KDZ'),
N = n('uhCe'),
R = n('dhVi'),
F = n('1TxM'),
H = n('YEs3'),
W =
(((_ = {})[0] = window.t('Bars')),
(_[1] = window.t('Candles')),
(_[9] = window.t('Hollow Candles')),
(_[8] = window.t('Heikin Ashi')),
(_[2] = window.t('Line')),
(_[3] = window.t('Area')),
(_[10] = window.t('Baseline')),
(_[12] = window.t('High-Low')),
_);
var L = { barsStyle: window.t("Bar's Style"), labels: W },
D = Object(F.b)(),
P = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
(a._handleChangeStyle = function (e) {
var t = a.state,
n = t.favorites,
i = t.lastSelectedNotFavorite,
o = t.activeStyle;
a.setState({
activeStyle: e,
lastSelectedNotFavorite: n.includes(o) ? i : o,
});
}),
(a._handleSelectStyle = function (e) {
var t = a.context.chartWidgetCollection;
e !== t.activeChartStyle.value() &&
t.trySetChartStyleToActiveWidget(e);
}),
(a._handleClickFavorite = function (e) {
a._isStyleFavorited(e)
? a._handleRemoveFavorite(e)
: a._handleAddFavorite(e);
}),
Object(F.c)(n, {
chartWidgetCollection: l.any.isRequired,
favoriteChartStylesService: l.any.isRequired,
});
var o = n.chartWidgetCollection,
r = n.favoriteChartStylesService,
s = o.activeChartStyle.value(),
c = r.get();
i.enabled('japanese_chart_styles');
return (
(a.state = {
activeStyle: s,
favorites: c,
styles: [0, 1, 9, 8, 2, 3, 10],
japaneseStyles: [],
}),
i.enabled('chart_style_hilo') && a.state.styles.push(12),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.context,
t = e.chartWidgetCollection,
n = e.favoriteChartStylesService;
t.activeChartStyle.subscribe(this._handleChangeStyle),
n.getOnChange().subscribe(this, this._handleChangeSettings);
}),
(t.prototype.componentWillUnmount = function () {
var e = this.context,
t = e.chartWidgetCollection,
n = e.favoriteChartStylesService;
t.activeChartStyle.unsubscribe(this._handleChangeStyle),
n.getOnChange().unsubscribe(this, this._handleChangeSettings);
}),
(t.prototype.render = function () {
var e = this,
t = this.props,
n = t.isShownQuicks,
a = t.displayMode,
i = void 0 === a ? 'full' : a,
s = t.id,
l = this.state,
u = l.activeStyle,
h = l.favorites,
d = l.styles,
v = l.japaneseStyles,
m = l.lastSelectedNotFavorite,
p = 'small' !== i && n && 0 !== h.length,
f = Object(o.__spreadArrays)(h);
f.includes(u) ? void 0 !== m && f.push(m) : f.push(u);
var b = p && f.length > 1;
return r.createElement(
z.a,
{ rule: N.a.TabletSmall },
function (t) {
var n = d.map(function (n) {
return e._renderPopupMenuItem(n, n === u, t);
}),
a = v.map(function (n) {
return e._renderPopupMenuItem(n, n === u, t);
});
return r.createElement(
M,
{ id: s },
b &&
f.map(function (t, n) {
return r.createElement(I, {
className: H.button,
icon: g[t],
isActive: p && u === t,
key: n,
hint: L.labels[t],
isFirst: 0 === n,
isLast: n === f.length - 1,
onClick: p ? e._handleSelectStyle : void 0,
onClickArg: t,
'data-value': c.STYLE_SHORT_NAMES[t],
});
}),
r.createElement(
y.a,
{
arrow: Boolean(b),
content: b
? void 0
: r.createElement(
M,
null,
r.createElement(w.Icon, { icon: g[u] }),
),
title: b ? L.barsStyle : L.labels[u],
className: H.menu,
isDrawer: t,
},
n,
!!a.length && r.createElement(A.a, null),
a,
),
);
},
);
}),
(t.prototype._renderPopupMenuItem = function (e, t, n) {
var a = this,
i = this.props.isFavoritingAllowed,
o = this._isStyleFavorited(e);
return r.createElement(S.b, {
key: e,
theme: n ? R.a : void 0,
icon: g[e],
isActive: t,
label: L.labels[e] || '',
onClick: this._handleSelectStyle,
onClickArg: e,
showToolboxOnHover: !o,
toolbox:
i &&
r.createElement(C.a, {
isActive: t,
isFilled: o,
onClick: function () {
return a._handleClickFavorite(e);
},
}),
'data-value': c.STYLE_SHORT_NAMES[e],
});
}),
(t.prototype._handleChangeSettings = function (e) {
this.setState({ lastSelectedNotFavorite: void 0, favorites: e });
}),
(t.prototype._isStyleFavorited = function (e) {
return -1 !== this.state.favorites.indexOf(e);
}),
(t.prototype._handleAddFavorite = function (e) {
var t = this.state.favorites;
this.context.favoriteChartStylesService.set(
Object(o.__spreadArrays)(t, [e]),
);
}),
(t.prototype._handleRemoveFavorite = function (e) {
var t = this.state.favorites;
this.context.favoriteChartStylesService.set(
t.filter(function (t) {
return t !== e;
}),
);
}),
(t.contextType = D),
t
);
})(r.PureComponent),
V = n('YFKU'),
B = n('1Tx8'),
U = ['medium', 'small'];
function G(e) {
var t = e.text,
n = e.className,
a = e.displayMode,
i = e.collapseWhen,
s = void 0 === i ? U : i,
l = Object(o.__rest)(e, [
'text',
'className',
'displayMode',
'collapseWhen',
]),
c = !s.includes(a);
return r.createElement(
E.b,
Object(o.__assign)({}, l, {
text: c ? t : void 0,
className: k(n, B.button, c ? B.withText : B.withoutText),
}),
);
}
var K = n('PC8g'),
q = n('RYBj'),
Q = {
compare: window.t('Compare'),
compareOrAddSymbol: window.t('Compare or Add Symbol'),
},
Y = Object(F.b)(),
J = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._handleClick = function () {
Object(K.trackEvent)('GUI', 'Chart Header Toolbar', 'compare'),
a.setState({ isActive: !0 }),
a.context.chartWidgetCollection
.showAddCompareDialog()
.then(function (e) {
e.on('afterOpen', function () {
return a.setState({ isActive: !0 });
}),
e.on('beforeClose', function () {
return a.setState({ isActive: !1 });
});
});
}),
Object(F.c)(n, { chartWidgetCollection: l.any.isRequired }),
(a.state = { isActive: !1 }),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.state.isActive;
return r.createElement(
G,
Object(o.__assign)({}, this.props, {
icon: q,
isOpened: e,
onClick: this._handleClick,
text: Q.compare,
title: Q.compareOrAddSymbol,
}),
);
}),
(t.contextType = Y),
t
);
})(r.PureComponent),
X = n('EvtC'),
Z = r.forwardRef(function (e, t) {
var n = e.className,
a = Object(o.__rest)(e, ['className']);
return r.createElement(
E.b,
Object(o.__assign)({}, a, { ref: t, className: k(n, X.button) }),
);
}),
$ = n('GgvM'),
ee = { hint: window.t('Fullscreen mode') },
te = Object(F.b)(),
ne = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._handleClick = function () {
a.context.chartWidgetCollection.startFullscreen();
}),
Object(F.c)(n, { chartWidgetCollection: l.any.isRequired }),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.className,
n = e.id;
return r.createElement(Z, {
id: n,
icon: $,
onClick: this._handleClick,
title: ee.hint,
className: k(t),
});
}),
(t.contextType = te),
t
);
})(r.PureComponent),
ae = n('Eyy1'),
ie = n('ei7k'),
oe = n('uOxu'),
re = Object(oe.getLogger)('FavoritesInfo');
function se(e, t) {
if (0 === e.length) return Promise.resolve([]);
re.logNormal('Requesting favorites info');
var n = [],
a = new Map(),
i = new Map(),
o = new Map();
return (
e.forEach(function (e) {
switch (e.type) {
case 'java':
o.set(e.studyId, e);
break;
case 'pine':
isPublishedPineId(e.pineId)
? a.set(e.pineId, e)
: i.set(e.pineId, e);
break;
default:
Object(ae.assert)(
!1,
'unknown favorite type ' + JSON.stringify(e),
);
}
}),
0 !== o.size &&
n.push(
t
.findAllJavaStudies()
.then(function (e) {
for (var t = new Map(), n = 0, a = e; n < a.length; n++) {
var i = a[n];
o.has(i.id) &&
t.set(i.id, {
name: i.description,
localizedName: i.description_localized,
studyMarketShittyObject: i,
});
}
return t;
})
.then(function (e) {
var t,
n,
a =
((t = e),
(n = { items: [], notFoundItems: [] }),
o.forEach(function (e, a) {
var i = t.get(a);
void 0 !== i
? n.items.push({ item: e, info: i })
: n.notFoundItems.push(e);
}),
n);
if (0 !== a.notFoundItems.length) {
var i = a.notFoundItems.map(function (e) {
return e.studyId;
});
re.logWarn(
'Cannot find java scripts: ' + JSON.stringify(i),
);
}
return a.items;
}),
),
Promise.all(n).then(function (e) {
return (
re.logNormal('Requesting favorites info finished'),
e.reduce(function (e, t) {
return e.concat(t);
}, [])
);
})
);
}
var le = n('CW80'),
ce = n('mMWL'),
ue = n('6KyJ'),
he = n('Oy6E');
function de(e) {
return r.createElement(
'div',
{ className: he.spinnerWrap },
r.createElement(ue.Loader, null),
);
}
var ve = n('sHKj');
function me(e) {
return r.createElement(
'div',
{ className: k(e.className, ve.title) },
e.children,
);
}
var pe = n('XWsk'),
fe = n('S0BX'),
be = {
text: window.t('Indicators'),
hint: i.enabled('study_dialog_fundamentals_economy_addons')
? window.t('Indicators & Strategies')
: window.t('Indicators'),
favorites: window.t('Favorites'),
},
ge = Object(ie.b)({ keys: ['/'], text: '{0}' }),
_e = Object(F.b)(),
Ce = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
(a._promise = null),
(a._menu = s.a.createRef()),
(a._handleClick = function () {
var e = a.props.studyMarket;
a.setState({ isActive: !0 }, function () {
e.isVisible() ? e.hide() : e.show();
});
}),
(a._handleSelectIndicator = function (e) {
e = Object(ae.ensureDefined)(e);
var t = a.context.chartWidgetCollection;
if ('java' === e.type) {
var n = Object(le.tryFindStudyLineToolNameByStudyId)(
e.studyId,
);
if (null !== n) return void ce.tool.setValue(n);
}
t.activeChartWidget.value().insertStudy(e);
}),
(a._handleFavoriteIndicatorsChange = function () {
var e = a.context.favoriteScriptsModel,
t = Object(o.__spreadArrays)(
Object(ae.ensureDefined)(e).favorites(),
);
a.setState({ favorites: t }), a._clearCache();
}),
(a._handleMouseEnter = function () {
a._prefetchFavorites();
}),
(a._handleWrapClick = function () {
a._prefetchFavorites();
}),
(a._handleChangeActiveWidget = function () {
a._clearCache();
}),
(a._clearCache = function () {
(a._promise = null), a.setState({ infos: [] });
}),
Object(F.c)(n, {
favoriteScriptsModel: l.any,
chartWidgetCollection: l.any.isRequired,
});
var i = n.favoriteScriptsModel,
r = void 0 !== i ? i.favorites() : [];
return (
(a.state = {
isActive: !1,
isLoading: !1,
favorites: r,
infos: [],
}),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.props.studyMarket,
t = this.context,
n = t.favoriteScriptsModel,
a = t.chartWidgetCollection;
e.visibilityChanged.subscribe(this, this._setActiveState),
void 0 !== n &&
(n
.favoritesChanged()
.subscribe(this, this._handleFavoriteIndicatorsChange),
a.activeChartWidget.subscribe(
this._handleChangeActiveWidget,
));
}),
(t.prototype.componentWillUnmount = function () {
var e = this.props.studyMarket,
t = this.context,
n = t.favoriteScriptsModel,
a = t.chartWidgetCollection;
e.visibilityChanged.unsubscribe(this, this._setActiveState),
void 0 !== n &&
(n
.favoritesChanged()
.unsubscribe(this, this._handleFavoriteIndicatorsChange),
a.activeChartWidget.unsubscribe(
this._handleChangeActiveWidget,
)),
(this._promise = null);
}),
(t.prototype.render = function () {
var e = this,
t = this.state,
n = t.isActive,
a = t.favorites,
i = t.isLoading,
o = this.props,
r = o.className,
l = o.displayMode,
c = o.id,
u = this.context.chartWidgetCollection;
return s.a.createElement(
M,
{
id: c,
onMouseEnter: this._handleMouseEnter,
onClick: this._handleWrapClick,
},
s.a.createElement(G, {
displayMode: l,
className: r,
icon: pe,
isOpened: n,
onClick: this._handleClick,
text: be.text,
title: be.hint,
'data-role': 'button',
'data-name': 'open-indicators-dialog',
'data-tooltip-hotkey': ge,
}),
a.length > 0 &&
s.a.createElement(
z.a,
{ rule: 'screen and (max-width: 419px)' },
function (t) {
return s.a.createElement(
y.a,
{
key: u.activeChartWidget.value().id(),
arrow: !0,
closeOnClickOutside: !0,
isDrawer: t,
drawerPosition: 'Bottom',
title: be.favorites,
ref: e._menu,
'data-name': 'show-favorite-indicators',
},
s.a.createElement(
'div',
{
className: x()(
fe.dropdown,
t && fe.smallWidthWrapper,
),
},
s.a.createElement(
me,
{ className: t && fe.smallWidthTitle },
window.t('Favorite Indicators'),
),
i && s.a.createElement(de, null),
!i &&
s.a.createElement(
s.a.Fragment,
null,
e.state.infos.length > 0
? e.state.infos.map(function (n) {
return s.a.createElement(S.b, {
className: x()(
t && fe.smallWidthMenuItem,
),
theme: t ? R.a : void 0,
key:
'java' === n.item.type
? n.item.studyId
: n.item.pineId,
onClick: e._handleSelectIndicator,
onClickArg: n.item,
label: s.a.createElement(
'span',
{
className: x()(
!t && fe.label,
t && fe.smallWidthLabel,
'apply-overflow-tooltip',
),
},
we(n),
),
});
})
: null !== e._promise &&
s.a.createElement(S.b, {
isDisabled: !0,
label: window.t(
'You have no Favorites Indicators yet',
),
}),
),
),
);
},
),
);
}),
(t.prototype._setActiveState = function (e) {
this.setState({ isActive: e });
}),
(t.prototype._prefetchFavorites = function () {
var e = this,
t = this.context.chartWidgetCollection;
if (null === this._promise) {
var n = t.activeChartWidget.value().model();
if (null !== n) {
var a = n.model().studyMetaInfoRepository();
this.setState({ isLoading: !0 });
var i = (this._promise = se(this.state.favorites, a).then(
function (t) {
if (i === e._promise) {
(t = Object(o.__spreadArrays)(t).sort(function (e, t) {
return we(e).localeCompare(we(t));
})),
e.setState(
{
infos: t,
isLoading: !1,
},
function () {
e._menu.current && e._menu.current.update();
},
);
}
},
));
}
}
}),
(t.contextType = _e),
t
);
})(s.a.PureComponent);
function we(e) {
return (
e.info.localizedName || Object(V.t)(e.info.name, { context: 'study' })
);
}
var Se = n('PT1i'),
ye = n('pPtI'),
ke = n('4hTN');
function xe(e) {
var t;
return r.createElement(
'div',
{
className: k(
ke.value,
((t = {}), (t[ke.selected] = e.isSelected), t),
),
},
e.value,
e.metric,
);
}
var Oe = n('9dlw'),
Me = n('ML8+'),
Ee = n('LxhU'),
je = n('CX26'),
Te = { add: window.t('Add') },
Ie = [
{ name: '1', label: window.t('minutes', { context: 'interval' }) },
{ name: '1H', label: window.t('hours', { context: 'interval' }) },
{ name: '1D', label: window.t('days', { context: 'interval' }) },
{ name: '1W', label: window.t('weeks', { context: 'interval' }) },
{ name: '1M', label: window.t('months', { context: 'interval' }) },
];
var Ae,
ze = (function (e) {
function t(t) {
var n = e.call(this, t) || this;
return (
(n._timeMenu = null),
(n._setMenuRef = function (e) {
n._timeMenu = e;
}),
(n._handleChangeInput = function (e) {
var t = e.currentTarget.value;
/^[0-9]*$/.test(t) && n.setState({ inputValue: t });
}),
(n._handleSelectTime = function (e) {
n.setState({ selectedTime: e }), n._closeMenu();
}),
(n._handleClickAdd = function () {
var e = n.state,
t = e.inputValue,
a = e.selectedTime,
i = parseInt(t);
if (
i ===
((o = i),
(r = a),
Math.max(1, Math.min(o, Object(ye.getMaxResolutionValue)(r))))
) {
var o,
r,
s = Ee.Interval.parse(a),
l = s.isMinuteHours() ? 60 * i : i,
c = new Ee.Interval(s.kind(), l);
n.props.onAdd(c.value());
}
}),
(n._toggleMenu = function () {
n.state.isOpenedMenu ? n._closeMenu() : n._openMenu();
}),
(n._closeMenu = function () {
n.props.onCloseMenu(), n.setState({ isOpenedMenu: !1 });
}),
(n._openMenu = function () {
n.props.onOpenMenu(), n.setState({ isOpenedMenu: !0 });
}),
(n._getMenuPosition = function () {
var e = Object(ae.ensureNotNull)(
n._timeMenu,
).getBoundingClientRect();
return { overrideWidth: e.width, x: e.left, y: e.bottom + 1 };
}),
(n.state = {
inputValue: '1',
isOpenedMenu: !1,
selectedTime: Ie[0].name,
}),
n
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e,
t = this,
n = this.state,
a = n.inputValue,
i = n.isOpenedMenu,
o = n.menuWidth,
s = n.selectedTime;
return r.createElement(
'div',
{
className: k(je.form, ((e = {}), (e[je.interacting] = i), e)),
},
r.createElement('input', {
className: je.input,
maxLength: 4,
onChange: this._handleChangeInput,
value: a,
}),
r.createElement(
'div',
{
className: je.menu,
onClick: this._toggleMenu,
ref: this._setMenuRef,
},
Ie.find(function (e) {
return e.name === s;
}).label,
r.createElement(Me.a, { dropped: i }),
),
r.createElement(
'div',
{ className: je.add, onClick: this._handleClickAdd },
Te.add,
),
r.createElement(
Oe.a,
{
doNotCloseOn: this,
isOpened: i,
minWidth: o,
onClose: this._closeMenu,
position: this._getMenuPosition,
},
Ie.map(function (e) {
return r.createElement(S.b, {
dontClosePopup: !0,
key: e.name,
label: e.label,
onClick: t._handleSelectTime,
onClickArg: e.name,
});
}),
),
);
}),
t
);
})(r.PureComponent),
Ne = (n('bf9a'), n('i/MG')),
Re = n('8d0Q');
function Fe(e) {
var t,
n,
a,
i,
s = e.interval,
l = e.hint,
c = e.isActive,
u = e.isDisabled,
h = e.isFavorite,
d = e.isSignaling,
v = e.onClick,
m = e.onClickRemove,
p = e.onClickFavorite,
f = Object(j.a)(e),
b = Object(Re.b)(),
g = b[0],
_ = b[1],
w = r.useCallback(
function () {
return m(s);
},
[m, s],
),
y = r.useCallback(
function () {
return p(s);
},
[p, s],
);
return r.createElement(
'div',
Object(o.__assign)({}, _),
r.createElement(
S.b,
Object(o.__assign)({}, f, {
isActive: c,
isDisabled: u,
isHovered: d,
onClick: v,
onClickArg: s,
toolbox:
((t = e.isRemovable),
(n = e.isFavoritingAllowed),
(a = r.createElement(Ne.a, {
key: 'remove',
isActive: c,
hidden: !Modernizr.touch && !g,
onClick: w,
})),
(i = r.createElement(C.a, {
key: 'favorite',
isActive: c,
isFilled: h,
onClick: y,
})),
[t && a, !u && n && i]),
showToolboxOnHover: !h,
label: l,
}),
),
);
}
var He =
(((Ae = {})[Ee.ResolutionKind.Seconds] = window.t('Seconds', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Minutes] = window.t('Minutes', {
context: 'interval_group_name',
})),
(Ae[Ee.SpecialResolutionKind.Hours] = window.t('Hours', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Days] = window.t('Days', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Weeks] = window.t('Weeks', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Months] = window.t('Months', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Range] = window.t('Ranges', {
context: 'interval_group_name',
})),
(Ae[Ee.ResolutionKind.Invalid] = ''),
Ae);
function We(e, t) {
return (
void 0 === t && (t = !1),
{ id: e, name: He[e], items: [], mayOmitSeparator: t }
);
}
var Le = n('fioS');
function De(e) {
return s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(
'div',
{
className: x()(e.className, Le.summary),
onClick: function () {
e.onStateChange && e.onStateChange(!e.open);
},
'data-open': e.open,
},
e.summary,
s.a.createElement(Me.a, {
className: Le.caret,
dropped: Boolean(e.open),
}),
),
e.open && e.children,
);
}
var Pe = n('aVq2'),
Ve = {
openDialog: window.t('Open Interval Dialog'),
timeInterval: window.t('Time Interval'),
},
Be = Object(ie.b)({ keys: [','], text: window.t('Number or {0}') }),
Ue = Object(F.b)(),
Ge = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
(a._menu = s.a.createRef()),
(a._handleChangeInterval = function (e) {
var t = a.state,
n = t.activeInterval,
i = t.lastNotQuicked,
o = a._getQuicks();
a.setState({
activeInterval: Object(ye.normalizeIntervalString)(e),
lastNotQuicked: void 0 === n || o.includes(n) ? i : n,
});
}),
(a._handleCloseMenu = function () {
a.setState({ isOpenedFormMenu: !1 });
}),
(a._handleOpenMenu = function () {
a.setState({ isOpenedFormMenu: !0 });
}),
(a._bindedForceUpdate = function () {
a.forceUpdate();
}),
(a._handleSelectInterval = function (e) {
void 0 !== e &&
e !== Se.linking.interval.value() &&
(Object(ye.setLastUsedResolution)(e),
Se.linking.interval.setValue(e)),
e && Object(K.trackEvent)('GUI', 'Time Interval', e);
}),
(a._handleClickFavorite = function (e) {
(e = Object(ae.ensureDefined)(e)),
a._isIntervalFavorite(e)
? a._handleRemoveFavorite(e)
: a._handleAddFavorite(e);
}),
(a._handleAddFavorite = function (e) {
var t = a.state.favorites;
a.context.favoriteIntervalsService.set(
Object(o.__spreadArrays)(t, [e]),
);
}),
(a._handleRemoveFavorite = function (e) {
var t = a.state.favorites;
a.context.favoriteIntervalsService.set(
t.filter(function (t) {
return t !== e;
}),
);
}),
(a._handleAddInterval = function (e) {
var t = a.state.customs,
n = a.context.customIntervalsService,
i = Object(ye.normalizeIntervalString)(e);
void 0 !== n &&
(a._isIntervalDefault(i) ||
t.includes(i) ||
n.set(
Object(ye.sortResolutions)(
Object(o.__spreadArrays)(t, [i]),
),
)),
a.setState({ lastAddedInterval: i });
}),
(a._handleRemoveInterval = function (e) {
var t = a.context.customIntervalsService,
n = a.state.customs;
void 0 !== t &&
(t.set(
n.filter(function (t) {
return t !== e;
}),
),
a._handleRemoveFavorite(e));
}),
(a._getHandleSectionStateChange = function (e) {
return function (t) {
var n,
i = a.state.menuViewState;
a.context.intervalsMenuViewStateService.set(
Object(o.__assign)(
Object(o.__assign)({}, i),
(((n = {})[e] = !t), n),
),
);
};
}),
Object(F.c)(n, {
chartApiInstance: l.any.isRequired,
favoriteIntervalsService: l.any.isRequired,
customIntervalsService: l.any,
intervalsMenuViewStateService: l.any.isRequired,
});
var r = n.chartApiInstance,
c = n.favoriteIntervalsService,
u = n.customIntervalsService,
h = n.intervalsMenuViewStateService;
a._customIntervals = i.enabled('custom_resolutions');
var d = Se.linking.interval.value(),
v = d && Object(ye.normalizeIntervalString)(d),
m = c.get(),
p = void 0 !== u ? u.get() : [],
f = h.get();
return (
(a._defaultsIntervals = r
.defaultResolutions()
.map(ye.normalizeIntervalString)),
(a.state = {
isOpenedFormMenu: !1,
activeInterval: v,
favorites: m,
customs: p,
menuViewState: f,
}),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.context,
t = e.favoriteIntervalsService,
n = e.customIntervalsService,
a = e.intervalsMenuViewStateService;
t.getOnChange().subscribe(this, this._handleChangeFavorites),
a
.getOnChange()
.subscribe(this, this._handleChangeMenuViewState),
void 0 !== n &&
n.getOnChange().subscribe(this, this._handleChangeCustoms),
Se.linking.interval.subscribe(this._handleChangeInterval),
Se.linking.intraday.subscribe(this._bindedForceUpdate),
Se.linking.supportedResolutions.subscribe(
this._bindedForceUpdate,
);
}),
(t.prototype.componentWillUnmount = function () {
var e = this.context,
t = e.favoriteIntervalsService,
n = e.customIntervalsService,
a = e.intervalsMenuViewStateService;
t.getOnChange().unsubscribe(this, this._handleChangeFavorites),
a
.getOnChange()
.unsubscribe(this, this._handleChangeMenuViewState),
n &&
n.getOnChange().unsubscribe(this, this._handleChangeCustoms),
Se.linking.interval.unsubscribe(this._handleChangeInterval),
Se.linking.intraday.unsubscribe(this._bindedForceUpdate),
Se.linking.supportedResolutions.unsubscribe(
this._bindedForceUpdate,
);
}),
(t.prototype.componentDidUpdate = function (e, t) {
var n = this;
this.state.lastAddedInterval &&
setTimeout(function () {
return n.setState({ lastAddedInterval: void 0 });
}, 400);
}),
(t.prototype.render = function () {
var e = this,
t = this.props,
n = t.isShownQuicks,
a = t.id,
i = this.state,
r = i.activeInterval,
l = i.customs,
c = i.lastNotQuicked,
u = this._defaultsIntervals,
h = this._getQuicks(),
d = Object(ye.sortResolutions)(Object(o.__spreadArrays)(h));
void 0 !== r && d.includes(r)
? void 0 !== c && d.push(c)
: void 0 !== r && d.push(r);
var v = (!(!n || 0 === h.length) || void 0) && d.length > 1,
m = {},
p = Object(ye.mergeResolutions)(u, l);
(void 0 !== r ? p.concat(r) : p)
.filter(ye.isAvailable)
.forEach(function (e) {
return (m[e] = !0);
});
var f = Object(o.__spreadArrays)(
this._createMenuItems(p),
this._createIntervalForm(),
),
b =
void 0 !== r
? Object(ye.getTranslatedResolutionModel)(r)
: null;
return s.a.createElement(
M,
{ id: a },
v &&
d.map(function (t, n) {
var a,
i = Object(ye.getTranslatedResolutionModel)(t);
return s.a.createElement(I, {
key: n,
className: k(
Pe.button,
((a = {}),
(a[Pe.first] = 0 === n),
(a[Pe.last] = n === d.length - 1),
a),
),
text: s.a.createElement(xe, {
value: i.mayOmitMultiplier ? void 0 : i.multiplier,
metric: i.shortKind,
}),
hint: i.hint,
isActive: r === t,
isDisabled: !m[t] && t !== c,
onClick: e._handleSelectInterval,
onClickArg: t,
'data-value': t,
});
}),
s.a.createElement(
y.a,
{
arrow: Boolean(v),
closeOnClickOutside: !0,
content:
v || null === b
? void 0
: s.a.createElement(
M,
{ className: Pe.menuContent },
s.a.createElement(xe, {
value: b.mayOmitMultiplier
? void 0
: b.multiplier,
metric: b.shortKind,
}),
),
title: v || null === b ? Ve.timeInterval : b.hint,
hotKey: v ? Be : void 0,
className: Pe.menu,
ref: this._menu,
},
s.a.createElement('div', { className: Pe.dropdown }, f),
),
);
}),
(t.prototype._createMenuItems = function (e) {
var t,
n,
a,
i,
o,
r,
s,
l,
c = this,
u = ((n = e),
(a = We(Ee.ResolutionKind.Seconds)),
(i = We(Ee.ResolutionKind.Minutes)),
(o = We(Ee.SpecialResolutionKind.Hours)),
(r = We(Ee.ResolutionKind.Days)),
(s = We(Ee.ResolutionKind.Range)),
n.forEach(function (e) {
var t = Ee.Interval.parse(e);
t.isMinuteHours()
? o.items.push(e)
: t.isMinutes()
? Object(Ee.isHour)(Number(t.multiplier()))
? o.items.push(e)
: i.items.push(e)
: t.isSeconds()
? a.items.push(e)
: t.isDWM()
? r.items.push(e)
: t.isRange() && s.items.push(e);
}),
[a, i, o, r, s].filter(function (e) {
return 0 !== e.items.length;
})).map(function (e, t, n) {
return c._renderResolutionsGroup(e, 1 === n.length);
}),
h = (t = []).concat.apply(t, u);
return (
(l = !1),
h.filter(function (e, t, n) {
var a = !0;
return (
e.type === A.a &&
((0 !== t && t !== n.length - 1) || (a = !1),
l && (a = !1)),
(l = e.type === A.a),
a
);
})
);
}),
(t.prototype._createIntervalForm = function () {
return this._customIntervals
? [
s.a.createElement(A.a, {
key: 'custom-interval-separator',
}),
s.a.createElement(ze, {
key: 'add-form',
onAdd: this._handleAddInterval,
onCloseMenu: this._handleCloseMenu,
onOpenMenu: this._handleOpenMenu,
}),
]
: [];
}),
(t.prototype._renderResolutionsGroup = function (e, t) {
var n = this;
void 0 === t && (t = !1);
var a = [],
i = e.items.map(function (e) {
return n._renderPopupMenuItem(e);
});
if (t) a.push.apply(a, i);
else {
var o = this.context.intervalsMenuViewStateService,
r = this.state.menuViewState;
if (!o.isAllowed(e.id)) return [];
var l = s.a.createElement(
De,
{
key: e.id,
className: Pe.section,
summary: e.name,
open: !r[e.id],
onStateChange: this._getHandleSectionStateChange(e.id),
},
i,
);
a.push(l);
}
return (
(!e.mayOmitSeparator || e.items.length > 1) &&
(a.unshift(
s.a.createElement(A.a, { key: 'begin-' + e.name }),
),
a.push(s.a.createElement(A.a, { key: 'end-' + e.name }))),
a
);
}),
(t.prototype._handleChangeFavorites = function (e) {
this.setState({ lastNotQuicked: void 0, favorites: e });
}),
(t.prototype._handleChangeCustoms = function (e) {
this.setState({ customs: e });
}),
(t.prototype._handleChangeMenuViewState = function (e) {
var t = this;
this.setState({ menuViewState: e }, function () {
t._menu.current && t._menu.current.update();
});
}),
(t.prototype._renderPopupMenuItem = function (e) {
var t = this.props.isFavoritingAllowed,
n = this.state,
a = n.activeInterval,
i = n.lastAddedInterval,
o = e === a,
r = Object(ye.isAvailable)(e),
l = this._isIntervalFavorite(e),
c = this._isIntervalDefault(e),
u = Object(ye.getTranslatedResolutionModel)(e);
return s.a.createElement(Fe, {
key: e,
interval: e,
hint: u.hint,
isSignaling: i === e,
isFavoritingAllowed: t,
isDisabled: !r,
isFavorite: l,
isRemovable: !c,
isActive: o,
onClick: this._handleSelectInterval,
onClickRemove: this._handleRemoveInterval,
onClickFavorite: this._handleClickFavorite,
'data-value': e,
});
}),
(t.prototype._isIntervalDefault = function (e) {
return this._defaultsIntervals.includes(e);
}),
(t.prototype._isIntervalFavorite = function (e) {
return this.state.favorites.includes(e);
}),
(t.prototype._getQuicks = function (e) {
return this.props.isShownQuicks &&
'small' !== this.props.displayMode
? void 0 === e
? this.state.favorites
: e
: [];
}),
(t.contextType = Ue),
t
);
})(s.a.PureComponent),
Ke = n('sbT4'),
qe = n('lAXe'),
Qe = { hint: window.t('Open chart in popup') },
Ye = Object(F.b)(),
Je = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._handleClick = function () {
var e = a.context,
t = e.chartWidgetCollection,
n = e.windowMessageService,
i = e.isFundamental,
o = t.activeChartWidget.value();
o.withModel(null, function () {
n.post(parent, 'openChartInPopup', {
symbol: o.model().mainSeries().actualSymbol(),
interval: o.model().mainSeries().interval(),
fundamental: i,
});
});
}),
Object(F.c)(n, {
isFundamental: l.any,
chartWidgetCollection: l.any.isRequired,
windowMessageService: l.any.isRequired,
}),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props.className;
return r.createElement(Z, {
className: k(e, Ke.button),
icon: qe,
onClick: this._handleClick,
title: Qe.hint,
});
}),
(t.contextType = Ye),
t
);
})(r.PureComponent),
Xe = n('uafl'),
Ze = { hint: window.t('Chart Properties') },
$e = Object(F.b)(),
et = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._handleClick = function () {
var e = a.context.chartWidgetCollection.activeChartWidget.value();
Object(K.trackEvent)(
'GUI',
'Chart Header Toolbar',
'chart properties',
),
e.showGeneralChartProperties();
}),
Object(F.c)(n, { chartWidgetCollection: l.any.isRequired }),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
return r.createElement(
Z,
Object(o.__assign)({}, this.props, {
icon: Xe,
title: Ze.hint,
onClick: this._handleClick,
}),
);
}),
(t.contextType = $e),
t
);
})(r.PureComponent),
tt = n('lxNp'),
nt = (n('bSeV'), n('beCu')),
at = n('j1f4'),
it = n('nrMg'),
ot =
'M21.5 21.5h-14a5 5 0 1 1 .42-9.983 7.5 7.5 0 0 1 14.57 2.106 4.002 4.002 0 0 1-.99 7.877z',
rt = 13.08991081237793,
st = {
strokeDashOffset: 49.242997817993164,
strokeDash: 49.866326904296876,
strokeGap: rt,
strokeDashCheck: 0,
},
lt = {
strokeDashOffset: 62.956237716674806,
strokeGap: 0,
strokeDash: 62.956237716674806,
strokeDashCheck: 200,
},
ct = (function (e) {
function t(t) {
var n = e.call(this, t) || this;
return (n.state = st), n;
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
'saved' === this.props.state
? this.setState(lt)
: this._goToNextState(this.props.state);
}),
(t.prototype.componentWillUnmount = function () {
this._currentAnimation = void 0;
}),
(t.prototype.componentWillReceiveProps = function (e) {
this.props.state !== e.state && this._goToNextState(e.state);
}),
(t.prototype.render = function () {
var e,
t = this.state,
n = t.strokeDashOffset,
a = t.strokeDash,
i = t.strokeGap,
o = t.strokeDashCheck,
s = this.props,
l = s.className,
c = s.size,
u = s.onClick,
h = s.state,
d = s.isHovered,
v = void 0 !== d && d,
m = k(
it.container,
l,
v && it.hovered,
(((e = {})[it.unsaved] = 'unsaved' === h),
(e[it.saving] = 'saving' === h),
(e[it.saved] = 'saved' === h),
e),
);
return r.createElement(
'svg',
{
xmlns: 'http://www.w3.org/2000/svg',
className: m,
version: '1.1',
width: c,
height: c,
viewBox: '0 0 28 28',
onClick: u,
},
r.createElement(
'g',
{ fill: 'none' },
r.createElement('path', {
className: it.dottedCloud,
stroke: 'currentColor',
strokeDasharray: '3.5,2.5',
d: ot,
}),
r.createElement('path', {
className: it.spinningCloud,
stroke: 'currentColor',
strokeDasharray: a + ' ' + i,
strokeDashoffset: n,
d: ot,
}),
r.createElement('path', {
className: it.arrowGap,
d: 'M11 20h6v5h-6z',
}),
r.createElement(
'g',
{ className: it.arrow, stroke: 'currentColor' },
r.createElement('path', {
strokeLinecap: 'square',
d: 'M14.5 14.5v10',
}),
r.createElement('path', { d: 'M11 17l3.5-3.5L18 17' }),
),
r.createElement(
'g',
{ className: it.check, stroke: 'currentColor' },
r.createElement('path', {
strokeDasharray: o + '% ' + (200 - o) + '%',
d: 'M10 15l2.5 2.5L18 12',
}),
),
),
);
}),
(t.prototype._goToNextState = function (e) {
var t = this;
switch (e) {
case 'unsaved':
this.setState(st);
break;
case 'saving':
'unsaved' !== this.props.state && this.setState(st),
(this._currentAnimation = Promise.resolve(
this._currentAnimation,
).then(function () {
return t._createSpinAnimationWhile(function () {
return 'saving' === t.props.state;
});
}));
break;
case 'saved':
this._currentAnimation = Promise.resolve(
this._currentAnimation,
)
.then(this._createFillGapAnimation.bind(this))
.then(this._createCheckAnimation.bind(this));
}
}),
(t.prototype._createSpinAnimationWhile = function (e) {
var t = this;
return this._createSpinAnimation().then(function () {
return e() ? t._createSpinAnimationWhile(e) : Promise.resolve();
});
}),
(t.prototype._createSpinAnimation = function () {
var e = this;
return new Promise(function (t) {
Object(nt.doAnimate)({
onStep: function (t, n) {
void 0 !== e._currentAnimation &&
e.setState({ strokeDashOffset: n });
},
onComplete: function () {
return t();
},
from: 49.242997817993164,
to: 111.57590644836426,
easing: at.easingFunc.linear,
duration: 1e3,
});
});
}),
(t.prototype._createCheckAnimation = function () {
var e = this;
return new Promise(function (t) {
Object(nt.doAnimate)({
onStep: function (t, n) {
void 0 !== e._currentAnimation &&
e.setState({ strokeDashCheck: Math.round(n) });
},
onComplete: function () {
return t();
},
from: 0,
to: 200,
easing: at.easingFunc.linear,
duration: 1e3,
});
});
}),
(t.prototype._createFillGapAnimation = function () {
var e = this;
return new Promise(function (t) {
Object(nt.doAnimate)({
onStep: function (t, n) {
void 0 !== e._currentAnimation &&
e.setState({
strokeDashOffset: 62.956237716674806 - n,
strokeGap: n,
strokeDash: 62.956237716674806 - n,
});
},
onComplete: function () {
return t();
},
from: rt,
to: 0,
easing: at.easingFunc.linear,
duration: 200,
});
});
}),
t
);
})(r.PureComponent),
ut = n('nPPD'),
ht = n('MB0Y'),
dt = n('3j+J'),
vt = (Object(ut.a)(ht.a, dt), n('+KIV')),
mt = n('RGo6'),
pt = n('SchQ'),
ft = (n('OP2o'), n('v1bN')),
bt = i.enabled('widget'),
gt = Object(ut.a)(E.a, pt),
_t = {
copy: window.t('Copy'),
makeCopy: window.t('Make a Copy'),
newChartLayout: window.t('New Chart Layout'),
loadChartLayout: window.t('Load Chart Layout...'),
rename: window.t('Rename...'),
renameChartLayout: window.t('Rename Chart Layout'),
saveAs: window.t('Make a Copy...'),
saveChartLayout: window.t('Save'),
saveChartLayoutLong: window.t(
'Save all charts for all symbols and intervals on your layout',
),
manageChartLayouts: window.t('Manage Chart Layouts'),
},
Ct = [],
wt = Object(ie.b)({ keys: ['Ctrl', 'S'], text: '{0} + {1}' }),
St = (function (e) {
function t(t) {
var n = e.call(this, t) || this;
return (
(n._toolWidgetMenuRef = r.createRef()),
(n._handleTooltipWizardClick = function () {
0;
}),
(n._handleSaveHoverBegin = function () {
n.setState({ iconHovered: !0 });
}),
(n._handleSaveHoverEnd = function () {
n.setState({ iconHovered: !1 });
}),
(n.state = { iconHovered: !1 }),
n
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.id,
n = e.isReadOnly,
a = e.displayMode,
i = e.isProcessing,
o = e.title,
s = e.chartId,
l = e.wasChanges,
c = e.onCloneChart,
u = e.onSaveChart,
h = e.hideMenu,
d = e.isTabletSmall,
v = this.state.iconHovered,
m = !n && !h,
p = 'saved';
return (
(!l && o) || (p = 'unsaved'),
i && (p = 'saving'),
r.createElement(
M,
null,
n
? r.createElement(
M,
null,
r.createElement(G, {
id: t,
displayMode: a,
icon: r.createElement(w.Icon, { icon: vt }),
isDisabled: i,
onClick: c,
text: _t.copy,
title: _t.makeCopy,
onMouseEnter: this._handleSaveHoverBegin,
onMouseLeave: this._handleSaveHoverEnd,
collapseWhen: Ct,
}),
)
: r.createElement(
M,
null,
r.createElement(G, {
id: t,
className: k(mt.button, m && mt.buttonSmallPadding),
displayMode: a,
icon: r.createElement(ct, {
size: 28,
state: p,
isHovered: v,
}),
isDisabled: (s && !l) || i,
onClick: u,
text: o || _t.saveChartLayout,
title: _t.saveChartLayoutLong,
onMouseEnter: this._handleSaveHoverBegin,
onMouseLeave: this._handleSaveHoverEnd,
theme: gt,
collapseWhen: Ct,
'data-tooltip-hotkey': bt ? '' : wt,
}),
m &&
r.createElement(
y.a,
{
ref: this._toolWidgetMenuRef,
className: 'js-save-load-menu-open-button',
arrow: !0,
isDrawer: d,
drawerPosition: 'Bottom',
title: _t.manageChartLayouts,
},
!1,
this._renderMenuItems(Boolean(d)),
),
),
)
);
}),
(t.prototype._renderMenuItems = function (e) {
var t = this.props,
n = t.wasChanges,
a = t.isProcessing,
i = t.chartId,
o = t.onSaveChartFromMenu,
s = t.onRenameChart,
l = t.onSaveAsChart,
c = t.onLoadChart,
u =
(t.onNewChart,
t.isAutoSaveEnabled,
t.autoSaveId,
t.sharingId,
t.onAutoSaveChanged,
t.isSharingEnabled,
t.onSharingChanged,
e ? R.a : ft),
h = e ? void 0 : 'Ctrl+S',
d = [];
return (
d.push(
r.createElement(S.b, {
key: 'save',
isDisabled: Boolean(a || (!n && i)),
label: _t.saveChartLayout,
onClick: o,
shortcut: h,
labelRowClassName: k(e && mt.popupItemRowTabletSmall),
theme: u,
}),
),
void 0 !== i &&
(e ||
d.push(
r.createElement(A.a, {
key: 'existing-chart-section-begin',
}),
),
d.push.apply(d, [
r.createElement(S.b, {
key: 'rename',
label: _t.rename,
onClick: s,
labelRowClassName: k(e && mt.popupItemRowTabletSmall),
theme: u,
}),
r.createElement(S.b, {
key: 'save-as',
label: _t.saveAs,
onClick: l,
labelRowClassName: k(e && mt.popupItemRowTabletSmall),
theme: u,
}),
])),
d.push(r.createElement(A.a, { key: 'platform-section-begin' })),
d.push(
r.createElement(S.b, {
key: 'load-chart',
className: 'js-save-load-menu-item-load-chart',
label: _t.loadChartLayout,
onClick: c,
labelRowClassName: k(e && mt.popupItemRowTabletSmall),
theme: u,
}),
),
d
);
}),
t
);
})(r.PureComponent),
yt = Object(F.b)(),
kt = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
(a._syncState = function (e) {
a.setState(e);
}),
(a._onChangeHasChanges = function (e) {
a.state.wasChanges !== e && a.setState({ wasChanges: e });
}),
(a._onChangeAutoSaveEnabled = function (e) {
0;
}),
(a._onChangeSharingEnabled = function (e) {
a.setState({ isSharingEnabled: e });
}),
(a._onChangeTitle = function (e) {
a.setState({ title: e });
}),
(a._onChangeId = function (e) {
a.setState({ id: e });
}),
(a._onChartAboutToBeSaved = function () {
a.setState({ isProcessing: !0 });
}),
(a._onChartSaved = function () {
a.setState({ isProcessing: !1 });
}),
(a._handleAutoSaveEnabled = function (e) {
0;
}),
(a._handleSharingEnabled = function (e) {}),
(a._handleClickSave = function () {
a.context.saveChartService.saveChartOrShowTitleDialog(),
a._trackEvent('Save click');
}),
(a._handleClickSaveFromMenu = function () {
a.context.saveChartService.saveChartOrShowTitleDialog(),
a._trackEvent('Save From Menu');
}),
(a._handleClickClone = function () {
a.context.saveChartService.cloneChart();
}),
(a._handleClickSaveAs = function () {
a.context.saveChartService.saveChartAs(),
a._trackEvent('Make a copy');
}),
(a._handleClickNew = function () {
a._trackEvent('New chart layout');
}),
(a._handleClickLoad = function () {
a.context.loadChartService.showLoadDialog(),
a._trackEvent('Load chart layout');
}),
(a._handleHotkey = function () {
a.context.loadChartService.showLoadDialog();
}),
(a._handleClickRename = function () {
a.context.saveChartService.renameChart(),
a._trackEvent('Rename');
}),
Object(F.c)(n, {
chartWidgetCollection: l.any.isRequired,
chartChangesWatcher: l.any.isRequired,
saveChartService: l.any.isRequired,
sharingChartService: l.any,
loadChartService: l.any.isRequired,
});
var i = n.chartWidgetCollection,
o = n.chartChangesWatcher;
n.saveChartService, n.sharingChartService;
return (
(a.state = {
isAuthenticated: window.is_authenticated,
isProcessing: !1,
id: i.metaInfo.id.value(),
title: i.metaInfo.name.value(),
wasChanges: o.hasChanges(),
iconHovered: !1,
}),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.props,
t = e.chartSaver,
n = e.isFake,
a = e.stateSyncEmitter,
i = this.context,
o = i.chartWidgetCollection,
r = i.chartChangesWatcher;
i.saveChartService, i.sharingChartService;
n
? a.on('change', this._syncState)
: (r.getOnChange().subscribe(this, this._onChangeHasChanges),
o.metaInfo.name.subscribe(this._onChangeTitle),
o.metaInfo.id.subscribe(this._onChangeId),
(this._hotkeys = Object(tt.createGroup)({
desc: 'Save/Load',
})),
this._hotkeys.add({
desc: window.t('Load Chart Layout'),
handler: this._handleHotkey,
hotkey: 190,
}),
t.chartSaved().subscribe(this, this._onChartSaved),
t
.chartAboutToBeSaved()
.subscribe(this, this._onChartAboutToBeSaved),
window.loginStateChange.subscribe(
this,
this._onLoginStateChange,
));
}),
(t.prototype.componentDidUpdate = function (e, t) {
this.props.isFake ||
(t !== this.state &&
this.props.stateSyncEmitter.emit('change', this.state));
}),
(t.prototype.componentWillUnmount = function () {
var e = this.props,
t = e.chartSaver,
n = e.isFake,
a = e.stateSyncEmitter,
i = this.context,
o = i.chartWidgetCollection,
r = i.chartChangesWatcher;
i.saveChartService, i.sharingChartService;
n
? a.off('change', this._syncState)
: (r.getOnChange().unsubscribe(this, this._onChangeHasChanges),
o.metaInfo.name.unsubscribe(this._onChangeTitle),
o.metaInfo.id.unsubscribe(this._onChangeId),
Object(ae.ensureDefined)(this._hotkeys).destroy(),
t.chartSaved().unsubscribe(this, this._onChartSaved),
t
.chartAboutToBeSaved()
.unsubscribe(this, this._onChartAboutToBeSaved),
window.loginStateChange.unsubscribe(
this,
this._onLoginStateChange,
));
}),
(t.prototype.render = function () {
var e = this.props,
t = e.isReadOnly,
n = e.displayMode,
a = e.id,
i = (e.isFake, this.state),
s = i.isProcessing,
l = i.isAuthenticated,
c = i.title,
u = i.id,
h = i.wasChanges,
d =
(i.isAutoSaveEnabled,
i.isSharingEnabled,
{
displayMode: n,
isReadOnly: t,
isAuthenticated: l,
isProcessing: s,
wasChanges: h,
title: c,
id: a,
chartId: null !== u ? u : void 0,
onCloneChart: this._handleClickClone,
onSaveChart: this._handleClickSave,
onSaveChartFromMenu: this._handleClickSaveFromMenu,
onRenameChart: this._handleClickRename,
onSaveAsChart: this._handleClickSaveAs,
onLoadChart: this._handleClickLoad,
});
return r.createElement(
z.a,
{ rule: N.a.TabletSmall },
function (e) {
return r.createElement(
St,
Object(o.__assign)({}, d, { isTabletSmall: e }),
);
},
);
}),
(t.prototype._onLoginStateChange = function () {
this.setState({ isAuthenticated: window.is_authenticated });
}),
(t.prototype._trackEvent = function (e) {
0;
}),
(t.contextType = yt),
t
);
})(r.PureComponent),
xt = n('FQhm'),
Ot = { takeSnapshot: window.t('Take a snapshot') },
Mt = Object(ie.b)({ keys: ['Alt', 'S'], text: '{0} + {1}' }),
Et = Object(F.b)();
var jt,
Tt,
It = n('koZ+'),
At =
((jt = function (e) {
return r.createElement(E.b, {
id: e.id,
className: e.className,
isDisabled: e.isProcessing,
onClick: e.onClick,
title: e.tooltip,
'data-tooltip-hotkey': e.hotkey,
icon: It,
});
}),
((Tt = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._handleClick = function (e) {
if (!i.enabled('show_dialog_on_snapshot_ready')) {
if (a.state.isProcessing) return;
a.setState({ isProcessing: !0 }),
xt.subscribe(
'onScreenshotReady',
function () {
return a.setState({ isProcessing: !1 });
},
null,
!0,
);
}
a.context.chartWidgetCollection.takeScreenshot();
}),
Object(F.c)(n, { chartWidgetCollection: l.any.isRequired }),
(a.state = { isProcessing: !1 }),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.className,
n = e.id,
a = this.state.isProcessing;
return r.createElement(jt, {
id: n,
className: t,
isProcessing: a,
onClick: this._handleClick,
tooltip: Ot.takeSnapshot,
hotkey: Mt,
});
}),
t
);
})(r.PureComponent)).contextType = Et),
Tt),
zt = n('pZll'),
Nt = n('h24c'),
Rt = n('X7WP'),
Ft = (function (e) {
function t() {
var t = (null !== e && e.apply(this, arguments)) || this;
return (
(t._actions = null),
(t._input = null),
(t._promise = null),
(t._preventDefault = function (e) {
e.preventDefault();
}),
(t._trackSymbolSearchOpenEvent = function () {
Object(K.trackEvent)('GUI', 'SS', 'main search');
}),
(t._handleMobileButtonClick = function () {
0;
}),
t
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this,
t = Object(ae.ensureNotNull)(this._input),
n = (this._promise = Object(zt.symbolSearchUIService)()
.bindToInput(t, {
spreadActions: this._actions || void 0,
syncWithChartWidget: !0,
syncOnBlur: !0,
onPopupOpen: this._trackSymbolSearchOpenEvent,
})
.then(function () {
n === e._promise &&
null !== e._actions &&
Array.from(e._actions.querySelectorAll('button')).forEach(
function (e) {
return (e.tabIndex = -1);
},
);
}));
}),
(t.prototype.componentWillUnmount = function () {
this._promise = null;
}),
(t.prototype.render = function () {
var e,
t = this,
n = this.props,
a = n.isActionsVisible,
i = n.isExpanded,
o = n.onFocus,
s = n.onBlur,
l = n.id,
c = n.className;
return r.createElement(
'div',
{ id: l, className: k(Rt.wrap, c) },
r.createElement(
'div',
{
className: k(
Rt.inner,
((e = {}), (e[Rt.isExpanded] = i), e),
),
},
!1,
r.createElement('input', {
className: Rt.input,
maxLength: 1e3,
onBlur: s,
onFocus: o,
ref: function (e) {
return (t._input = e);
},
type: 'text',
tabIndex: -1,
}),
Object(Nt.canShowSpreadActions)() &&
a &&
r.createElement('div', {
className: Rt.actions,
onMouseDown: this._preventDefault,
ref: function (e) {
return (t._actions = e);
},
}),
),
);
}),
t
);
})(r.PureComponent),
Ht = n('jKyl'),
Wt = n('23di'),
Lt = Object(ut.a)(S.a, Wt),
Dt = { text: window.t('Save Indicator template...') };
function Pt(e) {
var t = e.onClick,
n = e.isTabletSmall;
return s.a.createElement(S.b, {
theme: Lt,
className: Wt.wrap,
label: s.a.createElement(
'div',
{ className: Wt.titleWrap },
s.a.createElement(
'div',
{ className: x()(Wt.title, n && Wt.titleTabletSmall) },
s.a.createElement(w.Icon, { className: Wt.icon, icon: Ht }),
s.a.createElement('div', { className: Wt.text }, Dt.text),
),
),
onClick: t,
});
}
var Vt = n('8RO/'),
Bt = n('s0T6');
function Ut(e) {
return r.createElement(
'div',
{ className: k(Bt.description, e.className) },
e.children,
);
}
var Gt = n('fESK'),
Kt = Object(ut.a)(S.a, {
labelRow: Gt.labelRow,
toolbox: Gt.toolbox,
item: Gt.titleItem,
}),
qt = Object(ut.a)(S.a, {
labelRow: Gt.labelRow,
toolbox: Gt.toolbox,
item: Gt.titleItemTabletSmall,
}),
Qt = Object(ut.a)(S.a, { item: Gt.item }),
Yt = Object(ut.a)(S.a, { item: Gt.itemTabletSmall });
function Jt(e) {
var t = e.item,
n = e.onApply,
a = e.onRemove,
i = e.onFavor,
l = e.favorite,
c = e.isFavoritingAllowed,
u = e.isTabletSmall,
h = Object(Re.b)(),
d = h[0],
v = h[1],
m = t.meta_info,
p = m ? Object(Vt.b)(m.indicators) : void 0,
f = u ? qt : Kt,
b = u ? Yt : Qt,
g = Object(r.useCallback)(
function () {
return n(t);
},
[n, t],
),
_ = Object(r.useCallback)(
function () {
return a(t);
},
[a, t],
),
w = Object(r.useCallback)(
function () {
i && i(t);
},
[i, t],
);
return s.a.createElement(
'div',
Object(o.__assign)({}, v, {
className: Gt.wrap,
'data-name': t.name,
'data-id': t.id,
'data-is-default': Boolean(t.is_default),
}),
s.a.createElement(S.b, {
theme: f,
label: t.name,
labelRowClassName: x()(u && Gt.itemLabelTabletSmall),
isHovered: d,
showToolboxOnHover: !l && !d,
onClick: g,
toolbox: s.a.createElement(
s.a.Fragment,
null,
!t.is_default &&
s.a.createElement(Ne.a, {
key: 'remove',
hidden: !Modernizr.touch && !d,
onClick: _,
}),
Boolean(i) &&
c &&
s.a.createElement(C.a, {
key: 'favorite',
isFilled: Boolean(l),
onClick: w,
}),
),
}),
p &&
s.a.createElement(S.b, {
theme: b,
label: s.a.createElement(
Ut,
{
className: x()(
Gt.description,
u && Gt.descriptionTabletSmall,
),
},
p,
),
onClick: g,
isHovered: d,
}),
);
}
var Xt = n('9NBK'),
Zt = (function (e) {
function t() {
var t = (null !== e && e.apply(this, arguments)) || this;
return (
(t._handleClick = function (e) {
e.stopPropagation();
var n = t.props;
(0, n.onApply)(n.item);
}),
t
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.render = function () {
var e = this.props,
t = e.className,
n = e.item;
return r.createElement(
'div',
{
className: k(t, Xt.item, 'apply-common-tooltip'),
onClick: this._handleClick,
title: n.name,
},
r.createElement(
'div',
{ className: Xt.round },
n.name.length > 0 ? n.name[0].toUpperCase() : ' ',
),
);
}),
t
);
})(r.PureComponent),
$t = n('gla1'),
en = n('PN6A'),
tn = n('zgWb'),
nn = n('yGrx'),
an = {
title: Object(V.t)('Templates'),
tooltip: Object(V.t)('Indicator Templates'),
},
on = s.a.createContext(null),
rn = Object(F.b)(),
sn = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
(a._handleFavorTemplate = function (e) {
if (a.props.isShownQuicks) {
var t = e.name;
a._isTemplateFavorite(t)
? a._removeFavoriteTemplate(t)
: a._addFavoriteTemplate(t);
}
}),
(a._handleSaveTemplate = function () {
a.context.studyTemplates.showSaveAsDialog();
}),
(a._handleApplyTemplate = function (e) {
a._handleClose(),
a.context.studyTemplates.applyTemplate(e.name);
}),
(a._handleRemoveTemplate = function (e) {
a._handleClose(),
a.context.studyTemplates.deleteStudyTemplate(e.name);
}),
(a._handleClose = function () {
a._handleToggleDropdown(!1);
}),
(a._handleToggleDropdown = function (e) {
var t = a.state.isActive,
n = 'boolean' == typeof e ? e : !t;
a.setState({ isActive: n });
}),
(a._handleDropdownOpen = function () {
var e = a.context.chartWidgetCollection.activeChartWidget
.value()
.model(),
t = Object(Vt.a)(e);
a.setState({ indicatorNames: Object(Vt.b)(t.indicators) });
}),
Object(F.c)(n, {
chartWidgetCollection: l.any.isRequired,
favoriteStudyTemplatesService: l.any,
studyTemplates: l.any.isRequired,
templatesMenuViewStateService: l.any,
});
var i = n.favoriteStudyTemplatesService,
o = n.studyTemplates,
r = void 0 !== i ? i.get() : [],
s = o.list();
return (
(a.state = { isActive: !1, studyTemplatesList: s, favorites: r }),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.context,
t = e.favoriteStudyTemplatesService,
n = e.studyTemplates;
n.getOnChange().subscribe(this, this._handleTemplatesChange),
n.refreshStudyTemplateList(),
void 0 !== t &&
t.getOnChange().subscribe(this, this._handleFavoritesChange);
}),
(t.prototype.componentWillUnmount = function () {
var e = this.context,
t = e.favoriteStudyTemplatesService;
e.studyTemplates
.getOnChange()
.unsubscribe(this, this._handleTemplatesChange),
void 0 !== t &&
t
.getOnChange()
.unsubscribe(this, this._handleFavoritesChange);
}),
(t.prototype.render = function () {
var e = this.state,
t = e.studyTemplatesList,
n = e.favorites,
a = this.props,
i = a.isShownQuicks,
o = a.className,
r = a.displayMode,
l = a.id;
return s.a.createElement(
on.Provider,
{ value: this.context.templatesMenuViewStateService || null },
s.a.createElement(ln, {
id: l,
className: o,
mode: r,
templates: t,
favorites: n,
onMenuOpen: this._handleDropdownOpen,
onTemplateFavorite: i ? this._handleFavorTemplate : void 0,
onTemplateSelect: this._handleApplyTemplate,
onTemplateRemove: this._handleRemoveTemplate,
onTemplateSave: this._handleSaveTemplate,
}),
);
}),
(t.prototype._handleTemplatesChange = function () {
this.setState({
studyTemplatesList: this.context.studyTemplates.list(),
});
}),
(t.prototype._handleFavoritesChange = function (e) {
this.props.isShownQuicks && this.setState({ favorites: e });
}),
(t.prototype._removeFavoriteTemplate = function (e) {
var t = this.context.favoriteStudyTemplatesService;
if (void 0 !== t) {
var n = this.state.favorites;
t.set(
n.filter(function (t) {
return t !== e;
}),
);
}
}),
(t.prototype._addFavoriteTemplate = function (e) {
var t = this.context.favoriteStudyTemplatesService;
if (void 0 !== t) {
var n = this.state.favorites;
t.set(Object(o.__spreadArrays)(n, [e]));
}
}),
(t.prototype._isTemplateFavorite = function (e) {
return this.state.favorites.includes(e);
}),
(t.contextType = rn),
t
);
})(s.a.PureComponent);
function ln(e) {
var t,
n = e.id,
a = e.className,
i = e.mode,
o = e.favorites,
r = e.templates,
l = e.isMenuOpen,
c = e.onTemplateSelect,
u = e.onTemplateSave,
h = e.onTemplateFavorite,
d = e.onTemplateRemove,
v = x()(
a,
nn.wrap,
(((t = {})[nn.full] = 'full' === i),
(t[nn.medium] = 'medium' === i),
t),
),
m = r.filter(function (e) {
return o.includes(e.name);
}),
p = 'small' !== i && h && m.length > 0;
return s.a.createElement(
M,
{ id: n, className: v },
s.a.createElement(z.a, { rule: N.a.TabletSmall }, function (t) {
return s.a.createElement(
y.a,
{
onOpen: e.onMenuOpen,
isDrawer: t,
drawerPosition: 'Bottom',
arrow: !1,
content: s.a.createElement(G, {
className: x()(p && nn.buttonWithFavorites),
displayMode: i,
isOpened: l,
icon: tn,
text: an.title,
title: an.tooltip,
forceInteractive: !0,
}),
},
s.a.createElement(cn, {
onTemplateSave: u,
onTemplateSelect: c,
onTemplateRemove: d,
onTemplateFavorite: h,
templates: r,
favorites: m,
className: x()(nn.menu, t && nn.menuSmallTablet),
isTabletSmall: t,
}),
);
}),
p && s.a.createElement(dn, { favorites: m, onTemplateSelect: c }),
);
}
function cn(e) {
var t = e.templates,
n = e.favorites,
a = e.onTemplateSave,
i = e.onTemplateRemove,
o = e.onTemplateSelect,
l = e.onTemplateFavorite,
c = e.className,
u = e.isTabletSmall,
h = Object(r.useMemo)(
function () {
return t.filter(function (e) {
return e.is_default;
});
},
[t],
),
d = Object(r.useMemo)(
function () {
return t.filter(function (e) {
return !e.is_default;
});
},
[t],
),
v = Object(r.useMemo)(
function () {
return new Set(
n.map(function (e) {
return e.name;
}),
);
},
[n],
),
m = Object(r.useContext)(on),
p = Object(r.useContext)(en.a),
f = Object($t.a)();
Object(r.useEffect)(function () {
if (null !== m) {
var e = {};
return (
m.getOnChange().subscribe(e, function () {
f(), p && p.update();
}),
function () {
return m.getOnChange().unsubscribeAll(e);
}
);
}
return function () {};
}, []);
var b = function (e) {
return s.a.createElement(Jt, {
key: e.name,
item: e,
isFavoritingAllowed: Boolean(l),
favorite: v.has(e.name),
onApply: o,
onFavor: l,
onRemove: i,
isTabletSmall: u,
});
};
return s.a.createElement(
'div',
{ className: c },
s.a.createElement(Pt, { onClick: a, isTabletSmall: u }),
u
? s.a.createElement(un, { defaults: h, customs: d, render: b })
: s.a.createElement(hn, {
defaults: h,
customs: d,
render: b,
state: m,
}),
);
}
function un(e) {
var t = e.defaults,
n = e.customs,
a = e.render;
return s.a.createElement(
s.a.Fragment,
null,
n.length > 0 &&
s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(A.a, null),
s.a.createElement(
me,
{ className: nn.menuItemHeaderTabletSmall },
Object(V.t)('My templates'),
),
n.map(a),
),
t.length > 0 &&
s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(A.a, null),
s.a.createElement(
me,
{ className: nn.menuItemHeaderTabletSmall },
Object(V.t)('Default templates'),
),
t.map(a),
),
);
}
function hn(e) {
var t = e.defaults,
n = e.customs,
a = e.render,
i = e.state;
return s.a.createElement(
s.a.Fragment,
null,
n.length > 0 &&
s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(A.a, null),
s.a.createElement(
me,
{ className: nn.menuItemHeader },
Object(V.t)('My templates'),
),
n.map(a),
),
n.length > 0 &&
t.length > 0 &&
i &&
s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(A.a, null),
s.a.createElement(
De,
{
summary: Object(V.t)('Default templates'),
open: !i.get().defaultsCollapsed,
onStateChange: function (e) {
return i.set({ defaultsCollapsed: !e });
},
},
t.map(a),
),
),
0 === n.length &&
t.length > 0 &&
s.a.createElement(
s.a.Fragment,
null,
s.a.createElement(A.a, null),
s.a.createElement(
me,
{ className: nn.menuItemHeader },
Object(V.t)('Default templates'),
),
t.map(a),
),
);
}
function dn(e) {
return s.a.createElement(
s.a.Fragment,
null,
e.favorites.map(function (t, n, a) {
var i;
return s.a.createElement(Zt, {
key: t.name,
item: t,
onApply: e.onTemplateSelect,
className: x()(
((i = {}),
(i[nn.first] = 0 === n),
(i[nn.last] = n === a.length - 1),
i),
),
});
}),
);
}
n('HbRj');
var vn = n('S+Ii'),
mn = n('bQ7Y'),
pn = n('wnRL'),
fn = n('2xRE'),
bn = { undoHint: window.t('Undo {0}'), redoHint: window.t('Redo {0}') },
gn = {
undoHotKey: Object(ie.b)({ keys: ['Ctrl', 'Z'], text: '{0} + {1}' }),
redoHotKey: Object(ie.b)({ keys: ['Ctrl', 'Y'], text: '{0} + {1}' }),
},
_n = Object(ut.b)(mn, vn, {
buttonUndo: 'button',
buttonRedo: 'button',
}),
Cn = Object(o.__assign)(Object(o.__assign)({}, mn), {
button: _n.buttonUndo,
}),
wn = Object(o.__assign)(Object(o.__assign)({}, mn), {
button: _n.buttonRedo,
}),
Sn = Object(F.b)(),
yn = (function (e) {
function t(t, n) {
var a = e.call(this, t, n) || this;
return (
(a._batched = null),
(a._handleClickUndo = function () {
Object(K.trackEvent)('GUI', 'Undo'),
a.context.chartWidgetCollection.undoHistory.undo();
}),
(a._handleClickRedo = function () {
Object(K.trackEvent)('GUI', 'Redo'),
a.context.chartWidgetCollection.undoHistory.redo();
}),
Object(F.c)(n, { chartWidgetCollection: l.any.isRequired }),
(a.state = a._getStateFromUndoHistory()),
a
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.context.chartWidgetCollection;
e.undoHistory
.redoStack()
.onChange()
.subscribe(this, this._onChangeStack),
e.undoHistory
.undoStack()
.onChange()
.subscribe(this, this._onChangeStack);
}),
(t.prototype.componentWillUnmount = function () {
var e = this.context.chartWidgetCollection;
e.undoHistory
.redoStack()
.onChange()
.unsubscribe(this, this._onChangeStack),
e.undoHistory
.undoStack()
.onChange()
.unsubscribe(this, this._onChangeStack),
(this._batched = null);
}),
(t.prototype.render = function () {
var e = this.props.id,
t = this.state,
n = t.isEnabledRedo,
a = t.isEnabledUndo,
i = t.redoStack,
o = t.undoStack;
return r.createElement(
M,
{ id: e },
r.createElement(E.b, {
icon: pn,
isDisabled: !a,
onClick: this._handleClickUndo,
title: a ? bn.undoHint.format(o) : void 0,
'data-tooltip-hotkey': a ? gn.undoHotKey : void 0,
theme: Cn,
}),
r.createElement(E.b, {
icon: fn,
isDisabled: !n,
onClick: this._handleClickRedo,
title: n ? bn.redoHint.format(i) : void 0,
'data-tooltip-hotkey': n ? gn.redoHotKey : void 0,
theme: wn,
}),
);
}),
(t.prototype._onChangeStack = function () {
var e = this;
null === this._batched &&
(this._batched = Promise.resolve().then(function () {
if (null !== e._batched) {
e._batched = null;
var t = e._getStateFromUndoHistory();
e.setState(t);
}
}));
}),
(t.prototype._getStateFromUndoHistory = function () {
var e = this.context.chartWidgetCollection,
t = e.undoHistory.undoStack(),
n = e.undoHistory.redoStack(),
a = n.head(),
i = t.head();
return {
isEnabledRedo: !n.isEmpty(),
isEnabledUndo: !t.isEmpty(),
redoStack: a ? a.text() : '',
undoStack: i ? i.text() : '',
};
}),
(t.contextType = Sn),
t
);
})(r.PureComponent),
kn = n('i8i4'),
xn = n('XmVn'),
On = (function (e) {
function t() {
var t = (null !== e && e.apply(this, arguments)) || this;
return (
(t._ref = null),
(t._update = function () {
t.forceUpdate();
}),
(t._setRef = function (e) {
t._ref = e;
}),
(t._handleMeasure = function (e) {
var n = e.width;
t.props.width.setValue(n);
}),
t
);
}
return (
Object(o.__extends)(t, e),
(t.prototype.componentDidMount = function () {
var e = this.props,
t = e.element,
n = e.isFake,
a = e.width;
if (n) a.subscribe(this._update);
else {
var i = Object(ae.ensureNotNull)(this._ref);
kn.findDOMNode(i).appendChild(t);
}
}),
(t.prototype.componentWillUnmount = function () {
var e = this.props,
t = e.width;
e.isFake && t.unsubscribe(this._update);
}),
(t.prototype.render = function () {
var e = this.props,
t = e.isFake,
n = void 0 !== t && t,
a = e.width;
return r.createElement(
xn,
{
shouldMeasure: !n,
whitelist: ['width'],
onMeasure: this._handleMeasure,
},
r.createElement(M, {
ref: this._setRef,
style: n ? { width: a.value() } : void 0,
}),
);
}),
t
);
})(r.PureComponent);
function Mn() {
return {
Bars: i.enabled('header_chart_type') ? P : void 0,
Compare: i.enabled('header_compare') ? J : void 0,
Custom: On,
Fullscreen: i.enabled('header_fullscreen_button') ? ne : void 0,
Indicators: i.enabled('header_indicators') ? Ce : void 0,
Intervals: i.enabled('header_resolutions') ? Ge : void 0,
OpenPopup: Je,
Properties:
i.enabled('header_settings') &&
i.enabled('show_chart_property_page')
? et
: void 0,
SaveLoad: i.enabled('header_saveload') ? kt : void 0,
Screenshot: i.enabled('header_screenshot') ? At : void 0,
SymbolSearch: i.enabled('header_symbol_search') ? Ft : void 0,
Templates: i.enabled('study_templates') ? sn : void 0,
UndoRedo: i.enabled('header_undo_redo') ? yn : void 0,
Layout: void 0,
};
}
n.d(t, 'getRestrictedToolSet', function () {
return Mn;
});
},
nrMg: function (e, t, n) {
e.exports = {
dottedCloud: 'dottedCloud-1Vw3lVny',
check: 'check-3V48_rMp',
spinningCloud: 'spinningCloud-2fkbB-rw',
arrow: 'arrow-1zkKEROH',
arrowGap: 'arrowGap-gjAe6jEn',
container: 'container-riYIb01a',
unsaved: 'unsaved-2Kg_w3Vw',
hovered: 'hovered-18DzoW0E',
saving: 'saving-31YVVfHU',
saved: 'saved-2kLd4nmd',
};
},
pqsj: function (e, t) {
e.exports =
'';
},
pr86: function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return h;
});
var a = n('mrSG'),
i = (n('YFKU'), n('q1tI')),
o = n('TSYQ'),
r = n('Iivm'),
s = n('sg5d'),
l = n('XfUw'),
c = n('fEjm'),
u = {
add: window.t('Add to favorites'),
remove: window.t('Remove from favorites'),
};
function h(e) {
var t = e.className,
n = e.isFilled,
h = e.isActive,
d = e.onClick,
v = Object(a.__rest)(e, [
'className',
'isFilled',
'isActive',
'onClick',
]);
return i.createElement(
r.Icon,
Object(a.__assign)({}, v, {
className: o(
c.favorite,
'apply-common-tooltip',
n && c.checked,
h && c.active,
t,
),
icon: n ? s : l,
onClick: d,
title: n ? u.remove : u.add,
}),
);
}
},
s0T6: function (e, t, n) {
e.exports = { description: 'description-3yVDcIyu' };
},
sHKj: function (e, t, n) {
e.exports = { title: 'title-17mjZSJk' };
},
sbT4: function (e, t, n) {
e.exports = { button: 'button-3wAyKO3i' };
},
sg5d: function (e, t) {
e.exports =
'';
},
t2Sj: function (e, t) {
e.exports =
'';
},
uafl: function (e, t) {
e.exports =
'';
},
uhCe: function (e, t, n) {
'use strict';
n.d(t, 'a', function () {
return i;
});
var a = n('ASyk'),
i = {
SmallHeight: a['small-height-breakpoint'],
TabletSmall: a['tablet-small-breakpoint'],
TabletNormal: a['tablet-normal-breakpoint'],
};
},
wnRL: function (e, t) {
e.exports =
'';
},
yGrx: function (e, t, n) {
e.exports = {
wrap: 'wrap-15BhAobm',
full: 'full-2VMT2UlC',
first: 'first-1vAzGgSq',
last: 'last-xMjAcadb',
medium: 'medium-1BEsHMFf',
loader: 'loader-1uURoPBh',
buttonWithFavorites: 'buttonWithFavorites-3S-vuMxR',
menu: 'menu-pdQdEiwV',
menuSmallTablet: 'menuSmallTablet-tXzCU-3p',
menuItemHeader: 'menuItemHeader-228dcYv3',
menuItemHeaderTabletSmall: 'menuItemHeaderTabletSmall-QIvgZc1i',
};
},
zgWb: function (e, t) {
e.exports =
'';
},
},
]);