feat: добавлено отображение Статуса, дедлайна и названия доски на Mainpage.js
fix: пофикшен Mainpage.css, в частности адаптивность и отображение всего что есть на странице
This commit is contained in:
@@ -25,7 +25,6 @@ const Mainpage = () => {
|
|||||||
setLoading(false);
|
setLoading(false);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
checkSession();
|
checkSession();
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
@@ -37,7 +36,10 @@ const Mainpage = () => {
|
|||||||
const day = String(d.getDate()).padStart(2, '0');
|
const day = String(d.getDate()).padStart(2, '0');
|
||||||
const month = String(d.getMonth() + 1).padStart(2, '0');
|
const month = String(d.getMonth() + 1).padStart(2, '0');
|
||||||
const year = d.getFullYear();
|
const year = d.getFullYear();
|
||||||
return `${day}.${month}.${year}`;
|
const hours = String(d.getHours()).padStart(2, '0');
|
||||||
|
const minutes = String(d.getMinutes()).padStart(2, '0');
|
||||||
|
// Формат: 01.04.2026 · 12:00
|
||||||
|
return `${day}.${month}.${year} ${hours}:${minutes}`;
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleTaskClick = (boardId) => {
|
const handleTaskClick = (boardId) => {
|
||||||
@@ -52,51 +54,57 @@ const Mainpage = () => {
|
|||||||
<div className="mainpage">
|
<div className="mainpage">
|
||||||
<div className="mainpage__intro">
|
<div className="mainpage__intro">
|
||||||
<div className="left-content">
|
<div className="left-content">
|
||||||
<h1>Kanban-доска Fool-Stack</h1>
|
<h1>Добро пожаловать в Kanban!</h1>
|
||||||
<p>
|
<p>
|
||||||
Kanban-доска помогает видеть весь процесс целиком: что запланировано, что уже в работе и что
|
Kanban-доска помогает видеть весь процесс целиком: что запланировано,
|
||||||
готово.
|
что уже в работе и что готово. Перетаскивайте карточки между колонками, фиксируйте договорённости и не теряйте контекст — всё в одном месте.
|
||||||
Перетаскивайте карточки между колонками, фиксируйте договорённости и не теряйте контекст —
|
|
||||||
всё в одном месте.
|
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="tasks-container">
|
<div className="tasks-container">
|
||||||
|
<h2 className="tasks-title">Мои задачи ({count})</h2>
|
||||||
{loading ? (
|
{loading ? (
|
||||||
<>
|
<p className="tasks-loading">Загрузка...</p>
|
||||||
<h3 className="tasks-title">Ваши задачи</h3>
|
|
||||||
<p>Загрузка...</p>
|
|
||||||
</>
|
|
||||||
) : isAuthenticated ? (
|
) : isAuthenticated ? (
|
||||||
<>
|
<>
|
||||||
<h3 className="tasks-title">Ваши задачи</h3>
|
{tasks.length === 0 ? (
|
||||||
{count === 0 ? (
|
<p className="tasks-empty">Нет задач</p>
|
||||||
<p>Нет задач</p>
|
|
||||||
) : (
|
) : (
|
||||||
<div
|
<ul className={`tasks-list${showScrollbar ? ' tasks-list--scroll' : ''}`}>
|
||||||
className={`tasks-list-wrapper ${showScrollbar ? 'scrollable' : ''}`}
|
|
||||||
>
|
|
||||||
<ul className="tasks-list">
|
|
||||||
{tasks.map((task) => (
|
{tasks.map((task) => (
|
||||||
<li
|
<li
|
||||||
key={task.id}
|
key={task.id}
|
||||||
className="task-item"
|
className="task-item"
|
||||||
onClick={() => handleTaskClick(task.board_id)}
|
onClick={() => handleTaskClick(task.board_id)}
|
||||||
>
|
>
|
||||||
<div><strong>{task.title}</strong></div>
|
<div className="task-item__title">{task.title}</div>
|
||||||
<div><strong>Доска:</strong> {task.board_title}</div>
|
|
||||||
<div><strong>Дедлайн:</strong> {formatDeadline(task.deadline)}</div>
|
{task.category_title && (
|
||||||
|
<div className="task-item__meta">
|
||||||
|
<span className="task-item__label">Статус:</span>
|
||||||
|
<span className="task-item__badge">{task.category_title}</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
|
||||||
|
{task.board_title && (
|
||||||
|
<div className="task-item__meta">
|
||||||
|
<span className="task-item__label">Доска:</span>
|
||||||
|
<span className="task-item__value task-item__value--truncate">{task.board_title}</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
|
||||||
|
<div className="task-item__meta">
|
||||||
|
<span className="task-item__label">Дедлайн:</span>
|
||||||
|
<span className={`task-item__value${!task.deadline ? ' task-item__value--muted' : ''}`}>
|
||||||
|
{formatDeadline(task.deadline)}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
) : (
|
) : (
|
||||||
<>
|
<p className="tasks-empty">Войдите, чтобы увидеть свои задачи.</p>
|
||||||
<h3 className="tasks-title">Ваши задачи</h3>
|
|
||||||
<p>Войдите, чтобы увидеть свои задачи.</p>
|
|
||||||
</>
|
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -106,4 +114,3 @@ const Mainpage = () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export default Mainpage;
|
export default Mainpage;
|
||||||
//TODO: проверка правильности отображения даты в отображении, приоритет задачи, отображение категории
|
|
||||||
@@ -1,120 +1,264 @@
|
|||||||
.mainpage {
|
.mainpage {
|
||||||
transition: all .4s ease;
|
transition: all .4s ease;
|
||||||
|
padding: 0 16px;
|
||||||
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ── Основной контейнер — два равных блока рядом ── */
|
||||||
.mainpage__intro {
|
.mainpage__intro {
|
||||||
background-color: #1f2430;
|
background-color: #1f2430;
|
||||||
border-radius: 6px;
|
border-radius: 8px;
|
||||||
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18);
|
||||||
padding: 20px;
|
padding: 28px;
|
||||||
margin: 10px auto;
|
margin: 16px auto;
|
||||||
max-width: 1200px;
|
max-width: 1200px;
|
||||||
display: flex;
|
display: flex;
|
||||||
gap: 20px;
|
gap: 24px;
|
||||||
align-items: flex-start; /* Выравнивание по верху */
|
align-items: stretch; /* оба блока одной высоты */
|
||||||
min-height: 300px; /* Минимальная высота для стабильности */
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ── Левый блок — описание ── */
|
||||||
.left-content {
|
.left-content {
|
||||||
flex: 1; /* Берет все доступное пространство */
|
flex: 1 1 0; /* равная база flex с tasks-container */
|
||||||
min-width: 0; /* Позволяет сжиматься меньше контента */
|
min-width: 0;
|
||||||
text-align: left;
|
|
||||||
background-color: #2b3245;
|
background-color: #2b3245;
|
||||||
border-radius: 6px;
|
border-radius: 8px;
|
||||||
padding: 20px;
|
padding: 28px 32px;
|
||||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
|
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
|
||||||
|
box-sizing: border-box;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.left-content h1 {
|
||||||
|
margin: 0 0 14px 0;
|
||||||
|
font-size: 1.45rem;
|
||||||
|
font-weight: 700;
|
||||||
|
color: #e2e8f0;
|
||||||
|
line-height: 1.3;
|
||||||
}
|
}
|
||||||
|
|
||||||
.left-content h1,
|
|
||||||
.left-content p,
|
.left-content p,
|
||||||
.left-content li {
|
.left-content li {
|
||||||
margin: 6px 0;
|
margin: 6px 0;
|
||||||
text-align: left;
|
font-size: 1rem;
|
||||||
|
line-height: 1.65;
|
||||||
color: #CAD1D8;
|
color: #CAD1D8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ── Правый блок — задачи ── */
|
||||||
.tasks-container {
|
.tasks-container {
|
||||||
flex: 0 0 400px; /* Фиксированная ширина справа */
|
flex: 1 1 0; /* равная база flex с left-content */
|
||||||
max-width: 400px; /* Дополнительная защита */
|
max-width: 480px;
|
||||||
background-color: #2b3245;
|
background-color: #2b3245;
|
||||||
border-radius: 6px;
|
border-radius: 8px;
|
||||||
padding: 10px;
|
padding: 24px 20px 20px;
|
||||||
height: fit-content;
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
|
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
|
||||||
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Остальной CSS без изменений */
|
|
||||||
.tasks-title {
|
.tasks-title {
|
||||||
margin: 0 0 15px 0;
|
margin: 0 0 16px 0;
|
||||||
color: #CAD1D8;
|
font-size: 1.15rem;
|
||||||
|
font-weight: 700;
|
||||||
|
color: #e2e8f0;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
position: sticky;
|
position: sticky;
|
||||||
top: 0;
|
top: 0;
|
||||||
z-index: 10;
|
z-index: 10;
|
||||||
background-color: #2b3245;
|
background-color: #2b3245;
|
||||||
|
padding-bottom: 4px;
|
||||||
|
border-bottom: 1px solid rgba(255,255,255,0.07);
|
||||||
|
}
|
||||||
|
|
||||||
|
.tasks-loading,
|
||||||
|
.tasks-empty {
|
||||||
|
color: #8892a4;
|
||||||
|
text-align: center;
|
||||||
|
padding: 28px 0;
|
||||||
|
font-size: 0.95rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tasks-list {
|
.tasks-list {
|
||||||
list-style-type: none;
|
list-style-type: none;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
max-height: 250px;
|
flex: 1;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tasks-list--scroll {
|
||||||
|
max-height: 360px;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
padding-right: 10px;
|
padding-right: 6px;
|
||||||
flex: 1; /* Занимает оставшееся пространство */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.tasks-list::-webkit-scrollbar {
|
.tasks-list::-webkit-scrollbar { width: 6px; }
|
||||||
width: 8px;
|
.tasks-list::-webkit-scrollbar-track { background: #2b3245; border-radius: 8px; }
|
||||||
}
|
.tasks-list::-webkit-scrollbar-thumb { background: #6b7a99; border-radius: 8px; }
|
||||||
|
.tasks-list::-webkit-scrollbar-thumb:hover { background: #8892a4; }
|
||||||
.tasks-list::-webkit-scrollbar-track {
|
|
||||||
background: #2b3245;
|
|
||||||
border-radius: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.tasks-list::-webkit-scrollbar-thumb {
|
|
||||||
background: #aaa;
|
|
||||||
border-radius: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.tasks-list::-webkit-scrollbar-thumb:hover {
|
|
||||||
background: #888;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
/* ── Карточка задачи ── */
|
||||||
.task-item {
|
.task-item {
|
||||||
background-color: #3d4763;
|
background-color: #3d4763;
|
||||||
margin-bottom: 8px;
|
padding: 14px 16px;
|
||||||
padding: 4px 12px;
|
border-radius: 10px;
|
||||||
border-radius: 8px;
|
|
||||||
color: #CAD1D8;
|
color: #CAD1D8;
|
||||||
flex: 1;
|
|
||||||
text-align: left;
|
text-align: left;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
transition: all 0.3s ease;
|
transition: background-color 0.25s ease, transform 0.2s ease, box-shadow 0.2s ease;
|
||||||
|
min-width: 0;
|
||||||
|
box-sizing: border-box;
|
||||||
|
border: 1px solid rgba(255,255,255,0.05);
|
||||||
}
|
}
|
||||||
|
|
||||||
.task-item:hover {
|
.task-item:hover {
|
||||||
background-color: #4a587e;
|
background-color: #4a587e;
|
||||||
transform: translateY(-1px);
|
transform: translateY(-2px);
|
||||||
|
box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
|
||||||
}
|
}
|
||||||
|
|
||||||
.task-item:last-child {
|
.task-item:last-child { margin-bottom: 0; }
|
||||||
margin-bottom: 0;
|
|
||||||
|
/* Название задачи */
|
||||||
|
.task-item__title {
|
||||||
|
font-weight: 700;
|
||||||
|
font-size: 1.05rem;
|
||||||
|
color: #CAD1D8;
|
||||||
|
margin-bottom: 8px;
|
||||||
|
word-break: break-word;
|
||||||
|
line-height: 1.35;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Адаптивность для мобильных */
|
/* Строка метаданных */
|
||||||
@media (max-width: 768px) {
|
.task-item__meta {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 8px;
|
||||||
|
margin-top: 6px;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
min-width: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Лейбл — подчёркивание + засветка + капс */
|
||||||
|
.task-item__label {
|
||||||
|
font-size: 0.87rem;
|
||||||
|
font-weight: 700;
|
||||||
|
color: #CAD1D8;
|
||||||
|
white-space: nowrap;
|
||||||
|
flex-shrink: 0;
|
||||||
|
text-transform: uppercase;
|
||||||
|
letter-spacing: 0.08em;
|
||||||
|
background: rgba(202, 209, 216, 0.07);
|
||||||
|
padding: 1px 5px;
|
||||||
|
border-radius: 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Значение — нормальный регистр, чуть приглушённее */
|
||||||
|
.task-item__value {
|
||||||
|
font-size: 0.87rem;
|
||||||
|
font-weight: 400;
|
||||||
|
color: #CAD1D8;
|
||||||
|
word-break: break-word;
|
||||||
|
min-width: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.task-item__value--truncate {
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
max-width: 220px;
|
||||||
|
display: inline-block;
|
||||||
|
vertical-align: bottom;
|
||||||
|
}
|
||||||
|
|
||||||
|
.task-item__value--muted {
|
||||||
|
color: #CAD1D8;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Бейдж статуса */
|
||||||
|
.task-item__badge {
|
||||||
|
display: inline-block;
|
||||||
|
font-size: 0.78rem;
|
||||||
|
font-weight: 500;
|
||||||
|
padding: 2px 10px;
|
||||||
|
border-radius: 9999px;
|
||||||
|
background-color: rgba(74, 88, 126, 0.6);
|
||||||
|
color: #CAD1D8;
|
||||||
|
border: 1px solid rgba(168, 192, 232, 0.18);
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ── Планшет (< 960px) ── */
|
||||||
|
@media (max-width: 960px) {
|
||||||
.mainpage__intro {
|
.mainpage__intro {
|
||||||
flex-direction: column;
|
padding: 20px;
|
||||||
gap: 15px;
|
gap: 18px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tasks-container {
|
.tasks-container {
|
||||||
flex: none;
|
max-width: 380px;
|
||||||
max-width: none;
|
}
|
||||||
|
|
||||||
|
.task-item__value--truncate {
|
||||||
|
max-width: 160px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ── Мобильный (< 768px) ── */
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.mainpage {
|
||||||
|
padding: 0 8px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mainpage__intro {
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: stretch;
|
||||||
|
gap: 14px;
|
||||||
|
padding: 14px;
|
||||||
|
margin: 8px auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.left-content {
|
||||||
|
padding: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.tasks-container {
|
||||||
|
max-width: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tasks-list--scroll {
|
||||||
|
max-height: 300px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.task-item__value--truncate {
|
||||||
|
max-width: none;
|
||||||
|
white-space: normal;
|
||||||
|
overflow: visible;
|
||||||
|
text-overflow: unset;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ── Очень маленькие экраны (< 400px) ── */
|
||||||
|
@media (max-width: 400px) {
|
||||||
|
.mainpage__intro {
|
||||||
|
padding: 10px;
|
||||||
|
border-radius: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.task-item {
|
||||||
|
padding: 10px 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.task-item__title {
|
||||||
|
font-size: 0.98rem;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user