Оптимизация фильтрации изображений и выбора цвета в Django Product Display

Я создал три модели В Models.py:

class Color(models.Model):
    name=models.CharField(max_length=20)
    code=ColorField(default='#FF0000')

    def __str__(self):
        return self.name
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)
    cagtegory=models.ForeignKey(Category, on_delete=models.SET_NULL ,null=True,related_name="category")
    vendor=models.ForeignKey(Vendor, on_delete=models.SET_NULL,null=True,related_name="product")
    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=user_directory_path,default="product.jpg")
    description=models.TextField(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=models.TextField(null=True, blank=True)

    product_status=models.CharField(choices=STATUS, max_length=10,default="In_review")


    status=models.BooleanField(default=True)
    in_stock=models.BooleanField(default=True)
    featured=models.BooleanField(default=False)
    digital=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 src="%s" width="50" height="50"/>'%(self.image.url))

    def __str__(self):
        return self.title
    def get_percentage(self):
        new_price=((self.old_price-self.price)/self.old_price)*100
        return new_price

class ProductImages(models.Model):
    images=models.ImageField(upload_to="product-image",default="product.jpg")
    product=models.ForeignKey(Product,related_name="p_images" ,on_delete=models.SET_NULL ,null=True)
    color = models.ForeignKey(Color, on_delete=models.CASCADE)
    date=models.DateTimeField(auto_now_add=True)

    class Meta:
        verbose_name_plural="Product Images"

В моем админпанеле в разделе Product Model создается два подраздела один Общий и другой Изображения товара--->Вид модели товара и изображения товара будут выглядеть так--->Изображения товара В разделе "Общие" я загружаю основное изображение товара

<div class="left-column">
        {%  for p in products  %}
        {%  for c in colors  %}
        {%  for x in p_image  %}
          <img data-image="{{c.id}}" src="{{x.image.url}}" alt="">#1
          <img data-image="{{c.id}}" src="{{x.image.url}}" alt="">#2
          <img data-image="{{c.id}}" class="active" src="{{p.image.url}}" alt=""> #3
        {%  endfor  %}
        {%  endfor  %}
        {%  endfor  %}
      </div>

Отображение главного изображения во фронтенде с помощью #3 html кода и я также хочу отобразить другие изображения.Моя страница детализации продукта будет выглядеть так---> страница детализации продукта Вы можете видеть, что я создал некоторые цвета с гиперссылкой

<div class="product-color">
            <span>Color</span>
            {%  for c in colors  %}

            <div class="color-choose">
              <a href="?colorID={{c.id}}" style="display: inline-block; width: 40px; height: 40px; background-color: {{c.code}}; border-radius: 50%; border: 2px solid #FFFFFF; cursor: pointer; float: left; margin-right: 10px; box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.33);">
              </a>
            </div>
            {%  endfor  %}

          </div>

В этом коде каждый цвет имеет свой id Теперь я хочу отфильтровать изображения по id И я создал для этого представление В views.py

def product_detail_view(request,pid):
    product=Product.objects.get(pid=pid)
    colors = Color.objects.all()
    sizes= Size.objects.all()
    p_image=product.p_images.all()
    products=Product.objects.filter(cagtegory=product.cagtegory)
    ColorID=request.GET.get('colorID')
    if ColorID:
        product_images = ProductImages.objects.filter(color_id=ColorID)
    else:
        product=Product.objects.all()

    context={
        "p":product,
        "p_image":p_image,
        'colors': colors,
        'sizes': sizes,
        'products': products,
    }

    return render(request,"core/product_detail.html",context)

Я хочу, чтобы при нажатии на цвет отображалось изображение, которое я загрузил для этого цвета

Пожалуйста, помогите мне!!!

Вернуться на верх