@oanda/labs-sentiment-widget 1.0.6 → 1.0.8
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 +36 -0
- package/dist/main/SentimentWidget/Widget.js +0 -1
- package/dist/main/SentimentWidget/Widget.js.map +1 -1
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js +4 -3
- package/dist/main/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/main/SentimentWidget/components/SortSwitch/types.js +1 -2
- package/dist/main/SentimentWidget/components/SortSwitch/types.js.map +1 -1
- package/dist/main/SentimentWidget/types.js +1 -2
- package/dist/main/SentimentWidget/types.js.map +1 -1
- package/dist/main/gql/getInstrumentSentiment.js +1 -2
- package/dist/main/gql/getInstrumentSentiment.js.map +1 -1
- package/dist/main/gql/getSentimentList.js +1 -2
- package/dist/main/gql/getSentimentList.js.map +1 -1
- package/dist/module/SentimentWidget/Widget.js +0 -1
- package/dist/module/SentimentWidget/Widget.js.map +1 -1
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js +4 -3
- package/dist/module/SentimentWidget/components/SortSwitch/SortSwitch.js.map +1 -1
- package/dist/module/SentimentWidget/types.js.map +1 -1
- package/dist/module/gql/getInstrumentSentiment.js +1 -1
- package/dist/module/gql/getInstrumentSentiment.js.map +1 -1
- package/dist/types/SentimentWidget/types.d.ts +0 -1
- package/package.json +3 -3
- package/src/SentimentWidget/Widget.tsx +0 -1
- package/src/SentimentWidget/components/SortSwitch/SortSwitch.tsx +7 -3
- package/src/SentimentWidget/types.ts +0 -1
- package/src/gql/getInstrumentSentiment.ts +0 -2
- package/test/Widget.test.tsx +0 -2
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,42 @@
|
|
|
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.8 (2023-09-27)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
## 1.0.7 (2023-09-26)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## 1.0.6 (2023-09-21)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
## 1.0.5 (2023-09-13)
|
|
19
|
+
|
|
20
|
+
**Note:** Version bump only for package @oanda/labs-sentiment-widget
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
## 1.0.7 (2023-09-26)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
## 1.0.6 (2023-09-21)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
## 1.0.5 (2023-09-13)
|
|
35
|
+
|
|
36
|
+
**Note:** Version bump only for package @oanda/labs-sentiment-widget
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
|
|
6
42
|
## 1.0.6 (2023-09-21)
|
|
7
43
|
|
|
8
44
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Widget.js","names":["_react","_interopRequireDefault","require","_labsWidgetCommon","_client","_getInstrumentSentiment","obj","__esModule","default","Widget","_ref","instrument","loading","data","error","useQuery","getInstrumentSentiment","variables","
|
|
1
|
+
{"version":3,"file":"Widget.js","names":["_react","_interopRequireDefault","require","_labsWidgetCommon","_client","_getInstrumentSentiment","obj","__esModule","default","Widget","_ref","instrument","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';\n\nconst Widget = ({ instrument }: { instrument: string }) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\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;AAEvE,MAAMG,MAAM,GAAGC,IAAA,IAA4C;EAAA,IAA3C;IAAEC;EAAmC,CAAC,GAAAD,IAAA;EACpD,MAAM;IAAEE,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAG,IAAAC,gBAAQ,EAACC,8CAAsB,EAAE;IAChEC,SAAS,EAAE;MACTC,IAAI,EAAEP;IACR;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,OACEvB,MAAA,CAAAQ,OAAA,CAAAgB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;EAA0F,GACrI,CAACb,OAAO,GAELZ,MAAA,CAAAQ,OAAA,CAAAgB,aAAA,CAAAxB,MAAA,CAAAQ,OAAA,CAAAkB,QAAA,QACE1B,MAAA,CAAAQ,OAAA,CAAAgB,aAAA;IAAGC,SAAS,EAAC;EAA2B,GAAEd,UAAc,CAAC,EACxD,CAACS,OAAO,IAAIpB,MAAA,CAAAQ,OAAA,CAAAgB,aAAA,CAACrB,iBAAA,CAAAwB,SAAS;IAACC,MAAM,EAAEC,iCAAe,CAACC,EAAG;IAACX,SAAS,EAAEA;EAAU,CAAE,CAAC,EAC3EC,OAAO,IAAIpB,MAAA,CAAAQ,OAAA,CAAAgB,aAAA,CAACrB,iBAAA,CAAA4B,KAAK,MAAE,CACpB,CAAC,GACD/B,MAAA,CAAAQ,OAAA,CAAAgB,aAAA,CAACrB,iBAAA,CAAA6B,OAAO,MAAE,CACb,CAAC;AAEV,CAAC;AAACC,OAAA,CAAAxB,MAAA,GAAAA,MAAA"}
|
|
@@ -28,8 +28,7 @@ const SortSwitch = _ref => {
|
|
|
28
28
|
type: "button",
|
|
29
29
|
onClick: onClickButtonUp,
|
|
30
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
|
-
'
|
|
32
|
-
'border-navyBlue': !disabled
|
|
31
|
+
'bg-navyBlue': selected === _types.SelectedArrow.UP && !disabled
|
|
33
32
|
})
|
|
34
33
|
}, _react.default.createElement(_labsWidgetCommon.LongArrowUp, {
|
|
35
34
|
className: (0, _classnames.default)('transition-transform', {
|
|
@@ -42,7 +41,9 @@ const SortSwitch = _ref => {
|
|
|
42
41
|
disabled: disabled || selected === _types.SelectedArrow.DOWN,
|
|
43
42
|
type: "button",
|
|
44
43
|
onClick: onClickButtonDown,
|
|
45
|
-
className:
|
|
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
|
|
46
|
+
})
|
|
46
47
|
}, _react.default.createElement(_labsWidgetCommon.LongArrowDown, {
|
|
47
48
|
className: (0, _classnames.default)('transition-transform', {
|
|
48
49
|
'stroke-darkGrey': disabled,
|
|
@@ -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 '
|
|
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,0DAA0D,EAC1D;MACE,iBAAiB,EAAEH,QAAQ;MAC3B,iBAAiB,EAAE,CAACA;IACtB,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,mHAAmH,EACnH;MACE,aAAa,EAAEJ,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL;IACnD,CACF;EAAE,GAEFd,MAAA,CAAAQ,OAAA,CAAAO,aAAA,CAACX,iBAAA,CAAAkB,WAAW;IACVN,SAAS,EAAE,IAAAC,mBAAU,EACnB,sBAAsB,EACtB;MACE,iBAAiB,EAAEH,QAAQ;MAC3B,iBAAiB,EAAED,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL,QAAQ;MAC7D,cAAc,EAAED,QAAQ,KAAKK,oBAAa,CAACC,EAAE,IAAI,CAACL;IACpD,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,iGAAiG,EACjG;MACE,aAAa,EAAEJ,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT;IACrD,CACF;EAAE,GAEFd,MAAA,CAAAQ,OAAA,CAAAO,aAAA,CAACX,iBAAA,CAAAoB,aAAa;IACZR,SAAS,EAAE,IAAAC,mBAAU,EACnB,sBAAsB,EACtB;MACE,iBAAiB,EAAEH,QAAQ;MAC3B,iBAAiB,EAAED,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT,QAAQ;MAC/D,cAAc,EAAED,QAAQ,KAAKK,oBAAa,CAACK,IAAI,IAAI,CAACT;IACtD,CACF;EAAE,CACH,CACK,CACL,CAAC;AAAA,CACP;AAACW,OAAA,CAAAhB,UAAA,GAAAA,UAAA"}
|
|
@@ -4,10 +4,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.SelectedArrow = void 0;
|
|
7
|
-
let SelectedArrow = function (SelectedArrow) {
|
|
7
|
+
let SelectedArrow = exports.SelectedArrow = function (SelectedArrow) {
|
|
8
8
|
SelectedArrow["UP"] = "up";
|
|
9
9
|
SelectedArrow["DOWN"] = "down";
|
|
10
10
|
return SelectedArrow;
|
|
11
11
|
}({});
|
|
12
|
-
exports.SelectedArrow = SelectedArrow;
|
|
13
12
|
//# sourceMappingURL=types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":["SelectedArrow","exports"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/types.tsx"],"sourcesContent":["export enum SelectedArrow {\n UP = 'up',\n DOWN = 'down',\n}\n\nexport interface SortSwitchProps {\n onClickButtonUp: () => void;\n onClickButtonDown: () => void;\n selected: SelectedArrow;\n disabled?: boolean;\n}\n"],"mappings":";;;;;;IAAYA,aAAa,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA
|
|
1
|
+
{"version":3,"file":"types.js","names":["SelectedArrow","exports"],"sources":["../../../../../src/SentimentWidget/components/SortSwitch/types.tsx"],"sourcesContent":["export enum SelectedArrow {\n UP = 'up',\n DOWN = 'down',\n}\n\nexport interface SortSwitchProps {\n onClickButtonUp: () => void;\n onClickButtonDown: () => void;\n selected: SelectedArrow;\n disabled?: boolean;\n}\n"],"mappings":";;;;;;IAAYA,aAAa,GAAAC,OAAA,CAAAD,aAAA,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA"}
|
|
@@ -4,10 +4,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.SentimentSort = void 0;
|
|
7
|
-
let SentimentSort = function (SentimentSort) {
|
|
7
|
+
let SentimentSort = exports.SentimentSort = function (SentimentSort) {
|
|
8
8
|
SentimentSort["Bearish"] = "BEARISH";
|
|
9
9
|
SentimentSort["Bullish"] = "BULLISH";
|
|
10
10
|
return SentimentSort;
|
|
11
11
|
}({});
|
|
12
|
-
exports.SentimentSort = SentimentSort;
|
|
13
12
|
//# sourceMappingURL=types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":["SentimentSort","exports"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n instrument?: string;\n
|
|
1
|
+
{"version":3,"file":"types.js","names":["SentimentSort","exports"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n instrument?: string;\n}\n\nexport interface SentimentWidgetConfig {\n graphqlUrl: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n graphqlUrl: 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":";;;;;;IA0BYA,aAAa,GAAAC,OAAA,CAAAD,aAAA,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA"}
|
|
@@ -7,6 +7,5 @@ exports.getInstrumentSentiment = void 0;
|
|
|
7
7
|
var _client = require("@apollo/client");
|
|
8
8
|
var _templateObject;
|
|
9
9
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
10
|
-
const getInstrumentSentiment = (0, _client.gql)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetInstrumentSentiment(\n $
|
|
11
|
-
exports.getInstrumentSentiment = getInstrumentSentiment;
|
|
10
|
+
const getInstrumentSentiment = exports.getInstrumentSentiment = (0, _client.gql)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetInstrumentSentiment(\n $name: String!\n ) {\n sentiment(\n name: $name\n ) {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n"])));
|
|
12
11
|
//# sourceMappingURL=getInstrumentSentiment.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getInstrumentSentiment.js","names":["_client","require","_templateObject","_taggedTemplateLiteral","strings","raw","slice","Object","freeze","defineProperties","value","getInstrumentSentiment","
|
|
1
|
+
{"version":3,"file":"getInstrumentSentiment.js","names":["_client","require","_templateObject","_taggedTemplateLiteral","strings","raw","slice","Object","freeze","defineProperties","value","getInstrumentSentiment","exports","gql"],"sources":["../../../src/gql/getInstrumentSentiment.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getInstrumentSentiment = gql`\n query GetInstrumentSentiment(\n $name: String!\n ) {\n sentiment(\n name: $name\n ) {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n`;\n\nexport { getInstrumentSentiment };\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAAqC,IAAAC,eAAA;AAAA,SAAAC,uBAAAC,OAAA,EAAAC,GAAA,SAAAA,GAAA,IAAAA,GAAA,GAAAD,OAAA,CAAAE,KAAA,cAAAC,MAAA,CAAAC,MAAA,CAAAD,MAAA,CAAAE,gBAAA,CAAAL,OAAA,IAAAC,GAAA,IAAAK,KAAA,EAAAH,MAAA,CAAAC,MAAA,CAAAH,GAAA;AAErC,MAAMM,sBAAsB,GAAAC,OAAA,CAAAD,sBAAA,OAAGE,WAAG,EAAAX,eAAA,KAAAA,eAAA,GAAAC,sBAAA,iNAcjC"}
|
|
@@ -7,6 +7,5 @@ exports.getSentimentList = void 0;
|
|
|
7
7
|
var _client = require("@apollo/client");
|
|
8
8
|
var _templateObject;
|
|
9
9
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
10
|
-
const getSentimentList = (0, _client.gql)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetSentimentList {\n sentimentList {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n"])));
|
|
11
|
-
exports.getSentimentList = getSentimentList;
|
|
10
|
+
const getSentimentList = exports.getSentimentList = (0, _client.gql)(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetSentimentList {\n sentimentList {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n"])));
|
|
12
11
|
//# sourceMappingURL=getSentimentList.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getSentimentList.js","names":["_client","require","_templateObject","_taggedTemplateLiteral","strings","raw","slice","Object","freeze","defineProperties","value","getSentimentList","
|
|
1
|
+
{"version":3,"file":"getSentimentList.js","names":["_client","require","_templateObject","_taggedTemplateLiteral","strings","raw","slice","Object","freeze","defineProperties","value","getSentimentList","exports","gql"],"sources":["../../../src/gql/getSentimentList.ts"],"sourcesContent":["import { gql } from '@apollo/client';\n\nconst getSentimentList = gql`\n query GetSentimentList {\n sentimentList {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n`;\n\nexport { getSentimentList };\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAAqC,IAAAC,eAAA;AAAA,SAAAC,uBAAAC,OAAA,EAAAC,GAAA,SAAAA,GAAA,IAAAA,GAAA,GAAAD,OAAA,CAAAE,KAAA,cAAAC,MAAA,CAAAC,MAAA,CAAAD,MAAA,CAAAE,gBAAA,CAAAL,OAAA,IAAAC,GAAA,IAAAK,KAAA,EAAAH,MAAA,CAAAC,MAAA,CAAAH,GAAA;AAErC,MAAMM,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,OAAGE,WAAG,EAAAX,eAAA,KAAAA,eAAA,GAAAC,sBAAA,0JAU3B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Widget.js","names":["React","Sentiment","SentimentHeight","Spinner","Error","useQuery","getInstrumentSentiment","Widget","_ref","instrument","loading","data","error","variables","
|
|
1
|
+
{"version":3,"file":"Widget.js","names":["React","Sentiment","SentimentHeight","Spinner","Error","useQuery","getInstrumentSentiment","Widget","_ref","instrument","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';\n\nconst Widget = ({ instrument }: { instrument: string }) => {\n const { loading, data, error } = useQuery(getInstrumentSentiment, {\n variables: {\n name: instrument,\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;AAEtE,MAAMC,MAAM,GAAGC,IAAA,IAA4C;EAAA,IAA3C;IAAEC;EAAmC,CAAC,GAAAD,IAAA;EACpD,MAAM;IAAEE,OAAO;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGP,QAAQ,CAACC,sBAAsB,EAAE;IAChEO,SAAS,EAAE;MACTC,IAAI,EAAEL;IACR;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,OACEnB,KAAA,CAAAoB,aAAA;IAAK,eAAY,kBAAkB;IAACC,SAAS,EAAC;EAA0F,GACrI,CAACX,OAAO,GAELV,KAAA,CAAAoB,aAAA,CAAApB,KAAA,CAAAsB,QAAA,QACEtB,KAAA,CAAAoB,aAAA;IAAGC,SAAS,EAAC;EAA2B,GAAEZ,UAAc,CAAC,EACxD,CAACO,OAAO,IAAIhB,KAAA,CAAAoB,aAAA,CAACnB,SAAS;IAACsB,MAAM,EAAErB,eAAe,CAACsB,EAAG;IAACT,SAAS,EAAEA;EAAU,CAAE,CAAC,EAC3EC,OAAO,IAAIhB,KAAA,CAAAoB,aAAA,CAAChB,KAAK,MAAE,CACpB,CAAC,GACDJ,KAAA,CAAAoB,aAAA,CAACjB,OAAO,MAAE,CACb,CAAC;AAEV,CAAC;AAED,SAASI,MAAM"}
|
|
@@ -21,8 +21,7 @@ const SortSwitch = _ref => {
|
|
|
21
21
|
type: "button",
|
|
22
22
|
onClick: onClickButtonUp,
|
|
23
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
|
-
'
|
|
25
|
-
'border-navyBlue': !disabled
|
|
24
|
+
'bg-navyBlue': selected === SelectedArrow.UP && !disabled
|
|
26
25
|
})
|
|
27
26
|
}, React.createElement(LongArrowUp, {
|
|
28
27
|
className: classnames('transition-transform', {
|
|
@@ -35,7 +34,9 @@ const SortSwitch = _ref => {
|
|
|
35
34
|
disabled: disabled || selected === SelectedArrow.DOWN,
|
|
36
35
|
type: "button",
|
|
37
36
|
onClick: onClickButtonDown,
|
|
38
|
-
className:
|
|
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
|
|
39
|
+
})
|
|
39
40
|
}, React.createElement(LongArrowDown, {
|
|
40
41
|
className: classnames('transition-transform', {
|
|
41
42
|
'stroke-darkGrey': disabled,
|
|
@@ -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 '
|
|
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,0DAA0D,EAC1D;MACE,iBAAiB,EAAES,QAAQ;MAC3B,iBAAiB,EAAE,CAACA;IACtB,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,mHAAmH,EACnH;MACE,aAAa,EAAEQ,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH;IACnD,CACF;EAAE,GAEFV,KAAA,CAAAW,aAAA,CAACT,WAAW;IACVU,SAAS,EAAEX,UAAU,CACnB,sBAAsB,EACtB;MACE,iBAAiB,EAAES,QAAQ;MAC3B,iBAAiB,EAAED,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH,QAAQ;MAC7D,cAAc,EAAED,QAAQ,KAAKL,aAAa,CAACS,EAAE,IAAI,CAACH;IACpD,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,iGAAiG,EACjG;MACE,aAAa,EAAEQ,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN;IACrD,CACF;EAAE,GAEFV,KAAA,CAAAW,aAAA,CAACR,aAAa;IACZS,SAAS,EAAEX,UAAU,CACnB,sBAAsB,EACtB;MACE,iBAAiB,EAAES,QAAQ;MAC3B,iBAAiB,EAAED,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN,QAAQ;MAC/D,cAAc,EAAED,QAAQ,KAAKL,aAAa,CAACY,IAAI,IAAI,CAACN;IACtD,CACF;EAAE,CACH,CACK,CACL,CAAC;AAAA,CACP;AAED,SACEL,UAAU"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","names":["SentimentSort"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n instrument?: string;\n
|
|
1
|
+
{"version":3,"file":"types.js","names":["SentimentSort"],"sources":["../../../src/SentimentWidget/types.ts"],"sourcesContent":["export interface SentimentConfig {\n graphqlUrl: string;\n instrument?: string;\n}\n\nexport interface SentimentWidgetConfig {\n graphqlUrl: string;\n instrument: string;\n}\n\nexport interface SentimentToolConfig {\n graphqlUrl: 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":"AA0BA,WAAYA,aAAa,aAAbA,aAAa;EAAbA,aAAa;EAAbA,aAAa;EAAA,OAAbA,aAAa;AAAA"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
var _templateObject;
|
|
2
2
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
3
3
|
import { gql } from '@apollo/client';
|
|
4
|
-
const getInstrumentSentiment = gql(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetInstrumentSentiment(\n $
|
|
4
|
+
const getInstrumentSentiment = gql(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n query GetInstrumentSentiment(\n $name: String!\n ) {\n sentiment(\n name: $name\n ) {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n"])));
|
|
5
5
|
export { getInstrumentSentiment };
|
|
6
6
|
//# sourceMappingURL=getInstrumentSentiment.js.map
|
|
@@ -1 +1 @@
|
|
|
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(\n $
|
|
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(\n $name: String!\n ) {\n sentiment(\n name: $name\n ) {\n name\n sentiment {\n shortPercent\n longPercent\n }\n }\n }\n`;\n\nexport { getInstrumentSentiment };\n"],"mappings":";;AAAA,SAASA,GAAG,QAAQ,gBAAgB;AAEpC,MAAMC,sBAAsB,GAAGD,GAAG,CAAAE,eAAA,KAAAA,eAAA,GAAAC,sBAAA,iNAcjC;AAED,SAASF,sBAAsB"}
|
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.8",
|
|
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.8",
|
|
15
15
|
"classnames": "2.3.2",
|
|
16
16
|
"graphql": "16.7.1"
|
|
17
17
|
},
|
|
18
|
-
"gitHead": "
|
|
18
|
+
"gitHead": "e8490bb06552b5e7f37477c6472255637568a1f4"
|
|
19
19
|
}
|
|
@@ -8,7 +8,6 @@ import { getInstrumentSentiment } from '../gql/getInstrumentSentiment';
|
|
|
8
8
|
const Widget = ({ instrument }: { instrument: string }) => {
|
|
9
9
|
const { loading, data, error } = useQuery(getInstrumentSentiment, {
|
|
10
10
|
variables: {
|
|
11
|
-
division: 'OJ',
|
|
12
11
|
name: instrument,
|
|
13
12
|
},
|
|
14
13
|
});
|
|
@@ -24,8 +24,7 @@ const SortSwitch = ({
|
|
|
24
24
|
className={classnames(
|
|
25
25
|
'flex h-11 w-11 grow-0 items-center justify-center border-r-[1px] border-solid [&:enabled:hover>*]:-translate-y-1',
|
|
26
26
|
{
|
|
27
|
-
'
|
|
28
|
-
'border-navyBlue': !disabled,
|
|
27
|
+
'bg-navyBlue': selected === SelectedArrow.UP && !disabled,
|
|
29
28
|
},
|
|
30
29
|
)}
|
|
31
30
|
>
|
|
@@ -45,7 +44,12 @@ const SortSwitch = ({
|
|
|
45
44
|
disabled={disabled || selected === SelectedArrow.DOWN}
|
|
46
45
|
type="button"
|
|
47
46
|
onClick={onClickButtonDown}
|
|
48
|
-
className=
|
|
47
|
+
className={classnames(
|
|
48
|
+
'flex h-11 w-11 grow-0 items-center justify-center text-center [&:enabled:hover>*]:translate-y-1',
|
|
49
|
+
{
|
|
50
|
+
'bg-navyBlue': selected === SelectedArrow.DOWN && !disabled,
|
|
51
|
+
},
|
|
52
|
+
)}
|
|
49
53
|
>
|
|
50
54
|
<LongArrowDown
|
|
51
55
|
className={classnames(
|
package/test/Widget.test.tsx
CHANGED
|
@@ -12,7 +12,6 @@ const mocks = [
|
|
|
12
12
|
request: {
|
|
13
13
|
query: getInstrumentSentiment,
|
|
14
14
|
variables: {
|
|
15
|
-
division: 'OJ',
|
|
16
15
|
name: 'EUR/USD',
|
|
17
16
|
},
|
|
18
17
|
},
|
|
@@ -36,7 +35,6 @@ const zeroPercentMocks = [
|
|
|
36
35
|
request: {
|
|
37
36
|
query: getInstrumentSentiment,
|
|
38
37
|
variables: {
|
|
39
|
-
division: 'OJ',
|
|
40
38
|
name: 'GBP/USD',
|
|
41
39
|
},
|
|
42
40
|
},
|