mirror of
https://github.com/vector-im/element-web.git
synced 2026-05-27 11:00:06 +00:00
7fe8cdafe0
* Improve coverage * Add view model unit tests to improve coverage * Extract initial pure EventTile derived state helpers * Extract EventTile derived state helpers * Extract EventTile class state derivation * Extract EventTile line class derivation * Extract EventTile sender profile state * Extract EventTile avatar member selection * Extract EventTile avatar clickability state * Extract EventTile sender profile mode * Extract EventTile action bar visibility * Extract EventTile timestamp visibility * Extract EventTile timestamp selection * Extract EventTile timestamp display state * Extract ReplyChain timestamp visibility * Extract EventTile footer display state * Fix sonar issue
187 lines
6.0 KiB
TypeScript
187 lines
6.0 KiB
TypeScript
/*
|
|
* Copyright 2026 Element Creations Ltd.
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
* Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import * as DateUtils from "../../../src/DateUtils";
|
|
import { MessageTimestampViewModel } from "../../../src/viewmodels/room/timeline/event-tile/timestamp/MessageTimestampViewModel";
|
|
|
|
jest.mock("../../../src/settings/SettingsStore");
|
|
|
|
describe("MessageTimestampViewModel", () => {
|
|
// Friday Dec 17 2021, 9:09am
|
|
const nowDate = new Date("2021-12-17T08:09:00.000Z");
|
|
const HOUR_MS = 3600000;
|
|
const DAY_MS = HOUR_MS * 24;
|
|
|
|
afterEach(() => {
|
|
jest.restoreAllMocks();
|
|
});
|
|
|
|
it("should return the snapshot", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
});
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "08:09",
|
|
tsSentAt: "Fri, Dec 17, 2021, 08:09:00",
|
|
});
|
|
});
|
|
|
|
it("should return the snapshot with tsReceivedAt", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
receivedTs: nowDate.getTime() + DAY_MS,
|
|
});
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "08:09",
|
|
tsSentAt: "Fri, Dec 17, 2021, 08:09:00",
|
|
tsReceivedAt: "Sat, Dec 18, 2021, 08:09:00",
|
|
});
|
|
});
|
|
|
|
it("should return the snapshot without presentation class names", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
});
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "08:09",
|
|
tsSentAt: "Fri, Dec 17, 2021, 08:09:00",
|
|
});
|
|
});
|
|
|
|
it("should use formatRelativeTime when showRelative is true", () => {
|
|
jest.spyOn(DateUtils, "formatFullDate").mockReturnValue("SENT_AT");
|
|
const formatRelativeTimeSpy = jest.spyOn(DateUtils, "formatRelativeTime").mockReturnValue("RELATIVE");
|
|
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
showRelative: true,
|
|
showTwelveHour: true,
|
|
});
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "RELATIVE",
|
|
tsSentAt: "SENT_AT",
|
|
});
|
|
expect(formatRelativeTimeSpy).toHaveBeenCalledWith(expect.any(Date), true);
|
|
});
|
|
|
|
it("should use full date when showFullDate is true and respect showSeconds", () => {
|
|
const formatFullDateSpy = jest
|
|
.spyOn(DateUtils, "formatFullDate")
|
|
.mockImplementation((_date, _showTwelveHour, showSeconds) =>
|
|
showSeconds === false ? "FULL_NO_SECONDS" : "SENT_AT",
|
|
);
|
|
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
showFullDate: true,
|
|
showSeconds: false,
|
|
});
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "FULL_NO_SECONDS",
|
|
tsSentAt: "SENT_AT",
|
|
});
|
|
expect(formatFullDateSpy).toHaveBeenCalled();
|
|
});
|
|
|
|
it("should use full time when showSeconds is true without full date", () => {
|
|
jest.spyOn(DateUtils, "formatFullDate").mockReturnValue("SENT_AT");
|
|
const formatFullTimeSpy = jest.spyOn(DateUtils, "formatFullTime").mockReturnValue("FULL_TIME");
|
|
const formatTimeSpy = jest.spyOn(DateUtils, "formatTime").mockReturnValue("TIME");
|
|
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
showSeconds: true,
|
|
});
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "FULL_TIME",
|
|
tsSentAt: "SENT_AT",
|
|
});
|
|
expect(formatFullTimeSpy).toHaveBeenCalled();
|
|
expect(formatTimeSpy).not.toHaveBeenCalled();
|
|
});
|
|
|
|
it("should include tooltip inhibition and href in the snapshot", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
inhibitTooltip: true,
|
|
href: "https://example.test",
|
|
});
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
inhibitTooltip: true,
|
|
href: "https://example.test",
|
|
});
|
|
});
|
|
|
|
it("updates the timestamp and received timestamp", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
});
|
|
|
|
vm.setTimestamp(nowDate.getTime() + HOUR_MS);
|
|
vm.setReceivedTimestamp(nowDate.getTime() + DAY_MS);
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "09:09",
|
|
tsSentAt: "Fri, Dec 17, 2021, 09:09:00",
|
|
tsReceivedAt: "Sat, Dec 18, 2021, 08:09:00",
|
|
});
|
|
});
|
|
|
|
it("updates display options", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
});
|
|
|
|
vm.setDisplayOptions({
|
|
showTwelveHour: true,
|
|
showSeconds: true,
|
|
});
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
ts: "8:09:00 AM",
|
|
tsSentAt: "Fri, Dec 17, 2021, 8:09:00 AM",
|
|
});
|
|
});
|
|
|
|
it("updates tooltip, href, and handlers", () => {
|
|
const onClick = jest.fn();
|
|
const onContextMenu = jest.fn();
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
});
|
|
|
|
vm.setTooltipInhibited(true);
|
|
vm.setHref("https://example.test/event");
|
|
vm.setHandlers({ onClick, onContextMenu });
|
|
|
|
expect(vm.getSnapshot()).toMatchObject({
|
|
inhibitTooltip: true,
|
|
href: "https://example.test/event",
|
|
});
|
|
expect(vm.onClick).toBe(onClick);
|
|
expect(vm.onContextMenu).toBe(onContextMenu);
|
|
});
|
|
|
|
it("does not emit an update when props are unchanged", () => {
|
|
const vm = new MessageTimestampViewModel({
|
|
ts: nowDate.getTime(),
|
|
href: "https://example.test/event",
|
|
});
|
|
const listener = jest.fn();
|
|
vm.subscribe(listener);
|
|
|
|
vm.setTimestamp(nowDate.getTime());
|
|
vm.setHref("https://example.test/event");
|
|
|
|
expect(listener).not.toHaveBeenCalled();
|
|
});
|
|
});
|