page_type | urlFragment | products | languages | extensions | description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
sample |
outlook-add-in-set-signature |
|
|
|
Use Outlook event-based activation to set the signature. |
Applies to: Outlook on Windows | Outlook on the web | Outlook on Mac (new UI preview)
This sample uses event-based activation to run an Outlook add-in when the user creates a new message or appointment. The add-in can respond to events, even when the task pane is not open. It also uses the setSignatureAsync API. If no signature is set, the add-in prompts the user to set a signature, and can then open the task pane for the user.
For documentation related to this sample, see Configure your Outlook add-in for event-based activation.
- Use event-based activation to respond to events when the task pane is not open.
- Set a signature for Outlook to use in messages and appointments.
- Outlook
- Windows
- Web browser
- new Mac UI (preview)
-
Microsoft 365
Note: If you do not have a Microsoft 365 subscription, you can get one for development purposes by signing up for the Microsoft 365 developer program.
Solution | Author(s) |
---|---|
Use Outlook event-based activation to set the signature | Microsoft |
Version | Date | Comments |
---|---|---|
1.0 | 4-1-2021 | Initial release |
1.1 | 6-1-2021 | Update for GA of setSignature API |
1.2 | 7-27-2021 | Convert to GitHub hosting |
In this scenario, the add-in helps the user manage their email signature, even when the task pane is not open. When the user sends a new email message, or creates a new appointment, the add-in displays an information bar prompting the user to create a signature. If the user chooses to set a signature, the add-in opens the task pane for the user to continue setting their signature.
You can run this sample in Outlook on Windows, on Mac (new UI in preview), or in a browser. The add-in web files are served from this repo on GitHub.
- Download the manifest.xml file from this sample to a folder on your computer.
- Sideload the add-in manifest in Outlook on the web, on Windows, or on Mac by following the manual instructions in the article Sideload Outlook add-ins for testing.
Once the add-in is loaded use the following steps to try out the functionality.
-
Open Outlook on Windows, on Mac, or in a browser.
-
Create a new message or appointment.
You should see a notification at the top of the message that reads: Please set your signature with the PnP sample add-in.
-
Choose Set signatures. This will open the task pane for the add-in.
-
In the task pane fill out the fields for your signature data. Then choose Save.
-
The task pane will load a page of sample templates. You can assign the templates to a New Mail, Reply, or Forward action. Once you've assign the templates you want to use, choose Save.
The next time you create a message or appointment, you'll see the signature you selected applied by the add-in.
If you prefer to host the web server for the sample on your computer, follow these steps:
-
Install a recent version of npm and Node.js on your computer. To verify if you've already installed these tools, run the commands
node -v
andnpm -v
in your terminal. -
You need http-server to run the local web server. If you haven't installed this yet, run the following command.
npm install --global http-server
-
Use a tool such as openssl to generate a self-signed certificate that you can use for the web server. Move the cert.pem and key.pem files to the root folder for this sample.
-
From a command prompt, go to the root folder and run the following command.
http-server -S --cors . -p 3000
-
To reroute to localhost, run office-addin-https-reverse-proxy. If you haven't installed this, run the following command.
npm install --global office-addin-https-reverse-proxy
To reroute, run the following in another command prompt.
office-addin-https-reverse-proxy --url http://localhost:3000
-
Sideload
manifest-localhost.xml
in Outlook on the web, on Windows, or on Mac by following the manual instructions in the article Sideload Outlook add-ins for testing.
The manifest configures a runtime that is loaded specifically to handle event-based activation. The following <Runtime>
element specifies an HTML page resource ID that loads the runtime on Outlook on the web and on Mac. The <Override>
element specifies the JavaScript file instead, to load the runtime for Outlook on Windows. Outlook on Windows doesn't use the HTML page to load the runtime.
<Runtime resid="Autorun">
<Override type="javascript" resid="runtimeJs"/>
...
<bt:Url id="Autorun" DefaultValue="https://officedev.github.io/Office-Add-in-samples/Samples/outlook-set-signature/src/runtime/HTML/autorunweb.html"></bt:Url>
<bt:Url id="runtimeJs" DefaultValue="https://officedev.github.io/Office-Add-in-samples/Samples/outlook-set-signature/src/runtime/Js/autorunshared.js"></bt:Url>
The add-in handles two events that are mapped to the checkSignature()
function.
<LaunchEvents>
<LaunchEvent Type="OnNewMessageCompose" FunctionName="checkSignature" />
<LaunchEvent Type="OnNewAppointmentOrganizer" FunctionName="checkSignature" />
</LaunchEvents>
When the user creates a new message or appointment, Outlook will load the files specified in the manifest to handle the OnNewMessageCompose
and OnNewAppointmentOrganizer
events. Outlook on the web and on Mac will load the autorunweb.html
page, which then also loads autorunweb.js
and autorunshared.js
.
The autorunweb.js
file contains a version of the insert_auto_signature
function used specifically when running on Outlook on the web. The setSignatureAsync() API cannot be used in Outlook on the web for appointments. Therefore, insert_auto_signature
inserts the signature into a new appointment by directly writing to the body text of the appointment.
The autorunshared.js
file contains the checkSignature
function that handles the events from Outlook. It also contains additional code that is shared and loaded when the add-in is used in Outlook on the web, on Windows, and on Mac. In Outlook on Windows, this file is loaded directly and autorunweb.html
and autorunweb.js
are not loaded.
The autorunshared.js
file contains a version of the insert_auto_signature
function that uses the setSignatureAsync()
API to set the signature for both messages and appointments.
Note that you can use a similar pattern when handling events. If you need code that only applies to Outlook on the web, you can load it in a separate file like autorunweb.js
. And for code that applies to Outlook on the web, on Windows, and on Mac, you can load it in a shared file like autorunshared.js
.
Template A shows how to insert an image by embedding it in the signature. This will avoid the image being downloaded from your server when the signature is inserted into new mail items. The HTML uses the following <img>
tag format with the src set to cid:imageFileName to embed the image.
str +=
"<td style='border-right: 1px solid #000000; padding-right: 5px;'><img src='cid:" +
logoFileName +
"' alt='MS Logo' width='24' height='24' /></td>";
In the addTemplateSignature function, if template A is used, it will attach the image by calling the addFileAttachmentFromBase64Async() API. Then it calls the setSignatureAsync() API.
Template B shows how to reference an image from the HTML. It uses the <img>
tag and references the web location.
str +=
"<td style='border-right: 1px solid #000000; padding-right: 5px;'><img src='https://officedev.github.io/Office-Add-in-samples/Samples/outlook-set-signature/assets/sample-logo.png' alt='Logo' /></td>";
This is a simpler approach as you don't need to attach the image. Although your web server will need to provide the image anytime Outlook needs it for a signature.
The task pane code is located under the taskpane
folder of this project. The task pane HTML and JavaScript files only provide UI and functionality to let the user specify and save a signature.
editsignature.html
is loaded when the task pane first opens. It lets the user enter details such as name and title for their signature.assignsignature.html
is loaded when the user saves their details from theeditsignature.html
page. It lets the user assign the signature to actions such as "new email", "reply", and "forward.
Copyright (c) 2021 Microsoft Corporation. All rights reserved.
This project has adopted the Microsoft Open Source Code of Conduct. For more information, see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.