office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
91 lines • 4.54 kB
JavaScript
import * as tslib_1 from "tslib";
/* tslint:disable:no-unused-variable */
import * as React from 'react';
/* tslint:enable:no-unused-variable */
import { BaseComponent } from 'office-ui-fabric-react/lib/Utilities';
import { HoverCard } from 'office-ui-fabric-react/lib/HoverCard';
import { DetailsList, buildColumns } from 'office-ui-fabric-react/lib/DetailsList';
import { autobind } from 'office-ui-fabric-react/lib/Utilities';
import { createListItems } from '@uifabric/example-app-base';
import './HoverCard.Example.scss';
var _items;
var HoverCardField = /** @class */ (function (_super) {
tslib_1.__extends(HoverCardField, _super);
function HoverCardField(props) {
var _this = _super.call(this, props) || this;
_this.state = {
contentRendered: undefined
};
return _this;
}
HoverCardField.prototype.render = function () {
var _this = this;
return (React.createElement("div", { ref: function (c) { return !_this.state.contentRendered && _this.setState({ contentRendered: c }); }, "data-is-focusable": true },
this.props.content,
this.state.contentRendered &&
React.createElement(HoverCard, { expandingCardProps: this.props.expandingCardProps, target: this.state.contentRendered, cardDismissDelay: 300, onCardVisible: this._log('onCardVisible'), onCardHide: this._log('onCardHide'), trapFocus: true })));
};
HoverCardField.prototype._log = function (text) {
return function () {
console.log(text);
};
};
return HoverCardField;
}(BaseComponent));
var HoverCardTargetExample = /** @class */ (function (_super) {
tslib_1.__extends(HoverCardTargetExample, _super);
function HoverCardTargetExample(props) {
var _this = _super.call(this, props) || this;
_items = _items || createListItems(10);
_this.state = {
items: _items,
columns: _buildColumns()
};
return _this;
}
HoverCardTargetExample.prototype.render = function () {
var _a = this.state, items = _a.items, columns = _a.columns;
return (React.createElement("div", null,
React.createElement("p", null, " Hover over key of a row item to see the card "),
React.createElement(DetailsList, { setKey: 'hoverSet', items: items, columns: columns, onRenderItemColumn: this._onRenderItemColumn, ariaLabel: 'Hover card DetailsList test' })));
};
HoverCardTargetExample.prototype._onRenderItemColumn = function (item, index, column) {
var expandingCardProps = {
onRenderCompactCard: this._onRenderCompactCard,
onRenderExpandedCard: this._onRenderExpandedCard,
renderData: item,
directionalHint: 11 /* rightTopEdge */,
gapSpace: 16
};
if (column.key === 'key') {
return (React.createElement("div", { className: 'HoverCard-item' },
React.createElement(HoverCardField, { content: item.key, expandingCardProps: expandingCardProps })));
}
return item[column.key];
};
HoverCardTargetExample.prototype._onRenderCompactCard = function (item) {
return (React.createElement("div", { className: 'hoverCardExample-compactCard' },
React.createElement("a", { target: '_blank', href: "http://wikipedia.org/wiki/" + item.location }, item.location)));
};
HoverCardTargetExample.prototype._onRenderExpandedCard = function (item) {
var _a = this.state, items = _a.items, columns = _a.columns;
return (React.createElement("div", { className: 'hoverCardExample-expandedCard' },
item.description,
React.createElement(DetailsList, { setKey: 'expandedCardSet', items: items, columns: columns })));
};
tslib_1.__decorate([
autobind
], HoverCardTargetExample.prototype, "_onRenderItemColumn", null);
tslib_1.__decorate([
autobind
], HoverCardTargetExample.prototype, "_onRenderCompactCard", null);
tslib_1.__decorate([
autobind
], HoverCardTargetExample.prototype, "_onRenderExpandedCard", null);
return HoverCardTargetExample;
}(BaseComponent));
export { HoverCardTargetExample };
function _buildColumns() {
return buildColumns(_items).filter(function (column) { return column.name === 'location' || column.name === 'key'; });
}
//# sourceMappingURL=HoverCard.Target.Example.js.map