feat(i18n): integrate i18next for internationalization support and add initial translation setup
This commit is contained in:
File diff suppressed because it is too large
Load Diff
294
frontend/src/pages/optimizer.css
Normal file
294
frontend/src/pages/optimizer.css
Normal file
@@ -0,0 +1,294 @@
|
||||
.optimizer-set-panel {
|
||||
background: linear-gradient(180deg, #1f2c49 0%, #1a233b 100%);
|
||||
border: 1px solid rgba(255, 255, 255, 0.08);
|
||||
border-radius: 10px;
|
||||
padding: 6px;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 6px;
|
||||
}
|
||||
|
||||
.optimizer-panel-header {
|
||||
background: linear-gradient(90deg, rgba(120, 160, 220, 0.25), rgba(120, 160, 220, 0));
|
||||
color: #c9d7f7;
|
||||
font-weight: 600;
|
||||
font-size: 12px;
|
||||
padding: 4px 6px;
|
||||
border-radius: 6px;
|
||||
letter-spacing: 0.5px;
|
||||
}
|
||||
|
||||
.optimizer-set-row {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
background: rgba(6, 10, 20, 0.55);
|
||||
border: 1px solid rgba(255, 255, 255, 0.08);
|
||||
border-radius: 8px;
|
||||
padding: 6px;
|
||||
}
|
||||
|
||||
.optimizer-set-row-tight {
|
||||
padding: 6px 8px;
|
||||
}
|
||||
|
||||
.optimizer-set-badge {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
min-width: 34px;
|
||||
height: 26px;
|
||||
border-radius: 6px;
|
||||
background: #ffffff;
|
||||
color: #1b2744;
|
||||
font-weight: 600;
|
||||
font-size: 11px;
|
||||
}
|
||||
|
||||
.optimizer-set-select {
|
||||
flex: 1;
|
||||
}
|
||||
|
||||
.optimizer-set-select-tight .ant-select-selector {
|
||||
padding-left: 6px !important;
|
||||
}
|
||||
|
||||
.optimizer-set-select-tight .ant-select-selection-placeholder {
|
||||
color: #c9d7f7 !important;
|
||||
opacity: 0.9;
|
||||
}
|
||||
|
||||
.optimizer-set-button {
|
||||
flex: 1;
|
||||
height: 28px;
|
||||
background: transparent;
|
||||
border: none;
|
||||
color: #c9d7f7;
|
||||
text-align: left;
|
||||
padding: 0 4px;
|
||||
}
|
||||
|
||||
.optimizer-set-button:disabled {
|
||||
color: rgba(201, 215, 247, 0.4);
|
||||
}
|
||||
|
||||
.optimizer-set-popover-overlay {
|
||||
position: fixed;
|
||||
inset: 0;
|
||||
background: transparent;
|
||||
z-index: 1000;
|
||||
}
|
||||
|
||||
.optimizer-set-popover {
|
||||
position: fixed;
|
||||
width: 520px;
|
||||
background: #0b0f16;
|
||||
border-radius: 12px;
|
||||
padding: 0;
|
||||
box-shadow: 0 18px 40px rgba(0, 0, 0, 0.45);
|
||||
}
|
||||
|
||||
.optimizer-main-popover {
|
||||
position: fixed;
|
||||
width: 300px;
|
||||
background: #0b0f16;
|
||||
border-radius: 12px;
|
||||
padding: 0;
|
||||
box-shadow: 0 16px 32px rgba(0, 0, 0, 0.45);
|
||||
}
|
||||
|
||||
.optimizer-set-modal-list {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
gap: 8px 12px;
|
||||
padding: 12px 16px 16px 16px;
|
||||
max-height: 520px;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.optimizer-main-modal-list {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr;
|
||||
gap: 6px;
|
||||
padding: 10px 12px 12px 12px;
|
||||
max-height: 320px;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.optimizer-main-modal-list .optimizer-set-modal-item {
|
||||
padding: 6px 8px;
|
||||
gap: 6px;
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.optimizer-main-modal-list .optimizer-set-modal-label {
|
||||
font-size: 14px;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.optimizer-main-modal-list .optimizer-set-modal-icon {
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.optimizer-set-modal-item {
|
||||
display: grid;
|
||||
grid-template-columns: 20px 1fr auto;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
background: #0f131b;
|
||||
border: 1px solid rgba(255, 255, 255, 0.08);
|
||||
border-radius: 8px;
|
||||
padding: 8px 10px;
|
||||
color: #c9d7f7;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.optimizer-set-modal-item:hover {
|
||||
border-color: rgba(123, 180, 255, 0.6);
|
||||
}
|
||||
|
||||
.optimizer-set-modal-icon {
|
||||
color: #7bb4ff;
|
||||
}
|
||||
|
||||
.optimizer-set-modal-count {
|
||||
color: #7ad15f;
|
||||
font-weight: 600;
|
||||
}
|
||||
.optimizer-set-select .ant-select-selector {
|
||||
background: transparent !important;
|
||||
border: none !important;
|
||||
box-shadow: none !important;
|
||||
padding: 0 !important;
|
||||
min-height: 26px !important;
|
||||
}
|
||||
|
||||
.optimizer-set-select .ant-select-selection-item,
|
||||
.optimizer-set-select .ant-select-selection-placeholder {
|
||||
color: #c9d7f7 !important;
|
||||
}
|
||||
|
||||
.optimizer-set-select .ant-select-selection-overflow {
|
||||
gap: 6px;
|
||||
}
|
||||
|
||||
.optimizer-set-select .ant-select-selection-item-content {
|
||||
color: #c9d7f7;
|
||||
}
|
||||
|
||||
.optimizer-set-select .ant-select-selection-item-remove {
|
||||
color: #9fb3e5;
|
||||
}
|
||||
|
||||
.optimizer-weight-row {
|
||||
display: grid;
|
||||
grid-template-columns: 38px 1fr;
|
||||
align-items: center;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.optimizer-weight-label {
|
||||
color: #c9d7f7;
|
||||
font-size: 11px;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.optimizer-left-panels {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 8px;
|
||||
}
|
||||
|
||||
.optimizer-side-panel {
|
||||
display: flex;
|
||||
gap: 8px;
|
||||
align-items: flex-start;
|
||||
}
|
||||
|
||||
.optimizer-left-panels {
|
||||
flex: 1;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
.optimizer-weight-panel {
|
||||
flex: 1;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
.optimizer-weight-panel {
|
||||
background: linear-gradient(180deg, #1f2c49 0%, #1a233b 100%);
|
||||
border: 1px solid rgba(255, 255, 255, 0.08);
|
||||
border-radius: 10px;
|
||||
padding: 6px;
|
||||
align-self: flex-start;
|
||||
height: fit-content;
|
||||
}
|
||||
|
||||
.optimizer-weight-row {
|
||||
display: grid;
|
||||
grid-template-columns: 20px 34px 1fr;
|
||||
align-items: center;
|
||||
gap: 8px;
|
||||
margin-bottom: 6px;
|
||||
}
|
||||
|
||||
.optimizer-weight-row:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
|
||||
.optimizer-weight-row .ant-slider {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.optimizer-weight-icon {
|
||||
width: 18px;
|
||||
height: 18px;
|
||||
border-radius: 50%;
|
||||
background: rgba(255, 255, 255, 0.12);
|
||||
color: #c9d7f7;
|
||||
font-size: 11px;
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.optimizer-weight-label {
|
||||
color: #c9d7f7;
|
||||
font-size: 12px;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.optimizer-weight-slider .ant-slider-rail {
|
||||
background: repeating-linear-gradient(
|
||||
to right,
|
||||
rgba(255, 255, 255, 0.25),
|
||||
rgba(255, 255, 255, 0.25) 2px,
|
||||
rgba(255, 255, 255, 0) 14px,
|
||||
rgba(255, 255, 255, 0) 18px
|
||||
);
|
||||
height: 4px;
|
||||
}
|
||||
|
||||
.optimizer-weight-slider .ant-slider-track {
|
||||
background-color: #7bb4ff;
|
||||
height: 4px;
|
||||
}
|
||||
|
||||
.optimizer-weight-slider .ant-slider-handle {
|
||||
width: 12px;
|
||||
height: 12px;
|
||||
margin-top: -4px;
|
||||
border-color: #7bb4ff;
|
||||
}
|
||||
.optimizer-weight-row .ant-slider-rail {
|
||||
background-color: rgba(255, 255, 255, 0.15);
|
||||
}
|
||||
|
||||
.optimizer-weight-row .ant-slider-track {
|
||||
background-color: #6aa9ff;
|
||||
}
|
||||
|
||||
.optimizer-weight-row .ant-slider-handle {
|
||||
border-color: #6aa9ff;
|
||||
background-color: #ffffff;
|
||||
}
|
||||
Reference in New Issue
Block a user