feat: added bot, light and dark mode

This commit was merged in pull request #1.
This commit is contained in:
2026-04-22 10:22:22 +02:00
parent e83ec814d9
commit 2de003e497
36 changed files with 2047 additions and 498 deletions
@@ -0,0 +1,63 @@
.input-card {
background: var(--color-bg-card);
border: var(--border-width) solid var(--color-border);
border-radius: var(--border-radius-md);
padding: var(--size-lg-padding);
display: flex;
flex-direction: column;
gap: var(--size-lg-gap);
}
.move-card {
padding: var(--size-sm-padding);
gap: var(--size-sm-gap);
}
.move-card input {
min-height: 45px;
padding: var(--size-md-padding);
}
.input-card label {
color: var(--color-text-primary);
font-weight: 700;
margin-bottom: var(--size-xs);
}
.input-card textarea {
resize: vertical;
height: 40px;
background-color:lightcyan;
border: 3px solid var(--color-border);
border-radius: var(--border-radius-sm);
}
.input-card input {
min-width: unset;
background-color:lightcyan;
border: 3px solid var(--color-border);
border-radius: var(--border-radius-sm);
}
.input-card .btn {
border: var(--button-border);
border-radius: var(--border-radius-sm);
background: var(--color-bg-button);
color: var(--color-text-primary);
padding: var(--button-padding);
cursor: pointer;
font-weight: 600;
transition: background-color 0.2s, color 0.2s;
}
.input-card .btn:hover {
background: var(--color-bg-button-hover);
color: var(--color-text-button-hover);
}
.hint-text {
margin: 0;
color: var(--color-text-primary);
font-size: 0.9rem;
}
@@ -0,0 +1,31 @@
<section [ngClass]="['input-card', cardClass]">
<label>{{ label }}</label>
@if (inputType === 'textarea') {
<textarea
#textareaInput
[placeholder]="placeholder"
[value]="value"
[rows]="rows"
(input)="onValueChange(textareaInput.value)"
class="form-input"
></textarea>
} @else {
<input
#textInput
type="text"
[placeholder]="placeholder"
[value]="value"
(input)="onValueChange(textInput.value)"
class="form-input"
/>
}
<button type="button" class="btn w-100" (click)="onButtonClick()">
{{ buttonLabel }}
</button>
@if (hintText) {
<p class="hint-text">{{ hintText }}</p>
}
</section>
@@ -0,0 +1,33 @@
import { Component, Input, Output, EventEmitter } from '@angular/core';
import { CommonModule } from '@angular/common';
import { FormsModule } from '@angular/forms';
@Component({
selector: 'app-input-card',
standalone: true,
imports: [CommonModule, FormsModule],
templateUrl: './input-card.component.html',
styleUrl: './input-card.component.css',
})
export class InputCardComponent {
@Input() label: string = '';
@Input() placeholder: string = '';
@Input() buttonLabel: string = 'Send';
@Input() inputType: 'input' | 'textarea' = 'input';
@Input() value: string = '';
@Input() cardClass: string = '';
@Input() hintText: string = '';
@Input() rows: number = 4;
@Output() valueChange = new EventEmitter<string>();
@Output() buttonClick = new EventEmitter<void>();
onValueChange(newValue: string): void {
this.value = newValue;
this.valueChange.emit(newValue);
}
onButtonClick(): void {
this.buttonClick.emit();
}
}