AttributeError: объект 'str' не имеет атрибута 'is_registered' на странице пользовательского добавления продукта DjangoPython

Программы на Python
Ответить
Anonymous
 AttributeError: объект 'str' не имеет атрибута 'is_registered' на странице пользовательского добавления продукта Django

Сообщение Anonymous »

Title: AttributeError: объект 'str' не имеет атрибута 'is_registered' на странице пользовательского добавления продукта Django

< Strong>Постановка проблемы:
Я создаю специальную страницу в Django, чтобы пользователи (сотрудники) могли добавлять продукт. Продукт определен в модели Product, которая включает ManyToManyField для цвета. Хотя создание продукта в панели администратора работает нормально (с возможностью добавлять новые цвета с помощью значка «плюс» в поле цвета), эта функция не работает на моей пользовательской странице.
При попытке обернуть виджет для поля цвета с помощью linkedFieldWidgetWrapper я столкнулся со следующей ошибкой:

Код: Выделить всё

AttributeError at /useradmin/add_product/
'str' object has no attribute 'is_registered'
Ниже приведены соответствующие фрагменты кода и конфигурации. Буду признателен за любую помощь в выявлении проблемы и достижении желаемой функциональности.

Модели

Модель продукта

Код: Выделить всё

from django.db import models
from taggit.managers import TaggableManager
from shortuuidfield import ShortUUIDField
from ckeditor_uploader.fields import RichTextUploadingField
from django.utils.safestring import mark_safe

class Product(models.Model):
pid = ShortUUIDField(length=10, max_length=100, prefix="prd", alphabet="abcdef")
user = models.ForeignKey('CustomUser', on_delete=models.SET_NULL, null=True)
viewers = models.ManyToManyField('CustomUser', related_name="viewed_products", blank=True)
cagtegory = models.ForeignKey('Category', on_delete=models.SET_NULL, null=True, related_name="category")
subcategory = models.ForeignKey('SubCategory', on_delete=models.SET_NULL, null=True, blank=True, related_name="subcategory")
vendor = models.ForeignKey('Vendor', on_delete=models.SET_NULL, null=True, related_name="product")
main_product_color = models.ManyToManyField('Color_main', blank=True)
color = models.ManyToManyField('Color', blank=True)
size = models.ManyToManyField('Size', blank=True)
title = models.CharField(max_length=100, default="Apple")
image = models.ImageField(upload_to='uploads/products', default="product.jpg")
hover_image = models.ImageField(upload_to='uploads/products', default="product.jpg")
description = RichTextUploadingField(null=True, blank=True, default="This is a product")
price = models.DecimalField(max_digits=10, decimal_places=2, default=1.99)
old_price = models.DecimalField(max_digits=10, decimal_places=2, default=2.99)
specifications = RichTextUploadingField(null=True, blank=True)
tags = TaggableManager(blank=True)
return_days = models.PositiveIntegerField(default=7)
product_status = models.CharField(choices=[('In_review', 'In Review'), ('Approved', 'Approved')], max_length=1000, default="In_review")
yt_link = models.CharField(max_length=10000, blank=True, null=True)
status = models.BooleanField(default=True)
in_stock = models.BooleanField(default=True)
featured = models.BooleanField(default=False)
digital = models.BooleanField(default=False)
best_selling = models.BooleanField(default=False)
our_choice = models.BooleanField(default=False)
non_returnable = models.BooleanField(default=False)
sku = ShortUUIDField(length=10, max_length=100, prefix="sku", alphabet="abcdef")
date = models.DateTimeField(auto_now_add=True)
updated = models.DateTimeField(null=True, blank=True)

class Meta:
verbose_name_plural = "Products"

def product_image(self):
return mark_safe('
[img]%s[/img]
' % (self.image.url))

def __str__(self):
return self.title

Цветовая модель

Код: Выделить всё

class Color(models.Model):
coid = ShortUUIDField(length=10, max_length=100, prefix="col", alphabet="abcdefgh")
name = models.CharField(max_length=20)
code = models.CharField(max_length=7, default="#FF0000")
product_varients = models.ManyToManyField('Product', related_name='color_variants', blank=True)
image = models.ImageField(upload_to='uploads/colors', default="color.jpg")

class Meta:
verbose_name_plural = "Colors"

def __str__(self):
return self.name
Конфигурация администратора

Форма администратора продукта
[code]from django import forms
from core.models import Product

class ProductAdminForm(forms.ModelForm):
class Meta:
model = Product
fields = '__all__'
[/code]
Администратор продукта

Код: Выделить всё

from django.contrib import admin
from core.models import Product

class ProductAdmin(admin.ModelAdmin):
list_display = ['user', 'title', 'product_image', 'price', 'featured', 'product_status', 'pid']
filter_horizontal = ['color', 'size']
form = ProductAdminForm

admin.site.register(Product, ProductAdmin)
Пользовательский вид добавления продукта

Код: Выделить всё

from django.shortcuts import render, redirect
from django.contrib.auth.decorators import login_required, user_passes_test
from core.forms import ProductAdminForm

@login_required
@user_passes_test(lambda user: user.is_staff)
def add_product(request):
if request.method == "POST":
form = ProductAdminForm(request.POST, request.FILES)
if form.is_valid():
new_product = form.save(commit=False)
new_product.user = request.user
new_product.save()
form.save_m2m()
return redirect("useradmin:vendordashboard")
else:
print(form.errors)
else:
form = ProductAdminForm()

return render(request, "useradmin/add-product.html", {"form": form})
Сведения об ошибке
Ошибка:

Код: Выделить всё

AttributeError at /useradmin/add_product/
'str' object has no attribute 'is_registered'
Traceback:
Ошибка возникает при загрузке пользовательской страницы. Кажется, проблема возникает, когда связанныйFieldWidgetWrapper используется с полем цвета.

Что я пробовал< /strong>
  • Использование linkedFieldWidgetWrapper:
    Я попытался обернуть виджет поля цвета с помощью связанногоFieldWidgetWrapper< /код> в ProductAdminForm:

Код: Выделить всё

from django.contrib.admin.widgets import RelatedFieldWidgetWrapper
from django.urls import reverse

class ProductAdminForm(forms.ModelForm):
class Meta:
model = Product
fields = '__all__'

def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
if 'color' in self.fields:
rel = self._meta.model._meta.get_field('color').remote_field
self.fields['color'].widget = RelatedFieldWidgetWrapper(
self.fields['color'].widget,
rel,
reverse('admin:core_color_add')  # Admin add URL
)
  • Проверка обратного URL-адреса:
    Я проверил URL-адрес для добавления цвета объект в администраторе:

Код: Выделить всё

from django.urls import reverse
print(reverse('admin:core_color_add'))  # Outputs: '/admin/core/color/add/'
URL-адрес разрешается правильно.
  • Проверка регистрации администратора:
    Модель Color правильно зарегистрирована в администраторе:

Код: Выделить всё

@admin.register(Color)
class ColorAdmin(admin.ModelAdmin):
list_display = ['name', 'code']
  • Включение административного медиа в шаблон:
    Я убедился, что файлы JavaScript и CSS администратора загружено на мою пользовательскую страницу:

Код: Выделить всё

{% load static %}
[*]


Желаемый результат
  • Отображение «плюса» " в поле цвета на пользовательской странице add-product.html.
  • Разрешить сотрудникам добавлять новые цвета с помощью значка "плюс", не сталкиваясь с ошибки.
Вопрос
Что является причиной ошибки объекта 'str' без атрибута 'is_registered' и как ее устранить для достижения желаемой функциональности?


Подробнее здесь: https://stackoverflow.com/questions/793 ... o-custom-a
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»