I have this code that opens the file and replaces a string using replaceText.
var url = 'http://www.test.com';
var doc = DocumentApp.openById(file.getId());
doc.replaceText("<<urlGoesHere>>", url);
doc.saveAndClose();
When I open the doc, the replacement has occured, but the url is not a clickable hyperlink, it's just static text. Is there a way to programmatically make it a clickable link?
I found this method of text called setLinkUrl, but there's no documentation/examples: https://developers.google.com/apps-script/reference/document/text#setLinkUrl(String)
Any ideas?
To add a hyperlink in a document use Body. appendParagraph with setLinkUrl, then merge. let doc = DocumentApp. create("My Document"); let body = doc.
If you want to 'show' the URL, just change this line like this : var link = app. createAnchor(href, href). setId("link");
To concatenate two strings (i.e., to join them together), use the concatenation operator ( + ). Both the concatenation operator and the addition operator have the same symbol + but Apps Script will figure out which operation to perform based on the values being operated on.
Here is how it goes, at least if you have only one occurrence of the url placeHolder.
If you have more than one then you should iterate the whole doc content to find each or them and replace them all.
function myFunction() {
var url = 'http://www.google.com';
var doc = DocumentApp.getActiveDocument();// or DocumentApp.openById(file.getId()); as in your example code
var element = doc.getBody().findText("<<urlGoesHere>>");
if(element){ // if found a match
var start = element.getStartOffset();
var text = element.getElement().asText();
text.replaceText("<<urlGoesHere>>",url);
text.setLinkUrl(start, start+url.length, url);
doc.saveAndClose();
} // else do nothing
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With