beta v.1.1
This commit is contained in:
4
.gitignore
vendored
Normal file
4
.gitignore
vendored
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
# created by virtualenv automatically
|
||||||
|
.venv
|
||||||
|
venv
|
||||||
|
.idea
|
||||||
8
.idea/.gitignore
generated
vendored
Normal file
8
.idea/.gitignore
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
||||||
|
# Editor-based HTTP Client requests
|
||||||
|
/httpRequests/
|
||||||
|
# Datasource local storage ignored files
|
||||||
|
/dataSources/
|
||||||
|
/dataSources.local.xml
|
||||||
25
.idea/WevertonOrg.iml
generated
Normal file
25
.idea/WevertonOrg.iml
generated
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="PYTHON_MODULE" version="4">
|
||||||
|
<component name="FacetManager">
|
||||||
|
<facet type="django" name="Django">
|
||||||
|
<configuration>
|
||||||
|
<option name="rootFolder" value="$MODULE_DIR$" />
|
||||||
|
<option name="settingsModule" value="Setup/settings.py" />
|
||||||
|
<option name="manageScript" value="$MODULE_DIR$/manage.py" />
|
||||||
|
<option name="environment" value="<map/>" />
|
||||||
|
<option name="doNotUseTestRunner" value="false" />
|
||||||
|
<option name="trackFilePattern" value="migrations" />
|
||||||
|
</configuration>
|
||||||
|
</facet>
|
||||||
|
</component>
|
||||||
|
<component name="NewModuleRootManager">
|
||||||
|
<content url="file://$MODULE_DIR$">
|
||||||
|
<excludeFolder url="file://$MODULE_DIR$/.venv" />
|
||||||
|
</content>
|
||||||
|
<orderEntry type="jdk" jdkName="Python 3.12 (WevertonOrg)" jdkType="Python SDK" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
<component name="TemplatesService">
|
||||||
|
<option name="TEMPLATE_CONFIGURATION" value="Django" />
|
||||||
|
</component>
|
||||||
|
</module>
|
||||||
6
.idea/inspectionProfiles/profiles_settings.xml
generated
Normal file
6
.idea/inspectionProfiles/profiles_settings.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<component name="InspectionProjectProfileManager">
|
||||||
|
<settings>
|
||||||
|
<option name="USE_PROJECT_PROFILE" value="false" />
|
||||||
|
<version value="1.0" />
|
||||||
|
</settings>
|
||||||
|
</component>
|
||||||
6
.idea/misc.xml
generated
Normal file
6
.idea/misc.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="Black">
|
||||||
|
<option name="sdkName" value="Python 3.12 (WevertonOrg)" />
|
||||||
|
</component>
|
||||||
|
</project>
|
||||||
8
.idea/modules.xml
generated
Normal file
8
.idea/modules.xml
generated
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/.idea/WevertonOrg.iml" filepath="$PROJECT_DIR$/.idea/WevertonOrg.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
||||||
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
||||||
BIN
Base/__pycache__/__init__.cpython-312.pyc
Normal file
BIN
Base/__pycache__/__init__.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/__pycache__/admin.cpython-312.pyc
Normal file
BIN
Base/__pycache__/admin.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/__pycache__/apps.cpython-312.pyc
Normal file
BIN
Base/__pycache__/apps.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/__pycache__/models.cpython-312.pyc
Normal file
BIN
Base/__pycache__/models.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/__pycache__/urls.cpython-312.pyc
Normal file
BIN
Base/__pycache__/urls.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/__pycache__/views.cpython-312.pyc
Normal file
BIN
Base/__pycache__/views.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Base/migrations/__pycache__/__init__.cpython-312.pyc
Normal file
BIN
Base/migrations/__pycache__/__init__.cpython-312.pyc
Normal file
Binary file not shown.
11
Base/templates/Login/Dashboard.html
Normal file
11
Base/templates/Login/Dashboard.html
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{% extends "BaseLogin.html" %}
|
||||||
|
{% block title %} Dashboard {% endblock %}
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-12">
|
||||||
|
<h1> {{ Day }} </h1>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<br>
|
||||||
|
{% endblock %}
|
||||||
5
Base/templates/Login/Home.html
Normal file
5
Base/templates/Login/Home.html
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
{% extends "Base.html" %}
|
||||||
|
{% block title %} Home {% endblock %}
|
||||||
|
{% block content %}
|
||||||
|
<p class="text-center"> Home </p>
|
||||||
|
{% endblock %}
|
||||||
14
Base/urls.py
Normal file
14
Base/urls.py
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
from django.urls import path
|
||||||
|
from django.contrib.auth import views as auth_views
|
||||||
|
from Base.views import (
|
||||||
|
views,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
urlpatterns = [
|
||||||
|
# base das URLs
|
||||||
|
path('', views.Home, name='Home'),
|
||||||
|
path('login/', auth_views.LoginView.as_view(), name='login'),
|
||||||
|
path('logout/', auth_views.LogoutView.as_view(), name='logout'),
|
||||||
|
path('dashboard', views.Dashboard.as_view(), name='Dashboard'),
|
||||||
|
]
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
from django.shortcuts import render
|
|
||||||
|
|
||||||
# Create your views here.
|
|
||||||
BIN
Base/views/__pycache__/views.cpython-312.pyc
Normal file
BIN
Base/views/__pycache__/views.cpython-312.pyc
Normal file
Binary file not shown.
21
Base/views/views.py
Normal file
21
Base/views/views.py
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
from django.shortcuts import render
|
||||||
|
from django.views.generic import TemplateView
|
||||||
|
from django.contrib.auth.mixins import LoginRequiredMixin #, PermissionRequiredMixin
|
||||||
|
from django.utils import timezone
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Create your views here.
|
||||||
|
|
||||||
|
def Home(request):
|
||||||
|
context = { 'ok':'ok', }
|
||||||
|
return render(request,'Login/Home.html',context )
|
||||||
|
|
||||||
|
class Dashboard(LoginRequiredMixin, TemplateView):
|
||||||
|
template_name = 'Login/Dashboard.html'
|
||||||
|
def get_context_data(self, **kwargs):
|
||||||
|
context = super().get_context_data(**kwargs)
|
||||||
|
Day = timezone.localtime(timezone.now())
|
||||||
|
context['User'] = self.request.user.username.capitalize()
|
||||||
|
context['Day'] = Day
|
||||||
|
return context
|
||||||
BIN
Setup/__pycache__/__init__.cpython-312.pyc
Normal file
BIN
Setup/__pycache__/__init__.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Setup/__pycache__/settings.cpython-312.pyc
Normal file
BIN
Setup/__pycache__/settings.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Setup/__pycache__/urls.cpython-312.pyc
Normal file
BIN
Setup/__pycache__/urls.cpython-312.pyc
Normal file
Binary file not shown.
BIN
Setup/__pycache__/wsgi.cpython-312.pyc
Normal file
BIN
Setup/__pycache__/wsgi.cpython-312.pyc
Normal file
Binary file not shown.
@@ -25,7 +25,7 @@ SECRET_KEY = 'django-insecure-as6)9knap6(+0)#l=h&aq8j&dyjb9w0ao_uv(&q4epoccp6c&0
|
|||||||
# SECURITY WARNING: don't run with debug turned on in production!
|
# SECURITY WARNING: don't run with debug turned on in production!
|
||||||
DEBUG = True
|
DEBUG = True
|
||||||
|
|
||||||
ALLOWED_HOSTS = ['192.168.0.201','weverton.org']
|
ALLOWED_HOSTS = ['127.0.0.1','192.168.0.201','weverton.org']
|
||||||
|
|
||||||
|
|
||||||
# Application definition
|
# Application definition
|
||||||
@@ -37,6 +37,8 @@ INSTALLED_APPS = [
|
|||||||
'django.contrib.sessions',
|
'django.contrib.sessions',
|
||||||
'django.contrib.messages',
|
'django.contrib.messages',
|
||||||
'django.contrib.staticfiles',
|
'django.contrib.staticfiles',
|
||||||
|
#Apps
|
||||||
|
'Base',
|
||||||
]
|
]
|
||||||
|
|
||||||
MIDDLEWARE = [
|
MIDDLEWARE = [
|
||||||
@@ -54,7 +56,7 @@ ROOT_URLCONF = 'Setup.urls'
|
|||||||
TEMPLATES = [
|
TEMPLATES = [
|
||||||
{
|
{
|
||||||
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
||||||
'DIRS': [],
|
'DIRS': ['Templates'],
|
||||||
'APP_DIRS': True,
|
'APP_DIRS': True,
|
||||||
'OPTIONS': {
|
'OPTIONS': {
|
||||||
'context_processors': [
|
'context_processors': [
|
||||||
@@ -102,9 +104,9 @@ AUTH_PASSWORD_VALIDATORS = [
|
|||||||
# Internationalization
|
# Internationalization
|
||||||
# https://docs.djangoproject.com/en/5.2/topics/i18n/
|
# https://docs.djangoproject.com/en/5.2/topics/i18n/
|
||||||
|
|
||||||
LANGUAGE_CODE = 'en-us'
|
LANGUAGE_CODE = 'pt-br'
|
||||||
|
|
||||||
TIME_ZONE = 'UTC'
|
TIME_ZONE = 'America/Sao_Paulo'
|
||||||
|
|
||||||
USE_I18N = True
|
USE_I18N = True
|
||||||
|
|
||||||
@@ -115,12 +117,16 @@ USE_TZ = True
|
|||||||
# https://docs.djangoproject.com/en/5.2/howto/static-files/
|
# https://docs.djangoproject.com/en/5.2/howto/static-files/
|
||||||
|
|
||||||
STATIC_URL = 'static/'
|
STATIC_URL = 'static/'
|
||||||
|
STATIC_ROOT = BASE_DIR / 'static'
|
||||||
|
MEDIA_URL = '/media/'
|
||||||
|
MEDIA_ROOT = BASE_DIR / 'media'
|
||||||
|
|
||||||
# Default primary key field type
|
# Default primary key field type
|
||||||
# https://docs.djangoproject.com/en/5.2/ref/settings/#default-auto-field
|
# https://docs.djangoproject.com/en/5.2/ref/settings/#default-auto-field
|
||||||
|
|
||||||
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
|
DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'
|
||||||
|
|
||||||
STATIC_ROOT = BASE_DIR / 'static'
|
#Login
|
||||||
MEDIA_URL = '/media/'
|
LOGIN_URL = 'login'
|
||||||
MEDIA_ROOT = BASE_DIR / 'media'
|
LOGIN_REDIRECT_URL = '/dashboard'
|
||||||
|
LOGOUT_REDIRECT_URL = '/login'
|
||||||
@@ -15,8 +15,9 @@ Including another URLconf
|
|||||||
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
|
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
|
||||||
"""
|
"""
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
from django.urls import path
|
from django.urls import path, include
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('admin/', admin.site.urls),
|
path('admin/', admin.site.urls),
|
||||||
|
path('', include('Base.urls')),
|
||||||
]
|
]
|
||||||
|
|||||||
7
Templates/403.html
Normal file
7
Templates/403.html
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
{% extends "BaseLogin.html" %}
|
||||||
|
{% block title %} Dashboard {% endblock %}
|
||||||
|
{% block content %}
|
||||||
|
|
||||||
|
<br> Erro 403 <br>
|
||||||
|
|
||||||
|
{% endblock %}
|
||||||
11
Templates/404.html
Normal file
11
Templates/404.html
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>Não Encontrado</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1> Algo deu ruim ai . </h1>
|
||||||
|
<a href="{% url 'Home' %}" class="btn btn-secondary mt-3 "> Home </a>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
25
Templates/Base.html
Normal file
25
Templates/Base.html
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="pt-br" data-bs-theme="dark">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>{% block title %} {% endblock %}</title>
|
||||||
|
|
||||||
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css"
|
||||||
|
rel="stylesheet" integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH"
|
||||||
|
crossorigin="anonymous">
|
||||||
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css">
|
||||||
|
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
{% include 'components/_header.html' %}
|
||||||
|
<div class="row">
|
||||||
|
{% block content %}
|
||||||
|
{% endblock %}
|
||||||
|
</div>
|
||||||
|
{% include 'components/_footer.html' %}
|
||||||
|
|
||||||
|
<script async src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"
|
||||||
|
integrity="sha384-YvpcrYf0tY3lHB60NNkmXc5s9fDVZLESaAA55NDzOxhy9GkcIdslK1eN7N6jIeHz"
|
||||||
|
crossorigin="anonymous"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
43
Templates/BaseLogin.html
Normal file
43
Templates/BaseLogin.html
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="pt-br" data-bs-theme="dark">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<title>{% block title %} {% endblock %}</title>
|
||||||
|
|
||||||
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css"
|
||||||
|
rel="stylesheet" integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH"
|
||||||
|
crossorigin="anonymous">
|
||||||
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css">
|
||||||
|
|
||||||
|
</head>
|
||||||
|
<body class="">
|
||||||
|
{% include 'components/_header.html' %}
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-2 bg-body-tertiary " id="sidebar" >
|
||||||
|
{% include 'components/_sidebar.html' %}
|
||||||
|
|
||||||
|
{# {% include 'components/_sidebar_admin.html' %}#}
|
||||||
|
</div>
|
||||||
|
<div class="col-10">
|
||||||
|
<div class="container-fluid">
|
||||||
|
<div class="col py-3">
|
||||||
|
<main>
|
||||||
|
{% include 'components/_msg.html' %}
|
||||||
|
{% block content %}
|
||||||
|
{% endblock %}
|
||||||
|
</main>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% include 'components/_footer.html' %}
|
||||||
|
<script async src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"
|
||||||
|
integrity="sha384-YvpcrYf0tY3lHB60NNkmXc5s9fDVZLESaAA55NDzOxhy9GkcIdslK1eN7N6jIeHz"
|
||||||
|
crossorigin="anonymous"></script>
|
||||||
|
</body>
|
||||||
|
<style>
|
||||||
|
#sidebar {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</html>
|
||||||
12
Templates/components/_footer.html
Normal file
12
Templates/components/_footer.html
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
<footer class="footer mt-auto py-3 text-center bg-body-tertiary">
|
||||||
|
<div class="container">
|
||||||
|
<a class="navbar-brand --bs-success-text-emphasis" href="{% url 'Home' %}"> © Weverton </a>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
<style>
|
||||||
|
footer {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 0;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
34
Templates/components/_header.html
Normal file
34
Templates/components/_header.html
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
{% load tz %}
|
||||||
|
</nav>
|
||||||
|
<nav class="navbar navbar-expand-lg bg-body-tertiary">
|
||||||
|
<i class="bi bi-balloon-heart"></i>
|
||||||
|
<div class="container-fluid">
|
||||||
|
{% if not user.is_authenticated %}
|
||||||
|
<a class="navbar-brand --bs-success-text-emphasis" href="{% url 'Home' %}"> Wevertom </a>
|
||||||
|
{% endif %}
|
||||||
|
{% if user.is_authenticated %}
|
||||||
|
<a class="navbar-brand --bs-success-text-emphasis" href="{% url 'Dashboard' %}"> Weverton </a>
|
||||||
|
{% endif %}
|
||||||
|
<ul class="nav justify-content-center">
|
||||||
|
<li class="navbar-brand --bs-success-text-emphasis">
|
||||||
|
Hoje dia {% now "d" %} de {% now "F" %} de {% now "Y" %} ({% now "d/m/Y" %})
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="nav justify-content-end">
|
||||||
|
{% if not user.is_authenticated %}
|
||||||
|
<li class="nav-item">
|
||||||
|
<a class="btn btn-primary" aria-current="page" href="{% url 'login' %}">Login</a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
{% if user.is_authenticated %}
|
||||||
|
<li class="navbar-brand --bs-success-text-emphasis">
|
||||||
|
Ola, {{ user.username.capitalize }}
|
||||||
|
</li>
|
||||||
|
<form action="{% url 'logout' %}" method="post" id="logout-form" class="">
|
||||||
|
{% csrf_token %}
|
||||||
|
<button type="submit" class="btn btn-danger" aria-current="true"> Logout </button>
|
||||||
|
</form>
|
||||||
|
{% endif %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
17
Templates/components/_msg.html
Normal file
17
Templates/components/_msg.html
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
{% if messages %}
|
||||||
|
{% for message in messages %}
|
||||||
|
<div class="alert {% if 'success' in message.tags %}alert-primary{% elif 'error' in message.tags %}alert-danger{% endif %} message" role="alert">
|
||||||
|
{{ message }}
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<script>
|
||||||
|
// Espera 5 segundos e depois remove as mensagens
|
||||||
|
setTimeout(function() {
|
||||||
|
const messages = document.querySelectorAll('.message');
|
||||||
|
messages.forEach(function(message) {
|
||||||
|
message.style.display = 'none';
|
||||||
|
});
|
||||||
|
}, 9000);
|
||||||
|
</script>
|
||||||
49
Templates/components/_pagination.html
Normal file
49
Templates/components/_pagination.html
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
{% if page_obj.has_other_pages %}
|
||||||
|
<nav>
|
||||||
|
<ul class="pagination justify-content-center">
|
||||||
|
{% if page_obj.has_previous %}
|
||||||
|
<li class="page-item">
|
||||||
|
<a class="page-link" href="?page=1">
|
||||||
|
Primeira
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="page-item">
|
||||||
|
<a class="page-link" href="?page={{ page_obj.previous_page_number }}">
|
||||||
|
Anterior
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{% for page_number in page_obj.paginator.page_range %}
|
||||||
|
{% if page_number <= page_obj.number|add:3 and page_number >= page_obj.number|add:-3 %}
|
||||||
|
{% if page_obj.number == page_number %}
|
||||||
|
<li class="page-item active">
|
||||||
|
<a class="page-link" href="?page={{ page_number }}">
|
||||||
|
{{ page_number }}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% else %}
|
||||||
|
<li class="page-item">
|
||||||
|
<a class="page-link" href="?page={{ page_number }}">
|
||||||
|
{{ page_number }}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
|
{% endfor %}
|
||||||
|
|
||||||
|
{% if page_obj.has_next %}
|
||||||
|
<li class="page-item">
|
||||||
|
<a class="page-link" href="?page={{ page_obj.next_page_number }}">
|
||||||
|
Próxima
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="page-item">
|
||||||
|
<a class="page-link" href="?page={{ page_obj.paginator.num_pages }}">
|
||||||
|
Última
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{% endif %}
|
||||||
|
</ul>
|
||||||
|
</nav>
|
||||||
|
{% endif %}
|
||||||
10
Templates/components/_sidebar.html
Normal file
10
Templates/components/_sidebar.html
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
{% if user.is_authenticated %}
|
||||||
|
<div class="" >
|
||||||
|
<div class="list-group" >
|
||||||
|
<a class="list-group-item list-group-item-action list-group-item-primary"
|
||||||
|
aria-current="true" href="{% url 'Home' %}"> Home </a>
|
||||||
|
<a class="list-group-item list-group-item-action list-group-item-primary"
|
||||||
|
aria-current="true" href="{% url 'Dashboard' %}"> Dashboard </a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
29
Templates/components/_sidebar_admin.html
Normal file
29
Templates/components/_sidebar_admin.html
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
{% if user.is_authenticated %}
|
||||||
|
{% if user.is_superuser %}
|
||||||
|
<div class="" >
|
||||||
|
<div class="list-group" >
|
||||||
|
{% if user.is_superuser %}
|
||||||
|
<a class="list-group-item list-group-item-action list-group-item-primary" aria-current="true"
|
||||||
|
href="{% url 'DashboardAdmin' %}"> Dashboard Admin </a> {% endif %}
|
||||||
|
{% if user.is_superuser %}
|
||||||
|
<a class="list-group-item list-group-item-action list-group-item-danger" aria-current="true"
|
||||||
|
href="{% url 'DashboardTest' %}"> Dashboard Test </a>{% endif %}
|
||||||
|
|
||||||
|
{% if perms.Base.view_bankaccount %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'BankAccountsListView' %}" > Banks </a> {% endif %}
|
||||||
|
{% if perms.Movement.view_paymentmethod %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'PaymentMethodListView' %}" > Metodos de Pag. </a>{% endif %}
|
||||||
|
{% if perms.Base.view_product %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'ProductListListView' %}" > Lista de Produtos </a> {% endif %}
|
||||||
|
{% if perms.Base.view_professional %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'ProfessionalListView' %}" > Professional </a> {% endif %}
|
||||||
|
{% if perms.Calendar.view_time %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'TimeListView' %}" > Horarios </a> {% endif %}
|
||||||
|
{% if perms.Base.view_service %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'ServiceListListView' %}" > Lista de Service </a> {% endif %}
|
||||||
|
{% if perms.Movement.view_expensemovementt %}
|
||||||
|
<a class="list-group-item list-group-item-action" href="{% url 'AccountListListView' %}" > Lista de Despesa </a> {% endif %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
{% endif %}
|
||||||
44
Templates/registration/login.html
Normal file
44
Templates/registration/login.html
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
{% extends 'Base.html' %}
|
||||||
|
{% block title %}Login{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<div class="container mt-5">
|
||||||
|
<div class="row justify-content-center">
|
||||||
|
<div class="col-md-6">
|
||||||
|
<div class="card">
|
||||||
|
<div class="card-body">
|
||||||
|
<h5 class="card-title text-center mb-4">Login</h5>
|
||||||
|
<form method="post">
|
||||||
|
{% csrf_token %}
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="username" class="form-label">Usuário</label>
|
||||||
|
<input type="text" class="form-control" id="username" name="username" required>
|
||||||
|
</div>
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="password" class="form-label">Senha</label>
|
||||||
|
<input type="password" class="form-control" id="password" name="password" required>
|
||||||
|
</div>
|
||||||
|
<div class="d-grid gap-2">
|
||||||
|
<button type="submit" class="btn btn-primary">Entrar</button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% if form.errors %}
|
||||||
|
<div class="alert alert-danger mt-4">
|
||||||
|
<ul class="mb-0">
|
||||||
|
{% for field in form %}
|
||||||
|
{% for error in field.errors %}
|
||||||
|
<li>{{ error }}</li>
|
||||||
|
{% endfor %}
|
||||||
|
{% endfor %}
|
||||||
|
{% for error in form.non_field_errors %}
|
||||||
|
<li>{{ error }}</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
||||||
BIN
db.sqlite3
Normal file
BIN
db.sqlite3
Normal file
Binary file not shown.
BIN
requirements_win.txt
Normal file
BIN
requirements_win.txt
Normal file
Binary file not shown.
Reference in New Issue
Block a user