346 lines
14 KiB
PHP
346 lines
14 KiB
PHP
<?php
|
|
include '../auth.php';
|
|
include '../../koneksi.php';
|
|
?>
|
|
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta content="width=device-width, initial-scale=1.0" name="viewport">
|
|
|
|
<title>Tambahkan Artikel | Admin</title>
|
|
<meta content="" name="description">
|
|
<meta content="" name="keywords">
|
|
<meta name="robots" content="noindex">
|
|
|
|
|
|
<!-- Favicons -->
|
|
<link href="../../assets/img/favicon.png" rel="icon">
|
|
<link href="../../assets/img/apple-touch-icon.png" rel="apple-touch-icon">
|
|
|
|
<!-- Google Fonts -->
|
|
<link href="https://fonts.gstatic.com" rel="preconnect">
|
|
<link href="https://fonts.googleapis.com/css?family=Open+Sans:300,300i,400,400i,600,600i,700,700i|Nunito:300,300i,400,400i,600,600i,700,700i|Poppins:300,300i,400,400i,500,500i,600,600i,700,700i" rel="stylesheet">
|
|
|
|
<!-- Vendor CSS Files -->
|
|
<link href="../../assets/template/vendor/bootstrap/css/bootstrap.min.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/bootstrap-icons/bootstrap-icons.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/boxicons/css/boxicons.min.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/quill/quill.snow.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/quill/quill.bubble.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/remixicon/remixicon.css" rel="stylesheet">
|
|
<link href="../../assets/template/vendor/simple-datatables/style.css" rel="stylesheet">
|
|
|
|
<!-- Template Main CSS File -->
|
|
<link href="../../assets/template/css/style.css" rel="stylesheet">
|
|
|
|
<!-- =======================================================
|
|
* Template Name: NiceAdmin
|
|
* Template URL: https://bootstrapmade.com/nice-admin-bootstrap-admin-html-template/
|
|
* Updated: Apr 20 2024 with Bootstrap v5.3.3
|
|
* Author: BootstrapMade.com
|
|
* License: https://bootstrapmade.com/license/
|
|
======================================================== -->
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<!-- ======= Header ======= -->
|
|
<header id="header" class="header fixed-top d-flex align-items-center">
|
|
|
|
<div class="d-flex align-items-center justify-content-between">
|
|
<a href="" class="logo d-flex align-items-center">
|
|
<img src="../../assets/img/logo.png" alt="">
|
|
<span class="d-none d-lg-block">Portal UMKM</span>
|
|
</a>
|
|
<i class="bi bi-list toggle-sidebar-btn"></i>
|
|
</div><!-- End Logo -->
|
|
|
|
<nav class="header-nav ms-auto">
|
|
<ul class="d-flex align-items-center">
|
|
|
|
<li class="nav-item dropdown pe-3">
|
|
|
|
<a class="nav-link nav-profile d-flex align-items-center pe-0" href="#" data-bs-toggle="dropdown">
|
|
<span class="fw-semibold dropdown-toggle ps-2">Hai, <?php echo $_SESSION['nama_lengkap']; ?>!</span>
|
|
</a><!-- End Profile Iamge Icon -->
|
|
|
|
<ul class="dropdown-menu dropdown-menu-end dropdown-menu-arrow profile">
|
|
<li class="dropdown-header">
|
|
<h6><?php echo $_SESSION['nama_lengkap']; ?></h6>
|
|
<span><?php echo ucfirst($_SESSION['role']); ?></span>
|
|
</li>
|
|
<li>
|
|
<hr class="dropdown-divider">
|
|
</li>
|
|
|
|
<li>
|
|
<a class="dropdown-item d-flex align-items-center" href="../update-profile/">
|
|
<i class="bi bi-gear"></i>
|
|
<span>Pengaturan</span>
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<hr class="dropdown-divider">
|
|
</li>
|
|
|
|
<li>
|
|
<a class="dropdown-item d-flex align-items-center" href="#" data-bs-toggle="modal" data-bs-target="#confirmLogoutModal">
|
|
<i class="bi bi-box-arrow-right"></i>
|
|
<span>Keluar</span>
|
|
</a>
|
|
</li>
|
|
|
|
</ul><!-- End Profile Dropdown Items -->
|
|
</li><!-- End Profile Nav -->
|
|
|
|
</ul>
|
|
</nav><!-- End Icons Navigation -->
|
|
|
|
</header><!-- End Header -->
|
|
|
|
<!-- ======= Sidebar ======= -->
|
|
<aside id="sidebar" class="sidebar">
|
|
|
|
|
|
<ul class="sidebar-nav sidebar-nav">
|
|
|
|
<li class="nav-item mb-2">
|
|
<a class="nav-link d-flex align-items-center" href="../">
|
|
<i class="bi bi-columns-gap"></i>
|
|
<span>Dashboard</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li class="nav-item mb-2">
|
|
<a class="nav-link d-flex align-items-center" href="../landingpage">
|
|
<i class="bi bi-journal-richtext"></i>
|
|
<span>Landing Page</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li class="nav-item mb-2">
|
|
<a class="nav-link d-flex align-items-center collapsed" href="../artikel">
|
|
<i class="bi bi-newspaper"></i>
|
|
<span>Artikel</span>
|
|
</a>
|
|
</li>
|
|
|
|
<li class="nav-item mb-2">
|
|
<a class="nav-link d-flex align-items-center" href="../pengguna">
|
|
<i class="bi bi-people"></i>
|
|
<span>Pengguna</span>
|
|
</a>
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</aside><!-- End Sidebar-->
|
|
|
|
<main id="main" class="main">
|
|
|
|
<div class="pagetitle">
|
|
<h1>Tambahkan Artikel</h1>
|
|
<nav>
|
|
<ol class="breadcrumb">
|
|
<li class="breadcrumb-item"><a href="">Beranda</a></li>
|
|
<li class="breadcrumb-item">Artikel</li>
|
|
</ol>
|
|
</nav>
|
|
</div><!-- End Page Title -->
|
|
|
|
<?php if (isset($_SESSION['success'])): ?>
|
|
<div class="alert alert-success alert-dismissible fade show" role="alert">
|
|
<?php echo $_SESSION['success']; ?>
|
|
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
|
|
</div>
|
|
<?php unset($_SESSION['success']); // Hapus pesan setelah ditampilkan
|
|
?>
|
|
<?php endif; ?>
|
|
|
|
<?php if (isset($_SESSION['error'])): ?>
|
|
<div class="alert alert-danger alert-dismissible fade show" role="alert">
|
|
<?php echo $_SESSION['error']; ?>
|
|
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
|
|
</div>
|
|
<?php unset($_SESSION['error']); // Hapus pesan setelah ditampilkan
|
|
?>
|
|
<?php endif; ?>
|
|
|
|
<section class="section">
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
|
|
<div class="card">
|
|
<div class="card-body mt-3">
|
|
|
|
<form action="addartikel.php" method="POST" enctype="multipart/form-data">
|
|
<!-- Judul Artikel -->
|
|
<div class="mb-3">
|
|
<label for="judul" class="form-label">Judul Artikel<span class="text-danger">*</span></label>
|
|
<input type="text" id="judul" name="judul" class="form-control" value="<?= isset($_SESSION['old_input']['judul']) ? htmlspecialchars($_SESSION['old_input']['judul']) : '' ?>" required>
|
|
</div>
|
|
|
|
<!-- Form Editor -->
|
|
<div class="mb-3">
|
|
<label for="konten" class="form-label">Konten Artikel<span class="text-danger">*</span></label>
|
|
<textarea id="konten" name="konten" class="form-control"><?= isset($_SESSION['old_input']['konten']) ? htmlspecialchars($_SESSION['old_input']['konten']) : '' ?></textarea>
|
|
<script src="https://cdn.ckeditor.com/4.22.1/standard/ckeditor.js"></script>
|
|
<script>
|
|
CKEDITOR.replace('konten');
|
|
</script>
|
|
|
|
</div>
|
|
|
|
<!-- Gambar -->
|
|
<div class="mb-3">
|
|
<label for="gambar" class="form-label">Unggah Gambar<span class="text-danger">*</span></label>
|
|
<input type="file" id="gambar" name="gambar" accept="image/*" class="form-control" required>
|
|
</div>
|
|
|
|
<!-- Kategori Dropdown -->
|
|
<div class="mb-3">
|
|
<label for="kategori" class="form-label">Pilih Kategori<span class="text-danger">*</span></label>
|
|
<select id="kategori" name="kategori" class="form-control" required>
|
|
<option value="" disabled>-- Pilih Kategori --</option>
|
|
<option value="tutorial" <?= (isset($_SESSION['old_input']['kategori']) && $_SESSION['old_input']['kategori'] == 'tutorial') ? 'selected' : '' ?>>Tutorial</option>
|
|
<option value="informasi" <?= (isset($_SESSION['old_input']['kategori']) && $_SESSION['old_input']['kategori'] == 'informasi') ? 'selected' : '' ?>>Informasi</option>
|
|
<option value="lainnya" <?= (isset($_SESSION['old_input']['kategori']) && $_SESSION['old_input']['kategori'] == 'lainnya') ? 'selected' : '' ?>>Lainnya</option>
|
|
</select>
|
|
</div>
|
|
|
|
<!-- Meta Deskripsi -->
|
|
<div class="mb-3">
|
|
<label for="meta_deskripsi" class="form-label">Meta Deskripsi<span class="text-danger">*</span></label>
|
|
<textarea id="meta_deskripsi" name="meta_deskripsi" class="form-control" rows="2" required><?= isset($_SESSION['old_input']['meta_deskripsi']) ? htmlspecialchars($_SESSION['old_input']['meta_deskripsi']) : '' ?></textarea>
|
|
</div>
|
|
|
|
<!-- Meta Keyword -->
|
|
<div class="mb-3">
|
|
<label for="meta_keyword" class="form-label">Meta Kata Kunci<span class="text-danger">*</span></label>
|
|
<input type="text" id="meta_keyword" name="meta_keyword" class="form-control" required
|
|
value="<?= isset($_SESSION['old_input']['meta_keyword']) ? htmlspecialchars($_SESSION['old_input']['meta_keyword']) : '' ?>">
|
|
<ul id="suggestions" class="list-group mt-2"></ul>
|
|
<small class="text-muted">Pisahkan dengan koma, contoh: teknologi, berita, tutorial</small>
|
|
</div>
|
|
|
|
<!-- Tombol Submit -->
|
|
<div class="d-flex justify-content-end">
|
|
<button type="submit" class="btn btn-primary me-2"><i class="bi bi-check-circle"></i> Simpan</button>
|
|
<a href="../artikel/" class="btn btn-secondary me-2"><i class="bi bi-x-circle"></i> Batal</a>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Modal Konfirmasi Logout -->
|
|
<div class="modal fade" id="confirmLogoutModal" tabindex="-1" aria-labelledby="logoutModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="logoutModalLabel">Konfirmasi Keluar</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<div class="modal-body">
|
|
Apakah Anda yakin ingin keluar dari halaman ini?
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Batal</button>
|
|
<a href="../logout.php" id="logoutConfirmBtn" class="btn btn-danger">Keluar</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</main><!-- End #main -->
|
|
|
|
<!-- ======= Footer ======= -->
|
|
<footer id="footer" class="footer">
|
|
<div class="copyright">
|
|
© Copyright <strong><span>Portal UMKM</span></strong>. All Rights Reserved
|
|
</div>
|
|
<div class="credits">
|
|
<!-- All the links in the footer should remain intact. -->
|
|
<!-- You can delete the links only if you purchased the pro version. -->
|
|
<!-- Licensing information: https://bootstrapmade.com/license/ -->
|
|
<!-- Purchase the pro version with working PHP/AJAX contact form: https://bootstrapmade.com/nice-admin-bootstrap-admin-html-template/ -->
|
|
<!-- Designed by <a href="https://bootstrapmade.com/">BootstrapMade</a> -->
|
|
</div>
|
|
</footer><!-- End Footer -->
|
|
|
|
<a href="#" class="back-to-top d-flex align-items-center justify-content-center"><i class="bi bi-arrow-up-short"></i></a>
|
|
|
|
<!-- Vendor JS Files -->
|
|
<script src="../../assets/template/vendor/apexcharts/apexcharts.min.js"></script>
|
|
<script src="../../assets/template/vendor/bootstrap/js/bootstrap.bundle.min.js"></script>
|
|
<script src="../../assets/template/vendor/chart.js/chart.umd.js"></script>
|
|
<script src="../../assets/template/vendor/echarts/echarts.min.js"></script>
|
|
<script src="../../assets/template/vendor/quill/quill.js"></script>
|
|
<script src="../../assets/template/vendor/simple-datatables/simple-datatables.js"></script>
|
|
<script src="../../assets/template/vendor/tinymce/tinymce.min.js"></script>
|
|
<script src="../../assets/template/vendor/php-email-form/validate.js"></script>
|
|
|
|
<!-- Template Main JS File -->
|
|
<script src="../../assets/template/js/main.js"></script>
|
|
|
|
<!-- Place the following <script> and <textarea> tags your HTML's <body> -->
|
|
<script>
|
|
CKEDITOR.replace('konten', {
|
|
height: 300, // Sesuaikan tinggi editor
|
|
toolbar: [
|
|
{ name: 'basicstyles', items: ['Bold', 'Italic', 'Underline', 'Strike'] },
|
|
{ name: 'paragraph', items: ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent'] },
|
|
{ name: 'insert', items: ['Image', 'Table', 'Link'] },
|
|
{ name: 'styles', items: ['Font', 'FontSize', 'TextColor', 'BGColor'] },
|
|
{ name: 'tools', items: ['Maximize'] }
|
|
]
|
|
});
|
|
|
|
document.getElementById('meta_keyword').addEventListener('input', function () {
|
|
let inputField = this;
|
|
let suggestionsList = document.getElementById('suggestions');
|
|
if (!suggestionsList) return;
|
|
|
|
let values = inputField.value.split(',').map(v => v.trim());
|
|
let query = values.pop(); // Ambil kata terakhir untuk dijadikan query
|
|
|
|
if (query.length < 2) {
|
|
suggestionsList.innerHTML = '';
|
|
return;
|
|
}
|
|
|
|
fetch(`proxy.php?q=${query}`)
|
|
.then(response => response.json())
|
|
.then(data => {
|
|
let suggestions = data[1] || [];
|
|
suggestionsList.innerHTML = '';
|
|
|
|
suggestions.forEach(item => {
|
|
let li = document.createElement('li');
|
|
li.classList.add('list-group-item');
|
|
li.textContent = item;
|
|
li.style.cursor = 'pointer';
|
|
|
|
li.addEventListener('click', function () {
|
|
values.push(item); // Ganti kata terakhir dengan saran yang dipilih
|
|
inputField.value = values.join(', ') + ', '; // Gabungkan kembali dengan koma
|
|
suggestionsList.innerHTML = '';
|
|
});
|
|
|
|
suggestionsList.appendChild(li);
|
|
});
|
|
})
|
|
.catch(error => console.error('Error:', error));
|
|
});
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|