UNPKG

matrix-react-sdk

Version:
71 lines (66 loc) 12.1 kB
"use strict"; 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":[]}