diff --git a/assets/pasted-20260206-000101-e0693223.png b/assets/pasted-20260206-000101-e0693223.png
new file mode 100644
index 0000000..fdda5e3
Binary files /dev/null and b/assets/pasted-20260206-000101-e0693223.png differ
diff --git a/config/__pycache__/settings.cpython-311.pyc b/config/__pycache__/settings.cpython-311.pyc
index 96bce55..4495e11 100644
Binary files a/config/__pycache__/settings.cpython-311.pyc and b/config/__pycache__/settings.cpython-311.pyc differ
diff --git a/config/__pycache__/urls.cpython-311.pyc b/config/__pycache__/urls.cpython-311.pyc
index 0b85e94..894e171 100644
Binary files a/config/__pycache__/urls.cpython-311.pyc and b/config/__pycache__/urls.cpython-311.pyc differ
diff --git a/config/settings.py b/config/settings.py
index 291d043..37b9783 100644
--- a/config/settings.py
+++ b/config/settings.py
@@ -43,14 +43,9 @@ CSRF_COOKIE_SECURE = True
SESSION_COOKIE_SAMESITE = "None"
CSRF_COOKIE_SAMESITE = "None"
-# Quick-start development settings - unsuitable for production
-# See https://docs.djangoproject.com/en/5.2/howto/deployment/checklist/
-
# Application definition
INSTALLED_APPS = [
- 'django.contrib.admin',
- 'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
@@ -63,10 +58,7 @@ MIDDLEWARE = [
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
- 'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
- # Disable X-Frame-Options middleware to allow Flatlogic preview iframes.
- # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
X_FRAME_OPTIONS = 'ALLOWALL'
@@ -81,7 +73,6 @@ TEMPLATES = [
'OPTIONS': {
'context_processors': [
'django.template.context_processors.request',
- 'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
# IMPORTANT: do not remove – injects PROJECT_DESCRIPTION/PROJECT_IMAGE_URL and cache-busting timestamp
'core.context_processors.project_context',
@@ -110,26 +101,6 @@ DATABASES = {
},
}
-
-# Password validation
-# https://docs.djangoproject.com/en/5.2/ref/settings/#auth-password-validators
-
-AUTH_PASSWORD_VALIDATORS = [
- {
- 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
- },
- {
- 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
- },
- {
- 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
- },
- {
- 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
- },
-]
-
-
# Internationalization
# https://docs.djangoproject.com/en/5.2/topics/i18n/
diff --git a/config/urls.py b/config/urls.py
index bcfc074..be886bc 100644
--- a/config/urls.py
+++ b/config/urls.py
@@ -14,13 +14,11 @@ Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
-from django.contrib import admin
from django.urls import include, path
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = [
- path("admin/", admin.site.urls),
path("", include("core.urls")),
]
diff --git a/core/__pycache__/forms.cpython-311.pyc b/core/__pycache__/forms.cpython-311.pyc
new file mode 100644
index 0000000..143708c
Binary files /dev/null and b/core/__pycache__/forms.cpython-311.pyc differ
diff --git a/core/__pycache__/urls.cpython-311.pyc b/core/__pycache__/urls.cpython-311.pyc
index 5a69659..6159c03 100644
Binary files a/core/__pycache__/urls.cpython-311.pyc and b/core/__pycache__/urls.cpython-311.pyc differ
diff --git a/core/__pycache__/views.cpython-311.pyc b/core/__pycache__/views.cpython-311.pyc
index 37a3157..cac8e17 100644
Binary files a/core/__pycache__/views.cpython-311.pyc and b/core/__pycache__/views.cpython-311.pyc differ
diff --git a/core/forms.py b/core/forms.py
new file mode 100644
index 0000000..9df1830
--- /dev/null
+++ b/core/forms.py
@@ -0,0 +1,27 @@
+from django import forms
+from .models import Firma, Fatura, FaturaKalemi
+
+class FirmaForm(forms.ModelForm):
+ class Meta:
+ model = Firma
+ fields = ['ad', 'vergi_no', 'mersis_no', 'adres']
+ widgets = {
+ 'ad': forms.TextInput(attrs={'class': 'form-control', 'placeholder': 'Firma Tam Adı'}),
+ 'vergi_no': forms.TextInput(attrs={'class': 'form-control', 'placeholder': 'Vergi No / TC Kimlik No'}),
+ 'mersis_no': forms.TextInput(attrs={'class': 'form-control', 'placeholder': 'MERSİS No (Opsiyonel)'}),
+ 'adres': forms.Textarea(attrs={'class': 'form-control', 'rows': 3, 'placeholder': 'Firma Adresi'}),
+ }
+
+class FaturaForm(forms.ModelForm):
+ class Meta:
+ model = Fatura
+ fields = ['firma', 'fatura_no', 'tarih', 'ara_toplam', 'kdv_toplam', 'genel_toplam', 'pdf_dosyasi']
+ widgets = {
+ 'firma': forms.Select(attrs={'class': 'form-select'}),
+ 'fatura_no': forms.TextInput(attrs={'class': 'form-control', 'placeholder': 'Fatura No'}),
+ 'tarih': forms.DateInput(attrs={'class': 'form-control', 'type': 'date'}),
+ 'ara_toplam': forms.NumberInput(attrs={'class': 'form-control', 'step': '0.01'}),
+ 'kdv_toplam': forms.NumberInput(attrs={'class': 'form-control', 'step': '0.01'}),
+ 'genel_toplam': forms.NumberInput(attrs={'class': 'form-control', 'step': '0.01'}),
+ 'pdf_dosyasi': forms.FileInput(attrs={'class': 'form-control'}),
+ }
diff --git a/core/templates/base.html b/core/templates/base.html
index 43c2f26..f530a5f 100644
--- a/core/templates/base.html
+++ b/core/templates/base.html
@@ -3,7 +3,7 @@
- {% block title %}Fatura Yönetim Sistemi{% endblock %}
+ {% block title %}FaturaYol - Akıllı Fatura Yönetimi{% endblock %}
@@ -13,9 +13,10 @@
{% block extra_css %}{% endblock %}
@@ -121,49 +133,68 @@
-