Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Task 002: Done #109

Open
wants to merge 36 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
85f0b61
Added localhost as allowed host
MatthewBL Nov 15, 2022
9fef2d8
Added branches
MatthewBL Nov 15, 2022
779873d
Fixed the Stripe connection, changed order table and added delivery o…
sergiomdza Nov 21, 2022
16f45de
Updated DB
sergiomdza Nov 21, 2022
3a2d4e4
Merge pull request #1 from lintoeli/sm-delivery-options
sergiomdza Nov 21, 2022
f3cc5b0
Merge branch 'master' into Task-007
Pabloguti01 Nov 21, 2022
4054366
Task-003 almost done
lintoeli Nov 21, 2022
475381b
Task-007 done
Pabloguti01 Nov 24, 2022
e738134
Frontend style changes
Nov 24, 2022
a094443
Merge pull request #2 from lintoeli/Task-001
MatthewBL Nov 24, 2022
a626eb6
Merge branch 'master' into Task-003
MatthewBL Nov 24, 2022
a0edc50
Merge pull request #3 from lintoeli/Task-003
MatthewBL Nov 24, 2022
0c0e298
Merge pull request #4 from lintoeli/Task-007
MatthewBL Nov 24, 2022
7853d88
search function and search result page
Nov 28, 2022
90c0cc8
Merge pull request #5 from lintoeli/master
MatthewBL Nov 28, 2022
637be0c
Contact e-mail added
MatthewBL Nov 28, 2022
7929336
stock fixed
MatthewBL Nov 28, 2022
dee66bd
Task-008
sergiomdza Nov 29, 2022
69244ce
Merge pull request #7 from lintoeli/Task-012
MatthewBL Nov 29, 2022
c4ceca4
search filter
Nov 29, 2022
18b541f
db.sqlite3 reverted
MatthewBL Nov 29, 2022
aaac47d
gitignore updated
MatthewBL Nov 29, 2022
d888250
Merge branch 'master' into Task-008
MatthewBL Nov 29, 2022
6b6d982
Merge pull request #6 from lintoeli/Task-008
MatthewBL Nov 29, 2022
15b1ec2
Search filter is working
sergiomdza Nov 29, 2022
76d7b58
DB in gitignore
sergiomdza Nov 29, 2022
ba3dc0a
updated search filter
Nov 29, 2022
70ccc3f
Fixed conflict
sergiomdza Nov 29, 2022
7e874fc
Fixed about us info
sergiomdza Nov 29, 2022
94786e8
db.sqlite3 reverted
MatthewBL Nov 29, 2022
b7fdffd
revert db.sqlite3
MatthewBL Nov 29, 2022
41dd678
Merge pull request #8 from lintoeli/Task-009
MatthewBL Nov 29, 2022
69961fd
Merge pull request #9 from lintoeli/master
MatthewBL Nov 29, 2022
76fbf43
Task-002: Cambios en el front
lintoeli Dec 1, 2022
0f8eb7d
Task-002: Only more products remaining
lintoeli Dec 3, 2022
732c746
Task-002: Done
lintoeli Dec 3, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added .DS_Store
Binary file not shown.
4 changes: 2 additions & 2 deletions .env
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@ DB_PASSWORD=your-db-password
DB_HOST=localhost
STRIPE_LIVE_PUBLIC_KEY=your-live-public-key
STRIPE_LIVE_SECRET_KEY=your-live-secret-key
STRIPE_TEST_PUBLIC_KEY=your-test-public-key
STRIPE_TEST_SECRET_KEY=your-test-secret-key
STRIPE_TEST_PUBLIC_KEY=pk_test_51M6F30LGjE9fhQqPTS1xn299XD7lokUGfB28YhXT98EqRWpikN7nmKmm02G3Rhs3GzmzXBUAGB9U2wlj5GUF7mpA00MEZvJ96P
STRIPE_TEST_SECRET_KEY=sk_test_51M6F30LGjE9fhQqPY3kIzN9j6LmzUnrc9zy7viG4Iarpz7TvEZmr0etlIKpEUgaaSi3I3Db5C42QdnkXu2X2Qr8d00RbhctodS
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ share/python-wheels/
*.egg-info/
.installed.cfg
*.egg
.env
db.sqlite3
MANIFEST

# PyInstaller
Expand Down
8 changes: 8 additions & 0 deletions core/forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,11 @@
('P', 'PayPal')
)

DELIVERY_CHOICES = (
('ST', 'Standard (+ 3.00$)'),
('EX', 'Express (+ 6.00$)')
)


class CheckoutForm(forms.Form):
shipping_address = forms.CharField(required=False)
Expand Down Expand Up @@ -37,6 +42,9 @@ class CheckoutForm(forms.Form):
payment_option = forms.ChoiceField(
widget=forms.RadioSelect, choices=PAYMENT_CHOICES)

delivery_option = forms.ChoiceField(
widget=forms.RadioSelect, choices=DELIVERY_CHOICES)


class CouponForm(forms.Form):
code = forms.CharField(widget=forms.TextInput(attrs={
Expand Down
18 changes: 18 additions & 0 deletions core/migrations/0005_order_delivery_option.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-11-21 01:43

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0004_auto_20190630_1408'),
]

operations = [
migrations.AddField(
model_name='order',
name='delivery_option',
field=models.CharField(max_length=20, null=True),
),
]
23 changes: 23 additions & 0 deletions core/migrations/0006_auto_20221120_2004.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 2.2.14 on 2022-11-21 02:04

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0005_order_delivery_option'),
]

operations = [
migrations.AddField(
model_name='order',
name='deleteTag',
field=models.BooleanField(default=False),
),
migrations.AddField(
model_name='order',
name='email',
field=models.CharField(max_length=50, null=True),
),
]
18 changes: 18 additions & 0 deletions core/migrations/0007_auto_20221125_1731.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-11-25 17:31

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0006_auto_20221120_2004'),
]

operations = [
migrations.AlterField(
model_name='item',
name='category',
field=models.CharField(choices=[('A', 'Class A'), ('B', 'Class B'), ('C', 'Class C')], max_length=2),
),
]
18 changes: 18 additions & 0 deletions core/migrations/0007_order_totalorder.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-11-24 10:20

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0006_auto_20221120_2004'),
]

operations = [
migrations.AddField(
model_name='order',
name='totalOrder',
field=models.FloatField(null=True),
),
]
19 changes: 19 additions & 0 deletions core/migrations/0008_item_stock.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Generated by Django 2.2.14 on 2022-11-28 20:09

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0007_order_totalorder'),
]

operations = [
migrations.AddField(
model_name='item',
name='stock',
field=models.PositiveIntegerField(default=10),
preserve_default=False,
),
]
14 changes: 14 additions & 0 deletions core/migrations/0009_merge_20221201_1840.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# Generated by Django 2.2.14 on 2022-12-01 17:40

from django.db import migrations


class Migration(migrations.Migration):

dependencies = [
('core', '0007_auto_20221125_1731'),
('core', '0008_item_stock'),
]

operations = [
]
18 changes: 18 additions & 0 deletions core/migrations/0010_auto_20221201_1840.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-12-01 17:40

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0009_merge_20221201_1840'),
]

operations = [
migrations.AlterField(
model_name='item',
name='stock',
field=models.PositiveIntegerField(default=0),
),
]
23 changes: 23 additions & 0 deletions core/migrations/0011_auto_20221201_1908.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 2.2.14 on 2022-12-01 18:08

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0010_auto_20221201_1840'),
]

operations = [
migrations.AlterField(
model_name='item',
name='category',
field=models.CharField(choices=[('FU', 'Furniture'), ('VE', 'Vehicles'), ('CLT', 'Clothes'), ('OUT', 'Outdoor'), ('BP', 'Backpacks')], max_length=2),
),
migrations.AlterField(
model_name='item',
name='image',
field=models.URLField(),
),
]
18 changes: 18 additions & 0 deletions core/migrations/0012_auto_20221201_1910.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-12-01 18:10

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0011_auto_20221201_1908'),
]

operations = [
migrations.AlterField(
model_name='item',
name='image',
field=models.ImageField(upload_to=''),
),
]
18 changes: 18 additions & 0 deletions core/migrations/0013_auto_20221201_1923.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-12-01 18:23

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0012_auto_20221201_1910'),
]

operations = [
migrations.AlterField(
model_name='item',
name='image',
field=models.CharField(max_length=1000),
),
]
18 changes: 18 additions & 0 deletions core/migrations/0014_auto_20221202_1134.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Generated by Django 2.2.14 on 2022-12-02 10:34

from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('core', '0013_auto_20221201_1923'),
]

operations = [
migrations.AlterField(
model_name='item',
name='category',
field=models.CharField(choices=[('FU', 'Furniture'), ('VE', 'Vehicles'), ('CL', 'Clothes'), ('OD', 'Outdoor'), ('BP', 'Backpacks')], max_length=2),
),
]
36 changes: 30 additions & 6 deletions core/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,11 @@


CATEGORY_CHOICES = (
('S', 'Shirt'),
('SW', 'Sport wear'),
('OW', 'Outwear')
('FU', 'Furniture'),
('VE', 'Vehicles'),
('CL', 'Clothes'),
('OD', 'Outdoor'),
('BP', 'Backpacks')
)

LABEL_CHOICES = (
Expand Down Expand Up @@ -37,12 +39,14 @@ def __str__(self):
class Item(models.Model):
title = models.CharField(max_length=100)
price = models.FloatField()
description = models.CharField(max_length=1000)
discount_price = models.FloatField(blank=True, null=True)
category = models.CharField(choices=CATEGORY_CHOICES, max_length=2)
label = models.CharField(choices=LABEL_CHOICES, max_length=1)
slug = models.SlugField()
description = models.TextField()
image = models.ImageField()
stock = models.PositiveIntegerField(default=0)
image = models.CharField(max_length=1000)

def __str__(self):
return self.title
Expand Down Expand Up @@ -87,6 +91,10 @@ def get_final_price(self):
return self.get_total_discount_item_price()
return self.get_total_item_price()

def validate_stock(self):
if self.quantity > self.item.stock:
raise("Not enough stock for this item: ", self.item.title)


class Order(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL,
Expand All @@ -108,6 +116,10 @@ class Order(models.Model):
received = models.BooleanField(default=False)
refund_requested = models.BooleanField(default=False)
refund_granted = models.BooleanField(default=False)
delivery_option = models.CharField(max_length=20, null=True)
email = models.CharField(max_length=50, null=True)
deleteTag = models.BooleanField(default=False)
totalOrder = models.FloatField(null=True)

'''
1. Item added to cart
Expand All @@ -127,10 +139,22 @@ def get_total(self):
total = 0
for order_item in self.items.all():
total += order_item.get_final_price()
if self.coupon:
total -= self.coupon.amount
if total < 50.0:
if self.delivery_option == 'ST':
total += 3
if self.delivery_option == 'EX':
total += 6

self.totalOrder = total
self.save()
return total

def standard_delivery(self):
self.totalOrder = self.get_total() + 3

def express_delivery(self):
self.totalOrder = self.get_total() + 6


class Address(models.Model):
user = models.ForeignKey(settings.AUTH_USER_MODEL,
Expand Down
14 changes: 14 additions & 0 deletions core/urls.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,16 @@
from django.urls import path
from .views import (
ItemDetailView,
CategoryAll,
CategoryFU,
CategoryVE,
CategoryOD,
CategoryBP,
CategoryCL,
CheckoutView,
HomeView,
OrderSummaryView,
SearchResult,
add_to_cart,
remove_from_cart,
remove_single_item_from_cart,
Expand All @@ -16,6 +23,13 @@

urlpatterns = [
path('', HomeView.as_view(), name='home'),
path('search/', SearchResult.as_view(), name='search'),
path('all/', CategoryAll.as_view(), name='all'),
path('FU/', CategoryFU.as_view(), name='FU'),
path('VE/', CategoryVE.as_view(), name='VE'),
path('OD/', CategoryOD.as_view(), name='OD'),
path('BP/', CategoryBP.as_view(), name='BP'),
path('CL/', CategoryCL.as_view(), name='CL'),
path('checkout/', CheckoutView.as_view(), name='checkout'),
path('order-summary/', OrderSummaryView.as_view(), name='order-summary'),
path('product/<slug>/', ItemDetailView.as_view(), name='product'),
Expand Down
Loading