UNPKG

office-ui-fabric-react

Version:

Reusable React components for building experiences for Office 365.

121 lines 6.36 kB
define(["require", "exports", "tslib", "react", "office-ui-fabric-react/lib/Announced", "office-ui-fabric-react/lib/Link", "office-ui-fabric-react/lib/DetailsList", "office-ui-fabric-react/lib/Selection", "office-ui-fabric-react/lib/MarqueeSelection", "office-ui-fabric-react/lib/Text", "office-ui-fabric-react/lib/Stack", "office-ui-fabric-react/lib/Styling"], function (require, exports, tslib_1, React, Announced_1, Link_1, DetailsList_1, Selection_1, MarqueeSelection_1, Text_1, Stack_1, Styling_1) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _items = []; var theme = Styling_1.getTheme(); var dragEnterClass = Styling_1.mergeStyles({ backgroundColor: theme.palette.neutralLight }); var _columns = ['Name', 'Modified', 'Modified By', 'File Size'].map(function (name) { var fieldName = name.replace(' ', '').toLowerCase(); return { fieldName: fieldName, name: name, key: fieldName, minWidth: 100, maxWidth: 200, isResizable: true }; }); var _names = [ 'Annie Lindqvist', 'Aaron Reid', 'Alex Lundberg', 'Roko Kolar', 'Christian Bergqvist', 'Valentina Lovric', 'Makenzie Sharett' ]; function getMockDateString() { return 'Thu Jan 05 2017‌'; } var AnnouncedBulkOperationsExample = /** @class */ (function (_super) { tslib_1.__extends(AnnouncedBulkOperationsExample, _super); function AnnouncedBulkOperationsExample(props) { var _this = _super.call(this, props) || this; _this._onItemInvoked = function (item) { alert("Item invoked: " + item.name); }; _this._onRenderItemColumn = function (item, index, column) { if (column.key === 'name') { return React.createElement(Link_1.Link, { "data-selection-invoke": true }, item[column.key]); } return item[column.key]; }; _this._selection = new Selection_1.Selection(); _this._dragDropEvents = _this._getDragDropEvents(); _this._draggedIndex = -1; if (_items.length === 0) { for (var i = 0; i < 20; i++) { _items.push({ key: 'item-' + i, name: 'Item ' + i, modified: getMockDateString(), modifiedby: _names[Math.floor(Math.random() * _names.length)], filesize: Math.floor(Math.random() * 30).toString() + ' MB' }); } } _this.state = { items: _items, numberOfItems: 0 }; return _this; } AnnouncedBulkOperationsExample.prototype.render = function () { var items = this.state.items; var stackTokens = { childrenGap: 10 }; return (React.createElement(Stack_1.Stack, { tokens: stackTokens }, React.createElement(Text_1.Text, null, "Turn on Narrator and drag and drop the items."), React.createElement(Text_1.Text, null, "Note: This example is to showcase the concept of copying, uploading, or moving many items and not fully illustrative of the real world scenario."), this._renderAnnounced(), React.createElement(MarqueeSelection_1.MarqueeSelection, { selection: this._selection }, React.createElement(DetailsList_1.DetailsList, { setKey: "items", items: items, columns: _columns, selection: this._selection, selectionPreservedOnEmptyClick: true, onItemInvoked: this._onItemInvoked, onRenderItemColumn: this._onRenderItemColumn, dragDropEvents: this._dragDropEvents, ariaLabelForSelectionColumn: "Toggle selection", ariaLabelForSelectAllCheckbox: "Toggle selection for all items" })))); }; AnnouncedBulkOperationsExample.prototype._renderAnnounced = function () { var numberOfItems = this.state.numberOfItems; if (numberOfItems > 0) { return React.createElement(Announced_1.Announced, { message: numberOfItems + " item" + (numberOfItems === 1 ? '' : 's') + " moved" }); } }; AnnouncedBulkOperationsExample.prototype._getDragDropEvents = function () { var _this = this; return { canDrop: function () { return true; }, canDrag: function () { return true; }, // return string is the css class that will be added to the entering element. onDragEnter: function () { return dragEnterClass; }, onDragLeave: function () { return undefined; }, onDrop: function (item) { if (_this._draggedItem && item) { _this._insertBeforeItem(item); } }, onDragStart: function (item, itemIndex) { _this._draggedItem = item; _this._draggedIndex = itemIndex; }, onDragEnd: function () { _this._draggedItem = undefined; _this._draggedIndex = -1; } }; }; AnnouncedBulkOperationsExample.prototype._insertBeforeItem = function (item) { var draggedItems = this._selection.isIndexSelected(this._draggedIndex) ? this._selection.getSelection() : [this._draggedItem]; var items = this.state.items.filter(function (currentItem) { return draggedItems.indexOf(currentItem) === -1; }); var insertIndex = items.indexOf(item); // if dragging/dropping on itself, index will be 0. if (insertIndex === -1) { insertIndex = 0; } items.splice.apply(items, [insertIndex, 0].concat(draggedItems)); this.setState({ items: items, numberOfItems: draggedItems.length }); }; return AnnouncedBulkOperationsExample; }(React.Component)); exports.AnnouncedBulkOperationsExample = AnnouncedBulkOperationsExample; }); //# sourceMappingURL=Announced.BulkOperations.Example.js.map