mirror of
				https://github.com/ae-utbm/sith.git
				synced 2025-10-25 14:13:53 +00:00 
			
		
		
		
	Close alerts related to a moderated event
This commit is contained in:
		| @@ -1,5 +1,5 @@ | |||||||
| import { exportToHtml } from "#core:utils/globals"; | import { exportToHtml } from "#core:utils/globals"; | ||||||
| import { newsDeleteNews, newsModerateNews } from "#openapi"; | import { newsDeleteNews, newsFetchNewsDates, newsModerateNews } from "#openapi"; | ||||||
|  |  | ||||||
| // This will be used in jinja templates, | // This will be used in jinja templates, | ||||||
| // so we cannot use real enums as those are purely an abstraction of Typescript | // so we cannot use real enums as those are purely an abstraction of Typescript | ||||||
| @@ -24,6 +24,7 @@ document.addEventListener("alpine:init", () => { | |||||||
|       // biome-ignore lint/style/useNamingConvention: api is snake case |       // biome-ignore lint/style/useNamingConvention: api is snake case | ||||||
|       await newsModerateNews({ path: { news_id: this.newsId } }); |       await newsModerateNews({ path: { news_id: this.newsId } }); | ||||||
|       this.state = AlertState.MODERATED; |       this.state = AlertState.MODERATED; | ||||||
|  |       this.$dispatch("news-moderated", { newsId: this.newsId, state: this.state }); | ||||||
|       this.loading = false; |       this.loading = false; | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
| @@ -32,7 +33,36 @@ document.addEventListener("alpine:init", () => { | |||||||
|       // biome-ignore lint/style/useNamingConvention: api is snake case |       // biome-ignore lint/style/useNamingConvention: api is snake case | ||||||
|       await newsDeleteNews({ path: { news_id: this.newsId } }); |       await newsDeleteNews({ path: { news_id: this.newsId } }); | ||||||
|       this.state = AlertState.DELETED; |       this.state = AlertState.DELETED; | ||||||
|  |       this.$dispatch("news-moderated", { newsId: this.newsId, state: this.state }); | ||||||
|       this.loading = false; |       this.loading = false; | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Event receiver for when news dates are moderated. | ||||||
|  |      * | ||||||
|  |      * If the moderated date is linked to the same news | ||||||
|  |      * as the one this moderation alert is attached to, | ||||||
|  |      * then set the alert state to the same as the moderated one. | ||||||
|  |      */ | ||||||
|  |     dispatchModeration(event: CustomEvent) { | ||||||
|  |       if (event.detail.newsId === this.newsId) { | ||||||
|  |         this.state = event.detail.state; | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Query the server to know the number of news dates that would be moderated | ||||||
|  |      * if this one is moderated. | ||||||
|  |      */ | ||||||
|  |     async nbModerated() { | ||||||
|  |       // What we want here is the count attribute of the response. | ||||||
|  |       // We don't care about the actual results, | ||||||
|  |       // so we ask for the minimum page size possible. | ||||||
|  |       const response = await newsFetchNewsDates({ | ||||||
|  |         // biome-ignore lint/style/useNamingConvention: api is snake-case | ||||||
|  |         query: { news_id: this.newsId, page: 1, page_size: 1 }, | ||||||
|  |       }); | ||||||
|  |       return response.data.count; | ||||||
|  |     }, | ||||||
|   })); |   })); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -6,15 +6,41 @@ | |||||||
|     the given `alpineState` variable. |     the given `alpineState` variable. | ||||||
|     This state is a `AlertState`, as defined in `moderation-alert-index.ts` |     This state is a `AlertState`, as defined in `moderation-alert-index.ts` | ||||||
|  |  | ||||||
|     Example : |     This comes in three flavours : | ||||||
|  |     - You can pass the `News` object itself to the macro. | ||||||
|  |       In this case, if `request.user` can moderate news, | ||||||
|  |       it will perform an additional db query to know if it is a recurring event. | ||||||
|  |     - You can also give only the news id. | ||||||
|  |       In this case, a server request will be issued to know | ||||||
|  |       if it is a recurring event. | ||||||
|  |     - Finally, you can pass the name of an alpine variable, which value is the id. | ||||||
|  |       In this case, a server request will be issued to know | ||||||
|  |       if it is a recurring event. | ||||||
|  |  | ||||||
|  |     Example with full `News` object : | ||||||
|     ```jinja |     ```jinja | ||||||
|     <div x-data="{state: AlertState.PENDING}"> |     <div x-data="{state: AlertState.PENDING}"> | ||||||
|       {{ news_moderation_alert(news, user, "state") }} |       {{ news_moderation_alert(news, user, "state") }} | ||||||
|     </div> |     </div> | ||||||
|     ``` |     ``` | ||||||
|  |     With an id : | ||||||
|  |     ```jinja | ||||||
|  |     <div x-data="{state: AlertState.PENDING}"> | ||||||
|  |       {{ news_moderation_alert(news.id, user, "state") }} | ||||||
|  |     </div> | ||||||
|  |     ``` | ||||||
|  |     An with an alpine variable | ||||||
|  |     ```jinja | ||||||
|  |     <div x-data="{state: AlertState.PENDING, newsId: {{ news.id }}"> | ||||||
|  |       {{ news_moderation_alert("newsId", user, "state") }} | ||||||
|  |     </div> | ||||||
|  |     ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|     Args: |     Args: | ||||||
|         news: The `News` object to which this alert is related |         news: (News | int | string) | ||||||
|  |           Either the `News` object to which this alert is related, | ||||||
|  |           or its id, or the name of an Alpine which value is its id | ||||||
|         user: The request.user |         user: The request.user | ||||||
|         alpineState: An alpine variable name |         alpineState: An alpine variable name | ||||||
|  |  | ||||||
| @@ -23,7 +49,13 @@ | |||||||
|         in your template. |         in your template. | ||||||
|     #} |     #} | ||||||
|   <div |   <div | ||||||
|     x-data="moderationAlert({{ news.id }})" |     {% if news is integer or news is string %} | ||||||
|  |       x-data="moderationAlert({{ news }})" | ||||||
|  |     {% else %} | ||||||
|  |       x-data="moderationAlert({{ news.id }})" | ||||||
|  |     {% endif %} | ||||||
|  |     {# the news-moderated is received when a moderation alert is deleted or moderated #} | ||||||
|  |     @news-moderated.window="dispatchModeration($event)" | ||||||
|     {% if alpineState %} |     {% if alpineState %} | ||||||
|       x-modelable="{{ alpineState }}" |       x-modelable="{{ alpineState }}" | ||||||
|       x-model="state" |       x-model="state" | ||||||
| @@ -49,18 +81,31 @@ | |||||||
|             but it will be executed only for admin users, and only one time |             but it will be executed only for admin users, and only one time | ||||||
|             (if they do their job and moderated news as soon as they see them), |             (if they do their job and moderated news as soon as they see them), | ||||||
|             so it's still reasonable #} |             so it's still reasonable #} | ||||||
|             {% set nb_event=news.dates.count() %} |             <div | ||||||
|             {% if nb_event > 1 %} |               {% if news is integer or news is string %} | ||||||
|               <br> |                 x-data="{ nbEvents: nbModerated() }" | ||||||
|               <strong>{% trans %}Weekly event{% endtrans %}</strong> |               {% else %} | ||||||
|               <p> |                 x-data="{ nbEvents: {{ news.dates.count() }} }" | ||||||
|                 {% trans trimmed nb=nb_event %} |               {% endif %} | ||||||
|                   This event will take place every week for {{ nb }} weeks. |             > | ||||||
|                   If you moderate or delete this event, |               <template x-if="nbEvents > 1"> | ||||||
|                   it will also be moderated (or deleted) for the following weeks. |                 <div> | ||||||
|                 {% endtrans %} |                   <br> | ||||||
|               </p> |                   <strong>{% trans %}Weekly event{% endtrans %}</strong> | ||||||
|             {% endif %} |                   {# hybrid translation : the text is translated server-side, | ||||||
|  |                   but the interpolation of `nbEvents` is done client-side. #} | ||||||
|  |                   <p | ||||||
|  |                     x-text="interpolate(' | ||||||
|  |                             {%- trans trimmed -%} | ||||||
|  |                               This event will take place every week for %s weeks. | ||||||
|  |                               If you moderate or delete this event, | ||||||
|  |                               it will also be moderated (or deleted) for the following weeks. | ||||||
|  |                             {%- endtrans -%} | ||||||
|  |                             ', [nbEvents])" | ||||||
|  |                   ></p> | ||||||
|  |                 </div> | ||||||
|  |               </template> | ||||||
|  |             </div> | ||||||
|           {% endif %} |           {% endif %} | ||||||
|         </div> |         </div> | ||||||
|         {% if user.has_perm("com.moderate_news") %} |         {% if user.has_perm("com.moderate_news") %} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user