Merge pull request 'Upgrade CKEditoru na verzi 5' (!76) from ckeditor5 into master

Reviewed-on: #76
This commit is contained in:
Jonas Havelka 2024-11-26 18:36:07 +01:00
commit 5bf8df0218
8 changed files with 112 additions and 27 deletions

View file

@ -13,11 +13,11 @@ from django.contrib.flatpages.admin import FlatPageAdmin as FlatPageAdminOld
from django.contrib.flatpages.admin import FlatpageForm as FlatpageFormOld from django.contrib.flatpages.admin import FlatpageForm as FlatpageFormOld
from django import forms from django import forms
from ckeditor_uploader.widgets import CKEditorUploadingWidget from django_ckeditor_5.widgets import CKEditor5Widget
class FlatpageForm(FlatpageFormOld): class FlatpageForm(FlatpageFormOld):
content = forms.CharField(widget=CKEditorUploadingWidget()) content = forms.CharField(widget=CKEditor5Widget())
class Meta: class Meta:
model = FlatPage # this is not automatically inherited from FlatpageFormOld model = FlatPage # this is not automatically inherited from FlatpageFormOld
exclude = [] exclude = []

View file

@ -110,8 +110,7 @@ INSTALLED_APPS = (
'reversion', 'reversion',
'django_countries', 'django_countries',
'solo', 'solo',
'ckeditor', 'django_ckeditor_5',
'ckeditor_uploader',
'taggit', 'taggit',
'dal', 'dal',
'dal_select2', 'dal_select2',
@ -186,26 +185,98 @@ SUMMERNOTE_CONFIG = {
] ]
} }
CKEDITOR_UPLOAD_PATH = "uploads/" CKEDITOR_5_CUSTOM_CSS = "css/ckeditor5_fix.css"
CKEDITOR_IMAGE_BACKEND = 'pillow' # customColorPalette = [
#CKEDITOR_JQUERY_URL = '//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js' # {
CKEDITOR_CONFIGS = { # 'color': 'hsl(4, 90%, 58%)',
# 'label': 'Red',
# },
# {
# 'color': 'hsl(340, 82%, 52%)',
# 'label': 'Pink',
# },
# {
# 'color': 'hsl(291, 64%, 42%)',
# 'label': 'Purple',
# },
# {
# 'color': 'hsl(262, 52%, 47%)',
# 'label': 'Deep Purple',
# },
# {
# 'color': 'hsl(231, 48%, 48%)',
# 'label': 'Indigo',
# },
# {
# 'color': 'hsl(207, 90%, 54%)',
# 'label': 'Blue',
# },
# ]
CKEDITOR_5_FILE_STORAGE = "various.storage.UploadStorage"
CKEDITOR_5_CONFIGS = {
'default': { 'default': {
'entities': False, 'language': 'cs',
'toolbar': [ 'blockToolbar': [
['Source', 'ShowBlocks', '-', 'Maximize'], 'paragraph', 'heading1', 'heading2', 'heading3',
['Bold', 'Italic', 'Subscript', 'Superscript', '-', 'RemoveFormat'], '|',
['NumberedList','BulletedList','-','Blockquote','-','JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock'], 'bulletedList', 'numberedList',
['Link', 'Unlink', 'Anchor', '-', 'Image', 'Table', 'HorizontalRule'], '|',
['Format'], 'blockQuote',
], ],
# 'toolbar': 'full', 'toolbar': ['sourceEditing', '|', 'heading', '|',
'height': '40em', # 'outdent', 'indent', '|',
'width': '100%', 'bold', 'italic', 'link', 'underline', 'strikethrough',
'toolbarStartupExpanded': False, 'code',
'allowedContent' : True, # 'subscript', 'superscript',
# 'highlight',
'|', 'codeBlock', 'insertImage',
'bulletedList', 'numberedList', 'todoList', '|',
# 'blockQuote', '|',
# 'fontSize', 'fontFamily', 'fontColor', 'fontBackgroundColor',
# 'mediaEmbed',
'removeFormat',
# 'insertTable',
],
'image': {
'toolbar': ['imageTextAlternative', '|', 'imageStyle:alignLeft',
'imageStyle:alignRight', 'imageStyle:alignCenter', 'imageStyle:side', '|'],
'styles': [
'full',
'side',
'alignLeft',
'alignRight',
'alignCenter',
]
},
# 'table': {
# 'contentToolbar': [ 'tableColumn', 'tableRow', 'mergeTableCells',
# 'tableProperties', 'tableCellProperties' ],
# 'tableProperties': {
# 'borderColors': customColorPalette,
# 'backgroundColors': customColorPalette,
# },
# 'tableCellProperties': {
# 'borderColors': customColorPalette,
# 'backgroundColors': customColorPalette,
# }
# },
'heading' : {
'options': [
{ 'model': 'paragraph', 'title': 'Paragraph', 'class': 'ck-heading_paragraph' },
{ 'model': 'heading1', 'view': 'h1', 'title': 'Heading 1', 'class': 'ck-heading_heading1' },
{ 'model': 'heading2', 'view': 'h2', 'title': 'Heading 2', 'class': 'ck-heading_heading2' },
{ 'model': 'heading3', 'view': 'h3', 'title': 'Heading 3', 'class': 'ck-heading_heading3' },
]
},
}, },
'list': {
'properties': {
'styles': 'true',
'startIndex': 'true',
'reversed': 'true',
},
}
} }
# Webpack loader # Webpack loader

View file

@ -0,0 +1,3 @@
.ck.ck-editor {
color: black !important; /* V tmavém módu zapomene CKEditor přepnout barvu textu. (Bílý text na bílém pozadí je best.) */
}

View file

@ -15,7 +15,7 @@ urlpatterns = [
# Admin a nastroje # Admin a nastroje
path('admin/', admin.site.urls), # NOQA path('admin/', admin.site.urls), # NOQA
path('ckeditor/', include('ckeditor_uploader.urls')), path("ckeditor5/", include('django_ckeditor_5.urls')),
# Tvorba = ročníky, čísla, problémy atd. (ma vlastni podadresare) # Tvorba = ročníky, čísla, problémy atd. (ma vlastni podadresare)
path('', include('tvorba.urls')), path('', include('tvorba.urls')),

View file

@ -1,7 +1,7 @@
import django.forms import django.forms
from django.contrib import admin from django.contrib import admin
from ckeditor_uploader.widgets import CKEditorUploadingWidget from django_ckeditor_5.widgets import CKEditor5Widget
from .models import Novinky from .models import Novinky
@ -10,7 +10,7 @@ class NovinkyAdminForm(django.forms.ModelForm):
class Meta: class Meta:
model = Novinky model = Novinky
widgets = { widgets = {
'text': CKEditorUploadingWidget, 'text': CKEditor5Widget,
} }
fields = '__all__' fields = '__all__'

View file

@ -14,7 +14,7 @@ Django<5.0
django-reversion # Version control na datech v databázi django-reversion # Version control na datech v databázi
django-countries # Políčko ve formu / field v modelu ohledně států django-countries # Políčko ve formu / field v modelu ohledně států
django-solo # Singleton model (speciálně Nastavení) django-solo # Singleton model (speciálně Nastavení)
django-ckeditor # Editor htmlka (hlavně v adminu u flatpages) django-ckeditor-5 # Editor htmlka (hlavně v adminu u flatpages)
django-cleanup # Uklízí media/ od smazaných „databázových“ souborů django-cleanup # Uklízí media/ od smazaných „databázových“ souborů
django-taggit # Taggy v djangu (speciálně zaměření problémů) django-taggit # Taggy v djangu (speciálně zaměření problémů)
django-autocomplete-light>=3.9.0 # Automatické doplňování (problémů, účastníků, …) ve formulářích django-autocomplete-light>=3.9.0 # Automatické doplňování (problémů, účastníků, …) ve formulářích

View file

@ -3,7 +3,7 @@ from django.contrib import admin
from django.forms import widgets from django.forms import widgets
from django.db import models from django.db import models
from ckeditor_uploader.widgets import CKEditorUploadingWidget from django_ckeditor_5.widgets import CKEditor5Widget
import soustredeni.models as m import soustredeni.models as m
@ -42,7 +42,7 @@ class SoustredeniAdminForm(django.forms.ModelForm):
class Meta: class Meta:
model = m.Soustredeni model = m.Soustredeni
widgets = { widgets = {
'text': CKEditorUploadingWidget, 'text': CKEditor5Widget,
} }
fields = '__all__' fields = '__all__'

11
various/storage.py Normal file
View file

@ -0,0 +1,11 @@
import os
from urllib.parse import urljoin
from django.conf import settings
from django.core.files.storage import FileSystemStorage
class UploadStorage(FileSystemStorage):
"""Storage pro CKEditor"""
location = os.path.join(settings.MEDIA_ROOT, "uploads")
base_url = urljoin(settings.MEDIA_URL, "uploads/")