aboutsummaryrefslogtreecommitdiff
path: root/admin/tools/edit_row.php
blob: ceb59f391f55d9429f94fa3d79279c2bf117cf35 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
session_start();

// Load configuration
$config = include(__DIR__ . '/../../config.php');

// Get the website ID from the session
$websiteId = $_SESSION['websiteId'] ?? 1;

// Find the website configuration
$websiteConfig = array_filter($config, function($site) use ($websiteId) {
    return isset($site['id']) && $site['id'] === $websiteId;
});
$websiteConfig = reset($websiteConfig);

// Connect to SQLite database
$db = new SQLite3($websiteConfig['database']);

// Get the table and ID from the request
$table = $_GET['table'] ?? '';
$id = $_GET['id'] ?? 0;

$columns = [];
$columnsResult = $db->query("PRAGMA table_info($table)");
while ($row = $columnsResult->fetchArray(SQLITE3_ASSOC)) {
    $columns[] = $row['name'];
}

$stmt = $db->prepare("SELECT * FROM $table WHERE id = :id");
$stmt->bindValue(':id', $id, SQLITE3_INTEGER);
$result = $stmt->execute();

if ($result) {
    $row = $result->fetchArray(SQLITE3_ASSOC);
} else {
    $row = null;
}

if (isset($_POST['save_changes'])) {
    foreach ($columns as $column) {
        $value = $_POST[$column] ?: null;
        if ($column == 'date' && empty($value)) {
            $value = date('Y-m-d H:i:s');
        }
        if ($table == 'content' && $column == 'custom_html') {
            $value = $value ? 1 : 0;
        }
        $stmt = $db->prepare("UPDATE $table SET $column = :value WHERE id = :id");
        $stmt->bindValue(':value', $value, SQLITE3_TEXT);
        $stmt->bindValue(':id', $id, SQLITE3_INTEGER);
        $stmt->execute();
    }
    header("Location: edit_database.php?table=$table");
    exit();
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Edit Row</title>
</head>
<body>
    <h1>Edit Row in Table: <?php echo htmlspecialchars($table); ?></h1>
    <form method="post">
        <?php foreach ($columns as $column): ?>
            <label for="<?php echo htmlspecialchars($column); ?>"><?php echo htmlspecialchars($column); ?>:</label>
            <?php if ($table == 'content' && $column == 'content'): ?>
                <textarea id="<?php echo htmlspecialchars($column); ?>" name="<?php echo htmlspecialchars($column); ?>" style="resize: both;"><?php echo htmlspecialchars($row[$column] ?? ''); ?></textarea>
            <?php else: ?>
                <input type="text" id="<?php echo htmlspecialchars($column); ?>" name="<?php echo htmlspecialchars($column); ?>" value="<?php echo htmlspecialchars($row[$column] ?? ''); ?>">
            <?php endif; ?>
            <br>
        <?php endforeach; ?>
        <button type="submit" name="save_changes">Save Changes</button>
    </form>
    <a href="edit_database.php?table=<?php echo htmlspecialchars($table); ?>">Back to Table</a>
</body>
</html>