Marca d'água em todas as imagens enviadas

Dear all Discourse Developers,

I want to thanks all Discourse developers for their excellent work on making the best forum in the world. :smiling_face_with_three_hearts: Personally, I have used other programs, such as Discuz and Buddyboss (Wordpress) to build serval forums in past 10 years, none of them are as great as Discourse.

The only feature I missed in Discourse is the watermark feature. It will be perfect if Discourse support Watermark on all upload images. It doesn’t need to be extremely complicated, like some other user suggested in this forum. (I understand why developer ignore their request, because it is totally impractical.)


IMHO, A very simple watermark capability will be good enough. Add a icon/text on every uploaded images, just let others know the image is originated from my forum when someone share (or steal) your images to other website/platform.

Personally, I always add watermark by myself before upload to the forum, however many community members don’t want to do it by themselves, especially when they post image using smartphone, they hope to be automatically add by the forum.

I understand that Discourse original designed for more a text base forum, rather than forum with lots images, such as Photography forum. But thanks to many excellent Plugin / TC available, I can make a photo orientated forum with Discourse nicely.


I recommend add a watermark image upload box in
/admin/site_settings/category/branding

And add a selection button in
/admin/site_settings/category/files
2020-12-30_042258

And a pull down menu for watermark position, similar to,

Then, It will be good enough. No need other fancy features.
Other feature, like scaling, opacity, backup original image, etc. They are great but not necessary.

Lastly, I want to thanks all Discourse Developers for their continuous hardworking.
Thank you and Happy New year ~!:kissing_heart:

7 curtidas

Thanks Jacky, Sounds like an interesting plugin for someone to experiment with. I do not think though that we will make this a core feature, but core can certainly help facilitate the plugin.

If you have budget I recommend posting in marketplace, my guess is that a minimal prototype plugin (with minimal configuration - only supply text) would take about 1 to 2 days to build.

Watermark by superimposing images may take a bit longer to get right.

12 curtidas

After some experiment, I find a temp “solution” for the watermark. :partying_face:

Just in case, some others may interest. I want to share my workaround. Hope it may help. :smiling_face_with_three_hearts:

1, First, I install Chevereto (free) to another sub domain.
(it is very easy, just upload the installer.php file to server, load the page & follow the setup. It complete in mins) :kissing_heart:

2, The free version also support watermark, you can setup it in dashboard image upload setting.

You can also set Max. image width & height in dashboard, so all large image uploaded will automatically resize.

3, Add the Chevereto Plugin (script) to Discourse <head> tag
<script async src="https://img.example.com/sdk/pup.js" data-url="https://img.example.com/upload"></script>

4, Discourse seem don’t support i tag fa-icon anymore, so I have to modify the java script from
<i class="fa fa-cloud-upload d-icon d-icon-upload"></i>
to
<svg class="fa d-icon d-icon-cloud-upload-alt svg-icon svg-node" aria-hidden="true"><use xlink:href="#cloud-upload-alt"></use></svg>’

5, If everything setup right, it will show cloud upload icon in discourse editor.

6, Just click on the new icon, Drag & drop image to popup window and it automatically upload & paste the code to editor with watermark. :partying_face:

7, Now it work perfectly in desktop. But I am still figuring how to add the icon to smart phone. :thinking: I will update this post if I find a way to do it.

It is just a temp solution, workaround, not perfect at all but can do it easily within mins. I am still hoping Discourse can add watermark in core or by plugin / TC in future.

9 curtidas

This looks good. A theme component with all this, leaving only the installation of the Chevereto as a manual step, would be great.

4 curtidas

I modified the Chevereto Plugin Javascript a little bit.

By changing
sibling: ".upload.btn", siblingPos:"before",
to
sibling:".code.btn",siblingPos:"after",

Now, the icon show in both Desktop and Smartphone. :partying_face:

2 curtidas

Adorei! Ele tem um plugin para atingir o mesmo objetivo?

Seria melhor se houvesse um componente para esta marca d’água.

2 curtidas

Alguém pode me dizer em qual pasta as imagens são salvas?

Uma das maneiras que eu gostaria de colocar marca d’água nelas em lote é executando uma ferramenta externa de edição de imagem.

Alguém conseguiu fazer isso com o Discourse mais recente 3.2?

Isso é muito legal. Você também pode se interessar por este Theme component

2 curtidas

Eu tentei em um componente de tema. É apenas uma prova de conceito, então é básico. :smile:
Para cada upload, uma marca d’água é aplicada automaticamente.

Do lado técnico, assim como o Discourse pré-processa imagens antes do upload (como compressão), esta ferramenta faz o mesmo com a marca d’água. Graças à API e à biblioteca Uppy, a marca d’água é facilmente alcançável. :pray:

Me diga se você tem recursos/personalizações em mente que consideraria como um mínimo. :slight_smile:

EDIT: postarei uma versão assim que implementar configurações básicas.

14 curtidas

:heart: :heart: :heart:
Trabalho épico! Me avise se precisar de testadores

2 curtidas

Ei, isso está pronto para produção? Tenho muito interesse

1 curtida

Em que situação é adequado e legal imprimir marca d’água em todas as imagens?

1 curtida

isso está pronto para produção?

Desculpe, estou um pouco atrasado nisso. :sweat_smile:
Se você ainda estiver interessado, lancei um TC aqui: Watermark Image. Qualquer feedback é bem-vindo!

7 curtidas