@r3l/app
Version:
127 lines (97 loc) • 4.88 kB
JavaScript
;
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