Gisle Aune
6 years ago
9 changed files with 221 additions and 13 deletions
-
68marko/page/logs-content/components/edit-log-modal/component.js
-
25marko/page/logs-content/components/edit-log-modal/index.marko
-
2marko/page/logs-content/components/logs-content-menu/index.marko
-
4marko/page/logs-content/components/page/component.js
-
8marko/page/logs-content/components/page/index.marko
-
23marko/page/logs-content/components/page/style.less
-
2marko/page/logs/components/logs-list/index.marko
-
94rpdata/api/Log.js
-
6rpdata/api/LogHeader.js
@ -0,0 +1,68 @@ |
|||||
|
const moment = require("moment") |
||||
|
|
||||
|
const {logsApi} = require("../../../../../rpdata/api/Log") |
||||
|
|
||||
|
module.exports = class { |
||||
|
onCreate(input) { |
||||
|
this.state = { |
||||
|
error: null, |
||||
|
loading: false, |
||||
|
values: { |
||||
|
title: "", |
||||
|
event: "", |
||||
|
description: "", |
||||
|
open: false, |
||||
|
}, |
||||
|
} |
||||
|
|
||||
|
this.first = false |
||||
|
} |
||||
|
|
||||
|
onInput(input) { |
||||
|
if (input.log && !this.first) { |
||||
|
this.state.values = { |
||||
|
title: input.log.title, |
||||
|
event: input.log.eventName, |
||||
|
description: input.log.description, |
||||
|
open: input.log.open, |
||||
|
} |
||||
|
|
||||
|
this.first = true |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
change(key, ev) { |
||||
|
this.state.values[key] = ev.target.value |
||||
|
this.state.values = Object.assign({}, this.state.values) |
||||
|
} |
||||
|
|
||||
|
open() { |
||||
|
this.state.loading = false |
||||
|
} |
||||
|
|
||||
|
close() { |
||||
|
this.first = false |
||||
|
this.emit("close") |
||||
|
} |
||||
|
|
||||
|
save() { |
||||
|
if (this.state.loading) { |
||||
|
return |
||||
|
} |
||||
|
|
||||
|
const input = Object.assign({id: this.input.log.id}, this.state.values) |
||||
|
console.log(input) |
||||
|
|
||||
|
this.state.loading = true |
||||
|
logsApi.edit(input).then(data => { |
||||
|
this.emit("edited", data) |
||||
|
this.emit("close") |
||||
|
}).catch(errs => { |
||||
|
console.warn("Failed to edit:", errs) |
||||
|
|
||||
|
this.state.error = "Failed to edit: " + errs[0].message |
||||
|
}).then(() => { |
||||
|
this.state.loading = false |
||||
|
}) |
||||
|
} |
||||
|
} |
@ -0,0 +1,25 @@ |
|||||
|
import moment from "moment" |
||||
|
|
||||
|
<modal class="modal color-text nolabel" key="modal" enabled=(input.enabled) closable on-close("close") on-open("open") > |
||||
|
<h1>Edit Log</h1> |
||||
|
|
||||
|
<p key="error" class="color-error">${state.error}</p> |
||||
|
|
||||
|
<label>Title</label> |
||||
|
<input key="title" placeholder=(input.log.channel.name + " – " + moment(input.log.date).format("MMMM D, YYYY")) class="big" on-change("change", "title") value=state.values.title /> |
||||
|
|
||||
|
<label>Event Name</label> |
||||
|
<input key="event" placeholder="(Optional)" class="big" on-change("change", "event") value=state.values.event /> |
||||
|
|
||||
|
<label>Description</label> |
||||
|
<textarea key="description" placeholder="(Optional)" on-change("change", "description") value=state.values.description /> |
||||
|
|
||||
|
<toggle value=state.values.open on="Open" off="Closed" |
||||
|
onDesc=("New posts in "+input.log.channel.name+" will end up here.") |
||||
|
offDesc="The logbot will not append to this log." |
||||
|
on-change("change", "open") /> |
||||
|
|
||||
|
<p if(state.values.open) key="warning" class="color-danger">Opening a log will close all others for the same channels.</p> |
||||
|
|
||||
|
<button disabled=state.loading on-click("save")>Save</button> |
||||
|
</modal> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue