merge resolution
This commit is contained in:
@@ -2,11 +2,34 @@ from django.contrib.gis.db import models
|
||||
|
||||
from tagulous.models import SingleTagField, TagField, TagTreeModel
|
||||
|
||||
from core.models import TreeTag
|
||||
from companies.models import Company
|
||||
|
||||
# Create your models here.
|
||||
|
||||
class TreeTag(TagTreeModel):
|
||||
class TagMeta:
|
||||
initial = ""
|
||||
force_lowercase = True
|
||||
max_count=20
|
||||
# autocomplete_view = 'myapp.views.hobbies_autocomplete'
|
||||
|
||||
|
||||
class CategoryTag(TagTreeModel):
|
||||
class TagMeta:
|
||||
initial = ""
|
||||
force_lowercase = True
|
||||
max_count=20
|
||||
# autocomplete_view = 'myapp.views.hobbies_autocomplete'
|
||||
|
||||
|
||||
class AttributeTag(TagTreeModel):
|
||||
class TagMeta:
|
||||
initial = ""
|
||||
force_lowercase = True
|
||||
max_count=20
|
||||
# autocomplete_view = 'myapp.views.hobbies_autocomplete'
|
||||
|
||||
|
||||
|
||||
class Product(models.Model):
|
||||
|
||||
@@ -33,10 +56,10 @@ class Product(models.Model):
|
||||
sourcing_date = models.DateTimeField('Fecha de importación original de producto', null=True, blank=True)
|
||||
update_date = models.DateTimeField('Fecha de actualización de producto', null=True, blank=True)
|
||||
discount = models.DecimalField('Descuento', max_digits=5, decimal_places=2, null=True, blank=True)
|
||||
stock = models.PositiveIntegerField('Stock', null=True)
|
||||
stock = models.PositiveIntegerField('Stock', null=True, blank=True)
|
||||
tags = TagField(to=TreeTag)
|
||||
category = SingleTagField(blank=True, null=True) # main tag category
|
||||
attributes = TagField(to=TreeTag, related_name='product_attributes')
|
||||
category = SingleTagField(to=CategoryTag, null=True, blank=True) # main tag category
|
||||
attributes = TagField(to=AttributeTag, related_name='product_attributes')
|
||||
identifiers = models.TextField('Identificador único de producto', null=True, blank=True)
|
||||
|
||||
# internal
|
||||
|
||||
@@ -212,11 +212,11 @@ class ProductViewSetTest(APITestCase):
|
||||
|
||||
# Assert access is granted
|
||||
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||
# TODO: assert correct order
|
||||
previous_date = datetime.datetime.now()
|
||||
for instance in payload:
|
||||
self.assertTrue(datetime.datetime.fromisoformat(instance['created'][:-1]) < previous_date)
|
||||
previous_date = datetime.datetime.fromisoformat(instance['created'][:-1])
|
||||
# assert correct order
|
||||
dates = [d['created'][:-1] for d in payload]
|
||||
for i in range(len(dates)-1):
|
||||
# first instance should be most recent
|
||||
self.assertTrue(datetime.datetime.fromisoformat(dates[i]) > datetime.datetime.fromisoformat(dates[i+1]))
|
||||
|
||||
# authenticated user
|
||||
def test_auth_user_can_list_instances(self):
|
||||
@@ -321,7 +321,7 @@ class ProductViewSetTest(APITestCase):
|
||||
'discount': '0.05',
|
||||
'stock': 22,
|
||||
'tags': ['tag1x, tag2x'],
|
||||
'category': 'MayorTagCategory2',
|
||||
'category': 'mayortagcategory2',
|
||||
'attributes': ['color/blue', 'size/m'],
|
||||
'identifiers': '34rf34f43c43',
|
||||
}
|
||||
@@ -531,9 +531,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="azules"),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
|
||||
url = f"{self.endpoint}?query_string={query_string}"
|
||||
url = f"{self.endpoint}?q={q}"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
|
||||
@@ -565,10 +565,10 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="azules"),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
limit = 2
|
||||
|
||||
url = f"{self.endpoint}?query_string={query_string}&limit=2"
|
||||
url = f"{self.endpoint}?q={q}&limit=2"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
|
||||
@@ -592,9 +592,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="lunares/rojos", description="zapatos", shipping_cost=0.00),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
# shipping_cost=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&shipping_cost=true"
|
||||
url = f"{self.endpoint}?q={q}&shipping_cost=true"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -613,10 +613,10 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="azules", shipping_cost=10.00),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
|
||||
# shipping_cost=false
|
||||
url = f"{self.endpoint}?query_string={query_string}&shipping_cost=false"
|
||||
url = f"{self.endpoint}?q={q}&shipping_cost=false"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -636,9 +636,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", discount=None),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
# discount=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&discount=true"
|
||||
url = f"{self.endpoint}?q={q}&discount=true"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -658,9 +658,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="azules", discount=9.00),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
# discount=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&discount=false"
|
||||
url = f"{self.endpoint}?q={q}&discount=false"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -680,9 +680,8 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="azules"),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
# discount=true
|
||||
url = f"{self.endpoint}?query_string="
|
||||
url = f"{self.endpoint}?q="
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -702,9 +701,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="zapatos/azules", category="deporte", description='rojos', discount=12.00),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
# discount=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&category=ropa"
|
||||
url = f"{self.endpoint}?q={q}&category=ropa"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -724,9 +723,9 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="zapatos/azules", category="deporte", description='rojos', discount=12.00),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
q = quote("zapatos rojos")
|
||||
# discount=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&tags=deporte"
|
||||
url = f"{self.endpoint}?q={q}&tags=deporte"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# check response
|
||||
@@ -746,8 +745,8 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", price=None),
|
||||
]
|
||||
price_min = 5.00
|
||||
query_string = quote("zapatos rojos")
|
||||
url = f"{self.endpoint}?query_string={query_string}&price_min={price_min}"
|
||||
q = quote("zapatos rojos")
|
||||
url = f"{self.endpoint}?q={q}&price_min={price_min}"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
|
||||
@@ -770,8 +769,8 @@ class ProductSearchTest(TestCase):
|
||||
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", price=100.00),
|
||||
]
|
||||
price_max = 50.00
|
||||
query_string = quote("zapatos rojos")
|
||||
url = f"{self.endpoint}?query_string={query_string}&price_max={price_max}"
|
||||
q = quote("zapatos rojos")
|
||||
url = f"{self.endpoint}?q={q}&price_max={price_max}"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
|
||||
|
||||
@@ -28,7 +28,7 @@ from history.models import HistorySync
|
||||
from back_latienda.permissions import IsCreator
|
||||
from .utils import extract_search_filters, find_related_products_v3, find_related_products_v6
|
||||
from utils.tag_serializers import TaggitSerializer
|
||||
from utils.tag_filters import ProductTagFilter
|
||||
from utils.tag_filters import ProductTagFilter, ProductOrderFilter
|
||||
|
||||
|
||||
logging.basicConfig(
|
||||
@@ -40,21 +40,11 @@ logging.basicConfig(
|
||||
|
||||
|
||||
class ProductViewSet(viewsets.ModelViewSet):
|
||||
# queryset = Product.objects.all()
|
||||
queryset = Product.objects.all().order_by('-created')
|
||||
serializer_class = ProductSerializer
|
||||
permission_classes = [IsAuthenticatedOrReadOnly, IsCreator]
|
||||
filter_backends = [DjangoFilterBackend, OrderingFilter]
|
||||
filterset_class = ProductTagFilter
|
||||
filterset_fields = ['name', 'tags', 'category', 'attributes', 'company', 'created']
|
||||
# TODO: figure out why cant use filterset for company filter
|
||||
def get_queryset(self):
|
||||
try:
|
||||
company_id = self.request.GET.get('company')
|
||||
company_id = int(company_id)
|
||||
queryset = Product.objects.filter(company__id=company_id)
|
||||
except:
|
||||
queryset = Product.objects.all()
|
||||
return queryset
|
||||
|
||||
def perform_create(self, serializer):
|
||||
serializer.save(creator=self.request.user)
|
||||
@@ -159,7 +149,7 @@ def product_search(request):
|
||||
Takes a string of data, return relevant products
|
||||
|
||||
Params:
|
||||
- query_string: used for search [MANDATORY]
|
||||
- q: used for search [MANDATORY]
|
||||
- limit: max number of returned instances [OPTIONAL]
|
||||
- offset: where to start counting results [OPTIONAL]
|
||||
- shipping_cost: true/false
|
||||
@@ -168,7 +158,7 @@ def product_search(request):
|
||||
- tags: string
|
||||
"""
|
||||
# capture query params
|
||||
query_string = request.GET.get('query_string', None)
|
||||
q = request.GET.get('q', None)
|
||||
limit = request.GET.get('limit', None)
|
||||
offset = request.GET.get('offset', None)
|
||||
shipping_cost = request.GET.get('shipping_cost', None)
|
||||
@@ -192,9 +182,9 @@ def product_search(request):
|
||||
price_min = request.GET.get('price_min', None)
|
||||
price_max = request.GET.get('price_max', None)
|
||||
|
||||
if query_string is None:
|
||||
if q is None:
|
||||
return Response({"errors": {"details": "No query string to parse"}})
|
||||
elif query_string is '':
|
||||
elif q is '':
|
||||
# return everything
|
||||
serializer = ProductSerializer(Product.objects.all(), many=True)
|
||||
products = serializer.data
|
||||
@@ -205,7 +195,7 @@ def product_search(request):
|
||||
result_set = set()
|
||||
|
||||
# split query string into single words
|
||||
chunks = query_string.split(' ')
|
||||
chunks = q.split(' ')
|
||||
for chunk in chunks:
|
||||
product_set = find_related_products_v6(chunk, shipping_cost, discount, category, tags, price_min, price_max)
|
||||
# add to result set
|
||||
|
||||
Reference in New Issue
Block a user