matrix-react-sdk
Version:
SDK for matrix.org using React
71 lines (66 loc) • 12.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _CommandProvider = _interopRequireDefault(require("./CommandProvider"));
var _RoomProvider = _interopRequireDefault(require("./RoomProvider"));
var _UserProvider = _interopRequireDefault(require("./UserProvider"));
var _EmojiProvider = _interopRequireDefault(require("./EmojiProvider"));
var _NotifProvider = _interopRequireDefault(require("./NotifProvider"));
var _promise = require("../utils/promise");
var _SpaceProvider = _interopRequireDefault(require("./SpaceProvider"));
var _RoomContext = require("../contexts/RoomContext");
var _arrays = require("../utils/arrays");
/*
Copyright 2017-2024 New Vector Ltd.
Copyright 2016 Aviral Dasgupta
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const PROVIDERS = [_UserProvider.default, _RoomProvider.default, _EmojiProvider.default, _NotifProvider.default, _CommandProvider.default, _SpaceProvider.default];
// Providers will get rejected if they take longer than this.
const PROVIDER_COMPLETION_TIMEOUT = 3000;
class Autocompleter {
constructor(room, renderingType = _RoomContext.TimelineRenderingType.Room) {
(0, _defineProperty2.default)(this, "room", void 0);
(0, _defineProperty2.default)(this, "providers", void 0);
this.room = room;
this.providers = PROVIDERS.map(Prov => {
return new Prov(room, renderingType);
});
}
destroy() {
this.providers.forEach(p => {
p.destroy();
});
}
async getCompletions(query, selection, force = false, limit = -1) {
/* Note: This intentionally waits for all providers to return,
otherwise, we run into a condition where new completions are displayed
while the user is interacting with the list, which makes it difficult
to predict whether an action will actually do what is intended
*/
// list of results from each provider, each being a list of completions or null if it times out
const completionsList = await Promise.all(this.providers.map(async provider => {
return (0, _promise.timeout)(provider.getCompletions(query, selection, force, limit), null, PROVIDER_COMPLETION_TIMEOUT);
}));
// map then filter to maintain the index for the map-operation, for this.providers to line up
return (0, _arrays.filterBoolean)(completionsList.map((completions, i) => {
if (!completions || !completions.length) return;
return {
completions,
provider: this.providers[i],
/* the currently matched "command" the completer tried to complete
* we pass this through so that Autocomplete can figure out when to
* re-show itself once hidden.
*/
command: this.providers[i].getCurrentCommand(query, selection, force)
};
}));
}
}
exports.default = Autocompleter;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_CommandProvider","_interopRequireDefault","require","_RoomProvider","_UserProvider","_EmojiProvider","_NotifProvider","_promise","_SpaceProvider","_RoomContext","_arrays","PROVIDERS","UserProvider","RoomProvider","EmojiProvider","NotifProvider","CommandProvider","SpaceProvider","PROVIDER_COMPLETION_TIMEOUT","Autocompleter","constructor","room","renderingType","TimelineRenderingType","Room","_defineProperty2","default","providers","map","Prov","destroy","forEach","p","getCompletions","query","selection","force","limit","completionsList","Promise","all","provider","timeout","filterBoolean","completions","i","length","command","getCurrentCommand","exports"],"sources":["../../src/autocomplete/Autocompleter.ts"],"sourcesContent":["/*\nCopyright 2017-2024 New Vector Ltd.\nCopyright 2016 Aviral Dasgupta\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport { ReactElement } from \"react\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\n\nimport CommandProvider from \"./CommandProvider\";\nimport RoomProvider from \"./RoomProvider\";\nimport UserProvider from \"./UserProvider\";\nimport EmojiProvider from \"./EmojiProvider\";\nimport NotifProvider from \"./NotifProvider\";\nimport { timeout } from \"../utils/promise\";\nimport AutocompleteProvider, { ICommand } from \"./AutocompleteProvider\";\nimport SpaceProvider from \"./SpaceProvider\";\nimport { TimelineRenderingType } from \"../contexts/RoomContext\";\nimport { filterBoolean } from \"../utils/arrays\";\n\nexport interface ISelectionRange {\n    beginning?: boolean; // whether the selection is in the first block of the editor or not\n    start: number; // byte offset relative to the start anchor of the current editor selection.\n    end: number; // byte offset relative to the end anchor of the current editor selection.\n}\n\nexport interface ICompletion {\n    type?: \"at-room\" | \"command\" | \"community\" | \"room\" | \"user\";\n    completion: string;\n    completionId?: string;\n    component: ReactElement;\n    range: ISelectionRange;\n    command?: string;\n    suffix?: string;\n    // If provided, apply a LINK entity to the completion with the\n    // data = { url: href }.\n    href?: string;\n}\n\nconst PROVIDERS = [UserProvider, RoomProvider, EmojiProvider, NotifProvider, CommandProvider, SpaceProvider];\n\n// Providers will get rejected if they take longer than this.\nconst PROVIDER_COMPLETION_TIMEOUT = 3000;\n\nexport interface IProviderCompletions {\n    completions: ICompletion[];\n    provider: AutocompleteProvider;\n    command: Partial<ICommand>;\n}\n\nexport default class Autocompleter {\n    public room: Room;\n    public providers: AutocompleteProvider[];\n\n    public constructor(room: Room, renderingType: TimelineRenderingType = TimelineRenderingType.Room) {\n        this.room = room;\n        this.providers = PROVIDERS.map((Prov) => {\n            return new Prov(room, renderingType);\n        });\n    }\n\n    public destroy(): void {\n        this.providers.forEach((p) => {\n            p.destroy();\n        });\n    }\n\n    public async getCompletions(\n        query: string,\n        selection: ISelectionRange,\n        force = false,\n        limit = -1,\n    ): Promise<IProviderCompletions[]> {\n        /* Note: This intentionally waits for all providers to return,\n         otherwise, we run into a condition where new completions are displayed\n         while the user is interacting with the list, which makes it difficult\n         to predict whether an action will actually do what is intended\n        */\n        // list of results from each provider, each being a list of completions or null if it times out\n        const completionsList: Array<ICompletion[] | null> = await Promise.all(\n            this.providers.map(async (provider): Promise<ICompletion[] | null> => {\n                return timeout(\n                    provider.getCompletions(query, selection, force, limit),\n                    null,\n                    PROVIDER_COMPLETION_TIMEOUT,\n                );\n            }),\n        );\n\n        // map then filter to maintain the index for the map-operation, for this.providers to line up\n        return filterBoolean(\n            completionsList.map((completions, i) => {\n                if (!completions || !completions.length) return;\n\n                return {\n                    completions,\n                    provider: this.providers[i],\n\n                    /* the currently matched \"command\" the completer tried to complete\n                     * we pass this through so that Autocomplete can figure out when to\n                     * re-show itself once hidden.\n                     */\n                    command: this.providers[i].getCurrentCommand(query, selection, force),\n                };\n            }),\n        );\n    }\n}\n"],"mappings":";;;;;;;;AAWA,IAAAA,gBAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,aAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,aAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,cAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,cAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,QAAA,GAAAL,OAAA;AAEA,IAAAM,cAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,YAAA,GAAAP,OAAA;AACA,IAAAQ,OAAA,GAAAR,OAAA;AApBA;AACA;AACA;AACA;AACA;AACA;AACA;;AAmCA,MAAMS,SAAS,GAAG,CAACC,qBAAY,EAAEC,qBAAY,EAAEC,sBAAa,EAAEC,sBAAa,EAAEC,wBAAe,EAAEC,sBAAa,CAAC;;AAE5G;AACA,MAAMC,2BAA2B,GAAG,IAAI;AAQzB,MAAMC,aAAa,CAAC;EAIxBC,WAAWA,CAACC,IAAU,EAAEC,aAAoC,GAAGC,kCAAqB,CAACC,IAAI,EAAE;IAAA,IAAAC,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA;IAC9F,IAAI,CAACL,IAAI,GAAGA,IAAI;IAChB,IAAI,CAACM,SAAS,GAAGhB,SAAS,CAACiB,GAAG,CAAEC,IAAI,IAAK;MACrC,OAAO,IAAIA,IAAI,CAACR,IAAI,EAAEC,aAAa,CAAC;IACxC,CAAC,CAAC;EACN;EAEOQ,OAAOA,CAAA,EAAS;IACnB,IAAI,CAACH,SAAS,CAACI,OAAO,CAAEC,CAAC,IAAK;MAC1BA,CAAC,CAACF,OAAO,CAAC,CAAC;IACf,CAAC,CAAC;EACN;EAEA,MAAaG,cAAcA,CACvBC,KAAa,EACbC,SAA0B,EAC1BC,KAAK,GAAG,KAAK,EACbC,KAAK,GAAG,CAAC,CAAC,EACqB;IAC/B;AACR;AACA;AACA;AACA;IACQ;IACA,MAAMC,eAA4C,GAAG,MAAMC,OAAO,CAACC,GAAG,CAClE,IAAI,CAACb,SAAS,CAACC,GAAG,CAAC,MAAOa,QAAQ,IAAoC;MAClE,OAAO,IAAAC,gBAAO,EACVD,QAAQ,CAACR,cAAc,CAACC,KAAK,EAAEC,SAAS,EAAEC,KAAK,EAAEC,KAAK,CAAC,EACvD,IAAI,EACJnB,2BACJ,CAAC;IACL,CAAC,CACL,CAAC;;IAED;IACA,OAAO,IAAAyB,qBAAa,EAChBL,eAAe,CAACV,GAAG,CAAC,CAACgB,WAAW,EAAEC,CAAC,KAAK;MACpC,IAAI,CAACD,WAAW,IAAI,CAACA,WAAW,CAACE,MAAM,EAAE;MAEzC,OAAO;QACHF,WAAW;QACXH,QAAQ,EAAE,IAAI,CAACd,SAAS,CAACkB,CAAC,CAAC;QAE3B;AACpB;AACA;AACA;QACoBE,OAAO,EAAE,IAAI,CAACpB,SAAS,CAACkB,CAAC,CAAC,CAACG,iBAAiB,CAACd,KAAK,EAAEC,SAAS,EAAEC,KAAK;MACxE,CAAC;IACL,CAAC,CACL,CAAC;EACL;AACJ;AAACa,OAAA,CAAAvB,OAAA,GAAAP,aAAA","ignoreList":[]}