office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
71 lines • 3.39 kB
JavaScript
import * as tslib_1 from "tslib";
import * as React from 'react';
import { HoverCard } from 'office-ui-fabric-react/lib/HoverCard';
import { Fabric } from 'office-ui-fabric-react/lib/Fabric';
import { DetailsList, buildColumns } from 'office-ui-fabric-react/lib/DetailsList';
import { createListItems } from '@uifabric/example-data';
import { mergeStyleSets } from 'office-ui-fabric-react/lib/Styling';
var classNames = mergeStyleSets({
compactCard: {
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
height: '100%'
},
expandedCard: {
padding: '16px 24px'
},
item: {
selectors: {
'&:hover': {
textDecoration: 'underline',
cursor: 'pointer'
}
}
}
});
var HoverCardBasicExample = /** @class */ (function (_super) {
tslib_1.__extends(HoverCardBasicExample, _super);
function HoverCardBasicExample() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this._items = createListItems(10);
_this._columns = _this._buildColumns();
_this._onRenderItemColumn = function (item, index, column) {
var expandingCardProps = {
onRenderCompactCard: _this._onRenderCompactCard,
onRenderExpandedCard: _this._onRenderExpandedCard,
renderData: item
};
if (column.key === 'location') {
return (React.createElement(HoverCard, { expandingCardProps: expandingCardProps, instantOpenOnClick: true },
React.createElement("div", { className: classNames.item }, item.location)));
}
return item[column.key];
};
_this._onRenderCompactCard = function (item) {
return (React.createElement("div", { className: classNames.compactCard },
React.createElement("a", { target: "_blank", href: "http://wikipedia.org/wiki/" + item.location }, item.location)));
};
_this._onRenderExpandedCard = function (item) {
return (React.createElement("div", { className: classNames.expandedCard },
item.description,
React.createElement(DetailsList, { setKey: "expandedCardSet", items: _this._items, columns: _this._columns })));
};
return _this;
}
HoverCardBasicExample.prototype.render = function () {
return (React.createElement(Fabric, null,
React.createElement("p", null,
"Hover over the ",
React.createElement("i", null, "location"),
" cell of a row item to see the card or use the keyboard to navigate to it."),
React.createElement("p", null, "When using the keyboard to tab to it, the card will open but navigation inside of it will not be available."),
React.createElement(DetailsList, { setKey: "hoverSet", items: this._items, columns: this._columns, onRenderItemColumn: this._onRenderItemColumn })));
};
HoverCardBasicExample.prototype._buildColumns = function () {
return buildColumns(this._items).filter(function (column) { return column.name === 'location' || column.name === 'key'; });
};
return HoverCardBasicExample;
}(React.Component));
export { HoverCardBasicExample };
//# sourceMappingURL=HoverCard.Basic.Example.js.map