office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
49 lines • 3.21 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
/* tslint:disable */
var React = require("react");
/* tslint:enable */
var Utilities_1 = require("../../../../Utilities");
var Persona_1 = require("../../../../Persona");
var ContextualMenu_1 = require("../../../../ContextualMenu");
var Button_1 = require("../../../../Button");
var FocusZone_1 = require("../../../../FocusZone");
var stylesImport = require("./PickerItemsDefault.scss");
var styles = stylesImport;
var SelectedItemWithMenu = (function (_super) {
tslib_1.__extends(SelectedItemWithMenu, _super);
function SelectedItemWithMenu(props) {
var _this = _super.call(this, props) || this;
_this.state = { contextualMenuVisible: false };
return _this;
}
SelectedItemWithMenu.prototype.render = function () {
var _a = this.props, item = _a.item, onRemoveItem = _a.onRemoveItem, removeButtonAriaLabel = _a.removeButtonAriaLabel;
return (React.createElement("div", { "data-is-focusable": true, className: Utilities_1.css('ms-PickerItem-container', styles.itemContainer) },
React.createElement(FocusZone_1.FocusZone, { className: Utilities_1.css('ms-PickerPersona-container', styles.personaContainer) },
React.createElement("div", { className: Utilities_1.css('ms-PickerItem-content', styles.itemContent) },
React.createElement(Persona_1.Persona, tslib_1.__assign({}, item, { presence: item.presence !== undefined ? item.presence : Persona_1.PersonaPresence.none }))),
React.createElement("div", { ref: 'ellipsisRef', className: Utilities_1.css('ms-PickerItem-content', styles.itemContent) },
React.createElement(Button_1.IconButton, { iconProps: { iconName: 'More' }, onClick: this._onContextualMenu })),
React.createElement("div", { className: Utilities_1.css('ms-PickerItem-content', styles.itemContent) },
React.createElement(Button_1.IconButton, { iconProps: { iconName: 'Cancel' }, onClick: onRemoveItem, ariaLabel: removeButtonAriaLabel })),
this.state.contextualMenuVisible ? (React.createElement(ContextualMenu_1.ContextualMenu, { items: item.menuItems, shouldFocusOnMount: true, targetElement: this.refs.ellipsisRef, onDismiss: this._onCloseContextualMenu, directionalHint: ContextualMenu_1.DirectionalHint.bottomAutoEdge }))
: null)));
};
SelectedItemWithMenu.prototype._onContextualMenu = function (ev) {
this.setState({ contextualMenuVisible: true });
};
SelectedItemWithMenu.prototype._onCloseContextualMenu = function (ev) {
this.setState({ contextualMenuVisible: false });
};
tslib_1.__decorate([
Utilities_1.autobind
], SelectedItemWithMenu.prototype, "_onContextualMenu", null);
tslib_1.__decorate([
Utilities_1.autobind
], SelectedItemWithMenu.prototype, "_onCloseContextualMenu", null);
return SelectedItemWithMenu;
}(Utilities_1.BaseComponent));
exports.SelectedItemWithMenu = SelectedItemWithMenu;
//# sourceMappingURL=SelectedItemWithMenu.js.map
;