Differentiate between rooms and room aliases

This commit is contained in:
Danila Fedorin 2021-09-01 10:11:19 -07:00
parent 5f5359ae65
commit 3802829557
1 changed files with 13 additions and 6 deletions

View File

@ -15,7 +15,7 @@ limitations under the License.
*/ */
import {TemplateView} from "./utils/TemplateView.js"; import {TemplateView} from "./utils/TemplateView.js";
import {LinkKind} from "./Link.js"; import {LinkKind, IdentifierKind} from "./Link.js";
export class InvalidUrlView extends TemplateView { export class InvalidUrlView extends TemplateView {
render(t, vm) { render(t, vm) {
@ -29,12 +29,16 @@ export class InvalidUrlView extends TemplateView {
]); ]);
} }
_describeLinkKind(kind) { _describeRoom(identifierKind) {
switch (kind) { return identifierKind === IdentifierKind.RoomAlias ? "room alias" : "room";
case LinkKind.Room: return "The room "; }
_describeLinkKind(linkKind, identifierKind) {
switch (linkKind) {
case LinkKind.Room: return `The ${this._describeRoom(identifierKind)} `;
case LinkKind.User: return "The user "; case LinkKind.User: return "The user ";
case LinkKind.Group: return "The group "; case LinkKind.Group: return "The group ";
case LinkKind.Event: return "An event in room "; case LinkKind.Event: return `An event in ${this._describeRoom(identifierKind)} `;
} }
} }
@ -42,7 +46,10 @@ export class InvalidUrlView extends TemplateView {
return t.p([ return t.p([
'Did you mean any of the following?', 'Did you mean any of the following?',
t.ul(validFixes.map(fix => t.ul(validFixes.map(fix =>
t.li([this._describeLinkKind(fix.link.kind), t.a({ href: fix.url }, fix.link.identifier)]) t.li([
this._describeLinkKind(fix.link.kind, fix.link.identifierKind),
t.a({ href: fix.url }, fix.link.identifier)
])
)) ))
]); ]);
} }