@oanda/labs-sentiment-widget 1.0.173 → 1.0.175
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +1372 -0
- package/dist/main/SentimentWidget/SentimentWidget.js +10 -10
- package/dist/main/SentimentWidget/SentimentWidget.js.map +1 -1
- package/dist/main/SentimentWidget/Tool.js +19 -18
- package/dist/main/SentimentWidget/Tool.js.map +1 -1
- package/dist/main/SentimentWidget/Widget.js +17 -16
- package/dist/main/SentimentWidget/Widget.js.map +1 -1
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js +13 -13
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/main/SentimentWidget/render.js +9 -9
- package/dist/main/SentimentWidget/render.js.map +1 -1
- package/dist/main/SentimentWidget/types.js.map +1 -1
- package/dist/main/SentimentWidget/utils.js.map +1 -1
- package/dist/main/gql/getInstrumentSentiment.js +3 -19
- package/dist/main/gql/getInstrumentSentiment.js.map +1 -1
- package/dist/main/gql/getSentimentList.js +3 -17
- package/dist/main/gql/getSentimentList.js.map +1 -1
- package/dist/main/gql/types/fragment-masking.js +3 -2
- package/dist/main/gql/types/fragment-masking.js.map +1 -1
- package/dist/main/gql/types/gql.js +4 -3
- package/dist/main/gql/types/gql.js.map +1 -1
- package/dist/main/gql/types/graphql.js +154 -154
- package/dist/main/gql/types/graphql.js.map +1 -1
- package/dist/main/gql/types/index.js.map +1 -1
- package/dist/main/index.js +8 -8
- package/dist/main/index.js.map +1 -1
- package/dist/main/translations/index.js +1 -1
- package/dist/main/translations/index.js.map +1 -1
- package/dist/main/translations/translations.js.map +1 -1
- package/dist/module/SentimentWidget/SentimentWidget.js +10 -10
- package/dist/module/SentimentWidget/SentimentWidget.js.map +1 -1
- package/dist/module/SentimentWidget/Tool.js +18 -17
- package/dist/module/SentimentWidget/Tool.js.map +1 -1
- package/dist/module/SentimentWidget/Widget.js +18 -17
- package/dist/module/SentimentWidget/Widget.js.map +1 -1
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js +13 -13
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/module/SentimentWidget/render.js +9 -9
- package/dist/module/SentimentWidget/render.js.map +1 -1
- package/dist/module/SentimentWidget/types.js.map +1 -1
- package/dist/module/SentimentWidget/utils.js.map +1 -1
- package/dist/module/gql/getInstrumentSentiment.js +3 -19
- package/dist/module/gql/getInstrumentSentiment.js.map +1 -1
- package/dist/module/gql/getSentimentList.js +3 -17
- package/dist/module/gql/getSentimentList.js.map +1 -1
- package/dist/module/gql/types/fragment-masking.js +3 -2
- package/dist/module/gql/types/fragment-masking.js.map +1 -1
- package/dist/module/gql/types/gql.js +4 -3
- package/dist/module/gql/types/gql.js.map +1 -1
- package/dist/module/gql/types/graphql.js +154 -154
- package/dist/module/gql/types/graphql.js.map +1 -1
- package/dist/module/gql/types/index.js +2 -2
- package/dist/module/gql/types/index.js.map +1 -1
- package/dist/module/index.js +1 -1
- package/dist/module/index.js.map +1 -1
- package/dist/module/translations/index.js +1 -1
- package/dist/module/translations/index.js.map +1 -1
- package/dist/module/translations/translations.js.map +1 -1
- package/dist/types/SentimentWidget/SentimentWidget.d.ts +1 -1
- package/dist/types/SentimentWidget/Tool.d.ts +1 -1
- package/dist/types/SentimentWidget/Widget.d.ts +1 -1
- package/dist/types/SentimentWidget/components/SortSwitch/SortSwitch.d.ts +2 -2
- package/dist/types/SentimentWidget/types.d.ts +2 -2
- package/dist/types/SentimentWidget/utils.d.ts +2 -1
- package/dist/types/gql/types/gql.d.ts +4 -4
- package/dist/types/gql/types/index.d.ts +2 -2
- package/dist/types/index.d.ts +1 -1
- package/dist/types/translations/index.d.ts +2 -2
- package/package.json +3 -3
- package/src/SentimentWidget/SentimentWidget.tsx +18 -19
- package/src/SentimentWidget/Tool.tsx +94 -78
- package/src/SentimentWidget/Widget.tsx +70 -64
- package/src/SentimentWidget/components/SortSwitch/SortSwitch.tsx +41 -38
- package/src/SentimentWidget/render.tsx +40 -28
- package/src/SentimentWidget/types.ts +3 -2
- package/src/SentimentWidget/utils.ts +12 -4
- package/src/gql/getInstrumentSentiment.ts +2 -8
- package/src/gql/getSentimentList.ts +2 -6
- package/src/gql/types/fragment-masking.ts +41 -21
- package/src/gql/types/gql.ts +12 -5
- package/src/gql/types/graphql.ts +225 -47
- package/src/gql/types/index.ts +2 -2
- package/src/index.ts +1 -1
- package/src/translations/index.ts +4 -4
- package/src/translations/translations.ts +2 -1
- package/test/SortSwitch.test.tsx +11 -7
- package/test/Tool.test.tsx +8 -6
- package/test/Widget.test.tsx +26 -21
- package/test/sortData.test.ts +49 -13
package/dist/main/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["
|
|
1
|
+
{"version":3,"file":"index.js","names":["_SentimentWidget","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_types"],"sources":["../../src/index.ts"],"sourcesContent":["export * from './SentimentWidget/SentimentWidget';\nexport * from './SentimentWidget/types';\n"],"mappings":";;;;;AAAA,IAAAA,gBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,gBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,gBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,gBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,MAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,MAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,MAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,MAAA,CAAAL,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
|
|
@@ -6,9 +6,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.translations = void 0;
|
|
7
7
|
var _monoI18n = require("@oanda/mono-i18n");
|
|
8
8
|
var _en = _interopRequireDefault(require("./sources/en.json"));
|
|
9
|
-
var _zh_TW = _interopRequireDefault(require("./sources/zh_TW.json"));
|
|
10
9
|
var _es = _interopRequireDefault(require("./sources/es.json"));
|
|
11
10
|
var _th = _interopRequireDefault(require("./sources/th.json"));
|
|
11
|
+
var _zh_TW = _interopRequireDefault(require("./sources/zh_TW.json"));
|
|
12
12
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
13
13
|
const translations = exports.translations = {
|
|
14
14
|
[_monoI18n.Locale.en]: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["_monoI18n","require","_en","_interopRequireDefault","
|
|
1
|
+
{"version":3,"file":"index.js","names":["_monoI18n","require","_en","_interopRequireDefault","_es","_th","_zh_TW","e","__esModule","default","translations","exports","Locale","en","translation","zhTW","es","th"],"sources":["../../../src/translations/index.ts"],"sourcesContent":["import type { Translations } from '@oanda/mono-i18n';\nimport { Locale } from '@oanda/mono-i18n';\n\nimport en from './sources/en.json';\nimport es from './sources/es.json';\nimport th from './sources/th.json';\nimport zhTW from './sources/zh_TW.json';\nimport type { defaultTranslations } from './translations';\n\nexport type TranslationKey = keyof typeof defaultTranslations;\n\nexport const translations: Translations = {\n [Locale.en]: { translation: en },\n [Locale.zhTW]: { translation: zhTW },\n [Locale.es]: { translation: es },\n [Locale.th]: { translation: th },\n};\n"],"mappings":";;;;;;AACA,IAAAA,SAAA,GAAAC,OAAA;AAEA,IAAAC,GAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,GAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,GAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,MAAA,GAAAH,sBAAA,CAAAF,OAAA;AAAwC,SAAAE,uBAAAI,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAKjC,MAAMG,YAA0B,GAAAC,OAAA,CAAAD,YAAA,GAAG;EACxC,CAACE,gBAAM,CAACC,EAAE,GAAG;IAAEC,WAAW,EAAED;EAAG,CAAC;EAChC,CAACD,gBAAM,CAACG,IAAI,GAAG;IAAED,WAAW,EAAEC;EAAK,CAAC;EACpC,CAACH,gBAAM,CAACI,EAAE,GAAG;IAAEF,WAAW,EAAEE;EAAG,CAAC;EAChC,CAACJ,gBAAM,CAACK,EAAE,GAAG;IAAEH,WAAW,EAAEG;EAAG;AACjC,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"translations.js","names":["defaultTranslations","exports","data_unavailable","pagination_entries_range"],"sources":["../../../src/translations/translations.ts"],"sourcesContent":["export const defaultTranslations = {\n data_unavailable: 'Data unavailable',\n pagination_entries_range
|
|
1
|
+
{"version":3,"file":"translations.js","names":["defaultTranslations","exports","data_unavailable","pagination_entries_range"],"sources":["../../../src/translations/translations.ts"],"sourcesContent":["export const defaultTranslations = {\n data_unavailable: 'Data unavailable',\n pagination_entries_range:\n '{{firstItemOnPage}}-{{lastItemOnPage}} of {{itemCount}} entries',\n};\n"],"mappings":";;;;;;AAAO,MAAMA,mBAAmB,GAAAC,OAAA,CAAAD,mBAAA,GAAG;EACjCE,gBAAgB,EAAE,kBAAkB;EACpCC,wBAAwB,EACtB;AACJ,CAAC","ignoreList":[]}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import { ApolloClient, InMemoryCache } from '@apollo/client';
|
|
3
2
|
import { WidgetProvider, WidgetWrapper } from '@oanda/labs-widget-common';
|
|
4
|
-
import
|
|
5
|
-
import { Tool } from './Tool';
|
|
3
|
+
import React from 'react';
|
|
6
4
|
import { translations } from '../translations';
|
|
5
|
+
import { Tool } from './Tool';
|
|
6
|
+
import { Widget } from './Widget';
|
|
7
7
|
const SentimentWidget = _ref => {
|
|
8
8
|
let {
|
|
9
9
|
graphqlUrl,
|
|
@@ -20,18 +20,18 @@ const SentimentWidget = _ref => {
|
|
|
20
20
|
cache: new InMemoryCache()
|
|
21
21
|
});
|
|
22
22
|
return React.createElement(WidgetProvider, {
|
|
23
|
-
locale: locale,
|
|
24
|
-
translations: translations,
|
|
25
23
|
client: client,
|
|
26
|
-
|
|
24
|
+
locale: locale,
|
|
25
|
+
theme: theme,
|
|
26
|
+
translations: translations
|
|
27
27
|
}, React.createElement(WidgetWrapper, {
|
|
28
|
-
|
|
28
|
+
isParamError: isParamError,
|
|
29
29
|
linkArea: "logo",
|
|
30
|
-
|
|
30
|
+
logoLink: logoLink
|
|
31
31
|
}, instrument ? React.createElement(Widget, {
|
|
32
32
|
division: division,
|
|
33
|
-
|
|
34
|
-
|
|
33
|
+
includeDescriptionLabels: includeDescriptionLabels,
|
|
34
|
+
instrument: instrument
|
|
35
35
|
}) : React.createElement(Tool, {
|
|
36
36
|
division: division
|
|
37
37
|
})));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SentimentWidget.js","names":["
|
|
1
|
+
{"version":3,"file":"SentimentWidget.js","names":["ApolloClient","InMemoryCache","WidgetProvider","WidgetWrapper","React","translations","Tool","Widget","SentimentWidget","_ref","graphqlUrl","division","instrument","locale","theme","includeDescriptionLabels","isParamError","logoLink","client","uri","cache","createElement","linkArea"],"sources":["../../../src/SentimentWidget/SentimentWidget.tsx"],"sourcesContent":["import { ApolloClient, InMemoryCache } from '@apollo/client';\nimport { WidgetProvider, WidgetWrapper } from '@oanda/labs-widget-common';\nimport React from 'react';\n\nimport { translations } from '../translations';\nimport { Tool } from './Tool';\nimport type { SentimentConfig } from './types';\nimport { Widget } from './Widget';\n\nconst SentimentWidget = ({\n graphqlUrl,\n division,\n instrument,\n locale,\n theme,\n includeDescriptionLabels,\n isParamError,\n logoLink,\n}: SentimentConfig) => {\n const client = new ApolloClient({\n uri: graphqlUrl,\n cache: new InMemoryCache(),\n });\n\n return (\n <WidgetProvider\n client={client}\n locale={locale}\n theme={theme}\n translations={translations}\n >\n <WidgetWrapper\n isParamError={isParamError}\n linkArea=\"logo\"\n logoLink={logoLink}\n >\n {instrument ? (\n <Widget\n division={division}\n includeDescriptionLabels={includeDescriptionLabels}\n instrument={instrument}\n />\n ) : (\n <Tool division={division} />\n )}\n </WidgetWrapper>\n </WidgetProvider>\n );\n};\n\nexport { SentimentWidget };\n"],"mappings":"AAAA,SAASA,YAAY,EAAEC,aAAa,QAAQ,gBAAgB;AAC5D,SAASC,cAAc,EAAEC,aAAa,QAAQ,2BAA2B;AACzE,OAAOC,KAAK,MAAM,OAAO;AAEzB,SAASC,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,IAAI,QAAQ,QAAQ;AAE7B,SAASC,MAAM,QAAQ,UAAU;AAEjC,MAAMC,eAAe,GAAGC,IAAA,IASD;EAAA,IATE;IACvBC,UAAU;IACVC,QAAQ;IACRC,UAAU;IACVC,MAAM;IACNC,KAAK;IACLC,wBAAwB;IACxBC,YAAY;IACZC;EACe,CAAC,GAAAR,IAAA;EAChB,MAAMS,MAAM,GAAG,IAAIlB,YAAY,CAAC;IAC9BmB,GAAG,EAAET,UAAU;IACfU,KAAK,EAAE,IAAInB,aAAa,CAAC;EAC3B,CAAC,CAAC;EAEF,OACEG,KAAA,CAAAiB,aAAA,CAACnB,cAAc;IACbgB,MAAM,EAAEA,MAAO;IACfL,MAAM,EAAEA,MAAO;IACfC,KAAK,EAAEA,KAAM;IACbT,YAAY,EAAEA;EAAa,GAE3BD,KAAA,CAAAiB,aAAA,CAAClB,aAAa;IACZa,YAAY,EAAEA,YAAa;IAC3BM,QAAQ,EAAC,MAAM;IACfL,QAAQ,EAAEA;EAAS,GAElBL,UAAU,GACTR,KAAA,CAAAiB,aAAA,CAACd,MAAM;IACLI,QAAQ,EAAEA,QAAS;IACnBI,wBAAwB,EAAEA,wBAAyB;IACnDH,UAAU,EAAEA;EAAW,CACxB,CAAC,GAEFR,KAAA,CAAAiB,aAAA,CAACf,IAAI;IAACK,QAAQ,EAAEA;EAAS,CAAE,CAEhB,CACD,CAAC;AAErB,CAAC;AAED,SAASH,eAAe","ignoreList":[]}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import React, { useEffect, useState } from 'react';
|
|
2
|
-
import classNames from 'classnames';
|
|
3
|
-
import { Sentiment, SentimentHeight, Loader, LoaderSize, ChartError, Truncate, Tooltip, useLayoutProvider, Size, EMPTY_VALUE, LastUpdated } from '@oanda/labs-widget-common';
|
|
4
1
|
import { useQuery } from '@apollo/client';
|
|
2
|
+
import { ChartError, EMPTY_VALUE, LastUpdated, Loader, LoaderSize, Sentiment, SentimentHeight, Size, Tooltip, Truncate, useLayoutProvider } from '@oanda/labs-widget-common';
|
|
5
3
|
import { useLocale } from '@oanda/mono-i18n';
|
|
4
|
+
import classNames from 'classnames';
|
|
5
|
+
import React, { useEffect, useState } from 'react';
|
|
6
|
+
import { INSTRUMENT_TOOLTIP_ID } from '../constant';
|
|
6
7
|
import { getSentimentList } from '../gql/getSentimentList';
|
|
7
|
-
import { sortData } from './utils';
|
|
8
|
-
import { SelectedArrow, SortSwitch } from './components/SortSwitch';
|
|
9
8
|
import { Sort } from '../gql/types/graphql';
|
|
10
|
-
import {
|
|
9
|
+
import { SelectedArrow, SortSwitch } from './components/SortSwitch';
|
|
10
|
+
import { sortData } from './utils';
|
|
11
11
|
const Tool = _ref => {
|
|
12
12
|
let {
|
|
13
13
|
division
|
|
@@ -34,13 +34,14 @@ const Tool = _ref => {
|
|
|
34
34
|
const [updatedTimestamp, setUpdatedTimestamp] = useState(EMPTY_VALUE);
|
|
35
35
|
useEffect(() => {
|
|
36
36
|
if (data) {
|
|
37
|
+
var _;
|
|
37
38
|
setSortedData(sortData(data, sort));
|
|
38
|
-
setUpdatedTimestamp(data.sentimentList[0]
|
|
39
|
+
setUpdatedTimestamp((_ = data.sentimentList[0]) === null || _ === void 0 ? void 0 : _.updatedAt);
|
|
39
40
|
}
|
|
40
41
|
}, [data, sort]);
|
|
41
42
|
return React.createElement(React.Fragment, null, size && React.createElement("div", {
|
|
42
|
-
|
|
43
|
-
|
|
43
|
+
className: "lw-relative lw-bg-bg-primary lw-text-sm lw-tracking-normal lw-text-text-primary",
|
|
44
|
+
"data-testid": "sentiment-tool"
|
|
44
45
|
}, error || sortedData.length === 0 ? React.createElement("div", {
|
|
45
46
|
className: "lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-border-primary lw-p-2"
|
|
46
47
|
}, React.createElement(ChartError, null)) : React.createElement(React.Fragment, null, React.createElement("div", {
|
|
@@ -64,28 +65,28 @@ const Tool = _ref => {
|
|
|
64
65
|
'lw-mr-10': isDesktop
|
|
65
66
|
})
|
|
66
67
|
}, lang('net_long'))), sortedData.map((item, index) => React.createElement("div", {
|
|
67
|
-
|
|
68
|
-
|
|
68
|
+
key: item.name || index,
|
|
69
|
+
className: "lw-flex lw-h-8 lw-w-full lw-items-center"
|
|
69
70
|
}, React.createElement("div", {
|
|
70
71
|
className: "lw-w-[120px] lw-shrink-0"
|
|
71
72
|
}, loading ? React.createElement(Loader, {
|
|
72
73
|
size: LoaderSize.md
|
|
73
74
|
}) : React.createElement(Truncate, {
|
|
74
|
-
maxWidth: 120,
|
|
75
|
-
tooltipId: INSTRUMENT_TOOLTIP_ID,
|
|
76
75
|
className: "lw-pr-2 lw-font-sans lw-text-sm lw-font-bold",
|
|
77
|
-
|
|
76
|
+
maxWidth: 120,
|
|
77
|
+
text: item.displayName || '\u2014',
|
|
78
|
+
tooltipId: INSTRUMENT_TOOLTIP_ID
|
|
78
79
|
})), React.createElement(Sentiment, {
|
|
79
|
-
isLoading: loading,
|
|
80
80
|
height: SentimentHeight.md,
|
|
81
|
+
isLoading: loading,
|
|
81
82
|
sentiment: item.sentiment
|
|
82
83
|
}))))), React.createElement(Tooltip, {
|
|
83
84
|
id: INSTRUMENT_TOOLTIP_ID
|
|
84
85
|
}), !error && React.createElement("div", {
|
|
85
86
|
className: "lw-mt-2 lw-h-8"
|
|
86
87
|
}, React.createElement(LastUpdated, {
|
|
87
|
-
|
|
88
|
-
|
|
88
|
+
labelCallback: lang,
|
|
89
|
+
timestamp: updatedTimestamp
|
|
89
90
|
}))));
|
|
90
91
|
};
|
|
91
92
|
export { Tool };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tool.js","names":["
|
|
1
|
+
{"version":3,"file":"Tool.js","names":["useQuery","ChartError","EMPTY_VALUE","LastUpdated","Loader","LoaderSize","Sentiment","SentimentHeight","Size","Tooltip","Truncate","useLayoutProvider","useLocale","classNames","React","useEffect","useState","INSTRUMENT_TOOLTIP_ID","getSentimentList","Sort","SelectedArrow","SortSwitch","sortData","Tool","_ref","division","size","isDesktop","DESKTOP","sort","setSort","Bullish","sortedData","setSortedData","Array","fill","loading","data","error","variables","fetchPolicy","lang","updatedTimestamp","setUpdatedTimestamp","_","sentimentList","updatedAt","createElement","Fragment","className","length","disabled","selected","UP","DOWN","onClickButtonDown","Bearish","onClickButtonUp","map","item","index","key","name","md","maxWidth","text","displayName","tooltipId","height","isLoading","sentiment","id","labelCallback","timestamp"],"sources":["../../../src/SentimentWidget/Tool.tsx"],"sourcesContent":["import { useQuery } from '@apollo/client';\nimport {\n ChartError,\n EMPTY_VALUE,\n LastUpdated,\n Loader,\n LoaderSize,\n Sentiment,\n SentimentHeight,\n Size,\n Tooltip,\n Truncate,\n useLayoutProvider,\n} from '@oanda/labs-widget-common';\nimport { useLocale } from '@oanda/mono-i18n';\nimport classNames from 'classnames';\nimport React, { useEffect, useState } from 'react';\n\nimport { INSTRUMENT_TOOLTIP_ID } from '../constant';\nimport { getSentimentList } from '../gql/getSentimentList';\nimport type {\n GetSentimentListQuery,\n GetSentimentListQueryVariables,\n SentimentInstrument,\n} from '../gql/types/graphql';\nimport { Sort } from '../gql/types/graphql';\nimport { SelectedArrow, SortSwitch } from './components/SortSwitch';\nimport type { SentimentToolConfig } from './types';\nimport { sortData } from './utils';\n\nconst Tool = ({ division }: SentimentToolConfig) => {\n const { size } = useLayoutProvider();\n const isDesktop = size === Size.DESKTOP;\n const [sort, setSort] = useState(Sort.Bullish);\n const [sortedData, setSortedData] = useState<\n Omit<SentimentInstrument, 'id'>[]\n >(new Array(20).fill({}));\n const { loading, data, error } = useQuery<\n GetSentimentListQuery,\n GetSentimentListQueryVariables\n >(getSentimentList, {\n variables: {\n division,\n },\n fetchPolicy: 'cache-and-network',\n });\n\n const { lang } = useLocale();\n const [updatedTimestamp, setUpdatedTimestamp] = useState(EMPTY_VALUE);\n\n useEffect(() => {\n if (data) {\n setSortedData(sortData(data, sort));\n setUpdatedTimestamp(data.sentimentList![0]?.updatedAt);\n }\n }, [data, sort]);\n\n return (\n <>\n {size && (\n <div\n className=\"lw-relative lw-bg-bg-primary lw-text-sm lw-tracking-normal lw-text-text-primary\"\n data-testid=\"sentiment-tool\"\n >\n {error || sortedData.length === 0 ? (\n <div className=\"lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-border-primary lw-p-2\">\n <ChartError />\n </div>\n ) : (\n <>\n <div className=\"lw-flex lw-justify-end lw-pb-5\">\n <SortSwitch\n disabled={loading}\n selected={\n sort === Sort.Bullish\n ? SelectedArrow.UP\n : SelectedArrow.DOWN\n }\n onClickButtonDown={() => setSort(Sort.Bearish)}\n onClickButtonUp={() => setSort(Sort.Bullish)}\n />\n </div>\n <div className=\"lw-flex lw-flex-col lw-border lw-border-solid lw-border-border-primary lw-p-2\">\n <div className=\"lw-mb-2 lw-flex lw-justify-between lw-font-semibold\">\n <span\n className={classNames('lw-uppercase', {\n 'lw-ml-40': isDesktop,\n 'lw-ml-[7.5rem]': !isDesktop,\n })}\n >\n {lang('net_short')}\n </span>\n <span\n className={classNames('lw-text-right lw-uppercase', {\n 'lw-mr-10': isDesktop,\n })}\n >\n {lang('net_long')}\n </span>\n </div>\n {sortedData.map((item, index) => (\n <div\n key={item.name || index}\n className=\"lw-flex lw-h-8 lw-w-full lw-items-center\"\n >\n <div className=\"lw-w-[120px] lw-shrink-0\">\n {loading ? (\n <Loader size={LoaderSize.md} />\n ) : (\n <Truncate\n className=\"lw-pr-2 lw-font-sans lw-text-sm lw-font-bold\"\n maxWidth={120}\n text={item.displayName || '\\u2014'}\n tooltipId={INSTRUMENT_TOOLTIP_ID}\n />\n )}\n </div>\n <Sentiment\n height={SentimentHeight.md}\n isLoading={loading}\n sentiment={item.sentiment}\n />\n </div>\n ))}\n </div>\n </>\n )}\n <Tooltip id={INSTRUMENT_TOOLTIP_ID} />\n {!error && (\n <div className=\"lw-mt-2 lw-h-8\">\n <LastUpdated labelCallback={lang} timestamp={updatedTimestamp} />\n </div>\n )}\n </div>\n )}\n </>\n );\n};\n\nexport { Tool };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import classNames from 'classnames';
|
|
3
|
-
import { Sentiment, SentimentHeight, Error, Loader, LoaderSize, Truncate, useLayoutProvider, Size, LastUpdated } from '@oanda/labs-widget-common';
|
|
4
|
-
import { useLocale } from '@oanda/mono-i18n';
|
|
5
1
|
import { useQuery } from '@apollo/client';
|
|
6
|
-
import {
|
|
2
|
+
import { Error, LastUpdated, Loader, LoaderSize, Sentiment, SentimentHeight, Size, Truncate, useLayoutProvider } from '@oanda/labs-widget-common';
|
|
3
|
+
import { useLocale } from '@oanda/mono-i18n';
|
|
4
|
+
import classNames from 'classnames';
|
|
5
|
+
import React from 'react';
|
|
7
6
|
import { INSTRUMENT_TOOLTIP_ID } from '../constant';
|
|
7
|
+
import { getInstrumentSentiment } from '../gql/getInstrumentSentiment';
|
|
8
8
|
const Widget = _ref => {
|
|
9
|
+
var _data$sentiment;
|
|
9
10
|
let {
|
|
10
11
|
instrument,
|
|
11
12
|
division,
|
|
@@ -33,11 +34,11 @@ const Widget = _ref => {
|
|
|
33
34
|
displayName,
|
|
34
35
|
sentiment,
|
|
35
36
|
updatedAt
|
|
36
|
-
} = data
|
|
37
|
-
const isError = error || sentiment
|
|
37
|
+
} = (data === null || data === void 0 || (_data$sentiment = data.sentiment) === null || _data$sentiment === void 0 ? void 0 : _data$sentiment[0]) || {};
|
|
38
|
+
const isError = error || (sentiment === null || sentiment === void 0 ? void 0 : sentiment.shortPercent) === 0 && (sentiment === null || sentiment === void 0 ? void 0 : sentiment.longPercent) === 0 || (sentiment === null || sentiment === void 0 ? void 0 : sentiment.shortPercent) === undefined || (sentiment === null || sentiment === void 0 ? void 0 : sentiment.longPercent) === undefined;
|
|
38
39
|
return React.createElement(React.Fragment, null, size && React.createElement(React.Fragment, null, React.createElement("div", {
|
|
39
|
-
|
|
40
|
-
|
|
40
|
+
className: "lw-border lw-border-solid lw-border-border-primary lw-bg-bg-primary lw-p-4 lw-text-sm lw-tracking-normal lw-text-text-primary",
|
|
41
|
+
"data-testid": "sentiment-widget"
|
|
41
42
|
}, includeDescriptionLabels && !isError && React.createElement("div", {
|
|
42
43
|
className: "lw-mb-2 lw-flex lw-justify-between lw-font-semibold"
|
|
43
44
|
}, React.createElement("span", {
|
|
@@ -56,20 +57,20 @@ const Widget = _ref => {
|
|
|
56
57
|
}, loading && React.createElement(Loader, {
|
|
57
58
|
size: LoaderSize.md
|
|
58
59
|
}), !loading && !isError && React.createElement(Truncate, {
|
|
59
|
-
maxWidth: 120,
|
|
60
|
-
tooltipId: INSTRUMENT_TOOLTIP_ID,
|
|
61
60
|
className: "lw-pr-2 lw-font-sans lw-text-sm lw-font-bold",
|
|
62
|
-
|
|
61
|
+
maxWidth: 120,
|
|
62
|
+
text: displayName || '\u2014',
|
|
63
|
+
tooltipId: INSTRUMENT_TOOLTIP_ID
|
|
63
64
|
})), React.createElement(Sentiment, {
|
|
64
|
-
withError: false,
|
|
65
|
-
isLoading: loading,
|
|
66
65
|
height: SentimentHeight.md,
|
|
67
|
-
|
|
66
|
+
isLoading: loading,
|
|
67
|
+
sentiment: sentiment,
|
|
68
|
+
withError: false
|
|
68
69
|
})), !loading && isError && React.createElement(Error, null)), !isError && updatedAt && React.createElement("div", {
|
|
69
70
|
className: "lw-mt-2 lw-h-8"
|
|
70
71
|
}, React.createElement(LastUpdated, {
|
|
71
|
-
|
|
72
|
-
|
|
72
|
+
labelCallback: lang,
|
|
73
|
+
timestamp: updatedAt
|
|
73
74
|
}))));
|
|
74
75
|
};
|
|
75
76
|
export { Widget };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Widget.js","names":["
|
|
1
|
+
{"version":3,"file":"Widget.js","names":["useQuery","Error","LastUpdated","Loader","LoaderSize","Sentiment","SentimentHeight","Size","Truncate","useLayoutProvider","useLocale","classNames","React","INSTRUMENT_TOOLTIP_ID","getInstrumentSentiment","Widget","_ref","_data$sentiment","instrument","division","includeDescriptionLabels","loading","data","error","variables","name","fetchPolicy","size","isDesktop","DESKTOP","lang","displayName","sentiment","updatedAt","isError","shortPercent","longPercent","undefined","createElement","Fragment","className","md","maxWidth","text","tooltipId","height","isLoading","withError","labelCallback","timestamp"],"sources":["../../../src/SentimentWidget/Widget.tsx"],"sourcesContent":["import { useQuery } from '@apollo/client';\nimport {\n Error,\n LastUpdated,\n Loader,\n LoaderSize,\n Sentiment,\n SentimentHeight,\n Size,\n Truncate,\n useLayoutProvider,\n} from '@oanda/labs-widget-common';\nimport { useLocale } from '@oanda/mono-i18n';\nimport classNames from 'classnames';\nimport React from 'react';\n\nimport { INSTRUMENT_TOOLTIP_ID } from '../constant';\nimport { getInstrumentSentiment } from '../gql/getInstrumentSentiment';\nimport type {\n GetInstrumentSentimentQuery,\n GetInstrumentSentimentQueryVariables,\n} from '../gql/types/graphql';\nimport type { SentimentWidgetConfig } from './types';\n\nconst Widget = ({\n instrument,\n division,\n includeDescriptionLabels = false,\n}: SentimentWidgetConfig) => {\n const { loading, data, error } = useQuery<\n GetInstrumentSentimentQuery,\n GetInstrumentSentimentQueryVariables\n >(getInstrumentSentiment, {\n variables: {\n name: instrument,\n division,\n },\n fetchPolicy: 'cache-and-network',\n });\n const { size } = useLayoutProvider();\n const isDesktop = size === Size.DESKTOP;\n const { lang } = useLocale();\n\n const { displayName, sentiment, updatedAt } = data?.sentiment?.[0] || {};\n\n const isError =\n error ||\n (sentiment?.shortPercent === 0 && sentiment?.longPercent === 0) ||\n sentiment?.shortPercent === undefined ||\n sentiment?.longPercent === undefined;\n\n return (\n <>\n {size && (\n <>\n <div\n className=\"lw-border lw-border-solid lw-border-border-primary lw-bg-bg-primary lw-p-4 lw-text-sm lw-tracking-normal lw-text-text-primary\"\n data-testid=\"sentiment-widget\"\n >\n {includeDescriptionLabels && !isError && (\n <div className=\"lw-mb-2 lw-flex lw-justify-between lw-font-semibold\">\n <span\n className={classNames('lw-uppercase', {\n 'lw-ml-40': isDesktop,\n 'lw-ml-[7.5rem]': !isDesktop,\n })}\n >\n {lang('net_short')}\n </span>\n <span\n className={classNames('lw-text-right lw-uppercase', {\n 'lw-mr-10': isDesktop,\n })}\n >\n {lang('net_long')}\n </span>\n </div>\n )}\n <div className=\"lw-flex lw-items-center lw-justify-between\">\n <div className=\"lw-w-[120px] lw-shrink-0\">\n {loading && <Loader size={LoaderSize.md} />}\n {!loading && !isError && (\n <Truncate\n className=\"lw-pr-2 lw-font-sans lw-text-sm lw-font-bold\"\n maxWidth={120}\n text={displayName || '\\u2014'}\n tooltipId={INSTRUMENT_TOOLTIP_ID}\n />\n )}\n </div>\n <Sentiment\n height={SentimentHeight.md}\n isLoading={loading}\n sentiment={sentiment}\n withError={false}\n />\n </div>\n\n {!loading && isError && <Error />}\n </div>\n {!isError && updatedAt && (\n <div className=\"lw-mt-2 lw-h-8\">\n <LastUpdated labelCallback={lang} timestamp={updatedAt} />\n </div>\n )}\n </>\n )}\n </>\n );\n};\n\nexport { Widget };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { LongArrowDown, LongArrowUp, useLayoutProvider } from '@oanda/labs-widget-common';
|
|
2
2
|
import classnames from 'classnames';
|
|
3
|
-
import
|
|
3
|
+
import React from 'react';
|
|
4
4
|
import { SelectedArrow } from './types';
|
|
5
5
|
const SortSwitch = _ref => {
|
|
6
6
|
let {
|
|
@@ -13,20 +13,20 @@ const SortSwitch = _ref => {
|
|
|
13
13
|
isDark
|
|
14
14
|
} = useLayoutProvider();
|
|
15
15
|
return React.createElement("div", {
|
|
16
|
-
"data-testid": "sort-switch",
|
|
17
16
|
className: classnames('lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs lw-tracking-normal', {
|
|
18
17
|
'lw-border-border-disabled': disabled,
|
|
19
18
|
'lw-border-secondary': !disabled
|
|
20
|
-
})
|
|
19
|
+
}),
|
|
20
|
+
"data-testid": "sort-switch"
|
|
21
21
|
}, React.createElement("button", {
|
|
22
|
-
"data-testid": "sort-switch-button-up",
|
|
23
|
-
disabled: disabled || selected === SelectedArrow.UP,
|
|
24
|
-
type: "button",
|
|
25
|
-
onClick: onClickButtonUp,
|
|
26
22
|
className: classnames('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-solid focus:lw-outline-secondary [&:enabled:hover>*]:-lw-translate-y-1', {
|
|
27
23
|
'lw-border-r-[1px] lw-border-r-border-disabled': disabled,
|
|
28
24
|
'lw-bg-secondary': selected === SelectedArrow.UP && !disabled
|
|
29
|
-
})
|
|
25
|
+
}),
|
|
26
|
+
"data-testid": "sort-switch-button-up",
|
|
27
|
+
disabled: disabled || selected === SelectedArrow.UP,
|
|
28
|
+
type: "button",
|
|
29
|
+
onClick: onClickButtonUp
|
|
30
30
|
}, React.createElement(LongArrowUp, {
|
|
31
31
|
className: classnames('lw-transition-transform', {
|
|
32
32
|
'lw-stroke-border-disabled': disabled,
|
|
@@ -35,13 +35,13 @@ const SortSwitch = _ref => {
|
|
|
35
35
|
'lw-stroke-ok': selected === SelectedArrow.UP && !disabled && !isDark
|
|
36
36
|
})
|
|
37
37
|
})), React.createElement("button", {
|
|
38
|
+
className: classnames('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center focus:lw-outline-secondary [&:enabled:hover>*]:lw-translate-y-1', {
|
|
39
|
+
'lw-bg-secondary': selected === SelectedArrow.DOWN && !disabled
|
|
40
|
+
}),
|
|
38
41
|
"data-testid": "sort-switch-button-down",
|
|
39
42
|
disabled: disabled || selected === SelectedArrow.DOWN,
|
|
40
43
|
type: "button",
|
|
41
|
-
onClick: onClickButtonDown
|
|
42
|
-
className: classnames('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center focus:lw-outline-secondary [&:enabled:hover>*]:lw-translate-y-1', {
|
|
43
|
-
'lw-bg-secondary': selected === SelectedArrow.DOWN && !disabled
|
|
44
|
-
})
|
|
44
|
+
onClick: onClickButtonDown
|
|
45
45
|
}, React.createElement(LongArrowDown, {
|
|
46
46
|
className: classnames('lw-transition-transform', {
|
|
47
47
|
'lw-stroke-border-disabled': disabled,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortSwitch.js","names":["
|
|
1
|
+
{"version":3,"file":"SortSwitch.js","names":["LongArrowDown","LongArrowUp","useLayoutProvider","classnames","React","SelectedArrow","SortSwitch","_ref","onClickButtonDown","onClickButtonUp","selected","disabled","isDark","createElement","className","UP","type","onClick","DOWN"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/SortSwitch.tsx"],"sourcesContent":["import {\n LongArrowDown,\n LongArrowUp,\n useLayoutProvider,\n} from '@oanda/labs-widget-common';\nimport classnames from 'classnames';\nimport React from 'react';\n\nimport type { SortSwitchProps } from './types';\nimport { SelectedArrow } from './types';\n\nconst SortSwitch = ({\n onClickButtonDown,\n onClickButtonUp,\n selected,\n disabled,\n}: SortSwitchProps) => {\n const { isDark } = useLayoutProvider();\n\n return (\n <div\n className={classnames(\n 'lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs lw-tracking-normal',\n {\n 'lw-border-border-disabled': disabled,\n 'lw-border-secondary': !disabled,\n }\n )}\n data-testid=\"sort-switch\"\n >\n <button\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-solid focus:lw-outline-secondary [&:enabled:hover>*]:-lw-translate-y-1',\n {\n 'lw-border-r-[1px] lw-border-r-border-disabled': disabled,\n 'lw-bg-secondary': selected === SelectedArrow.UP && !disabled,\n }\n )}\n data-testid=\"sort-switch-button-up\"\n disabled={disabled || selected === SelectedArrow.UP}\n type=\"button\"\n onClick={onClickButtonUp}\n >\n <LongArrowUp\n className={classnames('lw-transition-transform', {\n 'lw-stroke-border-disabled': disabled,\n 'lw-stroke-secondary': selected !== SelectedArrow.UP && !disabled,\n 'lw-stroke-bg-primary':\n selected === SelectedArrow.UP && !disabled && isDark,\n 'lw-stroke-ok':\n selected === SelectedArrow.UP && !disabled && !isDark,\n })}\n />\n </button>\n <button\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center focus:lw-outline-secondary [&:enabled:hover>*]:lw-translate-y-1',\n {\n 'lw-bg-secondary': selected === SelectedArrow.DOWN && !disabled,\n }\n )}\n data-testid=\"sort-switch-button-down\"\n disabled={disabled || selected === SelectedArrow.DOWN}\n type=\"button\"\n onClick={onClickButtonDown}\n >\n <LongArrowDown\n className={classnames('lw-transition-transform', {\n 'lw-stroke-border-disabled': disabled,\n 'lw-stroke-secondary': selected !== SelectedArrow.DOWN && !disabled,\n 'lw-stroke-bg-primary':\n selected === SelectedArrow.DOWN && !disabled && isDark,\n 'lw-stroke-ok':\n selected === SelectedArrow.DOWN && !disabled && !isDark,\n })}\n />\n </button>\n </div>\n );\n};\n\nexport { SortSwitch };\n"],"mappings":"AAAA,SACEA,aAAa,EACbC,WAAW,EACXC,iBAAiB,QACZ,2BAA2B;AAClC,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,KAAK,MAAM,OAAO;AAGzB,SAASC,aAAa,QAAQ,SAAS;AAEvC,MAAMC,UAAU,GAAGC,IAAA,IAKI;EAAA,IALH;IAClBC,iBAAiB;IACjBC,eAAe;IACfC,QAAQ;IACRC;EACe,CAAC,GAAAJ,IAAA;EAChB,MAAM;IAAEK;EAAO,CAAC,GAAGV,iBAAiB,CAAC,CAAC;EAEtC,OACEE,KAAA,CAAAS,aAAA;IACEC,SAAS,EAAEX,UAAU,CACnB,+FAA+F,EAC/F;MACE,2BAA2B,EAAEQ,QAAQ;MACrC,qBAAqB,EAAE,CAACA;IAC1B,CACF,CAAE;IACF,eAAY;EAAa,GAEzBP,KAAA,CAAAS,aAAA;IACEC,SAAS,EAAEX,UAAU,CACnB,uJAAuJ,EACvJ;MACE,+CAA+C,EAAEQ,QAAQ;MACzD,iBAAiB,EAAED,QAAQ,KAAKL,aAAa,CAACU,EAAE,IAAI,CAACJ;IACvD,CACF,CAAE;IACF,eAAY,uBAAuB;IACnCA,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKL,aAAa,CAACU,EAAG;IACpDC,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAER;EAAgB,GAEzBL,KAAA,CAAAS,aAAA,CAACZ,WAAW;IACVa,SAAS,EAAEX,UAAU,CAAC,yBAAyB,EAAE;MAC/C,2BAA2B,EAAEQ,QAAQ;MACrC,qBAAqB,EAAED,QAAQ,KAAKL,aAAa,CAACU,EAAE,IAAI,CAACJ,QAAQ;MACjE,sBAAsB,EACpBD,QAAQ,KAAKL,aAAa,CAACU,EAAE,IAAI,CAACJ,QAAQ,IAAIC,MAAM;MACtD,cAAc,EACZF,QAAQ,KAAKL,aAAa,CAACU,EAAE,IAAI,CAACJ,QAAQ,IAAI,CAACC;IACnD,CAAC;EAAE,CACJ,CACK,CAAC,EACTR,KAAA,CAAAS,aAAA;IACEC,SAAS,EAAEX,UAAU,CACnB,oJAAoJ,EACpJ;MACE,iBAAiB,EAAEO,QAAQ,KAAKL,aAAa,CAACa,IAAI,IAAI,CAACP;IACzD,CACF,CAAE;IACF,eAAY,yBAAyB;IACrCA,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKL,aAAa,CAACa,IAAK;IACtDF,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAET;EAAkB,GAE3BJ,KAAA,CAAAS,aAAA,CAACb,aAAa;IACZc,SAAS,EAAEX,UAAU,CAAC,yBAAyB,EAAE;MAC/C,2BAA2B,EAAEQ,QAAQ;MACrC,qBAAqB,EAAED,QAAQ,KAAKL,aAAa,CAACa,IAAI,IAAI,CAACP,QAAQ;MACnE,sBAAsB,EACpBD,QAAQ,KAAKL,aAAa,CAACa,IAAI,IAAI,CAACP,QAAQ,IAAIC,MAAM;MACxD,cAAc,EACZF,QAAQ,KAAKL,aAAa,CAACa,IAAI,IAAI,CAACP,QAAQ,IAAI,CAACC;IACrD,CAAC;EAAE,CACJ,CACK,CACL,CAAC;AAEV,CAAC;AAED,SAASN,UAAU","ignoreList":[]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
+
import { validateLocale, validateToolParams } from '@oanda/labs-widget-common';
|
|
1
2
|
import React from 'react';
|
|
2
3
|
import { createRoot } from 'react-dom/client';
|
|
3
|
-
import { validateLocale, validateToolParams } from '@oanda/labs-widget-common';
|
|
4
|
-
import { SentimentWidget } from './SentimentWidget';
|
|
5
4
|
import { Division } from '../gql/types/graphql';
|
|
5
|
+
import { SentimentWidget } from './SentimentWidget';
|
|
6
6
|
const {
|
|
7
7
|
graphqlUrl: configGraphQl,
|
|
8
8
|
division: configDivision,
|
|
@@ -40,22 +40,22 @@ if (sentimentParamsElements.length > 0) {
|
|
|
40
40
|
name: 'graphqlUrl'
|
|
41
41
|
}]);
|
|
42
42
|
root.render(React.createElement(SentimentWidget, {
|
|
43
|
-
graphqlUrl: graphqlUrl,
|
|
44
43
|
division: division,
|
|
45
|
-
|
|
46
|
-
locale: locale,
|
|
47
|
-
theme: mode,
|
|
44
|
+
graphqlUrl: graphqlUrl,
|
|
48
45
|
includeDescriptionLabels: includeDescriptionLabels,
|
|
46
|
+
instrument: instrument,
|
|
49
47
|
isParamError: isParamError,
|
|
50
|
-
|
|
48
|
+
locale: locale,
|
|
49
|
+
logoLink: logoLink,
|
|
50
|
+
theme: mode
|
|
51
51
|
}));
|
|
52
52
|
});
|
|
53
53
|
} else {
|
|
54
|
-
const container = document.
|
|
54
|
+
const container = document.querySelector(configRenderElementId);
|
|
55
55
|
const root = createRoot(container);
|
|
56
56
|
root.render(React.createElement(SentimentWidget, {
|
|
57
|
-
graphqlUrl: configGraphQl,
|
|
58
57
|
division: configDivision,
|
|
58
|
+
graphqlUrl: configGraphQl,
|
|
59
59
|
instrument: configInstrument,
|
|
60
60
|
locale: configLocale
|
|
61
61
|
}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"render.js","names":["
|
|
1
|
+
{"version":3,"file":"render.js","names":["validateLocale","validateToolParams","React","createRoot","Division","SentimentWidget","graphqlUrl","configGraphQl","division","configDivision","instrument","configInstrument","renderElementId","configRenderElementId","locale","configLocale","window","sentimentWidgetConfig","widgetsConfig","sentimentParamsElements","document","querySelectorAll","length","forEach","element","root","params","getAttribute","mode","includeDescriptionLabels","logoLink","JSON","parse","isParamError","name","valueCheck","value","Object","values","includes","render","createElement","theme","container","querySelector"],"sources":["../../../src/SentimentWidget/render.tsx"],"sourcesContent":["import type { Theme } from '@oanda/labs-widget-common';\nimport { validateLocale, validateToolParams } from '@oanda/labs-widget-common';\nimport React from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport { Division } from '../gql/types/graphql';\nimport { SentimentWidget } from './SentimentWidget';\n\nconst {\n graphqlUrl: configGraphQl,\n division: configDivision,\n instrument: configInstrument,\n renderElementId: configRenderElementId,\n locale: configLocale,\n} = window.sentimentWidgetConfig || {};\n\nconst { graphqlUrl } = window.widgetsConfig || {};\n\nconst sentimentParamsElements = document.querySelectorAll(\n 'div[data-sentiment-params]'\n);\n\nif (sentimentParamsElements.length > 0) {\n sentimentParamsElements.forEach((element) => {\n const root = createRoot(element);\n const params = element.getAttribute('data-sentiment-params');\n const mode = element.getAttribute('data-mode');\n const { instrument, division, locale, includeDescriptionLabels, logoLink } =\n JSON.parse(params as string);\n\n const isParamError = validateToolParams(\n {\n division,\n locale,\n graphqlUrl,\n },\n [\n {\n name: 'locale',\n valueCheck: (value: string | undefined) => validateLocale(value),\n },\n {\n name: 'division',\n valueCheck: (value: Division) =>\n Object.values(Division).includes(value),\n },\n {\n name: 'graphqlUrl',\n },\n ]\n );\n root.render(\n <SentimentWidget\n division={division}\n graphqlUrl={graphqlUrl}\n includeDescriptionLabels={includeDescriptionLabels}\n instrument={instrument}\n isParamError={isParamError}\n locale={locale}\n logoLink={logoLink}\n theme={mode as Theme}\n />\n );\n });\n} else {\n const container: HTMLElement | null = document.querySelector(\n configRenderElementId\n );\n\n const root = createRoot(container!);\n root.render(\n <SentimentWidget\n division={configDivision}\n graphqlUrl={configGraphQl}\n instrument={configInstrument}\n locale={configLocale}\n />\n );\n}\n"],"mappings":"AACA,SAASA,cAAc,EAAEC,kBAAkB,QAAQ,2BAA2B;AAC9E,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,QAAQ,kBAAkB;AAE7C,SAASC,QAAQ,QAAQ,sBAAsB;AAC/C,SAASC,eAAe,QAAQ,mBAAmB;AAEnD,MAAM;EACJC,UAAU,EAAEC,aAAa;EACzBC,QAAQ,EAAEC,cAAc;EACxBC,UAAU,EAAEC,gBAAgB;EAC5BC,eAAe,EAAEC,qBAAqB;EACtCC,MAAM,EAAEC;AACV,CAAC,GAAGC,MAAM,CAACC,qBAAqB,IAAI,CAAC,CAAC;AAEtC,MAAM;EAAEX;AAAW,CAAC,GAAGU,MAAM,CAACE,aAAa,IAAI,CAAC,CAAC;AAEjD,MAAMC,uBAAuB,GAAGC,QAAQ,CAACC,gBAAgB,CACvD,4BACF,CAAC;AAED,IAAIF,uBAAuB,CAACG,MAAM,GAAG,CAAC,EAAE;EACtCH,uBAAuB,CAACI,OAAO,CAAEC,OAAO,IAAK;IAC3C,MAAMC,IAAI,GAAGtB,UAAU,CAACqB,OAAO,CAAC;IAChC,MAAME,MAAM,GAAGF,OAAO,CAACG,YAAY,CAAC,uBAAuB,CAAC;IAC5D,MAAMC,IAAI,GAAGJ,OAAO,CAACG,YAAY,CAAC,WAAW,CAAC;IAC9C,MAAM;MAAEjB,UAAU;MAAEF,QAAQ;MAAEM,MAAM;MAAEe,wBAAwB;MAAEC;IAAS,CAAC,GACxEC,IAAI,CAACC,KAAK,CAACN,MAAgB,CAAC;IAE9B,MAAMO,YAAY,GAAGhC,kBAAkB,CACrC;MACEO,QAAQ;MACRM,MAAM;MACNR;IACF,CAAC,EACD,CACE;MACE4B,IAAI,EAAE,QAAQ;MACdC,UAAU,EAAGC,KAAyB,IAAKpC,cAAc,CAACoC,KAAK;IACjE,CAAC,EACD;MACEF,IAAI,EAAE,UAAU;MAChBC,UAAU,EAAGC,KAAe,IAC1BC,MAAM,CAACC,MAAM,CAAClC,QAAQ,CAAC,CAACmC,QAAQ,CAACH,KAAK;IAC1C,CAAC,EACD;MACEF,IAAI,EAAE;IACR,CAAC,CAEL,CAAC;IACDT,IAAI,CAACe,MAAM,CACTtC,KAAA,CAAAuC,aAAA,CAACpC,eAAe;MACdG,QAAQ,EAAEA,QAAS;MACnBF,UAAU,EAAEA,UAAW;MACvBuB,wBAAwB,EAAEA,wBAAyB;MACnDnB,UAAU,EAAEA,UAAW;MACvBuB,YAAY,EAAEA,YAAa;MAC3BnB,MAAM,EAAEA,MAAO;MACfgB,QAAQ,EAAEA,QAAS;MACnBY,KAAK,EAAEd;IAAc,CACtB,CACH,CAAC;EACH,CAAC,CAAC;AACJ,CAAC,MAAM;EACL,MAAMe,SAA6B,GAAGvB,QAAQ,CAACwB,aAAa,CAC1D/B,qBACF,CAAC;EAED,MAAMY,IAAI,GAAGtB,UAAU,CAACwC,SAAU,CAAC;EACnClB,IAAI,CAACe,MAAM,CACTtC,KAAA,CAAAuC,aAAA,CAACpC,eAAe;IACdG,QAAQ,EAAEC,cAAe;IACzBH,UAAU,EAAEC,aAAc;IAC1BG,UAAU,EAAEC,gBAAiB;IAC7BG,MAAM,EAAEC;EAAa,CACtB,CACH,CAAC;AACH","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":[],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["import { WidgetConfig } from '@oanda/labs-widget-common';\nimport { Division } from '../gql/types/graphql';\n\nexport interface SentimentConfig extends WidgetConfig {\n division: Division;\n instrument?: string;\n includeDescriptionLabels?: boolean;\n}\nexport interface SentimentWrapperConfig extends SentimentConfig {\n renderElementId: string;\n}\nexport interface SentimentWidgetConfig {\n division: Division;\n instrument: string;\n includeDescriptionLabels?: boolean;\n}\n\nexport interface SentimentToolConfig {\n division: Division;\n}\n"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"types.js","names":[],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["import type { WidgetConfig } from '@oanda/labs-widget-common';\n\nimport type { Division } from '../gql/types/graphql';\n\nexport interface SentimentConfig extends WidgetConfig {\n division: Division;\n instrument?: string;\n includeDescriptionLabels?: boolean;\n}\nexport interface SentimentWrapperConfig extends SentimentConfig {\n renderElementId: string;\n}\nexport interface SentimentWidgetConfig {\n division: Division;\n instrument: string;\n includeDescriptionLabels?: boolean;\n}\n\nexport interface SentimentToolConfig {\n division: Division;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","names":["Sort","sortData","_ref","sort","sentimentList","Bullish","a","b","sentiment","shortPercent","longPercent"],"sources":["../../../src/SentimentWidget/utils.ts"],"sourcesContent":["import { GetSentimentListQuery
|
|
1
|
+
{"version":3,"file":"utils.js","names":["Sort","sortData","_ref","sort","sentimentList","Bullish","a","b","sentiment","shortPercent","longPercent"],"sources":["../../../src/SentimentWidget/utils.ts"],"sourcesContent":["import type { GetSentimentListQuery } from '../gql/types/graphql';\nimport { Sort } from '../gql/types/graphql';\n\nexport const sortData = (\n { sentimentList }: GetSentimentListQuery,\n sort: Sort\n) => {\n if (!sentimentList) {\n return [];\n }\n\n if (sort === Sort.Bullish) {\n return [...sentimentList].sort(\n (a, b) => a.sentiment.shortPercent - b.sentiment.shortPercent\n );\n }\n return [...sentimentList].sort(\n (a, b) => a.sentiment.longPercent - b.sentiment.longPercent\n );\n};\n"],"mappings":"AACA,SAASA,IAAI,QAAQ,sBAAsB;AAE3C,OAAO,MAAMC,QAAQ,GAAGA,CAAAC,IAAA,EAEtBC,IAAU,KACP;EAAA,IAFH;IAAEC;EAAqC,CAAC,GAAAF,IAAA;EAGxC,IAAI,CAACE,aAAa,EAAE;IAClB,OAAO,EAAE;EACX;EAEA,IAAID,IAAI,KAAKH,IAAI,CAACK,OAAO,EAAE;IACzB,OAAO,CAAC,GAAGD,aAAa,CAAC,CAACD,IAAI,CAC5B,CAACG,CAAC,EAAEC,CAAC,KAAKD,CAAC,CAACE,SAAS,CAACC,YAAY,GAAGF,CAAC,CAACC,SAAS,CAACC,YACnD,CAAC;EACH;EACA,OAAO,CAAC,GAAGL,aAAa,CAAC,CAACD,IAAI,CAC5B,CAACG,CAAC,EAAEC,CAAC,KAAKD,CAAC,CAACE,SAAS,CAACE,WAAW,GAAGH,CAAC,CAACC,SAAS,CAACE,WAClD,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1,22 +1,6 @@
|
|
|
1
|
+
var _templateObject;
|
|
2
|
+
function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
|
|
1
3
|
import { gql } from '@apollo/client';
|
|
2
|
-
const getInstrumentSentiment = gql
|
|
3
|
-
query GetInstrumentSentiment(
|
|
4
|
-
$name: String!
|
|
5
|
-
$division: Division
|
|
6
|
-
) {
|
|
7
|
-
sentiment(
|
|
8
|
-
name: $name
|
|
9
|
-
division: $division
|
|
10
|
-
) {
|
|
11
|
-
name
|
|
12
|
-
displayName
|
|
13
|
-
sentiment {
|
|
14
|
-
shortPercent
|
|
15
|
-
longPercent
|
|
16
|
-
}
|
|
17
|
-
updatedAt
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
`;
|
|
4
|
+
const getInstrumentSentiment = gql(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetInstrumentSentiment($name: String!, $division: Division) {\n sentiment(name: $name, division: $division) {\n name\n displayName\n sentiment {\n shortPercent\n longPercent\n }\n updatedAt\n }\n }\n"])));
|
|
21
5
|
export { getInstrumentSentiment };
|
|
22
6
|
//# sourceMappingURL=getInstrumentSentiment.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getInstrumentSentiment.js","names":["gql","getInstrumentSentiment"],"sources":["../../../src/gql/getInstrumentSentiment.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getInstrumentSentiment = gql`\n query GetInstrumentSentiment(
|
|
1
|
+
{"version":3,"file":"getInstrumentSentiment.js","names":["gql","getInstrumentSentiment","_templateObject","_taggedTemplateLiteral"],"sources":["../../../src/gql/getInstrumentSentiment.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getInstrumentSentiment = gql`\n query GetInstrumentSentiment($name: String!, $division: Division) {\n sentiment(name: $name, division: $division) {\n name\n displayName\n sentiment {\n shortPercent\n longPercent\n }\n updatedAt\n }\n }\n`;\n\nexport { getInstrumentSentiment };\n"],"mappings":";;AAAA,SAASA,GAAG,QAAQ,gBAAgB;AAEpC,MAAMC,sBAAsB,GAAGD,GAAG,CAAAE,eAAA,KAAAA,eAAA,GAAAC,sBAAA,uQAYjC;AAED,SAASF,sBAAsB","ignoreList":[]}
|
|
@@ -1,20 +1,6 @@
|
|
|
1
|
+
var _templateObject;
|
|
2
|
+
function _taggedTemplateLiteral(e, t) { return t || (t = e.slice(0)), Object.freeze(Object.defineProperties(e, { raw: { value: Object.freeze(t) } })); }
|
|
1
3
|
import { gql } from '@apollo/client';
|
|
2
|
-
const getSentimentList = gql
|
|
3
|
-
query GetSentimentList (
|
|
4
|
-
$division: Division
|
|
5
|
-
) {
|
|
6
|
-
sentimentList (
|
|
7
|
-
division: $division
|
|
8
|
-
) {
|
|
9
|
-
name
|
|
10
|
-
displayName
|
|
11
|
-
sentiment {
|
|
12
|
-
shortPercent
|
|
13
|
-
longPercent
|
|
14
|
-
}
|
|
15
|
-
updatedAt
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
`;
|
|
4
|
+
const getSentimentList = gql(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetSentimentList($division: Division) {\n sentimentList(division: $division) {\n name\n displayName\n sentiment {\n shortPercent\n longPercent\n }\n updatedAt\n }\n }\n"])));
|
|
19
5
|
export { getSentimentList };
|
|
20
6
|
//# sourceMappingURL=getSentimentList.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getSentimentList.js","names":["gql","getSentimentList"],"sources":["../../../src/gql/getSentimentList.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getSentimentList = gql`\n query GetSentimentList
|
|
1
|
+
{"version":3,"file":"getSentimentList.js","names":["gql","getSentimentList","_templateObject","_taggedTemplateLiteral"],"sources":["../../../src/gql/getSentimentList.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getSentimentList = gql`\n query GetSentimentList($division: Division) {\n sentimentList(division: $division) {\n name\n displayName\n sentiment {\n shortPercent\n longPercent\n }\n updatedAt\n }\n }\n`;\n\nexport { getSentimentList };\n"],"mappings":";;AAAA,SAASA,GAAG,QAAQ,gBAAgB;AAEpC,MAAMC,gBAAgB,GAAGD,GAAG,CAAAE,eAAA,KAAAA,eAAA,GAAAC,sBAAA,wOAY3B;AAED,SAASF,gBAAgB","ignoreList":[]}
|