1819 lines
66 KiB
JavaScript
1819 lines
66 KiB
JavaScript
module.exports =
|
|
/******/ (function(modules) { // webpackBootstrap
|
|
/******/ // The module cache
|
|
/******/ var installedModules = {};
|
|
/******/
|
|
/******/ // object to store loaded chunks
|
|
/******/ // "0" means "already loaded"
|
|
/******/ var installedChunks = {
|
|
/******/ 2: 0
|
|
/******/ };
|
|
/******/
|
|
/******/ // The require function
|
|
/******/ function __webpack_require__(moduleId) {
|
|
/******/
|
|
/******/ // Check if module is in cache
|
|
/******/ if(installedModules[moduleId]) {
|
|
/******/ return installedModules[moduleId].exports;
|
|
/******/ }
|
|
/******/ // Create a new module (and put it into the cache)
|
|
/******/ var module = installedModules[moduleId] = {
|
|
/******/ i: moduleId,
|
|
/******/ l: false,
|
|
/******/ exports: {}
|
|
/******/ };
|
|
/******/
|
|
/******/ // Execute the module function
|
|
/******/ var threw = true;
|
|
/******/ try {
|
|
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|
/******/ threw = false;
|
|
/******/ } finally {
|
|
/******/ if(threw) delete installedModules[moduleId];
|
|
/******/ }
|
|
/******/
|
|
/******/ // Flag the module as loaded
|
|
/******/ module.l = true;
|
|
/******/
|
|
/******/ // Return the exports of the module
|
|
/******/ return module.exports;
|
|
/******/ }
|
|
/******/
|
|
/******/ // This file contains only the entry chunk.
|
|
/******/ // The chunk loading function for additional chunks
|
|
/******/ __webpack_require__.e = function requireEnsure(chunkId) {
|
|
/******/ // "0" is the signal for "already loaded"
|
|
/******/ if(installedChunks[chunkId] !== 0) {
|
|
/******/ var chunk = require("../../" + ({"0":"chunks/comps_CodeMirror_51c113b8f0eb112cf9be60e9d3293726"}[chunkId]||chunkId) + "-" + {"0":"ed8718ca2da55a768680"}[chunkId] + ".js");
|
|
/******/ var moreModules = chunk.modules, chunkIds = chunk.ids;
|
|
/******/ for(var moduleId in moreModules) {
|
|
/******/ modules[moduleId] = moreModules[moduleId];
|
|
/******/ }
|
|
/******/ for(var i = 0; i < chunkIds.length; i++)
|
|
/******/ installedChunks[chunkIds[i]] = 0;
|
|
/******/ }
|
|
/******/ return require('next/dynamic').SameLoopPromise.resolve();
|
|
/******/ };
|
|
/******/
|
|
/******/ // expose the modules object (__webpack_modules__)
|
|
/******/ __webpack_require__.m = modules;
|
|
/******/
|
|
/******/ // expose the module cache
|
|
/******/ __webpack_require__.c = installedModules;
|
|
/******/
|
|
/******/ // define getter function for harmony exports
|
|
/******/ __webpack_require__.d = function(exports, name, getter) {
|
|
/******/ if(!__webpack_require__.o(exports, name)) {
|
|
/******/ Object.defineProperty(exports, name, {
|
|
/******/ configurable: false,
|
|
/******/ enumerable: true,
|
|
/******/ get: getter
|
|
/******/ });
|
|
/******/ }
|
|
/******/ };
|
|
/******/
|
|
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
/******/ __webpack_require__.n = function(module) {
|
|
/******/ var getter = module && module.__esModule ?
|
|
/******/ function getDefault() { return module['default']; } :
|
|
/******/ function getModuleExports() { return module; };
|
|
/******/ __webpack_require__.d(getter, 'a', getter);
|
|
/******/ return getter;
|
|
/******/ };
|
|
/******/
|
|
/******/ // Object.prototype.hasOwnProperty.call
|
|
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
|
/******/
|
|
/******/ // __webpack_public_path__
|
|
/******/ __webpack_require__.p = "";
|
|
/******/
|
|
/******/ // uncatched error handler for webpack runtime
|
|
/******/ __webpack_require__.oe = function(err) {
|
|
/******/ process.nextTick(function() {
|
|
/******/ throw err; // catch this error by using System.import().catch()
|
|
/******/ });
|
|
/******/ };
|
|
/******/
|
|
/******/ // Load entry module and return exports
|
|
/******/ return __webpack_require__(__webpack_require__.s = 42);
|
|
/******/ })
|
|
/************************************************************************/
|
|
/******/ ([
|
|
/* 0 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("react");
|
|
|
|
/***/ }),
|
|
/* 1 */
|
|
/***/ (function(module, exports, __webpack_require__) {
|
|
|
|
var url = __webpack_require__(10);
|
|
|
|
var urljoin = __webpack_require__(11);
|
|
|
|
module.exports = function (path, absolute) {
|
|
var _ref = typeof window === 'undefined' ? app.get('kbConf') : window.kbConf,
|
|
pathPrefix = _ref.pathPrefix;
|
|
|
|
path = urljoin(pathPrefix, path);
|
|
if (!absolute) return path; // absolute should only be used during ssr
|
|
|
|
return url.format({
|
|
hostname: app.get('host'),
|
|
port: app.get('port'),
|
|
pathname: path,
|
|
protocol: 'http'
|
|
});
|
|
};
|
|
|
|
/***/ }),
|
|
/* 2 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return SET_USER; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return LOGIN_PENDING; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return LOGIN_FAILED; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return LOGOUT; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return setUser; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return doLogout; });
|
|
/* harmony export (immutable) */ __webpack_exports__["e"] = doLogin;
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator__ = __webpack_require__(5);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_isomorphic_unfetch__ = __webpack_require__(7);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_isomorphic_unfetch___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_isomorphic_unfetch__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__store__ = __webpack_require__(12);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__util_getUrl__ = __webpack_require__(1);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__util_getUrl___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__util_getUrl__);
|
|
|
|
|
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _next(value) { step("next", value); } function _throw(err) { step("throw", err); } _next(); }); }; }
|
|
|
|
|
|
|
|
// define action types
|
|
|
|
var SET_USER = 'SET_USER';
|
|
var LOGIN_PENDING = 'LOGIN_PENDING';
|
|
var LOGIN_FAILED = 'LOGIN_FAILED';
|
|
var LOGOUT = 'LOGOUT';
|
|
var setUser = function setUser(user) {
|
|
__WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: SET_USER,
|
|
data: user
|
|
});
|
|
}; // setUser
|
|
|
|
var doLogout = function doLogout() {
|
|
if (typeof window !== 'undefined') {
|
|
window.localStorage.removeItem('jwt');
|
|
document.cookie = 'jwt=; expires=Thu, 01 Jan 1970 00:00:01 GMT;path=/;';
|
|
}
|
|
|
|
__WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: LOGOUT
|
|
});
|
|
}; // doLogout
|
|
|
|
function doLogin(_x, _x2, _x3) {
|
|
return _doLogin.apply(this, arguments);
|
|
} // doLogin
|
|
|
|
function _doLogin() {
|
|
_doLogin = _asyncToGenerator(
|
|
/*#__PURE__*/
|
|
__WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default.a.mark(function _callee(creds, jwt, noPend) {
|
|
var authReqOpts, authReqHead, authReqBody, authReq, authRes, error, _ref, accessToken, payload, _JSON$parse, userId, userReq, userRes;
|
|
|
|
return __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default.a.wrap(function _callee$(_context) {
|
|
while (1) {
|
|
switch (_context.prev = _context.next) {
|
|
case 0:
|
|
!noPend && __WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: LOGIN_PENDING
|
|
});
|
|
authReqOpts = {
|
|
method: 'POST',
|
|
credentials: 'include'
|
|
};
|
|
authReqHead = {
|
|
headers: jwt ? {
|
|
Authorization: jwt
|
|
} : {
|
|
'Content-Type': 'application/json'
|
|
}
|
|
};
|
|
authReqBody = jwt ? null : {
|
|
body: JSON.stringify(_objectSpread({}, creds, {
|
|
strategy: 'local'
|
|
}))
|
|
};
|
|
authReq = new Request(__WEBPACK_IMPORTED_MODULE_3__util_getUrl___default()('auth'), _objectSpread({}, authReqOpts, authReqHead, authReqBody));
|
|
_context.next = 7;
|
|
return __WEBPACK_IMPORTED_MODULE_1_isomorphic_unfetch___default()(authReq).catch(function (err) {
|
|
__WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: LOGIN_FAILED,
|
|
data: err.message
|
|
});
|
|
});
|
|
|
|
case 7:
|
|
authRes = _context.sent;
|
|
|
|
if (authRes.ok) {
|
|
_context.next = 20;
|
|
break;
|
|
}
|
|
|
|
_context.prev = 9;
|
|
_context.next = 12;
|
|
return authRes.json();
|
|
|
|
case 12:
|
|
error = _context.sent;
|
|
error = error.message;
|
|
_context.next = 19;
|
|
break;
|
|
|
|
case 16:
|
|
_context.prev = 16;
|
|
_context.t0 = _context["catch"](9);
|
|
error = authRes.status === 429 ? 'Max login attempts reached' : 'An error occurred during login';
|
|
|
|
case 19:
|
|
return _context.abrupt("return", __WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: LOGIN_FAILED,
|
|
data: error
|
|
}));
|
|
|
|
case 20:
|
|
_context.next = 22;
|
|
return authRes.json();
|
|
|
|
case 22:
|
|
_ref = _context.sent;
|
|
accessToken = _ref.accessToken;
|
|
payload = accessToken.split('.')[1];
|
|
_JSON$parse = JSON.parse(atob(payload)), userId = _JSON$parse.userId;
|
|
userReq = new Request(__WEBPACK_IMPORTED_MODULE_3__util_getUrl___default()("/users/".concat(userId)), {
|
|
headers: {
|
|
Authorization: accessToken
|
|
}
|
|
});
|
|
_context.next = 29;
|
|
return __WEBPACK_IMPORTED_MODULE_1_isomorphic_unfetch___default()(userReq);
|
|
|
|
case 29:
|
|
userRes = _context.sent;
|
|
|
|
if (userRes.ok) {
|
|
_context.next = 32;
|
|
break;
|
|
}
|
|
|
|
return _context.abrupt("return", __WEBPACK_IMPORTED_MODULE_2__store__["a" /* default */].dispatch({
|
|
type: LOGIN_FAILED,
|
|
data: 'failed to get user'
|
|
}));
|
|
|
|
case 32:
|
|
window.localStorage.setItem('jwt', accessToken);
|
|
_context.t1 = setUser;
|
|
_context.next = 36;
|
|
return userRes.json();
|
|
|
|
case 36:
|
|
_context.t2 = _context.sent;
|
|
(0, _context.t1)(_context.t2);
|
|
|
|
case 38:
|
|
case "end":
|
|
return _context.stop();
|
|
}
|
|
}
|
|
}, _callee, this, [[9, 16]]);
|
|
}));
|
|
return _doLogin.apply(this, arguments);
|
|
}
|
|
|
|
/***/ }),
|
|
/* 3 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("react-redux");
|
|
|
|
/***/ }),
|
|
/* 4 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony default export */ __webpack_exports__["a"] = (function (_ref) {
|
|
var user = _ref.user;
|
|
return {
|
|
user: user
|
|
};
|
|
});
|
|
|
|
/***/ }),
|
|
/* 5 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("@babel/runtime/regenerator");
|
|
|
|
/***/ }),
|
|
/* 6 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("next/router");
|
|
|
|
/***/ }),
|
|
/* 7 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("isomorphic-unfetch");
|
|
|
|
/***/ }),
|
|
/* 8 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(0);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);
|
|
|
|
|
|
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
|
|
var Spinner = function Spinner(props) {
|
|
return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement("div", _extends({
|
|
className: "spinner"
|
|
}, props));
|
|
};
|
|
|
|
/* harmony default export */ __webpack_exports__["a"] = (Spinner);
|
|
|
|
/***/ }),
|
|
/* 9 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(0);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);
|
|
|
|
|
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
var PaddedRow = function PaddedRow(_ref) {
|
|
var children = _ref.children,
|
|
amount = _ref.amount,
|
|
vCenter = _ref.vCenter;
|
|
amount = amount || 20;
|
|
|
|
var PadItem = function PadItem() {
|
|
return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement("div", {
|
|
className: 'column column-' + amount + ' nomob'
|
|
});
|
|
};
|
|
|
|
var rowProps = {
|
|
className: 'row'
|
|
};
|
|
if (vCenter) rowProps = {
|
|
className: 'row v-center'
|
|
};else rowProps = _objectSpread({}, rowProps, {
|
|
style: {
|
|
paddingTop: amount
|
|
}
|
|
});
|
|
return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement("div", rowProps, __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(PadItem, null), __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement("div", {
|
|
className: "column"
|
|
}, children), __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(PadItem, null));
|
|
};
|
|
|
|
/* harmony default export */ __webpack_exports__["a"] = (PaddedRow);
|
|
|
|
/***/ }),
|
|
/* 10 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("url");
|
|
|
|
/***/ }),
|
|
/* 11 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("url-join");
|
|
|
|
/***/ }),
|
|
/* 12 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
|
|
// EXTERNAL MODULE: external "redux"
|
|
var external__redux_ = __webpack_require__(15);
|
|
var external__redux__default = /*#__PURE__*/__webpack_require__.n(external__redux_);
|
|
|
|
// EXTERNAL MODULE: ./redux/actions/userAct.js
|
|
var userAct = __webpack_require__(2);
|
|
|
|
// CONCATENATED MODULE: ./redux/reducers/userRed.js
|
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
|
|
var initState = {
|
|
setup: false,
|
|
_id: null,
|
|
email: null,
|
|
admin: null,
|
|
pending: false,
|
|
error: null
|
|
};
|
|
|
|
function user() {
|
|
var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initState;
|
|
var action = arguments.length > 1 ? arguments[1] : undefined;
|
|
|
|
switch (action.type) {
|
|
case userAct["d" /* SET_USER */]:
|
|
{
|
|
return _objectSpread({}, initState, action.data);
|
|
}
|
|
|
|
case userAct["b" /* LOGIN_PENDING */]:
|
|
{
|
|
return _objectSpread({}, initState, {
|
|
pending: true
|
|
});
|
|
}
|
|
|
|
case userAct["a" /* LOGIN_FAILED */]:
|
|
{
|
|
return _objectSpread({}, state, {
|
|
pending: false,
|
|
error: action.data
|
|
});
|
|
}
|
|
|
|
case userAct["c" /* LOGOUT */]:
|
|
{
|
|
return initState;
|
|
}
|
|
|
|
default:
|
|
return state;
|
|
}
|
|
}
|
|
|
|
/* harmony default export */ var userRed = (user);
|
|
// CONCATENATED MODULE: ./redux/store.js
|
|
|
|
|
|
var middleware;
|
|
|
|
if (false) {
|
|
var logger = require('redux-logger').default;
|
|
|
|
if (typeof window !== 'undefined') {
|
|
middleware = applyMiddleware(logger);
|
|
}
|
|
}
|
|
|
|
var reducers = Object(external__redux_["combineReducers"])({
|
|
user: userRed
|
|
});
|
|
/* harmony default export */ var store = __webpack_exports__["a"] = (middleware ? Object(external__redux_["createStore"])(reducers, middleware) : Object(external__redux_["createStore"])(reducers));
|
|
|
|
/***/ }),
|
|
/* 13 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("next/dynamic");
|
|
|
|
/***/ }),
|
|
/* 14 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony default export */ __webpack_exports__["a"] = (function (req) {
|
|
if (req) return req.jwt;
|
|
|
|
if (typeof window !== 'undefined') {
|
|
return window.localStorage.getItem('jwt');
|
|
}
|
|
});
|
|
|
|
/***/ }),
|
|
/* 15 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("redux");
|
|
|
|
/***/ }),
|
|
/* 16 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("next/link");
|
|
|
|
/***/ }),
|
|
/* 17 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
|
|
// EXTERNAL MODULE: external "react"
|
|
var external__react_ = __webpack_require__(0);
|
|
var external__react__default = /*#__PURE__*/__webpack_require__.n(external__react_);
|
|
|
|
// EXTERNAL MODULE: external "react-redux"
|
|
var external__react_redux_ = __webpack_require__(3);
|
|
var external__react_redux__default = /*#__PURE__*/__webpack_require__.n(external__react_redux_);
|
|
|
|
// EXTERNAL MODULE: external "next/router"
|
|
var router_ = __webpack_require__(6);
|
|
var router__default = /*#__PURE__*/__webpack_require__.n(router_);
|
|
|
|
// EXTERNAL MODULE: ./redux/actions/userAct.js
|
|
var userAct = __webpack_require__(2);
|
|
|
|
// EXTERNAL MODULE: external "next/link"
|
|
var link_ = __webpack_require__(16);
|
|
var link__default = /*#__PURE__*/__webpack_require__.n(link_);
|
|
|
|
// EXTERNAL MODULE: ./util/getUrl.js
|
|
var getUrl = __webpack_require__(1);
|
|
var getUrl_default = /*#__PURE__*/__webpack_require__.n(getUrl);
|
|
|
|
// EXTERNAL MODULE: ./util/mapUser.js
|
|
var mapUser = __webpack_require__(4);
|
|
|
|
// CONCATENATED MODULE: ./comps/Header.js
|
|
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
|
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
|
|
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); } }
|
|
|
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
|
|
|
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
|
|
|
|
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, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
|
|
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var Header_NavLink = function NavLink(_ref) {
|
|
var children = _ref.children,
|
|
href = _ref.href,
|
|
active = _ref.active;
|
|
var activeClass = active ? ' active' : '';
|
|
return external__react__default.a.createElement(link__default.a, {
|
|
href: href,
|
|
as: getUrl_default()(href)
|
|
}, external__react__default.a.createElement("a", {
|
|
className: activeClass
|
|
}, children));
|
|
};
|
|
|
|
var navItems = [['/', 'Home'], ['/new', 'New Doc'], ['/settings', 'Settings']];
|
|
|
|
var Header_Header =
|
|
/*#__PURE__*/
|
|
function (_Component) {
|
|
_inherits(Header, _Component);
|
|
|
|
function Header() {
|
|
var _ref2;
|
|
|
|
var _temp, _this;
|
|
|
|
_classCallCheck(this, Header);
|
|
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
return _possibleConstructorReturn(_this, (_temp = _this = _possibleConstructorReturn(this, (_ref2 = Header.__proto__ || Object.getPrototypeOf(Header)).call.apply(_ref2, [this].concat(args))), Object.defineProperty(_assertThisInitialized(_this), "state", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: {
|
|
open: false
|
|
}
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "hideNav", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value() {
|
|
return _this.setState({
|
|
open: false
|
|
});
|
|
}
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "toggleNav", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value() {
|
|
return _this.setState({
|
|
open: !_this.state.open
|
|
});
|
|
}
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "isActive", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(url) {
|
|
return getUrl_default()(_this.props.router.pathname) === getUrl_default()(url);
|
|
}
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "logout", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
e.preventDefault();
|
|
|
|
_this.hideNav();
|
|
|
|
Object(userAct["f" /* doLogout */])();
|
|
}
|
|
}), _temp));
|
|
}
|
|
|
|
_createClass(Header, [{
|
|
key: "render",
|
|
value: function render() {
|
|
var _this2 = this;
|
|
|
|
var expandClass = this.state.open ? ' active' : '';
|
|
var user = this.props.user;
|
|
return external__react__default.a.createElement("nav", {
|
|
className: "navbar",
|
|
role: "navigation",
|
|
"aria-label": "main navigation"
|
|
}, external__react__default.a.createElement("div", {
|
|
className: "navbar-brand"
|
|
}, external__react__default.a.createElement(Header_NavLink, {
|
|
href: "/"
|
|
}, external__react__default.a.createElement("h3", {
|
|
onClick: this.hideNav
|
|
}, "MYKB"))), !user.email ? null : [external__react__default.a.createElement("div", {
|
|
className: 'navbar-burger ' + expandClass,
|
|
onClick: this.toggleNav,
|
|
key: "burger"
|
|
}, external__react__default.a.createElement("div", null), external__react__default.a.createElement("div", null), external__react__default.a.createElement("div", null)), external__react__default.a.createElement("div", {
|
|
className: 'navbar-items' + expandClass,
|
|
key: "items"
|
|
}, navItems.map(function (item) {
|
|
return external__react__default.a.createElement(Header_NavLink, {
|
|
key: item[0],
|
|
href: item[0],
|
|
active: _this2.isActive(item[0])
|
|
}, external__react__default.a.createElement("p", {
|
|
className: "item",
|
|
onClick: _this2.hideNav
|
|
}, item[1]));
|
|
}), external__react__default.a.createElement("a", {
|
|
href: "/logout",
|
|
onClick: this.logout
|
|
}, external__react__default.a.createElement("p", {
|
|
className: "item"
|
|
}, "Logout")))]);
|
|
}
|
|
}]);
|
|
|
|
return Header;
|
|
}(external__react_["Component"]);
|
|
|
|
/* harmony default export */ var comps_Header = (Object(router_["withRouter"])(Object(external__react_redux_["connect"])(mapUser["a" /* default */])(Header_Header)));
|
|
// EXTERNAL MODULE: ./util/keys.js
|
|
var keys = __webpack_require__(18);
|
|
var keys_default = /*#__PURE__*/__webpack_require__.n(keys);
|
|
|
|
// CONCATENATED MODULE: ./comps/KeyShortcuts.js
|
|
function KeyShortcuts__typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { KeyShortcuts__typeof = function _typeof(obj) { return typeof obj; }; } else { KeyShortcuts__typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return KeyShortcuts__typeof(obj); }
|
|
|
|
function KeyShortcuts__classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
|
|
function KeyShortcuts__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); } }
|
|
|
|
function KeyShortcuts__createClass(Constructor, protoProps, staticProps) { if (protoProps) KeyShortcuts__defineProperties(Constructor.prototype, protoProps); if (staticProps) KeyShortcuts__defineProperties(Constructor, staticProps); return Constructor; }
|
|
|
|
function KeyShortcuts__possibleConstructorReturn(self, call) { if (call && (KeyShortcuts__typeof(call) === "object" || typeof call === "function")) { return call; } return KeyShortcuts__assertThisInitialized(self); }
|
|
|
|
function KeyShortcuts__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, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
|
|
function KeyShortcuts__assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* - keyboard shortcuts
|
|
g then h -> navigate home
|
|
g then n -> navigate to new doc
|
|
g then s -> navigate to settings
|
|
g then l -> logout
|
|
e (when on doc page) -> edit doc
|
|
/ (when on home page) -> focus search
|
|
ctrl/cmd + enter -> submit new doc (handled in CodeMirror component)
|
|
*/
|
|
|
|
var keyToUrl = {
|
|
72: '/',
|
|
78: '/new',
|
|
83: '/settings'
|
|
};
|
|
var keyToEl = {
|
|
69: {
|
|
sel: '#edit',
|
|
func: 'click'
|
|
},
|
|
191: {
|
|
sel: '.search',
|
|
func: 'focus'
|
|
}
|
|
};
|
|
|
|
var KeyShortcuts_KeyShortcuts =
|
|
/*#__PURE__*/
|
|
function (_Component) {
|
|
KeyShortcuts__inherits(KeyShortcuts, _Component);
|
|
|
|
function KeyShortcuts() {
|
|
var _ref;
|
|
|
|
var _temp, _this;
|
|
|
|
KeyShortcuts__classCallCheck(this, KeyShortcuts);
|
|
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
return KeyShortcuts__possibleConstructorReturn(_this, (_temp = _this = KeyShortcuts__possibleConstructorReturn(this, (_ref = KeyShortcuts.__proto__ || Object.getPrototypeOf(KeyShortcuts)).call.apply(_ref, [this].concat(args))), Object.defineProperty(KeyShortcuts__assertThisInitialized(_this), "handleDown", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
var tag = e.target.tagName;
|
|
if (tag === 'INPUT' || tag === 'TEXTAREA') return;
|
|
var key = Object(keys["getKey"])(e);
|
|
|
|
if (_this.prevKey === 71) {
|
|
// prev key was g
|
|
switch (key) {
|
|
case 72:
|
|
case 78:
|
|
case 83:
|
|
{
|
|
var url = keyToUrl[key];
|
|
router__default.a.push(url, getUrl_default()(url));
|
|
break;
|
|
}
|
|
|
|
case 76:
|
|
{
|
|
setTimeout(userAct["f" /* doLogout */], 1);
|
|
break;
|
|
}
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
switch (key) {
|
|
case 69:
|
|
case 191:
|
|
{
|
|
var _keyToEl$key = keyToEl[key],
|
|
sel = _keyToEl$key.sel,
|
|
func = _keyToEl$key.func;
|
|
var el = document.querySelector(sel);
|
|
if (el) setTimeout(function () {
|
|
return el[func]();
|
|
}, 1);
|
|
break;
|
|
}
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
_this.prevKey = key;
|
|
}
|
|
}), Object.defineProperty(KeyShortcuts__assertThisInitialized(_this), "render", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value() {
|
|
return null;
|
|
}
|
|
}), _temp));
|
|
}
|
|
|
|
KeyShortcuts__createClass(KeyShortcuts, [{
|
|
key: "componentDidMount",
|
|
value: function componentDidMount() {
|
|
window.addEventListener('keydown', this.handleDown);
|
|
}
|
|
}, {
|
|
key: "componentWillUnmount",
|
|
value: function componentWillUnmount() {
|
|
window.removeEventListener('keydown', this.handleDown);
|
|
}
|
|
}]);
|
|
|
|
return KeyShortcuts;
|
|
}(external__react_["Component"]);
|
|
|
|
/* harmony default export */ var comps_KeyShortcuts = (KeyShortcuts_KeyShortcuts);
|
|
// CONCATENATED MODULE: ./comps/Footer.js
|
|
|
|
|
|
var Footer_Footer = function Footer() {
|
|
return external__react__default.a.createElement("footer", {
|
|
className: "footer"
|
|
}, external__react__default.a.createElement("p", null, "Powered by", ' ', external__react__default.a.createElement("a", {
|
|
href: "//github.com/ijjk/mykb",
|
|
target: "_blank",
|
|
rel: "noopener noreferrer"
|
|
}, "MYKB")));
|
|
};
|
|
|
|
/* harmony default export */ var comps_Footer = (Footer_Footer);
|
|
// EXTERNAL MODULE: ./comps/Spinner.js
|
|
var Spinner = __webpack_require__(8);
|
|
|
|
// EXTERNAL MODULE: ./comps/PaddedRow.js
|
|
var PaddedRow = __webpack_require__(9);
|
|
|
|
// CONCATENATED MODULE: ./comps/Login.js
|
|
function Login__typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { Login__typeof = function _typeof(obj) { return typeof obj; }; } else { Login__typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return Login__typeof(obj); }
|
|
|
|
function Login__classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
|
|
function Login__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); } }
|
|
|
|
function Login__createClass(Constructor, protoProps, staticProps) { if (protoProps) Login__defineProperties(Constructor.prototype, protoProps); if (staticProps) Login__defineProperties(Constructor, staticProps); return Constructor; }
|
|
|
|
function Login__possibleConstructorReturn(self, call) { if (call && (Login__typeof(call) === "object" || typeof call === "function")) { return call; } return Login__assertThisInitialized(self); }
|
|
|
|
function Login__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, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
|
|
function Login__assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var Login_Login =
|
|
/*#__PURE__*/
|
|
function (_Component) {
|
|
Login__inherits(Login, _Component);
|
|
|
|
function Login() {
|
|
var _ref;
|
|
|
|
var _temp, _this;
|
|
|
|
Login__classCallCheck(this, Login);
|
|
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
return Login__possibleConstructorReturn(_this, (_temp = _this = Login__possibleConstructorReturn(this, (_ref = Login.__proto__ || Object.getPrototypeOf(Login)).call.apply(_ref, [this].concat(args))), Object.defineProperty(Login__assertThisInitialized(_this), "state", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: {
|
|
email: '',
|
|
pass: ''
|
|
}
|
|
}), Object.defineProperty(Login__assertThisInitialized(_this), "updVal", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
var el = e.target;
|
|
var val = el.value;
|
|
|
|
if (el.getAttribute('type') === 'email') {
|
|
return _this.setState({
|
|
email: val
|
|
});
|
|
}
|
|
|
|
_this.setState({
|
|
pass: val
|
|
});
|
|
}
|
|
}), Object.defineProperty(Login__assertThisInitialized(_this), "submit", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
var pending = _this.props.user.pending;
|
|
var _this$state = _this.state,
|
|
email = _this$state.email,
|
|
pass = _this$state.pass;
|
|
email = email.trim();
|
|
pass = pass.trim();
|
|
e.preventDefault();
|
|
|
|
if (pending || email.length === 0 || pass.length == 0) {
|
|
return;
|
|
}
|
|
|
|
Object(userAct["e" /* doLogin */])({
|
|
email: email,
|
|
password: pass
|
|
});
|
|
}
|
|
}), _temp));
|
|
}
|
|
|
|
Login__createClass(Login, [{
|
|
key: "render",
|
|
value: function render() {
|
|
var _props$user = this.props.user,
|
|
pending = _props$user.pending,
|
|
error = _props$user.error;
|
|
return external__react__default.a.createElement("div", {
|
|
className: "container content"
|
|
}, external__react__default.a.createElement(PaddedRow["a" /* default */], {
|
|
amount: 25,
|
|
vCenter: true
|
|
}, external__react__default.a.createElement("h4", null, "Please login to continue"), external__react__default.a.createElement("form", {
|
|
noValidate: true
|
|
}, external__react__default.a.createElement("fieldset", null, external__react__default.a.createElement("label", {
|
|
htmlFor: "email"
|
|
}, "Email:"), external__react__default.a.createElement("input", {
|
|
type: "email",
|
|
id: "email",
|
|
name: "email",
|
|
autoFocus: true,
|
|
placeholder: "John@deux.com",
|
|
onChange: this.updVal
|
|
}), external__react__default.a.createElement("label", {
|
|
htmlFor: "pass"
|
|
}, "Pass:"), external__react__default.a.createElement("input", {
|
|
type: "password",
|
|
id: "pass",
|
|
name: "password",
|
|
placeholder: "Super secret password...",
|
|
onChange: this.updVal
|
|
})), external__react__default.a.createElement("button", {
|
|
className: 'float-right' + (pending ? ' disabled' : ''),
|
|
onClick: this.submit
|
|
}, pending ? external__react__default.a.createElement(Spinner["a" /* default */], null) : 'Submit'), !error ? null : external__react__default.a.createElement("p", null, error))));
|
|
}
|
|
}]);
|
|
|
|
return Login;
|
|
}(external__react_["Component"]);
|
|
|
|
/* harmony default export */ var comps_Login = (Object(external__react_redux_["connect"])(mapUser["a" /* default */])(Login_Login));
|
|
// CONCATENATED MODULE: ./comps/Setup.js
|
|
function Setup__typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { Setup__typeof = function _typeof(obj) { return typeof obj; }; } else { Setup__typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return Setup__typeof(obj); }
|
|
|
|
function Setup__classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
|
|
function Setup__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); } }
|
|
|
|
function Setup__createClass(Constructor, protoProps, staticProps) { if (protoProps) Setup__defineProperties(Constructor.prototype, protoProps); if (staticProps) Setup__defineProperties(Constructor, staticProps); return Constructor; }
|
|
|
|
function Setup__possibleConstructorReturn(self, call) { if (call && (Setup__typeof(call) === "object" || typeof call === "function")) { return call; } return Setup__assertThisInitialized(self); }
|
|
|
|
function Setup__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, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
|
|
function Setup__assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var Setup_Setup =
|
|
/*#__PURE__*/
|
|
function (_Component) {
|
|
Setup__inherits(Setup, _Component);
|
|
|
|
function Setup() {
|
|
var _ref;
|
|
|
|
var _temp, _this;
|
|
|
|
Setup__classCallCheck(this, Setup);
|
|
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
return Setup__possibleConstructorReturn(_this, (_temp = _this = Setup__possibleConstructorReturn(this, (_ref = Setup.__proto__ || Object.getPrototypeOf(Setup)).call.apply(_ref, [this].concat(args))), Object.defineProperty(Setup__assertThisInitialized(_this), "state", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: {
|
|
email: '',
|
|
password: '',
|
|
confirmPass: '',
|
|
pending: false,
|
|
error: null
|
|
}
|
|
}), Object.defineProperty(Setup__assertThisInitialized(_this), "updVal", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
var el = e.target;
|
|
var key = 'email';
|
|
if (el.id === 'pass') key = 'password';else if (el.id === 'pass2') key = 'confirmPass';
|
|
var obj = {};
|
|
obj[key] = el.value;
|
|
|
|
_this.setState(obj);
|
|
}
|
|
}), Object.defineProperty(Setup__assertThisInitialized(_this), "submit", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(e) {
|
|
e.preventDefault();
|
|
var _this$state = _this.state,
|
|
email = _this$state.email,
|
|
password = _this$state.password,
|
|
confirmPass = _this$state.confirmPass,
|
|
pending = _this$state.pending;
|
|
if (pending) return;
|
|
email = email.trim();
|
|
password = password.trim();
|
|
confirmPass = confirmPass.trim();
|
|
var hasEmpty = [email, password, confirmPass].some(function (val) {
|
|
return val.length === 0;
|
|
});
|
|
if (hasEmpty) return;
|
|
|
|
if (password.toLowerCase() !== confirmPass.toLowerCase()) {
|
|
return _this.setState({
|
|
error: "Passwords don't match"
|
|
});
|
|
}
|
|
|
|
_this.setState({
|
|
pending: true,
|
|
error: null
|
|
});
|
|
|
|
var defaultErr = 'Could not create account';
|
|
fetch(getUrl_default()('users'), {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json'
|
|
},
|
|
body: JSON.stringify({
|
|
email: email,
|
|
password: password,
|
|
admin: true
|
|
})
|
|
}).then(function (res) {
|
|
if (res.ok) {
|
|
return Object(userAct["e" /* doLogin */])({
|
|
email: email,
|
|
password: password
|
|
}, null, true);
|
|
}
|
|
|
|
res.json().then(function (_ref2) {
|
|
var message = _ref2.message;
|
|
var error = message || defaultErr;
|
|
|
|
_this.setState({
|
|
pending: false,
|
|
error: error
|
|
});
|
|
});
|
|
}).catch(function (err) {
|
|
var error = err.message || defaultErr;
|
|
|
|
_this.setState({
|
|
pending: false,
|
|
error: error
|
|
});
|
|
});
|
|
}
|
|
}), _temp));
|
|
}
|
|
|
|
Setup__createClass(Setup, [{
|
|
key: "render",
|
|
value: function render() {
|
|
var _state = this.state,
|
|
pending = _state.pending,
|
|
error = _state.error;
|
|
return external__react__default.a.createElement("div", {
|
|
className: "container content"
|
|
}, external__react__default.a.createElement(PaddedRow["a" /* default */], {
|
|
amount: 25,
|
|
vCenter: true
|
|
}, external__react__default.a.createElement("div", {
|
|
className: "column"
|
|
}, external__react__default.a.createElement("h3", null, "Setup account"), external__react__default.a.createElement("form", {
|
|
noValidate: true
|
|
}, external__react__default.a.createElement("fieldset", null, external__react__default.a.createElement("label", {
|
|
htmlFor: "email"
|
|
}, "Email:"), external__react__default.a.createElement("input", {
|
|
type: "email",
|
|
autoFocus: true,
|
|
id: "email",
|
|
placeholder: "Your email (does't have to be actual email)",
|
|
onChange: this.updVal
|
|
}), external__react__default.a.createElement("label", {
|
|
htmlFor: "pass"
|
|
}, "Password:"), external__react__default.a.createElement("input", {
|
|
type: "password",
|
|
id: "pass",
|
|
maxLength: 512,
|
|
placeholder: "A super secret password",
|
|
onChange: this.updVal
|
|
}), external__react__default.a.createElement("label", {
|
|
htmlFor: "pass2"
|
|
}, "Confirm Password:"), external__react__default.a.createElement("input", {
|
|
type: "password",
|
|
id: "pass2",
|
|
maxLength: 512,
|
|
placeholder: "Confirm your super secret password",
|
|
onChange: this.updVal
|
|
}), external__react__default.a.createElement("button", {
|
|
className: "float-right",
|
|
onClick: this.submit
|
|
}, pending ? external__react__default.a.createElement(Spinner["a" /* default */], null) : 'Submit'), !error ? null : external__react__default.a.createElement("p", {
|
|
className: "danger"
|
|
}, error))))));
|
|
}
|
|
}]);
|
|
|
|
return Setup;
|
|
}(external__react_["Component"]);
|
|
|
|
|
|
// CONCATENATED MODULE: ./comps/Page.js
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var Page_Page = function Page(_ref) {
|
|
var user = _ref.user,
|
|
children = _ref.children;
|
|
return external__react__default.a.createElement("div", null, external__react__default.a.createElement(comps_Header, null), external__react__default.a.createElement(comps_KeyShortcuts, null), user.email ? external__react__default.a.createElement("div", {
|
|
className: "container content"
|
|
}, children) : user.setup ? external__react__default.a.createElement(Setup_Setup, null) : external__react__default.a.createElement(comps_Login, {
|
|
user: user
|
|
}), external__react__default.a.createElement(comps_Footer, null));
|
|
};
|
|
|
|
/* harmony default export */ var comps_Page = __webpack_exports__["a"] = (Object(external__react_redux_["connect"])(mapUser["a" /* default */])(Page_Page));
|
|
|
|
/***/ }),
|
|
/* 18 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = {
|
|
getKey: function getKey(e) {
|
|
return e.which || e.keyCode;
|
|
},
|
|
isCtrlKey: function isCtrlKey(key) {
|
|
return key === 91 || key === 93 || key === 17;
|
|
}
|
|
};
|
|
|
|
/***/ }),
|
|
/* 19 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
|
|
// EXTERNAL MODULE: external "react"
|
|
var external__react_ = __webpack_require__(0);
|
|
var external__react__default = /*#__PURE__*/__webpack_require__.n(external__react_);
|
|
|
|
// EXTERNAL MODULE: external "next/dynamic"
|
|
var dynamic_ = __webpack_require__(13);
|
|
var dynamic__default = /*#__PURE__*/__webpack_require__.n(dynamic_);
|
|
|
|
// CONCATENATED MODULE: ./util/freezeSSR.js
|
|
|
|
|
|
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
|
|
var freezeSSR_freezeSSR = function freezeSSR(selector) {
|
|
var FrozenSSR = function FrozenSSR() {
|
|
var __html = '';
|
|
var props = {};
|
|
|
|
if (typeof document !== 'undefined') {
|
|
var el = document.querySelector(selector);
|
|
|
|
if (el) {
|
|
__html = el.innerHTML;
|
|
el.getAttributeNames().forEach(function (attr) {
|
|
var attrKey = attr === 'class' ? 'className' : attr;
|
|
props[attrKey] = el.getAttribute(attr);
|
|
});
|
|
}
|
|
}
|
|
|
|
return external__react__default.a.createElement("div", _extends({}, props, {
|
|
dangerouslySetInnerHTML: {
|
|
__html: __html
|
|
}
|
|
}));
|
|
};
|
|
|
|
return {
|
|
loading: FrozenSSR
|
|
};
|
|
};
|
|
|
|
/* harmony default export */ var util_freezeSSR = (freezeSSR_freezeSSR);
|
|
// CONCATENATED MODULE: ./comps/Markdown.js
|
|
|
|
|
|
function Markdown__extends() { Markdown__extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return Markdown__extends.apply(this, arguments); }
|
|
|
|
|
|
|
|
var Markdown = dynamic__default()(new (__webpack_require__(13).SameLoopPromise)(function (resolve, reject) {
|
|
var weakId = /*require.resolve*/(20);
|
|
|
|
try {
|
|
var weakModule = __webpack_require__(weakId);
|
|
|
|
return resolve(weakModule);
|
|
} catch (err) {}
|
|
|
|
new Promise(function(resolve) { resolve(); }).then((function (require) {
|
|
try {
|
|
var m = __webpack_require__(20);
|
|
|
|
m.__webpackChunkName = 'react_markdown_2310f29285bb72f338f5fec99785c0fb';
|
|
resolve(m);
|
|
} catch (error) {
|
|
reject(error);
|
|
}
|
|
}).bind(null, __webpack_require__)).catch(__webpack_require__.oe);
|
|
}), util_freezeSSR('.Markdown'));
|
|
|
|
var Markdown_link = function link(props) {
|
|
return external__react__default.a.createElement("a", Markdown__extends({}, props, {
|
|
target: "_blank",
|
|
rel: "noopener noreferrer"
|
|
}));
|
|
};
|
|
|
|
var renderers = {
|
|
link: Markdown_link
|
|
};
|
|
|
|
var Markdown_AddRenderers = function AddRenderers(_ref) {
|
|
var className = _ref.className,
|
|
source = _ref.source;
|
|
return external__react__default.a.createElement(Markdown, {
|
|
className: className,
|
|
source: source,
|
|
renderers: renderers
|
|
});
|
|
};
|
|
|
|
/* harmony default export */ var comps_Markdown = __webpack_exports__["a"] = (Markdown_AddRenderers);
|
|
|
|
/***/ }),
|
|
/* 20 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("react-markdown");
|
|
|
|
/***/ }),
|
|
/* 21 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony export (immutable) */ __webpack_exports__["a"] = updateStateFromId;
|
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
|
|
function updateStateFromId(e) {
|
|
var el = e.target;
|
|
this.setState(_defineProperty({}, el.id, el.value));
|
|
}
|
|
|
|
/***/ }),
|
|
/* 22 */,
|
|
/* 23 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return MngDoc; });
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator__ = __webpack_require__(5);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react__ = __webpack_require__(0);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_react__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_next_router__ = __webpack_require__(6);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_next_router___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_next_router__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_next_dynamic__ = __webpack_require__(13);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_next_dynamic___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_next_dynamic__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__comps_Page__ = __webpack_require__(17);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__comps_Markdown__ = __webpack_require__(19);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__util_checkDirParts__ = __webpack_require__(24);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__util_checkDirParts___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6__util_checkDirParts__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__util_updStateFromId__ = __webpack_require__(21);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__util_getUrl__ = __webpack_require__(1);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__util_getUrl___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_8__util_getUrl__);
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__util_getJwt__ = __webpack_require__(14);
|
|
|
|
|
|
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
|
|
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _next(value) { step("next", value); } function _throw(err) { step("throw", err); } _next(); }); }; }
|
|
|
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
|
|
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); } }
|
|
|
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
|
|
|
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
|
|
|
|
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, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
|
|
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var CodeMirrorSkel = function CodeMirrorSkel() {
|
|
return __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("textarea", {
|
|
style: {
|
|
height: 'calc(300px - 1.2rem)',
|
|
margin: 0
|
|
}
|
|
}));
|
|
};
|
|
|
|
var CodeMirror = __WEBPACK_IMPORTED_MODULE_3_next_dynamic___default()(new (__webpack_require__(13).SameLoopPromise)(function (resolve, reject) {
|
|
var weakId = /*require.resolve*/(22);
|
|
|
|
try {
|
|
var weakModule = __webpack_require__(weakId);
|
|
|
|
return resolve(weakModule);
|
|
} catch (err) {}
|
|
|
|
__webpack_require__.e/* require.ensure */(0).then((function (require) {
|
|
try {
|
|
var m = __webpack_require__(22);
|
|
|
|
m.__webpackChunkName = 'comps_CodeMirror_51c113b8f0eb112cf9be60e9d3293726';
|
|
resolve(m);
|
|
} catch (error) {
|
|
reject(error);
|
|
}
|
|
}).bind(null, __webpack_require__)).catch(__webpack_require__.oe);
|
|
}), {
|
|
loading: CodeMirrorSkel,
|
|
ssr: false
|
|
});
|
|
var initState = {
|
|
name: '',
|
|
dir: '',
|
|
md: '## New Document!!',
|
|
editMode: false,
|
|
error: null,
|
|
pending: false
|
|
};
|
|
|
|
var MngDoc =
|
|
/*#__PURE__*/
|
|
function (_Component) {
|
|
_inherits(MngDoc, _Component);
|
|
|
|
function MngDoc() {
|
|
var _ref;
|
|
|
|
var _temp, _this;
|
|
|
|
_classCallCheck(this, MngDoc);
|
|
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
return _possibleConstructorReturn(_this, (_temp = _this = _possibleConstructorReturn(this, (_ref = MngDoc.__proto__ || Object.getPrototypeOf(MngDoc)).call.apply(_ref, [this].concat(args))), Object.defineProperty(_assertThisInitialized(_this), "state", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: initState
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "updVal", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: __WEBPACK_IMPORTED_MODULE_7__util_updStateFromId__["a" /* default */].bind(_assertThisInitialized(_this))
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "updMd", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function value(md) {
|
|
return _this.setState({
|
|
md: md
|
|
});
|
|
}
|
|
}), Object.defineProperty(_assertThisInitialized(_this), "submit", {
|
|
configurable: true,
|
|
enumerable: true,
|
|
writable: true,
|
|
value: function () {
|
|
var _value = _asyncToGenerator(
|
|
/*#__PURE__*/
|
|
__WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default.a.mark(function _callee() {
|
|
var _this$state, name, md, dir, editMode, data, doErr, dirErr, url, method, headers, numRemoved, dataKeys, res, _data, id;
|
|
|
|
return __WEBPACK_IMPORTED_MODULE_0__babel_runtime_regenerator___default.a.wrap(function _callee$(_context) {
|
|
while (1) {
|
|
switch (_context.prev = _context.next) {
|
|
case 0:
|
|
_this$state = _this.state, name = _this$state.name, md = _this$state.md, dir = _this$state.dir, editMode = _this$state.editMode;
|
|
data = {
|
|
name: Object(__WEBPACK_IMPORTED_MODULE_6__util_checkDirParts__["checkName"])(name),
|
|
dir: Object(__WEBPACK_IMPORTED_MODULE_6__util_checkDirParts__["checkDir"])(dir),
|
|
md: md
|
|
};
|
|
|
|
doErr = function doErr(error) {
|
|
return _this.setState({
|
|
pending: false,
|
|
error: error
|
|
});
|
|
};
|
|
|
|
dirErr = 'can only contain A-Z, a-z, 0-9, -, or . and not start or end with .';
|
|
|
|
if (data.name) {
|
|
_context.next = 6;
|
|
break;
|
|
}
|
|
|
|
return _context.abrupt("return", doErr('Document name ' + (data.name === 0 ? 'can not be empty' : dirErr)));
|
|
|
|
case 6:
|
|
if (!(!data.dir && data.dir !== 0)) {
|
|
_context.next = 10;
|
|
break;
|
|
}
|
|
|
|
return _context.abrupt("return", doErr('Directory ' + dirErr));
|
|
|
|
case 10:
|
|
if (data.dir === 0) {
|
|
data.dir = '';
|
|
}
|
|
|
|
case 11:
|
|
if (!(data.md.trim().length === 0)) {
|
|
_context.next = 13;
|
|
break;
|
|
}
|
|
|
|
return _context.abrupt("return", doErr('Content can not be empty'));
|
|
|
|
case 13:
|
|
url = __WEBPACK_IMPORTED_MODULE_8__util_getUrl___default()('docs'), method = 'POST', headers = {
|
|
Authorization: Object(__WEBPACK_IMPORTED_MODULE_9__util_getJwt__["a" /* default */])(),
|
|
'Content-Type': 'application/json'
|
|
};
|
|
|
|
if (!editMode) {
|
|
_context.next = 22;
|
|
break;
|
|
}
|
|
|
|
numRemoved = 0;
|
|
dataKeys = Object.keys(data);
|
|
dataKeys.forEach(function (k) {
|
|
if (data[k] === _this.props.doc[k]) {
|
|
delete data[k];
|
|
numRemoved++;
|
|
}
|
|
});
|
|
|
|
if (!(dataKeys.length === numRemoved)) {
|
|
_context.next = 20;
|
|
break;
|
|
}
|
|
|
|
return _context.abrupt("return");
|
|
|
|
case 20:
|
|
url = __WEBPACK_IMPORTED_MODULE_8__util_getUrl___default()('docs/' + _this.props.doc.id);
|
|
method = 'PATCH';
|
|
|
|
case 22:
|
|
_this.setState({
|
|
error: null,
|
|
pending: true
|
|
});
|
|
|
|
_context.next = 25;
|
|
return fetch(url, {
|
|
headers: headers,
|
|
method: method,
|
|
body: JSON.stringify(data)
|
|
}).catch(doErr);
|
|
|
|
case 25:
|
|
res = _context.sent;
|
|
_context.prev = 26;
|
|
_context.next = 29;
|
|
return res.json();
|
|
|
|
case 29:
|
|
data = _context.sent;
|
|
_context.next = 35;
|
|
break;
|
|
|
|
case 32:
|
|
_context.prev = 32;
|
|
_context.t0 = _context["catch"](26);
|
|
data = {
|
|
message: 'An error occurred submitting doc'
|
|
};
|
|
|
|
case 35:
|
|
if (!res.ok) {
|
|
_context.next = 38;
|
|
break;
|
|
}
|
|
|
|
_data = data, id = _data.id;
|
|
return _context.abrupt("return", __WEBPACK_IMPORTED_MODULE_2_next_router___default.a.push({
|
|
pathname: '/k',
|
|
query: {
|
|
id: id
|
|
}
|
|
}, __WEBPACK_IMPORTED_MODULE_8__util_getUrl___default()("k/".concat(id))));
|
|
|
|
case 38:
|
|
doErr(data.message);
|
|
|
|
case 39:
|
|
case "end":
|
|
return _context.stop();
|
|
}
|
|
}
|
|
}, _callee, this, [[26, 32]]);
|
|
}));
|
|
|
|
return function value() {
|
|
return _value.apply(this, arguments);
|
|
};
|
|
}()
|
|
}), _temp));
|
|
}
|
|
|
|
_createClass(MngDoc, [{
|
|
key: "render",
|
|
value: function render() {
|
|
var _state = this.state,
|
|
md = _state.md,
|
|
dir = _state.dir,
|
|
name = _state.name,
|
|
error = _state.error,
|
|
pending = _state.pending;
|
|
var rowStyle = {
|
|
paddingTop: 10
|
|
};
|
|
return __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_4__comps_Page__["a" /* default */], null, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "row fill",
|
|
style: rowStyle
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column column-50"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement(__WEBPACK_IMPORTED_MODULE_5__comps_Markdown__["a" /* default */], {
|
|
className: "fill Markdown",
|
|
source: md
|
|
})), __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column column-50"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "row"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column column-60"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("input", {
|
|
type: "text",
|
|
maxLength: 250,
|
|
placeholder: "New document name",
|
|
id: "name",
|
|
value: name,
|
|
onChange: this.updVal
|
|
})), __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("input", {
|
|
type: "text",
|
|
maxLength: 1024,
|
|
placeholder: "Subdirectory (optional)",
|
|
id: "dir",
|
|
value: dir,
|
|
onChange: this.updVal
|
|
}))), __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "row"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement(CodeMirror, {
|
|
value: md,
|
|
className: "column WrapCodeMirror",
|
|
onChange: this.updMd,
|
|
onSubmit: this.submit,
|
|
options: {
|
|
theme: 'monokai',
|
|
mode: 'markdown',
|
|
lineWrapping: true
|
|
}
|
|
})), __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "row",
|
|
style: {
|
|
marginTop: 5
|
|
}
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("div", {
|
|
className: "column"
|
|
}, __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("span", null, error), __WEBPACK_IMPORTED_MODULE_1_react___default.a.createElement("button", {
|
|
className: "float-right",
|
|
style: {
|
|
marginTop: 5
|
|
},
|
|
onClick: pending ? null : this.submit
|
|
}, "Submit"))))));
|
|
}
|
|
}], [{
|
|
key: "getDerivedStateFromProps",
|
|
value: function getDerivedStateFromProps(nextProps, prevState) {
|
|
var doc = nextProps.doc;
|
|
|
|
if (doc) {
|
|
var name = doc.name,
|
|
dir = doc.dir,
|
|
md = doc.md;
|
|
return {
|
|
name: name,
|
|
md: md,
|
|
dir: dir,
|
|
editMode: true
|
|
};
|
|
} else if (prevState.id) {
|
|
return initState;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}]);
|
|
|
|
return MngDoc;
|
|
}(__WEBPACK_IMPORTED_MODULE_1_react__["Component"]);
|
|
|
|
|
|
|
|
/***/ }),
|
|
/* 24 */
|
|
/***/ (function(module, exports) {
|
|
|
|
var isOkDirPart = function isOkDirPart(str) {
|
|
if (str.length > 255 || str.length === 0) return false;
|
|
var end = str.length - 1;
|
|
|
|
for (var i = 0; i < str.length; i++) {
|
|
var c = str.charCodeAt(i);
|
|
|
|
if (!(c > 47 && c < 58) && // 0-9
|
|
!(c > 64 && c < 91) && // A-Z
|
|
!(c > 96 && c < 123) && // a-z
|
|
!(c === 95) && !(c === 45) && // _ and -
|
|
!((c === 46 || c === 32) && // period or space if not first or last
|
|
i !== 0 && i !== end)) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
};
|
|
|
|
module.exports = {
|
|
checkDir: function checkDir(dir) {
|
|
if (typeof dir !== 'string') return false;
|
|
dir = dir.trim();
|
|
if (dir.length === 0) return 0;
|
|
|
|
if (dir.indexOf('/') > -1) {
|
|
dir = dir.split('/').filter(function (p) {
|
|
return p.length !== 0;
|
|
});
|
|
|
|
if (dir.length === 1) {
|
|
if (!isOkDirPart(dir[0])) false;
|
|
dir = dir[0];
|
|
} else if (dir.length === 0) {
|
|
dir = '';
|
|
} else if (dir.some(function (part) {
|
|
return !isOkDirPart(part);
|
|
})) {
|
|
return false;
|
|
}
|
|
} else if (!isOkDirPart(dir)) {
|
|
return false;
|
|
}
|
|
|
|
return Array.isArray(dir) ? dir.join('/') : dir;
|
|
},
|
|
checkName: function checkName(name) {
|
|
if (typeof name !== 'string') return false;
|
|
name = name.trim();
|
|
if (name.length === 0) return 0;
|
|
if (!isOkDirPart(name)) return false;
|
|
return name;
|
|
}
|
|
};
|
|
|
|
/***/ }),
|
|
/* 25 */,
|
|
/* 26 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("codemirror");
|
|
|
|
/***/ }),
|
|
/* 27 */
|
|
/***/ (function(module, exports) {
|
|
|
|
module.exports = require("codemirror/mode/markdown/markdown");
|
|
|
|
/***/ }),
|
|
/* 28 */,
|
|
/* 29 */,
|
|
/* 30 */,
|
|
/* 31 */,
|
|
/* 32 */,
|
|
/* 33 */,
|
|
/* 34 */,
|
|
/* 35 */,
|
|
/* 36 */,
|
|
/* 37 */,
|
|
/* 38 */,
|
|
/* 39 */,
|
|
/* 40 */,
|
|
/* 41 */,
|
|
/* 42 */
|
|
/***/ (function(module, exports, __webpack_require__) {
|
|
|
|
module.exports = __webpack_require__(43);
|
|
|
|
|
|
/***/ }),
|
|
/* 43 */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
|
|
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__comps_MngDoc__ = __webpack_require__(23);
|
|
|
|
/* harmony default export */ __webpack_exports__["default"] = (__WEBPACK_IMPORTED_MODULE_0__comps_MngDoc__["a" /* default */]);
|
|
|
|
/***/ })
|
|
/******/ ]); |