Instance de l'environnement d'interface utilisateur d'une application Google qui permet au script d'ajouter des fonctionnalités telles que des menus, des boîtes de dialogue et des barres latérales. Un script ne peut interagir avec l'UI que pour l'instance actuelle d'un éditeur ouvert, et uniquement si le script est lié au conteneur de l'éditeur.
// Display a dialog box with a title, message, input field, and "Yes" and "No" // buttons. The user can also close the dialog by clicking the close button in // its title bar. const ui = SpreadsheetApp.getUi(); const response = ui.prompt( 'Getting to know you', 'May I know your name?', ui.ButtonSet.YES_NO, ); // Process the user's response. if (response.getSelectedButton() === ui.Button.YES) { Logger.log('The user\'s name is %s.', response.getResponseText()); } else if (response.getSelectedButton() === ui.Button.NO) { Logger.log('The user didn\'t want to provide a name.'); } else { Logger.log('The user clicked the close button in the dialog\'s title bar.'); }
Propriétés
Propriété | Type | Description |
---|---|---|
Button | Button | Enumération représentant les boutons de boîte de dialogue localisés et prédéterminés renvoyés par une alerte ou Prompt pour indiquer sur quel bouton de la boîte de dialogue l'utilisateur a cliqué. |
Button | Button | Enumération représentant des ensembles localisés prédéterminés d'un ou plusieurs boutons de boîte de dialogue pouvant être ajoutés à une alerte ou à une invite. |
Méthodes
Méthode | Type renvoyé | Brève description |
---|---|---|
alert(prompt) | Button | Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le message donné et un bouton "OK". |
alert(prompt, buttons) | Button | Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le message et l'ensemble de boutons donnés. |
alert(title, prompt, buttons) | Button | Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le titre, le message et l'ensemble de boutons donnés. |
create | Menu | Crée un outil de création permettant d'insérer un sous-menu dans le menu "Extensions" de l'éditeur. |
create | Menu | Crée un compilateur permettant d'ajouter un menu à l'interface utilisateur de l'éditeur. |
prompt(prompt) | Prompt | Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le message donné et un bouton "OK". |
prompt(prompt, buttons) | Prompt | Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le message et l'ensemble de boutons donnés. |
prompt(title, prompt, buttons) | Prompt | Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le titre, le message et l'ensemble de boutons donnés. |
show | void | Ouvre une boîte de dialogue modale dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. |
show | void | Ouvre une boîte de dialogue sans mode dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. |
show | void | Ouvre une barre latérale dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. |
Documentation détaillée
alert(prompt)
Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le message donné et un bouton "OK". Cette méthode suspend le script côté serveur lorsque la boîte de dialogue est ouverte. Le script reprend après que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display "Hello, world" in a dialog box with an "OK" button. The user can also // close the dialog by clicking the close button in its title bar. SpreadsheetApp.getUi().alert('Hello, world');
Paramètres
Nom | Type | Description |
---|---|---|
prompt | String | Message à afficher dans la boîte de dialogue. |
Renvois
Button
: bouton sur lequel l'utilisateur a cliqué.
alert(prompt, buttons)
Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le message et l'ensemble de boutons donnés. Cette méthode suspend le script côté serveur lorsque la boîte de dialogue est ouverte. Le script reprend après que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display a dialog box with a message and "Yes" and "No" buttons. The user can // also close the dialog by clicking the close button in its title bar. const ui = SpreadsheetApp.getUi(); const response = ui.alert( 'Are you sure you want to continue?', ui.ButtonSet.YES_NO, ); // Process the user's response. if (response === ui.Button.YES) { Logger.log('The user clicked "Yes."'); } else { Logger.log( 'The user clicked "No" or the close button in the dialog\'s title bar.', ); }
Paramètres
Nom | Type | Description |
---|---|---|
prompt | String | Message à afficher dans la boîte de dialogue. |
buttons | Button | Bouton défini pour s'afficher dans la boîte de dialogue. |
Renvois
Button
: bouton sur lequel l'utilisateur a cliqué.
alert(title, prompt, buttons)
Ouvre une boîte de dialogue dans l'éditeur de l'utilisateur avec le titre, le message et l'ensemble de boutons donnés. Cette méthode suspend le script côté serveur lorsque la boîte de dialogue est ouverte. Le script reprend une fois que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display a dialog box with a title, message, and "Yes" and "No" buttons. The // user can also close the dialog by clicking the close button in its title bar. const ui = SpreadsheetApp.getUi(); const response = ui.alert( 'Confirm', 'Are you sure you want to continue?', ui.ButtonSet.YES_NO, ); // Process the user's response. if (response === ui.Button.YES) { Logger.log('The user clicked "Yes."'); } else { Logger.log( 'The user clicked "No" or the close button in the dialog\'s title bar.', ); }
Paramètres
Nom | Type | Description |
---|---|---|
title | String | Titre à afficher au-dessus de la boîte de dialogue. |
prompt | String | Message à afficher dans la boîte de dialogue. |
buttons | Button | Bouton défini pour s'afficher dans la boîte de dialogue. |
Renvois
Button
: bouton sur lequel l'utilisateur a cliqué.
create Addon Menu()
Crée un outil de création permettant d'insérer un sous-menu dans le menu "Extensions" de l'éditeur. Le menu n'est pas réellement mis à jour tant que Menu.addToUi()
n'est pas appelé. Si le script s'exécute en tant que module complémentaire, le nom du sous-menu correspond au nom du module complémentaire dans la boutique Web. Si le script est lié directement au document, le nom du sous-menu correspond au nom du script. Pour en savoir plus, consultez le guide des menus.
// Add an item to the Add-on menu, under a sub-menu whose name is set // automatically. function onOpen(e) { SpreadsheetApp.getUi() .createAddonMenu() .addItem('Show', 'showSidebar') .addToUi(); }
Renvois
Menu
: nouveau générateur de menus.
create Menu(caption)
Crée un compilateur permettant d'ajouter un menu à l'interface utilisateur de l'éditeur. Le menu n'est pas réellement ajouté tant que Menu.addToUi()
n'est pas appelé. Pour en savoir plus, consultez le guide des menus. Le libellé d'un menu de premier niveau doit être en majuscules (tous les mots principaux sont en majuscules), tandis que celui d'un sous-menu doit être en minuscules (seulement le premier mot est en majuscule). Si le script est publié en tant que composant complémentaire, le paramètre caption
est ignoré et le menu est ajouté en tant que sous-menu du menu "Extensions", ce qui équivaut à create
.
// Add a custom menu to the active document, including a separator and a // sub-menu. function onOpen(e) { SpreadsheetApp.getUi() .createMenu('My Menu') .addItem('My menu item', 'myFunction') .addSeparator() .addSubMenu( SpreadsheetApp.getUi() .createMenu('My sub-menu') .addItem('One sub-menu item', 'mySecondFunction') .addItem('Another sub-menu item', 'myThirdFunction'), ) .addToUi(); }
Paramètres
Nom | Type | Description |
---|---|---|
caption | String | Libellé du menu, avec tous les mots principaux en majuscules pour un menu de premier niveau, ou seulement le premier mot en majuscules pour un sous-menu. |
Renvois
Menu
: nouveau générateur de menus.
prompt(prompt)
Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le message donné et un bouton "OK". Cette méthode suspend le script côté serveur lorsque la boîte de dialogue est ouverte. Le script reprend une fois que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display a dialog box with a message, input field, and an "OK" button. The // user can also close the dialog by clicking the close button in its title bar. const ui = SpreadsheetApp.getUi(); const response = ui.prompt('Enter your name:'); // Process the user's response. if (response.getSelectedButton() === ui.Button.OK) { Logger.log('The user\'s name is %s.', response.getResponseText()); } else { Logger.log('The user clicked the close button in the dialog\'s title bar.'); }
Paramètres
Nom | Type | Description |
---|---|---|
prompt | String | Message à afficher dans la boîte de dialogue. |
Renvois
Prompt
: représentation de la réponse de l'utilisateur.
prompt(prompt, buttons)
Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le message et l'ensemble de boutons donnés. Cette méthode suspend le script côté serveur lorsque la boîte de dialogue est ouverte. Le script reprend une fois que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display a dialog box with a message, input field, and "Yes" and "No" buttons. // The user can also close the dialog by clicking the close button in its title // bar. const ui = SpreadsheetApp.getUi(); const response = ui.prompt('May I know your name?', ui.ButtonSet.YES_NO); // Process the user's response. if (response.getSelectedButton() === ui.Button.YES) { Logger.log('The user\'s name is %s.', response.getResponseText()); } else if (response.getSelectedButton() === ui.Button.NO) { Logger.log('The user didn\'t want to provide a name.'); } else { Logger.log('The user clicked the close button in the dialog\'s title bar.'); }
Paramètres
Nom | Type | Description |
---|---|---|
prompt | String | Message à afficher dans la boîte de dialogue. |
buttons | Button | Bouton défini pour s'afficher dans la boîte de dialogue. |
Renvois
Prompt
: représentation de la réponse de l'utilisateur.
prompt(title, prompt, buttons)
Ouvre une boîte de dialogue de saisie dans l'éditeur de l'utilisateur avec le titre, le message et l'ensemble de boutons donnés. Cette méthode suspend le script côté serveur tant que la boîte de dialogue est ouverte. Le script reprend une fois que l'utilisateur a fermé la boîte de dialogue, mais les connexions Jdbc
et les verrous Lock
ne persistent pas pendant la suspension. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
// Display a dialog box with a title, message, input field, and "Yes" and "No" // buttons. The user can also close the dialog by clicking the close button in // its title bar. const ui = SpreadsheetApp.getUi(); const response = ui.prompt( 'Getting to know you', 'May I know your name?', ui.ButtonSet.YES_NO, ); // Process the user's response. if (response.getSelectedButton() === ui.Button.YES) { Logger.log('The user\'s name is %s.', response.getResponseText()); } else if (response.getSelectedButton() === ui.Button.NO) { Logger.log('The user didn\'t want to provide a name.'); } else { Logger.log('The user clicked the close button in the dialog\'s title bar.'); }
Paramètres
Nom | Type | Description |
---|---|---|
title | String | Titre à afficher au-dessus de la boîte de dialogue. |
prompt | String | Message à afficher dans la boîte de dialogue. |
buttons | Button | Bouton défini pour s'afficher dans la boîte de dialogue. |
Renvois
Prompt
: représentation de la réponse de l'utilisateur.
show Modal Dialog(userInterface, title)
Ouvre une boîte de dialogue modale dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. Cette méthode ne suspend pas le script côté serveur lorsque la boîte de dialogue est ouverte. Pour communiquer avec le script côté serveur, le composant côté client doit effectuer des rappels asynchrones à l'aide de l'API google.script
pour Html
. Pour fermer la boîte de dialogue de manière programmatique, appelez
google.script.host.close()
côté client d'une application Web Html
. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
Les boîtes de dialogue modales empêchent l'utilisateur d'interagir avec autre chose qu'elles. En revanche, les boîtes de dialogue sans mode et les barres latérales permettent à l'utilisateur d'interagir avec l'éditeur. Dans la plupart des cas, une boîte de dialogue modale ou une barre latérale est un meilleur choix qu'une boîte de dialogue sans mode.
// Display a modal dialog box with custom HtmlService content. const htmlOutput = HtmlService .createHtmlOutput( '<p>A change of speed, a change of style...</p>', ) .setWidth(250) .setHeight(300); SpreadsheetApp.getUi().showModalDialog(htmlOutput, 'My add-on');
Paramètres
Nom | Type | Description |
---|---|---|
user | Object | Html représentant l'interface à afficher. |
title | String | Titre de la boîte de dialogue. Remplace tout titre défini en appelant set sur l'objet user . |
Autorisation
Les scripts qui utilisent cette méthode nécessitent une autorisation avec un ou plusieurs des champs d'application suivants:
-
https://www.googleapis.com/auth/script.container.ui
show Modeless Dialog(userInterface, title)
Ouvre une boîte de dialogue sans mode dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. Cette méthode ne suspend pas le script côté serveur tant que la boîte de dialogue est ouverte. Pour communiquer avec le script côté serveur, le composant côté client doit effectuer des rappels asynchrones à l'aide de l'API google.script
pour Html
. Pour fermer la boîte de dialogue de manière programmatique, appelez
google.script.host.close()
côté client d'une application Web Html
. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
Les boîtes de dialogue sans mode permettent à l'utilisateur d'interagir avec l'éditeur derrière la boîte de dialogue. En revanche, les boîtes de dialogue modales ne le font pas. Dans la plupart des cas, une boîte de dialogue modale ou une barre latérale est un meilleur choix qu'une boîte de dialogue sans mode.
// Display a modeless dialog box with custom HtmlService content. const htmlOutput = HtmlService .createHtmlOutput( '<p>A change of speed, a change of style...</p>', ) .setWidth(250) .setHeight(300); SpreadsheetApp.getUi().showModelessDialog(htmlOutput, 'My add-on');
Paramètres
Nom | Type | Description |
---|---|---|
user | Object | Html représentant l'interface à afficher. |
title | String | Titre de la boîte de dialogue. Remplace tout titre défini en appelant set sur l'objet user . |
Autorisation
Les scripts qui utilisent cette méthode nécessitent une autorisation avec un ou plusieurs des champs d'application suivants:
-
https://www.googleapis.com/auth/script.container.ui
show Sidebar(userInterface)
Ouvre une barre latérale dans l'éditeur de l'utilisateur avec du contenu côté client personnalisé. Cette méthode ne suspend pas le script côté serveur lorsque la barre latérale est ouverte. Pour communiquer avec le script côté serveur, le composant côté client doit effectuer des rappels asynchrones à l'aide de l'API google.script
pour Html
. Pour fermer la barre latérale de manière programmatique, appelez
google.script.host.close()
côté client d'une application Web Html
. Pour en savoir plus, consultez le guide des boîtes de dialogue et des barres latérales.
La barre latérale s'affiche sur le côté droit de l'éditeur pour les utilisateurs dont les environnements utilisent une langue de gauche à droite, et sur le côté gauche de l'éditeur pour les langues de droite à gauche. Toutes les barres latérales affichées par les scripts mesurent 300 pixels de large.
// Display a sidebar with custom HtmlService content. const htmlOutput = HtmlService .createHtmlOutput( '<p>A change of speed, a change of style...</p>', ) .setTitle('My add-on'); SpreadsheetApp.getUi().showSidebar(htmlOutput);
Paramètres
Nom | Type | Description |
---|---|---|
user | Object | Html représentant l'interface à afficher. |
Autorisation
Les scripts qui utilisent cette méthode nécessitent une autorisation avec un ou plusieurs des champs d'application suivants:
-
https://www.googleapis.com/auth/script.container.ui