@pie-lib/graphing-solution-set 2.16.0-beta.0 → 2.17.0
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 +157 -1
- package/lib/axis/arrow.js +1 -1
- package/lib/axis/arrow.js.map +1 -0
- package/lib/axis/axes.js +4 -4
- package/lib/axis/axes.js.map +1 -0
- package/lib/axis/index.js +1 -1
- package/lib/axis/index.js.map +1 -0
- package/lib/bg.js +1 -1
- package/lib/bg.js.map +1 -0
- package/lib/container/actions.js +1 -1
- package/lib/container/actions.js.map +1 -0
- package/lib/container/index.js +1 -1
- package/lib/container/index.js.map +1 -0
- package/lib/container/marks.js +1 -1
- package/lib/container/marks.js.map +1 -0
- package/lib/container/middleware.js +1 -1
- package/lib/container/middleware.js.map +1 -0
- package/lib/container/reducer.js +1 -1
- package/lib/container/reducer.js.map +1 -0
- package/lib/coordinates-label.js +3 -3
- package/lib/coordinates-label.js.map +1 -0
- package/lib/graph-with-controls.js +4 -4
- package/lib/graph-with-controls.js.map +1 -0
- package/lib/graph.js +1 -1
- package/lib/graph.js.map +1 -0
- package/lib/grid-setup.js +4 -4
- package/lib/grid-setup.js.map +1 -0
- package/lib/grid.js +1 -1
- package/lib/grid.js.map +1 -0
- package/lib/index.js +1 -1
- package/lib/index.js.map +1 -0
- package/lib/labels.js +4 -4
- package/lib/labels.js.map +1 -0
- package/lib/mark-label.js +7 -7
- package/lib/mark-label.js.map +1 -0
- package/lib/shared/index.js +136 -0
- package/lib/toggle-bar.js +10 -10
- package/lib/toggle-bar.js.map +1 -0
- package/lib/tool-menu.js +1 -1
- package/lib/tool-menu.js.map +1 -0
- package/lib/tools/index.js +1 -1
- package/lib/tools/index.js.map +1 -0
- package/lib/tools/line/component.js +1 -1
- package/lib/tools/line/component.js.map +1 -0
- package/lib/tools/line/index.js +1 -1
- package/lib/tools/line/index.js.map +1 -0
- package/lib/tools/polygon/component.js +1 -1
- package/lib/tools/polygon/component.js.map +1 -0
- package/lib/tools/polygon/index.js +1 -1
- package/lib/tools/polygon/index.js.map +1 -0
- package/lib/tools/polygon/line.js +3 -3
- package/lib/tools/polygon/line.js.map +1 -0
- package/lib/tools/polygon/polygon.js +4 -4
- package/lib/tools/polygon/polygon.js.map +1 -0
- package/lib/tools/shared/arrow-head.js +3 -3
- package/lib/tools/shared/arrow-head.js.map +1 -0
- package/lib/tools/shared/line/index.js +7 -7
- package/lib/tools/shared/line/index.js.map +1 -0
- package/lib/tools/shared/line/line-path.js +4 -4
- package/lib/tools/shared/line/line-path.js.map +1 -0
- package/lib/tools/shared/line/with-root-edge.js +1 -1
- package/lib/tools/shared/line/with-root-edge.js.map +1 -0
- package/lib/tools/shared/point/arrow-point.js +1 -1
- package/lib/tools/shared/point/arrow-point.js.map +1 -0
- package/lib/tools/shared/point/arrow.js +1 -1
- package/lib/tools/shared/point/arrow.js.map +1 -0
- package/lib/tools/shared/point/base-point.js +3 -3
- package/lib/tools/shared/point/base-point.js.map +1 -0
- package/lib/tools/shared/point/index.js +3 -3
- package/lib/tools/shared/point/index.js.map +1 -0
- package/lib/tools/shared/styles.js +6 -6
- package/lib/tools/shared/styles.js.map +1 -0
- package/lib/tools/shared/types.js +1 -1
- package/lib/tools/shared/types.js.map +1 -0
- package/lib/undo-redo.js +3 -3
- package/lib/undo-redo.js.map +1 -0
- package/lib/use-debounce.js +1 -1
- package/lib/use-debounce.js.map +1 -0
- package/lib/utils.js +1 -1
- package/lib/utils.js.map +1 -0
- package/package.json +14 -9
- package/src/axis/axes.jsx +1 -1
- package/src/coordinates-label.jsx +1 -1
- package/src/graph-with-controls.jsx +1 -1
- package/src/grid-setup.jsx +5 -8
- package/src/labels.jsx +1 -1
- package/src/mark-label.jsx +1 -1
- package/src/toggle-bar.jsx +1 -1
- package/src/tools/polygon/line.jsx +1 -1
- package/src/tools/polygon/polygon.jsx +1 -1
- package/src/tools/shared/arrow-head.jsx +1 -1
- package/src/tools/shared/line/index.jsx +1 -1
- package/src/tools/shared/line/line-path.jsx +1 -1
- package/src/tools/shared/point/base-point.jsx +1 -1
- package/src/tools/shared/point/index.jsx +1 -1
- package/src/tools/shared/styles.js +1 -1
- package/src/undo-redo.jsx +1 -1
- package/lib/__tests__/graph-with-controls.test.js +0 -191
- package/lib/__tests__/graph.test.js +0 -290
- package/lib/__tests__/grid.test.js +0 -40
- package/lib/__tests__/labels.test.js +0 -59
- package/lib/__tests__/mark-label.test.js +0 -154
- package/lib/__tests__/toggle-bar.test.js +0 -54
- package/lib/__tests__/tool-menu.test.js +0 -43
- package/lib/__tests__/undo-redo.test.js +0 -42
- package/lib/__tests__/use-debounce.test.js +0 -28
- package/lib/__tests__/utils.js +0 -72
- package/lib/__tests__/utils.test.js +0 -133
- package/lib/axis/__tests__/arrow.test.js +0 -68
- package/lib/axis/__tests__/axes.test.js +0 -214
- package/lib/tools/line/__tests__/component.test.js +0 -56
- package/lib/tools/polygon/__tests__/component.test.js +0 -245
- package/lib/tools/polygon/__tests__/index.test.js +0 -95
- package/lib/tools/polygon/__tests__/line.test.js +0 -43
- package/lib/tools/polygon/__tests__/polygon.test.js +0 -73
- package/lib/tools/shared/__tests__/arrow-head.test.js +0 -62
- package/lib/tools/shared/line/__tests__/index.test.js +0 -291
- package/lib/tools/shared/line/__tests__/line-path.test.js +0 -78
- package/lib/tools/shared/line/__tests__/with-root-edge.test.js +0 -122
- package/lib/tools/shared/point/__tests__/arrow-point.test.js +0 -137
- package/lib/tools/shared/point/__tests__/base-point.test.js +0 -134
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/labels.jsx"],"names":["rotations","left","top","bottom","right","getTransform","side","width","height","t","x","y","rotate","getY","RawLabel","props","disabledLabel","placeholder","text","graphProps","classes","onChange","mathMlOptions","size","domain","range","totalHeight","padding","totalWidth","transform","finalHeight","activePlugins","bottomLabel","disabledAxisLabel","axisLabel","position","noPadding","noBorder","React","Component","PropTypes","string","object","bool","types","GraphPropsType","isRequired","func","Label","theme","label","fill","color","defaults","SECONDARY","fontSize","typography","textAlign","pointerEvents","marginTop","LabelType","Labels","newValue","value","labels","disabledLabels","placeholders","onChangeLabel","className","shape"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport { types } from '@pie-lib/plot';\nimport { color, Readable } from '../../render-ui/src/index';\nimport EditableHtml from '@pie-lib/editable-html';\nimport cn from 'classnames';\n\nconst rotations = {\n left: -90,\n top: 0,\n bottom: 0,\n right: 90,\n};\n\nexport const getTransform = (side, width, height) => {\n const t = (x, y, rotate) => `translate(${x}, ${y}), rotate(${rotate})`;\n\n if (side === 'left') {\n return t(-20, height / 2, rotations[side]);\n }\n if (side === 'right') {\n return t(width + 30, height / 2, rotations[side]);\n }\n if (side === 'top') {\n return t(width / 2, -20, rotations[side]);\n }\n if (side === 'bottom') {\n return t(width / 2, height + 30, rotations[side]);\n }\n};\n\nconst getY = (side, height) => {\n switch (side) {\n case 'left':\n return -height;\n case 'top':\n return -height;\n case 'right':\n return -height - 10;\n default:\n return -height + 10;\n }\n};\n\nclass RawLabel extends React.Component {\n static propTypes = {\n text: PropTypes.string,\n side: PropTypes.string,\n classes: PropTypes.object,\n disabledLabel: PropTypes.bool,\n placeholder: PropTypes.string,\n graphProps: types.GraphPropsType.isRequired,\n onChange: PropTypes.func,\n };\n\n static defaultProps = {\n onChange: () => {},\n };\n\n render() {\n const { disabledLabel, placeholder, text, side, graphProps, classes, onChange, mathMlOptions = {} } = this.props;\n const { size, domain, range } = graphProps;\n const totalHeight = (size.height || 500) + (range.padding || 0) * 2;\n const totalWidth = (size.width || 500) + (domain.padding || 0) * 2;\n\n const transform = getTransform(side, totalWidth, totalHeight);\n const width = side === 'left' || side === 'right' ? totalHeight : totalWidth;\n const height = 36;\n const y = getY(side, height);\n const finalHeight = side === 'bottom' ? height + 22 : height + 18;\n\n const activePlugins = [\n 'bold',\n 'italic',\n 'underline',\n 'strikethrough',\n 'math',\n // 'languageCharacters'\n ];\n\n return (\n <foreignObject\n x={-(width / 2)}\n y={y}\n width={width}\n height={finalHeight}\n transform={transform}\n textAnchor=\"middle\"\n >\n <Readable false>\n <EditableHtml\n className={cn(\n {\n [classes.bottomLabel]: side === 'bottom',\n [classes.disabledAxisLabel]: disabledLabel,\n },\n classes.axisLabel,\n )}\n markup={text || ''}\n onChange={onChange}\n placeholder={!disabledLabel && placeholder}\n toolbarOpts={{\n position: side === 'bottom' ? 'top' : 'bottom',\n noPadding: true,\n noBorder: true,\n }}\n activePlugins={activePlugins}\n mathMlOptions={mathMlOptions}\n />\n </Readable>\n </foreignObject>\n );\n }\n}\n\nconst Label = withStyles((theme) => ({\n label: {\n fill: color.defaults.SECONDARY,\n },\n axisLabel: {\n fontSize: theme.typography.fontSize - 2,\n textAlign: 'center',\n padding: '0 4px',\n },\n disabledAxisLabel: {\n pointerEvents: 'none',\n },\n bottomLabel: {\n marginTop: '44px',\n },\n}))(RawLabel);\n\nexport const LabelType = {\n left: PropTypes.string,\n top: PropTypes.string,\n bottom: PropTypes.string,\n right: PropTypes.string,\n};\n\nexport class Labels extends React.Component {\n static propTypes = {\n classes: PropTypes.object,\n className: PropTypes.string,\n disabledLabels: PropTypes.bool,\n placeholders: PropTypes.object,\n value: PropTypes.shape(LabelType),\n graphProps: PropTypes.object,\n onChange: PropTypes.object,\n };\n\n static defaultProps = {};\n\n onChangeLabel = (newValue, side) => {\n const { value, onChange } = this.props;\n const labels = {\n ...value,\n [side]: newValue,\n };\n\n onChange(labels);\n };\n\n render() {\n const { disabledLabels, placeholders = {}, value = {}, graphProps, mathMlOptions = {} } = this.props;\n\n return (\n <React.Fragment>\n <Label\n key=\"left\"\n side=\"left\"\n text={value.left}\n disabledLabel={disabledLabels}\n placeholder={placeholders.left}\n graphProps={graphProps}\n onChange={(value) => this.onChangeLabel(value, 'left')}\n mathMlOptions={mathMlOptions}\n />\n <Label\n key=\"top\"\n side=\"top\"\n text={value.top}\n disabledLabel={disabledLabels}\n placeholder={placeholders.top}\n graphProps={graphProps}\n onChange={(value) => this.onChangeLabel(value, 'top')}\n mathMlOptions={mathMlOptions}\n />\n <Label\n key=\"bottom\"\n side=\"bottom\"\n text={value.bottom}\n disabledLabel={disabledLabels}\n placeholder={placeholders.bottom}\n graphProps={graphProps}\n onChange={(value) => this.onChangeLabel(value, 'bottom')}\n mathMlOptions={mathMlOptions}\n />\n <Label\n key=\"right\"\n side=\"right\"\n text={value.right}\n disabledLabel={disabledLabels}\n placeholder={placeholders.right}\n graphProps={graphProps}\n onChange={(value) => this.onChangeLabel(value, 'right')}\n mathMlOptions={mathMlOptions}\n />\n </React.Fragment>\n );\n }\n}\n\nexport default Labels;\n"],"file":"labels.js"}
|
package/lib/mark-label.js
CHANGED
|
@@ -27,7 +27,7 @@ var _useDebounce = require("./use-debounce");
|
|
|
27
27
|
|
|
28
28
|
var _plot = require("@pie-lib/plot");
|
|
29
29
|
|
|
30
|
-
var
|
|
30
|
+
var _index = require("./shared/index");
|
|
31
31
|
|
|
32
32
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
33
33
|
|
|
@@ -44,18 +44,18 @@ var styles = function styles(theme) {
|
|
|
44
44
|
padding: theme.spacing.unit * 0.5,
|
|
45
45
|
fontFamily: theme.typography.fontFamily,
|
|
46
46
|
fontSize: theme.typography.fontSize,
|
|
47
|
-
border: "solid 1px ".concat(
|
|
47
|
+
border: "solid 1px ".concat(_index.color.defaults.SECONDARY),
|
|
48
48
|
borderRadius: '3px',
|
|
49
|
-
color:
|
|
49
|
+
color: _index.color.defaults.PRIMARY_DARK
|
|
50
50
|
},
|
|
51
51
|
disabled: {
|
|
52
|
-
border: "solid 1px ".concat(
|
|
52
|
+
border: "solid 1px ".concat(_index.color.defaults.PRIMARY_DARK),
|
|
53
53
|
background: theme.palette.background.paper
|
|
54
54
|
},
|
|
55
55
|
disabledMark: {
|
|
56
|
-
border: "solid 1px ".concat(
|
|
56
|
+
border: "solid 1px ".concat(_index.color.disabled()),
|
|
57
57
|
background: theme.palette.background.paper,
|
|
58
|
-
color:
|
|
58
|
+
color: _index.color.disabled()
|
|
59
59
|
}
|
|
60
60
|
};
|
|
61
61
|
};
|
|
@@ -205,4 +205,4 @@ var _default = (0, _styles.withStyles)(styles, {
|
|
|
205
205
|
})(MarkLabel);
|
|
206
206
|
|
|
207
207
|
exports["default"] = _default;
|
|
208
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/mark-label.jsx"],"names":["styles","theme","input","padding","spacing","unit","fontFamily","typography","fontSize","border","color","defaults","SECONDARY","borderRadius","PRIMARY_DARK","disabled","background","palette","paper","disabledMark","position","graphProps","mark","rect","width","height","scale","domain","range","shift","rightEdge","x","bottomEdge","y","h","max","v","min","coordinates","left","top","MarkLabel","props","setInput","_ref","node","classes","externalInputRef","inputRef","label","setLabel","onChange","e","target","value","debouncedLabel","getBoundingClientRect","pos","leftTop","style","pointerEvents","disabledInput","r","propTypes","PropTypes","bool","func","types","GraphPropsType","object","withTheme"],"mappings":";;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAEA,IAAMA,MAAM,GAAG,SAATA,MAAS,CAACC,KAAD;AAAA,SAAY;AACzBC,IAAAA,KAAK,EAAE;AACL,eAAO,OADF;AAELC,MAAAA,OAAO,EAAEF,KAAK,CAACG,OAAN,CAAcC,IAAd,GAAqB,GAFzB;AAGLC,MAAAA,UAAU,EAAEL,KAAK,CAACM,UAAN,CAAiBD,UAHxB;AAILE,MAAAA,QAAQ,EAAEP,KAAK,CAACM,UAAN,CAAiBC,QAJtB;AAKLC,MAAAA,MAAM,sBAAeC,gBAAMC,QAAN,CAAeC,SAA9B,CALD;AAMLC,MAAAA,YAAY,EAAE,KANT;AAOLH,MAAAA,KAAK,EAAEA,gBAAMC,QAAN,CAAeG;AAPjB,KADkB;AAUzBC,IAAAA,QAAQ,EAAE;AACRN,MAAAA,MAAM,sBAAeC,gBAAMC,QAAN,CAAeG,YAA9B,CADE;AAERE,MAAAA,UAAU,EAAEf,KAAK,CAACgB,OAAN,CAAcD,UAAd,CAAyBE;AAF7B,KAVe;AAczBC,IAAAA,YAAY,EAAE;AACZV,MAAAA,MAAM,sBAAeC,gBAAMK,QAAN,EAAf,CADM;AAEZC,MAAAA,UAAU,EAAEf,KAAK,CAACgB,OAAN,CAAcD,UAAd,CAAyBE,KAFzB;AAGZR,MAAAA,KAAK,EAAEA,gBAAMK,QAAN;AAHK;AAdW,GAAZ;AAAA,CAAf;;AAqBO,IAAMK,QAAQ,GAAG,SAAXA,QAAW,CAACC,UAAD,EAAaC,IAAb,EAAmBC,IAAnB,EAA4B;AAClDA,EAAAA,IAAI,GAAGA,IAAI,IAAI;AAAEC,IAAAA,KAAK,EAAE,CAAT;AAAYC,IAAAA,MAAM,EAAE;AAApB,GAAf;AACA,MAAQC,KAAR,GAAiCL,UAAjC,CAAQK,KAAR;AAAA,MAAeC,MAAf,GAAiCN,UAAjC,CAAeM,MAAf;AAAA,MAAuBC,KAAvB,GAAiCP,UAAjC,CAAuBO,KAAvB;AACA,MAAMC,KAAK,GAAG,EAAd;AAEA,MAAMC,SAAS,GAAGJ,KAAK,CAACK,CAAN,CAAQT,IAAI,CAACS,CAAb,IAAkBR,IAAI,CAACC,KAAvB,GAA+BK,KAAjD;AACA,MAAMG,UAAU,GAAGN,KAAK,CAACO,CAAN,CAAQX,IAAI,CAACW,CAAb,IAAkBV,IAAI,CAACE,MAAvB,GAAgCI,KAAnD;AAEA,MAAMK,CAAC,GAAGJ,SAAS,IAAIJ,KAAK,CAACK,CAAN,CAAQJ,MAAM,CAACQ,GAAf,CAAb,GAAmC,MAAnC,GAA4C,OAAtD;AACA,MAAMC,CAAC,GAAGJ,UAAU,IAAIN,KAAK,CAACO,CAAN,CAAQL,KAAK,CAACS,GAAd,CAAd,GAAmC,KAAnC,GAA2C,QAArD;AAEA,mBAAUD,CAAV,cAAeF,CAAf;AACD,CAZM;;;;AAcA,IAAMI,WAAW,GAAG,SAAdA,WAAc,CAACjB,UAAD,EAAaC,IAAb,EAAmBC,IAAnB,EAAyBH,QAAzB,EAAsC;AAC/D,MAAQM,KAAR,GAAkBL,UAAlB,CAAQK,KAAR;AACA,MAAMG,KAAK,GAAG,EAAd;AACAN,EAAAA,IAAI,GAAGA,IAAI,IAAI;AAAEC,IAAAA,KAAK,EAAE,CAAT;AAAYC,IAAAA,MAAM,EAAE;AAApB,GAAf;;AAEA,UAAQL,QAAR;AACE,SAAK,cAAL;AAAqB;AACnB,eAAO;AAAEmB,UAAAA,IAAI,EAAEb,KAAK,CAACK,CAAN,CAAQT,IAAI,CAACS,CAAb,IAAkBF,KAA1B;AAAiCW,UAAAA,GAAG,EAAEd,KAAK,CAACO,CAAN,CAAQX,IAAI,CAACW,CAAb,IAAkBJ;AAAxD,SAAP;AACD;;AACD,SAAK,aAAL;AAAoB;AAClB,eAAO;AAAEU,UAAAA,IAAI,EAAEb,KAAK,CAACK,CAAN,CAAQT,IAAI,CAACS,CAAb,IAAkBF,KAAlB,GAA0BN,IAAI,CAACC,KAAvC;AAA8CgB,UAAAA,GAAG,EAAEd,KAAK,CAACO,CAAN,CAAQX,IAAI,CAACW,CAAb,IAAkBJ;AAArE,SAAP;AACD;;AACD,SAAK,UAAL;AAAiB;AACf,eAAO;AACLU,UAAAA,IAAI,EAAEb,KAAK,CAACK,CAAN,CAAQT,IAAI,CAACS,CAAb,IAAkBF,KAAlB,GAA0BN,IAAI,CAACC,KADhC;AAELgB,UAAAA,GAAG,EAAEd,KAAK,CAACO,CAAN,CAAQX,IAAI,CAACW,CAAb,IAAkBJ,KAAlB,GAA0BN,IAAI,CAACE;AAF/B,SAAP;AAID;;AACD,SAAK,WAAL;AAAkB;AAChB,eAAO;AACLc,UAAAA,IAAI,EAAEb,KAAK,CAACK,CAAN,CAAQT,IAAI,CAACS,CAAb,IAAkBF,KADnB;AAELW,UAAAA,GAAG,EAAEd,KAAK,CAACO,CAAN,CAAQX,IAAI,CAACW,CAAb,IAAkBJ,KAAlB,GAA0BN,IAAI,CAACE;AAF/B,SAAP;AAID;AAlBH;AAoBD,CAzBM;;;;AA2BA,IAAMgB,SAAS,GAAG,SAAZA,SAAY,CAACC,KAAD,EAAW;AAAA;;AAClC,kBAA0B,qBAAS,IAAT,CAA1B;AAAA;AAAA,MAAOxC,KAAP;AAAA,MAAcyC,QAAd;;AACA,MAAMC,IAAI,GAAG,wBAAY,UAACC,IAAD;AAAA,WAAUF,QAAQ,CAACE,IAAD,CAAlB;AAAA,GAAZ,CAAb;;AAEA,MAAQvB,IAAR,GAAmFoB,KAAnF,CAAQpB,IAAR;AAAA,MAAcD,UAAd,GAAmFqB,KAAnF,CAAcrB,UAAd;AAAA,MAA0ByB,OAA1B,GAAmFJ,KAAnF,CAA0BI,OAA1B;AAAA,MAAmC/B,QAAnC,GAAmF2B,KAAnF,CAAmC3B,QAAnC;AAAA,MAAuDgC,gBAAvD,GAAmFL,KAAnF,CAA6CM,QAA7C;AAAA,MAAyE/C,KAAzE,GAAmFyC,KAAnF,CAAyEzC,KAAzE;;AAEA,mBAA0B,qBAASqB,IAAI,CAAC2B,KAAd,CAA1B;AAAA;AAAA,MAAOA,KAAP;AAAA,MAAcC,QAAd;;AAEA,MAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACC,CAAD;AAAA,WAAOF,QAAQ,CAACE,CAAC,CAACC,MAAF,CAASC,KAAV,CAAf;AAAA,GAAjB;;AAEA,MAAMC,cAAc,GAAG,8BAAYN,KAAZ,EAAmB,GAAnB,CAAvB,CAVkC,CAYlC;;AACA,wBAAU,YAAM;AACdC,IAAAA,QAAQ,CAAC5B,IAAI,CAAC2B,KAAN,CAAR;AACD,GAFD,EAEG,CAAC3B,IAAI,CAAC2B,KAAN,CAFH,EAbkC,CAiBlC;;AACA,wBAAU,YAAM;AACd,QAAI,OAAOM,cAAP,KAA0B,QAA1B,IAAsCA,cAAc,KAAKjC,IAAI,CAAC2B,KAAlE,EAAyE;AACvEP,MAAAA,KAAK,CAACS,QAAN,CAAeI,cAAf;AACD;AACF,GAJD,EAIG,CAACA,cAAD,CAJH;AAMA,MAAMhC,IAAI,GAAGrB,KAAK,GAAGA,KAAK,CAACsD,qBAAN,EAAH,GAAmC;AAAEhC,IAAAA,KAAK,EAAE,CAAT;AAAYC,IAAAA,MAAM,EAAE;AAApB,GAArD;AACA,MAAMgC,GAAG,GAAGrC,QAAQ,CAACC,UAAD,EAAaC,IAAb,EAAmBC,IAAnB,CAApB;AACA,MAAMmC,OAAO,GAAGpB,WAAW,CAACjB,UAAD,EAAaC,IAAb,EAAmBC,IAAnB,EAAyBkC,GAAzB,CAA3B;;AAEA,MAAME,KAAK;AACTvC,IAAAA,QAAQ,EAAE,OADD;AAETwC,IAAAA,aAAa,EAAE;AAFN,KAGNF,OAHM,CAAX;;AAMA,MAAMG,aAAa,GAAG9C,QAAQ,IAAIO,IAAI,CAACP,QAAvC;AAEA,sBACE,gCAAC,8BAAD;AACE,IAAA,QAAQ,EAAE,kBAAC+C,CAAD,EAAO;AACflB,MAAAA,IAAI,CAACkB,CAAD,CAAJ;;AACAf,MAAAA,gBAAgB,CAACe,CAAD,CAAhB;AACD,KAJH;AAKE,IAAA,QAAQ,EAAED,aALZ;AAME,IAAA,cAAc,EAAE,4BAAGf,OAAO,CAAC5C,KAAX,mDACb4C,OAAO,CAAC/B,QADK,EACMA,QADN,yCAEb+B,OAAO,CAAC3B,YAFK,EAEUG,IAAI,CAACP,QAFf,QANlB;AAUE,IAAA,KAAK,EAAEkC,KAVT;AAWE,IAAA,KAAK,EAAEU,KAXT;AAYE,IAAA,QAAQ,EAAER;AAZZ,IADF;AAgBD,CApDM;;;AAsDPV,SAAS,CAACsB,SAAV,GAAsB;AACpBhD,EAAAA,QAAQ,EAAEiD,sBAAUC,IADA;AAEpBd,EAAAA,QAAQ,EAAEa,sBAAUE,IAFA;AAGpB7C,EAAAA,UAAU,EAAE8C,YAAMC,cAHE;AAIpBtB,EAAAA,OAAO,EAAEkB,sBAAUK,MAJC;AAKpBrB,EAAAA,QAAQ,EAAEgB,sBAAUE,IALA;AAMpB5C,EAAAA,IAAI,EAAE0C,sBAAUK,MANI;AAOpBpE,EAAAA,KAAK,EAAE+D,sBAAUK;AAPG,CAAtB;;eAUe,wBAAWrE,MAAX,EAAmB;AAAEsE,EAAAA,SAAS,EAAE;AAAb,CAAnB,EAAwC7B,SAAxC,C","sourcesContent":["import React, { useState, useCallback, useEffect } from 'react';\nimport cn from 'classnames';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport AutosizeInput from 'react-input-autosize';\nimport { useDebounce } from './use-debounce';\nimport { types } from '@pie-lib/plot';\nimport { color } from '@pie-lib/render-ui';\n\nconst styles = (theme) => ({\n  input: {\n    float: 'right',\n    padding: theme.spacing.unit * 0.5,\n    fontFamily: theme.typography.fontFamily,\n    fontSize: theme.typography.fontSize,\n    border: `solid 1px ${color.defaults.SECONDARY}`,\n    borderRadius: '3px',\n    color: color.defaults.PRIMARY_DARK,\n  },\n  disabled: {\n    border: `solid 1px ${color.defaults.PRIMARY_DARK}`,\n    background: theme.palette.background.paper,\n  },\n  disabledMark: {\n    border: `solid 1px ${color.disabled()}`,\n    background: theme.palette.background.paper,\n    color: color.disabled(),\n  },\n});\n\nexport const position = (graphProps, mark, rect) => {\n  rect = rect || { width: 0, height: 0 };\n  const { scale, domain, range } = graphProps;\n  const shift = 10;\n\n  const rightEdge = scale.x(mark.x) + rect.width + shift;\n  const bottomEdge = scale.y(mark.y) + rect.height + shift;\n\n  const h = rightEdge >= scale.x(domain.max) ? 'left' : 'right';\n  const v = bottomEdge >= scale.y(range.min) ? 'top' : 'bottom';\n\n  return `${v}-${h}`;\n};\n\nexport const coordinates = (graphProps, mark, rect, position) => {\n  const { scale } = graphProps;\n  const shift = 10;\n  rect = rect || { width: 0, height: 0 };\n\n  switch (position) {\n    case 'bottom-right': {\n      return { left: scale.x(mark.x) + shift, top: scale.y(mark.y) + shift };\n    }\n    case 'bottom-left': {\n      return { left: scale.x(mark.x) - shift - rect.width, top: scale.y(mark.y) + shift };\n    }\n    case 'top-left': {\n      return {\n        left: scale.x(mark.x) - shift - rect.width,\n        top: scale.y(mark.y) - shift - rect.height,\n      };\n    }\n    case 'top-right': {\n      return {\n        left: scale.x(mark.x) + shift,\n        top: scale.y(mark.y) - shift - rect.height,\n      };\n    }\n  }\n};\n\nexport const MarkLabel = (props) => {\n  const [input, setInput] = useState(null);\n  const _ref = useCallback((node) => setInput(node));\n\n  const { mark, graphProps, classes, disabled, inputRef: externalInputRef, theme } = props;\n\n  const [label, setLabel] = useState(mark.label);\n\n  const onChange = (e) => setLabel(e.target.value);\n\n  const debouncedLabel = useDebounce(label, 200);\n\n  // useState only sets the value once, to synch props to state need useEffect\n  useEffect(() => {\n    setLabel(mark.label);\n  }, [mark.label]);\n\n  // pick up the change to debouncedLabel and save it\n  useEffect(() => {\n    if (typeof debouncedLabel === 'string' && debouncedLabel !== mark.label) {\n      props.onChange(debouncedLabel);\n    }\n  }, [debouncedLabel]);\n\n  const rect = input ? input.getBoundingClientRect() : { width: 0, height: 0 };\n  const pos = position(graphProps, mark, rect);\n  const leftTop = coordinates(graphProps, mark, rect, pos);\n\n  const style = {\n    position: 'fixed',\n    pointerEvents: 'auto',\n    ...leftTop,\n  };\n\n  const disabledInput = disabled || mark.disabled;\n\n  return (\n    <AutosizeInput\n      inputRef={(r) => {\n        _ref(r);\n        externalInputRef(r);\n      }}\n      disabled={disabledInput}\n      inputClassName={cn(classes.input, {\n        [classes.disabled]: disabled,\n        [classes.disabledMark]: mark.disabled,\n      })}\n      value={label}\n      style={style}\n      onChange={onChange}\n    />\n  );\n};\n\nMarkLabel.propTypes = {\n  disabled: PropTypes.bool,\n  onChange: PropTypes.func,\n  graphProps: types.GraphPropsType,\n  classes: PropTypes.object,\n  inputRef: PropTypes.func,\n  mark: PropTypes.object,\n  theme: PropTypes.object,\n};\n\nexport default withStyles(styles, { withTheme: true })(MarkLabel);\n"]}
|
|
208
|
+
//# sourceMappingURL=mark-label.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/mark-label.jsx"],"names":["styles","theme","input","padding","spacing","unit","fontFamily","typography","fontSize","border","color","defaults","SECONDARY","borderRadius","PRIMARY_DARK","disabled","background","palette","paper","disabledMark","position","graphProps","mark","rect","width","height","scale","domain","range","shift","rightEdge","x","bottomEdge","y","h","max","v","min","coordinates","left","top","MarkLabel","props","setInput","_ref","node","classes","externalInputRef","inputRef","label","setLabel","onChange","e","target","value","debouncedLabel","getBoundingClientRect","pos","leftTop","style","pointerEvents","disabledInput","r","propTypes","PropTypes","bool","func","types","GraphPropsType","object","withTheme"],"mappings":"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","sourcesContent":["import React, { useState, useCallback, useEffect } from 'react';\nimport cn from 'classnames';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport AutosizeInput from 'react-input-autosize';\nimport { useDebounce } from './use-debounce';\nimport { types } from '@pie-lib/plot';\nimport { color } from '../../render-ui/src/index';\n\nconst styles = (theme) => ({\n input: {\n float: 'right',\n padding: theme.spacing.unit * 0.5,\n fontFamily: theme.typography.fontFamily,\n fontSize: theme.typography.fontSize,\n border: `solid 1px ${color.defaults.SECONDARY}`,\n borderRadius: '3px',\n color: color.defaults.PRIMARY_DARK,\n },\n disabled: {\n border: `solid 1px ${color.defaults.PRIMARY_DARK}`,\n background: theme.palette.background.paper,\n },\n disabledMark: {\n border: `solid 1px ${color.disabled()}`,\n background: theme.palette.background.paper,\n color: color.disabled(),\n },\n});\n\nexport const position = (graphProps, mark, rect) => {\n rect = rect || { width: 0, height: 0 };\n const { scale, domain, range } = graphProps;\n const shift = 10;\n\n const rightEdge = scale.x(mark.x) + rect.width + shift;\n const bottomEdge = scale.y(mark.y) + rect.height + shift;\n\n const h = rightEdge >= scale.x(domain.max) ? 'left' : 'right';\n const v = bottomEdge >= scale.y(range.min) ? 'top' : 'bottom';\n\n return `${v}-${h}`;\n};\n\nexport const coordinates = (graphProps, mark, rect, position) => {\n const { scale } = graphProps;\n const shift = 10;\n rect = rect || { width: 0, height: 0 };\n\n switch (position) {\n case 'bottom-right': {\n return { left: scale.x(mark.x) + shift, top: scale.y(mark.y) + shift };\n }\n case 'bottom-left': {\n return { left: scale.x(mark.x) - shift - rect.width, top: scale.y(mark.y) + shift };\n }\n case 'top-left': {\n return {\n left: scale.x(mark.x) - shift - rect.width,\n top: scale.y(mark.y) - shift - rect.height,\n };\n }\n case 'top-right': {\n return {\n left: scale.x(mark.x) + shift,\n top: scale.y(mark.y) - shift - rect.height,\n };\n }\n }\n};\n\nexport const MarkLabel = (props) => {\n const [input, setInput] = useState(null);\n const _ref = useCallback((node) => setInput(node));\n\n const { mark, graphProps, classes, disabled, inputRef: externalInputRef, theme } = props;\n\n const [label, setLabel] = useState(mark.label);\n\n const onChange = (e) => setLabel(e.target.value);\n\n const debouncedLabel = useDebounce(label, 200);\n\n // useState only sets the value once, to synch props to state need useEffect\n useEffect(() => {\n setLabel(mark.label);\n }, [mark.label]);\n\n // pick up the change to debouncedLabel and save it\n useEffect(() => {\n if (typeof debouncedLabel === 'string' && debouncedLabel !== mark.label) {\n props.onChange(debouncedLabel);\n }\n }, [debouncedLabel]);\n\n const rect = input ? input.getBoundingClientRect() : { width: 0, height: 0 };\n const pos = position(graphProps, mark, rect);\n const leftTop = coordinates(graphProps, mark, rect, pos);\n\n const style = {\n position: 'fixed',\n pointerEvents: 'auto',\n ...leftTop,\n };\n\n const disabledInput = disabled || mark.disabled;\n\n return (\n <AutosizeInput\n inputRef={(r) => {\n _ref(r);\n externalInputRef(r);\n }}\n disabled={disabledInput}\n inputClassName={cn(classes.input, {\n [classes.disabled]: disabled,\n [classes.disabledMark]: mark.disabled,\n })}\n value={label}\n style={style}\n onChange={onChange}\n />\n );\n};\n\nMarkLabel.propTypes = {\n disabled: PropTypes.bool,\n onChange: PropTypes.func,\n graphProps: types.GraphPropsType,\n classes: PropTypes.object,\n inputRef: PropTypes.func,\n mark: PropTypes.object,\n theme: PropTypes.object,\n};\n\nexport default withStyles(styles, { withTheme: true })(MarkLabel);\n"],"file":"mark-label.js"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
Object.defineProperty(exports, "AppendCSSRules", {
|
|
11
|
+
enumerable: true,
|
|
12
|
+
get: function get() {
|
|
13
|
+
return _appendCssRules["default"];
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
Object.defineProperty(exports, "Collapsible", {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
get: function get() {
|
|
19
|
+
return _collapsible["default"];
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
Object.defineProperty(exports, "EnableAudioAutoplayImage", {
|
|
23
|
+
enumerable: true,
|
|
24
|
+
get: function get() {
|
|
25
|
+
return _enableAudioAutoplayImage["default"];
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
Object.defineProperty(exports, "Feedback", {
|
|
29
|
+
enumerable: true,
|
|
30
|
+
get: function get() {
|
|
31
|
+
return _feedback["default"];
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
Object.defineProperty(exports, "HtmlAndMath", {
|
|
35
|
+
enumerable: true,
|
|
36
|
+
get: function get() {
|
|
37
|
+
return _htmlAndMath["default"];
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
Object.defineProperty(exports, "InputContainer", {
|
|
41
|
+
enumerable: true,
|
|
42
|
+
get: function get() {
|
|
43
|
+
return _inputContainer["default"];
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
Object.defineProperty(exports, "PreviewLayout", {
|
|
47
|
+
enumerable: true,
|
|
48
|
+
get: function get() {
|
|
49
|
+
return _previewLayout["default"];
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
Object.defineProperty(exports, "PreviewPrompt", {
|
|
53
|
+
enumerable: true,
|
|
54
|
+
get: function get() {
|
|
55
|
+
return _previewPrompt["default"];
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
Object.defineProperty(exports, "Purpose", {
|
|
59
|
+
enumerable: true,
|
|
60
|
+
get: function get() {
|
|
61
|
+
return _purpose["default"];
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
Object.defineProperty(exports, "Readable", {
|
|
65
|
+
enumerable: true,
|
|
66
|
+
get: function get() {
|
|
67
|
+
return _readable["default"];
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
Object.defineProperty(exports, "UiLayout", {
|
|
71
|
+
enumerable: true,
|
|
72
|
+
get: function get() {
|
|
73
|
+
return _uiLayout["default"];
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
exports.color = void 0;
|
|
77
|
+
Object.defineProperty(exports, "hasMedia", {
|
|
78
|
+
enumerable: true,
|
|
79
|
+
get: function get() {
|
|
80
|
+
return _hasMedia.hasMedia;
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
Object.defineProperty(exports, "hasText", {
|
|
84
|
+
enumerable: true,
|
|
85
|
+
get: function get() {
|
|
86
|
+
return _hasText.hasText;
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
exports.indicators = void 0;
|
|
90
|
+
Object.defineProperty(exports, "withUndoReset", {
|
|
91
|
+
enumerable: true,
|
|
92
|
+
get: function get() {
|
|
93
|
+
return _withUndoReset["default"];
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
var indicators = _interopRequireWildcard(require("./response-indicators"));
|
|
98
|
+
|
|
99
|
+
exports.indicators = indicators;
|
|
100
|
+
|
|
101
|
+
var _feedback = _interopRequireDefault(require("./feedback"));
|
|
102
|
+
|
|
103
|
+
var _collapsible = _interopRequireDefault(require("./collapsible"));
|
|
104
|
+
|
|
105
|
+
var _withUndoReset = _interopRequireDefault(require("./withUndoReset"));
|
|
106
|
+
|
|
107
|
+
var _previewLayout = _interopRequireDefault(require("./preview-layout"));
|
|
108
|
+
|
|
109
|
+
var _uiLayout = _interopRequireDefault(require("./ui-layout"));
|
|
110
|
+
|
|
111
|
+
var _htmlAndMath = _interopRequireDefault(require("./html-and-math"));
|
|
112
|
+
|
|
113
|
+
var _inputContainer = _interopRequireDefault(require("./input-container"));
|
|
114
|
+
|
|
115
|
+
var _previewPrompt = _interopRequireDefault(require("./preview-prompt"));
|
|
116
|
+
|
|
117
|
+
var _readable = _interopRequireDefault(require("./readable"));
|
|
118
|
+
|
|
119
|
+
var _purpose = _interopRequireDefault(require("./purpose"));
|
|
120
|
+
|
|
121
|
+
var color = _interopRequireWildcard(require("./color"));
|
|
122
|
+
|
|
123
|
+
exports.color = color;
|
|
124
|
+
|
|
125
|
+
var _hasText = require("./has-text");
|
|
126
|
+
|
|
127
|
+
var _hasMedia = require("./has-media");
|
|
128
|
+
|
|
129
|
+
var _enableAudioAutoplayImage = _interopRequireDefault(require("./assets/enableAudioAutoplayImage"));
|
|
130
|
+
|
|
131
|
+
var _appendCssRules = _interopRequireDefault(require("./append-css-rules"));
|
|
132
|
+
|
|
133
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
134
|
+
|
|
135
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
136
|
+
//# sourceMappingURL=index.js.map
|
package/lib/toggle-bar.js
CHANGED
|
@@ -31,7 +31,7 @@ var _classnames = _interopRequireDefault(require("classnames"));
|
|
|
31
31
|
|
|
32
32
|
var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
|
|
33
33
|
|
|
34
|
-
var
|
|
34
|
+
var _index = require("./shared/index");
|
|
35
35
|
|
|
36
36
|
var _tools = require("./tools");
|
|
37
37
|
|
|
@@ -52,23 +52,23 @@ var translator = _translator["default"].translator;
|
|
|
52
52
|
var buttonStyles = function buttonStyles() {
|
|
53
53
|
return {
|
|
54
54
|
root: {
|
|
55
|
-
color:
|
|
55
|
+
color: _index.color.text()
|
|
56
56
|
},
|
|
57
57
|
selected: {
|
|
58
|
-
backgroundColor:
|
|
59
|
-
border: "1px solid ".concat(
|
|
58
|
+
backgroundColor: _index.color.background(),
|
|
59
|
+
border: "1px solid ".concat(_index.color.secondary())
|
|
60
60
|
},
|
|
61
61
|
notSelected: {
|
|
62
62
|
'& span': {
|
|
63
|
-
color:
|
|
63
|
+
color: _index.color.primary()
|
|
64
64
|
},
|
|
65
|
-
backgroundColor:
|
|
65
|
+
backgroundColor: _index.color.background()
|
|
66
66
|
},
|
|
67
67
|
disabled: {
|
|
68
68
|
'& span': {
|
|
69
|
-
color:
|
|
69
|
+
color: _index.color.primary()
|
|
70
70
|
},
|
|
71
|
-
backgroundColor:
|
|
71
|
+
backgroundColor: _index.color.disabled()
|
|
72
72
|
}
|
|
73
73
|
};
|
|
74
74
|
};
|
|
@@ -209,7 +209,7 @@ var styles = function styles(theme) {
|
|
|
209
209
|
button: {
|
|
210
210
|
marginRight: theme.spacing.unit / 2,
|
|
211
211
|
marginBottom: theme.spacing.unit / 2,
|
|
212
|
-
color:
|
|
212
|
+
color: _index.color.text()
|
|
213
213
|
},
|
|
214
214
|
under: {
|
|
215
215
|
position: 'absolute',
|
|
@@ -333,4 +333,4 @@ var collectSource = function collectSource(connect, monitor) {
|
|
|
333
333
|
};
|
|
334
334
|
|
|
335
335
|
var DragTool = (0, _drag.DropTarget)(DRAG_TYPE, itemTarget, collectTarget)((0, _drag.DragSource)(DRAG_TYPE, itemSource, collectSource)(Item));
|
|
336
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/toggle-bar.jsx"],"names":["translator","Translator","buttonStyles","root","color","text","selected","backgroundColor","background","border","secondary","notSelected","primary","disabled","MiniButton","props","classes","className","value","onClick","language","translatorKey","toLowerCase","e","buttonValue","t","lng","propTypes","PropTypes","bool","object","string","disabledClassName","func","ToggleBar","onChange","target","textContent","dragIndex","hoverIndex","options","onChangeToolsOrder","dragged","splice","selectedToolType","draggableTools","toolsContainer","map","option","index","allTools","includes","isSelected","toolRef","React","createRef","moveTool","button","select","Component","isRequired","arrayOf","styles","theme","display","flexWrap","marginRight","spacing","unit","marginBottom","under","position","top","left","zIndex","pointerEvents","wrapper","hidden","opacity","DRAG_TYPE","Item","children","connectDragSource","connectDropTarget","connectDragPreview","isDragging","oneOfType","node","any","itemSource","canDrag","draggable","beginDrag","itemTarget","hover","monitor","getItem","current","hoverBoundingRect","getBoundingClientRect","hoverMiddleX","right","clientOffset","getClientOffset","hoverClientX","x","collectTarget","connect","dropTarget","collectSource","dragSource","dragPreview","DragTool"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport cn from 'classnames';\nimport Button from '@material-ui/core/Button';\nimport { color } from '@pie-lib/render-ui';\nimport { allTools } from './tools';\nimport { withDragContext, DragSource, DropTarget } from '@pie-lib/drag';\nimport Translator from '@pie-lib/translator';\n\nconst { translator } = Translator;\n\nconst buttonStyles = () => ({\n  root: {\n    color: color.text(),\n  },\n  selected: {\n    backgroundColor: color.background(),\n    border: `1px solid ${color.secondary()}`,\n  },\n  notSelected: {\n    '& span': {\n      color: color.primary(),\n    },\n    backgroundColor: color.background(),\n  },\n  disabled: {\n    '& span': {\n      color: color.primary(),\n    },\n    backgroundColor: color.disabled(),\n  },\n});\n\nexport const MiniButton = withStyles(buttonStyles)((props) => {\n  const { disabled, classes, className, selected, value, onClick, language } = props;\n  const translatorKey = value.toLowerCase();\n\n  return (\n    <Button\n      size=\"small\"\n      disabled={disabled}\n      className={cn(classes.root, selected && classes.selected, className)}\n      classes={{ disabled: cn(disabled && classes.disabled) }}\n      value={value}\n      key={value}\n      variant=\"outlined\"\n      onClick={(e) => onClick({ ...e, buttonValue: value })}\n    >\n      {translator.t(`graphing.${translatorKey}`, { lng: language })}\n    </Button>\n  );\n});\n\nMiniButton.propTypes = {\n  disabled: PropTypes.bool,\n  classes: PropTypes.object,\n  className: PropTypes.string,\n  disabledClassName: PropTypes.string,\n  selected: PropTypes.bool,\n  value: PropTypes.string,\n  onClick: PropTypes.func,\n};\n\nexport class ToggleBar extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    className: PropTypes.string,\n    options: PropTypes.arrayOf(PropTypes.string),\n    selectedToolType: PropTypes.string,\n    disabled: PropTypes.bool,\n    draggableTools: PropTypes.bool,\n    onChange: PropTypes.func,\n    onChangeToolsOrder: PropTypes.func,\n    language: PropTypes.string,\n  };\n\n  static defaultProps = {};\n\n  select = (e) => this.props.onChange(e.buttonValue || e.target.textContent);\n\n  moveTool = (dragIndex, hoverIndex) => {\n    const { options, onChangeToolsOrder } = this.props;\n    const dragged = options[dragIndex];\n\n    options.splice(dragIndex, 1);\n    options.splice(hoverIndex, 0, dragged);\n\n    onChangeToolsOrder(options);\n  };\n\n  render() {\n    const { classes, className, disabled, options, selectedToolType, draggableTools, language } = this.props;\n\n    return (\n      <div className={cn(className, classes.toolsContainer)}>\n        {(options || []).map((option, index) => {\n          if ((allTools || []).includes(option)) {\n            const isSelected = option === selectedToolType;\n            const toolRef = React.createRef();\n\n            return (\n              <DragTool\n                key={option}\n                index={index}\n                draggable={draggableTools}\n                moveTool={this.moveTool}\n                classes={classes}\n                toolRef={toolRef}\n              >\n                <MiniButton\n                  className={cn(classes.button, isSelected && classes.selected)}\n                  disabled={disabled}\n                  disableRipple={true}\n                  onClick={this.select}\n                  value={option}\n                  selected={isSelected}\n                  language={language}\n                />\n              </DragTool>\n            );\n          }\n        })}\n      </div>\n    );\n  }\n}\n\nconst styles = (theme) => ({\n  toolsContainer: {\n    display: 'flex',\n    flexWrap: 'wrap',\n  },\n  button: {\n    marginRight: theme.spacing.unit / 2,\n    marginBottom: theme.spacing.unit / 2,\n    color: color.text(),\n  },\n  under: {\n    position: 'absolute',\n    top: 0,\n    left: 0,\n    zIndex: -1,\n    pointerEvents: 'none',\n  },\n  wrapper: {\n    position: 'relative',\n  },\n  hidden: {\n    opacity: 0,\n  },\n});\n\nexport default withDragContext(withStyles(styles)(ToggleBar));\n\nconst DRAG_TYPE = 'tool';\n\nexport class Item extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object.isRequired,\n    className: PropTypes.string,\n    children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n    connectDragSource: PropTypes.func.isRequired,\n    connectDragPreview: PropTypes.func.isRequired,\n    connectDropTarget: PropTypes.func.isRequired,\n    isDragging: PropTypes.bool,\n    toolRef: PropTypes.any,\n  };\n\n  static defaultProps = {};\n\n  render() {\n    const {\n      classes,\n      children,\n      connectDragSource,\n      connectDropTarget,\n      connectDragPreview,\n      isDragging,\n      toolRef,\n    } = this.props;\n\n    return (\n      <div className={classes.wrapper} ref={toolRef}>\n        {connectDragSource(connectDropTarget(<div className={isDragging && classes.hidden}>{children}</div>))}\n        {connectDragPreview(<div className={classes.under}>{children}</div>)}\n      </div>\n    );\n  }\n}\n\nconst itemSource = {\n  canDrag(props) {\n    return props.draggable;\n  },\n  beginDrag(props) {\n    return {\n      index: props.index,\n    };\n  },\n};\n\nconst itemTarget = {\n  hover(props, monitor) {\n    const dragIndex = monitor.getItem().index;\n    const { toolRef, index: hoverIndex } = props;\n\n    if (dragIndex === hoverIndex || !toolRef.current) {\n      return;\n    }\n\n    const hoverBoundingRect = toolRef.current?.getBoundingClientRect();\n    const hoverMiddleX = (hoverBoundingRect.right - hoverBoundingRect.left) / 2;\n    const clientOffset = monitor.getClientOffset();\n    const hoverClientX = clientOffset.x - hoverBoundingRect.left;\n\n    if (dragIndex < hoverIndex && hoverClientX < hoverMiddleX) {\n      return;\n    }\n\n    if (dragIndex > hoverIndex && hoverClientX > hoverMiddleX) {\n      return;\n    }\n\n    props.moveTool(dragIndex, hoverIndex);\n    monitor.getItem().index = hoverIndex;\n  },\n};\n\nconst collectTarget = (connect) => ({ connectDropTarget: connect.dropTarget() });\n\nconst collectSource = (connect, monitor) => ({\n  connectDragSource: connect.dragSource(),\n  connectDragPreview: connect.dragPreview(),\n  isDragging: monitor.isDragging(),\n});\n\nconst DragTool = DropTarget(\n  DRAG_TYPE,\n  itemTarget,\n  collectTarget,\n)(DragSource(DRAG_TYPE, itemSource, collectSource)(Item));\n"]}
|
|
336
|
+
//# sourceMappingURL=toggle-bar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/toggle-bar.jsx"],"names":["translator","Translator","buttonStyles","root","color","text","selected","backgroundColor","background","border","secondary","notSelected","primary","disabled","MiniButton","props","classes","className","value","onClick","language","translatorKey","toLowerCase","e","buttonValue","t","lng","propTypes","PropTypes","bool","object","string","disabledClassName","func","ToggleBar","onChange","target","textContent","dragIndex","hoverIndex","options","onChangeToolsOrder","dragged","splice","selectedToolType","draggableTools","toolsContainer","map","option","index","allTools","includes","isSelected","toolRef","React","createRef","moveTool","button","select","Component","isRequired","arrayOf","styles","theme","display","flexWrap","marginRight","spacing","unit","marginBottom","under","position","top","left","zIndex","pointerEvents","wrapper","hidden","opacity","DRAG_TYPE","Item","children","connectDragSource","connectDropTarget","connectDragPreview","isDragging","oneOfType","node","any","itemSource","canDrag","draggable","beginDrag","itemTarget","hover","monitor","getItem","current","hoverBoundingRect","getBoundingClientRect","hoverMiddleX","right","clientOffset","getClientOffset","hoverClientX","x","collectTarget","connect","dropTarget","collectSource","dragSource","dragPreview","DragTool"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport cn from 'classnames';\nimport Button from '@material-ui/core/Button';\nimport { color } from '../../render-ui/src/index';\nimport { allTools } from './tools';\nimport { withDragContext, DragSource, DropTarget } from '@pie-lib/drag';\nimport Translator from '@pie-lib/translator';\n\nconst { translator } = Translator;\n\nconst buttonStyles = () => ({\n root: {\n color: color.text(),\n },\n selected: {\n backgroundColor: color.background(),\n border: `1px solid ${color.secondary()}`,\n },\n notSelected: {\n '& span': {\n color: color.primary(),\n },\n backgroundColor: color.background(),\n },\n disabled: {\n '& span': {\n color: color.primary(),\n },\n backgroundColor: color.disabled(),\n },\n});\n\nexport const MiniButton = withStyles(buttonStyles)((props) => {\n const { disabled, classes, className, selected, value, onClick, language } = props;\n const translatorKey = value.toLowerCase();\n\n return (\n <Button\n size=\"small\"\n disabled={disabled}\n className={cn(classes.root, selected && classes.selected, className)}\n classes={{ disabled: cn(disabled && classes.disabled) }}\n value={value}\n key={value}\n variant=\"outlined\"\n onClick={(e) => onClick({ ...e, buttonValue: value })}\n >\n {translator.t(`graphing.${translatorKey}`, { lng: language })}\n </Button>\n );\n});\n\nMiniButton.propTypes = {\n disabled: PropTypes.bool,\n classes: PropTypes.object,\n className: PropTypes.string,\n disabledClassName: PropTypes.string,\n selected: PropTypes.bool,\n value: PropTypes.string,\n onClick: PropTypes.func,\n};\n\nexport class ToggleBar extends React.Component {\n static propTypes = {\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n options: PropTypes.arrayOf(PropTypes.string),\n selectedToolType: PropTypes.string,\n disabled: PropTypes.bool,\n draggableTools: PropTypes.bool,\n onChange: PropTypes.func,\n onChangeToolsOrder: PropTypes.func,\n language: PropTypes.string,\n };\n\n static defaultProps = {};\n\n select = (e) => this.props.onChange(e.buttonValue || e.target.textContent);\n\n moveTool = (dragIndex, hoverIndex) => {\n const { options, onChangeToolsOrder } = this.props;\n const dragged = options[dragIndex];\n\n options.splice(dragIndex, 1);\n options.splice(hoverIndex, 0, dragged);\n\n onChangeToolsOrder(options);\n };\n\n render() {\n const { classes, className, disabled, options, selectedToolType, draggableTools, language } = this.props;\n\n return (\n <div className={cn(className, classes.toolsContainer)}>\n {(options || []).map((option, index) => {\n if ((allTools || []).includes(option)) {\n const isSelected = option === selectedToolType;\n const toolRef = React.createRef();\n\n return (\n <DragTool\n key={option}\n index={index}\n draggable={draggableTools}\n moveTool={this.moveTool}\n classes={classes}\n toolRef={toolRef}\n >\n <MiniButton\n className={cn(classes.button, isSelected && classes.selected)}\n disabled={disabled}\n disableRipple={true}\n onClick={this.select}\n value={option}\n selected={isSelected}\n language={language}\n />\n </DragTool>\n );\n }\n })}\n </div>\n );\n }\n}\n\nconst styles = (theme) => ({\n toolsContainer: {\n display: 'flex',\n flexWrap: 'wrap',\n },\n button: {\n marginRight: theme.spacing.unit / 2,\n marginBottom: theme.spacing.unit / 2,\n color: color.text(),\n },\n under: {\n position: 'absolute',\n top: 0,\n left: 0,\n zIndex: -1,\n pointerEvents: 'none',\n },\n wrapper: {\n position: 'relative',\n },\n hidden: {\n opacity: 0,\n },\n});\n\nexport default withDragContext(withStyles(styles)(ToggleBar));\n\nconst DRAG_TYPE = 'tool';\n\nexport class Item extends React.Component {\n static propTypes = {\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n connectDragSource: PropTypes.func.isRequired,\n connectDragPreview: PropTypes.func.isRequired,\n connectDropTarget: PropTypes.func.isRequired,\n isDragging: PropTypes.bool,\n toolRef: PropTypes.any,\n };\n\n static defaultProps = {};\n\n render() {\n const {\n classes,\n children,\n connectDragSource,\n connectDropTarget,\n connectDragPreview,\n isDragging,\n toolRef,\n } = this.props;\n\n return (\n <div className={classes.wrapper} ref={toolRef}>\n {connectDragSource(connectDropTarget(<div className={isDragging && classes.hidden}>{children}</div>))}\n {connectDragPreview(<div className={classes.under}>{children}</div>)}\n </div>\n );\n }\n}\n\nconst itemSource = {\n canDrag(props) {\n return props.draggable;\n },\n beginDrag(props) {\n return {\n index: props.index,\n };\n },\n};\n\nconst itemTarget = {\n hover(props, monitor) {\n const dragIndex = monitor.getItem().index;\n const { toolRef, index: hoverIndex } = props;\n\n if (dragIndex === hoverIndex || !toolRef.current) {\n return;\n }\n\n const hoverBoundingRect = toolRef.current?.getBoundingClientRect();\n const hoverMiddleX = (hoverBoundingRect.right - hoverBoundingRect.left) / 2;\n const clientOffset = monitor.getClientOffset();\n const hoverClientX = clientOffset.x - hoverBoundingRect.left;\n\n if (dragIndex < hoverIndex && hoverClientX < hoverMiddleX) {\n return;\n }\n\n if (dragIndex > hoverIndex && hoverClientX > hoverMiddleX) {\n return;\n }\n\n props.moveTool(dragIndex, hoverIndex);\n monitor.getItem().index = hoverIndex;\n },\n};\n\nconst collectTarget = (connect) => ({ connectDropTarget: connect.dropTarget() });\n\nconst collectSource = (connect, monitor) => ({\n connectDragSource: connect.dragSource(),\n connectDragPreview: connect.dragPreview(),\n isDragging: monitor.isDragging(),\n});\n\nconst DragTool = DropTarget(\n DRAG_TYPE,\n itemTarget,\n collectTarget,\n)(DragSource(DRAG_TYPE, itemSource, collectSource)(Item));\n"],"file":"toggle-bar.js"}
|
package/lib/tool-menu.js
CHANGED
|
@@ -322,4 +322,4 @@ var styles = function styles(theme) {
|
|
|
322
322
|
var _default = (0, _styles.withStyles)(styles)(ToolMenu);
|
|
323
323
|
|
|
324
324
|
exports["default"] = _default;
|
|
325
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/tool-menu.jsx"],"names":["ToolMenu","event","props","gssLineData","onChange","oldSelectedTool","selectedTool","target","value","line","type","lineType","classes","disabled","selectLineRadioGroup","radioFieldOuter","radioFieldInner","onChangeRadioValue","lineTypeRadio","lineNameFont","radioFieldButtons","lineA","lineTypeChange","lineTypeButtonLeftSelectedDisabled","lineTypeButtonLeftSelected","lineTypeButtonLeftUnSelectedDisabled","lineTypeButtonLeftUnSelected","lineTypeButtonRightSelectedDisabled","lineTypeButtonRightSelected","lineTypeButtonRightUnSelectedDisabled","lineTypeButtonRightUnSelected","numberOfLines","lineB","React","Component","PropTypes","object","bool","func","styles","theme","radioButtonClass","display","flexWrap","flexDirection","alignItems","padding","lineTypeText","marginLeft","fontWeight","textTransform","border","borderRadius","backgroundColor","borderTopLeftRadius","borderBottomLeftRadius","color","borderTopRightRadius","borderBottomRightRadius","cursor","pointerEvents"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;IAEaA,Q;;;;;;;;;;;;;;;2GA4JU,UAACC,KAAD,EAAW;AAC9B,wBAAgC,MAAKC,KAArC;AAAA,UAAMC,WAAN,eAAMA,WAAN;AAAA,UAAmBC,QAAnB,eAAmBA,QAAnB;AACA,UAAIC,eAAe,GAAGF,WAAW,CAACG,YAAlC;AACAH,MAAAA,WAAW,CAACG,YAAZ,GAA2BL,KAAK,CAACM,MAAN,CAAaC,KAAxC;AACAJ,MAAAA,QAAQ,CAACD,WAAD,EAAcE,eAAd,CAAR;AACD,K;uGAEgB,UAACI,IAAD,EAAOC,IAAP,EAAgB;AAC/B,yBAAgC,MAAKR,KAArC;AAAA,UAAMC,WAAN,gBAAMA,WAAN;AAAA,UAAmBC,QAAnB,gBAAmBA,QAAnB;AACA,UAAIC,eAAe,GAAGF,WAAW,CAACG,YAAlC;AACAH,MAAAA,WAAW,eAAQM,IAAR,EAAX,CAA2BE,QAA3B,GAAsCD,IAAtC;AACAN,MAAAA,QAAQ,CAACD,WAAD,EAAcE,eAAd,CAAR;AACD,K;;;;;;WAhKD,kBAAS;AAAA;;AACP,yBAAyC,KAAKH,KAA9C;AAAA,UAAMU,OAAN,gBAAMA,OAAN;AAAA,UAAeT,WAAf,gBAAeA,WAAf;AAAA,UAA4BU,QAA5B,gBAA4BA,QAA5B;AAEA,0BACE;AAAK,QAAA,SAAS,EAAED,OAAO,CAACE;AAAxB,sBACE;AAAK,QAAA,SAAS,EAAEF,OAAO,CAACG;AAAxB,sBACE;AAAK,QAAA,SAAS,EAAEH,OAAO,CAACI;AAAxB,sBACE,gCAAC,iBAAD;AACE,QAAA,IAAI,EAAE,2BADR;AAEE,QAAA,QAAQ,EAAE,KAAKC,kBAFjB;AAGE,QAAA,KAAK,EAAE,OAHT;AAIE,QAAA,QAAQ,EAAE,CAAC,CAACJ,QAJd;AAKE,QAAA,OAAO,EAAEV,WAAW,CAACG,YAAZ,KAA6B,OALxC;AAME,QAAA,SAAS,EAAEM,OAAO,CAACM;AANrB,QADF,eASE,gCAAC,gBAAD;AAAY,QAAA,SAAS,EAAEN,OAAO,CAACO;AAA/B,kBATF,CADF,eAYE;AAAK,QAAA,SAAS,EAAEP,OAAO,CAACQ;AAAxB,SACGjB,WAAW,CAACkB,KAAZ,CAAkBV,QAAlB,KAA+B,OAA/B,gBACC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,KAAK,EAAE,SAHT;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACW,cAAL,CAAoB,GAApB,EAAyB,OAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EAAET,QAAQ,GAAGD,OAAO,CAACW,kCAAX,GAAgDX,OAAO,CAACY;AAL7E,wBADD,gBAWC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,QAAQ,EAAE,CAAC,CAACX,QAHd;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACS,cAAL,CAAoB,GAApB,EAAyB,OAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EACPT,QAAQ,GAAGD,OAAO,CAACa,oCAAX,GAAkDb,OAAO,CAACc;AANtE,iBAZJ,EAwBGvB,WAAW,CAACkB,KAAZ,CAAkBV,QAAlB,KAA+B,QAA/B,gBACC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,KAAK,EAAE,SAHT;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACW,cAAL,CAAoB,GAApB,EAAyB,QAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EAAET,QAAQ,GAAGD,OAAO,CAACe,mCAAX,GAAiDf,OAAO,CAACgB;AAL9E,yBADD,gBAWC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,QAAQ,EAAE,CAAC,CAACf,QAHd;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACS,cAAL,CAAoB,GAApB,EAAyB,QAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EACPT,QAAQ,GAAGD,OAAO,CAACiB,qCAAX,GAAmDjB,OAAO,CAACkB;AANvE,kBAnCJ,CAZF,CADF,EA8DG3B,WAAW,CAAC4B,aAAZ,KAA8B,CAA9B,gBACC;AAAK,QAAA,SAAS,EAAEnB,OAAO,CAACG;AAAxB,sBACE;AAAK,QAAA,SAAS,EAAEH,OAAO,CAACI;AAAxB,sBACE,gCAAC,iBAAD;AACE,QAAA,IAAI,EAAE,2BADR;AAEE,QAAA,QAAQ,EAAE,KAAKC,kBAFjB;AAGE,QAAA,KAAK,EAAE,OAHT;AAIE,QAAA,QAAQ,EAAE,CAAC,CAACJ,QAJd;AAKE,QAAA,OAAO,EAAEV,WAAW,CAACG,YAAZ,KAA6B,OALxC;AAME,QAAA,SAAS,EAAEM,OAAO,CAACM;AANrB,QADF,eASE,gCAAC,gBAAD;AAAY,QAAA,SAAS,EAAEN,OAAO,CAACO;AAA/B,kBATF,CADF,eAYE;AAAK,QAAA,SAAS,EAAEP,OAAO,CAACQ;AAAxB,SACGjB,WAAW,CAAC6B,KAAZ,CAAkBrB,QAAlB,KAA+B,OAA/B,gBACC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,KAAK,EAAE,SAHT;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACW,cAAL,CAAoB,GAApB,EAAyB,OAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EAAET,QAAQ,GAAGD,OAAO,CAACW,kCAAX,GAAgDX,OAAO,CAACY;AAL7E,wBADD,gBAWC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,QAAQ,EAAE,CAAC,CAACX,QAHd;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACS,cAAL,CAAoB,GAApB,EAAyB,OAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EACPT,QAAQ,GAAGD,OAAO,CAACa,oCAAX,GAAkDb,OAAO,CAACc;AANtE,iBAZJ,EAwBGvB,WAAW,CAAC6B,KAAZ,CAAkBrB,QAAlB,KAA+B,QAA/B,gBACC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,KAAK,EAAE,SAHT;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACW,cAAL,CAAoB,GAApB,EAAyB,QAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EACPT,QAAQ,GAAGD,OAAO,CAACe,mCAAX,GAAiDf,OAAO,CAACgB;AANrE,yBADD,gBAaC,gCAAC,YAAD;AACE,QAAA,IAAI,EAAE,OADR;AAEE,QAAA,OAAO,EAAE,WAFX;AAGE,QAAA,QAAQ,EAAE,CAAC,CAACf,QAHd;AAIE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACS,cAAL,CAAoB,GAApB,EAAyB,QAAzB,CAAN;AAAA,SAJX;AAKE,QAAA,SAAS,EACPT,QAAQ,GAAGD,OAAO,CAACiB,qCAAX,GAAmDjB,OAAO,CAACkB;AANvE,kBArCJ,CAZF,CADD,GAgEG,IA9HN,eA+HE;AAAK,QAAA,SAAS,EAAElB,OAAO,CAACG;AAAxB,sBACE;AAAK,QAAA,SAAS,EAAEH,OAAO,CAACI;AAAxB,sBACE,gCAAC,iBAAD;AACE,QAAA,IAAI,EAAE,2BADR;AAEE,QAAA,QAAQ,EAAE,KAAKC,kBAFjB;AAGE,QAAA,KAAK,EAAE,aAHT;AAIE,QAAA,QAAQ,EAAE,CAAC,CAACJ,QAJd;AAKE,QAAA,OAAO,EAAEV,WAAW,CAACG,YAAZ,KAA6B,aALxC;AAME,QAAA,SAAS,EAAEM,OAAO,CAACM;AANrB,QADF,eASE,gCAAC,gBAAD;AAAY,QAAA,SAAS,EAAEN,OAAO,CAACO;AAA/B,wBATF,CADF,CA/HF,CADF;AA+ID;;;EA1J2Bc,kBAAMC,S;;;iCAAvBlC,Q,eACQ;AACjBY,EAAAA,OAAO,EAAEuB,sBAAUC,MADF;AAEjBjC,EAAAA,WAAW,EAAEgC,sBAAUC,MAFN;AAGjBvB,EAAAA,QAAQ,EAAEsB,sBAAUE,IAHH;AAIjBjC,EAAAA,QAAQ,EAAE+B,sBAAUG;AAJH,C;;AA0KrB,IAAMC,MAAM,GAAG,SAATA,MAAS,CAACC,KAAD;AAAA,SAAY;AACzBC,IAAAA,gBAAgB,EAAE,EADO;AAEzB3B,IAAAA,oBAAoB,EAAE;AACpB4B,MAAAA,OAAO,EAAE,MADW;AAEpBC,MAAAA,QAAQ,EAAE,MAFU;AAGpBC,MAAAA,aAAa,EAAE;AAHK,KAFG;AAOzB5B,IAAAA,eAAe,EAAE;AACf0B,MAAAA,OAAO,EAAE,MADM;AAEfC,MAAAA,QAAQ,EAAE,MAFK;AAGfC,MAAAA,aAAa,EAAE,KAHA;AAIfC,MAAAA,UAAU,EAAE;AAJG,KAPQ;AAazB9B,IAAAA,eAAe,EAAE;AACf2B,MAAAA,OAAO,EAAE,MADM;AAEfC,MAAAA,QAAQ,EAAE,MAFK;AAGfC,MAAAA,aAAa,EAAE;AAHA,KAbQ;AAkBzBxB,IAAAA,iBAAiB,EAAE;AACjBsB,MAAAA,OAAO,EAAE,MADQ;AAEjBC,MAAAA,QAAQ,EAAE,MAFO;AAGjBC,MAAAA,aAAa,EAAE,KAHE;AAIjBE,MAAAA,OAAO,EAAE;AAJQ,KAlBM;AAwBzBC,IAAAA,YAAY,EAAE;AACZC,MAAAA,UAAU,EAAE;AADA,KAxBW;AA2BzB7B,IAAAA,YAAY,EAAE;AACZ8B,MAAAA,UAAU,EAAE,MADA;AAEZH,MAAAA,OAAO,EAAE;AAFG,KA3BW;AA+BzBtB,IAAAA,0BAA0B,EAAE;AAC1B0B,MAAAA,aAAa,EAAE,MADW;AAE1BC,MAAAA,MAAM,EAAE,mBAFkB;AAG1BC,MAAAA,YAAY,EAAE,GAHY;AAI1BC,MAAAA,eAAe,EAAE,oBAJS;AAK1BC,MAAAA,mBAAmB,EAAE,KALK;AAM1BC,MAAAA,sBAAsB,EAAE,KANE;AAO1BC,MAAAA,KAAK,EAAE;AAPmB,KA/BH;AAwCzB9B,IAAAA,4BAA4B,EAAE;AAC5BwB,MAAAA,aAAa,EAAE,MADa;AAE5BC,MAAAA,MAAM,EAAE,mBAFoB;AAG5BC,MAAAA,YAAY,EAAE,GAHc;AAI5BC,MAAAA,eAAe,EAAE,oBAJW;AAK5BC,MAAAA,mBAAmB,EAAE,KALO;AAM5BC,MAAAA,sBAAsB,EAAE,KANI;AAO5BC,MAAAA,KAAK,EAAE;AAPqB,KAxCL;AAiDzB5B,IAAAA,2BAA2B,EAAE;AAC3BsB,MAAAA,aAAa,EAAE,MADY;AAE3BC,MAAAA,MAAM,EAAE,mBAFmB;AAG3BC,MAAAA,YAAY,EAAE,GAHa;AAI3BC,MAAAA,eAAe,EAAE,oBAJU;AAK3BI,MAAAA,oBAAoB,EAAE,KALK;AAM3BC,MAAAA,uBAAuB,EAAE,KANE;AAO3BF,MAAAA,KAAK,EAAE;AAPoB,KAjDJ;AA0DzB1B,IAAAA,6BAA6B,EAAE;AAC7BoB,MAAAA,aAAa,EAAE,MADc;AAE7BC,MAAAA,MAAM,EAAE,mBAFqB;AAG7BC,MAAAA,YAAY,EAAE,GAHe;AAI7BC,MAAAA,eAAe,EAAE,oBAJY;AAK7BI,MAAAA,oBAAoB,EAAE,KALO;AAM7BC,MAAAA,uBAAuB,EAAE,KANI;AAO7BF,MAAAA,KAAK,EAAE;AAPsB,KA1DN;AAmEzBtC,IAAAA,aAAa,EAAE;AACbsC,MAAAA,KAAK,EAAE;AADM,KAnEU;AAsEzBjC,IAAAA,kCAAkC,EAAE;AAClC2B,MAAAA,aAAa,EAAE,MADmB;AAElCC,MAAAA,MAAM,EAAE,mBAF0B;AAGlCC,MAAAA,YAAY,EAAE,GAHoB;AAIlCC,MAAAA,eAAe,EAAE,oBAJiB;AAKlCC,MAAAA,mBAAmB,EAAE,KALa;AAMlCC,MAAAA,sBAAsB,EAAE,KANU;AAOlCC,MAAAA,KAAK,EAAE,oBAP2B;AAQlCG,MAAAA,MAAM,EAAE,SAR0B;AASlCC,MAAAA,aAAa,EAAE;AATmB,KAtEX;AAiFzBnC,IAAAA,oCAAoC,EAAE;AACpCyB,MAAAA,aAAa,EAAE,MADqB;AAEpCC,MAAAA,MAAM,EAAE,mBAF4B;AAGpCC,MAAAA,YAAY,EAAE,GAHsB;AAIpCC,MAAAA,eAAe,EAAE,oBAJmB;AAKpCC,MAAAA,mBAAmB,EAAE,KALe;AAMpCC,MAAAA,sBAAsB,EAAE,KANY;AAOpCC,MAAAA,KAAK,EAAE,oBAP6B;AAQpCG,MAAAA,MAAM,EAAE,SAR4B;AASpCC,MAAAA,aAAa,EAAE;AATqB,KAjFb;AA4FzBjC,IAAAA,mCAAmC,EAAE;AACnCuB,MAAAA,aAAa,EAAE,MADoB;AAEnCC,MAAAA,MAAM,EAAE,mBAF2B;AAGnCC,MAAAA,YAAY,EAAE,GAHqB;AAInCC,MAAAA,eAAe,EAAE,oBAJkB;AAKnCI,MAAAA,oBAAoB,EAAE,KALa;AAMnCC,MAAAA,uBAAuB,EAAE,KANU;AAOnCF,MAAAA,KAAK,EAAE,oBAP4B;AAQnCG,MAAAA,MAAM,EAAE,SAR2B;AASnCC,MAAAA,aAAa,EAAE;AAToB,KA5FZ;AAuGzB/B,IAAAA,qCAAqC,EAAE;AACrCqB,MAAAA,aAAa,EAAE,MADsB;AAErCC,MAAAA,MAAM,EAAE,mBAF6B;AAGrCC,MAAAA,YAAY,EAAE,GAHuB;AAIrCC,MAAAA,eAAe,EAAE,oBAJoB;AAKrCI,MAAAA,oBAAoB,EAAE,KALe;AAMrCC,MAAAA,uBAAuB,EAAE,KANY;AAOrCF,MAAAA,KAAK,EAAE,oBAP8B;AAQrCG,MAAAA,MAAM,EAAE,SAR6B;AASrCC,MAAAA,aAAa,EAAE;AATsB;AAvGd,GAAZ;AAAA,CAAf;;eAoHe,wBAAWrB,MAAX,EAAmBvC,QAAnB,C","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { Typography, Button } from '@material-ui/core';\nimport Radio from '@material-ui/core/Radio';\nimport { withStyles } from '@material-ui/core/styles';\n\nexport class ToolMenu extends React.Component {\n  static propTypes = {\n    classes: PropTypes.object,\n    gssLineData: PropTypes.object,\n    disabled: PropTypes.bool,\n    onChange: PropTypes.func,\n  };\n\n  render() {\n    let { classes, gssLineData, disabled } = this.props;\n\n    return (\n      <div className={classes.selectLineRadioGroup}>\n        <div className={classes.radioFieldOuter}>\n          <div className={classes.radioFieldInner}>\n            <Radio\n              name={'select-line-radio-buttons'}\n              onChange={this.onChangeRadioValue}\n              value={'lineA'}\n              disabled={!!disabled}\n              checked={gssLineData.selectedTool === 'lineA'}\n              className={classes.lineTypeRadio}\n            />\n            <Typography className={classes.lineNameFont}>Line A</Typography>\n          </div>\n          <div className={classes.radioFieldButtons}>\n            {gssLineData.lineA.lineType === 'Solid' ? (\n              <Button\n                size={'small'}\n                variant={'contained'}\n                color={'primary'}\n                onClick={() => this.lineTypeChange('A', 'Solid')}\n                className={disabled ? classes.lineTypeButtonLeftSelectedDisabled : classes.lineTypeButtonLeftSelected}\n              >\n                &#x2714; Solid\n              </Button>\n            ) : (\n              <Button\n                size={'small'}\n                variant={'contained'}\n                disabled={!!disabled}\n                onClick={() => this.lineTypeChange('A', 'Solid')}\n                className={\n                  disabled ? classes.lineTypeButtonLeftUnSelectedDisabled : classes.lineTypeButtonLeftUnSelected\n                }\n              >\n                Solid\n              </Button>\n            )}\n            {gssLineData.lineA.lineType === 'Dashed' ? (\n              <Button\n                size={'small'}\n                variant={'contained'}\n                color={'primary'}\n                onClick={() => this.lineTypeChange('A', 'Dashed')}\n                className={disabled ? classes.lineTypeButtonRightSelectedDisabled : classes.lineTypeButtonRightSelected}\n              >\n                &#x2714; Dashed\n              </Button>\n            ) : (\n              <Button\n                size={'small'}\n                variant={'contained'}\n                disabled={!!disabled}\n                onClick={() => this.lineTypeChange('A', 'Dashed')}\n                className={\n                  disabled ? classes.lineTypeButtonRightUnSelectedDisabled : classes.lineTypeButtonRightUnSelected\n                }\n              >\n                Dashed\n              </Button>\n            )}\n          </div>\n        </div>\n        {gssLineData.numberOfLines === 2 ? (\n          <div className={classes.radioFieldOuter}>\n            <div className={classes.radioFieldInner}>\n              <Radio\n                name={'select-line-radio-buttons'}\n                onChange={this.onChangeRadioValue}\n                value={'lineB'}\n                disabled={!!disabled}\n                checked={gssLineData.selectedTool === 'lineB'}\n                className={classes.lineTypeRadio}\n              />\n              <Typography className={classes.lineNameFont}>Line B</Typography>\n            </div>\n            <div className={classes.radioFieldButtons}>\n              {gssLineData.lineB.lineType === 'Solid' ? (\n                <Button\n                  size={'small'}\n                  variant={'contained'}\n                  color={'primary'}\n                  onClick={() => this.lineTypeChange('B', 'Solid')}\n                  className={disabled ? classes.lineTypeButtonLeftSelectedDisabled : classes.lineTypeButtonLeftSelected}\n                >\n                  &#x2714; Solid\n                </Button>\n              ) : (\n                <Button\n                  size={'small'}\n                  variant={'contained'}\n                  disabled={!!disabled}\n                  onClick={() => this.lineTypeChange('B', 'Solid')}\n                  className={\n                    disabled ? classes.lineTypeButtonLeftUnSelectedDisabled : classes.lineTypeButtonLeftUnSelected\n                  }\n                >\n                  Solid\n                </Button>\n              )}\n              {gssLineData.lineB.lineType === 'Dashed' ? (\n                <Button\n                  size={'small'}\n                  variant={'contained'}\n                  color={'primary'}\n                  onClick={() => this.lineTypeChange('B', 'Dashed')}\n                  className={\n                    disabled ? classes.lineTypeButtonRightSelectedDisabled : classes.lineTypeButtonRightSelected\n                  }\n                >\n                  &#x2714; Dashed\n                </Button>\n              ) : (\n                <Button\n                  size={'small'}\n                  variant={'contained'}\n                  disabled={!!disabled}\n                  onClick={() => this.lineTypeChange('B', 'Dashed')}\n                  className={\n                    disabled ? classes.lineTypeButtonRightUnSelectedDisabled : classes.lineTypeButtonRightUnSelected\n                  }\n                >\n                  Dashed\n                </Button>\n              )}\n            </div>\n          </div>\n        ) : null}\n        <div className={classes.radioFieldOuter}>\n          <div className={classes.radioFieldInner}>\n            <Radio\n              name={'select-line-radio-buttons'}\n              onChange={this.onChangeRadioValue}\n              value={'solutionSet'}\n              disabled={!!disabled}\n              checked={gssLineData.selectedTool === 'solutionSet'}\n              className={classes.lineTypeRadio}\n            />\n            <Typography className={classes.lineNameFont}>Solution Set</Typography>\n          </div>\n        </div>\n      </div>\n    );\n  }\n\n  onChangeRadioValue = (event) => {\n    let { gssLineData, onChange } = this.props;\n    let oldSelectedTool = gssLineData.selectedTool;\n    gssLineData.selectedTool = event.target.value;\n    onChange(gssLineData, oldSelectedTool);\n  };\n\n  lineTypeChange = (line, type) => {\n    let { gssLineData, onChange } = this.props;\n    let oldSelectedTool = gssLineData.selectedTool;\n    gssLineData[`line${line}`].lineType = type;\n    onChange(gssLineData, oldSelectedTool);\n  };\n}\n\nconst styles = (theme) => ({\n  radioButtonClass: {},\n  selectLineRadioGroup: {\n    display: 'flex',\n    flexWrap: 'wrap',\n    flexDirection: 'row',\n  },\n  radioFieldInner: {\n    display: 'flex',\n    flexWrap: 'wrap',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n  radioFieldOuter: {\n    display: 'flex',\n    flexWrap: 'wrap',\n    flexDirection: 'column',\n  },\n  radioFieldButtons: {\n    display: 'flex',\n    flexWrap: 'wrap',\n    flexDirection: 'row',\n    padding: '0 .9rem',\n  },\n  lineTypeText: {\n    marginLeft: '.7rem',\n  },\n  lineNameFont: {\n    fontWeight: 'bold',\n    padding: '0 5px 0 0',\n  },\n  lineTypeButtonLeftSelected: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#3E4EB1 !important',\n    borderTopLeftRadius: '4px',\n    borderBottomLeftRadius: '4px',\n    color: '#FFFFFF !important',\n  },\n  lineTypeButtonLeftUnSelected: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#FFFFFF !important',\n    borderTopLeftRadius: '4px',\n    borderBottomLeftRadius: '4px',\n    color: '#3E4EB1 !important',\n  },\n  lineTypeButtonRightSelected: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#3E4EB1 !important',\n    borderTopRightRadius: '4px',\n    borderBottomRightRadius: '4px',\n    color: '#FFFFFF !important',\n  },\n  lineTypeButtonRightUnSelected: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#FFFFFF !important',\n    borderTopRightRadius: '4px',\n    borderBottomRightRadius: '4px',\n    color: '#3E4EB1 !important',\n  },\n  lineTypeRadio: {\n    color: '#000000 !important',\n  },\n  lineTypeButtonLeftSelectedDisabled: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#3E4EB1 !important',\n    borderTopLeftRadius: '4px',\n    borderBottomLeftRadius: '4px',\n    color: '#FFFFFF !important',\n    cursor: 'default',\n    pointerEvents: 'none',\n  },\n  lineTypeButtonLeftUnSelectedDisabled: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#FFFFFF !important',\n    borderTopLeftRadius: '4px',\n    borderBottomLeftRadius: '4px',\n    color: '#3E4EB1 !important',\n    cursor: 'default',\n    pointerEvents: 'none',\n  },\n  lineTypeButtonRightSelectedDisabled: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#3E4EB1 !important',\n    borderTopRightRadius: '4px',\n    borderBottomRightRadius: '4px',\n    color: '#FFFFFF !important',\n    cursor: 'default',\n    pointerEvents: 'none',\n  },\n  lineTypeButtonRightUnSelectedDisabled: {\n    textTransform: 'none',\n    border: '1px solid #3E4EB1',\n    borderRadius: '0',\n    backgroundColor: '#FFFFFF !important',\n    borderTopRightRadius: '4px',\n    borderBottomRightRadius: '4px',\n    color: '#3E4EB1 !important',\n    cursor: 'default',\n    pointerEvents: 'none',\n  },\n});\n\nexport default withStyles(styles)(ToolMenu);\n"]}
|
|
325
|
+
//# sourceMappingURL=tool-menu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/tool-menu.jsx"],"names":["ToolMenu","event","props","gssLineData","onChange","oldSelectedTool","selectedTool","target","value","line","type","lineType","classes","disabled","selectLineRadioGroup","radioFieldOuter","radioFieldInner","onChangeRadioValue","lineTypeRadio","lineNameFont","radioFieldButtons","lineA","lineTypeChange","lineTypeButtonLeftSelectedDisabled","lineTypeButtonLeftSelected","lineTypeButtonLeftUnSelectedDisabled","lineTypeButtonLeftUnSelected","lineTypeButtonRightSelectedDisabled","lineTypeButtonRightSelected","lineTypeButtonRightUnSelectedDisabled","lineTypeButtonRightUnSelected","numberOfLines","lineB","React","Component","PropTypes","object","bool","func","styles","theme","radioButtonClass","display","flexWrap","flexDirection","alignItems","padding","lineTypeText","marginLeft","fontWeight","textTransform","border","borderRadius","backgroundColor","borderTopLeftRadius","borderBottomLeftRadius","color","borderTopRightRadius","borderBottomRightRadius","cursor","pointerEvents"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { Typography, Button } from '@material-ui/core';\nimport Radio from '@material-ui/core/Radio';\nimport { withStyles } from '@material-ui/core/styles';\n\nexport class ToolMenu extends React.Component {\n static propTypes = {\n classes: PropTypes.object,\n gssLineData: PropTypes.object,\n disabled: PropTypes.bool,\n onChange: PropTypes.func,\n };\n\n render() {\n let { classes, gssLineData, disabled } = this.props;\n\n return (\n <div className={classes.selectLineRadioGroup}>\n <div className={classes.radioFieldOuter}>\n <div className={classes.radioFieldInner}>\n <Radio\n name={'select-line-radio-buttons'}\n onChange={this.onChangeRadioValue}\n value={'lineA'}\n disabled={!!disabled}\n checked={gssLineData.selectedTool === 'lineA'}\n className={classes.lineTypeRadio}\n />\n <Typography className={classes.lineNameFont}>Line A</Typography>\n </div>\n <div className={classes.radioFieldButtons}>\n {gssLineData.lineA.lineType === 'Solid' ? (\n <Button\n size={'small'}\n variant={'contained'}\n color={'primary'}\n onClick={() => this.lineTypeChange('A', 'Solid')}\n className={disabled ? classes.lineTypeButtonLeftSelectedDisabled : classes.lineTypeButtonLeftSelected}\n >\n ✔ Solid\n </Button>\n ) : (\n <Button\n size={'small'}\n variant={'contained'}\n disabled={!!disabled}\n onClick={() => this.lineTypeChange('A', 'Solid')}\n className={\n disabled ? classes.lineTypeButtonLeftUnSelectedDisabled : classes.lineTypeButtonLeftUnSelected\n }\n >\n Solid\n </Button>\n )}\n {gssLineData.lineA.lineType === 'Dashed' ? (\n <Button\n size={'small'}\n variant={'contained'}\n color={'primary'}\n onClick={() => this.lineTypeChange('A', 'Dashed')}\n className={disabled ? classes.lineTypeButtonRightSelectedDisabled : classes.lineTypeButtonRightSelected}\n >\n ✔ Dashed\n </Button>\n ) : (\n <Button\n size={'small'}\n variant={'contained'}\n disabled={!!disabled}\n onClick={() => this.lineTypeChange('A', 'Dashed')}\n className={\n disabled ? classes.lineTypeButtonRightUnSelectedDisabled : classes.lineTypeButtonRightUnSelected\n }\n >\n Dashed\n </Button>\n )}\n </div>\n </div>\n {gssLineData.numberOfLines === 2 ? (\n <div className={classes.radioFieldOuter}>\n <div className={classes.radioFieldInner}>\n <Radio\n name={'select-line-radio-buttons'}\n onChange={this.onChangeRadioValue}\n value={'lineB'}\n disabled={!!disabled}\n checked={gssLineData.selectedTool === 'lineB'}\n className={classes.lineTypeRadio}\n />\n <Typography className={classes.lineNameFont}>Line B</Typography>\n </div>\n <div className={classes.radioFieldButtons}>\n {gssLineData.lineB.lineType === 'Solid' ? (\n <Button\n size={'small'}\n variant={'contained'}\n color={'primary'}\n onClick={() => this.lineTypeChange('B', 'Solid')}\n className={disabled ? classes.lineTypeButtonLeftSelectedDisabled : classes.lineTypeButtonLeftSelected}\n >\n ✔ Solid\n </Button>\n ) : (\n <Button\n size={'small'}\n variant={'contained'}\n disabled={!!disabled}\n onClick={() => this.lineTypeChange('B', 'Solid')}\n className={\n disabled ? classes.lineTypeButtonLeftUnSelectedDisabled : classes.lineTypeButtonLeftUnSelected\n }\n >\n Solid\n </Button>\n )}\n {gssLineData.lineB.lineType === 'Dashed' ? (\n <Button\n size={'small'}\n variant={'contained'}\n color={'primary'}\n onClick={() => this.lineTypeChange('B', 'Dashed')}\n className={\n disabled ? classes.lineTypeButtonRightSelectedDisabled : classes.lineTypeButtonRightSelected\n }\n >\n ✔ Dashed\n </Button>\n ) : (\n <Button\n size={'small'}\n variant={'contained'}\n disabled={!!disabled}\n onClick={() => this.lineTypeChange('B', 'Dashed')}\n className={\n disabled ? classes.lineTypeButtonRightUnSelectedDisabled : classes.lineTypeButtonRightUnSelected\n }\n >\n Dashed\n </Button>\n )}\n </div>\n </div>\n ) : null}\n <div className={classes.radioFieldOuter}>\n <div className={classes.radioFieldInner}>\n <Radio\n name={'select-line-radio-buttons'}\n onChange={this.onChangeRadioValue}\n value={'solutionSet'}\n disabled={!!disabled}\n checked={gssLineData.selectedTool === 'solutionSet'}\n className={classes.lineTypeRadio}\n />\n <Typography className={classes.lineNameFont}>Solution Set</Typography>\n </div>\n </div>\n </div>\n );\n }\n\n onChangeRadioValue = (event) => {\n let { gssLineData, onChange } = this.props;\n let oldSelectedTool = gssLineData.selectedTool;\n gssLineData.selectedTool = event.target.value;\n onChange(gssLineData, oldSelectedTool);\n };\n\n lineTypeChange = (line, type) => {\n let { gssLineData, onChange } = this.props;\n let oldSelectedTool = gssLineData.selectedTool;\n gssLineData[`line${line}`].lineType = type;\n onChange(gssLineData, oldSelectedTool);\n };\n}\n\nconst styles = (theme) => ({\n radioButtonClass: {},\n selectLineRadioGroup: {\n display: 'flex',\n flexWrap: 'wrap',\n flexDirection: 'row',\n },\n radioFieldInner: {\n display: 'flex',\n flexWrap: 'wrap',\n flexDirection: 'row',\n alignItems: 'center',\n },\n radioFieldOuter: {\n display: 'flex',\n flexWrap: 'wrap',\n flexDirection: 'column',\n },\n radioFieldButtons: {\n display: 'flex',\n flexWrap: 'wrap',\n flexDirection: 'row',\n padding: '0 .9rem',\n },\n lineTypeText: {\n marginLeft: '.7rem',\n },\n lineNameFont: {\n fontWeight: 'bold',\n padding: '0 5px 0 0',\n },\n lineTypeButtonLeftSelected: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#3E4EB1 !important',\n borderTopLeftRadius: '4px',\n borderBottomLeftRadius: '4px',\n color: '#FFFFFF !important',\n },\n lineTypeButtonLeftUnSelected: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#FFFFFF !important',\n borderTopLeftRadius: '4px',\n borderBottomLeftRadius: '4px',\n color: '#3E4EB1 !important',\n },\n lineTypeButtonRightSelected: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#3E4EB1 !important',\n borderTopRightRadius: '4px',\n borderBottomRightRadius: '4px',\n color: '#FFFFFF !important',\n },\n lineTypeButtonRightUnSelected: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#FFFFFF !important',\n borderTopRightRadius: '4px',\n borderBottomRightRadius: '4px',\n color: '#3E4EB1 !important',\n },\n lineTypeRadio: {\n color: '#000000 !important',\n },\n lineTypeButtonLeftSelectedDisabled: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#3E4EB1 !important',\n borderTopLeftRadius: '4px',\n borderBottomLeftRadius: '4px',\n color: '#FFFFFF !important',\n cursor: 'default',\n pointerEvents: 'none',\n },\n lineTypeButtonLeftUnSelectedDisabled: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#FFFFFF !important',\n borderTopLeftRadius: '4px',\n borderBottomLeftRadius: '4px',\n color: '#3E4EB1 !important',\n cursor: 'default',\n pointerEvents: 'none',\n },\n lineTypeButtonRightSelectedDisabled: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#3E4EB1 !important',\n borderTopRightRadius: '4px',\n borderBottomRightRadius: '4px',\n color: '#FFFFFF !important',\n cursor: 'default',\n pointerEvents: 'none',\n },\n lineTypeButtonRightUnSelectedDisabled: {\n textTransform: 'none',\n border: '1px solid #3E4EB1',\n borderRadius: '0',\n backgroundColor: '#FFFFFF !important',\n borderTopRightRadius: '4px',\n borderBottomRightRadius: '4px',\n color: '#3E4EB1 !important',\n cursor: 'default',\n pointerEvents: 'none',\n },\n});\n\nexport default withStyles(styles)(ToolMenu);\n"],"file":"tool-menu.js"}
|
package/lib/tools/index.js
CHANGED
|
@@ -26,4 +26,4 @@ var allTools = ['line', 'polygon'];
|
|
|
26
26
|
exports.allTools = allTools;
|
|
27
27
|
var toolsArr = [(0, _line.tool)(), (0, _polygon.tool)()];
|
|
28
28
|
exports.toolsArr = toolsArr;
|
|
29
|
-
//# sourceMappingURL=
|
|
29
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/tools/index.js"],"names":["allTools","toolsArr"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAEA,IAAMA,QAAQ,GAAG,CAAC,MAAD,EAAS,SAAT,CAAjB;;AAEA,IAAMC,QAAQ,GAAG,CAAC,iBAAD,EAAS,oBAAT,CAAjB","sourcesContent":["import { tool as polygon } from './polygon';\nimport { tool as line } from './line';\n\nconst allTools = ['line', 'polygon'];\n\nconst toolsArr = [line(), polygon()];\n\nexport { allTools, toolsArr, line, polygon };\n"],"file":"index.js"}
|
|
@@ -103,4 +103,4 @@ var Line = (0, _line.lineBase)(StyledArrowedLine);
|
|
|
103
103
|
var Component = (0, _line.lineToolComponent)(Line);
|
|
104
104
|
var _default = Component;
|
|
105
105
|
exports["default"] = _default;
|
|
106
|
-
//# sourceMappingURL=
|
|
106
|
+
//# sourceMappingURL=component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/tools/line/component.jsx"],"names":["lineStyles","theme","line","styles","dashedLine","enabledArrow","arrow","disabledArrow","disabled","correct","correctArrow","incorrect","incorrectArrow","missing","missingArrow","ArrowedLine","props","markerId","className","classes","correctness","graphProps","fill","from","to","rest","scale","domain","range","trig","edges","eFrom","eTo","suffix","x","y","propTypes","PropTypes","string","object","bool","types","GraphPropsType","PointType","StyledArrowedLine","Line","Component"],"mappings":"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","sourcesContent":["import { lineToolComponent, lineBase, styles } from '../shared/line';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { trig, types } from '@pie-lib/plot';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport { ArrowMarker, genUid } from '../shared/arrow-head';\nimport { thinnerShapesNeeded, getAdjustedGraphLimits } from '../../utils';\n\nconst lineStyles = (theme) => ({\n line: styles.line(theme),\n dashedLine: styles.dashedLine(theme),\n enabledArrow: styles.arrow(theme),\n disabledArrow: styles.disabledArrow(theme),\n disabled: styles.disabled(theme),\n correct: styles.correct(theme, 'stroke'),\n correctArrow: styles.correct(theme),\n incorrect: styles.incorrect(theme, 'stroke'),\n incorrectArrow: styles.incorrect(theme),\n missing: styles.missing(theme, 'stroke'),\n missingArrow: styles.missing(theme),\n});\n\nexport const ArrowedLine = (props) => {\n const markerId = genUid();\n const { className, classes, correctness, disabled, graphProps, fill = 'Solid', from, to, ...rest } = props;\n const { scale } = graphProps;\n const { domain, range } = getAdjustedGraphLimits(graphProps);\n const [eFrom, eTo] = trig.edges(domain, range)(from, to);\n const suffix = correctness || (disabled && 'disabled') || 'enabled';\n\n return (\n <g>\n <defs>\n <ArrowMarker\n size={thinnerShapesNeeded(graphProps) ? 4 : 5}\n id={`${props.markerId || markerId}-${suffix}`}\n className={classNames(classes[`${suffix}Arrow`])}\n />\n </defs>\n <line\n x1={scale.x(eFrom.x)}\n y1={scale.y(eFrom.y)}\n x2={scale.x(eTo.x)}\n y2={scale.y(eTo.y)}\n className={classNames(\n fill === 'Solid' ? classes.line : classes.dashedLine,\n disabled && classes.disabled,\n classes[correctness],\n className,\n )}\n markerEnd={`url(#${props.markerId || markerId}-${suffix})`}\n markerStart={`url(#${props.markerId || markerId}-${suffix})`}\n {...rest}\n />\n </g>\n );\n};\n\nArrowedLine.propTypes = {\n className: PropTypes.string,\n classes: PropTypes.object,\n fill: PropTypes.string,\n correctness: PropTypes.string,\n disabled: PropTypes.bool,\n graphProps: types.GraphPropsType,\n from: types.PointType,\n to: types.PointType,\n markerId: PropTypes.string,\n};\n\nconst StyledArrowedLine = withStyles(lineStyles)(ArrowedLine);\n\nconst Line = lineBase(StyledArrowedLine);\nconst Component = lineToolComponent(Line);\n\nexport default Component;\n"],"file":"component.js"}
|
package/lib/tools/line/index.js
CHANGED
|
@@ -13,4 +13,4 @@ var _line = require("../shared/line");
|
|
|
13
13
|
|
|
14
14
|
var tool = (0, _line.lineTool)('line', _component["default"]);
|
|
15
15
|
exports.tool = tool;
|
|
16
|
-
//# sourceMappingURL=
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/tools/line/index.js"],"names":["tool","Line"],"mappings":";;;;;;;;;AAAA;;AACA;;AAEO,IAAMA,IAAI,GAAG,oBAAS,MAAT,EAAiBC,qBAAjB,CAAb","sourcesContent":["import Line from './component';\nimport { lineTool } from '../shared/line';\n\nexport const tool = lineTool('line', Line);\n"],"file":"index.js"}
|