Mailspring/examples/N1-Quick-Schedule/lib/availability-composer-extension.coffee

38 lines
1.6 KiB
CoffeeScript
Raw Normal View History

{ComposerExtension} = require 'nylas-exports'
2015-10-03 07:06:56 +08:00
request = require 'request'
post = Promise.promisify(request.post, multiArgs: true)
2015-10-03 07:06:56 +08:00
class AvailabilityComposerExtension extends ComposerExtension
2015-10-03 07:06:56 +08:00
# When subclassing the ComposerExtension, you can add your own custom logic
2015-10-03 07:06:56 +08:00
# to execute before a draft is sent in the @finalizeSessionBeforeSending
# method. Here, we're registering the events before we send the draft.
@finalizeSessionBeforeSending: (session) ->
2015-10-03 07:06:56 +08:00
body = session.draft().body
participants = session.draft().participants()
sender = session.draft().from
matches = (/data-quick-schedule="(.*)?" style/).exec body
2015-10-03 07:06:56 +08:00
if matches?
json = atob(matches[1])
2015-10-03 07:06:56 +08:00
data = JSON.parse(json)
data.attendees = []
data.attendees = participants.map (p) ->
name: p.name, email: p.email, isSender: p.isMe()
serverUrl = "https://quickschedule.herokuapp.com/register-events"
post({url: serverUrl, body: JSON.stringify(data)})
.then (args) =>
data = args[1]
return data
.catch (error) ->
dialog = require('remote').require('dialog')
dialog.showErrorBox('Error creating QuickSchedule event',
"There was a problem connecting to the QuickSchedule server. Make sure you're connected to the internet and "+
"try sending again. If problems persist, contact the N1 team (using the blue question icon at the bottom right "+
"of your inbox) and we'll get right on it!")
Promise.reject(error)
else
Promise.resolve()
2015-10-03 07:06:56 +08:00
module.exports = AvailabilityComposerExtension