ваше сообщение коммита

This commit is contained in:
2025-04-28 22:54:47 +03:00
parent 5e062c8d9b
commit 3734bea350
13 changed files with 2746 additions and 2122 deletions

View File

@@ -316,24 +316,9 @@ input, textarea {
top: 0;
left: 0;
right: 0;
bottom: 205px;
transition: bottom var(--transition-normal);
}
/* Адаптация позиции при активации фокуса */
.chat-container:has(.chat-input.focused) .chat-messages {
bottom: 305px;
}
/* Реализуем программное изменение позиции через JS для браузеров без поддержки :has */
@media (max-width: 100vw) {
/* Примечание: Этот блок @media может потребовать обновления в JS коде, */
/* если он используется для имитации :has. Сейчас изменяем только CSS. */
.chat-input.focused ~ .messages-container {
bottom: 305px;
}
}
/* Стили для сообщений */
.message {
margin-bottom: var(--spacing-md);
@@ -421,8 +406,7 @@ input, textarea {
.chat-input {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
padding: var(--spacing-md) var(--spacing-lg);
padding: var(--spacing-sm) var(--spacing-md);
background: var(--color-white);
border-radius: var(--radius-lg);
border: 1px solid var(--color-grey-light);
@@ -430,73 +414,193 @@ input, textarea {
left: 0;
right: 0;
bottom: 0;
height: auto;
min-height: var(--chat-input-min-height);
max-height: var(--chat-input-max-height);
transition: min-height var(--transition-normal), padding var(--transition-normal);
transition: all var(--transition-normal);
z-index: 10;
box-shadow: none;
box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.05);
}
/* Стиль для input при фокусе */
.chat-input.focused {
min-height: var(--chat-input-focus-min-height);
max-height: var(--chat-input-focus-max-height);
padding: var(--spacing-lg);
box-shadow: var(--shadow-md);
.input-area {
display: flex;
align-items: flex-end;
gap: var(--spacing-sm);
}
.chat-input textarea {
flex: 1;
padding: var(--spacing-sm);
border: 1px solid var(--color-grey-light);
border-radius: var(--radius-sm);
border: none;
resize: none;
font-size: var(--font-size-md);
line-height: 1.5;
min-height: 40px;
transition: min-height var(--transition-normal), border-color var(--transition-normal);
min-height: 24px;
max-height: 120px; /* Ограничение высоты textarea */
padding: 8px 0; /* Уменьшаем вертикальные отступы */
outline: none;
overflow-y: hidden; /* Убираем скролл, так как высота меняется динамически */
height: auto; /* Позволяем высоте изменяться */
}
.chat-input textarea:focus {
outline: none;
border-color: var(--color-primary);
}
.chat-input.focused textarea {
min-height: 120px;
/* Контейнер для иконок */
.chat-icons {
display: flex;
gap: 6px;
flex-wrap: nowrap;
align-items: center;
}
.chat-input button {
padding: 0 var(--spacing-lg);
background: var(--color-primary);
color: var(--color-white);
/* Стили для кнопок-иконок */
.chat-icon-btn {
width: 36px;
height: 36px;
border-radius: 50%;
background: transparent;
border: none;
border-radius: var(--radius-sm);
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
font-size: var(--font-size-md);
transition: background-color var(--transition-normal);
transition: all var(--transition-fast);
color: var(--color-grey);
padding: 0;
position: relative;
}
.chat-input button:hover:not(:disabled) {
background: var(--color-primary-dark);
.chat-icon-btn:hover {
color: var(--color-primary);
background-color: rgba(0, 0, 0, 0.05);
}
.chat-input button:disabled {
background: #ccc;
.chat-icon-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
/* Стили для кнопки отправки */
.chat-icon-btn.send-button {
background-color: var(--color-primary);
color: white;
width: 36px;
height: 36px;
}
.chat-icon-btn.send-button:hover:not(:disabled) {
background-color: var(--color-primary-dark);
color: white;
transform: scale(1.05);
}
.chat-icon-btn.send-button:disabled {
background-color: #ccc;
opacity: 0.7;
}
/* Стили для состояния записи */
.chat-icon-btn.recording {
color: var(--color-danger);
animation: pulse 1.5s infinite;
}
.chat-icon-btn.recording::after {
content: '';
position: absolute;
width: 8px;
height: 8px;
background-color: var(--color-danger);
border-radius: 50%;
top: 2px;
right: 2px;
}
@keyframes pulse {
0% {
transform: scale(1);
}
50% {
transform: scale(1.1);
}
100% {
transform: scale(1);
}
}
/* Стили для области предпросмотра */
.attachment-preview {
display: flex;
flex-wrap: wrap;
gap: 8px;
margin-top: 8px;
padding-top: 8px;
border-top: 1px solid var(--color-grey-light);
max-height: 100px; /* Ограничение высоты области превью */
overflow-y: auto; /* Скролл для превью */
}
.preview-item {
position: relative;
display: flex;
align-items: center;
background-color: var(--color-light);
border-radius: var(--radius-md);
padding: 4px 8px;
font-size: var(--font-size-sm);
}
.image-preview {
width: 40px;
height: 40px;
object-fit: cover;
border-radius: var(--radius-sm);
margin-right: 8px;
}
.audio-preview,
.video-preview,
.file-preview {
display: flex;
align-items: center;
gap: 5px;
}
.remove-attachment-btn {
position: absolute;
top: -5px;
right: -5px;
width: 18px;
height: 18px;
background-color: rgba(0, 0, 0, 0.6);
color: white;
border: none;
border-radius: 50%;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
font-size: 12px;
line-height: 1;
padding: 0;
}
/* Новый контейнер для действий чата */
.chat-actions {
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
}
/* Стили для кнопок в чате */
.chat-buttons {
display: flex;
gap: var(--spacing-sm);
margin-top: var(--spacing-xs);
padding-bottom: 0;
width: 100%;
justify-content: flex-end;
flex-wrap: nowrap;
box-sizing: border-box;
align-items: center;
}
.chat-buttons button {
@@ -511,15 +615,6 @@ input, textarea {
max-width: 150px;
overflow: hidden;
text-overflow: ellipsis;
}
.chat-buttons button:first-child {
background-color: var(--color-primary);
color: var(--color-white);
}
.chat-buttons button:first-child:hover:not(:disabled) {
background-color: var(--color-primary-dark);
}
.chat-buttons .clear-btn {
@@ -1095,7 +1190,6 @@ input, textarea {
}
.chat-input textarea {
padding: var(--spacing-sm);
font-size: var(--font-size-md);
}
@@ -1148,7 +1242,7 @@ input, textarea {
}
.disconnect-block {
padding: var(--spacing-sm) 0;
margin-bottom: var(--spacing-sm);
}
.wallet-header {