office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
68 lines • 2.81 kB
JavaScript
import * as tslib_1 from "tslib";
import * as React from 'react';
import { GroupedList } from 'office-ui-fabric-react/lib/GroupedList';
import { Link } from 'office-ui-fabric-react/lib/Link';
import { createListItems, createGroups } from '@uifabric/example-data';
import { getTheme, mergeStyleSets } from 'office-ui-fabric-react/lib/Styling';
var theme = getTheme();
var headerAndFooterStyles = {
minWidth: 300,
minHeight: 40,
lineHeight: 40,
paddingLeft: 16
};
var classNames = mergeStyleSets({
header: [headerAndFooterStyles, theme.fonts.xLarge],
footer: [headerAndFooterStyles, theme.fonts.large],
name: {
display: 'inline-block',
overflow: 'hidden',
height: 24,
cursor: 'default',
padding: 8,
boxSizing: 'border-box',
verticalAlign: 'top',
background: 'none',
backgroundColor: 'transparent',
border: 'none',
paddingLeft: 32
}
});
var GroupedListCustomExample = /** @class */ (function (_super) {
tslib_1.__extends(GroupedListCustomExample, _super);
function GroupedListCustomExample() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this._items = createListItems(20);
_this._groups = createGroups(4, 0, 0, 5);
return _this;
}
GroupedListCustomExample.prototype.render = function () {
return (React.createElement(GroupedList, { items: this._items, onRenderCell: this._onRenderCell, groupProps: {
onRenderHeader: this._onRenderHeader,
onRenderFooter: this._onRenderFooter
}, groups: this._groups }));
};
GroupedListCustomExample.prototype._onRenderCell = function (nestingDepth, item, itemIndex) {
return (React.createElement("div", { "data-selection-index": itemIndex },
React.createElement("span", { className: classNames.name }, item.name)));
};
GroupedListCustomExample.prototype._onRenderHeader = function (props) {
var toggleCollapse = function () {
props.onToggleCollapse(props.group);
};
return (React.createElement("div", { className: classNames.header },
"This is a custom header for ",
props.group.name,
"\u00A0 (",
React.createElement(Link, { onClick: toggleCollapse }, props.group.isCollapsed ? 'Expand' : 'Collapse'),
")"));
};
GroupedListCustomExample.prototype._onRenderFooter = function (props) {
return React.createElement("div", { className: classNames.footer },
"This is a custom footer for ",
props.group.name);
};
return GroupedListCustomExample;
}(React.Component));
export { GroupedListCustomExample };
//# sourceMappingURL=GroupedList.Custom.Example.js.map