From d6304b2b52d99f61e082c57da7a40de529d1f63a Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Rafa=C5=82=20Ca=C5=82ka?=
<25438601+rafaucau@users.noreply.github.com>
Date: Thu, 5 Dec 2024 11:06:40 +0100
Subject: [PATCH] refactor(optional-policies): convert AcceptPoliciesModal to
JSX
---
.../forum/components/AcceptPoliciesModal.js | 146 +++++++++---------
resources/locale/en.yml | 2 +-
2 files changed, 70 insertions(+), 78 deletions(-)
diff --git a/js/src/forum/components/AcceptPoliciesModal.js b/js/src/forum/components/AcceptPoliciesModal.js
index b7ebc5c..e9e409b 100644
--- a/js/src/forum/components/AcceptPoliciesModal.js
+++ b/js/src/forum/components/AcceptPoliciesModal.js
@@ -23,7 +23,7 @@ export default class AcceptPoliciesModal extends Modal {
}
content() {
- return m('.Modal-body', this.body());
+ return
{this.body()}
;
}
body() {
@@ -36,91 +36,83 @@ export default class AcceptPoliciesModal extends Modal {
);
if (policies.length === 0) {
- return Button.component(
- {
- className: 'Button',
- onclick() {
+ return (
+ {
app.modal.close();
- },
- },
- app.translator.trans('fof-terms.forum.accept-modal.close')
+ }}
+ >
+ {app.translator.trans('fof-terms.forum.accept-modal.close')}
+
);
}
- return policies.map((policy) =>
- m('div', [
- m('h2', policy.name()),
- app.forum.attribute('fof-terms.hide-updated-at')
- ? null
- : m(
- 'p',
- policy.terms_updated_at()
- ? app.translator.trans('fof-terms.forum.accept-modal.updated-at', {
- date: dayjs(policy.terms_updated_at()).format(app.forum.attribute('fof-terms.date-format')),
- })
- : app.translator.trans('fof-terms.forum.accept-modal.updated-recently')
- ),
- policy.update_message() ? m('p', policy.update_message()) : null,
- m(
- '.Form-group',
- m(
- '.FoF-Terms-Check.FoF-Terms-Check--login',
- m('label.checkbox', [
- m('input', {
- type: 'checkbox',
- checked: this[policy.form_key()],
- onchange: () => {
+ return policies.map((policy) => (
+
+
{policy.name()}
+ {app.forum.attribute('fof-terms.hide-updated-at') ? null : (
+
+ {policy.terms_updated_at()
+ ? app.translator.trans('fof-terms.forum.accept-modal.updated-at', {
+ date: dayjs(policy.terms_updated_at()).format(app.forum.attribute('fof-terms.date-format')),
+ })
+ : app.translator.trans('fof-terms.forum.accept-modal.updated-recently')}
+
+ )}
+ {policy.update_message() ?
{policy.update_message()}
: null}
+
+
+
+ {
this[policy.form_key()] = !this[policy.form_key()];
- },
- }),
- app.translator.trans('fof-terms.forum.accept-modal.i-accept', {
+ }}
+ />
+ {app.translator.trans('fof-terms.forum.accept-modal.i-accept', {
policy: policy.name(),
- a: policy.url()
- ? m('a', {
- href: policy.url(),
- target: '_blank',
- })
- : m('span'),
- }),
- ])
- )
- ),
- Button.component(
- {
- className: 'Button Button--primary',
- disabled: !this[policy.form_key()] && !policy.optional(),
- onclick: () => {
- // We need to save the "must accept" property before performing the request
- // Because an updated user serializer will be returned
- const hadToAcceptToInteract = app.session.user.fofTermsPoliciesMustAccept();
+ a: policy.url() ? : ,
+ })}
+
+
+
+
{
+ // We need to save the "must accept" property before performing the request
+ // Because an updated user serializer will be returned
+ const hadToAcceptToInteract = app.session.user.fofTermsPoliciesMustAccept();
- app
- .request({
- url: app.forum.attribute('apiUrl') + policy.apiEndpoint() + (this[policy.form_key()] ? '/accept' : '/decline'),
- method: 'POST',
- errorHandler: this.onerror.bind(this),
- })
- .then((updated) => {
- app.store.pushPayload(updated);
+ app
+ .request({
+ url: app.forum.attribute('apiUrl') + policy.apiEndpoint() + (this[policy.form_key()] ? '/accept' : '/decline'),
+ method: 'POST',
+ errorHandler: this.onerror.bind(this),
+ })
+ .then((updated) => {
+ app.store.pushPayload(updated);
- // If this was the last policy to accept, close the modal
- if (policies.length === 1) {
- if (hadToAcceptToInteract) {
- // If the user was previously not allowed to interact with the forum,
- // we refresh to get updated permissions in the frontend
- window.location.reload();
- } else {
- app.modal.close();
- }
+ // If this was the last policy to accept, close the modal
+ if (policies.length === 1) {
+ if (hadToAcceptToInteract) {
+ // If the user was previously not allowed to interact with the forum,
+ // we refresh to get updated permissions in the frontend
+ window.location.reload();
+ } else {
+ app.modal.close();
}
+ }
- m.redraw();
- });
- },
- },
- app.translator.trans('fof-terms.forum.accept-modal.accept')
- ),
- ])
- );
+ m.redraw();
+ });
+ }}
+ >
+ {app.translator.trans('fof-terms.forum.accept-modal.accept')}
+
+
+ ));
}
}
diff --git a/resources/locale/en.yml b/resources/locale/en.yml
index 49d35d5..d878bad 100644
--- a/resources/locale/en.yml
+++ b/resources/locale/en.yml
@@ -71,7 +71,7 @@ fof-terms:
update-alert:
must-accept-message: We've temporarily restricted access to your account while you check out the new terms.
- can-accept-message: We recently updated the terms. You can accept them to continue using this website.
+ can-accept-message: We recently updated the terms. You must accept them to continue using this website.
review: Click here to review and accept the new terms
close: Close