UNPKG

@r3l/app

Version:
127 lines (97 loc) 4.88 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = SettingsModalContainer; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _react = _interopRequireDefault(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _utils = require("../../../utils"); var _reactRedux = require("react-redux"); var _auth = require("../../auth/auth.actions"); var _settingsModal = _interopRequireDefault(require("./settingsModal.component")); var _alert = require("../../../utils/alert"); var _toggle = _interopRequireDefault(require("../settings/toggle.container")); var _login = _interopRequireDefault(require("../../auth/web/login.web3")); var _styled = require("../../styled"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } SettingsModalContainer.propTypes = { close: _propTypes.default.func }; function SettingsModalContainer(_ref) { var close = _ref.close; var dispatch = (0, _reactRedux.useDispatch)(); var user = (0, _reactRedux.useSelector)(function (state) { return state.auth.user; }); var submit = /*#__PURE__*/function () { var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(vals) { var allVals, imageUrl, resp; return _regenerator.default.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.prev = 0; allVals = _objectSpread({}, vals); if (!(allVals.image && allVals.image.preview && allVals.image.fileName)) { _context.next = 7; break; } _context.next = 5; return _utils.s3.uploadFile(allVals.image.preview, allVals.image.fileType); case 5: imageUrl = _context.sent; allVals.image = imageUrl; case 7: _context.next = 9; return dispatch((0, _auth.updateUser)(allVals)); case 9: resp = _context.sent; if (resp) close(); _context.next = 16; break; case 13: _context.prev = 13; _context.t0 = _context["catch"](0); _alert.browserAlerts.alert(_context.t0); case 16: case "end": return _context.stop(); } } }, _callee, null, [[0, 13]]); })); return function submit(_x) { return _ref2.apply(this, arguments); }; }(); return /*#__PURE__*/_react.default.createElement(_styled.View, null, /*#__PURE__*/_react.default.createElement(_settingsModal.default, { initialValues: user, enableReinitialize: true, onSubmit: submit }), /*#__PURE__*/_react.default.createElement(_styled.Box, { sx: { mt: 4 } }), /*#__PURE__*/_react.default.createElement(_styled.Header, null, "Connect Accounts"), /*#__PURE__*/_react.default.createElement(_styled.View, { sx: { my: 3, flexDirection: ['column', 'row'], alignItems: ['flex-start', 'center'] } }, /*#__PURE__*/_react.default.createElement(_login.default, { type: "metamask", text: 'Connect Ethereum Address' }), user.ethLogin ? /*#__PURE__*/_react.default.createElement(_styled.Text, null, "Connected address: ", /*#__PURE__*/_react.default.createElement(_styled.EthAddress, { address: user.ethLogin })) : /*#__PURE__*/_react.default.createElement(_styled.Text, { sx: { mt: [1, 0] } }, "Not connected")), /*#__PURE__*/_react.default.createElement(_toggle.default, null)); } //# sourceMappingURL=settingsModal.container.js.map