mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-04 07:10:06 +08:00
268 lines
11 KiB
HTML
268 lines
11 KiB
HTML
---
|
|
layout: default
|
|
title: Getting started with plugins
|
|
---
|
|
|
|
<style>
|
|
code.background{
|
|
background-color: #f6f6f6;
|
|
padding: 0 5px;
|
|
border-radius: 5px;
|
|
}
|
|
table.code {
|
|
-webkit-box-shadow: 0 5px 15px #AAA;
|
|
-moz-box-shadow: 0 5px 15px #AAA;
|
|
box-shadow: 0 5px 15px #AAA;
|
|
}
|
|
table.code td {
|
|
border: none;
|
|
padding: 0;
|
|
line-height: 20px;
|
|
font-family: monospace;
|
|
font-size: 14px;
|
|
}
|
|
table.code td.code {
|
|
padding-left: 20px;
|
|
}
|
|
table.code td.code.hlt {
|
|
background: #D0E0FF;
|
|
}
|
|
table.code td.code.add {
|
|
background: #D0FFD0;
|
|
}
|
|
table.code td.code.rm {
|
|
background: #FFD0D0;
|
|
}
|
|
table.code td.line-num {
|
|
color: #AAA;
|
|
border-right: 1px solid #EEE;
|
|
padding: 0 5px;
|
|
background: #F8F8F8;
|
|
|
|
-webkit-user-select: none;
|
|
-moz-user-select: none;
|
|
-ms-user-select: none;
|
|
-o-user-select: none;
|
|
user-select: none;
|
|
}
|
|
table.code td.filename {
|
|
background: #EEE;
|
|
border-bottom: 1px solid #CCC;
|
|
padding-left: 5px;
|
|
}
|
|
|
|
|
|
table.code td.code span.str{
|
|
color: #008800;
|
|
}
|
|
table.code td.code span.op{
|
|
font-weight: bold;
|
|
color: #DD7700
|
|
}
|
|
|
|
div.links-overlay {
|
|
background: #EEE;
|
|
border: 1px solid #DDD;
|
|
border-radius: 5px;
|
|
}
|
|
div.links-overlay p {
|
|
margin-top: 5px;
|
|
font-size: 18px;
|
|
line-height: 22px;
|
|
}
|
|
|
|
.grid .unit:last-child {
|
|
padding-right: 10px;
|
|
}
|
|
</style>
|
|
|
|
<div class="container">
|
|
<div class="grid wider" style="padding-top: 100px">
|
|
<div class="unit golden-small" style="text-align: center">
|
|
<img src="/N1/images/watercolor_help.png" style="
|
|
width: 200px;
|
|
margin: auto;
|
|
display: inline-block;
|
|
">
|
|
</div>
|
|
<div class="unit golden-large" style="margin-top: 34px">
|
|
<h2 style="margin-bottom: 10px; margin-top:0">Build an N1 plugin</h2>
|
|
<div style="">
|
|
<h4 style="margin-top: 0">Extend your mail client in five minutes</h4>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="grid wider">
|
|
<div class="unit whole">
|
|
<p>
|
|
Plugins lie at the heart of N1. The thread list, composer
|
|
and other core parts of the app are packages bundled with the
|
|
app, and you can create your own in a matter of minutes.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="grid wider feature" style="margin-top: 60px;">
|
|
<div class="unit two-thirds" style="margin-top:60px;">
|
|
<h3>1. Install N1</h3>
|
|
<p>
|
|
Download and install Nylas for
|
|
<a href="https://invite.nylas.com/download">Mac OS X</a>
|
|
(or <a href="https://invite.nylas.com/download">Linux</a>).
|
|
Open it and sign in to your email account.
|
|
</p>
|
|
</div>
|
|
<div class="unit one-third" style="text-align: right;">
|
|
<img src="/N1/images/screenshot-select-provider.png"/>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="grid wider feature">
|
|
<div class="unit one-third">
|
|
<img src="/N1/images/screenshot-create-plugin.png"/>
|
|
</div>
|
|
<div class="unit two-thirds" style="padding-left: 20px;">
|
|
<h3>2. Create a plugin</h3>
|
|
<p>First, switch over to development mode: go to the <code class="background">Developer</code> menu
|
|
and select <code class="background">Relaunch with debug flags...</code>. Dev mode turns on better exception
|
|
logging and enables hot-reloading, but runs a bit slower.
|
|
</p>
|
|
<p>Next, choose <code class="background">Create a Package...</code> from the the <code class="background">Developer</code> menu,
|
|
and name your new plugin. This will create a directory in <code class="background">~/.nylas/dev/packages</code>
|
|
containing your new plugin.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="grid wider feature">
|
|
<div class="unit three-fifths">
|
|
<h3>3. Start hacking!</h3>
|
|
<p>
|
|
Open the file <code class="background"><your-package-name>/lib/my-message-sidebar.cjsx</code> in your
|
|
favorite text editor. Your new plugin is pre-filled with a simple example component
|
|
for the message sidebar (on the right when you're viewing an email), which is defined in this file. It
|
|
just shows the name of the selected contact, but with a few quick changes we can build something interesting.
|
|
</p>
|
|
<p>
|
|
Scroll down to line 34, the <code class="background">render</code> method. We can replace the code here
|
|
to change what shows up in the sidebar, and see it happen live when we save.
|
|
</p>
|
|
</div>
|
|
<div class="unit two-fifths">
|
|
<table class="code">
|
|
<tbody>
|
|
<tr><td class="filename" colspan="2"><your-package>/lib/my-message-sidebar.cjsx</td></tr>
|
|
<tr><td class="line-num">30</td><td class="code"></td></tr>
|
|
<tr><td class="line-num">31</td><td class="code">componentWillUnmount: =></td></tr>
|
|
<tr><td class="line-num">32</td><td class="code"> @unsubscribe()</td></tr>
|
|
<tr><td class="line-num">33</td><td class="code"></td></tr>
|
|
<tr><td class="line-num">34</td><td class="code hlt">render: =></td></tr>
|
|
<tr><td class="line-num">35</td><td class="code hlt"> <span class="op">if</span> @state.contact</td></tr>
|
|
<tr><td class="line-num">36</td><td class="code hlt"> content = @_renderContent()</td></tr>
|
|
<tr><td class="line-num">37</td><td class="code hlt"> <span class="op">else</span></td></tr>
|
|
<tr><td class="line-num">38</td><td class="code hlt"> content = @_renderPlaceholder()</td></tr>
|
|
<tr><td class="line-num">39</td><td class="code hlt"></td></tr>
|
|
<tr><td class="line-num">40</td><td class="code hlt"> <div className=<span class="str">"my-message-sidebar"</span>></td></tr>
|
|
<tr><td class="line-num">41</td><td class="code hlt"> {content}</td></tr>
|
|
<tr><td class="line-num">42</td><td class="code hlt"> </div></td></tr>
|
|
<tr><td class="line-num">43</td><td class="code"></td></tr>
|
|
<tr><td class="line-num">44</td><td class="code">_renderContent: =></td></tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
</div>
|
|
<div class="grid wider" style="margin-top: 30px">
|
|
|
|
<div class="unit half" >
|
|
<img src="/N1/images/screenshot-base-plugin.png"/>
|
|
</div>
|
|
<div class="unit half" style="margin-top: 50px">
|
|
<p>
|
|
Try opening a message in N1 - you'll see the new package's example text show up on the
|
|
sidebar. Now delete the content of the <code class="background">render</code> method
|
|
and save - the text should disappear.
|
|
</p>
|
|
</div>
|
|
|
|
</div>
|
|
<div class="grid wider" style="margin-top: 30px">
|
|
|
|
<div class="unit one-third">
|
|
<p>
|
|
Now let's add something - a bar that changes color based on the active contact in the
|
|
sidebar. Replace the existing <code class="background">render</code> method with the
|
|
code to the right, then save the file.
|
|
</p>
|
|
</div>
|
|
<div class="unit two-thirds">
|
|
<table class="code">
|
|
<tbody>
|
|
<tr><td class="filename" colspan="2"><your-package>/lib/my-message-sidebar.cjsx</td></tr>
|
|
<tr><td class="line-num">33</td><td class="code"></td></tr>
|
|
<tr><td class="line-num">34</td><td class="code">render: =></td></tr>
|
|
<tr><td class="line-num">35</td><td class="code add"> <div className=<span class="str">"email-color"</span> style={@_getStyles()}></div></td></tr>
|
|
<tr><td class="line-num">36</td><td class="code add"></td></tr>
|
|
<tr><td class="line-num">37</td><td class="code add">_getStyles: =></td></tr>
|
|
<tr><td class="line-num">38</td><td class="code add"> domain = @state.contact.email.split("@")[1]</td></tr>
|
|
<tr><td class="line-num">39</td><td class="code add"> hue = (domain.split('').reduce(((sum, char) -> sum + char.charCodeAt(0)), 0) % 36)*10</td></tr>
|
|
<tr><td class="line-num">40</td><td class="code add"> color = <span class="str">"hsl(#{hue}, 62%, 57%)"</span></td></tr>
|
|
<tr><td class="line-num">41</td><td class="code add"> <span class="op">return</span> {background: color, height: 2, 'margin-top': 5}</td></tr>
|
|
<tr><td class="line-num">42</td><td class="code"></td></tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
</div>
|
|
<div class="grid wider" style="margin-top: 30px">
|
|
|
|
<div class="unit half" style="text-align: right;">
|
|
<img src="/N1/images/screenshot-color-bar.png"/>
|
|
</div>
|
|
<div class="unit half" style="margin-top: 50px">
|
|
<p>
|
|
Now go back to N1, and open a message. You should see a horizontal bar that changes
|
|
color based on the domain of the contact's email address.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
|
|
<div class="grid feature wider">
|
|
<div class="unit whole">
|
|
<h3>That's it!</h3>
|
|
<p>
|
|
Extending the N1 mail client is that simple. Try making more code changes and seeing
|
|
how they affect the message sidebar. Then when you're ready, follow one of the links
|
|
below to learn more.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
<div class="grid wider links-overlay">
|
|
<div class="unit one-third">
|
|
<h4><a href="">Keep building</a></h4>
|
|
<p>
|
|
Build more functionality into the message sidebar in an extended
|
|
tutorial that picks up where this one left off.
|
|
</p>
|
|
</div>
|
|
<div class="unit one-third">
|
|
<h4><a href="">See more examples</a></h4>
|
|
<p>
|
|
Check out our library of example plugins to see what else you can build on top of
|
|
N1.
|
|
</p>
|
|
</div>
|
|
<div class="unit one-third">
|
|
<h4><a href="">Read the docs</a></h4>
|
|
<p>
|
|
Head over to the full API documentation to learn about everything you can leverage
|
|
to build an N1 plugin.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|