Gisle Aune
6 years ago
7 changed files with 144 additions and 6 deletions
-
59marko/page/logs-content/components/add-post-modal/component.js
-
26marko/page/logs-content/components/add-post-modal/index.marko
-
5marko/page/logs-content/components/logs-content-menu/component.js
-
4marko/page/logs-content/components/logs-content-menu/index.marko
-
20marko/page/logs-content/components/page/component.js
-
4marko/page/logs-content/components/page/index.marko
-
30rpdata/api/Post.js
@ -0,0 +1,59 @@ |
|||
const moment = require("moment") |
|||
|
|||
const {postApi} = require("../../../../../rpdata/api/Post") |
|||
|
|||
module.exports = class { |
|||
onCreate(input) { |
|||
this.state = { |
|||
error: null, |
|||
loading: false, |
|||
values: { |
|||
time: moment.utc(new Date()).format("YYYY-MM-DD HH:mm:ss"), |
|||
kind: "text", |
|||
nick: "", |
|||
text: "", |
|||
}, |
|||
} |
|||
|
|||
this.first = false |
|||
} |
|||
|
|||
change(key, ev) { |
|||
this.state.values[key] = ev.target.value |
|||
} |
|||
|
|||
open() { |
|||
} |
|||
|
|||
close() { |
|||
this.first = false |
|||
this.emit("close") |
|||
} |
|||
|
|||
save() { |
|||
if (this.state.loading) { |
|||
return |
|||
} |
|||
|
|||
const values = this.state.values |
|||
|
|||
let time = new Date(values.time + " UTC") |
|||
if (Number.isNaN(time)) { |
|||
this.state.error = `Could not parse ${values.time} as date` |
|||
return |
|||
} |
|||
|
|||
const input = {logId: this.input.logId, time, kind: this.state.values.kind, nick: this.state.values.nick, text: this.state.values.text} |
|||
|
|||
this.state.loading = true |
|||
postApi.add(input).then(data => { |
|||
this.emit("added", data) |
|||
this.emit("close") |
|||
}).catch(errs => { |
|||
console.warn("Failed to add post:", errs) |
|||
this.state.error = "Failed to add post: " + errs[0].message |
|||
}).then(() => { |
|||
this.state.loading = false |
|||
}) |
|||
} |
|||
} |
@ -0,0 +1,26 @@ |
|||
<modal class="modal color-text nolabel" key="modal" enabled=(input.enabled) closable on-close("close") on-open("open") > |
|||
<h1>Add Post</h1> |
|||
|
|||
<p key="error" class="color-error">${state.error}</p> |
|||
|
|||
<label>Timestamp</label> |
|||
<input key="time" placeholder="Title" class="big" on-change("change", "time") value=state.values.time /> |
|||
|
|||
<label>Kind</label> |
|||
<select key="kind" class="big" placeholder="Kind" on-change("change", "kind") value=state.values.kind> |
|||
<option value="text" selected=(state.values.kind === "text")>Text (text, /npc)</option> |
|||
<option value="action" selected=(state.values.kind === "action")>Action (/me, /npca)</option> |
|||
<option value="scene" selected=(state.values.kind === "scene")>Scene (/scene)</option> |
|||
<option value="annotation.info" selected=(state.values.kind === "annotation.info")>Annotation - Info</option> |
|||
<option value="annotation.warning" selected=(state.values.kind === "annotation.warning")>Annotation - Warning</option> |
|||
<option value="annotation.error" selected=(state.values.kind === "annotation.error")>Annotation - Error</option> |
|||
</select> |
|||
|
|||
<label>Nick</label> |
|||
<input key="nick" placeholder="IRC_Nick (You can use non-IRC letters here, like ', but I recommend you don't so the character is found)" class="big" on-change("change", "nick") value=state.values.nick /> |
|||
|
|||
<label>Text</label> |
|||
<textarea key="text" placeholder="Text" class="tall" on-change("change", "text") value=state.values.text /> |
|||
|
|||
<button disabled=state.loading on-click("save")>Add Post</button> |
|||
</modal> |
@ -0,0 +1,5 @@ |
|||
module.exports = class { |
|||
select(value) { |
|||
this.emit("select", value) |
|||
} |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue