-
-
Notifications
You must be signed in to change notification settings - Fork 99
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(forums): rewrite viewtopic page in React #3205
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Something about http://localhost:64000/forums/topic/28943?page=2 is causing it to not render.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
> | ||
{t('Edit')} | ||
</a> | ||
) : null} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[url=] at end of [spoiler] is falling outside of spoiler.
[url=] in [spoiler] is not being evaluated.
http://localhost:64000/viewtopic.php?t=29236&c=262386#262386
http://localhost:64000/forums/topic/29236?comment=262386#262386
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch. This proved exceptionally difficult to debug and fix.
The root cause of the issue is the first spoiler tag in the post, which contains placeholders.
I discovered the following input worked great:
content here
[spoiler]
[ach=9]
[game=14492]
[url=https://google.com]My Link[/url]
[/spoiler]
However, this input made things go off the rails:
content here
[spoiler]
[ach=]
[url=]Link[/url]
[/spoiler]
[spoiler]
[ach=9]
[game=14492]
[url=https://google.com]My Link[/url]
[/spoiler]
The 3rd party <BBCode />
component seems overly greedy towards the "placeholder" tags. Despite my efforts, I couldn't get it to ignore trying to process them.
To work around the issue, I made some changes to the postprocessor to trick <BBCode />
into not processing these placeholders. When the postprocessor sees a placeholder like [ach=]
, it now converts it to [text]{ach=}[/text]
. A new <ShortcodeText />
component then converts the content back to plain text: "[ach=]".
This is a lot of arm wrestling to get things to work, so I made sure it's well-covered by tests.
<> | ||
<SEO title={forumTopic.title as TranslatedString} description={description} /> | ||
|
||
<AppLayout.Main> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Surprisingly, it appears this is how the forum title is literally stored in the database (check the forums
table). We should probably manually update the title to "RA em Português!".
This PR rewrites the viewtopic.php in React. Like other PRs involving shortcodes, viewtopic.php and the new React UI coexist on this branch, with the intention of removing viewtopic.php in an immediate followup.
How to test this PR:
In the follow-up PR, I will also add comprehensive redirect logic to ensure old URLs link to the correct new route.
Behaviors to verify:
?page
query param.All of this logic should be covered by tests, but it's all probably worth a routine spot check. For the time being, I tried to do as close to a 1:1 migration as I could, avoiding any major behavior changes.
Before
data:image/s3,"s3://crabby-images/d4830/d48305760693b35ed0f405b0ba1a30901d64e982" alt="Screenshot 2025-02-10 at 7 19 42 PM"
After
data:image/s3,"s3://crabby-images/bf5b7/bf5b78c864957d4c831d6dc162b722c026e69fc8" alt="Screenshot 2025-02-10 at 7 19 14 PM"