Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Commit

Permalink
Merge pull request #5162 from matrix-org/t3chguy/lodash
Browse files Browse the repository at this point in the history
Consolidate Lodash files in bundle
  • Loading branch information
t3chguy authored Sep 3, 2020
2 parents 03588f8 + 842821b commit 97ebfa0
Show file tree
Hide file tree
Showing 13 changed files with 20 additions and 22 deletions.
2 changes: 1 addition & 1 deletion src/Markdown.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ limitations under the License.
*/

import commonmark from 'commonmark';
import escape from 'lodash/escape';
import {escape} from "lodash";

const ALLOWED_HTML_TAGS = ['sub', 'sup', 'del', 'u'];

Expand Down
4 changes: 2 additions & 2 deletions src/SendHistoryManager.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

import _clamp from 'lodash/clamp';
import {clamp} from "lodash";

export default class SendHistoryManager {
history: Array<HistoryItem> = [];
Expand Down Expand Up @@ -54,7 +54,7 @@ export default class SendHistoryManager {
}

getItem(offset: number): ?HistoryItem {
this.currentIndex = _clamp(this.currentIndex + offset, 0, this.history.length - 1);
this.currentIndex = clamp(this.currentIndex + offset, 0, this.history.length - 1);
return this.history[this.currentIndex];
}
}
4 changes: 2 additions & 2 deletions src/autocomplete/CommunityProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ import {MatrixClientPeg} from '../MatrixClientPeg';
import QueryMatcher from './QueryMatcher';
import {PillCompletion} from './Components';
import * as sdk from '../index';
import _sortBy from 'lodash/sortBy';
import {sortBy} from "lodash";
import {makeGroupPermalink} from "../utils/permalinks/Permalinks";
import {ICompletion, ISelectionRange} from "./Autocompleter";
import FlairStore from "../stores/FlairStore";
Expand Down Expand Up @@ -81,7 +81,7 @@ export default class CommunityProvider extends AutocompleteProvider {

const matchedString = command[0];
completions = this.matcher.match(matchedString);
completions = _sortBy(completions, [
completions = sortBy(completions, [
(c) => score(matchedString, c.groupId),
(c) => c.groupId.length,
]).map(({avatarUrl, groupId, name}) => ({
Expand Down
5 changes: 2 additions & 3 deletions src/autocomplete/EmojiProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,7 @@ import AutocompleteProvider from './AutocompleteProvider';
import QueryMatcher from './QueryMatcher';
import {PillCompletion} from './Components';
import {ICompletion, ISelectionRange} from './Autocompleter';
import _uniq from 'lodash/uniq';
import _sortBy from 'lodash/sortBy';
import {uniq, sortBy} from 'lodash';
import SettingsStore from "../settings/SettingsStore";
import { shortcodeToUnicode } from '../HtmlUtils';
import { EMOJI, IEmoji } from '../emoji';
Expand Down Expand Up @@ -115,7 +114,7 @@ export default class EmojiProvider extends AutocompleteProvider {
}
// Finally, sort by original ordering
sorters.push((c) => c._orderBy);
completions = _sortBy(_uniq(completions), sorters);
completions = sortBy(uniq(completions), sorters);

completions = completions.map(({shortname}) => {
const unicode = shortcodeToUnicode(shortname);
Expand Down
7 changes: 3 additions & 4 deletions src/autocomplete/QueryMatcher.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,7 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

import _at from 'lodash/at';
import _uniq from 'lodash/uniq';
import {at, uniq} from 'lodash';
import {removeHiddenChars} from "matrix-js-sdk/src/utils";

interface IOptions<T extends {}> {
Expand Down Expand Up @@ -73,7 +72,7 @@ export default class QueryMatcher<T extends Object> {
// type for their values. We assume that those values who's keys have
// been specified will be string. Also, we cannot infer all the
// types of the keys of the objects at compile.
const keyValues = _at<string>(<any>object, this._options.keys);
const keyValues = at<string>(<any>object, this._options.keys);

if (this._options.funcs) {
for (const f of this._options.funcs) {
Expand Down Expand Up @@ -137,7 +136,7 @@ export default class QueryMatcher<T extends Object> {
});

// Now map the keys to the result objects. Also remove any duplicates.
return _uniq(matches.map((match) => match.object));
return uniq(matches.map((match) => match.object));
}

private processQuery(query: string): string {
Expand Down
2 changes: 1 addition & 1 deletion src/autocomplete/RoomProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ import {PillCompletion} from './Components';
import * as sdk from '../index';
import {makeRoomPermalink} from "../utils/permalinks/Permalinks";
import {ICompletion, ISelectionRange} from "./Autocompleter";
import { uniqBy, sortBy } from 'lodash';
import {uniqBy, sortBy} from "lodash";

const ROOM_REGEX = /\B#\S*/g;

Expand Down
4 changes: 2 additions & 2 deletions src/autocomplete/UserProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ import AutocompleteProvider from './AutocompleteProvider';
import {PillCompletion} from './Components';
import * as sdk from '../index';
import QueryMatcher from './QueryMatcher';
import _sortBy from 'lodash/sortBy';
import {sortBy} from 'lodash';
import {MatrixClientPeg} from '../MatrixClientPeg';

import MatrixEvent from "matrix-js-sdk/src/models/event";
Expand Down Expand Up @@ -156,7 +156,7 @@ export default class UserProvider extends AutocompleteProvider {
const currentUserId = MatrixClientPeg.get().credentials.userId;
this.users = this.room.getJoinedMembers().filter(({userId}) => userId !== currentUserId);

this.users = _sortBy(this.users, (member) => 1E20 - lastSpoken[member.userId] || 1E20);
this.users = sortBy(this.users, (member) => 1E20 - lastSpoken[member.userId] || 1E20);

this.matcher.setObjects(this.users);
}
Expand Down
2 changes: 1 addition & 1 deletion src/components/structures/SearchBox.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import createReactClass from 'create-react-class';
import PropTypes from 'prop-types';
import { Key } from '../../Keyboard';
import dis from '../../dispatcher/dispatcher';
import { throttle } from 'lodash';
import {throttle} from 'lodash';
import AccessibleButton from '../../components/views/elements/AccessibleButton';
import classNames from 'classnames';

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ See the License for the specific language governing permissions and
limitations under the License.
*/

import { debounce } from 'lodash';
import {debounce} from "lodash";
import classNames from 'classnames';
import React from 'react';
import PropTypes from "prop-types";
Expand Down
2 changes: 1 addition & 1 deletion src/components/views/elements/Field.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ limitations under the License.
import React, {InputHTMLAttributes, SelectHTMLAttributes, TextareaHTMLAttributes} from 'react';
import classNames from 'classnames';
import * as sdk from '../../../index';
import { debounce } from 'lodash';
import {debounce} from "lodash";
import {IFieldState, IValidationResult} from "./Validation";

// Invoke validation from user input (when typing, etc.) at most once every N ms.
Expand Down
2 changes: 1 addition & 1 deletion src/components/views/rooms/Autocomplete.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ limitations under the License.

import React, {createRef, KeyboardEvent} from 'react';
import classNames from 'classnames';
import flatMap from 'lodash/flatMap';
import {flatMap} from "lodash";
import {ICompletion, ISelectionRange, IProviderCompletions} from '../../../autocomplete/Autocompleter';
import {Room} from 'matrix-js-sdk/src/models/room';

Expand Down
2 changes: 1 addition & 1 deletion src/ratelimitedfunc.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ limitations under the License.
* on unmount or similar to cancel any pending update.
*/

import { throttle } from "lodash";
import {throttle} from "lodash";

export default function ratelimitedfunc(fn, time) {
const throttledFn = throttle(fn, time, {
Expand Down
4 changes: 2 additions & 2 deletions src/utils/DMRoomMap.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ limitations under the License.
*/

import {MatrixClientPeg} from '../MatrixClientPeg';
import _uniq from 'lodash/uniq';
import {uniq} from "lodash";
import {Room} from "matrix-js-sdk/src/matrix";

/**
Expand Down Expand Up @@ -111,7 +111,7 @@ export default class DMRoomMap {
userToRooms[userId] = [roomId];
} else {
roomIds.push(roomId);
userToRooms[userId] = _uniq(roomIds);
userToRooms[userId] = uniq(roomIds);
}
});
return true;
Expand Down

0 comments on commit 97ebfa0

Please sign in to comment.