matrix-react-sdk
Version:
SDK for matrix.org using React
96 lines (92 loc) • 12.7 kB
JavaScript
"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"));
/*
Copyright 2019-2024 New Vector Ltd.
Copyright 2019 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class AutocompleteWrapperModel {
constructor(updateCallback, getAutocompleterComponent, updateQuery, partCreator) {
(0, _defineProperty2.default)(this, "partIndex", void 0);
this.updateCallback = updateCallback;
this.getAutocompleterComponent = getAutocompleterComponent;
this.updateQuery = updateQuery;
this.partCreator = partCreator;
}
onEscape(e) {
this.getAutocompleterComponent()?.onEscape(e);
}
close() {
this.updateCallback({
close: true
});
}
hasSelection() {
return !!this.getAutocompleterComponent()?.hasSelection();
}
hasCompletions() {
const ac = this.getAutocompleterComponent();
return !!ac && ac.countCompletions() > 0;
}
confirmCompletion() {
this.getAutocompleterComponent()?.onConfirmCompletion();
this.updateCallback({
close: true
});
}
/**
* If there is no current autocompletion, start one and move to the first selection.
*/
async startSelection() {
const acComponent = this.getAutocompleterComponent();
if (acComponent && acComponent.countCompletions() === 0) {
// Force completions to show for the text currently entered
await acComponent.forceComplete();
}
}
selectPreviousSelection() {
this.getAutocompleterComponent()?.moveSelection(-1);
}
selectNextSelection() {
this.getAutocompleterComponent()?.moveSelection(+1);
}
onPartUpdate(part, pos) {
this.partIndex = pos.index;
return this.updateQuery(part.text);
}
onComponentConfirm(completion) {
this.updateCallback({
replaceParts: this.partForCompletion(completion),
close: true
});
}
partForCompletion(completion) {
const {
completionId
} = completion;
const text = completion.completion;
switch (completion.type) {
case "room":
return [this.partCreator.roomPill(text, completionId), this.partCreator.plain(completion.suffix || "")];
case "at-room":
return [this.partCreator.atRoomPill(completionId || ""), this.partCreator.plain(completion.suffix || "")];
case "user":
// Insert suffix only if the pill is the part with index 0 - we are at the start of the composer
return this.partCreator.createMentionParts(this.partIndex === 0, text, completionId || "");
case "command":
// command needs special handling for auto complete, but also renders as plain texts
return [this.partCreator.command(text)];
default:
// used for emoji and other plain text completion replacement
return this.partCreator.plainWithEmoji(text);
}
}
}
exports.default = AutocompleteWrapperModel;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["AutocompleteWrapperModel","constructor","updateCallback","getAutocompleterComponent","updateQuery","partCreator","_defineProperty2","default","onEscape","e","close","hasSelection","hasCompletions","ac","countCompletions","confirmCompletion","onConfirmCompletion","startSelection","acComponent","forceComplete","selectPreviousSelection","moveSelection","selectNextSelection","onPartUpdate","part","pos","partIndex","index","text","onComponentConfirm","completion","replaceParts","partForCompletion","completionId","type","roomPill","plain","suffix","atRoomPill","createMentionParts","command","plainWithEmoji","exports"],"sources":["../../src/editor/autocomplete.ts"],"sourcesContent":["/*\nCopyright 2019-2024 New Vector Ltd.\nCopyright 2019 The Matrix.org Foundation C.I.C.\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 { KeyboardEvent } from \"react\";\n\nimport { Part, CommandPartCreator, PartCreator } from \"./parts\";\nimport DocumentPosition from \"./position\";\nimport { ICompletion } from \"../autocomplete/Autocompleter\";\nimport Autocomplete from \"../components/views/rooms/Autocomplete\";\n\nexport interface ICallback {\n    replaceParts?: Part[];\n    close?: boolean;\n}\n\nexport type UpdateCallback = (data: ICallback) => void;\nexport type GetAutocompleterComponent = () => Autocomplete | null;\nexport type UpdateQuery = (test: string) => Promise<void>;\n\nexport default class AutocompleteWrapperModel {\n    private partIndex?: number;\n\n    public constructor(\n        private updateCallback: UpdateCallback,\n        private getAutocompleterComponent: GetAutocompleterComponent,\n        private updateQuery: UpdateQuery,\n        private partCreator: PartCreator | CommandPartCreator,\n    ) {}\n\n    public onEscape(e: KeyboardEvent): void {\n        this.getAutocompleterComponent()?.onEscape(e);\n    }\n\n    public close(): void {\n        this.updateCallback({ close: true });\n    }\n\n    public hasSelection(): boolean {\n        return !!this.getAutocompleterComponent()?.hasSelection();\n    }\n\n    public hasCompletions(): boolean {\n        const ac = this.getAutocompleterComponent();\n        return !!ac && ac.countCompletions() > 0;\n    }\n\n    public confirmCompletion(): void {\n        this.getAutocompleterComponent()?.onConfirmCompletion();\n        this.updateCallback({ close: true });\n    }\n\n    /**\n     * If there is no current autocompletion, start one and move to the first selection.\n     */\n    public async startSelection(): Promise<void> {\n        const acComponent = this.getAutocompleterComponent();\n        if (acComponent && acComponent.countCompletions() === 0) {\n            // Force completions to show for the text currently entered\n            await acComponent.forceComplete();\n        }\n    }\n\n    public selectPreviousSelection(): void {\n        this.getAutocompleterComponent()?.moveSelection(-1);\n    }\n\n    public selectNextSelection(): void {\n        this.getAutocompleterComponent()?.moveSelection(+1);\n    }\n\n    public onPartUpdate(part: Part, pos: DocumentPosition): Promise<void> {\n        this.partIndex = pos.index;\n        return this.updateQuery(part.text);\n    }\n\n    public onComponentConfirm(completion: ICompletion): void {\n        this.updateCallback({\n            replaceParts: this.partForCompletion(completion),\n            close: true,\n        });\n    }\n\n    private partForCompletion(completion: ICompletion): Part[] {\n        const { completionId } = completion;\n        const text = completion.completion;\n        switch (completion.type) {\n            case \"room\":\n                return [this.partCreator.roomPill(text, completionId), this.partCreator.plain(completion.suffix || \"\")];\n            case \"at-room\":\n                return [\n                    this.partCreator.atRoomPill(completionId || \"\"),\n                    this.partCreator.plain(completion.suffix || \"\"),\n                ];\n            case \"user\":\n                // Insert suffix only if the pill is the part with index 0 - we are at the start of the composer\n                return this.partCreator.createMentionParts(this.partIndex === 0, text, completionId || \"\");\n            case \"command\":\n                // command needs special handling for auto complete, but also renders as plain texts\n                return [(this.partCreator as CommandPartCreator).command(text)];\n            default:\n                // used for emoji and other plain text completion replacement\n                return this.partCreator.plainWithEmoji(text);\n        }\n    }\n}\n"],"mappings":"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","ignoreList":[]}