Scadenza automatica del badge

Vorrei offrire dei vantaggi agli utenti Discourse che rimangono coinvolti periodicamente. Ad esempio, vorrei concedere benefici solo agli utenti che invitano almeno un nuovo utente al mese.

Potrei impostare questo meccanismo assegnando tali vantaggi a tutti gli utenti che possiedono il badge “Promoter”. Tuttavia, il badge “Promoter” richiede che l’utente inviti un solo visitatore, dopodiché mantiene il badge per sempre.

Esiste un modo per configurare una scadenza automatica del badge, in modo che dopo un mese il badge “Promoter” (o qualsiasi altro) venga rimosso dall’utente, costringendolo a guadagnarlo di nuovo?

Oppure esiste un approccio migliore per ciò che sto cercando di ottenere (richiedere un coinvolgimento mensile da parte degli utenti)?

Grazie in anticipo.

Definitely an interesting idea.

@codinghorror, I understand then that there is no such feature yet? :slight_smile:
Is there any workaround that can be used to implement this, even if manually? The main problem I see now is that I can’t see even information about when a badge was granted to a user. Is this available somewhere, even if it via API?

I guess you could use Discourse Data Explorer Plugin to replicate SQL queries and add time constraints to create new “expiring” badges. I did not check in the #plugin:data-explorer category or (Superseded) What cool data explorer queries have you come up with? collection if there are such queries already. It would definitely be appreciated to share what you come up with in this topic!

Under the 3 lines next to your Avatar, click Badges. Each badge has a number… for how many users have it. Click on the number it shows. Then, each user with the badge will be listed with the date they earned the badge.

But why would anyone want expiring badges? Users will get ticked, IMO.

This is actually a common ask within the community space. Badges that are tied to more recent/current actions of the users vs. the historical granting of badges you get to keep forever regardless of whether or not you are still active in the community. Especially for communities that have been up for years. Facebook does this with the “Top Fan” badge which is not static and can go away if you fade away from participating on the page.

If I simply manually delete a badge from an user, will he/she gain that badge again if he perform the needed actions?

Per questo, penso che il consiglio sarebbe comunque quello di creare nuovi badge che avessero un elemento temporale integrato nella query SQL sottostante.

Se qualcuno desidera aiuto con una query, può avviare un argomento in Data & reporting. :+1: