summaryrefslogtreecommitdiff
path: root/public/assets/js/lib/views/index/threadform.js
diff options
context:
space:
mode:
Diffstat (limited to 'public/assets/js/lib/views/index/threadform.js')
-rw-r--r--public/assets/js/lib/views/index/threadform.js91
1 files changed, 48 insertions, 43 deletions
diff --git a/public/assets/js/lib/views/index/threadform.js b/public/assets/js/lib/views/index/threadform.js
index b71eea0..ad3c2fb 100644
--- a/public/assets/js/lib/views/index/threadform.js
+++ b/public/assets/js/lib/views/index/threadform.js
@@ -1,5 +1,4 @@
var ThreadForm = FormView.extend({
-
el: "#thread_form",
events: {
@@ -9,58 +8,64 @@ var ThreadForm = FormView.extend({
action: "/api/thread",
method: "POST",
- initialize: function(){
- this.__super__.initialize.call(this)
- this.template = this.$(".template").html()
+ initialize: function () {
+ this.__super__.initialize.call(this);
+ this.template = this.$(".template").html();
},
- load: function(selected_keyword){
- $.get("/api/keywords", function(data){
- var tags = {}
- data.keywords.forEach(keyword => {
- var kw = keyword.keyword
- var opt = document.createElement('option')
- opt.value = kw
- opt.innerHTML = kw
- tags[kw] = opt
- })
- var sorted = Object.keys(tags).sort().map(kw => tags[kw])
- this.$('[name=keyword]').append(sorted)
- if (selected_keyword) {
- this.$('[name=keyword]').val(selected_keyword)
- } else {
- this.$('[name=keyword]').val('unsorted')
- }
- $("body").removeClass('loading')
- }.bind(this))
+ load: function (selected_keyword) {
+ $.get(
+ "/api/keywords",
+ function (data) {
+ var tags = {};
+ data.keywords.forEach((keyword) => {
+ var kw = keyword.keyword;
+ var opt = document.createElement("option");
+ opt.value = kw;
+ opt.innerHTML = kw;
+ tags[kw] = opt;
+ });
+ var sorted = Object.keys(tags)
+ .sort()
+ .map((kw) => tags[kw]);
+ this.$("[name=keyword]").append(sorted);
+ if (selected_keyword) {
+ this.$("[name=keyword]").val(selected_keyword);
+ } else {
+ this.$("[name=keyword]").val("unsorted");
+ }
+ $("body").removeClass("loading");
+ }.bind(this)
+ );
},
- keydown: function(e){
- if ((e.ctrlKey || e.metaKey || e.altKey) && e.keyCode == 83) { // "s" key
- e.preventDefault()
- e.stopPropagation()
- this.save()
+ keydown: function (e) {
+ if ((e.ctrlKey || e.metaKey || e.altKey) && e.keyCode == 83) {
+ // "s" key
+ e.preventDefault();
+ e.stopPropagation();
+ this.save();
}
},
- validate: function(){
- var errors = []
- var title = this.$("[name=title]").val()
- if (! title || ! title.length) {
- errors.push("Please title your post.")
+ validate: function () {
+ var errors = [];
+ var title = this.$("[name=title]").val();
+ if (!title || !title.length) {
+ errors.push("Please title your post.");
}
- var comment = this.$("[name=comment]").val()
- var files = this.$("[name=files]").val()
- if ((! comment || ! comment.length) && ! files) {
- errors.push("Please enter a comment or add some files.")
+ var comment = this.$("[name=comment]").val();
+ var files = this.$("[name=files]").val();
+ if ((!comment || !comment.length) && !files) {
+ errors.push("Please enter a comment or add some files.");
}
- return errors.length ? errors : null
+ return errors.length ? errors : null;
},
- success: function(data){
+ success: function (data) {
if (data.error) {
- return alert(data.error)
+ return alert(data.error);
}
- window.location.href = "/details/" + data.id
- }
-})
+ window.location.href = "/details/" + data.id;
+ },
+});