chem-generic-ui 0.1.47 → 0.1.48

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.
Files changed (114) hide show
  1. package/dist/app.js +104 -0
  2. package/{src → dist}/asserts/main.css +7 -0
  3. package/{src → dist}/asserts/main.scss +7 -1
  4. package/dist/components/admin/ElementManager.js +54 -0
  5. package/dist/components/details/GenDSDetails.js +273 -0
  6. package/dist/components/details/GenSgDetails.js +566 -0
  7. package/{src → dist}/components/dnd/DragDropItemTypes.js +8 -1
  8. package/dist/components/dnd/GenericElDropTarget.js +274 -0
  9. package/dist/components/dnd/GridDnD.js +77 -0
  10. package/dist/components/dnd/PanelDnD.js +171 -0
  11. package/dist/components/fields/ButtonConfirm.js +76 -0
  12. package/dist/components/fields/ButtonTooltip.js +88 -0
  13. package/dist/components/fields/FieldLabel.js +38 -0
  14. package/dist/components/fields/GenDSMisType.js +44 -0
  15. package/dist/components/fields/GenFormGroupCb.js +31 -0
  16. package/dist/components/fields/GenProperties.js +83 -0
  17. package/dist/components/fields/GenPropertiesFields.js +616 -0
  18. package/dist/components/flow/FlowView.js +88 -0
  19. package/dist/components/flow/FlowViewerModal.js +83 -0
  20. package/dist/components/flow/LayerNode.js +59 -0
  21. package/dist/components/layers/GenPropertiesLayer.js +280 -0
  22. package/dist/components/layers/LayerModal.js +81 -0
  23. package/dist/components/layers/LayersLayout.js +88 -0
  24. package/dist/components/models/Attachment.js +73 -0
  25. package/dist/components/models/GenericSubField.js +37 -0
  26. package/dist/components/table/DropLinkRenderer.js +55 -0
  27. package/dist/components/table/DropRenderer.js +45 -0
  28. package/dist/components/table/DropTextRenderer.js +45 -0
  29. package/dist/components/table/GenericElTableDropTarget.js +252 -0
  30. package/dist/components/table/GridBtn.js +102 -0
  31. package/dist/components/table/GridEntry.js +163 -0
  32. package/dist/components/table/SamOption.js +87 -0
  33. package/dist/components/table/SelectRenderer.js +52 -0
  34. package/dist/components/table/TableRecord.js +454 -0
  35. package/dist/components/table/UConverterRenderer.js +41 -0
  36. package/dist/components/tools/collate.js +103 -0
  37. package/dist/components/tools/orten.js +294 -0
  38. package/dist/components/tools/utils.js +593 -0
  39. package/dist/data/SystemUnits.js +588 -0
  40. package/{src → dist}/data/systemUnits.json +0 -0
  41. package/{src → dist}/index.css +0 -0
  42. package/dist/index.js +38 -0
  43. package/{src → dist}/logo.svg +0 -0
  44. package/dist/simulations/SimWF.js +123 -0
  45. package/dist/simulations/SimuDS.js +118 -0
  46. package/dist/simulations/SimuSG.js +123 -0
  47. package/package.json +51 -43
  48. package/.babelrc +0 -11
  49. package/.eslintrc +0 -23
  50. package/.tool-versions +0 -3
  51. package/chem-generic-ui-v0.1.41.tgz +0 -0
  52. package/dist/bundle.js +0 -2
  53. package/dist/bundle.js.LICENSE.txt +0 -70
  54. package/dist/ds_details.json +0 -57
  55. package/dist/ds_klass.json +0 -102
  56. package/dist/ds_props.json +0 -54
  57. package/dist/index.html +0 -14
  58. package/dist/sg_details.json +0 -2036
  59. package/dist/sg_klass.json +0 -850
  60. package/dist/units_system.json +0 -430
  61. package/public/ds_details.json +0 -57
  62. package/public/ds_klass.json +0 -102
  63. package/public/ds_props.json +0 -54
  64. package/public/favicon.ico +0 -0
  65. package/public/images/not_available.svg +0 -1
  66. package/public/index.html +0 -47
  67. package/public/logo192.png +0 -0
  68. package/public/logo512.png +0 -0
  69. package/public/manifest.json +0 -25
  70. package/public/robots.txt +0 -3
  71. package/public/sg_details.json +0 -2036
  72. package/public/sg_klass.json +0 -850
  73. package/public/test/ds_props.json +0 -54
  74. package/public/units_system.json +0 -430
  75. package/src/app.js +0 -52
  76. package/src/asserts/bootstrap-theme.min.css +0 -6
  77. package/src/asserts/bootstrap.min.css +0 -6
  78. package/src/components/admin/ElementManager.js +0 -28
  79. package/src/components/details/GenDSDetails.js +0 -164
  80. package/src/components/details/GenSgDetails.js +0 -396
  81. package/src/components/dnd/GenericElDropTarget.js +0 -160
  82. package/src/components/dnd/GridDnD.js +0 -42
  83. package/src/components/dnd/PanelDnD.js +0 -85
  84. package/src/components/fields/ButtonConfirm.js +0 -45
  85. package/src/components/fields/ButtonTooltip.js +0 -46
  86. package/src/components/fields/FieldLabel.js +0 -18
  87. package/src/components/fields/GenDSMisType.js +0 -20
  88. package/src/components/fields/GenFormGroupCb.js +0 -17
  89. package/src/components/fields/GenProperties.js +0 -56
  90. package/src/components/fields/GenPropertiesFields.js +0 -440
  91. package/src/components/layers/GenPropertiesLayer.js +0 -178
  92. package/src/components/layers/LayerModal.js +0 -52
  93. package/src/components/layers/LayersLayout.js +0 -68
  94. package/src/components/models/Attachment.js +0 -37
  95. package/src/components/models/GenericSubField.js +0 -10
  96. package/src/components/table/DropLinkRenderer.js +0 -35
  97. package/src/components/table/DropRenderer.js +0 -31
  98. package/src/components/table/DropTextRenderer.js +0 -25
  99. package/src/components/table/GenericElTableDropTarget.js +0 -131
  100. package/src/components/table/GridBtn.js +0 -41
  101. package/src/components/table/GridEntry.js +0 -75
  102. package/src/components/table/SamOption.js +0 -53
  103. package/src/components/table/SelectRenderer.js +0 -34
  104. package/src/components/table/TableRecord.js +0 -254
  105. package/src/components/table/UConverterRenderer.js +0 -24
  106. package/src/components/tools/collate.js +0 -65
  107. package/src/components/tools/orten.js +0 -171
  108. package/src/components/tools/utils.js +0 -414
  109. package/src/data/SystemUnits.js +0 -434
  110. package/src/index.html +0 -1
  111. package/src/index.js +0 -45
  112. package/src/simulations/SimuDS.js +0 -52
  113. package/src/simulations/SimuSG.js +0 -54
  114. package/webpack.config.js +0 -46
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _lodash = require("lodash");
11
+
12
+ var _GenPropertiesLayer = _interopRequireDefault(require("./GenPropertiesLayer"));
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ var LayersLayout = function LayersLayout(layers, options, funcChange) {
17
+ var funcSubChange = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : function () {};
18
+ var funcClick = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : function () {};
19
+ var layout = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : [];
20
+ var id = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 0;
21
+ var isPreview = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : false;
22
+ var activeWF = arguments.length > 8 && arguments[8] !== undefined ? arguments[8] : false;
23
+ var sortedLayers = (0, _lodash.sortBy)(layers, ['position', 'wf_position']) || [];
24
+ sortedLayers.forEach(function (layer, idx) {
25
+ var uk = "".concat(layer.key, "_").concat(idx);
26
+
27
+ if (typeof layer.cond_fields === 'undefined' || layer.cond_fields == null || layer.cond_fields.length === 0) {
28
+ var ig = /*#__PURE__*/_react.default.createElement(_GenPropertiesLayer.default, {
29
+ id: id,
30
+ key: uk,
31
+ layer: layer,
32
+ onChange: funcChange,
33
+ onSubChange: funcSubChange,
34
+ selectOptions: options,
35
+ onClick: funcClick,
36
+ layers: layers,
37
+ isPreview: isPreview,
38
+ activeWF: activeWF
39
+ });
40
+
41
+ layout.push(ig);
42
+ } else if (layer.cond_fields && layer.cond_fields.length > 0) {
43
+ var showLayer = false;
44
+
45
+ var _loop = function _loop(i) {
46
+ var cond = layer.cond_fields[i] || {};
47
+ var fd = ((layers[cond.layer] || {}).fields || []).find(function (f) {
48
+ return f.field === cond.field;
49
+ }) || {};
50
+
51
+ if (fd.type === 'checkbox' && (['false', 'no', 'f', '0'].includes((cond.value || '').trim().toLowerCase()) && (typeof (fd && fd.value) === 'undefined' || fd.value === false) || ['true', 'yes', 't', '1'].includes((cond.value || '').trim().toLowerCase()) && typeof fd.value !== 'undefined' && fd.value === true)) {
52
+ showLayer = true;
53
+ return "break";
54
+ } else if (['text', 'select'].includes(fd.type) && typeof (fd && fd.value) !== 'undefined' && (fd.value || '').trim() === (cond.value || '').trim()) {
55
+ showLayer = true;
56
+ return "break";
57
+ }
58
+ };
59
+
60
+ for (var i = 0; i < layer.cond_fields.length; i += 1) {
61
+ var _ret = _loop(i);
62
+
63
+ if (_ret === "break") break;
64
+ }
65
+
66
+ if (showLayer === true) {
67
+ var igs = /*#__PURE__*/_react.default.createElement(_GenPropertiesLayer.default, {
68
+ id: id,
69
+ key: uk,
70
+ layer: layer,
71
+ onChange: funcChange,
72
+ onSubChange: funcSubChange,
73
+ selectOptions: options,
74
+ onClick: funcClick,
75
+ layers: layers,
76
+ isPreview: isPreview,
77
+ activeWF: activeWF
78
+ });
79
+
80
+ layout.push(igs);
81
+ }
82
+ }
83
+ });
84
+ return layout;
85
+ };
86
+
87
+ var _default = LayersLayout;
88
+ exports.default = _default;
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _uuid = require("uuid");
9
+
10
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
11
+
12
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
13
+
14
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
15
+
16
+ function _get() { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }
17
+
18
+ function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
19
+
20
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
21
+
22
+ var Attachment = /*#__PURE__*/function () {
23
+ function Attachment(args) {
24
+ _classCallCheck(this, Attachment);
25
+
26
+ Object.assign(this, args);
27
+
28
+ if (!this.id) {
29
+ this.id = Attachment.buildID();
30
+ }
31
+ }
32
+
33
+ _createClass(Attachment, [{
34
+ key: "isNew",
35
+ get: function get() {
36
+ return this.is_new === true;
37
+ }
38
+ }, {
39
+ key: "serialize",
40
+ value: function serialize() {
41
+ return _get(_getPrototypeOf(Attachment.prototype), "serialize", this).call(this, {
42
+ filename: this.filename,
43
+ identifier: this.identifier,
44
+ file: this.file,
45
+ thumb: this.thumb,
46
+ content_type: this.content_type,
47
+ is_deleted: this.is_deleted,
48
+ id: this.id,
49
+ is_new: this.isNew || false
50
+ });
51
+ }
52
+ }], [{
53
+ key: "buildID",
54
+ value: function buildID() {
55
+ return (0, _uuid.v4)();
56
+ }
57
+ }, {
58
+ key: "fromFile",
59
+ value: function fromFile(file) {
60
+ return new Attachment({
61
+ file: file,
62
+ name: file.name,
63
+ filename: file.name,
64
+ identifier: file.id,
65
+ is_deleted: false
66
+ });
67
+ }
68
+ }]);
69
+
70
+ return Attachment;
71
+ }();
72
+
73
+ exports.default = Attachment;
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _uuid = require("uuid");
9
+
10
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
11
+
12
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
13
+
14
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
15
+
16
+ var GenericSubField = /*#__PURE__*/function () {
17
+ function GenericSubField(args) {
18
+ _classCallCheck(this, GenericSubField);
19
+
20
+ Object.assign(this, args);
21
+
22
+ if (!this.id) {
23
+ this.id = GenericSubField.buildID();
24
+ }
25
+ }
26
+
27
+ _createClass(GenericSubField, null, [{
28
+ key: "buildID",
29
+ value: function buildID() {
30
+ return (0, _uuid.v4)();
31
+ }
32
+ }]);
33
+
34
+ return GenericSubField;
35
+ }();
36
+
37
+ exports.default = GenericSubField;
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _propTypes = _interopRequireDefault(require("prop-types"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ /* eslint-disable jsx-a11y/anchor-is-valid */
15
+
16
+ /* eslint-disable jsx-a11y/click-events-have-key-events */
17
+
18
+ /* eslint-disable jsx-a11y/interactive-supports-focus */
19
+
20
+ /* eslint-disable react/forbid-prop-types */
21
+ // import Aviator from 'aviator';
22
+ // import UIStore from '../stores/UIStore';
23
+ // const linkSample = (type, id) => {
24
+ // const { currentCollection, isSync } = UIStore.getState();
25
+ // const collectionUrl = (!isNaN(id)) ?
26
+ // `${currentCollection.id}/${type}/${id}` : `${currentCollection.id}/${type}`;
27
+ // Aviator.navigate(isSync ? `/scollection/${collectionUrl}` : `/collection/${collectionUrl}`);
28
+ // };
29
+ var DropLinkRenderer = function DropLinkRenderer(props) {
30
+ var sField = props.sField,
31
+ node = props.node,
32
+ onLink = props.onLink;
33
+ var dId = ((node.data[sField.id] || {}).value || {}).el_id || '';
34
+ var dVal = ((node.data[sField.id] || {}).value || {}).el_short_label || ' ';
35
+ if (dId === '') return /*#__PURE__*/_react.default.createElement("div", null);
36
+ return /*#__PURE__*/_react.default.createElement("a", {
37
+ role: "link",
38
+ onClick: function onClick() {
39
+ return onLink('sample', dId);
40
+ },
41
+ style: {
42
+ cursor: 'pointer'
43
+ }
44
+ }, /*#__PURE__*/_react.default.createElement("span", {
45
+ className: "reaction-material-link"
46
+ }, dVal));
47
+ };
48
+
49
+ DropLinkRenderer.propTypes = {
50
+ sField: _propTypes.default.object.isRequired,
51
+ node: _propTypes.default.object.isRequired,
52
+ onLink: _propTypes.default.func.isRequired
53
+ };
54
+ var _default = DropLinkRenderer;
55
+ exports.default = _default;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _propTypes = _interopRequireDefault(require("prop-types"));
11
+
12
+ var _lodash = require("lodash");
13
+
14
+ var _GenericElTableDropTarget = _interopRequireDefault(require("./GenericElTableDropTarget"));
15
+
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+
18
+ /* eslint-disable react/forbid-prop-types */
19
+ var DropRenderer = function DropRenderer(props) {
20
+ var opt = props.opt,
21
+ sField = props.sField,
22
+ onChange = props.onChange,
23
+ node = props.node;
24
+ if (!['drag_molecule', 'drag_sample'].includes(sField.type)) return null;
25
+ var data = node.data;
26
+ opt.dndItems = [sField.type.split('_')[1]];
27
+ opt.sField = sField;
28
+ opt.data = data;
29
+ var oopt = (0, _lodash.cloneDeep)(opt);
30
+ return /*#__PURE__*/_react.default.createElement("div", {
31
+ className: "drop_generic_properties drop_generic_table_wrap"
32
+ }, /*#__PURE__*/_react.default.createElement(_GenericElTableDropTarget.default, {
33
+ opt: oopt,
34
+ onDrop: onChange
35
+ }));
36
+ };
37
+
38
+ DropRenderer.propTypes = {
39
+ sField: _propTypes.default.object.isRequired,
40
+ opt: _propTypes.default.object.isRequired,
41
+ onChange: _propTypes.default.func.isRequired,
42
+ node: _propTypes.default.object.isRequired
43
+ };
44
+ var _default = DropRenderer;
45
+ exports.default = _default;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _propTypes = _interopRequireDefault(require("prop-types"));
11
+
12
+ var _reactBootstrap = require("react-bootstrap");
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
+
16
+ /* eslint-disable react/forbid-prop-types */
17
+ var DropTextRenderer = function DropTextRenderer(props) {
18
+ var attr = props.attr,
19
+ sField = props.sField,
20
+ node = props.node;
21
+ var displayValue = ((node.data[sField.id] || {}).value || {})["el_".concat(attr.value)] || '';
22
+ displayValue = attr.value === 'molecular_weight' && displayValue !== '' ? displayValue.toFixed(6) : displayValue;
23
+ return /*#__PURE__*/_react.default.createElement(_reactBootstrap.OverlayTrigger, {
24
+ placement: "top",
25
+ overlay: /*#__PURE__*/_react.default.createElement(_reactBootstrap.Tooltip, {
26
+ id: "copy_clipboard"
27
+ }, "copy to clipboard")
28
+ }, /*#__PURE__*/_react.default.createElement("div", {
29
+ role: "button",
30
+ "data-clipboard-text": displayValue,
31
+ className: "clipboardBtn",
32
+ style: {
33
+ wordBreak: 'break-all',
34
+ cursor: 'copy'
35
+ }
36
+ }, displayValue));
37
+ };
38
+
39
+ DropTextRenderer.propTypes = {
40
+ attr: _propTypes.default.object.isRequired,
41
+ sField: _propTypes.default.object.isRequired,
42
+ node: _propTypes.default.object.isRequired
43
+ };
44
+ var _default = DropTextRenderer;
45
+ exports.default = _default;
@@ -0,0 +1,252 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+
10
+ var _react = _interopRequireWildcard(require("react"));
11
+
12
+ var _propTypes = _interopRequireDefault(require("prop-types"));
13
+
14
+ var _uuid = require("uuid");
15
+
16
+ var _reactDnd = require("react-dnd");
17
+
18
+ var _reactBootstrap = require("react-bootstrap");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
+
22
+ 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); }
23
+
24
+ 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; }
25
+
26
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
27
+
28
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
29
+
30
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
31
+
32
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
33
+
34
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
35
+
36
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
37
+
38
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
39
+
40
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
41
+
42
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
43
+
44
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
45
+
46
+ var base = function base(opt, iconClass) {
47
+ var onDrop = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {};
48
+ var params = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
49
+ var noSvg = '/images/not_available.svg';
50
+
51
+ if (opt.value && opt.value.el_id) {
52
+ var label = opt.value.el_label;
53
+ var svg = opt.value.el_svg && opt.value.el_svg.endsWith('.svg') ? opt.value.el_svg : noSvg;
54
+
55
+ var pop = /*#__PURE__*/_react.default.createElement(_reactBootstrap.Popover, {
56
+ id: "popover-svg",
57
+ title: label,
58
+ style: {
59
+ maxWidth: 'none',
60
+ maxHeight: 'none'
61
+ }
62
+ }, /*#__PURE__*/_react.default.createElement("img", {
63
+ src: svg,
64
+ style: {
65
+ height: '26vh',
66
+ width: '26vh'
67
+ },
68
+ alt: ""
69
+ }));
70
+
71
+ var simg = function simg(path, txt) {
72
+ return path && path !== '' ? /*#__PURE__*/_react.default.createElement("div", {
73
+ className: "s-img"
74
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.OverlayTrigger, {
75
+ delayShow: 1000,
76
+ trigger: ['hover'],
77
+ placement: "top",
78
+ rootClose: true,
79
+ onHide: null,
80
+ overlay: pop
81
+ }, /*#__PURE__*/_react.default.createElement("img", {
82
+ className: "generic_grid_img",
83
+ src: path,
84
+ alt: ""
85
+ })), /*#__PURE__*/_react.default.createElement("div", {
86
+ className: "del_btn"
87
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.OverlayTrigger, {
88
+ delayShow: 1000,
89
+ placement: "top",
90
+ overlay: /*#__PURE__*/_react.default.createElement(_reactBootstrap.Tooltip, {
91
+ id: (0, _uuid.v4)()
92
+ }, "remove this molecule")
93
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Button, {
94
+ className: "btn_del",
95
+ bsSize: "xsmall",
96
+ onClick: function onClick() {
97
+ return onDrop({}, params);
98
+ }
99
+ }, /*#__PURE__*/_react.default.createElement("i", {
100
+ className: "fa fa-trash-o",
101
+ "aria-hidden": "true"
102
+ }))))) : /*#__PURE__*/_react.default.createElement("div", {
103
+ className: "data",
104
+ style: {
105
+ width: '4vw'
106
+ }
107
+ }, txt);
108
+ };
109
+
110
+ return simg(svg, label);
111
+ }
112
+
113
+ return /*#__PURE__*/_react.default.createElement("span", {
114
+ className: "icon-".concat(iconClass, " indicator"),
115
+ style: {
116
+ width: '4vw'
117
+ }
118
+ });
119
+ };
120
+
121
+ var show = function show(opt, iconClass, onDrop) {
122
+ if (opt.type === 'table') {
123
+ var sField = opt.sField || {};
124
+ var subVal = opt.data[sField.id];
125
+ var data = opt.data;
126
+ return base(subVal, iconClass, onDrop, {
127
+ sField: sField,
128
+ data: data
129
+ });
130
+ }
131
+
132
+ return base(opt, iconClass);
133
+ };
134
+
135
+ var source = function source(type, props, id) {
136
+ var isAssoc = false;
137
+ var taggable = props && props.tag && props.tag.taggable_data || {};
138
+
139
+ if (taggable.element && taggable.element.id === id) {
140
+ isAssoc = false;
141
+ } else {
142
+ isAssoc = !!(taggable.reaction_id || taggable.wellplate_id || taggable.element);
143
+ }
144
+
145
+ switch (type) {
146
+ case 'molecule':
147
+ return {
148
+ el_id: props.molecule.id,
149
+ el_type: 'molecule',
150
+ el_label: props.molecule.cano_smiles || props.molecule_formula || props.molecule_name_label,
151
+ el_inchikey: props.molecule.inchikey,
152
+ el_smiles: props.molecule.cano_smiles,
153
+ el_iupac: props.molecule.iupac_name,
154
+ el_molecular_weight: props.molecule.molecular_weight,
155
+ el_svg: "/images/molecules/".concat(props.molecule.molecule_svg_file)
156
+ };
157
+
158
+ case 'sample':
159
+ return {
160
+ el_id: props.id,
161
+ is_new: true,
162
+ cr_opt: 1,
163
+ isAssoc: isAssoc,
164
+ el_type: 'sample',
165
+ el_label: props.short_label,
166
+ el_short_label: props.short_label,
167
+ el_name: props.name,
168
+ el_external_label: props.external_label,
169
+ el_molecular_weight: props.molecule_molecular_weight,
170
+ el_svg: props.sample_svg_file ? "/images/samples/".concat(props.sample_svg_file) : "/images/molecules/".concat(props.molecule.molecule_svg_file)
171
+ };
172
+
173
+ default:
174
+ return {
175
+ el_id: props.id,
176
+ is_new: true,
177
+ cr_opt: 0,
178
+ el_type: props.type,
179
+ el_label: props.short_label
180
+ };
181
+ }
182
+ };
183
+
184
+ var dropTarget = {
185
+ drop: function drop(targetProps, monitor) {
186
+ var sourceProps = monitor.getItem().element;
187
+ var type = targetProps.opt.sField.type.split('_')[1];
188
+ var sourceTag = source(type, sourceProps, targetProps.opt.id);
189
+ targetProps.onDrop(sourceTag, targetProps.opt);
190
+ },
191
+ canDrop: function canDrop(targetProps, monitor) {
192
+ return true;
193
+ }
194
+ };
195
+
196
+ var dropCollect = function dropCollect(connect, monitor) {
197
+ return {
198
+ connectDropTarget: connect.dropTarget(),
199
+ isOver: monitor.isOver(),
200
+ canDrop: monitor.canDrop()
201
+ };
202
+ };
203
+
204
+ var GenericElTableDropTarget = /*#__PURE__*/function (_Component) {
205
+ _inherits(GenericElTableDropTarget, _Component);
206
+
207
+ var _super = _createSuper(GenericElTableDropTarget);
208
+
209
+ function GenericElTableDropTarget() {
210
+ _classCallCheck(this, GenericElTableDropTarget);
211
+
212
+ return _super.apply(this, arguments);
213
+ }
214
+
215
+ _createClass(GenericElTableDropTarget, [{
216
+ key: "render",
217
+ value: function render() {
218
+ var _this$props = this.props,
219
+ connectDropTarget = _this$props.connectDropTarget,
220
+ isOver = _this$props.isOver,
221
+ canDrop = _this$props.canDrop,
222
+ opt = _this$props.opt,
223
+ onDrop = _this$props.onDrop;
224
+ var className = "target".concat(isOver ? ' is-over' : '').concat(canDrop ? ' can-drop' : '');
225
+ return connectDropTarget( /*#__PURE__*/_react.default.createElement("div", {
226
+ className: className,
227
+ style: {
228
+ display: 'inline-flex',
229
+ justifyContent: 'center'
230
+ }
231
+ }, show(opt, 'sample', onDrop)));
232
+ }
233
+ }]);
234
+
235
+ return GenericElTableDropTarget;
236
+ }(_react.Component);
237
+
238
+ var _default = (0, _reactDnd.DropTarget)(function (props) {
239
+ return props.opt.dndItems;
240
+ }, dropTarget, dropCollect)(GenericElTableDropTarget);
241
+
242
+ exports.default = _default;
243
+ GenericElTableDropTarget.propTypes = {
244
+ connectDropTarget: _propTypes.default.func.isRequired,
245
+ isOver: _propTypes.default.bool.isRequired,
246
+ canDrop: _propTypes.default.bool.isRequired,
247
+ opt: _propTypes.default.object.isRequired,
248
+ onDrop: _propTypes.default.func
249
+ };
250
+ GenericElTableDropTarget.defaultProps = {
251
+ onDrop: function onDrop() {}
252
+ };