
var express = require('express')
var router = express.Router()
var settings = require('../../settings')
router.get('/', async function(req, res, next) {
    settings.dLogo = 'ទំព័រស្តាទិក'
  
    if(req.session.user){
        const today = new Date()
        const date = today.toLocaleDateString('fr-CA')
        const time = today.toLocaleTimeString('it-IT')
        settings.datetime = date + 'T' +  time
        const count = await require('../../controllers/pages/count')()
        settings.message = `ចំនួនទំព័រស្តាទិកសរុបៈ ${count}`
        
        const read = await require('../../controllers/pages/read')
        settings.items = await read(settings.dItemLimit)
        
        settings.route = 'page'
        
        res.render('users/page', settings)
    }else{
        res.redirect('/users')
    }
    
})
router.post('/', async function(req, res, next) {
    if(req.session.user.role === "Admin"){
        await require('../../controllers/pages/create')(req)
        res.redirect('/users/page')
    }else{
        res.redirect('/users')
    }
})
router.get('/edit/:id', async function(req, res, next) {
    if(req.session.user){
        if(req.session.user.role === 'Admin'){
            settings.dLogo = 'កែប្រែទំព័រស្តាទិក'
            const page = await require('../../controllers/pages/read')(false, req.params.id)
            const date = page.date.toLocaleDateString('fr-CA')
            const time = page.date.toLocaleTimeString('it-IT')
            settings.datetime = date + 'T' +  time
            settings.page = page
            settings.route = 'page'
            res.render('users/edit_page', settings)
        }else{
            res.redirect('/users/page')
        }
    }else{
        res.redirect('/users')
    }
})
router.post('/edit/:id', async function(req, res, next){
    if(req.session.user){
        await require('../../controllers/pages/update')(req)
        
        res.redirect('/users/page/edit/' + req.params.id)
    }else{
        res.redirect('/users')
    }
})
module.exports = router
const schema = require('./schema')
async function updatePage(req){
    const pageSchema = await schema()
    const page = await pageSchema.findOne({id: req.params.id})
    page.title = req.body.title
    page.content = req.body.content
    page.thumb = req.body.thumb
    page.video = req.body.entries
    page.date = new Date(req.body.datetime)
  
    return await page.save()
  }
module.exports = updatePage
<%- include('partials/header.ejs') %>
<link href="/styles/users/post.css" rel="stylesheet"></link>
<script src="/scripts/ckeditor/ckeditor.js"></script>
<script src="/scripts/users/post.js"></script>
<style>
    .Main .content form .wrapper{
        margin-top:5px;
        display: grid;
        grid-template-columns: auto 30% 15%;
    }
</style>
  
<section class='Main region'>
    <div class='sidebar'>
        <%- include('partials/menu.ejs') %>
    </div>
    <div class='content'>
        <form action='/users/page/edit/<%= page.id %>' method='post'>
            <input type='text' name='title' value='<%= page.title %>' required />
            <textarea name="content" id="editor" ><%- page.content %></textarea>
            <div class='wrapper'>
                <input type='text' name='thumb' requred value="<%= page.thumb %>" />
                <input type='datetime-local' value='<%= datetime %>' name='datetime' required />
                <input type='submit' value='ចុះផ្សាយ' />
            </div>
            <input name='entries' value='<%= page.video %>' type='hidden' />
        </form>
        <div class='form'>
            <select name='type'>
                <option>YouTube</option>
                <option>YouTubePlaylist</option>
                <option>Facebook</option>
                <option>OK</option>
                <option>Dailymotion</option>
                <option>Vimeo</option>
            </select>
            <input name='id' type='text' placeholder="អត្តសញ្ញាណវីដេអូ" required />
            <select name='ending'>
                <option>ចប់ហើយ</option>
                <option>មិនទាន់ចប់</option>
            </select>
            <input onclick='genJson()' type="button" value="បញ្ចូលវីដេអូ" />
        </div>
        <table class='viddata'></table>
        
        <div class='item'>
            <div class='thumb'>
                <a href='/<%= route %>/<%= page.id %>'><img src='<%- page.thumb %>' /></a>
            </div>
            <div class='title-date'>
                <a class='title' href='/<%= route %>/<%= page.id %>'><%= page.title %></a>
                <div><%= page.author %></div>
            </div>
            <div class='edit-delete'>
                <a href='/users/<%= route %>/delete/<%= page.id %>'>
                    <img src='/images/delete.png' />
                </a>
            </div>
        </div>
        <% if(page.video !== ''){ %>
            <script>
                var entries = JSON.parse('<%- page.video %>')
            </script>
        <% }else{ %>
            <script>
               var entries = []
            </script>
        <% } %>
        <script>
        if(entries.length > 0){
            let html = ``
            for(let v in entries){
                episode += 1
                html += `<tr>`
                html += `<td title="Delete" onClick="deleteRow(event)" class="episode">${episode}</td>`
                html += `<td class="td${episode}">${entries[v].type}</td>`
                html += `<td class="td${episode}">${entries[v].id}</td>`
                html += `<td class="td${episode}">${entries[v].ending}</td>`
                html += `</tr>`
            }
            if($('.viddata').html() === ''){
                $('.viddata').append('<tr>')
                $('.viddata').append('<th>ភាគ/លុប</th>')
                $('.viddata').append('<th>ប្រភេទ</th>')
                $('.viddata').append('<th>អត្តសញ្ញាណ</th>')
                $('.viddata').append('<th>ចប់ឬនៅ?</th>')
                $('.viddata').append('</tr>')
            }
            $('.viddata').append(`${html}`)
        }
        </script>
        
        <script src="/scripts/ckeditor/config.js"></script>
    </div>
</section>
    
<%- include('partials/footer.ejs') %>
GitHub: https://github.com/Sokhavuth/tv
Vercel: https://tv-neon.vercel.app
Responsive: http://www.responsinator.com