2015-07-28 02:31:08 +00:00
|
|
|
// labels is a map of campaign statuses to
|
|
|
|
// CSS classes
|
|
|
|
var labels = {
|
2016-01-17 04:59:40 +00:00
|
|
|
"In progress": "label-primary",
|
|
|
|
"Queued": "label-info",
|
|
|
|
"Completed": "label-success",
|
|
|
|
"Emails Sent": "label-success",
|
|
|
|
"Error": "label-danger"
|
2015-07-28 02:31:08 +00:00
|
|
|
}
|
|
|
|
|
2016-01-17 05:50:11 +00:00
|
|
|
var campaigns = []
|
|
|
|
|
2015-06-17 04:09:27 +00:00
|
|
|
// Save attempts to POST to /campaigns/
|
2016-01-17 04:59:40 +00:00
|
|
|
function save() {
|
2015-09-16 03:57:47 +00:00
|
|
|
groups = []
|
2016-01-17 04:59:40 +00:00
|
|
|
$.each($("#groupTable").DataTable().rows().data(), function(i, group) {
|
|
|
|
groups.push({
|
|
|
|
name: group[0]
|
|
|
|
})
|
|
|
|
})
|
2015-06-17 03:22:51 +00:00
|
|
|
var campaign = {
|
2016-01-17 04:59:40 +00:00
|
|
|
name: $("#name").val(),
|
|
|
|
template: {
|
|
|
|
name: $("#template").val()
|
|
|
|
},
|
|
|
|
url: $("#url").val(),
|
|
|
|
page: {
|
|
|
|
name: $("#page").val()
|
|
|
|
},
|
|
|
|
smtp: {
|
|
|
|
from_address: $("input[name=from]").val(),
|
|
|
|
host: $("input[name=host]").val(),
|
|
|
|
username: $("input[name=username]").val(),
|
|
|
|
password: $("input[name=password]").val(),
|
|
|
|
},
|
|
|
|
groups: groups
|
|
|
|
}
|
|
|
|
// Submit the campaign
|
2015-06-17 04:09:27 +00:00
|
|
|
api.campaigns.post(campaign)
|
2016-01-17 04:59:40 +00:00
|
|
|
.success(function(data) {
|
|
|
|
successFlash("Campaign successfully launched!")
|
|
|
|
window.location = "/campaigns/" + campaign.id.toString()
|
|
|
|
})
|
|
|
|
.error(function(data) {
|
|
|
|
$("#modal\\.flashes").empty().append("<div style=\"text-align:center\" class=\"alert alert-danger\">\
|
2015-06-17 03:22:51 +00:00
|
|
|
<i class=\"fa fa-exclamation-circle\"></i> " + data.responseJSON.message + "</div>")
|
2016-01-17 04:59:40 +00:00
|
|
|
})
|
2015-06-17 03:22:51 +00:00
|
|
|
}
|
2015-06-17 04:09:27 +00:00
|
|
|
|
2016-01-17 04:59:40 +00:00
|
|
|
function dismiss() {
|
2015-06-18 03:44:05 +00:00
|
|
|
$("#modal\\.flashes").empty()
|
|
|
|
$("#modal").modal('hide')
|
2015-07-07 03:26:08 +00:00
|
|
|
$("#groupTable").dataTable().DataTable().clear().draw()
|
2015-06-18 03:44:05 +00:00
|
|
|
}
|
|
|
|
|
2016-01-17 05:50:11 +00:00
|
|
|
function deleteCampaign(idx) {
|
|
|
|
if (confirm("Delete " + campaigns[idx].name + "?")) {
|
|
|
|
api.campaignId.delete(campaigns[idx].id)
|
|
|
|
.success(function(data) {
|
|
|
|
successFlash(data.message)
|
2016-01-17 19:15:32 +00:00
|
|
|
location.reload()
|
2016-01-17 05:50:11 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-17 04:59:40 +00:00
|
|
|
function edit(campaign) {
|
2015-07-07 03:26:08 +00:00
|
|
|
// Clear the bloodhound instance
|
2015-09-16 03:57:47 +00:00
|
|
|
group_bh.clear();
|
|
|
|
template_bh.clear();
|
2015-10-23 03:29:10 +00:00
|
|
|
page_bh.clear();
|
2015-06-30 04:52:26 +00:00
|
|
|
if (campaign == "new") {
|
|
|
|
api.groups.get()
|
2016-01-17 04:59:40 +00:00
|
|
|
.success(function(groups) {
|
|
|
|
if (groups.length == 0) {
|
|
|
|
modalError("No groups found!")
|
|
|
|
return false;
|
|
|
|
} else {
|
|
|
|
group_bh.add(groups)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
api.templates.get()
|
|
|
|
.success(function(templates) {
|
|
|
|
if (templates.length == 0) {
|
|
|
|
modalError("No templates found!")
|
|
|
|
return false
|
|
|
|
} else {
|
|
|
|
template_bh.add(templates)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
api.pages.get()
|
|
|
|
.success(function(pages) {
|
|
|
|
if (pages.length == 0) {
|
|
|
|
modalError("No pages found!")
|
|
|
|
return false
|
|
|
|
} else {
|
|
|
|
page_bh.add(pages)
|
|
|
|
}
|
|
|
|
})
|
2015-06-30 04:52:26 +00:00
|
|
|
}
|
2015-06-17 04:09:27 +00:00
|
|
|
}
|
|
|
|
|
2016-01-17 04:59:40 +00:00
|
|
|
$(document).ready(function() {
|
2015-06-17 04:09:27 +00:00
|
|
|
api.campaigns.get()
|
2016-01-17 05:50:11 +00:00
|
|
|
.success(function(cs) {
|
|
|
|
campaigns = cs
|
2016-01-17 04:59:40 +00:00
|
|
|
$("#loading").hide()
|
|
|
|
if (campaigns.length > 0) {
|
|
|
|
$("#campaignTable").show()
|
|
|
|
campaignTable = $("#campaignTable").DataTable();
|
|
|
|
$.each(campaigns, function(i, campaign) {
|
|
|
|
label = labels[campaign.status] || "label-default";
|
|
|
|
campaignTable.row.add([
|
|
|
|
campaign.name,
|
|
|
|
moment(campaign.created_date).format('MMMM Do YYYY, h:mm:ss a'),
|
|
|
|
"<span class=\"label " + label + "\">" + campaign.status + "</span>",
|
2016-01-18 04:20:38 +00:00
|
|
|
"<div class='pull-right'><a class='btn btn-primary' href='/campaigns/" + campaign.id + "' data-toggle='tooltip' data-placement='left' title='View Results'>\
|
2015-07-07 03:26:08 +00:00
|
|
|
<i class='fa fa-bar-chart'></i>\
|
2015-08-05 02:27:04 +00:00
|
|
|
</a>\
|
2016-01-18 04:20:38 +00:00
|
|
|
<button class='btn btn-danger' onclick='deleteCampaign(" + i + ")' data-toggle='tooltip' data-placement='left' title='Delete Campaign'>\
|
2015-07-07 03:26:08 +00:00
|
|
|
<i class='fa fa-trash-o'></i>\
|
|
|
|
</button></div>"
|
2016-01-17 04:59:40 +00:00
|
|
|
]).draw()
|
2016-01-18 04:20:38 +00:00
|
|
|
$('[data-toggle="tooltip"]').tooltip()
|
2016-01-17 04:59:40 +00:00
|
|
|
})
|
|
|
|
} else {
|
|
|
|
$("#emptyMessage").show()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.error(function() {
|
|
|
|
$("#loading").hide()
|
|
|
|
errorFlash("Error fetching campaigns")
|
|
|
|
})
|
|
|
|
$("#groupForm").submit(function() {
|
|
|
|
groupTable.row.add([
|
|
|
|
$("#groupSelect").val(),
|
|
|
|
'<span style="cursor:pointer;"><i class="fa fa-trash-o"></i></span>'
|
|
|
|
]).draw()
|
|
|
|
$("#groupTable").on("click", "span>i.fa-trash-o", function() {
|
|
|
|
groupTable.row($(this).parents('tr'))
|
|
|
|
.remove()
|
|
|
|
.draw();
|
2015-06-17 04:09:27 +00:00
|
|
|
})
|
2016-01-17 04:59:40 +00:00
|
|
|
return false;
|
2015-07-07 03:26:08 +00:00
|
|
|
})
|
2016-01-17 04:59:40 +00:00
|
|
|
// Create the group typeahead objects
|
2015-07-07 03:26:08 +00:00
|
|
|
groupTable = $("#groupTable").DataTable()
|
2015-09-16 03:57:47 +00:00
|
|
|
group_bh = new Bloodhound({
|
2016-01-17 04:59:40 +00:00
|
|
|
datumTokenizer: function(g) {
|
|
|
|
return Bloodhound.tokenizers.whitespace(g.name)
|
|
|
|
},
|
2015-07-07 03:26:08 +00:00
|
|
|
queryTokenizer: Bloodhound.tokenizers.whitespace,
|
|
|
|
local: []
|
|
|
|
})
|
2015-09-16 03:57:47 +00:00
|
|
|
group_bh.initialize()
|
2015-07-07 03:26:08 +00:00
|
|
|
$("#groupSelect.typeahead.form-control").typeahead({
|
2016-01-17 04:59:40 +00:00
|
|
|
hint: true,
|
|
|
|
highlight: true,
|
|
|
|
minLength: 1
|
|
|
|
}, {
|
|
|
|
name: "groups",
|
|
|
|
source: group_bh,
|
|
|
|
templates: {
|
|
|
|
empty: function(data) {
|
|
|
|
return '<div class="tt-suggestion">No groups matched that query</div>'
|
|
|
|
},
|
|
|
|
suggestion: function(data) {
|
|
|
|
return '<div>' + data.name + '</div>'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.bind('typeahead:select', function(ev, group) {
|
|
|
|
$("#groupSelect").typeahead('val', group.name)
|
|
|
|
})
|
|
|
|
.bind('typeahead:autocomplete', function(ev, group) {
|
|
|
|
$("#groupSelect").typeahead('val', group.name)
|
|
|
|
});
|
2015-09-16 03:57:47 +00:00
|
|
|
// Create the template typeahead objects
|
|
|
|
template_bh = new Bloodhound({
|
2016-01-17 04:59:40 +00:00
|
|
|
datumTokenizer: function(t) {
|
|
|
|
return Bloodhound.tokenizers.whitespace(t.name)
|
|
|
|
},
|
2015-09-16 03:57:47 +00:00
|
|
|
queryTokenizer: Bloodhound.tokenizers.whitespace,
|
|
|
|
local: []
|
|
|
|
})
|
|
|
|
template_bh.initialize()
|
|
|
|
$("#template.typeahead.form-control").typeahead({
|
2016-01-17 04:59:40 +00:00
|
|
|
hint: true,
|
|
|
|
highlight: true,
|
|
|
|
minLength: 1
|
|
|
|
}, {
|
|
|
|
name: "templates",
|
|
|
|
source: template_bh,
|
|
|
|
templates: {
|
|
|
|
empty: function(data) {
|
|
|
|
return '<div class="tt-suggestion">No templates matched that query</div>'
|
|
|
|
},
|
|
|
|
suggestion: function(data) {
|
|
|
|
return '<div>' + data.name + '</div>'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.bind('typeahead:select', function(ev, template) {
|
|
|
|
$("#template").typeahead('val', template.name)
|
|
|
|
})
|
|
|
|
.bind('typeahead:autocomplete', function(ev, template) {
|
|
|
|
$("#template").typeahead('val', template.name)
|
|
|
|
});
|
2015-10-23 03:29:10 +00:00
|
|
|
// Create the landing page typeahead objects
|
|
|
|
page_bh = new Bloodhound({
|
2016-01-17 04:59:40 +00:00
|
|
|
datumTokenizer: function(p) {
|
|
|
|
return Bloodhound.tokenizers.whitespace(p.name)
|
|
|
|
},
|
2015-10-23 03:29:10 +00:00
|
|
|
queryTokenizer: Bloodhound.tokenizers.whitespace,
|
|
|
|
local: []
|
|
|
|
})
|
|
|
|
page_bh.initialize()
|
|
|
|
$("#page.typeahead.form-control").typeahead({
|
2016-01-17 04:59:40 +00:00
|
|
|
hint: true,
|
|
|
|
highlight: true,
|
|
|
|
minLength: 1
|
|
|
|
}, {
|
|
|
|
name: "pages",
|
|
|
|
source: page_bh,
|
|
|
|
templates: {
|
|
|
|
empty: function(data) {
|
|
|
|
return '<div class="tt-suggestion">No pages matched that query</div>'
|
|
|
|
},
|
|
|
|
suggestion: function(data) {
|
|
|
|
return '<div>' + data.name + '</div>'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.bind('typeahead:select', function(ev, page) {
|
|
|
|
$("#page").typeahead('val', page.name)
|
|
|
|
})
|
|
|
|
.bind('typeahead:autocomplete', function(ev, page) {
|
|
|
|
$("#page").typeahead('val', page.name)
|
|
|
|
});
|
2015-06-16 03:51:18 +00:00
|
|
|
})
|