Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
Empty file added src/author/__init__.py
Empty file.
24 changes: 24 additions & 0 deletions src/author/admin.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
"""
Функции панели управления для приложения "Автор".
"""

from django.contrib import admin
from author.models import Author


@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
list_display = (
"cv_link",
"github_link",
"email",
"created_at",
"updated_at",
)

search_fields = ("email", "github_link")

list_filter = (
"created_at",
"updated_at",
)
7 changes: 7 additions & 0 deletions src/author/apps.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
from django.apps import AppConfig


class AuthorConfig(AppConfig):
default_auto_field = "django.db.models.BigAutoField"
name = "author"
verbose_name = "Автор"
9 changes: 9 additions & 0 deletions src/author/context_processors.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
from django.http import HttpRequest
from author.models import Author


def author(request: HttpRequest) -> dict:
"""
Контекстный процессор для информации об авторе
"""
return {"author": Author.objects.last()}
49 changes: 49 additions & 0 deletions src/author/migrations/0001_initial.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
# Generated by Django 4.1.13 on 2024-03-16 14:46

from django.db import migrations, models


class Migration(migrations.Migration):

initial = True

dependencies = []

operations = [
migrations.CreateModel(
name="Author",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
(
"created_at",
models.DateTimeField(
auto_now_add=True, verbose_name="Время создания записи"
),
),
(
"updated_at",
models.DateTimeField(
auto_now=True, verbose_name="Время обновления записи"
),
),
("cv_link", models.URLField(verbose_name="Ссылка на резюме")),
("github_link", models.URLField(verbose_name="Ссылка на GitHub")),
(
"email",
models.EmailField(max_length=254, verbose_name="Почтовый адрес"),
),
],
options={
"verbose_name": "Автор",
"verbose_name_plural": "Авторы",
},
),
]
Empty file.
19 changes: 19 additions & 0 deletions src/author/models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
from django.db import models
from base.models import TimeStampMixin


class Author(TimeStampMixin):
"""
Модель для хранения информации об авторе.
"""

cv_link = models.URLField(verbose_name="Ссылка на резюме")
github_link = models.URLField(verbose_name="Ссылка на GitHub")
email = models.EmailField(verbose_name="Почтовый адрес")

class Meta:
verbose_name = "Автор"
verbose_name_plural = "Авторы"

def __str__(self) -> str:
return f'Объект "автор" (id={self.pk})'
1 change: 1 addition & 0 deletions src/author/tests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Create your tests here.
1 change: 1 addition & 0 deletions src/author/views.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Create your views here.
23 changes: 23 additions & 0 deletions src/jobs/migrations/0002_job_full_description.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Generated by Django 4.1.13 on 2024-03-16 11:05

import ckeditor_uploader.fields
from django.db import migrations


class Migration(migrations.Migration):

dependencies = [
("jobs", "0001_initial"),
]

operations = [
migrations.AddField(
model_name="job",
name="full_description",
field=ckeditor_uploader.fields.RichTextUploadingField(
default="Подробное описание",
help_text="Подробное описание выполненной работы",
verbose_name="Подробное описание работы",
),
),
]
15 changes: 15 additions & 0 deletions src/jobs/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

from django.db import models

from ckeditor_uploader.fields import RichTextUploadingField
from base.models import TimeStampMixin


Expand All @@ -22,10 +23,24 @@ class Job(TimeStampMixin):
verbose_name="Описание",
help_text="Краткое описание выполненной работы",
)
full_description = RichTextUploadingField(
verbose_name="Подробное описание работы",
help_text="Подробное описание выполненной работы",
default="Подробное описание",
)

class Meta:
verbose_name = "Выполненная работа"
verbose_name_plural = "Выполненные работы"

def __str__(self) -> str:
return f'Объект "Выполненная работа" (id={self.pk})'

def summary(self) -> str:
"""
Краткое содержание выполненной работы.

:return:
"""

return self.full_description[:100] + "..."
8 changes: 4 additions & 4 deletions src/jobs/templates/jobs/job_detail.html
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,10 @@
{% block content %}

<div class="container">
<h1 class="text-center pt-3 display-4">{{ blog.title }}</h1>
<p class="text-center">{{ blog.pub_date }}</p>
<p><img src="{{ blog.image.url }}" class="img-fluid" alt="{{ blog.title }}"></p>
<p>{{ blog.content }}</p>
<h1 class="text-center pt-3 display-4">{{ job.description }}</h1>
<p class="text-center">{{ job.pub_date }}</p>
<p><img src="{{ job.image.url }}" class="img-fluid" alt="{{ job.description }}"></p>
<p>{{ job.full_description|safe }}</p>
<a href="{% url 'blogs' %}" class="btn btn-light" role="button">Вернуться в блог</a>
</div>

Expand Down
10 changes: 6 additions & 4 deletions src/jobs/templates/jobs/job_list.html
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@
<div class="row py-lg-5">
<div class="col-lg-6 col-md-8 mx-auto">
<p class="fw-light h1">Привет!</p>
<p class="lead text-muted">Меня зовут Иван Иванов. <br />Я профессионально занимаюсь разработкой на Python.</p>
<p class="lead text-muted">Меня зовут Данил. <br />Я профессионально занимаюсь разработкой на Python.</p>
<p>
<img src="{% static 'images/my_photo.jpeg' %}" height="300" alt="Иван Иванов"/>
<img src="{% static 'images/my_photo.jpeg' %}" height="300" alt="Данил"/>
</p>
<p>
<a href="mailto:username(att)somemailserver(dott)com" class="btn btn-primary my-2">Написать мне</a>
Expand All @@ -33,10 +33,12 @@
alt="job image"/>

<div class="card-body">
<p class="card-text">{{ job.description }}</p>
<p class="card-text"><strong>{{ job.description }}</strong></p>
<p class="card-text text-muted">{{ job.summary|safe }}</p>
<div class="d-flex justify-content-between align-items-center">
<div class="btn-group">
<a href="#" type="button" class="btn btn-sm btn-outline-secondary">Подробнее</a>
<a href="{% url 'job' job.id %}" type="button"
class="btn btn-sm btn-outline-secondary">Подробнее</a>
</div>
<small class="text-muted"><p>{{ job.created_at|date:"d E Y" }}</p></small>
</div>
Expand Down
35 changes: 35 additions & 0 deletions src/jobs/tests.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
from django.test import TestCase

from jobs.models import Job


class JobTestCase(TestCase):
"""
Тестирование функций выполненных работ.
"""

def setUp(self) -> None:
"""
Настройка перед тестированием.

:return:
"""

Job.objects.create(
image="Job №1 image path",
description="Job №1 description",
full_description="Job №1 full description. " * 100,
)

def test_job_creation(self) -> None:
"""
Тестирование моделей сообщений для выполненной работы.

:return:
"""

job = Job.objects.get(description="Job №1 description")

content = "Job №1 full description. " * 100
self.assertEqual(job.summary(), content[:100] + "...")
self.assertEqual(str(job), f'Объект "Выполненная работа" (id={job.pk})')
7 changes: 7 additions & 0 deletions src/jobs/urls.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
from django.urls import path

from jobs.views import IndexJobsDetailView

urlpatterns = [
path("<int:pk>/", IndexJobsDetailView.as_view(), name="job"),
]
6 changes: 5 additions & 1 deletion src/jobs/views.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
from django.views.generic import ListView
from django.views.generic import ListView, DetailView

from jobs.models import Job


class IndexJobsListView(ListView):
model = Job


class IndexJobsDetailView(DetailView):
model = Job
2 changes: 2 additions & 0 deletions src/portfolio/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@
# созданные приложения
"jobs.apps.JobsConfig",
"blog.apps.BlogConfig",
"author.apps.AuthorConfig",
# установленные приложения
"ckeditor",
"ckeditor_uploader",
Expand Down Expand Up @@ -73,6 +74,7 @@
"django.template.context_processors.request",
"django.contrib.auth.context_processors.auth",
"django.contrib.messages.context_processors.messages",
"author.context_processors.author",
],
},
},
Expand Down
6 changes: 3 additions & 3 deletions src/portfolio/templates/base.html
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,9 @@ <h4 class="text-white">Обо мне</h4>
<div class="col-sm-4 offset-md-1 py-4">
<h4 class="text-white">Мои контакты</h4>
<ul class="list-unstyled">
<li><a href="#" class="text-white">Резюме</a></li>
<li><a href="https://github.com" target="_blank" class="text-white">GitHub</a></li>
<li><a href="mailto:username(att)somemailserver(dott)com" class="text-white">Email</a></li>
<li><a href="{{ author.cv_link }}" class="text-white">Резюме</a></li>
<li><a href="{{ author.github_link }}" target="_blank" class="text-white">GitHub</a></li>
<li><a href="mailto:{{ author.email }}" class="text-white">Email</a></li>
</ul>
</div>
</div>
Expand Down
1 change: 1 addition & 0 deletions src/portfolio/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,5 +29,6 @@
path("ckeditor/", include("ckeditor_uploader.urls")),
path("", IndexJobsListView.as_view(), name="home"),
path("blog/", include("blog.urls")),
path("jobs/", include("jobs.urls")),
]
urlpatterns.extend(static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT))