--- /dev/null
+<script>
+ export let actions;
+
+ import { _ } from 'svelte-i18n';
+</script>
+
+<li>
+ <a href="/reply/{actions.id}" title={$_('header.action.reply.title')}>
+ {@html $_('header.action.reply.display')}
+ </a>
+</li>
+
+<style>
+ li {
+ display: inline;
+ margin: 5px;
+ }
+
+ a {
+ text-decoration: none;
+ line-height: 3em;
+ display: inline-block;
+ }
+</style>
--- /dev/null
+import '@testing-library/jest-dom/extend-expect';
+
+import { render } from '@testing-library/svelte';
+import '$/config/i18n';
+
+import Topic from './topic.svelte';
+
+const internals = {
+ results: null
+};
+
+describe('Topic Actions component', () => {
+
+ test('Should link to reply page', () => {
+
+ const results = render(Topic, { props: {
+ actions: {
+ id: '8ebaa211-fd9b-423a-8b4f-b57622007fde'
+ }
+ } });
+
+ expect(results.getByTitle('Reply').closest('a'))
+ .toHaveAttribute('href', '/reply/8ebaa211-fd9b-423a-8b4f-b57622007fde');
+ });
+});
<script>
import { _ } from 'svelte-i18n';
import { version } from '$/config/config';
- import { actions } from '$/stores/actions';
-
- $: topic_id = $actions.topic_id;
+ import { topicActions } from '$/stores/actions';
+ import TopicActions from '$/components/actions/topic.svelte';
</script>
<header title={$_('header.title')}>
<ul>
<li>
<strong
- ><a href="/" aria-label={$_('header.long_version', { values: { version } })}
+ ><a href="/" title={$_('header.long_version', { values: { version } })}
>{$_('header.short_version', { values: { version } })}</a
></strong
>
</li>
<li>
- <a href="/new" aria-label={$_('header.action.new.title')}
+ <a href="/new" title={$_('header.action.new.title')}
>{@html $_('header.action.new.display')}</a
>
</li>
- {#if topic_id}
- <li>
- <a href="/reply/{topic_id}" aria-label={$_('header.action.reply.title')}
- >{@html $_('header.action.reply.display')}</a
- >
- </li>
+ {#if $topicActions}
+ <TopicActions actions={$topicActions} />
{/if}
<li>
- <a href="/search" aria-label={$_('header.action.search.title')}
+ <a href="/search" title={$_('header.action.search.title')}
>{@html $_('header.action.search.display')}</a
>
</li>
<li>
- <a href="/logout" aria-label={$_('header.action.log_out.title')}
+ <a href="/logout" title={$_('header.action.log_out.title')}
>{@html $_('header.action.log_out.display')}</a
>
</li>
--- /dev/null
+import '@testing-library/jest-dom/extend-expect';
+
+import { render } from '@testing-library/svelte';
+import '$/config/i18n';
+import { enableTopicActions } from '$/stores/actions';
+
+import Header from './header.svelte';
+
+describe('Header component', () => {
+
+ test('Should not display topic if action is not set', () => {
+
+ const results = render(Header);
+
+ expect(results.queryByTitle('Reply'))
+ .toBe(null);
+ });
+
+ test('Should display topic if action is set', () => {
+
+ enableTopicActions('d138d6d8-e669-42e7-995d-20a7fcc176f5');
+ const results = render(Header);
+
+ expect(results.getByTitle('Reply'))
+ .toBeVisible();
+ });
+});
version: packageVersion
};
-export const socketServer = import.meta.env.FORUM_SOCKET_SERVER;
-
export const version = packageVersion;
-import { writable } from 'svelte/store';
+import { derived, writable } from 'svelte/store';
/*
* This is a store to set the actions in the top header.
actions.update((actionsValue) => {
- actionsValue.topic_id = id;
+ actionsValue.topic = {
+ id
+ };
return actionsValue;
});
};
actions.update((actionsValue) => {
- delete actionsValue.id;
+ delete actionsValue.topic;
return actionsValue;
});
};
+
+export const topicActions = derived(
+ actions,
+ ($actions) => $actions.topic
+);