django-fast-treenode 2.0.4__py3-none-any.whl → 2.0.6__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- {django_fast_treenode-2.0.4.dist-info → django_fast_treenode-2.0.6.dist-info}/METADATA +2 -1
- {django_fast_treenode-2.0.4.dist-info → django_fast_treenode-2.0.6.dist-info}/RECORD +6 -6
- treenode/admin.py +47 -12
- {django_fast_treenode-2.0.4.dist-info → django_fast_treenode-2.0.6.dist-info}/LICENSE +0 -0
- {django_fast_treenode-2.0.4.dist-info → django_fast_treenode-2.0.6.dist-info}/WHEEL +0 -0
- {django_fast_treenode-2.0.4.dist-info → django_fast_treenode-2.0.6.dist-info}/top_level.txt +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.2
|
2
2
|
Name: django-fast-treenode
|
3
|
-
Version: 2.0.
|
3
|
+
Version: 2.0.6
|
4
4
|
Summary: Application for supporting tree (hierarchical) data structure in Django projects
|
5
5
|
Home-page: https://github.com/TimurKady/django-fast-treenode
|
6
6
|
Author: Timur Kady
|
@@ -53,6 +53,7 @@ Description-Content-Type: text/markdown
|
|
53
53
|
License-File: LICENSE
|
54
54
|
Requires-Dist: Django>=4.0
|
55
55
|
Requires-Dist: pympler>=1.0
|
56
|
+
Requires-Dist: django-widget-tweaks>=1.5
|
56
57
|
Provides-Extra: import-export
|
57
58
|
Requires-Dist: openpyxl; extra == "import-export"
|
58
59
|
Requires-Dist: pyyaml; extra == "import-export"
|
@@ -1,5 +1,5 @@
|
|
1
1
|
treenode/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
2
|
-
treenode/admin.py,sha256=
|
2
|
+
treenode/admin.py,sha256=ltpCmPCpZpIAOX-ZIuxrleEUvBiUj7AX-jygUjGBHEs,15209
|
3
3
|
treenode/apps.py,sha256=M0O9IKEnJZFfhfz12v4wksYJ-0ECyj1Cy3qXrfywos8,472
|
4
4
|
treenode/cache.py,sha256=Z_FpaS0vTKXqAI4n1QkZ7A_ILsLU3Q8rLgerA6pYyAA,7210
|
5
5
|
treenode/forms.py,sha256=imoLzr7qFlOBdeMQK12rAFp6hINpe0PS_U4-V8RRcDU,2802
|
@@ -34,8 +34,8 @@ treenode/utils/__init__.py,sha256=jAVT-uNGQDKPVq5ET4JE2GhRpzbxFdHU25w9sLC3_To,13
|
|
34
34
|
treenode/utils/base36.py,sha256=ydgu9hqDaK-WyS8zG-mtSWo7hJqbB4iHqkGz4-IVrb4,834
|
35
35
|
treenode/utils/exporter.py,sha256=l-IEsk2fK8xe-E-Hi7SMOV7ZIwxM6mZih5-0rhvsx9E,5396
|
36
36
|
treenode/utils/importer.py,sha256=n23PBFPXN-6S_Dl8Qmx56sp0eLy_lWfpxrzJqwygQf0,14190
|
37
|
-
django_fast_treenode-2.0.
|
38
|
-
django_fast_treenode-2.0.
|
39
|
-
django_fast_treenode-2.0.
|
40
|
-
django_fast_treenode-2.0.
|
41
|
-
django_fast_treenode-2.0.
|
37
|
+
django_fast_treenode-2.0.6.dist-info/LICENSE,sha256=GiiEe4Y9oOCbn9eGuNew1mMYHU_bJWaCK9zOusnKvvU,1091
|
38
|
+
django_fast_treenode-2.0.6.dist-info/METADATA,sha256=DGr3UvNjD2IXwN9RETGgHsUwhgb417Z9drd2DIcrSko,23109
|
39
|
+
django_fast_treenode-2.0.6.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
|
40
|
+
django_fast_treenode-2.0.6.dist-info/top_level.txt,sha256=fmgxHbXyx1O2MPi_9kjx8aL9L-8TmV0gre4Go8XgqFk,9
|
41
|
+
django_fast_treenode-2.0.6.dist-info/RECORD,,
|
treenode/admin.py
CHANGED
@@ -6,7 +6,7 @@ This module provides Django admin integration for the TreeNode model.
|
|
6
6
|
It includes custom tree-based sorting, optimized queries, and
|
7
7
|
import/export functionality for hierarchical data structures.
|
8
8
|
|
9
|
-
Version: 2.0.
|
9
|
+
Version: 2.0.6
|
10
10
|
Author: Timur Kady
|
11
11
|
Email: kaduevtr@gmail.com
|
12
12
|
"""
|
@@ -81,7 +81,7 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
81
81
|
TREENODE_DISPLAY_MODE_INDENTATION = 'indentation'
|
82
82
|
|
83
83
|
treenode_display_mode = TREENODE_DISPLAY_MODE_ACCORDION
|
84
|
-
|
84
|
+
import_export = False # Track import/export availability
|
85
85
|
change_list_template = "admin/tree_node_changelist.html"
|
86
86
|
ordering = []
|
87
87
|
list_per_page = 1000
|
@@ -107,10 +107,25 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
107
107
|
"""Динамически добавляем поле `tn_order` в `list_display`."""
|
108
108
|
super().__init__(model, admin_site)
|
109
109
|
|
110
|
-
#
|
110
|
+
# If `list_display` is empty, take all `fields`
|
111
111
|
if not self.list_display:
|
112
112
|
self.list_display = [field.name for field in model._meta.fields]
|
113
113
|
|
114
|
+
# Check for necessary dependencies
|
115
|
+
self.import_export = all(
|
116
|
+
importlib.util.find_spec(pkg) is not None
|
117
|
+
for pkg in ["openpyxl", "pyyaml", "pandas"]
|
118
|
+
)
|
119
|
+
|
120
|
+
if self.import_export:
|
121
|
+
from .utils import TreeNodeImporter, TreeNodeExporter
|
122
|
+
|
123
|
+
self.TreeNodeImporter = TreeNodeImporter
|
124
|
+
self.TreeNodeExporter = TreeNodeExporter
|
125
|
+
else:
|
126
|
+
self.TreeNodeImporter = None
|
127
|
+
self.TreeNodeExporter = None
|
128
|
+
|
114
129
|
def get_queryset(self, request):
|
115
130
|
"""Override get_ueryset()."""
|
116
131
|
queryset = super().get_queryset(request)
|
@@ -182,10 +197,7 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
182
197
|
def changelist_view(self, request, extra_context=None):
|
183
198
|
"""Changelist View."""
|
184
199
|
extra_context = extra_context or {}
|
185
|
-
extra_context['import_export_enabled'] =
|
186
|
-
importlib.util.find_spec(pkg)
|
187
|
-
is not None for pkg in ["openpyxl", "pyyaml", "pandas"]
|
188
|
-
)
|
200
|
+
extra_context['import_export_enabled'] = self.import_export
|
189
201
|
return super().changelist_view(request, extra_context=extra_context)
|
190
202
|
|
191
203
|
def get_ordering(self, request):
|
@@ -250,12 +262,19 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
250
262
|
return form
|
251
263
|
|
252
264
|
def get_urls(self):
|
253
|
-
"""
|
265
|
+
"""
|
266
|
+
Extend admin URLs with custom import/export routes.
|
267
|
+
|
268
|
+
Register these URLs only if all the required packages are installed.
|
269
|
+
"""
|
254
270
|
urls = super().get_urls()
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
271
|
+
if self.import_export:
|
272
|
+
custom_urls = [
|
273
|
+
path('import/', self.import_view, name='tree_node_import'),
|
274
|
+
path('export/', self.export_view, name='tree_node_export'),
|
275
|
+
]
|
276
|
+
else:
|
277
|
+
custom_urls = []
|
259
278
|
return custom_urls + urls
|
260
279
|
|
261
280
|
def import_view(self, request):
|
@@ -265,6 +284,14 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
265
284
|
File upload processing, auto-detection of format, validation and data
|
266
285
|
import.
|
267
286
|
"""
|
287
|
+
if not self.import_export:
|
288
|
+
self.message_user(
|
289
|
+
request,
|
290
|
+
"Import functionality is disabled because required \
|
291
|
+
packages are not installed."
|
292
|
+
)
|
293
|
+
return redirect("..")
|
294
|
+
|
268
295
|
if request.method == 'POST':
|
269
296
|
if 'file' not in request.FILES:
|
270
297
|
return render(
|
@@ -317,6 +344,14 @@ class TreeNodeAdminModel(admin.ModelAdmin):
|
|
317
344
|
link for manual download,
|
318
345
|
and a button to go to the model page.
|
319
346
|
"""
|
347
|
+
if not self.import_export:
|
348
|
+
self.message_user(
|
349
|
+
request,
|
350
|
+
"Export functionality is disabled because required \
|
351
|
+
packages are not installed."
|
352
|
+
)
|
353
|
+
return redirect("..")
|
354
|
+
|
320
355
|
# If the download parameter is present, we give the file directly
|
321
356
|
if 'download' in request.GET:
|
322
357
|
# Get file format
|
File without changes
|
File without changes
|
File without changes
|