128 lines
3.9 KiB
PHP
Executable File
128 lines
3.9 KiB
PHP
Executable File
<?php
|
|
// models/Chapter.php
|
|
|
|
class Chapter {
|
|
private $pdo;
|
|
|
|
public function __construct($pdo) {
|
|
$this->pdo = $pdo;
|
|
}
|
|
|
|
public function findById($id) {
|
|
$stmt = $this->pdo->prepare("
|
|
SELECT c.*, b.user_id, b.title as book_title
|
|
FROM chapters c
|
|
JOIN books b ON c.book_id = b.id
|
|
WHERE c.id = ?
|
|
");
|
|
$stmt->execute([$id]);
|
|
return $stmt->fetch(PDO::FETCH_ASSOC);
|
|
}
|
|
|
|
public function findByBook($book_id) {
|
|
$stmt = $this->pdo->prepare("
|
|
SELECT * FROM chapters
|
|
WHERE book_id = ?
|
|
ORDER BY sort_order, created_at
|
|
");
|
|
$stmt->execute([$book_id]);
|
|
return $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
}
|
|
|
|
public function create($data) {
|
|
$stmt = $this->pdo->prepare("SELECT MAX(sort_order) as max_order FROM chapters WHERE book_id = ?");
|
|
$stmt->execute([$data['book_id']]);
|
|
$result = $stmt->fetch();
|
|
$next_order = ($result['max_order'] ?? 0) + 1;
|
|
|
|
$word_count = $this->countWords($data['content']);
|
|
|
|
$stmt = $this->pdo->prepare("
|
|
INSERT INTO chapters (book_id, title, content, sort_order, word_count, status)
|
|
VALUES (?, ?, ?, ?, ?, ?)
|
|
");
|
|
return $stmt->execute([
|
|
$data['book_id'],
|
|
$data['title'],
|
|
$data['content'],
|
|
$next_order,
|
|
$word_count,
|
|
$data['status'] ?? 'draft'
|
|
]);
|
|
}
|
|
|
|
public function update($id, $data) {
|
|
$word_count = $this->countWords($data['content']);
|
|
|
|
$stmt = $this->pdo->prepare("
|
|
UPDATE chapters
|
|
SET title = ?, content = ?, word_count = ?, status = ?, updated_at = CURRENT_TIMESTAMP
|
|
WHERE id = ?
|
|
");
|
|
return $stmt->execute([
|
|
$data['title'],
|
|
$data['content'],
|
|
$word_count,
|
|
$data['status'] ?? 'draft',
|
|
$id
|
|
]);
|
|
}
|
|
|
|
public function delete($id) {
|
|
$stmt = $this->pdo->prepare("DELETE FROM chapters WHERE id = ?");
|
|
return $stmt->execute([$id]);
|
|
}
|
|
|
|
public function updateSortOrder($chapter_id, $new_order) {
|
|
$stmt = $this->pdo->prepare("UPDATE chapters SET sort_order = ? WHERE id = ?");
|
|
return $stmt->execute([$new_order, $chapter_id]);
|
|
}
|
|
|
|
private function countWords($text) {
|
|
$text = strip_tags($text);
|
|
$text = preg_replace('/[^\p{L}\p{N}\s]/u', ' ', $text);
|
|
$words = preg_split('/\s+/', $text);
|
|
$words = array_filter($words);
|
|
return count($words);
|
|
}
|
|
|
|
public function userOwnsChapter($chapter_id, $user_id) {
|
|
$stmt = $this->pdo->prepare("
|
|
SELECT c.id
|
|
FROM chapters c
|
|
JOIN books b ON c.book_id = b.id
|
|
WHERE c.id = ? AND b.user_id = ?
|
|
");
|
|
$stmt->execute([$chapter_id, $user_id]);
|
|
return $stmt->fetch() !== false;
|
|
}
|
|
|
|
|
|
public function getPublishedChapters($book_id) {
|
|
$stmt = $this->pdo->prepare("
|
|
SELECT * FROM chapters
|
|
WHERE book_id = ? AND status = 'published'
|
|
ORDER BY sort_order, created_at
|
|
");
|
|
$stmt->execute([$book_id]);
|
|
return $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
}
|
|
|
|
// private function getAllChapters($book_id) {
|
|
// $stmt = $this->pdo->prepare("SELECT id, content FROM chapters WHERE book_id = ?");
|
|
// $stmt->execute([$book_id]);
|
|
// return $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
// }
|
|
|
|
// private function updateChapterContent($chapter_id, $content) {
|
|
// $word_count = $this->countWords($content);
|
|
// $stmt = $this->pdo->prepare("
|
|
// UPDATE chapters
|
|
// SET content = ?, word_count = ?, updated_at = CURRENT_TIMESTAMP
|
|
// WHERE id = ?
|
|
// ");
|
|
// return $stmt->execute([$content, $word_count, $chapter_id]);
|
|
// }
|
|
|
|
}
|
|
?>
|