/** * @OnlyCurrentDoc * * The above comment directs Apps Script to limit the scope of file * access for this add-on. It specifies that this add-on will only * attempt to read or modify the files in which the add-on is used, * and not all of the user's files. The authorization request message * presented to users will reflect this limited scope. *//** * Creates a menu entry in the Google Docs UI when the document is opened. * This method is only used by the regular add-on, and is never called by * the mobile add-on version. * * @param {object} e The event parameter for a simple onOpen trigger. To * determine which authorization mode (ScriptApp.AuthMode) the trigger is * running in, inspect e.authMode. */functiononOpen(e){DocumentApp.getUi().createAddonMenu().addItem('Start','showSidebar').addToUi();}/** * Runs when the add-on is installed. * This method is only used by the regular add-on, and is never called by * the mobile add-on version. * * @param {object} e The event parameter for a simple onInstall trigger. To * determine which authorization mode (ScriptApp.AuthMode) the trigger is * running in, inspect e.authMode. (In practice, onInstall triggers always * run in AuthMode.FULL, but onOpen triggers may be AuthMode.LIMITED or * AuthMode.NONE.) */functiononInstall(e){onOpen(e);}/** * Opens a sidebar in the document containing the add-on's user interface. * This method is only used by the regular add-on, and is never called by * the mobile add-on version. */functionshowSidebar(){constui=HtmlService.createHtmlOutputFromFile('sidebar').setTitle('Translate');DocumentApp.getUi().showSidebar(ui);}/** * Gets the text the user has selected. If there is no selection, * this function displays an error message. * * @return {Array.<string>} The selected text. */functiongetSelectedText(){constselection=DocumentApp.getActiveDocument().getSelection();consttext=[];if(selection){constelements=selection.getSelectedElements();for(leti=0;i < elements.length;++i){if(elements[i].isPartial()){constelement=elements[i].getElement().asText();conststartIndex=elements[i].getStartOffset();constendIndex=elements[i].getEndOffsetInclusive();text.push(element.getText().substring(startIndex,endIndex+1));}else{constelement=elements[i].getElement();// Only translate elements that can be edited as text; skip images and// other non-text elements.if(element.editAsText){constelementText=element.asText().getText();// This check is necessary to exclude images, which return a blank// text element.if(elementText){text.push(elementText);}}}}}if(!text.length)thrownewError('Pleaseselectsometext.');returntext;}/** * Gets the stored user preferences for the origin and destination languages, * if they exist. * This method is only used by the regular add-on, and is never called by * the mobile add-on version. * * @return {Object} The user's origin and destination language preferences, if * they exist. */functiongetPreferences(){constuserProperties=PropertiesService.getUserProperties();return{originLang:userProperties.getProperty('originLang'),destLang:userProperties.getProperty('destLang')};}/** * Gets the user-selected text and translates it from the origin language to the * destination language. The languages are notated by their two-letter short * form. For example, English is 'en', and Spanish is 'es'. The origin language * may be specified as an empty string to indicate that Google Translate should * auto-detect the language. * * @param {string} origin The two-letter short form for the origin language. * @param {string} dest The two-letter short form for the destination language. * @param {boolean} savePrefs Whether to save the origin and destination * language preferences. * @return {Object} Object containing the original text and the result of the * translation. */functiongetTextAndTranslation(origin,dest,savePrefs){if(savePrefs){PropertiesService.getUserProperties().setProperty('originLang',origin).setProperty('destLang',dest);}consttext=getSelectedText().join('\n');return{text:text,translation:translateText(text,origin,dest)};}/** * Replaces the text of the current selection with the provided text, or * inserts text at the current cursor location. (There will always be either * a selection or a cursor.) If multiple elements are selected, only inserts the * translated text in the first element that can contain text and removes the * other elements. * * @param {string} newText The text with which to replace the current selection. */functioninsertText(newText){constselection=DocumentApp.getActiveDocument().getSelection();if(selection){letreplaced=false;constelements=selection.getSelectedElements();if(elements.length===1 && elements[0].getElement().getType()===DocumentApp.ElementType.INLINE_IMAGE){thrownewError('Can\'tinserttextintoanimage.');}for(leti=0;i < elements.length;++i){if(elements[i].isPartial()){constelement=elements[i].getElement().asText();conststartIndex=elements[i].getStartOffset();constendIndex=elements[i].getEndOffsetInclusive();element.deleteText(startIndex,endIndex);if(!replaced){element.insertText(startIndex,newText);replaced=true;}else{// This block handles a selection that ends with a partial element. We// want to copy this partial text to the previous element so we don't// have a line-break before the last partial.constparent=element.getParent();constremainingText=element.getText().substring(endIndex+1);parent.getPreviousSibling().asText().appendText(remainingText);// We cannot remove the last paragraph of a doc. If this is the case,// just remove the text within the last paragraph instead.if(parent.getNextSibling()){parent.removeFromParent();}else{element.removeFromParent();}}}else{constelement=elements[i].getElement();if(!replaced && element.editAsText){// Only translate elements that can be edited as text, removing other// elements.element.clear();element.asText().setText(newText);replaced=true;}else{// We cannot remove the last paragraph of a doc. If this is the case,// just clear the element.if(element.getNextSibling()){element.removeFromParent();}else{element.clear();}}}}}else{constcursor=DocumentApp.getActiveDocument().getCursor();constsurroundingText=cursor.getSurroundingText().getText();constsurroundingTextOffset=cursor.getSurroundingTextOffset();// If the cursor follows or preceds a non-space character, insert a space// between the character and the translation. Otherwise, just insert the// translation.if(surroundingTextOffset > 0){if(surroundingText.charAt(surroundingTextOffset-1)!==''){newText=''+newText;}}if(surroundingTextOffset < surroundingText.length){if(surroundingText.charAt(surroundingTextOffset)!==''){newText+='';}}cursor.insertText(newText);}}/** * Given text, translate it from the origin language to the destination * language. The languages are notated by their two-letter short form. For * example, English is 'en', and Spanish is 'es'. The origin language may be * specified as an empty string to indicate that Google Translate should * auto-detect the language. * * @param {string} text text to translate. * @param {string} origin The two-letter short form for the origin language. * @param {string} dest The two-letter short form for the destination language. * @return {string} The result of the translation, or the original text if * origin and dest languages are the same. */functiontranslateText(text,origin,dest){if(origin===dest)returntext;returnLanguageApp.translate(text,origin,dest);}
[[["Fácil de comprender","easyToUnderstand","thumb-up"],["Resolvió mi problema","solvedMyProblem","thumb-up"],["Otro","otherUp","thumb-up"]],[["Falta la información que necesito","missingTheInformationINeed","thumb-down"],["Muy complicado o demasiados pasos","tooComplicatedTooManySteps","thumb-down"],["Desactualizado","outOfDate","thumb-down"],["Problema de traducción","translationIssue","thumb-down"],["Problema con las muestras o los códigos","samplesCodeIssue","thumb-down"],["Otro","otherDown","thumb-down"]],["Última actualización: 2024-10-18 (UTC)"],[[["This quickstart guide demonstrates how to build a Google Docs add-on using Apps Script that translates selected text within a document."],["The add-on allows users to select text, choose source and target languages, and obtain the translation, with an option to insert the translated text directly into the document."],["Users need a Google Account and a web browser to utilize this add-on, which involves setting up a script, running it, and authorizing permissions."],["The add-on provides a user interface within a sidebar in Google Docs for easy interaction and language selection."],["Further resources are available for extending Google Docs functionality with Apps Script and exploring the Document service for more advanced customizations."]]],[]]