Files
kanban-elements-ui/src/components/kb-toolbar/kb-toolbar.component.scss
Giuliano Silvestro c7fe04e8e3 Initial commit: kanban-elements-ui library
Angular 19 component library for kanban boards:
- kb-board: main board with toolbar, swimlanes, and pipeline view
- kb-column: columns with WIP limits, collapse, and drag reorder
- kb-card: draggable cards with labels, assignees, and priorities
- kb-swimlane: horizontal grouping with collapsible rows
- kb-toolbar: search, sort, filter, and view toggle
- kb-quick-add: inline card creation
- kb-wip-indicator: WIP limit status display
- kb-card-def / kb-column-header-def: custom template directives

Includes signal-based services (board, drag, filter), SCSS design
tokens with dark mode, and full TypeScript type definitions.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-13 21:54:33 +10:00

176 lines
3.6 KiB
SCSS

:host {
display: block;
}
.kb-toolbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
padding: var(--kb-toolbar-padding);
background: var(--kb-glass-bg);
backdrop-filter: blur(var(--kb-glass-blur));
-webkit-backdrop-filter: blur(var(--kb-glass-blur));
border: 1px solid var(--kb-glass-border);
border-bottom: 1px solid var(--kb-toolbar-border);
border-radius: var(--kb-column-radius) var(--kb-column-radius) 0 0;
}
.kb-toolbar__search {
display: flex;
align-items: center;
gap: 0.5rem;
flex: 1;
max-width: 320px;
padding: 0.375rem 0.75rem;
background: var(--kb-bg);
border: 1px solid var(--kb-toolbar-border);
border-radius: 999px;
transition: border-color 200ms var(--kb-ease-smooth), box-shadow 200ms var(--kb-ease-smooth);
&:focus-within {
border-color: var(--kb-drop-zone-border);
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
}
.kb-toolbar__search-icon {
display: inline-flex;
color: var(--kb-card-meta-color);
flex-shrink: 0;
svg {
width: 0.875rem;
height: 0.875rem;
}
}
.kb-toolbar__search-input {
flex: 1;
border: none;
background: transparent;
color: var(--kb-card-title-color);
font-size: var(--font-size-sm, 0.875rem);
outline: none;
&::placeholder {
color: var(--kb-quick-add-text);
}
}
.kb-toolbar__actions {
display: flex;
align-items: center;
gap: 0.5rem;
}
.kb-toolbar__btn {
padding: 0.375rem 0.875rem;
border: 1px solid var(--kb-toolbar-border);
border-radius: 999px;
background: transparent;
color: var(--kb-card-desc-color);
font-size: var(--font-size-sm, 0.875rem);
cursor: pointer;
transition: all 200ms var(--kb-ease-smooth);
&:hover {
background: var(--kb-quick-add-hover-bg);
color: var(--kb-card-title-color);
}
&--active {
background: var(--color-primary-50, #eff6ff);
color: var(--color-primary-500, #3b82f6);
border-color: var(--color-primary-500, #3b82f6);
}
}
.kb-toolbar__btn-icon {
display: inline-flex;
align-items: center;
gap: 0.375rem;
svg {
width: 0.875rem;
height: 0.875rem;
}
}
.kb-toolbar__sort {
position: relative;
}
.kb-toolbar__sort-menu {
position: absolute;
top: calc(100% + 0.375rem);
right: 0;
z-index: 10;
min-width: 180px;
background: var(--kb-card-bg);
border: 1px solid var(--kb-card-border);
border-radius: var(--kb-card-radius);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
overflow: hidden;
animation: kb-slide-down 150ms var(--kb-ease-spring);
}
@keyframes kb-slide-down {
from {
opacity: 0;
transform: translateY(-4px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.kb-toolbar__sort-option {
display: flex;
align-items: center;
justify-content: space-between;
width: 100%;
padding: 0.5rem 0.75rem;
border: none;
background: transparent;
color: var(--kb-card-title-color);
font-size: var(--font-size-sm, 0.875rem);
cursor: pointer;
text-align: left;
transition: background var(--kb-transition);
&:hover {
background: var(--kb-quick-add-hover-bg);
}
&--active {
color: var(--color-primary-500, #3b82f6);
font-weight: 500;
}
}
.kb-toolbar__sort-dir {
display: inline-flex;
svg {
width: 0.625rem;
height: 0.625rem;
}
}
.kb-toolbar__filter-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 1.25rem;
height: 1.25rem;
padding: 0 0.25rem;
border-radius: 999px;
background: var(--color-primary-500, #3b82f6);
color: #fff;
font-size: 0.625rem;
font-weight: 600;
font-variant-numeric: tabular-nums;
}