Skip to content
Merged
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
Original file line number Diff line number Diff line change
Expand Up @@ -471,28 +471,7 @@ const WorkspaceItem: React.FC<WorkspaceItemProps> = ({
<Plus size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.newSession')}</span>
</button>
{isDefaultAssistantWorkspace && (
<button
type="button"
className="bitfun-nav-panel__workspace-item-menu-item is-danger"
onClick={handleRequestResetWorkspace}
disabled={isResettingWorkspace}
>
<RotateCcw size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.resetWorkspace')}</span>
</button>
)}
{isNamedAssistantWorkspace && (
<button
type="button"
className="bitfun-nav-panel__workspace-item-menu-item is-danger"
onClick={handleRequestDeleteAssistant}
disabled={isDeletingAssistant}
>
<Trash2 size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.deleteAssistant')}</span>
</button>
)}
<div className="bitfun-nav-panel__workspace-item-menu-divider" />
<button
type="button"
className="bitfun-nav-panel__workspace-item-menu-item"
Expand All @@ -511,6 +490,33 @@ const WorkspaceItem: React.FC<WorkspaceItemProps> = ({
<FolderSearch size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.reveal')}</span>
</button>
{(isDefaultAssistantWorkspace || isNamedAssistantWorkspace) ? (
<>
<div className="bitfun-nav-panel__workspace-item-menu-divider" />
{isDefaultAssistantWorkspace ? (
<button
type="button"
className="bitfun-nav-panel__workspace-item-menu-item is-danger"
onClick={handleRequestResetWorkspace}
disabled={isResettingWorkspace}
>
<RotateCcw size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.resetWorkspace')}</span>
</button>
) : null}
{isNamedAssistantWorkspace ? (
<button
type="button"
className="bitfun-nav-panel__workspace-item-menu-item is-danger"
onClick={handleRequestDeleteAssistant}
disabled={isDeletingAssistant}
>
<Trash2 size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.deleteAssistant')}</span>
</button>
) : null}
</>
) : null}
</div>,
document.body
)}
Expand Down Expand Up @@ -649,6 +655,7 @@ const WorkspaceItem: React.FC<WorkspaceItemProps> = ({
<FileText size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.initAgents')}</span>
</button>
<div className="bitfun-nav-panel__workspace-item-menu-divider" />
{isLinkedWorktree ? (
<button
type="button"
Expand Down Expand Up @@ -691,6 +698,7 @@ const WorkspaceItem: React.FC<WorkspaceItemProps> = ({
<FolderSearch size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.reveal')}</span>
</button>
<div className="bitfun-nav-panel__workspace-item-menu-divider" />
<button type="button" className="bitfun-nav-panel__workspace-item-menu-item is-danger" onClick={() => { void handleCloseWorkspace(); }}>
<FolderOpen size={13} />
<span className="bitfun-nav-panel__workspace-item-menu-label">{t('nav.workspaces.actions.close')}</span>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -91,16 +91,25 @@
}

&.is-active {
background: transparent;
border-color: transparent;
background: color-mix(
in srgb,
var(--color-accent-500) 9%,
color-mix(in srgb, var(--element-bg-soft) 68%, transparent)
);
border-color: color-mix(in srgb, var(--border-subtle) 45%, transparent);
}

&.is-single {
background: transparent;
border-color: transparent;

&.is-active {
background: transparent;
background: color-mix(
in srgb,
var(--color-accent-500) 9%,
color-mix(in srgb, var(--element-bg-soft) 68%, transparent)
);
border-color: color-mix(in srgb, var(--border-subtle) 45%, transparent);
}
}

Expand Down Expand Up @@ -462,6 +471,13 @@
animation: bitfun-footer-menu-in $motion-fast $easing-decelerate forwards;
}

/* Match `.bitfun-nav-panel__footer-menu-divider` (PersistentFooterActions more menu) */
&__workspace-item-menu-divider {
height: 1px;
margin: $size-gap-1 $size-gap-2;
background: var(--border-subtle, rgba(255, 255, 255, 0.08));
}

&__workspace-item-menu-item {
display: flex;
align-items: center;
Expand Down Expand Up @@ -594,8 +610,12 @@
}

&.is-active {
background: transparent;
border-color: transparent;
background: color-mix(
in srgb,
var(--color-accent-500) 9%,
color-mix(in srgb, var(--element-bg-soft) 68%, transparent)
);
border-color: color-mix(in srgb, var(--border-subtle) 45%, transparent);
}

&:not(.is-active):not(:hover):not(:focus-within):not(.is-menu-open) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,23 +26,36 @@
align-self: stretch;
}

&__ui-segment-block {
width: 100%;
min-width: 0;
}

&__level-buttons {
display: flex;
flex-wrap: nowrap;
flex-wrap: wrap;
align-items: center;
gap: $size-gap-2;
flex-shrink: 0;
width: 100%;
min-width: 0;
}

&__ui-control-row {
display: flex;
align-items: center;
gap: $size-gap-3;
/* 第六档「自定义」与右侧步进器保持同一行,整组可随前置按钮换行 */
&__custom-segment-inline {
display: inline-flex;
flex-wrap: nowrap;
width: 100%;
align-items: center;
gap: $size-gap-2;
min-width: 0;
overflow-x: auto;
scrollbar-width: thin;
padding-bottom: 2px;
}

&__custom-controls {
display: inline-flex;
flex-wrap: nowrap;
align-items: center;
gap: $size-gap-2;
flex-shrink: 0;
box-sizing: border-box;
}

&__flow-chat {
Expand Down Expand Up @@ -115,6 +128,7 @@
align-items: center;
justify-content: center;
min-height: 36px;
min-width: 0;
padding: $size-gap-2 $size-gap-3;
font-size: var(--font-size-sm);
font-family: var(--font-sans, var(--font-family-sans));
Expand Down Expand Up @@ -156,75 +170,6 @@
color: inherit;
}

&__custom-row {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: $size-gap-2;

&--capsule {
flex-wrap: nowrap;
margin-left: auto;
align-items: center;
gap: $size-gap-2;
padding: 4px 4px 4px $size-gap-3;
border: 1px solid var(--border-strong);
border-radius: 999px;
background: var(--bg-secondary);
box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

&--active {
.font-pref-panel__custom-label {
color: var(--text-primary);
}
}

&--capsule.font-pref-panel__custom-row--active {
@include btn-primary.btn-primary-surface-default;
border-color: var(--btn-primary-border, transparent);
box-shadow: var(--btn-primary-shadow, none);

.font-pref-panel__custom-label,
.font-pref-panel__custom-unit {
color: var(--btn-primary-color, var(--text-primary));
opacity: 0.95;
}

.font-pref-panel__stepper {
border-color: color-mix(in srgb, var(--btn-primary-color, #fff) 22%, transparent);
}

.font-pref-panel__step-btn {
color: var(--btn-primary-color, var(--text-primary));

&:hover:not(:disabled) {
background: color-mix(in srgb, var(--btn-primary-color, #fff) 14%, transparent);
color: var(--btn-primary-color, var(--text-primary));
}
}

.font-pref-panel__number-input {
background: color-mix(in srgb, var(--btn-primary-bg, #000) 12%, transparent);
color: var(--btn-primary-color, var(--text-primary));
border-left-color: color-mix(in srgb, var(--btn-primary-color, #fff) 22%, transparent);
border-right-color: color-mix(in srgb, var(--btn-primary-color, #fff) 22%, transparent);
}

.font-pref-panel__number-input--readonly {
background: color-mix(in srgb, var(--btn-primary-color, #fff) 8%, transparent);
color: var(--btn-primary-color, var(--text-primary));
opacity: 0.92;
}
}
}

&__custom-label {
font-size: var(--font-size-sm);
color: var(--text-secondary);
flex-shrink: 0;
}

&__stepper {
display: flex;
align-items: center;
Expand All @@ -242,8 +187,9 @@
}

&__custom-unit {
font-size: var(--font-size-xs);
color: var(--text-muted);
font-size: var(--font-size-sm);
color: var(--text-secondary);
flex-shrink: 0;
}

&__step-btn {
Expand Down Expand Up @@ -304,12 +250,6 @@
cursor: not-allowed;
}

&--readonly {
background: var(--bg-secondary);
color: var(--text-secondary);
cursor: pointer;
}

&--error {
border-left-color: var(--color-semantic-error);
border-right-color: var(--color-semantic-error);
Expand Down
Loading
Loading