Migrating from safer_staticfiles¤
This guide is for you if you're upgrating django_components to v0.100 or later from older versions.
In version 0.100, we changed how components' static JS and CSS files are handled. See more in the "Static files" section.
Migration steps:
- Remove
django_components.safer_staticfiles
fromINSTALLED_APPS
in yoursettings.py
, and replace it withdjango.contrib.staticfiles
.
Before:
INSTALLED_APPS = [
"django.contrib.admin",
...
# "django.contrib.staticfiles", # <-- ADD
"django_components",
"django_components.safer_staticfiles", # <-- REMOVE
]
After:
- Add
STATICFILES_FINDERS
tosettings.py
, and adddjango_components.finders.ComponentsFileSystemFinder
:
STATICFILES_FINDERS = [
# Default finders
"django.contrib.staticfiles.finders.FileSystemFinder",
"django.contrib.staticfiles.finders.AppDirectoriesFinder",
# Django components
"django_components.finders.ComponentsFileSystemFinder", # <-- ADDED
]
- Add
COMPONENTS.dirs
tosettings.py
.
If you previously defined STATICFILES_DIRS
, move only those directories from STATICFILES_DIRS
that point to components directories, and keep the rest.
E.g. if you have STATICFILES_DIRS
like this:
STATICFILES_DIRS = [
BASE_DIR / "components", # <-- MOVE
BASE_DIR / "myapp" / "components", # <-- MOVE
BASE_DIR / "assets",
]
Then first two entries point to components dirs, whereas /assets
points to non-component static files. In this case move only the first two paths:
COMPONENTS = {
"dirs": [
BASE_DIR / "components", # <-- MOVED
BASE_DIR / "myapp" / "components", # <-- MOVED
],
}
STATICFILES_DIRS = [
BASE_DIR / "assets",
]
Moreover, if you defined app-level component directories in STATICFILES_DIRS
before, you can now define as a RELATIVE path in app_dirs
: