M
21 октября 2017 г. 21:33

Создание истории редактирования постов на сайте

Привет всем,


Делаю базу данных по игре на сайте который работает на Django. Хочется что бы любой пользователь мог редактировать статьи в базе данных и в связи с этим также хочется реализовать историю редактирования. Например как на Википедии или в WordPress админке.

Если ли у кого то идеи как это можно реализовать на Django?
2

Вам это нравится? Поделитесь в социальных сетях!

7
Evgenii Legotckoi
  • 21 октября 2017 г. 22:15
  • (ред.)
  • Ответ был помечен как решение.

Добрый день!


Само редактирование страниц можно сделать в обычной форме редактирования с использованием того же самого CKEditor, поскольку вам понадобится WYSIWYG редактор для такого функционала.
А  потом самый простой есть вариант, это сделать кнопочку Редактировать на сайте, которая откроет страницу в которой будет форма редактирования статьи. Это будет ближе к админке WordPressa, то что сделано на Википедии - это значительно более сложная реализация.

Что касается истории сохраний, ревизий, то можно поискать среди готовых батареек для Django, например, django-simple-history, вроде как его советуют для подобного функционала, и он должен позволять откатиться до определённой ревизии.
    M
    • 21 октября 2017 г. 22:37

    Большое спасибо за развернутый ответ. Первые два пункта уже готовы, редактор кстати выбрал quilljs .

      Evgenii Legotckoi
      • 21 октября 2017 г. 22:46

      Не встречался с таким, когда подбирал редактор для своего сайта. django-quill - это он?
      Как у него по удобству с кастомизацией внешнего вида? А также что с подсветкой синтаксиса кода?

        M
        • 21 октября 2017 г. 23:19

        Quilljs сложно сравнивать CKEditor. Quill намного менее функциональный редактор, но самая большая проблема с ним по крайней мере для меня, он по умолчанию(ли скорее рекомендовано) использует для сохранения json Delta, а не html. Хотя я сохраняю в БД html вот таким образом


        const quill = new Quill('#editor-container', {
            modules: {
              toolbar: '#toolbar-container'
            },
            placeholder: 'Напишите что то...',
            theme: 'snow'
          });
        
        
          $(document).ready(function () {
            var content = document.getElementById('id_content');
            var qlEditor = document.getElementsByClassName('ql-editor');
        
            if (content.value === '') {
              // Ести поле textarea пустое, вставлет пробел 
              content.value = ' ';
            } else {
              // При редактировании поста вставляет html
              // с textarea в quill редактор
              $('.ql-editor').html(content.value);
            }
        
            $("#toolbar-container").stick_in_parent();
        
          });
          // Передает html разметку с редактора в textarea
          // при отправке формы
          var form = document.querySelector('form');
          form.onsubmit = function () {
            var content = document.getElementById('id_content');
            content.value = quill.root.innerHTML;
          };
        django-quill заброшен так что я его не использую
          M
          • 21 октября 2017 г. 23:29

          Кастомизируется очень просто и удобно, подсветку кода я не тестил, но как я понял для этого используется highlight.js

            Evgenii Legotckoi
            • 21 октября 2017 г. 23:33

            Ясно. Тогда я лучше не буду тратить время на его проверку. Тем более, что я использую гугловский prettyprint для подсветки кода.

            Спасибо за информацию.
              M
              • 22 октября 2017 г. 23:37
              • (ред.)

              Вдруг кому будет интересно нашел уже готовое решение вопроса django-reversion + django-reversion-compare.

                Комментарии

                Только авторизованные пользователи могут публиковать комментарии.
                Пожалуйста, авторизуйтесь или зарегистрируйтесь
                • Последние комментарии
                • Evgenii Legotckoi
                  16 апреля 2025 г. 17:08
                  Благодарю за отзыв. И вам желаю всяческих успехов!
                • IscanderChe
                  12 апреля 2025 г. 17:12
                  Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
                • AK
                  1 апреля 2025 г. 11:41
                  Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
                • Evgenii Legotckoi
                  9 марта 2025 г. 21:02
                  К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
                • VP
                  9 марта 2025 г. 16:14
                  Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…