@oanda/labs-sentiment-widget 1.0.14 → 1.0.16
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 +100 -0
- package/dist/main/SentimentWidget/Tool.js +7 -7
- package/dist/main/SentimentWidget/Tool.js.map +1 -1
- package/dist/main/SentimentWidget/Widget.js +2 -2
- package/dist/main/SentimentWidget/Widget.js.map +1 -1
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js +15 -15
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/main/SentimentWidget/render.js +3 -2
- package/dist/main/SentimentWidget/render.js.map +1 -1
- package/dist/main/SentimentWidget/types.js.map +1 -1
- package/dist/module/SentimentWidget/Tool.js +7 -7
- package/dist/module/SentimentWidget/Tool.js.map +1 -1
- package/dist/module/SentimentWidget/Widget.js +2 -2
- package/dist/module/SentimentWidget/Widget.js.map +1 -1
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js +15 -15
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/module/SentimentWidget/render.js +3 -2
- package/dist/module/SentimentWidget/render.js.map +1 -1
- package/dist/module/SentimentWidget/types.js.map +1 -1
- package/dist/types/SentimentWidget/render.d.ts +2 -2
- package/dist/types/SentimentWidget/types.d.ts +3 -0
- package/package.json +3 -3
- package/src/SentimentWidget/Tool.tsx +7 -7
- package/src/SentimentWidget/Widget.tsx +2 -2
- package/src/SentimentWidget/components/SortSwitch/SortSwitch.tsx +15 -15
- package/src/SentimentWidget/render.tsx +4 -3
- package/src/SentimentWidget/types.ts +3 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,106 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## 1.0.16 (2023-10-04)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
## 1.0.15 (2023-10-04)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## 1.0.14 (2023-10-03)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
## 1.0.13 (2023-10-03)
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
## 1.0.12 (2023-10-03)
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
## 1.0.11 (2023-10-02)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
## 1.0.10 (2023-09-29)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
## 1.0.9 (2023-09-28)
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
## 1.0.8 (2023-09-27)
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
## 1.0.7 (2023-09-26)
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
## 1.0.6 (2023-09-21)
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
## 1.0.5 (2023-09-13)
|
|
51
|
+
|
|
52
|
+
**Note:** Version bump only for package @oanda/labs-sentiment-widget
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
## 1.0.15 (2023-10-04)
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
## 1.0.14 (2023-10-03)
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
## 1.0.13 (2023-10-03)
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
## 1.0.12 (2023-10-03)
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
## 1.0.11 (2023-10-02)
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
## 1.0.10 (2023-09-29)
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
## 1.0.9 (2023-09-28)
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
## 1.0.8 (2023-09-27)
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
## 1.0.7 (2023-09-26)
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
## 1.0.6 (2023-09-21)
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
## 1.0.5 (2023-09-13)
|
|
99
|
+
|
|
100
|
+
**Note:** Version bump only for package @oanda/labs-sentiment-widget
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
|
|
6
106
|
## 1.0.14 (2023-10-03)
|
|
7
107
|
|
|
8
108
|
|
|
@@ -35,27 +35,27 @@ const Tool = _ref => {
|
|
|
35
35
|
}, [data, sort]);
|
|
36
36
|
return _react.default.createElement("div", {
|
|
37
37
|
"data-testid": "sentiment-tool",
|
|
38
|
-
className: "text-sm text-black"
|
|
38
|
+
className: "lw-text-sm lw-text-black"
|
|
39
39
|
}, error ? _react.default.createElement("div", {
|
|
40
|
-
className: "flex h-[200px] items-center justify-center border border-solid border-grey p-2"
|
|
40
|
+
className: "lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-grey lw-p-2"
|
|
41
41
|
}, _react.default.createElement(_labsWidgetCommon.ChartError, null)) : _react.default.createElement(_react.default.Fragment, null, _react.default.createElement("div", {
|
|
42
|
-
className: "flex justify-end pb-5"
|
|
42
|
+
className: "lw-flex lw-justify-end lw-pb-5"
|
|
43
43
|
}, _react.default.createElement(_SortSwitch.SortSwitch, {
|
|
44
44
|
disabled: loading,
|
|
45
45
|
selected: sort === _types.SentimentSort.Bullish ? _SortSwitch.SelectedArrow.UP : _SortSwitch.SelectedArrow.DOWN,
|
|
46
46
|
onClickButtonDown: () => setSort(_types.SentimentSort.Bearish),
|
|
47
47
|
onClickButtonUp: () => setSort(_types.SentimentSort.Bullish)
|
|
48
48
|
})), _react.default.createElement("div", {
|
|
49
|
-
className: "flex flex-col border border-solid border-grey p-2"
|
|
49
|
+
className: "lw-flex lw-flex-col lw-border lw-border-solid lw-border-grey lw-p-2"
|
|
50
50
|
}, sortedData.map((item, index) => _react.default.createElement("div", {
|
|
51
|
-
className: "flex h-8 w-full items-center",
|
|
51
|
+
className: "lw-flex lw-h-8 lw-w-full lw-items-center",
|
|
52
52
|
key: item.name || index
|
|
53
53
|
}, _react.default.createElement("div", {
|
|
54
|
-
className: "w-[120px] shrink-0"
|
|
54
|
+
className: "lw-w-[120px] lw-shrink-0"
|
|
55
55
|
}, loading ? _react.default.createElement(_labsWidgetCommon.Loader, {
|
|
56
56
|
size: _labsWidgetCommon.LoaderSize.md
|
|
57
57
|
}) : _react.default.createElement("p", {
|
|
58
|
-
className: "truncate font-sans font-bold"
|
|
58
|
+
className: "lw-truncate lw-font-sans lw-font-bold"
|
|
59
59
|
}, item.name || '\u2014')), _react.default.createElement(_labsWidgetCommon.Sentiment, {
|
|
60
60
|
isLoading: loading,
|
|
61
61
|
height: _labsWidgetCommon.SentimentHeight.md,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tool.js","names":["_react","_interopRequireWildcard","require","_labsWidgetCommon","_client","_getSentimentList","_types","_utils","_SortSwitch","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Tool","_ref","division","sort","setSort","useState","SentimentSort","Bullish","sortedData","setSortedData","Array","fill","loading","data","error","useQuery","getSentimentList","variables","useEffect","sortData","sentimentList","createElement","className","ChartError","Fragment","SortSwitch","disabled","selected","SelectedArrow","UP","DOWN","onClickButtonDown","Bearish","onClickButtonUp","map","item","index","name","Loader","size","LoaderSize","md","Sentiment","isLoading","height","SentimentHeight","sentiment","exports"],"sources":["../../../src/SentimentWidget/Tool.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport {\n Sentiment, SentimentHeight, Loader, LoaderSize, ChartError,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getSentimentList } from '../gql/getSentimentList';\nimport {\n SentimentListResponse, SentimentSort, SentimentListData, SentimentToolConfig,\n} from './types';\nimport { sortData } from './utils';\nimport { SelectedArrow, SortSwitch } from './components/SortSwitch';\n\nconst Tool = ({ division }: SentimentToolConfig) => {\n const [sort, setSort] = useState(SentimentSort.Bullish);\n const [sortedData, setSortedData] = useState<SentimentListData[]>(new Array(20).fill({}));\n const { loading, data, error } = useQuery<SentimentListResponse>(getSentimentList, {\n variables: {\n division,\n },\n });\n\n useEffect(() => {\n if (data) {\n setSortedData(sortData(data.sentimentList, sort));\n }\n }, [data, sort]);\n\n return (\n <div data-testid=\"sentiment-tool\" className=\"text-sm text-black\">\n {error ? (\n <div className=\"flex h-[200px] items-center justify-center border border-solid border-grey p-2\">\n <ChartError />\n </div>\n ) : (\n <>\n <div className=\"flex justify-end pb-5\">\n <SortSwitch\n disabled={loading}\n selected={sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN}\n onClickButtonDown={() => setSort(SentimentSort.Bearish)}\n onClickButtonUp={() => setSort(SentimentSort.Bullish)}\n />\n </div>\n <div className=\"flex flex-col border border-solid border-grey p-2\">\n {sortedData.map((item, index) => (\n <div className=\"flex h-8 w-full items-center\" key={item.name || index}>\n <div className=\"w-[120px] shrink-0\">\n {loading ? (\n <Loader size={LoaderSize.md} />\n ) : (\n <p className=\"truncate font-sans font-bold\">{item.name || '\\u2014'}</p>\n )}\n </div>\n <Sentiment\n isLoading={loading}\n height={SentimentHeight.md}\n sentiment={item.sentiment}\n />\n </div>\n ))}\n </div>\n </>\n )}\n </div>\n );\n};\n\nexport { Tool };\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AAGA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAH,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AAGA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,WAAA,GAAAN,OAAA;AAAoE,SAAAO,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAT,wBAAAa,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAG,KAAA,GAAAR,wBAAA,CAAAC,WAAA,OAAAO,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAJ,GAAA,YAAAG,KAAA,CAAAE,GAAA,CAAAL,GAAA,SAAAM,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAX,GAAA,QAAAW,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAd,GAAA,EAAAW,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAV,GAAA,EAAAW,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAX,GAAA,CAAAW,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAF,GAAA,MAAAG,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAhB,GAAA,EAAAM,MAAA,YAAAA,MAAA;AAEpE,MAAMW,IAAI,GAAGC,IAAA,IAAuC;EAAA,IAAtC;IAAEC;EAA8B,CAAC,GAAAD,IAAA;EAC7C,MAAM,CAACE,IAAI,EAAEC,OAAO,CAAC,GAAG,IAAAC,eAAQ,EAACC,oBAAa,CAACC,OAAO,CAAC;EACvD,MAAM,CAACC,UAAU,EAAEC,aAAa,CAAC,GAAG,IAAAJ,eAAQ,EAAsB,IAAIK,KAAK,CAAC,EAAE,CAAC,CAACC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;EACzF,MAAM;IAAEC,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAG,IAAAC,gBAAQ,EAAwBC,kCAAgB,EAAE;IACjFC,SAAS,EAAE;MACTf;IACF;EACF,CAAC,CAAC;EAEF,IAAAgB,gBAAS,EAAC,MAAM;IACd,IAAIL,IAAI,EAAE;MACRJ,aAAa,CAAC,IAAAU,eAAQ,EAACN,IAAI,CAACO,aAAa,EAAEjB,IAAI,CAAC,CAAC;IACnD;EACF,CAAC,EAAE,CAACU,IAAI,EAAEV,IAAI,CAAC,CAAC;EAEhB,OACElC,MAAA,CAAAgB,OAAA,CAAAoC,aAAA;IAAK,eAAY,gBAAgB;IAACC,SAAS,EAAC;
|
|
1
|
+
{"version":3,"file":"Tool.js","names":["_react","_interopRequireWildcard","require","_labsWidgetCommon","_client","_getSentimentList","_types","_utils","_SortSwitch","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Tool","_ref","division","sort","setSort","useState","SentimentSort","Bullish","sortedData","setSortedData","Array","fill","loading","data","error","useQuery","getSentimentList","variables","useEffect","sortData","sentimentList","createElement","className","ChartError","Fragment","SortSwitch","disabled","selected","SelectedArrow","UP","DOWN","onClickButtonDown","Bearish","onClickButtonUp","map","item","index","name","Loader","size","LoaderSize","md","Sentiment","isLoading","height","SentimentHeight","sentiment","exports"],"sources":["../../../src/SentimentWidget/Tool.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport {\n Sentiment, SentimentHeight, Loader, LoaderSize, ChartError,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getSentimentList } from '../gql/getSentimentList';\nimport {\n SentimentListResponse, SentimentSort, SentimentListData, SentimentToolConfig,\n} from './types';\nimport { sortData } from './utils';\nimport { SelectedArrow, SortSwitch } from './components/SortSwitch';\n\nconst Tool = ({ division }: SentimentToolConfig) => {\n const [sort, setSort] = useState(SentimentSort.Bullish);\n const [sortedData, setSortedData] = useState<SentimentListData[]>(new Array(20).fill({}));\n const { loading, data, error } = useQuery<SentimentListResponse>(getSentimentList, {\n variables: {\n division,\n },\n });\n\n useEffect(() => {\n if (data) {\n setSortedData(sortData(data.sentimentList, sort));\n }\n }, [data, sort]);\n\n return (\n <div data-testid=\"sentiment-tool\" className=\"lw-text-sm lw-text-black\">\n {error ? (\n <div className=\"lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-grey 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={sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN}\n onClickButtonDown={() => setSort(SentimentSort.Bearish)}\n onClickButtonUp={() => setSort(SentimentSort.Bullish)}\n />\n </div>\n <div className=\"lw-flex lw-flex-col lw-border lw-border-solid lw-border-grey lw-p-2\">\n {sortedData.map((item, index) => (\n <div className=\"lw-flex lw-h-8 lw-w-full lw-items-center\" key={item.name || index}>\n <div className=\"lw-w-[120px] lw-shrink-0\">\n {loading ? (\n <Loader size={LoaderSize.md} />\n ) : (\n <p className=\"lw-truncate lw-font-sans lw-font-bold\">{item.name || '\\u2014'}</p>\n )}\n </div>\n <Sentiment\n isLoading={loading}\n height={SentimentHeight.md}\n sentiment={item.sentiment}\n />\n </div>\n ))}\n </div>\n </>\n )}\n </div>\n );\n};\n\nexport { Tool };\n"],"mappings":"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"}
|
|
@@ -30,9 +30,9 @@ const Widget = _ref => {
|
|
|
30
30
|
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;
|
|
31
31
|
return _react.default.createElement("div", {
|
|
32
32
|
"data-testid": "sentiment-widget",
|
|
33
|
-
className: "flex items-center justify-between border border-solid border-grey p-4 text-sm text-black"
|
|
33
|
+
className: "lw-flex lw-items-center lw-justify-between lw-border lw-border-solid lw-border-grey lw-p-4 lw-text-sm lw-text-black"
|
|
34
34
|
}, !loading ? _react.default.createElement(_react.default.Fragment, null, _react.default.createElement("p", {
|
|
35
|
-
className: "mr-12 font-sans font-bold"
|
|
35
|
+
className: "lw-mr-12 lw-font-sans lw-font-bold"
|
|
36
36
|
}, instrument), !isError && _react.default.createElement(_labsWidgetCommon.Sentiment, {
|
|
37
37
|
height: _labsWidgetCommon.SentimentHeight.md,
|
|
38
38
|
sentiment: sentiment
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Widget.js","names":["_react","_interopRequireDefault","require","_labsWidgetCommon","_client","_getInstrumentSentiment","obj","__esModule","default","Widget","_ref","instrument","division","loading","data","error","useQuery","getInstrumentSentiment","variables","name","sentiment","isError","shortPercent","longPercent","undefined","createElement","className","Fragment","Sentiment","height","SentimentHeight","md","Error","Spinner","exports"],"sources":["../../../src/SentimentWidget/Widget.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Sentiment, SentimentHeight, Spinner, Error,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getInstrumentSentiment } from '../gql/getInstrumentSentiment';\nimport { SentimentWidgetConfig } from './types';\n\nconst Widget = ({ instrument, division }: SentimentWidgetConfig) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\n division,\n },\n });\n\n const { sentiment } = data?.sentiment[0] || {};\n const isError = error\n || (sentiment?.shortPercent === 0 && sentiment?.longPercent === 0)\n || sentiment?.shortPercent === undefined\n || sentiment?.longPercent === undefined;\n\n return (\n <div data-testid=\"sentiment-widget\" className=\"flex items-center justify-between border border-solid border-grey p-4 text-sm text-black\">\n {!loading\n ? (\n <>\n <p className=\"mr-12 font-sans font-bold\">{instrument}</p>\n {!isError && <Sentiment height={SentimentHeight.md} sentiment={sentiment} />}\n {isError && <Error />}\n </>\n ) : <Spinner />}\n </div>\n );\n};\n\nexport { Widget };\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AAGA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,uBAAA,GAAAH,OAAA;AAAuE,SAAAD,uBAAAK,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAGvE,MAAMG,MAAM,GAAGC,IAAA,IAAqD;EAAA,IAApD;IAAEC,UAAU;IAAEC;EAAgC,CAAC,GAAAF,IAAA;EAC7D,MAAM;IAAEG,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAG,IAAAC,gBAAQ,EAACC,8CAAsB,EAAE;IAChEC,SAAS,EAAE;MACTC,IAAI,EAAER,UAAU;MAChBC;IACF;EACF,CAAC,CAAC;EAEF,MAAM;IAAEQ;EAAU,CAAC,GAAG,CAAAN,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEM,SAAS,CAAC,CAAC,CAAC,KAAI,CAAC,CAAC;EAC9C,MAAMC,OAAO,GAAGN,KAAK,IACf,CAAAK,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAK,CAAC,IAAI,CAAAF,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAK,CAAE,IAC/D,CAAAH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAKE,SAAS,IACrC,CAAAJ,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAKC,SAAS;EAEzC,OACExB,MAAA,CAAAQ,OAAA,CAAAiB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;
|
|
1
|
+
{"version":3,"file":"Widget.js","names":["_react","_interopRequireDefault","require","_labsWidgetCommon","_client","_getInstrumentSentiment","obj","__esModule","default","Widget","_ref","instrument","division","loading","data","error","useQuery","getInstrumentSentiment","variables","name","sentiment","isError","shortPercent","longPercent","undefined","createElement","className","Fragment","Sentiment","height","SentimentHeight","md","Error","Spinner","exports"],"sources":["../../../src/SentimentWidget/Widget.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Sentiment, SentimentHeight, Spinner, Error,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getInstrumentSentiment } from '../gql/getInstrumentSentiment';\nimport { SentimentWidgetConfig } from './types';\n\nconst Widget = ({ instrument, division }: SentimentWidgetConfig) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\n division,\n },\n });\n\n const { sentiment } = data?.sentiment[0] || {};\n const isError = error\n || (sentiment?.shortPercent === 0 && sentiment?.longPercent === 0)\n || sentiment?.shortPercent === undefined\n || sentiment?.longPercent === undefined;\n\n return (\n <div data-testid=\"sentiment-widget\" className=\"lw-flex lw-items-center lw-justify-between lw-border lw-border-solid lw-border-grey lw-p-4 lw-text-sm lw-text-black\">\n {!loading\n ? (\n <>\n <p className=\"lw-mr-12 lw-font-sans lw-font-bold\">{instrument}</p>\n {!isError && <Sentiment height={SentimentHeight.md} sentiment={sentiment} />}\n {isError && <Error />}\n </>\n ) : <Spinner />}\n </div>\n );\n};\n\nexport { Widget };\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AAGA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,uBAAA,GAAAH,OAAA;AAAuE,SAAAD,uBAAAK,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAGvE,MAAMG,MAAM,GAAGC,IAAA,IAAqD;EAAA,IAApD;IAAEC,UAAU;IAAEC;EAAgC,CAAC,GAAAF,IAAA;EAC7D,MAAM;IAAEG,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAG,IAAAC,gBAAQ,EAACC,8CAAsB,EAAE;IAChEC,SAAS,EAAE;MACTC,IAAI,EAAER,UAAU;MAChBC;IACF;EACF,CAAC,CAAC;EAEF,MAAM;IAAEQ;EAAU,CAAC,GAAG,CAAAN,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEM,SAAS,CAAC,CAAC,CAAC,KAAI,CAAC,CAAC;EAC9C,MAAMC,OAAO,GAAGN,KAAK,IACf,CAAAK,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAK,CAAC,IAAI,CAAAF,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAK,CAAE,IAC/D,CAAAH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAKE,SAAS,IACrC,CAAAJ,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAKC,SAAS;EAEzC,OACExB,MAAA,CAAAQ,OAAA,CAAAiB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;EAAqH,GAChK,CAACb,OAAO,GAELb,MAAA,CAAAQ,OAAA,CAAAiB,aAAA,CAAAzB,MAAA,CAAAQ,OAAA,CAAAmB,QAAA,QACE3B,MAAA,CAAAQ,OAAA,CAAAiB,aAAA;IAAGC,SAAS,EAAC;EAAoC,GAAEf,UAAc,CAAC,EACjE,CAACU,OAAO,IAAIrB,MAAA,CAAAQ,OAAA,CAAAiB,aAAA,CAACtB,iBAAA,CAAAyB,SAAS;IAACC,MAAM,EAAEC,iCAAe,CAACC,EAAG;IAACX,SAAS,EAAEA;EAAU,CAAE,CAAC,EAC3EC,OAAO,IAAIrB,MAAA,CAAAQ,OAAA,CAAAiB,aAAA,CAACtB,iBAAA,CAAA6B,KAAK,MAAE,CACpB,CAAC,GACDhC,MAAA,CAAAQ,OAAA,CAAAiB,aAAA,CAACtB,iBAAA,CAAA8B,OAAO,MAAE,CACb,CAAC;AAEV,CAAC;AAACC,OAAA,CAAAzB,MAAA,GAAAA,MAAA"}
|
|
@@ -18,37 +18,37 @@ const SortSwitch = _ref => {
|
|
|
18
18
|
} = _ref;
|
|
19
19
|
return _react.default.createElement("div", {
|
|
20
20
|
"data-testid": "sort-switch",
|
|
21
|
-
className: (0, _classnames.default)('flex rounded border-[1px] border-solid font-sans text-xs', {
|
|
22
|
-
'border-darkGrey': disabled,
|
|
23
|
-
'border-navyBlue': !disabled
|
|
21
|
+
className: (0, _classnames.default)('lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs', {
|
|
22
|
+
'lw-border-darkGrey': disabled,
|
|
23
|
+
'lw-border-navyBlue': !disabled
|
|
24
24
|
})
|
|
25
25
|
}, _react.default.createElement("button", {
|
|
26
26
|
"data-testid": "sort-switch-button-up",
|
|
27
27
|
disabled: disabled || selected === _types.SelectedArrow.UP,
|
|
28
28
|
type: "button",
|
|
29
29
|
onClick: onClickButtonUp,
|
|
30
|
-
className: (0, _classnames.default)('flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1', {
|
|
31
|
-
'bg-navyBlue': selected === _types.SelectedArrow.UP && !disabled
|
|
30
|
+
className: (0, _classnames.default)('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-r-[1px] lw-border-solid [&:enabled:hover>*]:-lw-translate-y-1', {
|
|
31
|
+
'lw-bg-navyBlue': selected === _types.SelectedArrow.UP && !disabled
|
|
32
32
|
})
|
|
33
33
|
}, _react.default.createElement(_labsWidgetCommon.LongArrowUp, {
|
|
34
|
-
className: (0, _classnames.default)('transition-transform', {
|
|
35
|
-
'stroke-darkGrey': disabled,
|
|
36
|
-
'stroke-navyBlue': selected !== _types.SelectedArrow.UP && !disabled,
|
|
37
|
-
'stroke-green': selected === _types.SelectedArrow.UP && !disabled
|
|
34
|
+
className: (0, _classnames.default)('lw-transition-transform', {
|
|
35
|
+
'lw-stroke-darkGrey': disabled,
|
|
36
|
+
'lw-stroke-navyBlue': selected !== _types.SelectedArrow.UP && !disabled,
|
|
37
|
+
'lw-stroke-green': selected === _types.SelectedArrow.UP && !disabled
|
|
38
38
|
})
|
|
39
39
|
})), _react.default.createElement("button", {
|
|
40
40
|
"data-testid": "sort-switch-button-down",
|
|
41
41
|
disabled: disabled || selected === _types.SelectedArrow.DOWN,
|
|
42
42
|
type: "button",
|
|
43
43
|
onClick: onClickButtonDown,
|
|
44
|
-
className: (0, _classnames.default)('flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1', {
|
|
45
|
-
'bg-navyBlue': selected === _types.SelectedArrow.DOWN && !disabled
|
|
44
|
+
className: (0, _classnames.default)('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center [&:enabled:hover>*]:lw-translate-y-1', {
|
|
45
|
+
'lw-bg-navyBlue': selected === _types.SelectedArrow.DOWN && !disabled
|
|
46
46
|
})
|
|
47
47
|
}, _react.default.createElement(_labsWidgetCommon.LongArrowDown, {
|
|
48
|
-
className: (0, _classnames.default)('transition-transform', {
|
|
49
|
-
'stroke-darkGrey': disabled,
|
|
50
|
-
'stroke-navyBlue': selected !== _types.SelectedArrow.DOWN && !disabled,
|
|
51
|
-
'stroke-green': selected === _types.SelectedArrow.DOWN && !disabled
|
|
48
|
+
className: (0, _classnames.default)('lw-transition-transform', {
|
|
49
|
+
'lw-stroke-darkGrey': disabled,
|
|
50
|
+
'lw-stroke-navyBlue': selected !== _types.SelectedArrow.DOWN && !disabled,
|
|
51
|
+
'lw-stroke-green': selected === _types.SelectedArrow.DOWN && !disabled
|
|
52
52
|
})
|
|
53
53
|
})));
|
|
54
54
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortSwitch.js","names":["_react","_interopRequireDefault","require","_classnames","_labsWidgetCommon","_types","obj","__esModule","default","SortSwitch","_ref","onClickButtonDown","onClickButtonUp","selected","disabled","createElement","className","classnames","SelectedArrow","UP","type","onClick","LongArrowUp","DOWN","LongArrowDown","exports"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/SortSwitch.tsx"],"sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport { LongArrowUp, LongArrowDown } from '@oanda/labs-widget-common';\nimport { SelectedArrow, SortSwitchProps } from './types';\n\nconst SortSwitch = ({\n onClickButtonDown, onClickButtonUp, selected, disabled,\n}: SortSwitchProps) => (\n <div\n data-testid=\"sort-switch\"\n className={classnames(\n 'flex rounded border-[1px] border-solid font-sans text-xs',\n {\n 'border-darkGrey': disabled,\n 'border-navyBlue': !disabled,\n },\n )}\n >\n <button\n data-testid=\"sort-switch-button-up\"\n disabled={disabled || selected === SelectedArrow.UP}\n type=\"button\"\n onClick={onClickButtonUp}\n className={classnames(\n 'flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1',\n {\n 'bg-navyBlue': selected === SelectedArrow.UP && !disabled,\n },\n )}\n >\n <LongArrowUp\n className={classnames(\n 'transition-transform',\n {\n 'stroke-darkGrey': disabled,\n 'stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,\n 'stroke-green': selected === SelectedArrow.UP && !disabled,\n },\n )}\n />\n </button>\n <button\n data-testid=\"sort-switch-button-down\"\n disabled={disabled || selected === SelectedArrow.DOWN}\n type=\"button\"\n onClick={onClickButtonDown}\n className={classnames(\n 'flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1',\n {\n 'bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n >\n <LongArrowDown\n className={classnames(\n 'transition-transform',\n {\n 'stroke-darkGrey': disabled,\n 'stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,\n 'stroke-green': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n />\n </button>\n </div>\n);\n\nexport {\n SortSwitch,\n};\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,iBAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AAAyD,SAAAD,uBAAAK,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAEzD,MAAMG,UAAU,GAAGC,IAAA;EAAA,IAAC;IAClBC,iBAAiB;IAAEC,eAAe;IAAEC,QAAQ;IAAEC;EAC/B,CAAC,GAAAJ,IAAA;EAAA,OAChBV,MAAA,CAAAQ,OAAA,CAAAO,aAAA;IACE,eAAY,aAAa;IACzBC,SAAS,EAAE,IAAAC,mBAAU,EACnB,
|
|
1
|
+
{"version":3,"file":"SortSwitch.js","names":["_react","_interopRequireDefault","require","_classnames","_labsWidgetCommon","_types","obj","__esModule","default","SortSwitch","_ref","onClickButtonDown","onClickButtonUp","selected","disabled","createElement","className","classnames","SelectedArrow","UP","type","onClick","LongArrowUp","DOWN","LongArrowDown","exports"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/SortSwitch.tsx"],"sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport { LongArrowUp, LongArrowDown } from '@oanda/labs-widget-common';\nimport { SelectedArrow, SortSwitchProps } from './types';\n\nconst SortSwitch = ({\n onClickButtonDown, onClickButtonUp, selected, disabled,\n}: SortSwitchProps) => (\n <div\n data-testid=\"sort-switch\"\n className={classnames(\n 'lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs',\n {\n 'lw-border-darkGrey': disabled,\n 'lw-border-navyBlue': !disabled,\n },\n )}\n >\n <button\n data-testid=\"sort-switch-button-up\"\n disabled={disabled || selected === SelectedArrow.UP}\n type=\"button\"\n onClick={onClickButtonUp}\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-r-[1px] lw-border-solid [&:enabled:hover>*]:-lw-translate-y-1',\n {\n 'lw-bg-navyBlue': selected === SelectedArrow.UP && !disabled,\n },\n )}\n >\n <LongArrowUp\n className={classnames(\n 'lw-transition-transform',\n {\n 'lw-stroke-darkGrey': disabled,\n 'lw-stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,\n 'lw-stroke-green': selected === SelectedArrow.UP && !disabled,\n },\n )}\n />\n </button>\n <button\n data-testid=\"sort-switch-button-down\"\n disabled={disabled || selected === SelectedArrow.DOWN}\n type=\"button\"\n onClick={onClickButtonDown}\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center [&:enabled:hover>*]:lw-translate-y-1',\n {\n 'lw-bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n >\n <LongArrowDown\n className={classnames(\n 'lw-transition-transform',\n {\n 'lw-stroke-darkGrey': disabled,\n 'lw-stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,\n 'lw-stroke-green': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n />\n </button>\n </div>\n);\n\nexport {\n SortSwitch,\n};\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,iBAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AAAyD,SAAAD,uBAAAK,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAEzD,MAAMG,UAAU,GAAGC,IAAA;EAAA,IAAC;IAClBC,iBAAiB;IAAEC,eAAe;IAAEC,QAAQ;IAAEC;EAC/B,CAAC,GAAAJ,IAAA;EAAA,OAChBV,MAAA,CAAAQ,OAAA,CAAAO,aAAA;IACE,eAAY,aAAa;IACzBC,SAAS,EAAE,IAAAC,mBAAU,EACnB,4EAA4E,EAC5E;MACE,oBAAoB,EAAEH,QAAQ;MAC9B,oBAAoB,EAAE,CAACA;IACzB,CACF;EAAE,GAEFd,MAAA,CAAAQ,OAAA,CAAAO,aAAA;IACE,eAAY,uBAAuB;IACnCD,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKK,oBAAa,CAACC,EAAG;IACpDC,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAET,eAAgB;IACzBI,SAAS,EAAE,IAAAC,mBAAU,EACnB,8IAA8I,EAC9I;MACE,gBAAgB,EAAEJ,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL;IACtD,CACF;EAAE,GAEFd,MAAA,CAAAQ,OAAA,CAAAO,aAAA,CAACX,iBAAA,CAAAkB,WAAW;IACVN,SAAS,EAAE,IAAAC,mBAAU,EACnB,yBAAyB,EACzB;MACE,oBAAoB,EAAEH,QAAQ;MAC9B,oBAAoB,EAAED,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL,QAAQ;MAChE,iBAAiB,EAAED,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL;IACvD,CACF;EAAE,CACH,CACK,CAAC,EACTd,MAAA,CAAAQ,OAAA,CAAAO,aAAA;IACE,eAAY,yBAAyB;IACrCD,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKK,oBAAa,CAACK,IAAK;IACtDH,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAEV,iBAAkB;IAC3BK,SAAS,EAAE,IAAAC,mBAAU,EACnB,yHAAyH,EACzH;MACE,gBAAgB,EAAEJ,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT;IACxD,CACF;EAAE,GAEFd,MAAA,CAAAQ,OAAA,CAAAO,aAAA,CAACX,iBAAA,CAAAoB,aAAa;IACZR,SAAS,EAAE,IAAAC,mBAAU,EACnB,yBAAyB,EACzB;MACE,oBAAoB,EAAEH,QAAQ;MAC9B,oBAAoB,EAAED,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT,QAAQ;MAClE,iBAAiB,EAAED,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT;IACzD,CACF;EAAE,CACH,CACK,CACL,CAAC;AAAA,CACP;AAACW,OAAA,CAAAhB,UAAA,GAAAA,UAAA"}
|
|
@@ -7,11 +7,12 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
7
7
|
const {
|
|
8
8
|
graphqlUrl,
|
|
9
9
|
division,
|
|
10
|
-
instrument
|
|
10
|
+
instrument,
|
|
11
|
+
renderElementId
|
|
11
12
|
} = window.sentimentWidgetConfig;
|
|
12
13
|
(0, _reactDom.render)(_react.default.createElement(_SentimentWidget.SentimentWidget, {
|
|
13
14
|
graphqlUrl: graphqlUrl,
|
|
14
15
|
division: division,
|
|
15
16
|
instrument: instrument
|
|
16
|
-
}), document.getElementById(
|
|
17
|
+
}), document.getElementById(renderElementId));
|
|
17
18
|
//# sourceMappingURL=render.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"render.js","names":["_react","_interopRequireDefault","require","_reactDom","_SentimentWidget","obj","__esModule","default","graphqlUrl","division","instrument","window","sentimentWidgetConfig","render","createElement","SentimentWidget","document","getElementById"],"sources":["../../../src/SentimentWidget/render.tsx"],"sourcesContent":["import React from 'react';\nimport { render } from 'react-dom';\nimport { SentimentWidget } from './SentimentWidget';\nimport {
|
|
1
|
+
{"version":3,"file":"render.js","names":["_react","_interopRequireDefault","require","_reactDom","_SentimentWidget","obj","__esModule","default","graphqlUrl","division","instrument","renderElementId","window","sentimentWidgetConfig","render","createElement","SentimentWidget","document","getElementById"],"sources":["../../../src/SentimentWidget/render.tsx"],"sourcesContent":["import React from 'react';\nimport { render } from 'react-dom';\nimport { SentimentWidget } from './SentimentWidget';\nimport { SentimentWrapperConfig } from './types';\n\ndeclare global {\n interface Window {\n sentimentWidgetConfig: SentimentWrapperConfig;\n }\n}\n\nconst {\n graphqlUrl,\n division,\n instrument,\n renderElementId,\n} = window.sentimentWidgetConfig;\n\nrender(\n <SentimentWidget\n graphqlUrl={graphqlUrl}\n division={division}\n instrument={instrument}\n />,\n document.getElementById(renderElementId),\n);\n"],"mappings":";;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,SAAA,GAAAD,OAAA;AACA,IAAAE,gBAAA,GAAAF,OAAA;AAAoD,SAAAD,uBAAAI,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AASpD,MAAM;EACJG,UAAU;EACVC,QAAQ;EACRC,UAAU;EACVC;AACF,CAAC,GAAGC,MAAM,CAACC,qBAAqB;AAEhC,IAAAC,gBAAM,EACJd,MAAA,CAAAO,OAAA,CAAAQ,aAAA,CAACX,gBAAA,CAAAY,eAAe;EACdR,UAAU,EAAEA,UAAW;EACvBC,QAAQ,EAAEA,QAAS;EACnBC,UAAU,EAAEA;AAAW,CACxB,CAAC,EACFO,QAAQ,CAACC,cAAc,CAACP,eAAe,CACzC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":["SentimentSort","exports"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n division: string;\n instrument?: string;\n}\n\nexport interface SentimentWidgetConfig {\n division: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n division: string;\n}\n\nexport interface SentimentListData {\n name: string;\n sentiment: {\n shortPercent: number;\n longPercent: number;\n }\n}\n\nexport interface SentimentListResponse {\n sentimentList: SentimentListData[]\n}\n\nexport enum SentimentSort {\n Bearish = 'BEARISH',\n Bullish = 'BULLISH',\n}\n"],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"types.js","names":["SentimentSort","exports"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n division: string;\n instrument?: string;\n}\nexport interface SentimentWrapperConfig extends SentimentConfig {\n renderElementId: string;\n}\nexport interface SentimentWidgetConfig {\n division: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n division: string;\n}\n\nexport interface SentimentListData {\n name: string;\n sentiment: {\n shortPercent: number;\n longPercent: number;\n }\n}\n\nexport interface SentimentListResponse {\n sentimentList: SentimentListData[]\n}\n\nexport enum SentimentSort {\n Bearish = 'BEARISH',\n Bullish = 'BULLISH',\n}\n"],"mappings":";;;;;;IA6BYA,aAAa,GAAAC,OAAA,CAAAD,aAAA,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA"}
|
|
@@ -27,27 +27,27 @@ const Tool = _ref => {
|
|
|
27
27
|
}, [data, sort]);
|
|
28
28
|
return React.createElement("div", {
|
|
29
29
|
"data-testid": "sentiment-tool",
|
|
30
|
-
className: "text-sm text-black"
|
|
30
|
+
className: "lw-text-sm lw-text-black"
|
|
31
31
|
}, error ? React.createElement("div", {
|
|
32
|
-
className: "flex h-[200px] items-center justify-center border border-solid border-grey p-2"
|
|
32
|
+
className: "lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-grey lw-p-2"
|
|
33
33
|
}, React.createElement(ChartError, null)) : React.createElement(React.Fragment, null, React.createElement("div", {
|
|
34
|
-
className: "flex justify-end pb-5"
|
|
34
|
+
className: "lw-flex lw-justify-end lw-pb-5"
|
|
35
35
|
}, React.createElement(SortSwitch, {
|
|
36
36
|
disabled: loading,
|
|
37
37
|
selected: sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN,
|
|
38
38
|
onClickButtonDown: () => setSort(SentimentSort.Bearish),
|
|
39
39
|
onClickButtonUp: () => setSort(SentimentSort.Bullish)
|
|
40
40
|
})), React.createElement("div", {
|
|
41
|
-
className: "flex flex-col border border-solid border-grey p-2"
|
|
41
|
+
className: "lw-flex lw-flex-col lw-border lw-border-solid lw-border-grey lw-p-2"
|
|
42
42
|
}, sortedData.map((item, index) => React.createElement("div", {
|
|
43
|
-
className: "flex h-8 w-full items-center",
|
|
43
|
+
className: "lw-flex lw-h-8 lw-w-full lw-items-center",
|
|
44
44
|
key: item.name || index
|
|
45
45
|
}, React.createElement("div", {
|
|
46
|
-
className: "w-[120px] shrink-0"
|
|
46
|
+
className: "lw-w-[120px] lw-shrink-0"
|
|
47
47
|
}, loading ? React.createElement(Loader, {
|
|
48
48
|
size: LoaderSize.md
|
|
49
49
|
}) : React.createElement("p", {
|
|
50
|
-
className: "truncate font-sans font-bold"
|
|
50
|
+
className: "lw-truncate lw-font-sans lw-font-bold"
|
|
51
51
|
}, item.name || '\u2014')), React.createElement(Sentiment, {
|
|
52
52
|
isLoading: loading,
|
|
53
53
|
height: SentimentHeight.md,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tool.js","names":["React","useEffect","useState","Sentiment","SentimentHeight","Loader","LoaderSize","ChartError","useQuery","getSentimentList","SentimentSort","sortData","SelectedArrow","SortSwitch","Tool","_ref","division","sort","setSort","Bullish","sortedData","setSortedData","Array","fill","loading","data","error","variables","sentimentList","createElement","className","Fragment","disabled","selected","UP","DOWN","onClickButtonDown","Bearish","onClickButtonUp","map","item","index","key","name","size","md","isLoading","height","sentiment"],"sources":["../../../src/SentimentWidget/Tool.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport {\n Sentiment, SentimentHeight, Loader, LoaderSize, ChartError,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getSentimentList } from '../gql/getSentimentList';\nimport {\n SentimentListResponse, SentimentSort, SentimentListData, SentimentToolConfig,\n} from './types';\nimport { sortData } from './utils';\nimport { SelectedArrow, SortSwitch } from './components/SortSwitch';\n\nconst Tool = ({ division }: SentimentToolConfig) => {\n const [sort, setSort] = useState(SentimentSort.Bullish);\n const [sortedData, setSortedData] = useState<SentimentListData[]>(new Array(20).fill({}));\n const { loading, data, error } = useQuery<SentimentListResponse>(getSentimentList, {\n variables: {\n division,\n },\n });\n\n useEffect(() => {\n if (data) {\n setSortedData(sortData(data.sentimentList, sort));\n }\n }, [data, sort]);\n\n return (\n <div data-testid=\"sentiment-tool\" className=\"text-sm text-black\">\n {error ? (\n <div className=\"flex h-[200px] items-center justify-center border border-solid border-grey p-2\">\n <ChartError />\n </div>\n ) : (\n <>\n <div className=\"flex justify-end pb-5\">\n <SortSwitch\n disabled={loading}\n selected={sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN}\n onClickButtonDown={() => setSort(SentimentSort.Bearish)}\n onClickButtonUp={() => setSort(SentimentSort.Bullish)}\n />\n </div>\n <div className=\"flex flex-col border border-solid border-grey p-2\">\n {sortedData.map((item, index) => (\n <div className=\"flex h-8 w-full items-center\" key={item.name || index}>\n <div className=\"w-[120px] shrink-0\">\n {loading ? (\n <Loader size={LoaderSize.md} />\n ) : (\n <p className=\"truncate font-sans font-bold\">{item.name || '\\u2014'}</p>\n )}\n </div>\n <Sentiment\n isLoading={loading}\n height={SentimentHeight.md}\n sentiment={item.sentiment}\n />\n </div>\n ))}\n </div>\n </>\n )}\n </div>\n );\n};\n\nexport { Tool };\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAClD,SACEC,SAAS,EAAEC,eAAe,EAAEC,MAAM,EAAEC,UAAU,EAAEC,UAAU,QACrD,2BAA2B;AAClC,SAASC,QAAQ,QAAQ,gBAAgB;AACzC,SAASC,gBAAgB,QAAQ,yBAAyB;AAC1D,SACyBC,aAAa,QAC/B,SAAS;AAChB,SAASC,QAAQ,QAAQ,SAAS;AAClC,SAASC,aAAa,EAAEC,UAAU,QAAQ,yBAAyB;AAEnE,MAAMC,IAAI,GAAGC,IAAA,IAAuC;EAAA,IAAtC;IAAEC;EAA8B,CAAC,GAAAD,IAAA;EAC7C,MAAM,CAACE,IAAI,EAAEC,OAAO,CAAC,GAAGhB,QAAQ,CAACQ,aAAa,CAACS,OAAO,CAAC;EACvD,MAAM,CAACC,UAAU,EAAEC,aAAa,CAAC,GAAGnB,QAAQ,CAAsB,IAAIoB,KAAK,CAAC,EAAE,CAAC,CAACC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;EACzF,MAAM;IAAEC,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGlB,QAAQ,CAAwBC,gBAAgB,EAAE;IACjFkB,SAAS,EAAE;MACTX;IACF;EACF,CAAC,CAAC;EAEFf,SAAS,CAAC,MAAM;IACd,IAAIwB,IAAI,EAAE;MACRJ,aAAa,CAACV,QAAQ,CAACc,IAAI,CAACG,aAAa,EAAEX,IAAI,CAAC,CAAC;IACnD;EACF,CAAC,EAAE,CAACQ,IAAI,EAAER,IAAI,CAAC,CAAC;EAEhB,OACEjB,KAAA,CAAA6B,aAAA;IAAK,eAAY,gBAAgB;IAACC,SAAS,EAAC;
|
|
1
|
+
{"version":3,"file":"Tool.js","names":["React","useEffect","useState","Sentiment","SentimentHeight","Loader","LoaderSize","ChartError","useQuery","getSentimentList","SentimentSort","sortData","SelectedArrow","SortSwitch","Tool","_ref","division","sort","setSort","Bullish","sortedData","setSortedData","Array","fill","loading","data","error","variables","sentimentList","createElement","className","Fragment","disabled","selected","UP","DOWN","onClickButtonDown","Bearish","onClickButtonUp","map","item","index","key","name","size","md","isLoading","height","sentiment"],"sources":["../../../src/SentimentWidget/Tool.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport {\n Sentiment, SentimentHeight, Loader, LoaderSize, ChartError,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getSentimentList } from '../gql/getSentimentList';\nimport {\n SentimentListResponse, SentimentSort, SentimentListData, SentimentToolConfig,\n} from './types';\nimport { sortData } from './utils';\nimport { SelectedArrow, SortSwitch } from './components/SortSwitch';\n\nconst Tool = ({ division }: SentimentToolConfig) => {\n const [sort, setSort] = useState(SentimentSort.Bullish);\n const [sortedData, setSortedData] = useState<SentimentListData[]>(new Array(20).fill({}));\n const { loading, data, error } = useQuery<SentimentListResponse>(getSentimentList, {\n variables: {\n division,\n },\n });\n\n useEffect(() => {\n if (data) {\n setSortedData(sortData(data.sentimentList, sort));\n }\n }, [data, sort]);\n\n return (\n <div data-testid=\"sentiment-tool\" className=\"lw-text-sm lw-text-black\">\n {error ? (\n <div className=\"lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-grey 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={sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN}\n onClickButtonDown={() => setSort(SentimentSort.Bearish)}\n onClickButtonUp={() => setSort(SentimentSort.Bullish)}\n />\n </div>\n <div className=\"lw-flex lw-flex-col lw-border lw-border-solid lw-border-grey lw-p-2\">\n {sortedData.map((item, index) => (\n <div className=\"lw-flex lw-h-8 lw-w-full lw-items-center\" key={item.name || index}>\n <div className=\"lw-w-[120px] lw-shrink-0\">\n {loading ? (\n <Loader size={LoaderSize.md} />\n ) : (\n <p className=\"lw-truncate lw-font-sans lw-font-bold\">{item.name || '\\u2014'}</p>\n )}\n </div>\n <Sentiment\n isLoading={loading}\n height={SentimentHeight.md}\n sentiment={item.sentiment}\n />\n </div>\n ))}\n </div>\n </>\n )}\n </div>\n );\n};\n\nexport { Tool };\n"],"mappings":"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"}
|
|
@@ -23,9 +23,9 @@ const Widget = _ref => {
|
|
|
23
23
|
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;
|
|
24
24
|
return React.createElement("div", {
|
|
25
25
|
"data-testid": "sentiment-widget",
|
|
26
|
-
className: "flex items-center justify-between border border-solid border-grey p-4 text-sm text-black"
|
|
26
|
+
className: "lw-flex lw-items-center lw-justify-between lw-border lw-border-solid lw-border-grey lw-p-4 lw-text-sm lw-text-black"
|
|
27
27
|
}, !loading ? React.createElement(React.Fragment, null, React.createElement("p", {
|
|
28
|
-
className: "mr-12 font-sans font-bold"
|
|
28
|
+
className: "lw-mr-12 lw-font-sans lw-font-bold"
|
|
29
29
|
}, instrument), !isError && React.createElement(Sentiment, {
|
|
30
30
|
height: SentimentHeight.md,
|
|
31
31
|
sentiment: sentiment
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Widget.js","names":["React","Sentiment","SentimentHeight","Spinner","Error","useQuery","getInstrumentSentiment","Widget","_ref","instrument","division","loading","data","error","variables","name","sentiment","isError","shortPercent","longPercent","undefined","createElement","className","Fragment","height","md"],"sources":["../../../src/SentimentWidget/Widget.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Sentiment, SentimentHeight, Spinner, Error,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getInstrumentSentiment } from '../gql/getInstrumentSentiment';\nimport { SentimentWidgetConfig } from './types';\n\nconst Widget = ({ instrument, division }: SentimentWidgetConfig) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\n division,\n },\n });\n\n const { sentiment } = data?.sentiment[0] || {};\n const isError = error\n || (sentiment?.shortPercent === 0 && sentiment?.longPercent === 0)\n || sentiment?.shortPercent === undefined\n || sentiment?.longPercent === undefined;\n\n return (\n <div data-testid=\"sentiment-widget\" className=\"flex items-center justify-between border border-solid border-grey p-4 text-sm text-black\">\n {!loading\n ? (\n <>\n <p className=\"mr-12 font-sans font-bold\">{instrument}</p>\n {!isError && <Sentiment height={SentimentHeight.md} sentiment={sentiment} />}\n {isError && <Error />}\n </>\n ) : <Spinner />}\n </div>\n );\n};\n\nexport { Widget };\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SACEC,SAAS,EAAEC,eAAe,EAAEC,OAAO,EAAEC,KAAK,QACrC,2BAA2B;AAClC,SAASC,QAAQ,QAAQ,gBAAgB;AACzC,SAASC,sBAAsB,QAAQ,+BAA+B;AAGtE,MAAMC,MAAM,GAAGC,IAAA,IAAqD;EAAA,IAApD;IAAEC,UAAU;IAAEC;EAAgC,CAAC,GAAAF,IAAA;EAC7D,MAAM;IAAEG,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGR,QAAQ,CAACC,sBAAsB,EAAE;IAChEQ,SAAS,EAAE;MACTC,IAAI,EAAEN,UAAU;MAChBC;IACF;EACF,CAAC,CAAC;EAEF,MAAM;IAAEM;EAAU,CAAC,GAAG,CAAAJ,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEI,SAAS,CAAC,CAAC,CAAC,KAAI,CAAC,CAAC;EAC9C,MAAMC,OAAO,GAAGJ,KAAK,IACf,CAAAG,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAK,CAAC,IAAI,CAAAF,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAK,CAAE,IAC/D,CAAAH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAKE,SAAS,IACrC,CAAAJ,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAKC,SAAS;EAEzC,OACEpB,KAAA,CAAAqB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;
|
|
1
|
+
{"version":3,"file":"Widget.js","names":["React","Sentiment","SentimentHeight","Spinner","Error","useQuery","getInstrumentSentiment","Widget","_ref","instrument","division","loading","data","error","variables","name","sentiment","isError","shortPercent","longPercent","undefined","createElement","className","Fragment","height","md"],"sources":["../../../src/SentimentWidget/Widget.tsx"],"sourcesContent":["import React from 'react';\nimport {\n Sentiment, SentimentHeight, Spinner, Error,\n} from '@oanda/labs-widget-common';\nimport { useQuery } from '@apollo/client';\nimport { getInstrumentSentiment } from '../gql/getInstrumentSentiment';\nimport { SentimentWidgetConfig } from './types';\n\nconst Widget = ({ instrument, division }: SentimentWidgetConfig) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\n division,\n },\n });\n\n const { sentiment } = data?.sentiment[0] || {};\n const isError = error\n || (sentiment?.shortPercent === 0 && sentiment?.longPercent === 0)\n || sentiment?.shortPercent === undefined\n || sentiment?.longPercent === undefined;\n\n return (\n <div data-testid=\"sentiment-widget\" className=\"lw-flex lw-items-center lw-justify-between lw-border lw-border-solid lw-border-grey lw-p-4 lw-text-sm lw-text-black\">\n {!loading\n ? (\n <>\n <p className=\"lw-mr-12 lw-font-sans lw-font-bold\">{instrument}</p>\n {!isError && <Sentiment height={SentimentHeight.md} sentiment={sentiment} />}\n {isError && <Error />}\n </>\n ) : <Spinner />}\n </div>\n );\n};\n\nexport { Widget };\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SACEC,SAAS,EAAEC,eAAe,EAAEC,OAAO,EAAEC,KAAK,QACrC,2BAA2B;AAClC,SAASC,QAAQ,QAAQ,gBAAgB;AACzC,SAASC,sBAAsB,QAAQ,+BAA+B;AAGtE,MAAMC,MAAM,GAAGC,IAAA,IAAqD;EAAA,IAApD;IAAEC,UAAU;IAAEC;EAAgC,CAAC,GAAAF,IAAA;EAC7D,MAAM;IAAEG,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGR,QAAQ,CAACC,sBAAsB,EAAE;IAChEQ,SAAS,EAAE;MACTC,IAAI,EAAEN,UAAU;MAChBC;IACF;EACF,CAAC,CAAC;EAEF,MAAM;IAAEM;EAAU,CAAC,GAAG,CAAAJ,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEI,SAAS,CAAC,CAAC,CAAC,KAAI,CAAC,CAAC;EAC9C,MAAMC,OAAO,GAAGJ,KAAK,IACf,CAAAG,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAK,CAAC,IAAI,CAAAF,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAK,CAAE,IAC/D,CAAAH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEE,YAAY,MAAKE,SAAS,IACrC,CAAAJ,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEG,WAAW,MAAKC,SAAS;EAEzC,OACEpB,KAAA,CAAAqB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;EAAqH,GAChK,CAACX,OAAO,GAELX,KAAA,CAAAqB,aAAA,CAAArB,KAAA,CAAAuB,QAAA,QACEvB,KAAA,CAAAqB,aAAA;IAAGC,SAAS,EAAC;EAAoC,GAAEb,UAAc,CAAC,EACjE,CAACQ,OAAO,IAAIjB,KAAA,CAAAqB,aAAA,CAACpB,SAAS;IAACuB,MAAM,EAAEtB,eAAe,CAACuB,EAAG;IAACT,SAAS,EAAEA;EAAU,CAAE,CAAC,EAC3EC,OAAO,IAAIjB,KAAA,CAAAqB,aAAA,CAACjB,KAAK,MAAE,CACpB,CAAC,GACDJ,KAAA,CAAAqB,aAAA,CAAClB,OAAO,MAAE,CACb,CAAC;AAEV,CAAC;AAED,SAASI,MAAM"}
|
|
@@ -11,37 +11,37 @@ const SortSwitch = _ref => {
|
|
|
11
11
|
} = _ref;
|
|
12
12
|
return React.createElement("div", {
|
|
13
13
|
"data-testid": "sort-switch",
|
|
14
|
-
className: classnames('flex rounded border-[1px] border-solid font-sans text-xs', {
|
|
15
|
-
'border-darkGrey': disabled,
|
|
16
|
-
'border-navyBlue': !disabled
|
|
14
|
+
className: classnames('lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs', {
|
|
15
|
+
'lw-border-darkGrey': disabled,
|
|
16
|
+
'lw-border-navyBlue': !disabled
|
|
17
17
|
})
|
|
18
18
|
}, React.createElement("button", {
|
|
19
19
|
"data-testid": "sort-switch-button-up",
|
|
20
20
|
disabled: disabled || selected === SelectedArrow.UP,
|
|
21
21
|
type: "button",
|
|
22
22
|
onClick: onClickButtonUp,
|
|
23
|
-
className: classnames('flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1', {
|
|
24
|
-
'bg-navyBlue': selected === SelectedArrow.UP && !disabled
|
|
23
|
+
className: classnames('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-r-[1px] lw-border-solid [&:enabled:hover>*]:-lw-translate-y-1', {
|
|
24
|
+
'lw-bg-navyBlue': selected === SelectedArrow.UP && !disabled
|
|
25
25
|
})
|
|
26
26
|
}, React.createElement(LongArrowUp, {
|
|
27
|
-
className: classnames('transition-transform', {
|
|
28
|
-
'stroke-darkGrey': disabled,
|
|
29
|
-
'stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,
|
|
30
|
-
'stroke-green': selected === SelectedArrow.UP && !disabled
|
|
27
|
+
className: classnames('lw-transition-transform', {
|
|
28
|
+
'lw-stroke-darkGrey': disabled,
|
|
29
|
+
'lw-stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,
|
|
30
|
+
'lw-stroke-green': selected === SelectedArrow.UP && !disabled
|
|
31
31
|
})
|
|
32
32
|
})), React.createElement("button", {
|
|
33
33
|
"data-testid": "sort-switch-button-down",
|
|
34
34
|
disabled: disabled || selected === SelectedArrow.DOWN,
|
|
35
35
|
type: "button",
|
|
36
36
|
onClick: onClickButtonDown,
|
|
37
|
-
className: classnames('flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1', {
|
|
38
|
-
'bg-navyBlue': selected === SelectedArrow.DOWN && !disabled
|
|
37
|
+
className: classnames('lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center [&:enabled:hover>*]:lw-translate-y-1', {
|
|
38
|
+
'lw-bg-navyBlue': selected === SelectedArrow.DOWN && !disabled
|
|
39
39
|
})
|
|
40
40
|
}, React.createElement(LongArrowDown, {
|
|
41
|
-
className: classnames('transition-transform', {
|
|
42
|
-
'stroke-darkGrey': disabled,
|
|
43
|
-
'stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,
|
|
44
|
-
'stroke-green': selected === SelectedArrow.DOWN && !disabled
|
|
41
|
+
className: classnames('lw-transition-transform', {
|
|
42
|
+
'lw-stroke-darkGrey': disabled,
|
|
43
|
+
'lw-stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,
|
|
44
|
+
'lw-stroke-green': selected === SelectedArrow.DOWN && !disabled
|
|
45
45
|
})
|
|
46
46
|
})));
|
|
47
47
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortSwitch.js","names":["React","classnames","LongArrowUp","LongArrowDown","SelectedArrow","SortSwitch","_ref","onClickButtonDown","onClickButtonUp","selected","disabled","createElement","className","UP","type","onClick","DOWN"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/SortSwitch.tsx"],"sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport { LongArrowUp, LongArrowDown } from '@oanda/labs-widget-common';\nimport { SelectedArrow, SortSwitchProps } from './types';\n\nconst SortSwitch = ({\n onClickButtonDown, onClickButtonUp, selected, disabled,\n}: SortSwitchProps) => (\n <div\n data-testid=\"sort-switch\"\n className={classnames(\n 'flex rounded border-[1px] border-solid font-sans text-xs',\n {\n 'border-darkGrey': disabled,\n 'border-navyBlue': !disabled,\n },\n )}\n >\n <button\n data-testid=\"sort-switch-button-up\"\n disabled={disabled || selected === SelectedArrow.UP}\n type=\"button\"\n onClick={onClickButtonUp}\n className={classnames(\n 'flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1',\n {\n 'bg-navyBlue': selected === SelectedArrow.UP && !disabled,\n },\n )}\n >\n <LongArrowUp\n className={classnames(\n 'transition-transform',\n {\n 'stroke-darkGrey': disabled,\n 'stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,\n 'stroke-green': selected === SelectedArrow.UP && !disabled,\n },\n )}\n />\n </button>\n <button\n data-testid=\"sort-switch-button-down\"\n disabled={disabled || selected === SelectedArrow.DOWN}\n type=\"button\"\n onClick={onClickButtonDown}\n className={classnames(\n 'flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1',\n {\n 'bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n >\n <LongArrowDown\n className={classnames(\n 'transition-transform',\n {\n 'stroke-darkGrey': disabled,\n 'stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,\n 'stroke-green': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n />\n </button>\n </div>\n);\n\nexport {\n SortSwitch,\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,WAAW,EAAEC,aAAa,QAAQ,2BAA2B;AACtE,SAASC,aAAa,QAAyB,SAAS;AAExD,MAAMC,UAAU,GAAGC,IAAA;EAAA,IAAC;IAClBC,iBAAiB;IAAEC,eAAe;IAAEC,QAAQ;IAAEC;EAC/B,CAAC,GAAAJ,IAAA;EAAA,OAChBN,KAAA,CAAAW,aAAA;IACE,eAAY,aAAa;IACzBC,SAAS,EAAEX,UAAU,CACnB,
|
|
1
|
+
{"version":3,"file":"SortSwitch.js","names":["React","classnames","LongArrowUp","LongArrowDown","SelectedArrow","SortSwitch","_ref","onClickButtonDown","onClickButtonUp","selected","disabled","createElement","className","UP","type","onClick","DOWN"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/SortSwitch.tsx"],"sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport { LongArrowUp, LongArrowDown } from '@oanda/labs-widget-common';\nimport { SelectedArrow, SortSwitchProps } from './types';\n\nconst SortSwitch = ({\n onClickButtonDown, onClickButtonUp, selected, disabled,\n}: SortSwitchProps) => (\n <div\n data-testid=\"sort-switch\"\n className={classnames(\n 'lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs',\n {\n 'lw-border-darkGrey': disabled,\n 'lw-border-navyBlue': !disabled,\n },\n )}\n >\n <button\n data-testid=\"sort-switch-button-up\"\n disabled={disabled || selected === SelectedArrow.UP}\n type=\"button\"\n onClick={onClickButtonUp}\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-r-[1px] lw-border-solid [&:enabled:hover>*]:-lw-translate-y-1',\n {\n 'lw-bg-navyBlue': selected === SelectedArrow.UP && !disabled,\n },\n )}\n >\n <LongArrowUp\n className={classnames(\n 'lw-transition-transform',\n {\n 'lw-stroke-darkGrey': disabled,\n 'lw-stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,\n 'lw-stroke-green': selected === SelectedArrow.UP && !disabled,\n },\n )}\n />\n </button>\n <button\n data-testid=\"sort-switch-button-down\"\n disabled={disabled || selected === SelectedArrow.DOWN}\n type=\"button\"\n onClick={onClickButtonDown}\n className={classnames(\n 'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center [&:enabled:hover>*]:lw-translate-y-1',\n {\n 'lw-bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n >\n <LongArrowDown\n className={classnames(\n 'lw-transition-transform',\n {\n 'lw-stroke-darkGrey': disabled,\n 'lw-stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,\n 'lw-stroke-green': selected === SelectedArrow.DOWN && !disabled,\n },\n )}\n />\n </button>\n </div>\n);\n\nexport {\n SortSwitch,\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,WAAW,EAAEC,aAAa,QAAQ,2BAA2B;AACtE,SAASC,aAAa,QAAyB,SAAS;AAExD,MAAMC,UAAU,GAAGC,IAAA;EAAA,IAAC;IAClBC,iBAAiB;IAAEC,eAAe;IAAEC,QAAQ;IAAEC;EAC/B,CAAC,GAAAJ,IAAA;EAAA,OAChBN,KAAA,CAAAW,aAAA;IACE,eAAY,aAAa;IACzBC,SAAS,EAAEX,UAAU,CACnB,4EAA4E,EAC5E;MACE,oBAAoB,EAAES,QAAQ;MAC9B,oBAAoB,EAAE,CAACA;IACzB,CACF;EAAE,GAEFV,KAAA,CAAAW,aAAA;IACE,eAAY,uBAAuB;IACnCD,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKL,aAAa,CAACS,EAAG;IACpDC,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAEP,eAAgB;IACzBI,SAAS,EAAEX,UAAU,CACnB,8IAA8I,EAC9I;MACE,gBAAgB,EAAEQ,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH;IACtD,CACF;EAAE,GAEFV,KAAA,CAAAW,aAAA,CAACT,WAAW;IACVU,SAAS,EAAEX,UAAU,CACnB,yBAAyB,EACzB;MACE,oBAAoB,EAAES,QAAQ;MAC9B,oBAAoB,EAAED,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH,QAAQ;MAChE,iBAAiB,EAAED,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH;IACvD,CACF;EAAE,CACH,CACK,CAAC,EACTV,KAAA,CAAAW,aAAA;IACE,eAAY,yBAAyB;IACrCD,QAAQ,EAAEA,QAAQ,IAAID,QAAQ,KAAKL,aAAa,CAACY,IAAK;IACtDF,IAAI,EAAC,QAAQ;IACbC,OAAO,EAAER,iBAAkB;IAC3BK,SAAS,EAAEX,UAAU,CACnB,yHAAyH,EACzH;MACE,gBAAgB,EAAEQ,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN;IACxD,CACF;EAAE,GAEFV,KAAA,CAAAW,aAAA,CAACR,aAAa;IACZS,SAAS,EAAEX,UAAU,CACnB,yBAAyB,EACzB;MACE,oBAAoB,EAAES,QAAQ;MAC9B,oBAAoB,EAAED,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN,QAAQ;MAClE,iBAAiB,EAAED,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN;IACzD,CACF;EAAE,CACH,CACK,CACL,CAAC;AAAA,CACP;AAED,SACEL,UAAU"}
|
|
@@ -4,11 +4,12 @@ import { SentimentWidget } from './SentimentWidget';
|
|
|
4
4
|
const {
|
|
5
5
|
graphqlUrl,
|
|
6
6
|
division,
|
|
7
|
-
instrument
|
|
7
|
+
instrument,
|
|
8
|
+
renderElementId
|
|
8
9
|
} = window.sentimentWidgetConfig;
|
|
9
10
|
render(React.createElement(SentimentWidget, {
|
|
10
11
|
graphqlUrl: graphqlUrl,
|
|
11
12
|
division: division,
|
|
12
13
|
instrument: instrument
|
|
13
|
-
}), document.getElementById(
|
|
14
|
+
}), document.getElementById(renderElementId));
|
|
14
15
|
//# sourceMappingURL=render.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"render.js","names":["React","render","SentimentWidget","graphqlUrl","division","instrument","window","sentimentWidgetConfig","createElement","document","getElementById"],"sources":["../../../src/SentimentWidget/render.tsx"],"sourcesContent":["import React from 'react';\nimport { render } from 'react-dom';\nimport { SentimentWidget } from './SentimentWidget';\nimport {
|
|
1
|
+
{"version":3,"file":"render.js","names":["React","render","SentimentWidget","graphqlUrl","division","instrument","renderElementId","window","sentimentWidgetConfig","createElement","document","getElementById"],"sources":["../../../src/SentimentWidget/render.tsx"],"sourcesContent":["import React from 'react';\nimport { render } from 'react-dom';\nimport { SentimentWidget } from './SentimentWidget';\nimport { SentimentWrapperConfig } from './types';\n\ndeclare global {\n interface Window {\n sentimentWidgetConfig: SentimentWrapperConfig;\n }\n}\n\nconst {\n graphqlUrl,\n division,\n instrument,\n renderElementId,\n} = window.sentimentWidgetConfig;\n\nrender(\n <SentimentWidget\n graphqlUrl={graphqlUrl}\n division={division}\n instrument={instrument}\n />,\n document.getElementById(renderElementId),\n);\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,eAAe,QAAQ,mBAAmB;AASnD,MAAM;EACJC,UAAU;EACVC,QAAQ;EACRC,UAAU;EACVC;AACF,CAAC,GAAGC,MAAM,CAACC,qBAAqB;AAEhCP,MAAM,CACJD,KAAA,CAAAS,aAAA,CAACP,eAAe;EACdC,UAAU,EAAEA,UAAW;EACvBC,QAAQ,EAAEA,QAAS;EACnBC,UAAU,EAAEA;AAAW,CACxB,CAAC,EACFK,QAAQ,CAACC,cAAc,CAACL,eAAe,CACzC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":["SentimentSort"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n division: string;\n instrument?: string;\n}\n\nexport interface SentimentWidgetConfig {\n division: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n division: string;\n}\n\nexport interface SentimentListData {\n name: string;\n sentiment: {\n shortPercent: number;\n longPercent: number;\n }\n}\n\nexport interface SentimentListResponse {\n sentimentList: SentimentListData[]\n}\n\nexport enum SentimentSort {\n Bearish = 'BEARISH',\n Bullish = 'BULLISH',\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","names":["SentimentSort"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n division: string;\n instrument?: string;\n}\nexport interface SentimentWrapperConfig extends SentimentConfig {\n renderElementId: string;\n}\nexport interface SentimentWidgetConfig {\n division: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n division: string;\n}\n\nexport interface SentimentListData {\n name: string;\n sentiment: {\n shortPercent: number;\n longPercent: number;\n }\n}\n\nexport interface SentimentListResponse {\n sentimentList: SentimentListData[]\n}\n\nexport enum SentimentSort {\n Bearish = 'BEARISH',\n Bullish = 'BULLISH',\n}\n"],"mappings":"AA6BA,WAAYA,aAAa,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA"}
|
|
@@ -3,6 +3,9 @@ export interface SentimentConfig {
|
|
|
3
3
|
division: string;
|
|
4
4
|
instrument?: string;
|
|
5
5
|
}
|
|
6
|
+
export interface SentimentWrapperConfig extends SentimentConfig {
|
|
7
|
+
renderElementId: string;
|
|
8
|
+
}
|
|
6
9
|
export interface SentimentWidgetConfig {
|
|
7
10
|
division: string;
|
|
8
11
|
instrument: string;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@oanda/labs-sentiment-widget",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.16",
|
|
4
4
|
"description": "Labs Sentiment Widget",
|
|
5
5
|
"main": "dist/main/index.js",
|
|
6
6
|
"module": "dist/module/index.js",
|
|
@@ -11,9 +11,9 @@
|
|
|
11
11
|
"license": "UNLICENSED",
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@apollo/client": "3.7.17",
|
|
14
|
-
"@oanda/labs-widget-common": "^1.0.
|
|
14
|
+
"@oanda/labs-widget-common": "^1.0.16",
|
|
15
15
|
"classnames": "2.3.2",
|
|
16
16
|
"graphql": "16.7.1"
|
|
17
17
|
},
|
|
18
|
-
"gitHead": "
|
|
18
|
+
"gitHead": "d3da8df6da16f89440ea05148ad3472e3213e592"
|
|
19
19
|
}
|
|
@@ -26,14 +26,14 @@ const Tool = ({ division }: SentimentToolConfig) => {
|
|
|
26
26
|
}, [data, sort]);
|
|
27
27
|
|
|
28
28
|
return (
|
|
29
|
-
<div data-testid="sentiment-tool" className="text-sm text-black">
|
|
29
|
+
<div data-testid="sentiment-tool" className="lw-text-sm lw-text-black">
|
|
30
30
|
{error ? (
|
|
31
|
-
<div className="flex h-[200px] items-center justify-center border border-solid border-grey p-2">
|
|
31
|
+
<div className="lw-flex lw-h-[200px] lw-items-center lw-justify-center lw-border lw-border-solid lw-border-grey lw-p-2">
|
|
32
32
|
<ChartError />
|
|
33
33
|
</div>
|
|
34
34
|
) : (
|
|
35
35
|
<>
|
|
36
|
-
<div className="flex justify-end pb-5">
|
|
36
|
+
<div className="lw-flex lw-justify-end lw-pb-5">
|
|
37
37
|
<SortSwitch
|
|
38
38
|
disabled={loading}
|
|
39
39
|
selected={sort === SentimentSort.Bullish ? SelectedArrow.UP : SelectedArrow.DOWN}
|
|
@@ -41,14 +41,14 @@ const Tool = ({ division }: SentimentToolConfig) => {
|
|
|
41
41
|
onClickButtonUp={() => setSort(SentimentSort.Bullish)}
|
|
42
42
|
/>
|
|
43
43
|
</div>
|
|
44
|
-
<div className="flex flex-col border border-solid border-grey p-2">
|
|
44
|
+
<div className="lw-flex lw-flex-col lw-border lw-border-solid lw-border-grey lw-p-2">
|
|
45
45
|
{sortedData.map((item, index) => (
|
|
46
|
-
<div className="flex h-8 w-full items-center" key={item.name || index}>
|
|
47
|
-
<div className="w-[120px] shrink-0">
|
|
46
|
+
<div className="lw-flex lw-h-8 lw-w-full lw-items-center" key={item.name || index}>
|
|
47
|
+
<div className="lw-w-[120px] lw-shrink-0">
|
|
48
48
|
{loading ? (
|
|
49
49
|
<Loader size={LoaderSize.md} />
|
|
50
50
|
) : (
|
|
51
|
-
<p className="truncate font-sans font-bold">{item.name || '\u2014'}</p>
|
|
51
|
+
<p className="lw-truncate lw-font-sans lw-font-bold">{item.name || '\u2014'}</p>
|
|
52
52
|
)}
|
|
53
53
|
</div>
|
|
54
54
|
<Sentiment
|
|
@@ -21,11 +21,11 @@ const Widget = ({ instrument, division }: SentimentWidgetConfig) => {
|
|
|
21
21
|
|| sentiment?.longPercent === undefined;
|
|
22
22
|
|
|
23
23
|
return (
|
|
24
|
-
<div data-testid="sentiment-widget" className="flex items-center justify-between border border-solid border-grey p-4 text-sm text-black">
|
|
24
|
+
<div data-testid="sentiment-widget" className="lw-flex lw-items-center lw-justify-between lw-border lw-border-solid lw-border-grey lw-p-4 lw-text-sm lw-text-black">
|
|
25
25
|
{!loading
|
|
26
26
|
? (
|
|
27
27
|
<>
|
|
28
|
-
<p className="mr-12 font-sans font-bold">{instrument}</p>
|
|
28
|
+
<p className="lw-mr-12 lw-font-sans lw-font-bold">{instrument}</p>
|
|
29
29
|
{!isError && <Sentiment height={SentimentHeight.md} sentiment={sentiment} />}
|
|
30
30
|
{isError && <Error />}
|
|
31
31
|
</>
|
|
@@ -9,10 +9,10 @@ const SortSwitch = ({
|
|
|
9
9
|
<div
|
|
10
10
|
data-testid="sort-switch"
|
|
11
11
|
className={classnames(
|
|
12
|
-
'flex rounded border-[1px] border-solid font-sans text-xs',
|
|
12
|
+
'lw-flex lw-rounded lw-border-[1px] lw-border-solid lw-font-sans lw-text-xs',
|
|
13
13
|
{
|
|
14
|
-
'border-darkGrey': disabled,
|
|
15
|
-
'border-navyBlue': !disabled,
|
|
14
|
+
'lw-border-darkGrey': disabled,
|
|
15
|
+
'lw-border-navyBlue': !disabled,
|
|
16
16
|
},
|
|
17
17
|
)}
|
|
18
18
|
>
|
|
@@ -22,19 +22,19 @@ const SortSwitch = ({
|
|
|
22
22
|
type="button"
|
|
23
23
|
onClick={onClickButtonUp}
|
|
24
24
|
className={classnames(
|
|
25
|
-
'flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1',
|
|
25
|
+
'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-border-r-[1px] lw-border-solid [&:enabled:hover>*]:-lw-translate-y-1',
|
|
26
26
|
{
|
|
27
|
-
'bg-navyBlue': selected === SelectedArrow.UP && !disabled,
|
|
27
|
+
'lw-bg-navyBlue': selected === SelectedArrow.UP && !disabled,
|
|
28
28
|
},
|
|
29
29
|
)}
|
|
30
30
|
>
|
|
31
31
|
<LongArrowUp
|
|
32
32
|
className={classnames(
|
|
33
|
-
'transition-transform',
|
|
33
|
+
'lw-transition-transform',
|
|
34
34
|
{
|
|
35
|
-
'stroke-darkGrey': disabled,
|
|
36
|
-
'stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,
|
|
37
|
-
'stroke-green': selected === SelectedArrow.UP && !disabled,
|
|
35
|
+
'lw-stroke-darkGrey': disabled,
|
|
36
|
+
'lw-stroke-navyBlue': selected !== SelectedArrow.UP && !disabled,
|
|
37
|
+
'lw-stroke-green': selected === SelectedArrow.UP && !disabled,
|
|
38
38
|
},
|
|
39
39
|
)}
|
|
40
40
|
/>
|
|
@@ -45,19 +45,19 @@ const SortSwitch = ({
|
|
|
45
45
|
type="button"
|
|
46
46
|
onClick={onClickButtonDown}
|
|
47
47
|
className={classnames(
|
|
48
|
-
'flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1',
|
|
48
|
+
'lw-flex lw-h-11 lw-w-11 lw-grow-0 lw-items-center lw-justify-center lw-text-center [&:enabled:hover>*]:lw-translate-y-1',
|
|
49
49
|
{
|
|
50
|
-
'bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,
|
|
50
|
+
'lw-bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,
|
|
51
51
|
},
|
|
52
52
|
)}
|
|
53
53
|
>
|
|
54
54
|
<LongArrowDown
|
|
55
55
|
className={classnames(
|
|
56
|
-
'transition-transform',
|
|
56
|
+
'lw-transition-transform',
|
|
57
57
|
{
|
|
58
|
-
'stroke-darkGrey': disabled,
|
|
59
|
-
'stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,
|
|
60
|
-
'stroke-green': selected === SelectedArrow.DOWN && !disabled,
|
|
58
|
+
'lw-stroke-darkGrey': disabled,
|
|
59
|
+
'lw-stroke-navyBlue': selected !== SelectedArrow.DOWN && !disabled,
|
|
60
|
+
'lw-stroke-green': selected === SelectedArrow.DOWN && !disabled,
|
|
61
61
|
},
|
|
62
62
|
)}
|
|
63
63
|
/>
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { render } from 'react-dom';
|
|
3
3
|
import { SentimentWidget } from './SentimentWidget';
|
|
4
|
-
import {
|
|
4
|
+
import { SentimentWrapperConfig } from './types';
|
|
5
5
|
|
|
6
6
|
declare global {
|
|
7
7
|
interface Window {
|
|
8
|
-
sentimentWidgetConfig:
|
|
8
|
+
sentimentWidgetConfig: SentimentWrapperConfig;
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
11
|
|
|
@@ -13,6 +13,7 @@ const {
|
|
|
13
13
|
graphqlUrl,
|
|
14
14
|
division,
|
|
15
15
|
instrument,
|
|
16
|
+
renderElementId,
|
|
16
17
|
} = window.sentimentWidgetConfig;
|
|
17
18
|
|
|
18
19
|
render(
|
|
@@ -21,5 +22,5 @@ render(
|
|
|
21
22
|
division={division}
|
|
22
23
|
instrument={instrument}
|
|
23
24
|
/>,
|
|
24
|
-
document.getElementById(
|
|
25
|
+
document.getElementById(renderElementId),
|
|
25
26
|
);
|
|
@@ -3,7 +3,9 @@ export interface SentimentConfig {
|
|
|
3
3
|
division: string;
|
|
4
4
|
instrument?: string;
|
|
5
5
|
}
|
|
6
|
-
|
|
6
|
+
export interface SentimentWrapperConfig extends SentimentConfig {
|
|
7
|
+
renderElementId: string;
|
|
8
|
+
}
|
|
7
9
|
export interface SentimentWidgetConfig {
|
|
8
10
|
division: string;
|
|
9
11
|
instrument: string;
|