-
Notifications
You must be signed in to change notification settings - Fork 1
/
navigation.js
180 lines (180 loc) · 20.4 KB
/
navigation.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
var __extends = (this && this.__extends) || (function () {
var extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __assign = (this && this.__assign) || Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)
t[p[i]] = s[p[i]];
return t;
};
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import { withLang, Logo } from 'olymp-utils';
import { Link } from 'olymp-router';
import { withAuth } from 'olymp-auth';
import { Menu, Icon } from 'antd';
import { createComponent } from 'olymp-fela';
import { GatewayDest, GatewayRegistry } from 'react-gateway';
import Gravatar from 'react-gravatar';
import { get } from 'lodash';
var getInitials = function (name) {
if (name) {
var array = name.split(' ');
switch (array.length) {
case 1:
return array[0].charAt(0).toUpperCase();
default:
return (array[0].charAt(0).toUpperCase() +
array[array.length - 1].charAt(0).toUpperCase());
}
}
return false;
};
var UserIcon = createComponent(function (_a) {
var theme = _a.theme, name = _a.name;
return ({
float: 'left',
borderRadius: '50%',
marginY: theme.space2,
background: "url(https://invatar0.appspot.com/svg/" + getInitials(name) + ".jpg?s=26&bg=" + encodeURIComponent(theme.color) + "&color=" + encodeURIComponent(theme.light) + ") center center no-repeat, " + theme.color,
onHover: {
opacity: 0.85,
},
});
}, function (p) { return React.createElement(Gravatar, __assign({}, p, { size: 30 })); }, function (p) { return Object.keys(p); });
var VerticalMenu = createComponent(function (_a) {
var theme = _a.theme, padding = _a.padding;
return ({
position: 'relative',
zIndex: 3,
backgroundColor: '#404040',
boxShadow: 'inset 0 -10px 10px -10px #000000',
paddingX: theme.space2,
hasFlex: {
display: 'flex',
justifyContent: 'space-between',
},
'> ul': {
zIndex: 3,
boxShadow: 'inset 0 -10px 10px -10px #000000',
},
'> ul > li.ant-menu-item-selected.ant-menu-item': {
backgroundColor: theme.color,
'> a': {
color: theme.light,
},
},
ifSmallDown: {
display: 'none',
},
padding: padding,
});
}, 'div', function (_a) {
var padding = _a.padding, p = __rest(_a, ["padding"]);
return Object.keys(p);
});
var LeftMenu = createComponent(function (_a) {
var theme = _a.theme;
return ({
float: 'left',
});
}, function (p) { return React.createElement(Menu, __assign({}, p)); }, function (p) { return Object.keys(p); });
var Filler = createComponent(function (_a) {
var theme = _a.theme;
return ({
flex: '1 1 0%',
});
}, function (p) { return React.createElement("div", __assign({}, p)); }, function (p) { return Object.keys(p); });
var RightMenu = createComponent(function (_a) {
var theme = _a.theme;
return ({
float: 'right !important',
'> ul': {
right: 0,
left: 'auto !important',
'> li > ul': {
left: 'auto !important',
marginLeft: '0 !important',
right: '100%',
marginRight: 4,
},
},
});
}, function (p) { return React.createElement(Menu.SubMenu, __assign({}, p)); }, function (p) { return Object.keys(p); });
var AntMenu = function (_a) {
var keys = _a.keys, p = __rest(_a, ["keys"]);
return React.createElement(LeftMenu, __assign({ theme: "dark", selectedKeys: keys, mode: "horizontal" }, p));
};
var AntSubMenu = function (_a) {
var keys = _a.keys, title = _a.title, children = _a.children, p = __rest(_a, ["keys", "title", "children"]);
return React.createElement(AntMenu, __assign({}, p),
React.createElement(RightMenu, { title: title || React.createElement(Icon, { type: "bars" }) }, children));
};
var Navigation = (function (_super) {
__extends(Navigation, _super);
function Navigation(props, context) {
var _this = _super.call(this, props, context) || this;
_this.gatewayRegistry = context.gatewayRegistry;
return _this;
}
Navigation.prototype.componentWillMount = function () {
this.gatewayRegistry.addContainer('toolbar', this);
};
Navigation.prototype.componentWillUnmount = function () {
this.gatewayRegistry.removeContainer('toolbar', this);
};
Navigation.prototype.render = function () {
var _a = this.props, auth = _a.auth, padding = _a.padding, _b = _a.query, query = _b === void 0 ? {} : _b, pathname = _a.pathname, children = _a.children, _c = _a.keys, keys = _c === void 0 ? [pathname] : _c;
return (React.createElement(VerticalMenu, { padding: padding },
React.createElement(AntMenu, { keys: keys },
React.createElement(Menu.Item, null,
React.createElement(Link, { to: { pathname: pathname } },
React.createElement(Logo, { size: 33, margin: "0 0 -7px 0" }))),
children),
React.createElement(Filler, null),
React.createElement(GatewayDest, { name: "quick", component: AntMenu }),
React.createElement("div", null,
React.createElement(GatewayDest, { name: "navigation", component: AntMenu }),
get(auth, 'user') &&
React.createElement(AntSubMenu, { title: React.createElement(UserIcon, { email: auth.user.email, name: auth.user.name, default: "blank" }) },
React.createElement(Menu.Item, { key: "logout" },
React.createElement("a", { onClick: auth.logout, href: "javascript:;" },
React.createElement(Icon, { type: "poweroff" }),
" Abmelden"))))));
};
Navigation.contextTypes = {
gatewayRegistry: PropTypes.instanceOf(GatewayRegistry).isRequired,
};
Navigation = __decorate([
withLang,
withAuth
], Navigation);
return Navigation;
}(Component));
Navigation.Item = Menu.Item;
export default Navigation;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["packages/ui/navigation.tsx"],"names":[],"mappings":"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","file":"packages/ui/navigation.js","sourcesContent":["import React, { Component, createElement } from 'react';\nimport PropTypes from 'prop-types';\nimport { withLang, Logo } from 'olymp-utils';\nimport { Link } from 'olymp-router';\nimport { withAuth } from 'olymp-auth';\nimport { Menu, Icon } from 'antd';\nimport { createComponent } from 'olymp-fela';\nimport { GatewayDest, GatewayRegistry } from 'react-gateway';\nimport Gravatar from 'react-gravatar';\nimport { get } from 'lodash';\n\nconst getInitials = name => {\n  if (name) {\n    const array = name.split(' ');\n\n    switch (array.length) {\n      case 1:\n        return array[0].charAt(0).toUpperCase();\n      default:\n        return (\n          array[0].charAt(0).toUpperCase() +\n          array[array.length - 1].charAt(0).toUpperCase()\n        );\n    }\n  }\n  return false;\n};\n\nconst UserIcon = createComponent(\n  ({ theme, name }) => ({\n    float: 'left',\n    borderRadius: '50%',\n    marginY: theme.space2,\n    background: `url(https://invatar0.appspot.com/svg/${getInitials(\n      name\n    )}.jpg?s=26&bg=${encodeURIComponent(\n      theme.color\n    )}&color=${encodeURIComponent(\n      theme.light\n    )}) center center no-repeat, ${theme.color}`,\n    onHover: {\n      opacity: 0.85,\n    },\n  }),\n  p => <Gravatar {...p} size={30} />,\n  p => Object.keys(p)\n);\n\nconst VerticalMenu = createComponent(\n  ({ theme, padding }) => ({\n    position: 'relative',\n    zIndex: 3,\n    backgroundColor: '#404040',\n    boxShadow: 'inset 0 -10px 10px -10px #000000',\n    paddingX: theme.space2,\n    hasFlex: {\n      display: 'flex',\n      justifyContent: 'space-between',\n    },\n    '> ul': {\n      zIndex: 3,\n      boxShadow: 'inset 0 -10px 10px -10px #000000',\n    },\n    '> ul > li.ant-menu-item-selected.ant-menu-item': {\n      backgroundColor: theme.color,\n      '> a': {\n        color: theme.light,\n      },\n    },\n    ifSmallDown: {\n      display: 'none',\n    },\n    padding,\n  }),\n  'div',\n  ({ padding, ...p }) => Object.keys(p)\n);\n\nconst LeftMenu = createComponent(\n  ({ theme }) => ({\n    float: 'left',\n  }),\n  p => <Menu {...p} />,\n  p => Object.keys(p)\n);\n\nconst Filler = createComponent(\n  ({ theme }) => ({\n    flex: '1 1 0%',\n  }),\n  p => <div {...p} />,\n  p => Object.keys(p)\n);\n\nconst RightMenu = createComponent(\n  ({ theme }) => ({\n    float: 'right !important',\n    '> ul': {\n      right: 0,\n      left: 'auto !important',\n      '> li > ul': {\n        left: 'auto !important',\n        marginLeft: '0 !important',\n        right: '100%',\n        marginRight: 4,\n      },\n    },\n  }),\n  p => <Menu.SubMenu {...p} />,\n  p => Object.keys(p)\n);\n\nconst AntMenu = ({ keys, ...p }) =>\n  <LeftMenu theme=\"dark\" selectedKeys={keys} mode=\"horizontal\" {...p} />;\n\nconst AntSubMenu = ({ keys, title, children, ...p }) =>\n  <AntMenu {...p}>\n    <RightMenu title={title || <Icon type=\"bars\" />}>\n      {children}\n    </RightMenu>\n  </AntMenu>;\n\n@withLang\n@withAuth\nclass Navigation extends Component {\n  static contextTypes = {\n    gatewayRegistry: PropTypes.instanceOf(GatewayRegistry).isRequired,\n  };\n\n  constructor(props, context) {\n    super(props, context);\n    this.gatewayRegistry = context.gatewayRegistry;\n  }\n\n  componentWillMount() {\n    this.gatewayRegistry.addContainer('toolbar', this);\n  }\n\n  componentWillUnmount() {\n    this.gatewayRegistry.removeContainer('toolbar', this);\n  }\n\n  render() {\n    const {\n      auth,\n      padding,\n      query = {},\n      pathname,\n      children,\n      keys = [pathname],\n    } = this.props;\n    return (\n      <VerticalMenu padding={padding}>\n        <AntMenu keys={keys}>\n          <Menu.Item>\n            <Link to={{ pathname }}>\n              <Logo size={33} margin=\"0 0 -7px 0\" />\n            </Link>\n          </Menu.Item>\n          {children}\n        </AntMenu>\n        <Filler />\n        <GatewayDest name=\"quick\" component={AntMenu} />\n        <div>\n          <GatewayDest name=\"navigation\" component={AntMenu} />\n          {get(auth, 'user') &&\n            <AntSubMenu\n              title={\n                <UserIcon\n                  email={auth.user.email}\n                  name={auth.user.name}\n                  default=\"blank\"\n                />\n              }\n            >\n              <Menu.Item key=\"logout\">\n                <a onClick={auth.logout} href=\"javascript:;\">\n                  <Icon type=\"poweroff\" /> Abmelden\n                </a>\n              </Menu.Item>\n            </AntSubMenu>}\n        </div>\n      </VerticalMenu>\n    );\n  }\n}\n\nNavigation.Item = Menu.Item;\nexport default Navigation;\n"]}