I am using s3 for host my files on my discourse community, i made ios app and i need to download pdf files instead of open in the app
I found a solution for a link download:
<a href="download-url?wtn-download-file=true"> download File</a>
But for pdf uploaded on s3 i don`t know what to do.
Canapin
(Coin-coin le Canapin)
2
Edit: removing my answer as I misunderstood the topic data:image/s3,"s3://crabby-images/29b02/29b02ea44ac5f6d53cac05c4a98dcbb54d737e82" alt=":person_facepalming: :person_facepalming:"
Thanks thoka data:image/s3,"s3://crabby-images/278c2/278c263d0706ac1efb7e2a471d8b87a864092f81" alt=":+1: :+1:"
thoka
(Thomas Kalka)
3
Hm. It seems, he demands exactly the opposite of my feature request …
1 Like
thoka
(Thomas Kalka)
4
According to this source, you should be able to achieve the desired behavior by adding download
to these links via a theme component.
1 Like
I need to find a way to change all my pdf links… it`s almost 3000 links
Should be a matter of discourse remap
Word of caution: Test it first on a staging site. It might not work as expected.
1 Like
Don
7
Hello data:image/s3,"s3://crabby-images/62f08/62f0851661e92bde61121e43a7a3fdd02c6f4743" alt=":wave: :wave:"
I think this topic is same: Force download pdf on IOS
For this you have to use api.decorateCookedElement.
Something like this should work data:image/s3,"s3://crabby-images/83590/83590e8cbb5acd751f80dc358fef194dbd5c703b" alt=":arrow_down_small: :arrow_down_small:"
Place it to the Header section to a component.
<script type="text/discourse-plugin" version="0.8.42">
api.decorateCookedElement(
element => {
const pdfFiles = element.querySelectorAll("a.attachment[href$='.pdf']");
if (!pdfFiles.length) {
return;
}
pdfFiles.forEach((pdf) => {
pdf.setAttribute("download", "");
});
},
{ id: "download-pdf", onlyStream: true }
);
</script>
I’ve tested it on my device and it works for me but if you want to use other attribute etc… you can easily change it… I hope it helps data:image/s3,"s3://crabby-images/fc6d2/fc6d27ad610fa159f2466a504b7cfca7fb8c9b8f" alt=":slight_smile: :slight_smile:"
2 Likes