2018-04-02 05:34:16 +00:00
|
|
|
import AnimeNotifier from "../AnimeNotifier"
|
2017-10-17 09:27:15 +00:00
|
|
|
|
|
|
|
// Edit post
|
|
|
|
export function editPost(arn: AnimeNotifier, element: HTMLElement) {
|
|
|
|
let postId = element.dataset.id
|
|
|
|
|
2018-04-02 05:44:11 +00:00
|
|
|
let render = document.getElementById("render-" + postId)
|
|
|
|
let toolbar = document.getElementById("toolbar-" + postId)
|
|
|
|
let title = document.getElementById("title-" + postId)
|
|
|
|
let source = document.getElementById("source-" + postId)
|
|
|
|
let edit = document.getElementById("edit-toolbar-" + postId)
|
2017-10-17 09:27:15 +00:00
|
|
|
|
|
|
|
render.classList.toggle("hidden")
|
|
|
|
toolbar.classList.toggle("hidden")
|
|
|
|
source.classList.toggle("hidden")
|
|
|
|
edit.classList.toggle("hidden")
|
|
|
|
|
|
|
|
if(title) {
|
|
|
|
title.classList.toggle("hidden")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save post
|
|
|
|
export function savePost(arn: AnimeNotifier, element: HTMLElement) {
|
|
|
|
let postId = element.dataset.id
|
2018-04-02 05:44:11 +00:00
|
|
|
let source = document.getElementById("source-" + postId) as HTMLTextAreaElement
|
|
|
|
let title = document.getElementById("title-" + postId) as HTMLInputElement
|
2017-10-17 09:27:15 +00:00
|
|
|
let text = source.value
|
|
|
|
|
|
|
|
let updates: any = {
|
|
|
|
Text: text,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add title for threads only
|
|
|
|
if(title) {
|
|
|
|
updates.Title = title.value
|
|
|
|
}
|
|
|
|
|
|
|
|
let apiEndpoint = arn.findAPIEndpoint(element)
|
|
|
|
|
|
|
|
arn.post(apiEndpoint, updates)
|
|
|
|
.then(() => arn.reloadContent())
|
|
|
|
.catch(err => arn.statusMessage.showError(err))
|
|
|
|
}
|
|
|
|
|
2017-11-25 14:26:56 +00:00
|
|
|
// Delete post
|
2017-11-24 22:55:29 +00:00
|
|
|
export function deletePost(arn: AnimeNotifier, element: HTMLElement) {
|
2017-11-25 14:26:56 +00:00
|
|
|
if(!confirm(`Are you sure you want to delete this Post?`)) {
|
2017-11-24 22:55:29 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
let endpoint = arn.findAPIEndpoint(element)
|
|
|
|
|
2018-04-25 16:59:23 +00:00
|
|
|
arn.post(endpoint + "/delete")
|
2017-11-25 14:26:56 +00:00
|
|
|
.then(() => arn.reloadContent())
|
|
|
|
.catch(err => arn.statusMessage.showError(err))
|
2017-11-24 22:55:29 +00:00
|
|
|
}
|
|
|
|
|
2018-10-29 02:30:23 +00:00
|
|
|
// Create post
|
|
|
|
export function createPost(arn: AnimeNotifier, element: HTMLElement) {
|
|
|
|
let textarea = document.getElementById("new-post") as HTMLTextAreaElement
|
|
|
|
let {parentId, parentType} = element.dataset
|
2017-10-17 09:27:15 +00:00
|
|
|
|
|
|
|
let post = {
|
|
|
|
text: textarea.value,
|
2018-10-29 02:30:23 +00:00
|
|
|
parentId,
|
|
|
|
parentType,
|
2017-10-17 09:27:15 +00:00
|
|
|
tags: []
|
|
|
|
}
|
|
|
|
|
|
|
|
arn.post("/api/new/post", post)
|
|
|
|
.then(() => arn.reloadContent())
|
|
|
|
.then(() => textarea.value = "")
|
|
|
|
.catch(err => arn.statusMessage.showError(err))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create thread
|
|
|
|
export function createThread(arn: AnimeNotifier) {
|
2018-04-02 05:44:11 +00:00
|
|
|
let title = document.getElementById("title") as HTMLInputElement
|
|
|
|
let text = document.getElementById("text") as HTMLTextAreaElement
|
|
|
|
let category = document.getElementById("tag") as HTMLInputElement
|
2017-10-17 09:27:15 +00:00
|
|
|
|
|
|
|
let thread = {
|
|
|
|
title: title.value,
|
|
|
|
text: text.value,
|
|
|
|
tags: [category.value]
|
|
|
|
}
|
|
|
|
|
|
|
|
arn.post("/api/new/thread", thread)
|
|
|
|
.then(() => arn.app.load("/forum/" + thread.tags[0]))
|
|
|
|
.catch(err => arn.statusMessage.showError(err))
|
2018-04-25 16:59:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Lock thread
|
|
|
|
export function lockThread(arn: AnimeNotifier, element: HTMLButtonElement) {
|
|
|
|
setThreadLock(arn, element, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unlock thread
|
|
|
|
export function unlockThread(arn: AnimeNotifier, element: HTMLButtonElement) {
|
|
|
|
setThreadLock(arn, element, false)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set thread locked state
|
|
|
|
function setThreadLock(arn: AnimeNotifier, element: HTMLButtonElement, state: boolean) {
|
|
|
|
let verb = state ? "lock" : "unlock"
|
|
|
|
|
|
|
|
if(!confirm(`Are you sure you want to ${verb} this Thread?`)) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
let endpoint = arn.findAPIEndpoint(element)
|
|
|
|
|
|
|
|
arn.post(`${endpoint}/${verb}`)
|
|
|
|
.then(() => arn.reloadContent())
|
|
|
|
.catch(err => arn.statusMessage.showError(err))
|
2017-10-17 09:27:15 +00:00
|
|
|
}
|