matrix-react-sdk
Version:
SDK for matrix.org using React
105 lines (102 loc) • 15.3 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 _react = _interopRequireDefault(require("react"));
var _languageHandler = require("../languageHandler");
var _AutocompleteProvider = _interopRequireDefault(require("./AutocompleteProvider"));
var _QueryMatcher = _interopRequireDefault(require("./QueryMatcher"));
var _Components = require("./Components");
var _SlashCommands = require("../SlashCommands");
var _MatrixClientPeg = require("../MatrixClientPeg");
/*
Copyright 2024 New Vector Ltd.
Copyright 2018 Michael Telatynski <7t3chguy@gmail.com>
Copyright 2017 Vector Creations Ltd
Copyright 2017 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 COMMAND_RE = /(^\/\w*)(?: .*)?/g;
class CommandProvider extends _AutocompleteProvider.default {
constructor(room, renderingType) {
super({
commandRegex: COMMAND_RE,
renderingType
});
(0, _defineProperty2.default)(this, "matcher", void 0);
this.matcher = new _QueryMatcher.default(_SlashCommands.Commands, {
keys: ["command", "args", "description"],
funcs: [({
aliases
}) => aliases.join(" ")],
// aliases
context: renderingType
});
}
async getCompletions(query, selection, force, limit = -1) {
const {
command,
range
} = this.getCurrentCommand(query, selection);
if (!command) return [];
const cli = _MatrixClientPeg.MatrixClientPeg.get();
let matches = [];
// check if the full match differs from the first word (i.e. returns false if the command has args)
if (command[0] !== command[1]) {
// The input looks like a command with arguments, perform exact match
const name = command[1].slice(1); // strip leading `/`
if (_SlashCommands.CommandMap.has(name) && _SlashCommands.CommandMap.get(name).isEnabled(cli)) {
// some commands, namely `me` don't suit having the usage shown whilst typing their arguments
if (_SlashCommands.CommandMap.get(name).hideCompletionAfterSpace) return [];
matches = [_SlashCommands.CommandMap.get(name)];
}
} else {
if (query === "/") {
// If they have just entered `/` show everything
// We exclude the limit on purpose to have a comprehensive list
matches = _SlashCommands.Commands;
} else {
// otherwise fuzzy match against all of the fields
matches = this.matcher.match(command[1], limit);
}
}
return matches.filter(cmd => {
const display = !cmd.renderingTypes || cmd.renderingTypes.includes(this.renderingType);
return cmd.isEnabled(cli) && display;
}).map(result => {
let completion = result.getCommand() + " ";
const usedAlias = result.aliases.find(alias => `/${alias}` === command[1]);
// If the command (or an alias) is the same as the one they entered, we don't want to discard their arguments
if (usedAlias || result.getCommand() === command[1]) {
completion = command[0];
}
return {
completion,
type: "command",
component: /*#__PURE__*/_react.default.createElement(_Components.TextualCompletion, {
title: `/${usedAlias || result.command}`,
subtitle: result.args,
description: (0, _languageHandler._t)(result.description)
}),
range: range
};
});
}
getName() {
return "*️⃣ " + (0, _languageHandler._t)("composer|autocomplete|command_description");
}
renderCompletions(completions) {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Autocomplete_Completion_container_pill",
role: "presentation",
"aria-label": (0, _languageHandler._t)("composer|autocomplete|command_a11y")
}, completions);
}
}
exports.default = CommandProvider;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_AutocompleteProvider","_QueryMatcher","_Components","_SlashCommands","_MatrixClientPeg","COMMAND_RE","CommandProvider","AutocompleteProvider","constructor","room","renderingType","commandRegex","_defineProperty2","default","matcher","QueryMatcher","Commands","keys","funcs","aliases","join","context","getCompletions","query","selection","force","limit","command","range","getCurrentCommand","cli","MatrixClientPeg","get","matches","name","slice","CommandMap","has","isEnabled","hideCompletionAfterSpace","match","filter","cmd","display","renderingTypes","includes","map","result","completion","getCommand","usedAlias","find","alias","type","component","createElement","TextualCompletion","title","subtitle","args","description","_t","getName","renderCompletions","completions","className","role","exports"],"sources":["../../src/autocomplete/CommandProvider.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2018 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2017 Vector Creations Ltd\nCopyright 2017 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 React from \"react\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\n\nimport { _t } from \"../languageHandler\";\nimport AutocompleteProvider from \"./AutocompleteProvider\";\nimport QueryMatcher from \"./QueryMatcher\";\nimport { TextualCompletion } from \"./Components\";\nimport { ICompletion, ISelectionRange } from \"./Autocompleter\";\nimport { Command, Commands, CommandMap } from \"../SlashCommands\";\nimport { TimelineRenderingType } from \"../contexts/RoomContext\";\nimport { MatrixClientPeg } from \"../MatrixClientPeg\";\n\nconst COMMAND_RE = /(^\\/\\w*)(?: .*)?/g;\n\nexport default class CommandProvider extends AutocompleteProvider {\n    public matcher: QueryMatcher<Command>;\n\n    public constructor(room: Room, renderingType?: TimelineRenderingType) {\n        super({ commandRegex: COMMAND_RE, renderingType });\n        this.matcher = new QueryMatcher(Commands, {\n            keys: [\"command\", \"args\", \"description\"],\n            funcs: [({ aliases }) => aliases.join(\" \")], // aliases\n            context: renderingType,\n        });\n    }\n\n    public async getCompletions(\n        query: string,\n        selection: ISelectionRange,\n        force?: boolean,\n        limit = -1,\n    ): Promise<ICompletion[]> {\n        const { command, range } = this.getCurrentCommand(query, selection);\n        if (!command) return [];\n\n        const cli = MatrixClientPeg.get();\n\n        let matches: Command[] = [];\n        // check if the full match differs from the first word (i.e. returns false if the command has args)\n        if (command[0] !== command[1]) {\n            // The input looks like a command with arguments, perform exact match\n            const name = command[1].slice(1); // strip leading `/`\n            if (CommandMap.has(name) && CommandMap.get(name)!.isEnabled(cli)) {\n                // some commands, namely `me` don't suit having the usage shown whilst typing their arguments\n                if (CommandMap.get(name)!.hideCompletionAfterSpace) return [];\n                matches = [CommandMap.get(name)!];\n            }\n        } else {\n            if (query === \"/\") {\n                // If they have just entered `/` show everything\n                // We exclude the limit on purpose to have a comprehensive list\n                matches = Commands;\n            } else {\n                // otherwise fuzzy match against all of the fields\n                matches = this.matcher.match(command[1], limit);\n            }\n        }\n\n        return matches\n            .filter((cmd) => {\n                const display = !cmd.renderingTypes || cmd.renderingTypes.includes(this.renderingType);\n                return cmd.isEnabled(cli) && display;\n            })\n            .map((result) => {\n                let completion = result.getCommand() + \" \";\n                const usedAlias = result.aliases.find((alias) => `/${alias}` === command[1]);\n                // If the command (or an alias) is the same as the one they entered, we don't want to discard their arguments\n                if (usedAlias || result.getCommand() === command[1]) {\n                    completion = command[0];\n                }\n\n                return {\n                    completion,\n                    type: \"command\",\n                    component: (\n                        <TextualCompletion\n                            title={`/${usedAlias || result.command}`}\n                            subtitle={result.args}\n                            description={_t(result.description)}\n                        />\n                    ),\n                    range: range!,\n                };\n            });\n    }\n\n    public getName(): string {\n        return \"*️⃣ \" + _t(\"composer|autocomplete|command_description\");\n    }\n\n    public renderCompletions(completions: React.ReactNode[]): React.ReactNode {\n        return (\n            <div\n                className=\"mx_Autocomplete_Completion_container_pill\"\n                role=\"presentation\"\n                aria-label={_t(\"composer|autocomplete|command_a11y\")}\n            >\n                {completions}\n            </div>\n        );\n    }\n}\n"],"mappings":";;;;;;;;AAWA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAGA,IAAAC,gBAAA,GAAAD,OAAA;AACA,IAAAE,qBAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,aAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,WAAA,GAAAJ,OAAA;AAEA,IAAAK,cAAA,GAAAL,OAAA;AAEA,IAAAM,gBAAA,GAAAN,OAAA;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAcA,MAAMO,UAAU,GAAG,mBAAmB;AAEvB,MAAMC,eAAe,SAASC,6BAAoB,CAAC;EAGvDC,WAAWA,CAACC,IAAU,EAAEC,aAAqC,EAAE;IAClE,KAAK,CAAC;MAAEC,YAAY,EAAEN,UAAU;MAAEK;IAAc,CAAC,CAAC;IAAC,IAAAE,gBAAA,CAAAC,OAAA;IACnD,IAAI,CAACC,OAAO,GAAG,IAAIC,qBAAY,CAACC,uBAAQ,EAAE;MACtCC,IAAI,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,aAAa,CAAC;MACxCC,KAAK,EAAE,CAAC,CAAC;QAAEC;MAAQ,CAAC,KAAKA,OAAO,CAACC,IAAI,CAAC,GAAG,CAAC,CAAC;MAAE;MAC7CC,OAAO,EAAEX;IACb,CAAC,CAAC;EACN;EAEA,MAAaY,cAAcA,CACvBC,KAAa,EACbC,SAA0B,EAC1BC,KAAe,EACfC,KAAK,GAAG,CAAC,CAAC,EACY;IACtB,MAAM;MAAEC,OAAO;MAAEC;IAAM,CAAC,GAAG,IAAI,CAACC,iBAAiB,CAACN,KAAK,EAAEC,SAAS,CAAC;IACnE,IAAI,CAACG,OAAO,EAAE,OAAO,EAAE;IAEvB,MAAMG,GAAG,GAAGC,gCAAe,CAACC,GAAG,CAAC,CAAC;IAEjC,IAAIC,OAAkB,GAAG,EAAE;IAC3B;IACA,IAAIN,OAAO,CAAC,CAAC,CAAC,KAAKA,OAAO,CAAC,CAAC,CAAC,EAAE;MAC3B;MACA,MAAMO,IAAI,GAAGP,OAAO,CAAC,CAAC,CAAC,CAACQ,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;MAClC,IAAIC,yBAAU,CAACC,GAAG,CAACH,IAAI,CAAC,IAAIE,yBAAU,CAACJ,GAAG,CAACE,IAAI,CAAC,CAAEI,SAAS,CAACR,GAAG,CAAC,EAAE;QAC9D;QACA,IAAIM,yBAAU,CAACJ,GAAG,CAACE,IAAI,CAAC,CAAEK,wBAAwB,EAAE,OAAO,EAAE;QAC7DN,OAAO,GAAG,CAACG,yBAAU,CAACJ,GAAG,CAACE,IAAI,CAAC,CAAE;MACrC;IACJ,CAAC,MAAM;MACH,IAAIX,KAAK,KAAK,GAAG,EAAE;QACf;QACA;QACAU,OAAO,GAAGjB,uBAAQ;MACtB,CAAC,MAAM;QACH;QACAiB,OAAO,GAAG,IAAI,CAACnB,OAAO,CAAC0B,KAAK,CAACb,OAAO,CAAC,CAAC,CAAC,EAAED,KAAK,CAAC;MACnD;IACJ;IAEA,OAAOO,OAAO,CACTQ,MAAM,CAAEC,GAAG,IAAK;MACb,MAAMC,OAAO,GAAG,CAACD,GAAG,CAACE,cAAc,IAAIF,GAAG,CAACE,cAAc,CAACC,QAAQ,CAAC,IAAI,CAACnC,aAAa,CAAC;MACtF,OAAOgC,GAAG,CAACJ,SAAS,CAACR,GAAG,CAAC,IAAIa,OAAO;IACxC,CAAC,CAAC,CACDG,GAAG,CAAEC,MAAM,IAAK;MACb,IAAIC,UAAU,GAAGD,MAAM,CAACE,UAAU,CAAC,CAAC,GAAG,GAAG;MAC1C,MAAMC,SAAS,GAAGH,MAAM,CAAC5B,OAAO,CAACgC,IAAI,CAAEC,KAAK,IAAK,IAAIA,KAAK,EAAE,KAAKzB,OAAO,CAAC,CAAC,CAAC,CAAC;MAC5E;MACA,IAAIuB,SAAS,IAAIH,MAAM,CAACE,UAAU,CAAC,CAAC,KAAKtB,OAAO,CAAC,CAAC,CAAC,EAAE;QACjDqB,UAAU,GAAGrB,OAAO,CAAC,CAAC,CAAC;MAC3B;MAEA,OAAO;QACHqB,UAAU;QACVK,IAAI,EAAE,SAAS;QACfC,SAAS,eACL1D,MAAA,CAAAiB,OAAA,CAAA0C,aAAA,CAACrD,WAAA,CAAAsD,iBAAiB;UACdC,KAAK,EAAE,IAAIP,SAAS,IAAIH,MAAM,CAACpB,OAAO,EAAG;UACzC+B,QAAQ,EAAEX,MAAM,CAACY,IAAK;UACtBC,WAAW,EAAE,IAAAC,mBAAE,EAACd,MAAM,CAACa,WAAW;QAAE,CACvC,CACJ;QACDhC,KAAK,EAAEA;MACX,CAAC;IACL,CAAC,CAAC;EACV;EAEOkC,OAAOA,CAAA,EAAW;IACrB,OAAO,MAAM,GAAG,IAAAD,mBAAE,EAAC,2CAA2C,CAAC;EACnE;EAEOE,iBAAiBA,CAACC,WAA8B,EAAmB;IACtE,oBACIpE,MAAA,CAAAiB,OAAA,CAAA0C,aAAA;MACIU,SAAS,EAAC,2CAA2C;MACrDC,IAAI,EAAC,cAAc;MACnB,cAAY,IAAAL,mBAAE,EAAC,oCAAoC;IAAE,GAEpDG,WACA,CAAC;EAEd;AACJ;AAACG,OAAA,CAAAtD,OAAA,GAAAP,eAAA","ignoreList":[]}