Compare commits

...

7 Commits

18 changed files with 2124 additions and 1532 deletions

30
.editorconfig Normal file
View File

@@ -0,0 +1,30 @@
# EditorConfig helps maintain consistent coding styles across all files
# https://editorconfig.org
root = true
# Unix-style newlines, UTF-8 encoding for all files
[*]
end_of_line = lf
charset = utf-8
insert_final_newline = true
trim_trailing_whitespace = true
# Python: 4 spaces (PEP 8)
[*.py]
indent_style = space
indent_size = 4
# JavaScript/JSON/YAML: 2 spaces (common web standard)
[*.{js,json,yml,yaml}]
indent_style = space
indent_size = 2
# HTML/CSS: 2 spaces
[*.{html,css}]
indent_style = space
indent_size = 2
# Markdown: preserve formatting
[*.md]
trim_trailing_whitespace = false

2
.gitignore vendored
View File

@@ -8,6 +8,8 @@ releases/*/kx-bridge
releases/*/extract_credentials releases/*/extract_credentials
releases/*/extract_credentials.exe releases/*/extract_credentials.exe
node_modules/*
!kx-bridge.spec !kx-bridge.spec
# Laufzeit-Daten und Drucker-Credentials — nie committen # Laufzeit-Daten und Drucker-Credentials — nie committen

View File

@@ -1 +1 @@
0.9.26 0.9.27-nightly1

View File

@@ -13,6 +13,7 @@ _BASE = pathlib.Path(sys.executable).parent if getattr(sys, "frozen", False) els
CONFIG_SECTION_CONNECTION = "connection" CONFIG_SECTION_CONNECTION = "connection"
CONFIG_SECTION_PRINT = "print" CONFIG_SECTION_PRINT = "print"
CONFIG_SECTION_BRIDGE = "bridge" CONFIG_SECTION_BRIDGE = "bridge"
CONFIG_SECTION_SPOOLMAN = "spoolman"
def _find_config_file() -> pathlib.Path | None: def _find_config_file() -> pathlib.Path | None:
@@ -63,6 +64,8 @@ def _load_config_file(path: pathlib.Path):
"WEB_UPLOAD_WARNING": (CONFIG_SECTION_PRINT, "web_upload_warning"), "WEB_UPLOAD_WARNING": (CONFIG_SECTION_PRINT, "web_upload_warning"),
"PRINT_START_DIALOG": (CONFIG_SECTION_PRINT, "print_start_dialog"), "PRINT_START_DIALOG": (CONFIG_SECTION_PRINT, "print_start_dialog"),
"BRIDGE_PRINTER_NAME": (CONFIG_SECTION_BRIDGE, "printer_name"), "BRIDGE_PRINTER_NAME": (CONFIG_SECTION_BRIDGE, "printer_name"),
"SPOOLMAN_SERVER": (CONFIG_SECTION_SPOOLMAN, "server"),
"SPOOLMAN_SYNC_RATE": (CONFIG_SECTION_SPOOLMAN, "sync_rate"),
} }
for env_key, (section, option) in mapping.items(): for env_key, (section, option) in mapping.items():
if env_key not in os.environ: if env_key not in os.environ:
@@ -317,3 +320,5 @@ AUTO_LEVELING = int(get("AUTO_LEVELING","1"))
CAMERA_ON_PRINT = int(get("CAMERA_ON_PRINT","0")) CAMERA_ON_PRINT = int(get("CAMERA_ON_PRINT","0"))
WEB_UPLOAD_WARNING = int(get("WEB_UPLOAD_WARNING", "1")) WEB_UPLOAD_WARNING = int(get("WEB_UPLOAD_WARNING", "1"))
PRINT_START_DIALOG = int(get("PRINT_START_DIALOG", get("FILE_READY_DIALOG", "1"))) PRINT_START_DIALOG = int(get("PRINT_START_DIALOG", get("FILE_READY_DIALOG", "1")))
SPOOLMAN_SERVER = get("SPOOLMAN_SERVER", "")
SPOOLMAN_SYNC_RATE = int(get("SPOOLMAN_SYNC_RATE", "0"))

View File

@@ -0,0 +1,3 @@
services:
kx-bridge:
image: gitea.it-drui.de/viewit/kx-bridge:nightly

View File

@@ -0,0 +1,25 @@
# KX-Bridge Nightly — Portainer Stack
#
# Paste this into Portainer → Stacks → Add stack → Web editor
#
# Uses the nightly build — may be unstable, for testing new features early.
# For production use, see docker-compose.portainer.yml (:latest).
services:
kx-bridge:
image: gitea.it-drui.de/viewit/kx-bridge:nightly
volumes:
- /mnt/dockerdata/kx-nightly/config:/app/config
- /mnt/dockerdata/kx-nightly/data:/app/data
ports:
# Port 7125 = first printer. Add 7126, 7127, … for each additional printer.
- "7125:7125"
restart: unless-stopped
logging:
driver: json-file
options:
max-size: "10m"
max-file: "3"
# Verzeichnisse müssen auf dem Host existieren:
# mkdir -p /mnt/dockerdata/kx-nightly/config /mnt/dockerdata/kx-nightly/data

View File

@@ -733,6 +733,40 @@ class CameraCache:
await asyncio.sleep(2.0) await asyncio.sleep(2.0)
class SpoolmanClient:
"""Thin synchronous HTTP client for Spoolman filament tracking.
Designed to be called from daemon threads (poll loop, _on_print callbacks).
Uses requests (already in requirements) so no event-loop dependency.
"""
def __init__(self, server_url: str, sync_rate: int = 0):
self.server_url = server_url.rstrip("/")
self.sync_rate = sync_rate
def _req(self, method: str, path: str, **kwargs):
import requests
r = requests.request(method, f"{self.server_url}{path}", timeout=5, **kwargs)
r.raise_for_status()
return r.json()
def health_check(self) -> bool:
try:
self._req("GET", "/api/v1/health")
return True
except Exception:
return False
def list_spools(self) -> list:
return self._req("GET", "/api/v1/spool")
def use_filament(self, spool_id: int, use_length_mm: float) -> None:
"""Report consumed filament length in mm. Spoolman converts to weight
using the spool's filament profile density."""
self._req("PUT", f"/api/v1/spool/{spool_id}/use",
json={"use_length": round(use_length_mm, 2)})
class KobraXBridge: class KobraXBridge:
def __init__(self, client: KobraXClient, args=None, store=None, printer_id: str = "1", all_bridges=None): def __init__(self, client: KobraXClient, args=None, store=None, printer_id: str = "1", all_bridges=None):
self.client = client self.client = client
@@ -793,6 +827,7 @@ class KobraXBridge:
"file_ready": "", "file_ready": "",
"print_start_dialog": getattr(args, "print_start_dialog", 1), "print_start_dialog": getattr(args, "print_start_dialog", 1),
"filament_mode": "toolhead", "filament_mode": "toolhead",
"supplies_usage": 0,
"ace_drying": {"status": 0, "target_temp": 0, "duration": 0, "remain_time": 0, "humidity": None, "current_temp": None}, "ace_drying": {"status": 0, "target_temp": 0, "duration": 0, "remain_time": 0, "humidity": None, "current_temp": None},
} }
self._ams_slots: list[dict] = [] # flat global list; each entry has global_index + box_id self._ams_slots: list[dict] = [] # flat global list; each entry has global_index + box_id
@@ -819,6 +854,18 @@ class KobraXBridge:
self._pending_preprint_skip: list[str] = [] self._pending_preprint_skip: list[str] = []
self._pending_preprint_skip_deadline: float = 0.0 self._pending_preprint_skip_deadline: float = 0.0
# Spoolman filament tracking
_sm_url = (getattr(args, "spoolman_server", "") or "").strip()
self._spoolman: SpoolmanClient | None = (
SpoolmanClient(_sm_url, getattr(args, "spoolman_sync_rate", 0))
if _sm_url else None
)
self._spoolman_slot_spools: dict[int, int] = {} # {ams_slot_idx: spoolman_spool_id}
self._spoolman_slot_usage: dict[int, float] = {} # per-slot accumulated mm this print
self._spoolman_slot_reported: dict[int, float] = {} # per-slot mm already sent to Spoolman
self._spoolman_last_usage: float = 0.0 # supplies_usage at last attribution tick
self._spoolman_last_sync: float = 0.0
# Theme-Name prüfen (keine Sonderzeichen oder Umlaute) # Theme-Name prüfen (keine Sonderzeichen oder Umlaute)
raw_theme = (getattr(args, "ui_theme", None) or "default").strip() raw_theme = (getattr(args, "ui_theme", None) or "default").strip()
if not _UI_THEME_NAME_RE.match(raw_theme): if not _UI_THEME_NAME_RE.match(raw_theme):
@@ -837,6 +884,139 @@ class KobraXBridge:
client.callbacks["light/report"] = self._on_light client.callbacks["light/report"] = self._on_light
client.callbacks["skip/report"] = self._on_skip client.callbacks["skip/report"] = self._on_skip
if self._spoolman:
threading.Thread(
target=lambda: log.info(
f"Spoolman: {'OK' if self._spoolman.health_check() else 'unreachable'} "
f"at {self._spoolman.server_url}"
),
daemon=True, name="spoolman-health",
).start()
# ── Spoolman helpers ──────────────────────────────────────────────────────
def _spoolman_filament_mm(self) -> float:
"""Total filament_used_mm for the current print file from the GCode DB."""
filename = self._state.get("filename", "")
if not filename:
return 0.0
try:
gf = self._store.get_file_by_name(filename)
return float(gf.get("filament_used_mm") or 0.0) if gf else 0.0
except Exception:
return 0.0
def _spoolman_attribute_tick(self, activity_map: dict) -> None:
"""Attribute the supplies_usage delta since last tick to the active slot.
Skips attribution during loading/unloading transitions (tool changes +
purges) to avoid charging the wrong spool for purge material."""
if not self._spoolman or not self._spoolman_slot_spools:
return
if self._state.get("print_state") != "printing":
return
current = self._state.get("supplies_usage", 0)
delta = current - self._spoolman_last_usage
self._spoolman_last_usage = current
if delta <= 0:
return
loaded = self._ams_loaded_slot
if loaded < 0:
return
if activity_map.get(loaded):
return
self._spoolman_slot_usage[loaded] = self._spoolman_slot_usage.get(loaded, 0.0) + delta
def _spoolman_unreported(self) -> dict[int, float]:
"""Return {slot_idx: mm} of usage not yet reported to Spoolman.
Falls back to equal split of total supplies_usage when per-slot
attribution data is absent (e.g. single-extruder with no AMS)."""
total_used = self._state.get("supplies_usage", 0)
if self._spoolman_slot_usage:
return {
slot: self._spoolman_slot_usage.get(slot, 0.0)
- self._spoolman_slot_reported.get(slot, 0.0)
for slot in self._spoolman_slot_spools
}
n = len(self._spoolman_slot_spools)
already = sum(self._spoolman_slot_reported.values())
per = (total_used - already) / n if n else 0.0
return {slot: per for slot in self._spoolman_slot_spools}
def _spoolman_report(self, unreported: dict[int, float], min_mm: float = 0.1) -> None:
"""Fire-and-forget report of unreported mm to each mapped spool."""
sm = self._spoolman
for slot_idx, mm in unreported.items():
if mm < min_mm:
continue
spool_id = self._spoolman_slot_spools.get(slot_idx)
if not spool_id:
continue
self._spoolman_slot_reported[slot_idx] = (
self._spoolman_slot_reported.get(slot_idx, 0.0) + mm
)
def _send(sid=spool_id, length=mm):
try:
sm.use_filament(sid, length)
log.info(f"Spoolman: {length:.1f} mm → spool {sid}")
except Exception as e:
log.warning(f"Spoolman: report failed (spool {sid}): {e}")
threading.Thread(target=_send, daemon=True, name="spoolman-report").start()
def _spoolman_notify_end(self):
"""Report remaining filament on print end."""
if not self._spoolman or not self._spoolman_slot_spools:
return
self._spoolman_report(self._spoolman_unreported())
def _spoolman_sync_midprint(self):
"""Report incremental filament usage during a print (sync_rate interval)."""
if not self._spoolman or not self._spoolman_slot_spools:
return
self._spoolman_report(self._spoolman_unreported(), min_mm=10.0)
# ── Spoolman API handlers ─────────────────────────────────────────────────
async def handle_kx_spoolman_status(self, request):
"""GET /kx/spoolman/status"""
return self._json_cors({
"configured": bool(self._spoolman),
"server": self._spoolman.server_url if self._spoolman else "",
"sync_rate": self._spoolman.sync_rate if self._spoolman else 0,
"slot_spools": {str(k): v for k, v in self._spoolman_slot_spools.items()},
})
async def handle_kx_spoolman_spools(self, request):
"""GET /kx/spoolman/spools — proxied from Spoolman."""
if not self._spoolman:
return self._json_cors({"error": "Spoolman not configured"}, status=503)
try:
spools = await asyncio.get_event_loop().run_in_executor(
None, self._spoolman.list_spools
)
return self._json_cors({"spools": spools})
except Exception as e:
log.warning(f"Spoolman: list_spools failed: {e}")
return self._json_cors({"error": str(e)}, status=502)
async def handle_kx_spoolman_set_active(self, request):
"""POST /kx/spoolman/active-spool
Body: {"slot_map": {"0": 42, "2": 17}} — AMS slot index → Spoolman spool ID."""
try:
data = await request.json()
except Exception:
return self._json_cors({"error": "invalid JSON"}, status=400)
slot_map = data.get("slot_map") or {}
self._spoolman_slot_spools = {
int(k): int(v) for k, v in slot_map.items()
if str(v).isdigit() and int(v) > 0
}
self._spoolman_slot_usage = {}
self._spoolman_slot_reported = {}
self._spoolman_last_usage = 0.0
return self._json_cors({"slot_spools": {str(k): v for k, v in self._spoolman_slot_spools.items()}})
def _default_ace_dry_presets(self) -> dict[str, dict]: def _default_ace_dry_presets(self) -> dict[str, dict]:
return { return {
"pla": {"temp": 45, "duration_sec": 4 * 3600}, "pla": {"temp": 45, "duration_sec": 4 * 3600},
@@ -951,15 +1131,21 @@ class KobraXBridge:
printer_id=self._printer_id, printer_id=self._printer_id,
) )
log.info(f"Job started: {self._current_job_id} for {filename}") log.info(f"Job started: {self._current_job_id} for {filename}")
self._spoolman_slot_usage = {}
self._spoolman_slot_reported = {}
self._spoolman_last_usage = 0.0
self._spoolman_last_sync = 0.0
# Job-History: Druckende erkennen # Job-History: Druckende erkennen
if kobra_state in ("finished",) and self._current_job_id: if kobra_state in ("finished",) and self._current_job_id:
self._store.finish_job(self._current_job_id, status="completed") self._store.finish_job(self._current_job_id, status="completed")
log.info(f"Job abgeschlossen: {self._current_job_id}") log.info(f"Job abgeschlossen: {self._current_job_id}")
self._spoolman_notify_end()
self._current_job_id = "" self._current_job_id = ""
elif kobra_state in ("stoped", "canceled") and self._current_job_id: elif kobra_state in ("stoped", "canceled") and self._current_job_id:
self._store.finish_job(self._current_job_id, status="cancelled") self._store.finish_job(self._current_job_id, status="cancelled")
log.info(f"Job abgebrochen: {self._current_job_id}") log.info(f"Job abgebrochen: {self._current_job_id}")
self._spoolman_notify_end()
self._current_job_id = "" self._current_job_id = ""
# Nach Druckende das Upload-Banner verschwinden lassen (Issue #29): der # Nach Druckende das Upload-Banner verschwinden lassen (Issue #29): der
@@ -976,6 +1162,7 @@ class KobraXBridge:
self._state["slicer_time"] = 0 self._state["slicer_time"] = 0
self._state["layer_height"] = 0.0 self._state["layer_height"] = 0.0
self._state["first_layer_height"] = 0.0 self._state["first_layer_height"] = 0.0
self._state["supplies_usage"] = 0
self._thumbnail_b64 = "" self._thumbnail_b64 = ""
self._state["filename"] = d.get("filename", self._state["filename"]) self._state["filename"] = d.get("filename", self._state["filename"])
if "progress" in d: if "progress" in d:
@@ -990,6 +1177,8 @@ class KobraXBridge:
self._state["total_layers"] = d["total_layers"] self._state["total_layers"] = d["total_layers"]
if "taskid" in d: if "taskid" in d:
self._state["taskid"] = str(d["taskid"]) self._state["taskid"] = str(d["taskid"])
if "supplies_usage" in d:
self._state["supplies_usage"] = int(d["supplies_usage"])
settings = d.get("settings") or {} settings = d.get("settings") or {}
if "print_speed_mode" in settings: if "print_speed_mode" in settings:
self._state["print_speed_mode"] = int(settings["print_speed_mode"]) self._state["print_speed_mode"] = int(settings["print_speed_mode"])
@@ -2967,10 +3156,10 @@ class KobraXBridge:
if not file_data: if not file_data:
return web.json_response({"error": "no file received"}, status=400) return web.json_response({"error": "no file received"}, status=400)
# Nur druckbare Dateien zulassen (Issue #59) — verhindert dass z.B. ein # Nur druckbare Dateien zulassen (Issue #59) — der Kobra X akzeptiert
# JPG im File-Browser landet. OrcaSlicer-Uploads sind .gcode/.gcode.3mf, # ausschließlich .gcode und .bgcode; .3mf-Uploads werden vom Drucker
# der Kobra X akzeptiert .gcode/.3mf/.bgcode. # nicht verarbeitet und daher abgelehnt (Issue #59, @gangoke).
_allowed_ext = (".gcode", ".gcode.3mf", ".3mf", ".bgcode") _allowed_ext = (".gcode", ".bgcode")
_fn_lower = (remote_filename or "").lower() _fn_lower = (remote_filename or "").lower()
if not _fn_lower.endswith(_allowed_ext): if not _fn_lower.endswith(_allowed_ext):
log.warning(f"Upload abgelehnt (kein GCode): {remote_filename}") log.warning(f"Upload abgelehnt (kein GCode): {remote_filename}")
@@ -4804,6 +4993,14 @@ class KobraXBridge:
print_r = self.client.publish("print", "query", timeout=3.0) print_r = self.client.publish("print", "query", timeout=3.0)
if print_r: if print_r:
self._on_print(print_r) self._on_print(print_r)
# Spoolman mid-print sync
if (self._spoolman and self._spoolman.sync_rate > 0
and self._spoolman_slot_spools
and self._state.get("print_state") == "printing"):
now = time.time()
if now - self._spoolman_last_sync >= self._spoolman.sync_rate:
self._spoolman_sync_midprint()
self._spoolman_last_sync = now
box = self.client.query_multicolor_box() box = self.client.query_multicolor_box()
if box: if box:
data = box.get("data") or {} data = box.get("data") or {}
@@ -4820,6 +5017,10 @@ class KobraXBridge:
if global_slots: if global_slots:
self._ams_slots = global_slots self._ams_slots = global_slots
self._ams_loaded_slot = global_loaded self._ams_loaded_slot = global_loaded
self._spoolman_attribute_tick(activity_map)
else:
# No multiColorBox data — still attribute (no transitions to skip)
self._spoolman_attribute_tick({})
except Exception as e: except Exception as e:
log.warning(f"Poll-Fehler: {e}") log.warning(f"Poll-Fehler: {e}")
# Prüfen ob Drucker wirklich weg ist # Prüfen ob Drucker wirklich weg ist
@@ -4954,6 +5155,9 @@ def build_app(bridge: KobraXBridge) -> web.Application:
r.add_post("/kx/skip", bridge.handle_kx_skip) r.add_post("/kx/skip", bridge.handle_kx_skip)
r.add_post("/kx/skip/query", bridge.handle_kx_skip_query) r.add_post("/kx/skip/query", bridge.handle_kx_skip_query)
r.add_get("/kx/skip/state", bridge.handle_kx_skip_state) r.add_get("/kx/skip/state", bridge.handle_kx_skip_state)
r.add_get("/kx/spoolman/status", bridge.handle_kx_spoolman_status)
r.add_get("/kx/spoolman/spools", bridge.handle_kx_spoolman_spools)
r.add_post("/kx/spoolman/active-spool", bridge.handle_kx_spoolman_set_active)
r.add_route("OPTIONS", "/kx/{path:.*}", bridge.handle_kx_options) r.add_route("OPTIONS", "/kx/{path:.*}", bridge.handle_kx_options)
# Root + Printer-Routen (Single-Page, JS liest Pathname) # Root + Printer-Routen (Single-Page, JS liest Pathname)
@@ -5119,6 +5323,10 @@ def main():
parser.add_argument("--web-upload-warning", type=int, default=env_loader.WEB_UPLOAD_WARNING) parser.add_argument("--web-upload-warning", type=int, default=env_loader.WEB_UPLOAD_WARNING)
parser.add_argument("--print-start-dialog", dest="print_start_dialog", type=int, default=env_loader.PRINT_START_DIALOG) parser.add_argument("--print-start-dialog", dest="print_start_dialog", type=int, default=env_loader.PRINT_START_DIALOG)
parser.add_argument("--file-ready-dialog", dest="print_start_dialog", type=int) parser.add_argument("--file-ready-dialog", dest="print_start_dialog", type=int)
parser.add_argument("--spoolman-server", default=env_loader.SPOOLMAN_SERVER,
help="Spoolman URL (e.g. http://192.168.x.x:7912); leave empty to disable")
parser.add_argument("--spoolman-sync-rate", type=int, default=env_loader.SPOOLMAN_SYNC_RATE,
help="Mid-print filament sync interval in seconds (0 = only on print end)")
parser.add_argument("--host", default="0.0.0.0", parser.add_argument("--host", default="0.0.0.0",
help="Bind-Adresse für den Bridge-Server") help="Bind-Adresse für den Bridge-Server")

31
package-lock.json generated Normal file
View File

@@ -0,0 +1,31 @@
{
"name": "kx-bridge",
"version": "0.9.27",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "kx-bridge",
"version": "0.9.27",
"devDependencies": {
"prettier": "^3.0.0"
}
},
"node_modules/prettier": {
"version": "3.8.4",
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.8.4.tgz",
"integrity": "sha512-N2MylSdi48+5N/6S5j+maeHbUSIzzZ5uOcX5Hm4QpV8Dkb1HFjfAKTKX6yNPJQD9AhcT3ifHNB66tWTTJDi11Q==",
"dev": true,
"license": "MIT",
"bin": {
"prettier": "bin/prettier.cjs"
},
"engines": {
"node": ">=14"
},
"funding": {
"url": "https://github.com/prettier/prettier?sponsor=1"
}
}
}
}

23
package.json Normal file
View File

@@ -0,0 +1,23 @@
{
"name": "kx-bridge",
"version": "0.9.27",
"description": "Moonraker-compatible bridge for Anycubic Kobra X",
"type": "module",
"devDependencies": {
"prettier": "^3.0.0"
},
"scripts": {
"format:js": "prettier --write 'web/**/*.js' '*.js'",
"format:json": "prettier --write '*.json' 'web/**/*.json'",
"format:web": "prettier --write 'web/**/*.{js,json,html,css,yml,yaml,md}'",
"format": "npm run format:web"
},
"prettier": {
"semi": true,
"singleQuote": false,
"trailingComma": "es5",
"printWidth": 100,
"tabWidth": 2,
"useTabs": false
}
}

2
requirements-dev.txt Normal file
View File

@@ -0,0 +1,2 @@
# Code formatting
black>=24.1.0

View File

@@ -44,6 +44,62 @@ var ACE_DRY_PRESETS={
custom_3:{name:'Custom 3',temp:45,duration_sec:4*3600} custom_3:{name:'Custom 3',temp:45,duration_sec:4*3600}
}; };
// Spoolman state
var _spoolmanStatus={configured:false,server:'',sync_rate:0,slot_spools:{}};
var _spoolmanSpools=[];
var _slotSpoolMap={}; // {String(global_index): spoolman_spool_id} — last committed assignment
function _loadSpoolmanStatus(){
fetch(_apiUrl('/kx/spoolman/status')).then(function(r){return r.json();}).then(function(d){
_spoolmanStatus=d;
_slotSpoolMap=d.slot_spools||{};
}).catch(function(){});
}
function _buildSpoolmanSection(){
var sec=document.getElementById('fd-spoolman-section');
var rows=document.getElementById('fd-spoolman-rows');
var loading=document.getElementById('fd-spoolman-loading');
if(!sec||!rows)return;
if(!_spoolmanStatus.configured){sec.style.display='none';return;}
sec.style.display='';
rows.innerHTML='';
if(loading)loading.style.display='';
var usedSlots={};
document.querySelectorAll('#fd-slots select').forEach(function(sel){
var idx=parseInt(sel.value);
if(idx>=0){
var slot=(_amsSlots||[]).find(function(s){return s.slot_index===idx;});
if(slot&&!usedSlots[idx])usedSlots[idx]=slot;
}
});
fetch(_apiUrl('/kx/spoolman/spools')).then(function(r){return r.json();}).then(function(d){
if(loading)loading.style.display='none';
_spoolmanSpools=d.spools||[];
var slotKeys=Object.keys(usedSlots).map(Number).sort(function(a,b){return a-b;});
if(!slotKeys.length){rows.innerHTML='<span style="font-size:11px;color:var(--txt2)"></span>';return;}
rows.innerHTML=slotKeys.map(function(idx){
var slot=usedSlots[idx];
var col=(slot.color_hex||'#888');
var currentSpool=_slotSpoolMap[String(idx)]||'';
var opts='<option value=""></option>'+_spoolmanSpools.map(function(sp){
var rem=sp.remaining_weight!=null?' ('+sp.remaining_weight.toFixed(0)+'g)':'';
var vendor=sp.filament&&sp.filament.vendor?sp.filament.vendor+' ':'';
var name=sp.filament&&sp.filament.name?sp.filament.name:'Spool';
return '<option value="'+sp.id+'"'+(sp.id==currentSpool?' selected':'')+'>'+
escHtml('#'+sp.id+' '+vendor+name+rem)+'</option>';
}).join('');
return '<div style="display:flex;align-items:center;gap:8px;font-size:12px">'+
'<span style="display:inline-block;width:14px;height:14px;border-radius:50%;background:'+col+';border:1px solid var(--border);flex-shrink:0"></span>'+
'<span style="color:var(--txt2);min-width:46px">Slot '+(idx+1)+'</span>'+
'<select data-spool-slot="'+idx+'" style="flex:1;padding:3px 6px;border-radius:6px;border:1px solid var(--border);background:var(--raised);color:var(--txt);font-size:12px">'+
opts+'</select></div>';
}).join('');
}).catch(function(){if(loading)loading.style.display='none';});
}
function _aceAutoRefillGet(aceId){return !!aceAutoRefillPrefs[String(aceId)];} function _aceAutoRefillGet(aceId){return !!aceAutoRefillPrefs[String(aceId)];}
function _aceAutoRefillSet(aceId,on){ function _aceAutoRefillSet(aceId,on){
aceAutoRefillPrefs[String(aceId)]=!!on; aceAutoRefillPrefs[String(aceId)]=!!on;
@@ -2494,6 +2550,7 @@ function openFilamentDialog(slots){
_amsSlots=slots _amsSlots=slots
.filter(function(s){return s.status==='loaded';}) .filter(function(s){return s.status==='loaded';})
.sort(function(a,b){return (a.slot_index||0)-(b.slot_index||0);}); .sort(function(a,b){return (a.slot_index||0)-(b.slot_index||0);});
_loadSpoolmanStatus();
var dlg=document.getElementById('filament-dialog'); var dlg=document.getElementById('filament-dialog');
var title=document.getElementById('fd-title'); var title=document.getElementById('fd-title');
var body=document.getElementById('fd-slots'); var body=document.getElementById('fd-slots');
@@ -2623,6 +2680,8 @@ function openFilamentDialog(slots){
}).join(''); }).join('');
} }
if(dlg)dlg.classList.add('open'); if(dlg)dlg.classList.add('open');
// Spoolman-Section nach Slot-Render aufbauen (braucht die selects im DOM)
setTimeout(_buildSpoolmanSection, 0);
} }
function closeFilamentDialog(){ function closeFilamentDialog(){
@@ -2675,6 +2734,17 @@ function confirmFilamentPrint(){
var excludedObjects=_printObjects.filter(function(o){return o.skip;}).map(function(o){return o.name;}); var excludedObjects=_printObjects.filter(function(o){return o.skip;}).map(function(o){return o.name;});
var fdAlEl=document.getElementById('fd-auto-leveling'); var fdAlEl=document.getElementById('fd-auto-leveling');
var fdAutoLeveling=fdAlEl?( fdAlEl.checked?1:0):(S.auto_leveling===undefined?1:S.auto_leveling?1:0); var fdAutoLeveling=fdAlEl?( fdAlEl.checked?1:0):(S.auto_leveling===undefined?1:S.auto_leveling?1:0);
// Spoolman: Slot→Spool-Mapping aus Dialog sammeln und senden
if(_spoolmanStatus.configured){
var slotMap={};
document.querySelectorAll('[data-spool-slot]').forEach(function(sel){
var idx=sel.dataset.spoolSlot;
var val=parseInt(sel.value);
if(val>0)slotMap[idx]=val;
});
_slotSpoolMap=slotMap;
post('/kx/spoolman/active-spool',{slot_map:slotMap}).catch(function(){});
}
closeFilamentDialog(); closeFilamentDialog();
if(_filamentDialogMode==='banner'){ if(_filamentDialogMode==='banner'){
// Banner-Modus: /kx/print bevorzugen wenn _storeFileId bekannt (gleicher Pfad wie File-Browser). // Banner-Modus: /kx/print bevorzugen wenn _storeFileId bekannt (gleicher Pfad wie File-Browser).

View File

@@ -646,6 +646,13 @@
<label for="fd-auto-leveling" style="margin:0;cursor:pointer;font-size:13px" id="fd-lbl-auto-leveling">Auto-Leveling</label> <label for="fd-auto-leveling" style="margin:0;cursor:pointer;font-size:13px" id="fd-lbl-auto-leveling">Auto-Leveling</label>
</div> </div>
</div> </div>
<div id="fd-spoolman-section" style="display:none;margin-bottom:16px;border-top:1px solid var(--border);padding-top:12px">
<p style="font-size:12px;color:var(--txt2);margin-bottom:8px;display:flex;align-items:center;gap:6px">
<span id="fd-spoolman-lbl">🧵 Spoolman</span>
<span id="fd-spoolman-loading" style="display:none;font-size:10px"></span>
</p>
<div id="fd-spoolman-rows" style="display:flex;flex-direction:column;gap:6px"></div>
</div>
<div style="display:flex;gap:8px;justify-content:flex-end"> <div style="display:flex;gap:8px;justify-content:flex-end">
<button id="fd-cancel" onclick="closeFilamentDialog()" style="padding:8px 16px;background:var(--raised);border:1px solid var(--border);border-radius:8px;color:var(--txt);cursor:pointer">Abbrechen</button> <button id="fd-cancel" onclick="closeFilamentDialog()" style="padding:8px 16px;background:var(--raised);border:1px solid var(--border);border-radius:8px;color:var(--txt);cursor:pointer">Abbrechen</button>
<button id="fd-print" onclick="confirmFilamentPrint()" style="padding:8px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600">▶ Drucken</button> <button id="fd-print" onclick="confirmFilamentPrint()" style="padding:8px 18px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600">▶ Drucken</button>

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "Bereit", "ace_dry_auto_refill": "Auto-Nachschub",
"header_status_printing": "Druckt", "ace_dry_chart": "Verlauf (Temp/Feuchte)",
"header_status_complete": "Fertig", "ace_dry_current_temp": "Temperatur",
"header_status_error": "Fehler", "ace_dry_dialog_cancel": "Abbrechen",
"kobra_free": "Bereit", "ace_dry_dialog_confirm": "Bestätigen",
"kobra_busy": "Beschäftigt", "ace_dry_dialog_custom_name": "Eigener Name",
"kobra_printing": "Druckt", "ace_dry_dialog_reset_default": "Auf Standard zurücksetzen",
"kobra_preheating": "Aufheizen", "ace_dry_dialog_save_restart": "Speichern & Neustart",
"kobra_auto_leveling": "Nivellierung", "ace_dry_dialog_temp": "Temperatur (30-80°C)",
"kobra_checking": "Prüfung", "ace_dry_dialog_time": "Restzeit (h:m:s)",
"kobra_updated": "Aktualisierung", "ace_dry_dialog_title": "Trockner Temp/Zeit-Einstellungen",
"kobra_init": "Initialisierung",
"kobra_pausing": "Pausiert...",
"kobra_paused": "Pausiert",
"kobra_resuming": "Fortsetzen...",
"kobra_resumed": "Fortgesetzt",
"kobra_stopping": "Stoppt...",
"kobra_stoped": "Gestoppt",
"kobra_finished": "Abgeschlossen",
"kobra_failed": "Fehler",
"kobra_canceled": "Abgebrochen",
"kobra_offline": "Offline",
"nav_dashboard": "Dashboard",
"nav_print": "Druck",
"nav_temps": "Temperaturen",
"nav_motion": "Achsen",
"nav_ams": "AMS",
"nav_extras": "Licht / Lüfter",
"nav_console": "Konsole",
"card_progress": "Fortschritt",
"card_temps": "Temperaturen",
"card_light_fan": "Lüfter",
"card_speed": "Druckgeschwindigkeit",
"card_cam": "Kamera",
"lbl_elapsed": "Verstrichen:",
"lbl_remaining": "Restzeit:",
"lbl_slicer_time": "Slicer-Schätzung:",
"lbl_layers": "Layer",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 Leise",
"speed_normal": "⚡ Normal",
"speed_sport": "🚀 Sport",
"lbl_light": "💡 Licht",
"lbl_feed": "Einziehen",
"lbl_unload": "Ausziehen",
"card_ace_dry": "ACE Trocknung",
"ace_dry_dryer": "Trockner", "ace_dry_dryer": "Trockner",
"ace_dry_duration": "Dauer (Min)",
"ace_dry_enable": "Trocknung aktivieren",
"ace_dry_humidity": "Luftfeuchte",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "Custom",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ Start",
"ace_dry_status_off": "Status: Aus", "ace_dry_status_off": "Status: Aus",
"ace_dry_status_on": "Status: Aktiv", "ace_dry_status_on": "Status: Aktiv",
"ace_dry_status_remaining": "Rest", "ace_dry_status_remaining": "Rest",
"ace_dry_humidity": "Luftfeuchte",
"ace_dry_current_temp": "Temperatur",
"ace_dry_chart": "Verlauf (Temp/Feuchte)",
"ace_dry_temp": "Temperatur (°C)",
"ace_dry_duration": "Dauer (Min)",
"ace_dry_start": "▶ Start",
"ace_dry_stop": "■ Stop", "ace_dry_stop": "■ Stop",
"ace_dry_auto_refill": "Auto-Nachschub", "ace_dry_temp": "Temperatur (°C)",
"ace_dry_enable": "Trocknung aktivieren",
"ace_dry_temp_line": "Trocknungstemperatur", "ace_dry_temp_line": "Trocknungstemperatur",
"ace_dry_time_line": "Trocknungszeit", "ace_dry_time_line": "Trocknungszeit",
"ace_dry_ui_pending": "(nur UI, Backend folgt)", "ace_dry_ui_pending": "(nur UI, Backend folgt)",
"ace_dry_dialog_title": "Trockner Temp/Zeit-Einstellungen", "add_printer": "Drucker hinzufügen",
"ace_dry_dialog_temp": "Temperatur (30-80°C)", "ams_empty": "Leer",
"ace_dry_dialog_time": "Restzeit (h:m:s)", "ams_no_data": "Keine AMS-Daten empfangen",
"ace_dry_dialog_confirm": "Bestätigen", "apd_cancel": "Abbrechen",
"ace_dry_dialog_cancel": "Abbrechen", "apd_confirm": "Hinzufügen",
"ace_dry_dialog_save_restart": "Speichern & Neustart", "apd_err_ip": "Bitte IP-Adresse eingeben",
"ace_dry_dialog_custom_name": "Eigener Name", "apd_fetching": "Hole Daten vom Drucker…",
"ace_dry_dialog_reset_default": "Auf Standard zurücksetzen", "apd_lbl_ip": "Drucker-IP",
"cam_placeholder": "📷 Kamera nicht gestartet", "apd_lbl_name": "Name (optional)",
"cam_stream_unavailable": "Stream nicht verfügbar", "apd_placeholder_name": "z.B. Kobra X Wohnzimmer",
"apd_success": "Drucker hinzugefügt, Bridge startet neu…",
"apd_title": "Drucker hinzufügen",
"btn_cam_start": "▶ Kamera", "btn_cam_start": "▶ Kamera",
"btn_cam_start2": "▶ Start",
"btn_cam_stop": "◼ Kamera", "btn_cam_stop": "◼ Kamera",
"btn_cam_stop2": "◼ Stop",
"btn_cancel": "✕ Stopp",
"btn_cancel_generic": "Abbrechen",
"btn_confirm_generic": "Bestätigen",
"btn_connect": "⚡ Verbinden",
"btn_delete": "Löschen",
"btn_disable_motors": "Motoren aus",
"btn_disconnect": "✕ Trennen",
"btn_home_all": "Home All",
"btn_home_xy": "Home XY",
"btn_home_z": "Home Z",
"btn_pause": "⏸ Pause", "btn_pause": "⏸ Pause",
"btn_resume": "▶ Weiter", "btn_resume": "▶ Weiter",
"btn_cancel": "✕ Stopp", "cam_placeholder": "📷 Kamera nicht gestartet",
"label_nozzle": "Düse", "cam_stream_unavailable": "Stream nicht verfügbar",
"card_ace_dry": "ACE Trocknung",
"card_ams": "Filament",
"card_cam": "Kamera",
"card_light_fan": "Lüfter",
"card_progress": "Fortschritt",
"card_speed": "Druckgeschwindigkeit",
"card_temps": "Temperaturen",
"confirm_cancel": "Druck wirklich abbrechen?",
"fd_cancel": "Abbrechen",
"fd_no_matching_material": "Kein passendes Material",
"fd_no_slots_msg": "Keine belegten AMS-Slots.{br}Druck trotzdem starten?",
"fd_objects_hint": "Objekte überspringen (optional):",
"fd_objects_toggle": "Objekte überspringen",
"fd_options_title": "Optionen",
"fd_print": "▶ Drucken",
"fd_slot": "Slot",
"fd_slots_hint": "GCode-Kanal → AMS-Slot zuweisen:",
"fd_title": "Slot-Zuweisung",
"fd_used": "BELEGT",
"file_cancel_btn": "✕ Abbrechen",
"file_ready_btn": "▶ Druck starten",
"file_slots_btn": "🎨 Slots wählen",
"header_status_complete": "Fertig",
"header_status_error": "Fehler",
"header_status_printing": "Druckt",
"header_status_standby": "Bereit",
"hint_ip_no_port": "Nur IP-Adresse, kein Port (z.B. 192.168.1.102)",
"kobra_auto_leveling": "Nivellierung",
"kobra_busy": "Beschäftigt",
"kobra_canceled": "Abgebrochen",
"kobra_checking": "Prüfung",
"kobra_failed": "Fehler",
"kobra_finished": "Abgeschlossen",
"kobra_free": "Bereit",
"kobra_init": "Initialisierung",
"kobra_offline": "Offline",
"kobra_paused": "Pausiert",
"kobra_pausing": "Pausiert...",
"kobra_preheating": "Aufheizen",
"kobra_printing": "Druckt",
"kobra_resumed": "Fortgesetzt",
"kobra_resuming": "Fortsetzen...",
"kobra_stoped": "Gestoppt",
"kobra_stopping": "Stoppt...",
"kobra_updated": "Aktualisierung",
"label_bed": "Bett", "label_bed": "Bett",
"label_fan": "🌀 Lüfter", "label_fan": "🌀 Lüfter",
"label_light": "💡 Licht", "label_light": "💡 Licht",
"label_on_off": "Ein / Aus", "label_nozzle": "Düse",
"label_speed": "Geschwindigkeit",
"panel_print_title": "Drucksteuerung",
"panel_print_btn_pause": "⏸ Pause",
"panel_print_btn_resume": "▶ Fortsetzen",
"panel_print_btn_cancel": "✕ Abbrechen",
"panel_print_temps_live": "Temperaturen (Live)",
"label_set": "Setzen",
"label_off": "Aus", "label_off": "Aus",
"panel_temps_nozzle": "Düse", "label_on_off": "Ein / Aus",
"panel_temps_bed": "Heizbett", "label_set": "Setzen",
"panel_temps_chart": "Verlauf (letzte 60 Messungen)",
"label_target_c": "Ziel:",
"panel_motion_xy": "XY-Achsen",
"panel_motion_z": "Z-Achse",
"label_step": "Schrittweite:",
"btn_home_z": "Home Z",
"btn_home_xy": "Home XY",
"btn_home_all": "Home All",
"btn_disable_motors": "Motoren aus",
"panel_ams_title": "Filament",
"card_ams": "Filament",
"ams_no_data": "Keine AMS-Daten empfangen",
"label_slot": "Slot", "label_slot": "Slot",
"ams_empty": "Leer", "label_speed": "Geschwindigkeit",
"panel_extras_light": "Licht", "label_step": "Schrittweite:",
"panel_extras_fan": "Lüfter", "label_target_c": "Ziel:",
"panel_extras_camera": "Kamera", "lbl_conn_error": "Verbindungsfehler:",
"btn_cam_start2": "▶ Start", "lbl_elapsed": "Verstrichen:",
"btn_cam_stop2": "◼ Stop", "lbl_feed": "Einziehen",
"panel_console_title": "Ereignis-Log", "lbl_layers": "Layer",
"log_light_on": "Licht an", "lbl_light": "💡 Licht",
"log_light_off": "Licht aus", "lbl_remaining": "Restzeit:",
"log_fan": "Lüfter →", "lbl_slicer_time": "Slicer-Schätzung:",
"log_nozzle": "Düse →", "lbl_unload": "Ausziehen",
"log_bed": "Bett →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ Auto",
"log_axis": "Achse", "log_axis": "Achse",
"log_home": "Home", "log_bed": "Bett →",
"log_home_all": "Home All",
"log_cam_start": "Kamera gestartet:", "log_cam_start": "Kamera gestartet:",
"log_cam_stop": "Kamera gestoppt", "log_cam_stop": "Kamera gestoppt",
"log_poll_error": "Poll-Fehler:", "log_clear": "✕ Leeren",
"log_delete_failed": "Löschung fehlgeschlagen",
"log_dir_all": "Alle",
"log_dir_label": "Richtung:",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ Download",
"log_error": "Fehler:", "log_error": "Fehler:",
"confirm_cancel": "Druck wirklich abbrechen?", "log_fan": "Lüfter →",
"settings_title": "Einstellungen", "log_filter_placeholder": "Filtern…",
"settings_connection": "Verbindung", "log_home": "Home",
"settings_print": "Druckeinstellungen", "log_home_all": "Home All",
"settings_poll": "Poll-Intervall (Sekunden)", "log_light_off": "Licht aus",
"settings_version": "Version", "log_light_on": "Licht an",
"log_lvl_err": "⛔ Fehler",
"log_lvl_label": "Level:",
"log_lvl_warn": "⚠ Warnung",
"log_nozzle": "Düse →",
"log_poll_error": "Poll-Fehler:",
"log_print_action": "Druck:",
"log_print_start": "Druckstart:",
"log_topic_ams": "AMS",
"log_topic_info": "Info",
"log_topic_label": "Thema:",
"log_topic_print": "Druck",
"log_topic_status": "Status",
"nav_ams": "AMS",
"nav_browser": "Browser",
"nav_console": "Konsole",
"nav_dashboard": "Dashboard",
"nav_extras": "Licht / Lüfter",
"nav_motion": "Achsen",
"nav_print": "Druck",
"nav_printers": "Drucker",
"nav_settings": "Einstellungen", "nav_settings": "Einstellungen",
"settings_cat_display": "Darstellung", "nav_temps": "Temperaturen",
"settings_cat_filament": "Filament", "orca_profile_done": "Importiert",
"settings_cat_language": "Sprache", "orca_profile_dropmsg": "Hierher ziehen oder klicken",
"settings_cat_theme": "Hell / Dunkel umschalten", "orca_profile_help_html": "Lade ein <b>ZIP</b> deines OrcaSlicer-Filament-Ordners oder einzelne <b>.json</b>-Files hoch.<br>In OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "Filament-Profil-Mapping (pro Slot)",
"settings_filament_mapping_save": "Mapping speichern",
"settings_visible_vendors": "Sichtbare Hersteller (Profil-Dropdown)",
"settings_visible_vendors_hint": "Nur diese Hersteller erscheinen im Slot-Profil-Dropdown. Nichts ausgewählt = alle anzeigen. „Generic\" und eigene Profile sind immer sichtbar.",
"settings_visible_vendors_save": "Auswahl speichern",
"progress_action_print": "Drucken",
"progress_action_slots": "Slots zuordnen",
"progress_action_clear": "Leeren",
"settings_save": "Speichern & Neustart",
"settings_printer_name": "Drucker-Name",
"settings_printer_ip": "Drucker-IP",
"settings_mqtt_port": "MQTT-Port",
"settings_username": "MQTT-Benutzername",
"settings_password": "MQTT-Passwort",
"settings_device_id": "Device-ID",
"settings_mode_id": "Mode-ID",
"hint_ip_no_port": "Nur IP-Adresse, kein Port (z.B. 192.168.1.102)",
"settings_default_slot": "Standard-Slot (Einfarbdruck)",
"settings_slot_auto": "Auto (alle belegten Slots)",
"settings_auto_leveling": "Auto-Leveling vor Druck",
"settings_camera_on_print": "Kamera bei Druckstart einschalten",
"settings_web_upload_warning": "Warnung bei Web-Upload-Druck anzeigen",
"update_check": "Auf Updates prüfen",
"update_checking": "Prüfe...",
"update_available": "verfügbar",
"update_none": "Bereits aktuell",
"update_apply": "Jetzt installieren",
"update_applying": "Lade herunter...",
"update_restarting": "Starte neu...",
"update_error": "Fehler",
"btn_connect": "⚡ Verbinden",
"btn_disconnect": "✕ Trennen",
"lbl_conn_error": "Verbindungsfehler:",
"slot_edit_title": "Slot bearbeiten",
"slot_edit_color": "Farbe",
"slot_edit_material": "Material",
"slot_edit_load": "⬇ Einziehen",
"slot_edit_unload": "⬆ Ausziehen",
"slot_edit_save": "💾 Speichern",
"slot_edit_custom": "z.B. PLA, PETG, ABS…",
"slot_edit_ok": "AMS Slot",
"slot_edit_profile": "OrcaSlicer-Profil",
"slot_edit_profile_hint": "Sendet beim OrcaSlicer-Sync die konkrete Marke statt nur „Generic\"",
"slot_edit_profile_default": "— Generic (Default) —",
"orca_profile_section": "OrcaSlicer-Profile",
"orca_profile_hint": "Eigene Profile aus OrcaSlicer importieren (User-Dir öffnen via Help → Show Configuration Folder)", "orca_profile_hint": "Eigene Profile aus OrcaSlicer importieren (User-Dir öffnen via Help → Show Configuration Folder)",
"orca_profile_import_btn": "Profile importieren", "orca_profile_import_btn": "Profile importieren",
"orca_profile_import_link": "★ Eigene Profile importieren…", "orca_profile_import_link": "★ Eigene Profile importieren…",
"orca_profile_import_title": "Eigene OrcaSlicer-Profile importieren", "orca_profile_import_title": "Eigene OrcaSlicer-Profile importieren",
"orca_profile_help_html": "Lade ein <b>ZIP</b> deines OrcaSlicer-Filament-Ordners oder einzelne <b>.json</b>-Files hoch.<br>In OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "Hierher ziehen oder klicken",
"orca_profile_list_label": "Aktuell importiert", "orca_profile_list_label": "Aktuell importiert",
"orca_profile_user_label": "Eigene Profile", "orca_profile_section": "OrcaSlicer-Profile",
"orca_profile_user_empty": " keine ",
"orca_profile_uploading": "Lade hoch…",
"orca_profile_done": "Importiert",
"orca_profile_skipped": "übersprungen", "orca_profile_skipped": "übersprungen",
"log_dir_all": "Alle", "orca_profile_uploading": "Lade hoch…",
"log_lvl_label": "Level:", "orca_profile_user_empty": " keine ",
"file_ready_btn": "▶ Druck starten", "orca_profile_user_label": "Eigene Profile",
"file_slots_btn": "🎨 Slots wählen", "panel_ams_title": "Filament",
"file_cancel_btn": "✕ Abbrechen", "panel_browser_title": "Datei-Browser",
"nav_printers": "Drucker", "panel_console_title": "Ereignis-Log",
"skip_title": "✂ Objekte überspringen", "panel_extras_camera": "Kamera",
"skip_hint": "Objekte abwählen, die nicht weiter gedruckt werden sollen:", "panel_extras_fan": "Lüfter",
"skip_btn_label": "Objekte", "panel_extras_light": "Licht",
"skip_no_objects": "Keine Objekte in diesem Druck.", "panel_motion_xy": "XY-Achsen",
"panel_motion_z": "Z-Achse",
"panel_print_btn_cancel": "✕ Abbrechen",
"panel_print_btn_pause": "⏸ Pause",
"panel_print_btn_resume": "▶ Fortsetzen",
"panel_print_temps_live": "Temperaturen (Live)",
"panel_print_title": "Drucksteuerung",
"panel_temps_bed": "Heizbett",
"panel_temps_chart": "Verlauf (letzte 60 Messungen)",
"panel_temps_nozzle": "Düse",
"print_auto_leveling": "Auto-Leveling für diesen Druck",
"printers_active": "● aktiv",
"printers_current": "Aktueller Drucker",
"printers_empty_hint": "Noch kein Drucker eingerichtet.",
"printers_loading": "Lade…",
"printers_none": "Keine Drucker konfiguriert.",
"printers_remove": "Drucker entfernen",
"printers_remove_confirm": "Drucker \"{name}\" entfernen? Die Bridge startet neu.",
"printers_switch": "Wechseln →",
"progress_action_clear": "Leeren",
"progress_action_print": "Drucken",
"progress_action_slots": "Slots zuordnen",
"settings_auto_leveling": "Auto-Leveling vor Druck",
"settings_auto_leveling_label": "Auto-Leveling vor dem Druck",
"settings_btn_tooltip": "Einstellungen",
"settings_camera_on_print": "Kamera bei Druckstart einschalten",
"settings_cat_connection": "Verbindung",
"settings_cat_display": "Darstellung",
"settings_cat_filament": "Filament",
"settings_cat_language": "Sprache",
"settings_cat_printer": "Drucker",
"settings_cat_system": "System",
"settings_cat_theme": "Hell / Dunkel umschalten",
"settings_connection": "Verbindung",
"settings_default_slot": "Standard-Slot (Einfarbdruck)",
"settings_device_id": "Device-ID",
"settings_device_id_hint": "32 Hexzeichen",
"settings_device_id_placeholder": "32 Hexzeichen",
"settings_filament_mapping": "Filament-Profil-Mapping (pro Slot)",
"settings_filament_mapping_hint": "Festes Orca-Profil pro AMS-Slot. Bei der Slicer-Synchronisierung sendet die Bridge dieses Profil statt \"Generic\".",
"settings_filament_mapping_label": "Filament-Profil-Mapping (pro Slot)",
"settings_filament_mapping_save": "Mapping speichern",
"settings_filament_mapping_save_label": "Mapping speichern",
"settings_file_ready_banner": "Druckleiste",
"settings_file_ready_dialog": "Druckdialog",
"settings_file_ready_mode": "Nach Upload: Druckstart-Verhalten",
"settings_language": "Sprache",
"settings_mode_id": "Mode-ID",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "MQTT-Port",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "Profile importieren",
"settings_orca_profiles_label": "OrcaSlicer-Profile",
"settings_password": "MQTT-Passwort",
"settings_poll": "Poll-Intervall (Sekunden)",
"settings_poll_interval_hint": "Wie oft die Bridge den Druckerstatus abfragt",
"settings_poll_interval_label": "Poll-Intervall (Sekunden)",
"settings_print": "Druckeinstellungen",
"settings_printer_ip": "Drucker-IP",
"settings_printer_name": "Drucker-Name",
"settings_printer_name_placeholder": "z.B. Kobra X Links",
"settings_save": "Speichern & Neustart",
"settings_slot_auto": "Auto (alle belegten Slots)",
"settings_theme_toggle": "Wechsel Hell / Dunkel",
"settings_title": "Einstellungen",
"settings_username": "MQTT-Benutzername",
"settings_vendor_filter_placeholder": "Hersteller suchen…",
"settings_version": "Version",
"settings_visible_vendors": "Sichtbare Hersteller (Profil-Dropdown)",
"settings_visible_vendors_hint": "Nur diese Hersteller erscheinen im Slot-Profil-Dropdown. Nichts ausgewählt = alle anzeigen. „Generic\" und eigene Profile sind immer sichtbar.",
"settings_visible_vendors_label": "Sichtbare Hersteller (Profil-Dropdown)",
"settings_visible_vendors_save": "Auswahl speichern",
"settings_visible_vendors_save_label": "Auswahl speichern",
"settings_web_upload_warning": "Warnung bei Web-Upload-Druck anzeigen",
"sf_all": "Alle",
"sf_err": "✗ Fehler",
"sf_new": "Neu",
"sf_ok": "✓ Erfolgreich",
"skip_already": "übersprungen", "skip_already": "übersprungen",
"skip_btn_label": "Objekte",
"skip_cancel": "Abbrechen",
"skip_confirm": "Überspringen",
"skip_confirm_btn": "Überspringen",
"skip_hint": "Objekte abwählen, die nicht weiter gedruckt werden sollen:",
"skip_no_objects": "Keine Objekte in diesem Druck.",
"skip_select_at_least_one": "Bitte mindestens ein Objekt wählen.", "skip_select_at_least_one": "Bitte mindestens ein Objekt wählen.",
"skip_sending": "Sende …", "skip_sending": "Sende …",
"skip_success": "Objekte werden übersprungen.", "skip_success": "Objekte werden übersprungen.",
"fd_objects_hint": "Objekte überspringen (optional):", "skip_title": "Objekte überspringen",
"fd_objects_toggle": "Objekte überspringen", "slot_edit_color": "Farbe",
"fd_slots_hint": "GCode-Kanal → AMS-Slot zuweisen:", "slot_edit_custom": "z.B. PLA, PETG, ABS…",
"fd_cancel": "Abbrechen", "slot_edit_load": "⬇ Einziehen",
"fd_print": "▶ Drucken", "slot_edit_material": "Material",
"fd_no_slots_msg": "Keine belegten AMS-Slots.{br}Druck trotzdem starten?", "slot_edit_ok": "AMS Slot",
"fd_slot": "Slot", "slot_edit_profile": "OrcaSlicer-Profil",
"fd_no_matching_material": "Kein passendes Material", "slot_edit_profile_default": "— Generic (Default) —",
"fd_used": "BELEGT", "slot_edit_profile_hint": "Sendet beim OrcaSlicer-Sync die konkrete Marke statt nur „Generic\"",
"add_printer": "Drucker hinzufügen", "slot_edit_save": "💾 Speichern",
"apd_lbl_ip": "Drucker-IP", "slot_edit_title": "Slot bearbeiten",
"apd_lbl_name": "Name (optional)", "slot_edit_unload": "⬆ Ausziehen",
"apd_placeholder_name": "z.B. Kobra X Wohnzimmer", "speed_normal": "⚡ Normal",
"apd_cancel": "Abbrechen", "speed_silent": "🐢 Leise",
"apd_confirm": "Hinzufügen", "speed_sport": "🚀 Sport",
"apd_fetching": "Hole Daten vom Drucker…",
"apd_success": "Drucker hinzugefügt, Bridge startet neu…",
"apd_err_ip": "Bitte IP-Adresse eingeben",
"printers_remove": "Drucker entfernen",
"printers_remove_confirm": "Drucker \"{name}\" entfernen? Die Bridge startet neu.",
"printers_active": "● aktiv",
"printers_switch": "Wechseln →",
"printers_current": "Aktueller Drucker",
"printers_loading": "Lade…",
"printers_none": "Keine Drucker konfiguriert.",
"printers_empty_hint": "Noch kein Drucker eingerichtet.",
"nav_browser": "Browser",
"panel_browser_title": "Datei-Browser",
"store_search_placeholder": "🔍 Suche…",
"store_empty": "Noch keine Dateien hochgeladen.",
"store_refresh": "↻ Aktualisieren",
"store_print": "▶ Drucken",
"store_download": "⬇ Download",
"store_delete_confirm": "Datei löschen?",
"store_print_confirm": "Datei drucken?",
"store_web_verify_title": "Datei verifizieren",
"store_web_verify_msg": "Bitte bestätige, dass diese Datei für den Anycubic Kobra X erstellt wurde.",
"store_web_verify_confirm": "Bestätigen",
"store_web_verify_abort": "Abbrechen",
"store_no_results": "Keine Dateien gefunden.",
"store_never": "noch nicht gedruckt",
"store_estimate": "Schätzung",
"store_upload_label_prefix": "GCode hierher ziehen oder ",
"store_upload_label_browse": "durchsuchen",
"store_upload_busy": "⏳ Hochladen…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ Nur GCode-Dateien erlaubt (.gcode, .3mf, .bgcode)",
"sf_all": "Alle",
"sf_ok": "✓ Erfolgreich",
"sf_err": "✗ Fehler",
"sf_new": "Neu",
"ss_date": "↓ Datum", "ss_date": "↓ Datum",
"ss_name": "AZ Name",
"ss_dur": "⏱ Druckzeit", "ss_dur": "⏱ Druckzeit",
"ace_dry_preset_pla": "PLA", "ss_name": "AZ Name",
"ace_dry_preset_pla_plus": "PLA+", "store_delete_confirm": "Datei löschen?",
"ace_dry_preset_petg": "PETG", "store_download": "⬇ Download",
"ace_dry_preset_tpu": "TPU", "store_empty": "Noch keine Dateien hochgeladen.",
"ace_dry_preset_abs_asa": "ABS / ASA", "store_estimate": "Schätzung",
"ace_dry_preset_pa_pc": "PA / PC", "store_never": "noch nicht gedruckt",
"ace_dry_preset_custom": "Custom", "store_no_results": "Keine Dateien gefunden.",
"fd_options_title": "Optionen", "store_print": "▶ Drucken",
"print_auto_leveling": "Auto-Leveling für diesen Druck", "store_print_confirm": "Datei drucken?",
"settings_file_ready_mode": "Druckdialog starten", "store_refresh": "↻ Aktualisieren",
"settings_file_ready_banner": "Druckleiste", "store_search_placeholder": "🔍 Suche…",
"settings_file_ready_dialog": "Druckdialog", "store_upload_busy": "⏳ Hochladen…",
"log_dir_rx": "RX", "store_upload_error": "✗ {error}",
"log_dir_tx": "TX", "store_upload_label_browse": "durchsuchen",
"log_dir_label": "Richtung:", "store_upload_label_prefix": "GCode hierher ziehen oder ",
"log_lvl_err": "⛔ Fehler", "store_upload_only_gcode": "✗ Nur GCode-Dateien erlaubt (.gcode, .3mf, .bgcode)",
"log_lvl_warn": "⚠ Warnung", "store_upload_success": "✓ {file}",
"log_topic_label": "Thema:", "store_web_verify_abort": "Abbrechen",
"log_topic_ams": "AMS", "store_web_verify_confirm": "Bestätigen",
"log_topic_print": "Druck", "store_web_verify_msg": "Bitte bestätige, dass diese Datei für den Anycubic Kobra X erstellt wurde.",
"log_topic_info": "Info", "store_web_verify_title": "Datei verifizieren",
"log_topic_status": "Status", "update_apply": "Jetzt installieren",
"log_download": "⬇ Download", "update_applying": "Lade herunter...",
"log_auto": "⬇ Auto", "update_available": "verfügbar",
"log_clear": "✕ Leeren", "update_check": "Auf Updates prüfen",
"log_filter_placeholder": "Filtern…", "update_checking": "Prüfe...",
"skip_cancel": "Abbrechen", "update_error": "Fehler",
"skip_confirm": "Überspringen" "update_none": "Bereits aktuell",
"update_restarting": "Starte neu..."
} }

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "Ready", "ace_dry_auto_refill": "Auto Refill",
"header_status_printing": "Printing", "ace_dry_chart": "History (Temp/Humidity)",
"header_status_complete": "Complete", "ace_dry_current_temp": "Temperature",
"header_status_error": "Error", "ace_dry_dialog_cancel": "Cancel",
"kobra_free": "Ready", "ace_dry_dialog_confirm": "Confirm",
"kobra_busy": "Busy", "ace_dry_dialog_custom_name": "Custom Name",
"kobra_printing": "Printing", "ace_dry_dialog_reset_default": "Reset to Default",
"kobra_preheating": "Preheating", "ace_dry_dialog_save_restart": "Save & Restart",
"kobra_auto_leveling": "Auto Leveling", "ace_dry_dialog_temp": "Temperature (30-80°C)",
"kobra_checking": "Checking", "ace_dry_dialog_time": "Rem. Time (h:m:s)",
"kobra_updated": "Updating", "ace_dry_dialog_title": "Dryer Temp/Time Settings",
"kobra_init": "Initializing",
"kobra_pausing": "Pausing...",
"kobra_paused": "Paused",
"kobra_resuming": "Resuming...",
"kobra_resumed": "Resumed",
"kobra_stopping": "Stopping...",
"kobra_stoped": "Stopped",
"kobra_finished": "Finished",
"kobra_failed": "Error",
"kobra_canceled": "Cancelled",
"kobra_offline": "Offline",
"nav_dashboard": "Dashboard",
"nav_print": "Print",
"nav_temps": "Temperatures",
"nav_motion": "Motion",
"nav_ams": "AMS",
"nav_extras": "Light / Fan",
"nav_console": "Console",
"card_progress": "Progress",
"card_temps": "Temperatures",
"card_light_fan": "Fan",
"card_speed": "Print Speed",
"card_cam": "Camera",
"lbl_elapsed": "Elapsed:",
"lbl_remaining": "Remaining:",
"lbl_slicer_time": "Slicer estimate:",
"lbl_layers": "Layer",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 Silent",
"speed_normal": "⚡ Normal",
"speed_sport": "🚀 Sport",
"lbl_light": "💡 Light",
"lbl_feed": "Load",
"lbl_unload": "Unload",
"card_ace_dry": "ACE Drying",
"ace_dry_dryer": "Dryer", "ace_dry_dryer": "Dryer",
"ace_dry_duration": "Duration (min)",
"ace_dry_enable": "Enable Drying",
"ace_dry_humidity": "Humidity",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "Custom",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ Start",
"ace_dry_status_off": "Status: Off", "ace_dry_status_off": "Status: Off",
"ace_dry_status_on": "Status: Active", "ace_dry_status_on": "Status: Active",
"ace_dry_status_remaining": "Remaining", "ace_dry_status_remaining": "Remaining",
"ace_dry_humidity": "Humidity",
"ace_dry_current_temp": "Temperature",
"ace_dry_chart": "History (Temp/Humidity)",
"ace_dry_temp": "Temperature (°C)",
"ace_dry_duration": "Duration (min)",
"ace_dry_start": "▶ Start",
"ace_dry_stop": "■ Stop", "ace_dry_stop": "■ Stop",
"ace_dry_auto_refill": "Auto Refill", "ace_dry_temp": "Temperature (°C)",
"ace_dry_enable": "Enable Drying",
"ace_dry_temp_line": "Drying Temperature", "ace_dry_temp_line": "Drying Temperature",
"ace_dry_time_line": "Drying Time", "ace_dry_time_line": "Drying Time",
"ace_dry_ui_pending": "(UI only, backend next)", "ace_dry_ui_pending": "(UI only, backend next)",
"ace_dry_dialog_title": "Dryer Temp/Time Settings", "add_printer": "Add printer",
"ace_dry_dialog_temp": "Temperature (30-80°C)", "ams_empty": "Empty",
"ace_dry_dialog_time": "Rem. Time (h:m:s)", "ams_no_data": "No AMS data received",
"ace_dry_dialog_confirm": "Confirm", "apd_cancel": "Cancel",
"ace_dry_dialog_cancel": "Cancel", "apd_confirm": "Add",
"ace_dry_dialog_save_restart": "Save & Restart", "apd_err_ip": "Please enter an IP address",
"ace_dry_dialog_custom_name": "Custom Name", "apd_fetching": "Fetching data from printer…",
"ace_dry_dialog_reset_default": "Reset to Default", "apd_lbl_ip": "Printer IP",
"ace_dry_preset_pla": "PLA", "apd_lbl_name": "Name (optional)",
"ace_dry_preset_pla_plus": "PLA+", "apd_placeholder_name": "e.g. Kobra X Living Room",
"ace_dry_preset_petg": "PETG", "apd_success": "Printer added, bridge restarting…",
"ace_dry_preset_tpu": "TPU", "apd_title": "Add printer",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_custom": "Custom",
"cam_placeholder": "📷 Camera not started",
"cam_stream_unavailable": "Stream unavailable",
"btn_cam_start": "▶ Camera", "btn_cam_start": "▶ Camera",
"btn_cam_start2": "▶ Start",
"btn_cam_stop": "◼ Camera", "btn_cam_stop": "◼ Camera",
"btn_cam_stop2": "◼ Stop",
"btn_cancel": "✕ Stop",
"btn_cancel_generic": "Cancel",
"btn_confirm_generic": "Confirm",
"btn_connect": "⚡ Connect",
"btn_delete": "Delete",
"btn_disable_motors": "Motors Off",
"btn_disconnect": "✕ Disconnect",
"btn_home_all": "Home All",
"btn_home_xy": "Home XY",
"btn_home_z": "Home Z",
"btn_pause": "⏸ Pause", "btn_pause": "⏸ Pause",
"btn_resume": "▶ Resume", "btn_resume": "▶ Resume",
"btn_cancel": "✕ Stop", "cam_placeholder": "📷 Camera not started",
"label_nozzle": "Nozzle", "cam_stream_unavailable": "Stream unavailable",
"card_ace_dry": "ACE Drying",
"card_ams": "Filament",
"card_cam": "Camera",
"card_light_fan": "Fan",
"card_progress": "Progress",
"card_speed": "Print Speed",
"card_temps": "Temperatures",
"confirm_cancel": "Really cancel the print?",
"fd_cancel": "Cancel",
"fd_no_matching_material": "No matching material",
"fd_no_slots_msg": "No loaded AMS slots.{br}Start print anyway?",
"fd_objects_hint": "Skip objects (optional):",
"fd_objects_toggle": "Skip objects",
"fd_options_title": "Print Options",
"fd_print": "▶ Print",
"fd_slot": "Slot",
"fd_slots_hint": "Assign GCode channel to AMS slot:",
"fd_title": "Slot Assignment",
"fd_used": "USED",
"file_cancel_btn": "✕ Cancel",
"file_ready_btn": "▶ Start Print",
"file_slots_btn": "🎨 Select Slots",
"header_status_complete": "Complete",
"header_status_error": "Error",
"header_status_printing": "Printing",
"header_status_standby": "Ready",
"hint_ip_no_port": "IP address only, no port (e.g. 192.168.1.102)",
"kobra_auto_leveling": "Auto Leveling",
"kobra_busy": "Busy",
"kobra_canceled": "Cancelled",
"kobra_checking": "Checking",
"kobra_failed": "Error",
"kobra_finished": "Finished",
"kobra_free": "Ready",
"kobra_init": "Initializing",
"kobra_offline": "Offline",
"kobra_paused": "Paused",
"kobra_pausing": "Pausing...",
"kobra_preheating": "Preheating",
"kobra_printing": "Printing",
"kobra_resumed": "Resumed",
"kobra_resuming": "Resuming...",
"kobra_stoped": "Stopped",
"kobra_stopping": "Stopping...",
"kobra_updated": "Updating",
"label_bed": "Bed", "label_bed": "Bed",
"label_fan": "🌀 Fan", "label_fan": "🌀 Fan",
"label_light": "💡 Light", "label_light": "💡 Light",
"label_on_off": "On / Off", "label_nozzle": "Nozzle",
"label_speed": "Speed",
"panel_print_title": "Print Control",
"panel_print_btn_pause": "⏸ Pause",
"panel_print_btn_resume": "▶ Resume",
"panel_print_btn_cancel": "✕ Cancel",
"panel_print_temps_live": "Temperatures (Live)",
"label_set": "Set",
"label_off": "Off", "label_off": "Off",
"panel_temps_nozzle": "Nozzle", "label_on_off": "On / Off",
"panel_temps_bed": "Heated Bed", "label_set": "Set",
"panel_temps_chart": "History (last 60 readings)",
"label_target_c": "Target:",
"panel_motion_xy": "XY Axes",
"panel_motion_z": "Z Axis",
"label_step": "Step size:",
"btn_home_z": "Home Z",
"btn_home_xy": "Home XY",
"btn_home_all": "Home All",
"btn_disable_motors": "Motors Off",
"panel_ams_title": "Filament",
"card_ams": "Filament",
"ams_no_data": "No AMS data received",
"label_slot": "Slot", "label_slot": "Slot",
"ams_empty": "Empty", "label_speed": "Speed",
"panel_extras_light": "Light", "label_step": "Step size:",
"panel_extras_fan": "Fan", "label_target_c": "Target:",
"panel_extras_camera": "Camera", "lbl_conn_error": "Connection error:",
"btn_cam_start2": "▶ Start", "lbl_elapsed": "Elapsed:",
"btn_cam_stop2": "◼ Stop", "lbl_feed": "Load",
"panel_console_title": "Event Log", "lbl_layers": "Layer",
"log_light_on": "Light on", "lbl_light": "💡 Light",
"log_light_off": "Light off", "lbl_remaining": "Remaining:",
"log_fan": "Fan →", "lbl_slicer_time": "Slicer estimate:",
"log_nozzle": "Nozzle →", "lbl_unload": "Unload",
"log_bed": "Bed →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ Auto",
"log_axis": "Axis", "log_axis": "Axis",
"log_home": "Home", "log_bed": "Bed →",
"log_home_all": "Home All",
"log_cam_start": "Camera started:", "log_cam_start": "Camera started:",
"log_cam_stop": "Camera stopped", "log_cam_stop": "Camera stopped",
"log_poll_error": "Poll error:", "log_clear": "✕ Clear",
"log_delete_failed": "Delete failed",
"log_dir_all": "All",
"log_dir_label": "Dir:",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ Download",
"log_error": "Error:", "log_error": "Error:",
"confirm_cancel": "Really cancel the print?", "log_fan": "Fan →",
"settings_title": "Settings", "log_filter_placeholder": "Filter…",
"settings_connection": "Connection", "log_home": "Home",
"settings_print": "Print Settings", "log_home_all": "Home All",
"settings_poll": "Poll Interval (seconds)", "log_light_off": "Light off",
"log_light_on": "Light on",
"log_lvl_err": "⛔ Errors",
"log_lvl_label": "Level:",
"log_lvl_warn": "⚠ Warn",
"log_nozzle": "Nozzle →",
"log_poll_error": "Poll error:",
"log_print_action": "Print:",
"log_print_start": "Print start:",
"log_topic_ams": "AMS",
"log_topic_info": "Info",
"log_topic_label": "Topic:",
"log_topic_print": "Print",
"log_topic_status": "Status",
"nav_ams": "AMS",
"nav_browser": "Browser",
"nav_console": "Console",
"nav_dashboard": "Dashboard",
"nav_extras": "Light / Fan",
"nav_motion": "Motion",
"nav_print": "Print",
"nav_printers": "Printers",
"nav_settings": "Settings", "nav_settings": "Settings",
"settings_cat_display": "Appearance", "nav_temps": "Temperatures",
"settings_cat_filament": "Filament", "orca_profile_done": "Imported",
"settings_cat_language": "Language", "orca_profile_dropmsg": "Drop here or click",
"settings_cat_theme": "Toggle light / dark", "orca_profile_help_html": "Upload a <b>ZIP</b> of your OrcaSlicer filament folder or single <b>.json</b> files.<br>In OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "Filament profile mapping (per slot)",
"settings_filament_mapping_save": "Save mapping",
"settings_visible_vendors": "Visible vendors (profile dropdown)",
"settings_visible_vendors_hint": "Only these vendors appear in the slot profile dropdown. Nothing selected = show all. \"Generic\" and your own profiles are always visible.",
"settings_visible_vendors_save": "Save selection",
"progress_action_print": "Print",
"progress_action_slots": "Map slots",
"progress_action_clear": "Clear",
"settings_version": "Version",
"settings_save": "Save & Restart",
"settings_printer_name": "Printer Name",
"settings_printer_ip": "Printer IP",
"settings_mqtt_port": "MQTT Port",
"settings_username": "MQTT Username",
"settings_password": "MQTT Password",
"settings_device_id": "Device ID",
"settings_mode_id": "Mode ID",
"hint_ip_no_port": "IP address only, no port (e.g. 192.168.1.102)",
"settings_default_slot": "Default Slot (single color)",
"settings_slot_auto": "Auto (all loaded slots)",
"settings_auto_leveling": "Auto-Leveling Default",
"fd_options_title": "Print Options",
"print_auto_leveling": "Auto-Leveling",
"settings_file_ready_mode": "Start Print Behavior",
"settings_file_ready_banner": "Print Bar",
"settings_file_ready_dialog": "Print Dialog",
"settings_camera_on_print": "Turn camera on at print start",
"settings_web_upload_warning": "Show warning when printing web uploads",
"update_check": "Check for Updates",
"update_checking": "Checking...",
"update_available": "available",
"update_none": "Already up to date",
"update_apply": "Install Now",
"update_applying": "Downloading...",
"update_restarting": "Restarting...",
"update_error": "Error",
"btn_connect": "⚡ Connect",
"btn_disconnect": "✕ Disconnect",
"lbl_conn_error": "Connection error:",
"slot_edit_title": "Edit Slot",
"slot_edit_color": "Color",
"slot_edit_material": "Material",
"slot_edit_load": "⬇ Load",
"slot_edit_unload": "⬆ Unload",
"slot_edit_save": "💾 Save",
"slot_edit_custom": "e.g. PLA, PETG, ABS…",
"slot_edit_ok": "AMS Slot",
"slot_edit_profile": "OrcaSlicer profile",
"slot_edit_profile_hint": "Sent on OrcaSlicer sync as the specific brand instead of just \"Generic\"",
"slot_edit_profile_default": "— Generic (default) —",
"orca_profile_section": "OrcaSlicer Profiles",
"orca_profile_hint": "Import your own OrcaSlicer filament profiles (open the user dir via Help → Show Configuration Folder)", "orca_profile_hint": "Import your own OrcaSlicer filament profiles (open the user dir via Help → Show Configuration Folder)",
"orca_profile_import_btn": "Import profiles", "orca_profile_import_btn": "Import profiles",
"orca_profile_import_link": "★ Import own profiles…", "orca_profile_import_link": "★ Import own profiles…",
"orca_profile_import_title": "Import your OrcaSlicer profiles", "orca_profile_import_title": "Import your OrcaSlicer profiles",
"orca_profile_help_html": "Upload a <b>ZIP</b> of your OrcaSlicer filament folder or single <b>.json</b> files.<br>In OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "Drop here or click",
"orca_profile_list_label": "Currently imported", "orca_profile_list_label": "Currently imported",
"orca_profile_user_label": "Own profiles", "orca_profile_section": "OrcaSlicer Profiles",
"orca_profile_user_empty": " none ",
"orca_profile_uploading": "Uploading…",
"orca_profile_done": "Imported",
"orca_profile_skipped": "skipped", "orca_profile_skipped": "skipped",
"log_dir_all": "All", "orca_profile_uploading": "Uploading…",
"log_dir_rx": "RX", "orca_profile_user_empty": " none ",
"log_dir_tx": "TX", "orca_profile_user_label": "Own profiles",
"log_dir_label": "Dir:", "panel_ams_title": "Filament",
"log_lvl_label": "Level:", "panel_browser_title": "File Browser",
"log_lvl_err": "⛔ Errors", "panel_console_title": "Event Log",
"log_lvl_warn": "⚠ Warn", "panel_extras_camera": "Camera",
"log_topic_label": "Topic:", "panel_extras_fan": "Fan",
"log_topic_ams": "AMS", "panel_extras_light": "Light",
"log_topic_print": "Print", "panel_motion_xy": "XY Axes",
"log_topic_info": "Info", "panel_motion_z": "Z Axis",
"log_topic_status": "Status", "panel_print_btn_cancel": "✕ Cancel",
"log_download": "⬇ Download", "panel_print_btn_pause": "⏸ Pause",
"log_auto": "⬇ Auto", "panel_print_btn_resume": "▶ Resume",
"log_clear": "✕ Clear", "panel_print_temps_live": "Temperatures (Live)",
"log_filter_placeholder": "Filter…", "panel_print_title": "Print Control",
"file_ready_btn": "▶ Start Print", "panel_temps_bed": "Heated Bed",
"file_slots_btn": "🎨 Select Slots", "panel_temps_chart": "History (last 60 readings)",
"file_cancel_btn": "✕ Cancel", "panel_temps_nozzle": "Nozzle",
"nav_printers": "Printers", "print_auto_leveling": "Auto-Leveling",
"skip_title": "✂ Skip objects", "printers_active": "● active",
"skip_hint": "Uncheck objects you no longer want to print:", "printers_current": "Current printer",
"skip_btn_label": "Objects", "printers_empty_hint": "No printer set up yet.",
"skip_no_objects": "No objects in this print.", "printers_loading": "Loading…",
"printers_none": "No printers configured.",
"printers_remove": "Remove printer",
"printers_remove_confirm": "Remove printer \"{name}\"? The bridge will restart.",
"printers_switch": "Switch →",
"progress_action_clear": "Clear",
"progress_action_print": "Print",
"progress_action_slots": "Map slots",
"settings_auto_leveling": "Auto-Leveling Default",
"settings_auto_leveling_label": "Auto-Leveling before print",
"settings_btn_tooltip": "Settings",
"settings_camera_on_print": "Turn camera on at print start",
"settings_cat_connection": "Connection",
"settings_cat_display": "Appearance",
"settings_cat_filament": "Filament",
"settings_cat_language": "Language",
"settings_cat_printer": "Printer",
"settings_cat_system": "System",
"settings_cat_theme": "Toggle light / dark",
"settings_connection": "Connection",
"settings_default_slot": "Default Slot (single color)",
"settings_device_id": "Device ID",
"settings_device_id_hint": "32 hex characters",
"settings_device_id_placeholder": "32 hex characters",
"settings_filament_mapping": "Filament profile mapping (per slot)",
"settings_filament_mapping_hint": "Fixed Orca profile per AMS slot. On slicer sync, the bridge sends this profile instead of \"Generic\".",
"settings_filament_mapping_label": "Filament profile mapping (per slot)",
"settings_filament_mapping_save": "Save mapping",
"settings_filament_mapping_save_label": "Save mapping",
"settings_file_ready_banner": "Print bar",
"settings_file_ready_dialog": "Print dialog",
"settings_file_ready_mode": "After upload: Start print behavior",
"settings_language": "Language",
"settings_mode_id": "Mode ID",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "MQTT Port",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "Import profiles",
"settings_orca_profiles_label": "OrcaSlicer Profiles",
"settings_password": "MQTT Password",
"settings_poll": "Poll Interval (seconds)",
"settings_poll_interval_hint": "How often the bridge queries printer status",
"settings_poll_interval_label": "Poll Interval (seconds)",
"settings_print": "Print Settings",
"settings_printer_ip": "Printer IP",
"settings_printer_name": "Printer Name",
"settings_printer_name_placeholder": "e.g. Kobra X Left",
"settings_save": "Save & Restart",
"settings_slot_auto": "Auto (all loaded slots)",
"settings_theme_toggle": "Toggle light / dark",
"settings_title": "Settings",
"settings_username": "MQTT Username",
"settings_vendor_filter_placeholder": "Search vendors…",
"settings_version": "Version",
"settings_visible_vendors": "Visible vendors (profile dropdown)",
"settings_visible_vendors_hint": "Only these vendors appear in the slot profile dropdown. Nothing selected = show all. \"Generic\" and your own profiles are always visible.",
"settings_visible_vendors_label": "Visible vendors (profile dropdown)",
"settings_visible_vendors_save": "Save selection",
"settings_visible_vendors_save_label": "Save selection",
"settings_web_upload_warning": "Show warning when printing web uploads",
"sf_all": "All",
"sf_err": "✗ Failed",
"sf_new": "New",
"sf_ok": "✓ Completed",
"skip_already": "skipped", "skip_already": "skipped",
"skip_btn_label": "Objects",
"skip_cancel": "Cancel", "skip_cancel": "Cancel",
"skip_confirm": "Skip", "skip_confirm": "Skip",
"skip_confirm_btn": "Skip",
"skip_hint": "Uncheck objects you no longer want to print:",
"skip_no_objects": "No objects in this print.",
"skip_select_at_least_one": "Please pick at least one object.", "skip_select_at_least_one": "Please pick at least one object.",
"skip_sending": "Sending …", "skip_sending": "Sending …",
"skip_success": "Objects will be skipped.", "skip_success": "Objects will be skipped.",
"fd_objects_hint": "Skip objects (optional):", "skip_title": "Skip objects",
"fd_objects_toggle": "Skip objects", "slot_edit_color": "Color",
"fd_slots_hint": "Assign GCode channel to AMS slot:", "slot_edit_custom": "e.g. PLA, PETG, ABS…",
"fd_cancel": "Cancel", "slot_edit_load": "⬇ Load",
"fd_print": "▶ Print", "slot_edit_material": "Material",
"fd_no_slots_msg": "No loaded AMS slots.{br}Start print anyway?", "slot_edit_ok": "AMS Slot",
"fd_slot": "Slot", "slot_edit_profile": "OrcaSlicer profile",
"fd_no_matching_material": "No matching material", "slot_edit_profile_default": "— Generic (default) —",
"fd_used": "USED", "slot_edit_profile_hint": "Sent on OrcaSlicer sync as the specific brand instead of just \"Generic\"",
"add_printer": "Add printer", "slot_edit_save": "💾 Save",
"apd_lbl_ip": "Printer IP", "slot_edit_title": "Edit Slot",
"apd_lbl_name": "Name (optional)", "slot_edit_unload": "⬆ Unload",
"apd_placeholder_name": "e.g. Kobra X Living Room", "speed_normal": "⚡ Normal",
"apd_cancel": "Cancel", "speed_silent": "🐢 Silent",
"apd_confirm": "Add", "speed_sport": "🚀 Sport",
"apd_fetching": "Fetching data from printer…",
"apd_success": "Printer added, bridge restarting…",
"apd_err_ip": "Please enter an IP address",
"printers_remove": "Remove printer",
"printers_remove_confirm": "Remove printer \"{name}\"? The bridge will restart.",
"printers_active": "● active",
"printers_switch": "Switch →",
"printers_current": "Current printer",
"printers_loading": "Loading…",
"printers_none": "No printers configured.",
"printers_empty_hint": "No printer set up yet.",
"nav_browser": "Browser",
"panel_browser_title": "File Browser",
"store_search_placeholder": "🔍 Search…",
"store_empty": "No files uploaded yet.",
"store_refresh": "↻ Refresh",
"store_print": "▶ Print",
"store_download": "⬇ Download",
"store_delete_confirm": "Delete file?",
"store_print_confirm": "Print file?",
"store_web_verify_title": "Verify file",
"store_web_verify_msg": "Please verify this file was made for Anycubic Kobra X.",
"store_web_verify_confirm": "Confirm",
"store_web_verify_abort": "Abort",
"store_no_results": "No files found.",
"store_never": "never printed",
"store_estimate": "Estimate",
"store_upload_label_prefix": "Drag GCode here or ",
"store_upload_label_browse": "browse",
"store_upload_busy": "⏳ Uploading…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ Only GCode files allowed (.gcode, .3mf, .bgcode)",
"sf_all": "All",
"sf_ok": "✓ Completed",
"sf_err": "✗ Failed",
"sf_new": "New",
"ss_date": "↓ Date", "ss_date": "↓ Date",
"ss_dur": "⏱ Print time",
"ss_name": "AZ Name", "ss_name": "AZ Name",
"ss_dur": "⏱ Print time" "store_delete_confirm": "Delete file?",
"store_download": "⬇ Download",
"store_empty": "No files uploaded yet.",
"store_estimate": "Estimate",
"store_never": "never printed",
"store_no_results": "No files found.",
"store_print": "▶ Print",
"store_print_confirm": "Print file?",
"store_refresh": "↻ Refresh",
"store_search_placeholder": "🔍 Search…",
"store_upload_busy": "⏳ Uploading…",
"store_upload_error": "✗ {error}",
"store_upload_label_browse": "browse",
"store_upload_label_prefix": "Drag GCode here or ",
"store_upload_only_gcode": "✗ Only GCode files allowed (.gcode, .3mf, .bgcode)",
"store_upload_success": "✓ {file}",
"store_web_verify_abort": "Cancel",
"store_web_verify_confirm": "Confirm",
"store_web_verify_msg": "Please verify this file was made for Anycubic Kobra X.",
"store_web_verify_title": "Verify file",
"update_apply": "Install Now",
"update_applying": "Downloading...",
"update_available": "available",
"update_check": "Check for Updates",
"update_checking": "Checking...",
"update_error": "Error",
"update_none": "Already up to date",
"update_restarting": "Restarting..."
} }

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "Listo", "ace_dry_auto_refill": "Relleno automático",
"header_status_printing": "Imprimiendo", "ace_dry_chart": "Historial (Temp/Humedad)",
"header_status_complete": "Completado", "ace_dry_current_temp": "Temperatura",
"header_status_error": "Error", "ace_dry_dialog_cancel": "Cancelar",
"kobra_free": "Listo", "ace_dry_dialog_confirm": "Confirmar",
"kobra_busy": "Ocupado", "ace_dry_dialog_custom_name": "Nombre personalizado",
"kobra_printing": "Imprimiendo", "ace_dry_dialog_reset_default": "Restablecer valores predeterminados",
"kobra_preheating": "Precalentando", "ace_dry_dialog_save_restart": "Guardar y reiniciar",
"kobra_auto_leveling": "Autonivelado", "ace_dry_dialog_temp": "Temperatura (30-80°C)",
"kobra_checking": "Comprobando", "ace_dry_dialog_time": "Tiempo restante (h:m:s)",
"kobra_updated": "Actualizando", "ace_dry_dialog_title": "Ajustes de temp/tiempo del secador",
"kobra_init": "Inicializando",
"kobra_pausing": "Pausando...",
"kobra_paused": "Pausado",
"kobra_resuming": "Reanudando...",
"kobra_resumed": "Reanudado",
"kobra_stopping": "Deteniendo...",
"kobra_stoped": "Detenido",
"kobra_finished": "Finalizado",
"kobra_failed": "Error",
"kobra_canceled": "Cancelado",
"kobra_offline": "Desconectada",
"nav_dashboard": "Panel",
"nav_print": "Impresión",
"nav_temps": "Temperaturas",
"nav_motion": "Movimiento",
"nav_ams": "AMS",
"nav_extras": "Luz / Ventilador",
"nav_console": "Consola",
"card_progress": "Progreso",
"card_temps": "Temperaturas",
"card_light_fan": "Ventilador",
"card_speed": "Velocidad de impresión",
"card_cam": "Cámara",
"lbl_elapsed": "Transcurrido:",
"lbl_remaining": "Restante:",
"lbl_slicer_time": "Estimación del slicer:",
"lbl_layers": "Capa",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 Silencioso",
"speed_normal": "⚡ Normal",
"speed_sport": "🚀 Sport",
"lbl_light": "💡 Luz",
"lbl_feed": "Cargar",
"lbl_unload": "Descargar",
"card_ace_dry": "Secado ACE",
"ace_dry_dryer": "Secador", "ace_dry_dryer": "Secador",
"ace_dry_duration": "Duración (min)",
"ace_dry_enable": "Activar secado",
"ace_dry_humidity": "Humedad",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "Personalizado",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ Iniciar",
"ace_dry_status_off": "Estado: Apagado", "ace_dry_status_off": "Estado: Apagado",
"ace_dry_status_on": "Estado: Activo", "ace_dry_status_on": "Estado: Activo",
"ace_dry_status_remaining": "Restante", "ace_dry_status_remaining": "Restante",
"ace_dry_humidity": "Humedad",
"ace_dry_current_temp": "Temperatura",
"ace_dry_chart": "Historial (Temp/Humedad)",
"ace_dry_temp": "Temperatura (°C)",
"ace_dry_duration": "Duración (min)",
"ace_dry_start": "▶ Iniciar",
"ace_dry_stop": "■ Parar", "ace_dry_stop": "■ Parar",
"ace_dry_auto_refill": "Relleno automático", "ace_dry_temp": "Temperatura (°C)",
"ace_dry_enable": "Activar secado",
"ace_dry_temp_line": "Temperatura de secado", "ace_dry_temp_line": "Temperatura de secado",
"ace_dry_time_line": "Tiempo de secado", "ace_dry_time_line": "Tiempo de secado",
"ace_dry_ui_pending": "(solo UI, backend después)", "ace_dry_ui_pending": "(solo UI, backend después)",
"ace_dry_dialog_title": "Ajustes de temp/tiempo del secador", "add_printer": "Añadir impresora",
"ace_dry_dialog_temp": "Temperatura (30-80°C)", "ams_empty": "Vacío",
"ace_dry_dialog_time": "Tiempo restante (h:m:s)", "ams_no_data": "No se recibieron datos de AMS",
"ace_dry_dialog_confirm": "Confirmar", "apd_cancel": "Cancelar",
"ace_dry_dialog_cancel": "Cancelar", "apd_confirm": "Agregar",
"ace_dry_dialog_save_restart": "Guardar y reiniciar", "apd_err_ip": "Introduce una dirección IP",
"ace_dry_dialog_custom_name": "Nombre personalizado", "apd_fetching": "Obteniendo datos de la impresora…",
"ace_dry_dialog_reset_default": "Restablecer valores predeterminados", "apd_lbl_ip": "IP de impresora",
"cam_placeholder": "📷 Cámara no iniciada", "apd_lbl_name": "Nombre (opcional)",
"cam_stream_unavailable": "Stream no disponible", "apd_placeholder_name": "p. ej. Kobra X Sala",
"apd_success": "Impresora añadida, reiniciando bridge…",
"apd_title": "Agregar impresora",
"btn_cam_start": "▶ Cámara", "btn_cam_start": "▶ Cámara",
"btn_cam_start2": "▶ Iniciar",
"btn_cam_stop": "◼ Cámara", "btn_cam_stop": "◼ Cámara",
"btn_cam_stop2": "◼ Detener",
"btn_cancel": "✕ Detener",
"btn_cancel_generic": "Cancelar",
"btn_confirm_generic": "Confirmar",
"btn_connect": "⚡ Conectar",
"btn_delete": "Eliminar",
"btn_disable_motors": "Motores apagados",
"btn_disconnect": "✕ Desconectar",
"btn_home_all": "Home All",
"btn_home_xy": "Home XY",
"btn_home_z": "Home Z",
"btn_pause": "⏸ Pausa", "btn_pause": "⏸ Pausa",
"btn_resume": "▶ Reanudar", "btn_resume": "▶ Reanudar",
"btn_cancel": "✕ Detener", "cam_placeholder": "📷 Cámara no iniciada",
"label_nozzle": "Boquilla", "cam_stream_unavailable": "Stream no disponible",
"card_ace_dry": "Secado ACE",
"card_ams": "Filamento",
"card_cam": "Cámara",
"card_light_fan": "Ventilador",
"card_progress": "Progreso",
"card_speed": "Velocidad de impresión",
"card_temps": "Temperaturas",
"confirm_cancel": "¿Realmente cancelar la impresión?",
"fd_cancel": "Cancelar",
"fd_no_matching_material": "No hay material compatible",
"fd_no_slots_msg": "No hay slots AMS cargados.{br}¿Iniciar impresión de todos modos?",
"fd_objects_hint": "Omitir objetos (opcional):",
"fd_objects_toggle": "Omitir objetos",
"fd_options_title": "Opciones",
"fd_print": "▶ Imprimir",
"fd_slot": "Ranura",
"fd_slots_hint": "Asignar canal GCode a la ranura AMS:",
"fd_title": "Asignación de ranura",
"fd_used": "USADO",
"file_cancel_btn": "✕ Cancelar",
"file_ready_btn": "▶ Iniciar impresión",
"file_slots_btn": "🎨 Seleccionar ranuras",
"header_status_complete": "Completado",
"header_status_error": "Error",
"header_status_printing": "Imprimiendo",
"header_status_standby": "Listo",
"hint_ip_no_port": "Solo dirección IP, sin puerto (p. ej. 192.168.1.102)",
"kobra_auto_leveling": "Autonivelado",
"kobra_busy": "Ocupado",
"kobra_canceled": "Cancelado",
"kobra_checking": "Comprobando",
"kobra_failed": "Error",
"kobra_finished": "Finalizado",
"kobra_free": "Listo",
"kobra_init": "Inicializando",
"kobra_offline": "Desconectada",
"kobra_paused": "Pausado",
"kobra_pausing": "Pausando...",
"kobra_preheating": "Precalentando",
"kobra_printing": "Imprimiendo",
"kobra_resumed": "Reanudado",
"kobra_resuming": "Reanudando...",
"kobra_stoped": "Detenido",
"kobra_stopping": "Deteniendo...",
"kobra_updated": "Actualizando",
"label_bed": "Cama", "label_bed": "Cama",
"label_fan": "🌀 Ventilador", "label_fan": "🌀 Ventilador",
"label_light": "💡 Luz", "label_light": "💡 Luz",
"label_on_off": "Encendido / Apagado", "label_nozzle": "Boquilla",
"label_speed": "Velocidad",
"panel_print_title": "Control de impresión",
"panel_print_btn_pause": "⏸ Pausa",
"panel_print_btn_resume": "▶ Reanudar",
"panel_print_btn_cancel": "✕ Cancelar",
"panel_print_temps_live": "Temperaturas (en vivo)",
"label_set": "Set",
"label_off": "Apagado", "label_off": "Apagado",
"panel_temps_nozzle": "Boquilla", "label_on_off": "Encendido / Apagado",
"panel_temps_bed": "Cama caliente", "label_set": "Set",
"panel_temps_chart": "Historial (últimas 60 lecturas)",
"label_target_c": "Objetivo:",
"panel_motion_xy": "Ejes XY",
"panel_motion_z": "Eje Z",
"label_step": "Tamaño del paso:",
"btn_home_z": "Home Z",
"btn_home_xy": "Home XY",
"btn_home_all": "Home All",
"btn_disable_motors": "Motores apagados",
"panel_ams_title": "Filamento",
"card_ams": "Filamento",
"ams_no_data": "No se recibieron datos de AMS",
"label_slot": "Ranura", "label_slot": "Ranura",
"ams_empty": "Vacío", "label_speed": "Velocidad",
"panel_extras_light": "Luz", "label_step": "Tamaño del paso:",
"panel_extras_fan": "Ventilador", "label_target_c": "Objetivo:",
"panel_extras_camera": "Cámara", "lbl_conn_error": "Error de conexión:",
"btn_cam_start2": "▶ Iniciar", "lbl_elapsed": "Transcurrido:",
"btn_cam_stop2": "◼ Detener", "lbl_feed": "Cargar",
"panel_console_title": "Registro de eventos", "lbl_layers": "Capa",
"log_light_on": "Luz encendida", "lbl_light": "💡 Luz",
"log_light_off": "Luz apagada", "lbl_remaining": "Restante:",
"log_fan": "Ventilador →", "lbl_slicer_time": "Estimación del slicer:",
"log_nozzle": "Boquilla →", "lbl_unload": "Descargar",
"log_bed": "Cama →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ Auto",
"log_axis": "Eje", "log_axis": "Eje",
"log_home": "Home", "log_bed": "Cama →",
"log_home_all": "Home All",
"log_cam_start": "Cámara iniciada:", "log_cam_start": "Cámara iniciada:",
"log_cam_stop": "Cámara detenida", "log_cam_stop": "Cámara detenida",
"log_poll_error": "Error de sondeo:", "log_clear": "✕ Limpiar",
"log_delete_failed": "Error al eliminar",
"log_dir_all": "Todos",
"log_dir_label": "Dirección:",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ Descargar",
"log_error": "Error:", "log_error": "Error:",
"confirm_cancel": "¿Realmente cancelar la impresión?", "log_fan": "Ventilador →",
"settings_title": "Configuración", "log_filter_placeholder": "Filtrar…",
"settings_connection": "Conexión", "log_home": "Home",
"settings_print": "Ajustes de impresión", "log_home_all": "Home All",
"settings_poll": "Intervalo de sondeo (segundos)", "log_light_off": "Luz apagada",
"log_light_on": "Luz encendida",
"log_lvl_err": "⛔ Errores",
"log_lvl_label": "Nivel:",
"log_lvl_warn": "⚠ Avisos",
"log_nozzle": "Boquilla →",
"log_poll_error": "Error de sondeo:",
"log_print_action": "Impresión:",
"log_print_start": "Inicio de impresión:",
"log_topic_ams": "AMS",
"log_topic_info": "Info",
"log_topic_label": "Tema:",
"log_topic_print": "Impresión",
"log_topic_status": "Estado",
"nav_ams": "AMS",
"nav_browser": "Explorador",
"nav_console": "Consola",
"nav_dashboard": "Panel",
"nav_extras": "Luz / Ventilador",
"nav_motion": "Movimiento",
"nav_print": "Impresión",
"nav_printers": "Impresoras",
"nav_settings": "Ajustes", "nav_settings": "Ajustes",
"settings_cat_display": "Apariencia", "nav_temps": "Temperaturas",
"settings_cat_filament": "Filamento", "orca_profile_done": "Importado",
"settings_cat_language": "Idioma", "orca_profile_dropmsg": "Suelta aquí o haz clic",
"settings_cat_theme": "Alternar claro / oscuro", "orca_profile_help_html": "Sube un <b>ZIP</b> de tu carpeta de filamentos de OrcaSlicer o archivos <b>.json</b> sueltos.<br>En OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "Asignación de perfil de filamento (por ranura)",
"settings_filament_mapping_save": "Guardar asignación",
"settings_visible_vendors": "Fabricantes visibles (lista de perfiles)",
"settings_visible_vendors_hint": "Solo estos fabricantes aparecen en la lista de perfiles de ranura. Nada seleccionado = mostrar todos. «Generic» y tus propios perfiles siempre son visibles.",
"settings_visible_vendors_save": "Guardar selección",
"progress_action_print": "Imprimir",
"progress_action_slots": "Asignar ranuras",
"progress_action_clear": "Vaciar",
"settings_version": "Versión",
"settings_save": "Guardar y reiniciar",
"settings_printer_name": "Nombre de impresora",
"settings_printer_ip": "IP de impresora",
"settings_mqtt_port": "MQTT Port",
"settings_username": "Usuario MQTT",
"settings_password": "Contraseña MQTT",
"settings_device_id": "ID del dispositivo",
"settings_mode_id": "ID de modo",
"hint_ip_no_port": "Solo dirección IP, sin puerto (p. ej. 192.168.1.102)",
"settings_default_slot": "Ranura predeterminada (un color)",
"settings_slot_auto": "Auto (todos los slots cargados)",
"settings_auto_leveling": "Autonivelado antes de imprimir",
"settings_camera_on_print": "Encender cámara al iniciar impresión",
"settings_web_upload_warning": "Mostrar advertencia al imprimir subidas web",
"update_check": "Buscar actualizaciones",
"update_checking": "Comprobando...",
"update_available": "disponible",
"update_none": "Ya actualizado",
"update_apply": "Instalar ahora",
"update_applying": "Descargando...",
"update_restarting": "Reiniciando...",
"update_error": "Error",
"btn_connect": "⚡ Conectar",
"btn_disconnect": "✕ Desconectar",
"lbl_conn_error": "Error de conexión:",
"slot_edit_title": "Editar slot",
"slot_edit_color": "Color",
"slot_edit_material": "Material",
"slot_edit_load": "⬇ Cargar",
"slot_edit_unload": "⬆ Descargar",
"slot_edit_save": "💾 Guardar",
"slot_edit_custom": "p. ej. PLA, PETG, ABS…",
"slot_edit_ok": "Ranura AMS",
"slot_edit_profile": "Perfil de OrcaSlicer",
"slot_edit_profile_hint": "Envía al sincronizar con OrcaSlicer la marca concreta en lugar de solo \"Generic\"",
"slot_edit_profile_default": "— Genérico (Predeterminado) —",
"orca_profile_section": "Perfiles de OrcaSlicer",
"orca_profile_hint": "Importa tus propios perfiles de filamento de OrcaSlicer (abre el directorio del usuario vía Help → Show Configuration Folder)", "orca_profile_hint": "Importa tus propios perfiles de filamento de OrcaSlicer (abre el directorio del usuario vía Help → Show Configuration Folder)",
"orca_profile_import_btn": "Importar perfiles", "orca_profile_import_btn": "Importar perfiles",
"orca_profile_import_link": "★ Importar perfiles propios…", "orca_profile_import_link": "★ Importar perfiles propios…",
"orca_profile_import_title": "Importar tus perfiles de OrcaSlicer", "orca_profile_import_title": "Importar tus perfiles de OrcaSlicer",
"orca_profile_help_html": "Sube un <b>ZIP</b> de tu carpeta de filamentos de OrcaSlicer o archivos <b>.json</b> sueltos.<br>En OrcaSlicer: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "Suelta aquí o haz clic",
"orca_profile_list_label": "Actualmente importados", "orca_profile_list_label": "Actualmente importados",
"orca_profile_user_label": "Perfiles propios", "orca_profile_section": "Perfiles de OrcaSlicer",
"orca_profile_user_empty": " ninguno ",
"orca_profile_uploading": "Subiendo…",
"orca_profile_done": "Importado",
"orca_profile_skipped": "omitido", "orca_profile_skipped": "omitido",
"log_dir_all": "Todos", "orca_profile_uploading": "Subiendo",
"log_lvl_label": "Nivel:", "orca_profile_user_empty": " ninguno ",
"file_ready_btn": "▶ Iniciar impresión", "orca_profile_user_label": "Perfiles propios",
"file_slots_btn": "🎨 Seleccionar ranuras", "panel_ams_title": "Filamento",
"file_cancel_btn": "✕ Cancelar", "panel_browser_title": "Explorador de archivos",
"nav_printers": "Impresoras", "panel_console_title": "Registro de eventos",
"skip_title": "✂ Omitir objetos", "panel_extras_camera": "Cámara",
"skip_hint": "Deselecciona los objetos que ya no quieras imprimir:", "panel_extras_fan": "Ventilador",
"skip_btn_label": "Objetos", "panel_extras_light": "Luz",
"skip_no_objects": "No hay objetos en esta impresión.", "panel_motion_xy": "Ejes XY",
"panel_motion_z": "Eje Z",
"panel_print_btn_cancel": "✕ Cancelar",
"panel_print_btn_pause": "⏸ Pausa",
"panel_print_btn_resume": "▶ Reanudar",
"panel_print_temps_live": "Temperaturas (en vivo)",
"panel_print_title": "Control de impresión",
"panel_temps_bed": "Cama caliente",
"panel_temps_chart": "Historial (últimas 60 lecturas)",
"panel_temps_nozzle": "Boquilla",
"print_auto_leveling": "Autonivelado para esta impresión",
"printers_active": "● activa",
"printers_current": "Impresora actual",
"printers_empty_hint": "Aún no hay impresora configurada.",
"printers_loading": "Cargando…",
"printers_none": "No hay impresoras configuradas.",
"printers_remove": "Eliminar impresora",
"printers_remove_confirm": "¿Eliminar impresora \"{name}\"? El bridge se reiniciará.",
"printers_switch": "Cambiar →",
"progress_action_clear": "Vaciar",
"progress_action_print": "Imprimir",
"progress_action_slots": "Asignar ranuras",
"settings_auto_leveling": "Autonivelado antes de imprimir",
"settings_auto_leveling_label": "Autonivelado antes de imprimir",
"settings_btn_tooltip": "Ajustes",
"settings_camera_on_print": "Encender cámara al iniciar impresión",
"settings_cat_connection": "Conexión",
"settings_cat_display": "Apariencia",
"settings_cat_filament": "Filamento",
"settings_cat_language": "Idioma",
"settings_cat_printer": "Impresora",
"settings_cat_system": "Sistema",
"settings_cat_theme": "Alternar claro / oscuro",
"settings_connection": "Conexión",
"settings_default_slot": "Ranura predeterminada (un color)",
"settings_device_id": "ID del dispositivo",
"settings_device_id_hint": "32 caracteres hexadecimales",
"settings_device_id_placeholder": "32 caracteres hexadecimales",
"settings_filament_mapping": "Asignación de perfil de filamento (por ranura)",
"settings_filament_mapping_hint": "Perfil Orca fijo por ranura AMS. Al sincronizar con el slicer, el bridge envía este perfil en lugar de \"Generic\".",
"settings_filament_mapping_label": "Asignación de perfil de filamento (por ranura)",
"settings_filament_mapping_save": "Guardar asignación",
"settings_filament_mapping_save_label": "Guardar asignación",
"settings_file_ready_banner": "Barra de impresión",
"settings_file_ready_dialog": "Diálogo de impresión",
"settings_file_ready_mode": "Después de carga: Comportamiento de inicio de impresión",
"settings_language": "Idioma",
"settings_mode_id": "ID de modo",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "MQTT Port",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "Importar perfiles",
"settings_orca_profiles_label": "Perfiles de OrcaSlicer",
"settings_password": "Contraseña MQTT",
"settings_poll": "Intervalo de sondeo (segundos)",
"settings_poll_interval_hint": "Con qué frecuencia el bridge consulta el estado de la impresora",
"settings_poll_interval_label": "Intervalo de sondeo (segundos)",
"settings_print": "Ajustes de impresión",
"settings_printer_ip": "IP de impresora",
"settings_printer_name": "Nombre de impresora",
"settings_printer_name_placeholder": "p. ej. Kobra X Sala",
"settings_save": "Guardar y reiniciar",
"settings_slot_auto": "Auto (todos los slots cargados)",
"settings_theme_toggle": "Alternar claro / oscuro",
"settings_title": "Configuración",
"settings_username": "Usuario MQTT",
"settings_vendor_filter_placeholder": "Buscar fabricantes…",
"settings_version": "Versión",
"settings_visible_vendors": "Fabricantes visibles (lista de perfiles)",
"settings_visible_vendors_hint": "Solo estos fabricantes aparecen en la lista de perfiles de ranura. Nada seleccionado = mostrar todos. «Generic» y tus propios perfiles siempre son visibles.",
"settings_visible_vendors_label": "Fabricantes visibles (lista de perfiles)",
"settings_visible_vendors_save": "Guardar selección",
"settings_visible_vendors_save_label": "Guardar selección",
"settings_web_upload_warning": "Mostrar advertencia al imprimir subidas web",
"sf_all": "Todos",
"sf_err": "✗ Fallido",
"sf_new": "Nuevo",
"sf_ok": "✓ Completado",
"skip_already": "omitido", "skip_already": "omitido",
"skip_btn_label": "Objetos",
"skip_cancel": "Cancelar",
"skip_confirm": "Omitir",
"skip_confirm_btn": "Omitir",
"skip_hint": "Deselecciona los objetos que ya no quieras imprimir:",
"skip_no_objects": "No hay objetos en esta impresión.",
"skip_select_at_least_one": "Selecciona al menos un objeto.", "skip_select_at_least_one": "Selecciona al menos un objeto.",
"skip_sending": "Enviando …", "skip_sending": "Enviando …",
"skip_success": "Se omitirán los objetos.", "skip_success": "Se omitirán los objetos.",
"fd_objects_hint": "Omitir objetos (opcional):", "skip_title": "Omitir objetos",
"fd_objects_toggle": "Omitir objetos", "slot_edit_color": "Color",
"fd_slots_hint": "Asignar canal GCode a la ranura AMS:", "slot_edit_custom": "p. ej. PLA, PETG, ABS…",
"fd_cancel": "Cancelar", "slot_edit_load": "⬇ Cargar",
"fd_print": "▶ Imprimir", "slot_edit_material": "Material",
"fd_no_slots_msg": "No hay slots AMS cargados.{br}¿Iniciar impresión de todos modos?", "slot_edit_ok": "Ranura AMS",
"fd_slot": "Ranura", "slot_edit_profile": "Perfil de OrcaSlicer",
"fd_no_matching_material": "No hay material compatible", "slot_edit_profile_default": "— Genérico (Predeterminado) —",
"fd_used": "USADO", "slot_edit_profile_hint": "Envía al sincronizar con OrcaSlicer la marca concreta en lugar de solo \"Generic\"",
"add_printer": "Añadir impresora", "slot_edit_save": "💾 Guardar",
"apd_lbl_ip": "IP de impresora", "slot_edit_title": "Editar slot",
"apd_lbl_name": "Nombre (opcional)", "slot_edit_unload": "⬆ Descargar",
"apd_placeholder_name": "p. ej. Kobra X Sala", "speed_normal": "⚡ Normal",
"apd_cancel": "Cancelar", "speed_silent": "🐢 Silencioso",
"apd_confirm": "Añadir", "speed_sport": "🚀 Sport",
"apd_fetching": "Obteniendo datos de la impresora…",
"apd_success": "Impresora añadida, reiniciando bridge…",
"apd_err_ip": "Introduce una dirección IP",
"printers_remove": "Eliminar impresora",
"printers_remove_confirm": "¿Eliminar impresora \"{name}\"? El bridge se reiniciará.",
"printers_active": "● activa",
"printers_switch": "Cambiar →",
"printers_current": "Impresora actual",
"printers_loading": "Cargando…",
"printers_none": "No hay impresoras configuradas.",
"printers_empty_hint": "Aún no hay impresora configurada.",
"nav_browser": "Explorador",
"panel_browser_title": "Explorador de archivos",
"store_search_placeholder": "🔍 Buscar…",
"store_empty": "Aún no hay archivos subidos.",
"store_refresh": "↻ Actualizar",
"store_print": "▶ Imprimir",
"store_download": "⬇ Descargar",
"store_delete_confirm": "¿Eliminar archivo?",
"store_print_confirm": "¿Imprimir archivo?",
"store_web_verify_title": "Verificar archivo",
"store_web_verify_msg": "Verifica que este archivo fue creado para Anycubic Kobra X.",
"store_web_verify_confirm": "Confirmar",
"store_web_verify_abort": "Abortar",
"store_no_results": "No se encontraron archivos.",
"store_never": "nunca impreso",
"store_estimate": "Estimación",
"store_upload_label_prefix": "Arrastra el GCode aquí o ",
"store_upload_label_browse": "buscar",
"store_upload_busy": "⏳ Subiendo…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ Solo se permiten archivos GCode (.gcode, .3mf, .bgcode)",
"sf_all": "Todos",
"sf_ok": "✓ Completado",
"sf_err": "✗ Fallido",
"sf_new": "Nuevo",
"ss_date": "↓ Fecha", "ss_date": "↓ Fecha",
"ss_name": "AZ Nombre",
"ss_dur": "⏱ Tiempo de impresión", "ss_dur": "⏱ Tiempo de impresión",
"ace_dry_preset_pla": "PLA", "ss_name": "AZ Nombre",
"ace_dry_preset_pla_plus": "PLA+", "store_delete_confirm": "¿Eliminar archivo?",
"ace_dry_preset_petg": "PETG", "store_download": "⬇ Descargar",
"ace_dry_preset_tpu": "TPU", "store_empty": "Aún no hay archivos subidos.",
"ace_dry_preset_abs_asa": "ABS / ASA", "store_estimate": "Estimación",
"ace_dry_preset_pa_pc": "PA / PC", "store_never": "nunca impreso",
"ace_dry_preset_custom": "Personalizado", "store_no_results": "No se encontraron archivos.",
"fd_options_title": "Opciones", "store_print": "▶ Imprimir",
"print_auto_leveling": "Autonivelado para esta impresión", "store_print_confirm": "¿Imprimir archivo?",
"settings_file_ready_mode": "Iniciar diálogo de impresión", "store_refresh": "↻ Actualizar",
"settings_file_ready_banner": "Barra de impresión", "store_search_placeholder": "🔍 Buscar…",
"settings_file_ready_dialog": "Diálogo de impresión", "store_upload_busy": "⏳ Subiendo…",
"log_dir_rx": "RX", "store_upload_error": "✗ {error}",
"log_dir_tx": "TX", "store_upload_label_browse": "buscar",
"log_dir_label": "Dirección:", "store_upload_label_prefix": "Arrastra el GCode aquí o ",
"log_lvl_err": "⛔ Errores", "store_upload_only_gcode": "✗ Solo se permiten archivos GCode (.gcode, .3mf, .bgcode)",
"log_lvl_warn": "⚠ Avisos", "store_upload_success": "✓ {file}",
"log_topic_label": "Tema:", "store_web_verify_abort": "Cancelar",
"log_topic_ams": "AMS", "store_web_verify_confirm": "Confirmar",
"log_topic_print": "Impresión", "store_web_verify_msg": "Verifica que este archivo fue hecho para Anycubic Kobra X.",
"log_topic_info": "Info", "store_web_verify_title": "Verificar archivo",
"log_topic_status": "Estado", "update_apply": "Instalar ahora",
"log_download": "Descargar", "update_applying": "Descargando...",
"log_auto": "⬇ Auto", "update_available": "disponible",
"log_clear": "✕ Limpiar", "update_check": "Buscar actualizaciones",
"log_filter_placeholder": "Filtrar…", "update_checking": "Comprobando...",
"skip_cancel": "Cancelar", "update_error": "Error",
"skip_confirm": "Omitir" "update_none": "Ya actualizado",
"update_restarting": "Reiniciando..."
} }

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "Prêt", "ace_dry_auto_refill": "Remplissage auto",
"header_status_printing": "Impression", "ace_dry_chart": "Historique (Temp/Humidité)",
"header_status_complete": "Terminé", "ace_dry_current_temp": "Température",
"header_status_error": "Erreur", "ace_dry_dialog_cancel": "Annuler",
"kobra_free": "Disponible", "ace_dry_dialog_confirm": "Confirmer",
"kobra_busy": "Occupé", "ace_dry_dialog_custom_name": "Nom personnalisé",
"kobra_printing": "Impression", "ace_dry_dialog_reset_default": "Réinitialiser",
"kobra_preheating": "Préchauffage", "ace_dry_dialog_save_restart": "Enregistrer et redémarrer",
"kobra_auto_leveling": "Mise à niveau auto", "ace_dry_dialog_temp": "Température (30-80°C)",
"kobra_checking": "Vérification", "ace_dry_dialog_time": "Temps restant (h:m:s)",
"kobra_updated": "Mise à jour", "ace_dry_dialog_title": "Réglages Temp/Durée du séchoir",
"kobra_init": "Initialisation",
"kobra_pausing": "Pause en cours…",
"kobra_paused": "En pause",
"kobra_resuming": "Reprise en cours…",
"kobra_resumed": "Repris",
"kobra_stopping": "Arrêt en cours…",
"kobra_stoped": "Arrêté",
"kobra_finished": "Terminé",
"kobra_failed": "Erreur",
"kobra_canceled": "Annulé",
"kobra_offline": "Hors ligne",
"nav_dashboard": "Tableau de bord",
"nav_print": "Impression",
"nav_temps": "Températures",
"nav_motion": "Mouvement",
"nav_ams": "AMS",
"nav_extras": "Lumière / Ventilateur",
"nav_console": "Console",
"card_progress": "Progression",
"card_temps": "Températures",
"card_light_fan": "Ventilateur",
"card_speed": "Vitesse d'impression",
"card_cam": "Caméra",
"lbl_elapsed": "Écoulé :",
"lbl_remaining": "Restant :",
"lbl_slicer_time": "Estimation slicer :",
"lbl_layers": "Couche",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 Silencieux",
"speed_normal": "⚡ Normal",
"speed_sport": "🚀 Sport",
"lbl_light": "💡 Lumière",
"lbl_feed": "Charger",
"lbl_unload": "Décharger",
"card_ace_dry": "Séchage ACE",
"ace_dry_dryer": "Séchoir", "ace_dry_dryer": "Séchoir",
"ace_dry_duration": "Durée (min)",
"ace_dry_enable": "Activer le séchage",
"ace_dry_humidity": "Humidité",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "Personnalisé",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ Démarrer",
"ace_dry_status_off": "Statut : Arrêté", "ace_dry_status_off": "Statut : Arrêté",
"ace_dry_status_on": "Statut : Actif", "ace_dry_status_on": "Statut : Actif",
"ace_dry_status_remaining": "Restant", "ace_dry_status_remaining": "Restant",
"ace_dry_humidity": "Humidité",
"ace_dry_current_temp": "Température",
"ace_dry_chart": "Historique (Temp/Humidité)",
"ace_dry_temp": "Température (°C)",
"ace_dry_duration": "Durée (min)",
"ace_dry_start": "▶ Démarrer",
"ace_dry_stop": "■ Arrêter", "ace_dry_stop": "■ Arrêter",
"ace_dry_auto_refill": "Remplissage auto", "ace_dry_temp": "Température (°C)",
"ace_dry_enable": "Activer le séchage",
"ace_dry_temp_line": "Température de séchage", "ace_dry_temp_line": "Température de séchage",
"ace_dry_time_line": "Durée de séchage", "ace_dry_time_line": "Durée de séchage",
"ace_dry_ui_pending": "(Interface seule, backend suivant)", "ace_dry_ui_pending": "(Interface seule, backend suivant)",
"ace_dry_dialog_title": "Réglages Temp/Durée du séchoir", "add_printer": "Ajouter une imprimante",
"ace_dry_dialog_temp": "Température (30-80°C)", "ams_empty": "Vide",
"ace_dry_dialog_time": "Temps restant (h:m:s)", "ams_no_data": "Aucune donnée AMS reçue",
"ace_dry_dialog_confirm": "Confirmer", "apd_cancel": "Annuler",
"ace_dry_dialog_cancel": "Annuler", "apd_confirm": "Ajouter",
"ace_dry_dialog_save_restart": "Enregistrer et redémarrer", "apd_err_ip": "Veuillez saisir une adresse IP",
"ace_dry_dialog_custom_name": "Nom personnalisé", "apd_fetching": "Récupération des données de l'imprimante…",
"ace_dry_dialog_reset_default": "Réinitialiser", "apd_lbl_ip": "IP de l'imprimante",
"cam_placeholder": "📷 Caméra non démarrée", "apd_lbl_name": "Nom (optionnel)",
"cam_stream_unavailable": "Flux indisponible", "apd_placeholder_name": "ex. Kobra X Salon",
"apd_success": "Imprimante ajoutée, redémarrage du bridge…",
"apd_title": "Ajouter une imprimante",
"btn_cam_start": "▶ Caméra", "btn_cam_start": "▶ Caméra",
"btn_cam_start2": "▶ Démarrer",
"btn_cam_stop": "◼ Caméra", "btn_cam_stop": "◼ Caméra",
"btn_cam_stop2": "◼ Arrêter",
"btn_cancel": "✕ Arrêter",
"btn_cancel_generic": "Annuler",
"btn_confirm_generic": "Confirmer",
"btn_connect": "⚡ Connecter",
"btn_delete": "Supprimer",
"btn_disable_motors": "Moteurs Off",
"btn_disconnect": "✕ Déconnecter",
"btn_home_all": "Origine Tout",
"btn_home_xy": "Origine XY",
"btn_home_z": "Origine Z",
"btn_pause": "⏸ Pause", "btn_pause": "⏸ Pause",
"btn_resume": "▶ Reprendre", "btn_resume": "▶ Reprendre",
"btn_cancel": "✕ Arrêter", "cam_placeholder": "📷 Caméra non démarrée",
"label_nozzle": "Buse", "cam_stream_unavailable": "Flux indisponible",
"card_ace_dry": "Séchage ACE",
"card_ams": "Filament",
"card_cam": "Caméra",
"card_light_fan": "Ventilateur",
"card_progress": "Progression",
"card_speed": "Vitesse d'impression",
"card_temps": "Températures",
"confirm_cancel": "Vraiment annuler l'impression ?",
"fd_cancel": "Annuler",
"fd_no_matching_material": "Aucun matériau correspondant",
"fd_no_slots_msg": "Aucun slot AMS chargé.{br}Lancer l'impression quand même ?",
"fd_objects_hint": "Ignorer des objets (optionnel) :",
"fd_objects_toggle": "Ignorer des objets",
"fd_options_title": "Options",
"fd_print": "▶ Imprimer",
"fd_slot": "Slot",
"fd_slots_hint": "Associer le canal GCode au slot AMS :",
"fd_title": "Attribution de fente",
"fd_used": "UTILISÉ",
"file_cancel_btn": "✕ Annuler",
"file_ready_btn": "▶ Lancer l'impression",
"file_slots_btn": "🎨 Choisir les slots",
"header_status_complete": "Terminé",
"header_status_error": "Erreur",
"header_status_printing": "Impression",
"header_status_standby": "Prêt",
"hint_ip_no_port": "Adresse IP uniquement, sans port (ex. 192.168.1.102)",
"kobra_auto_leveling": "Mise à niveau auto",
"kobra_busy": "Occupé",
"kobra_canceled": "Annulé",
"kobra_checking": "Vérification",
"kobra_failed": "Erreur",
"kobra_finished": "Terminé",
"kobra_free": "Disponible",
"kobra_init": "Initialisation",
"kobra_offline": "Hors ligne",
"kobra_paused": "En pause",
"kobra_pausing": "Pause en cours…",
"kobra_preheating": "Préchauffage",
"kobra_printing": "Impression",
"kobra_resumed": "Repris",
"kobra_resuming": "Reprise en cours…",
"kobra_stoped": "Arrêté",
"kobra_stopping": "Arrêt en cours…",
"kobra_updated": "Mise à jour",
"label_bed": "Plateau", "label_bed": "Plateau",
"label_fan": "🌀 Ventilateur", "label_fan": "🌀 Ventilateur",
"label_light": "💡 Lumière", "label_light": "💡 Lumière",
"label_on_off": "On / Off", "label_nozzle": "Buse",
"label_speed": "Vitesse",
"panel_print_title": "Contrôle impression",
"panel_print_btn_pause": "⏸ Pause",
"panel_print_btn_resume": "▶ Reprendre",
"panel_print_btn_cancel": "✕ Annuler",
"panel_print_temps_live": "Températures (en direct)",
"label_set": "Définir",
"label_off": "Éteint", "label_off": "Éteint",
"panel_temps_nozzle": "Buse", "label_on_off": "On / Off",
"panel_temps_bed": "Plateau chauffant", "label_set": "Définir",
"panel_temps_chart": "Historique (60 dernières valeurs)",
"label_target_c": "Cible :",
"panel_motion_xy": "Axes XY",
"panel_motion_z": "Axe Z",
"label_step": "Pas :",
"btn_home_z": "Origine Z",
"btn_home_xy": "Origine XY",
"btn_home_all": "Origine Tout",
"btn_disable_motors": "Moteurs Off",
"panel_ams_title": "Filament",
"card_ams": "Filament",
"ams_no_data": "Aucune donnée AMS reçue",
"label_slot": "Slot", "label_slot": "Slot",
"ams_empty": "Vide", "label_speed": "Vitesse",
"panel_extras_light": "Lumière", "label_step": "Pas :",
"panel_extras_fan": "Ventilateur", "label_target_c": "Cible :",
"panel_extras_camera": "Caméra", "lbl_conn_error": "Erreur de connexion :",
"btn_cam_start2": "▶ Démarrer", "lbl_elapsed": "Écoulé :",
"btn_cam_stop2": "◼ Arrêter", "lbl_feed": "Charger",
"panel_console_title": "Journal d'événements", "lbl_layers": "Couche",
"log_light_on": "Lumière allumée", "lbl_light": "💡 Lumière",
"log_light_off": "Lumière éteinte", "lbl_remaining": "Restant :",
"log_fan": "Ventilateur ", "lbl_slicer_time": "Estimation slicer :",
"log_nozzle": "Buse →", "lbl_unload": "Décharger",
"log_bed": "Plateau →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ Auto",
"log_axis": "Axe", "log_axis": "Axe",
"log_home": "Origine", "log_bed": "Plateau →",
"log_home_all": "Origine Tout",
"log_cam_start": "Caméra démarrée :", "log_cam_start": "Caméra démarrée :",
"log_cam_stop": "Caméra arrêtée", "log_cam_stop": "Caméra arrêtée",
"log_poll_error": "Erreur de sondage :", "log_clear": "✕ Effacer",
"log_delete_failed": "Échec de la suppression",
"log_dir_all": "Tout",
"log_dir_label": "Sens :",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ Télécharger",
"log_error": "Erreur :", "log_error": "Erreur :",
"confirm_cancel": "Vraiment annuler l'impression ?", "log_fan": "Ventilateur →",
"settings_title": "Paramètres", "log_filter_placeholder": "Filtrer…",
"settings_connection": "Connexion", "log_home": "Origine",
"settings_print": "Paramètres d'impression", "log_home_all": "Origine Tout",
"settings_poll": "Intervalle de sondage (secondes)", "log_light_off": "Lumière éteinte",
"log_light_on": "Lumière allumée",
"log_lvl_err": "⛔ Erreurs",
"log_lvl_label": "Niveau :",
"log_lvl_warn": "⚠ Avert.",
"log_nozzle": "Buse →",
"log_poll_error": "Erreur de sondage :",
"log_print_action": "Impression :",
"log_print_start": "Début de l'impression :",
"log_topic_ams": "AMS",
"log_topic_info": "Info",
"log_topic_label": "Sujet :",
"log_topic_print": "Impression",
"log_topic_status": "Statut",
"nav_ams": "AMS",
"nav_browser": "Navigateur",
"nav_console": "Console",
"nav_dashboard": "Tableau de bord",
"nav_extras": "Lumière / Ventilateur",
"nav_motion": "Mouvement",
"nav_print": "Impression",
"nav_printers": "Imprimantes",
"nav_settings": "Paramètres", "nav_settings": "Paramètres",
"settings_cat_display": "Apparence", "nav_temps": "Températures",
"settings_cat_filament": "Filament", "orca_profile_done": "Importé",
"settings_cat_language": "Langue", "orca_profile_dropmsg": "Déposez ici ou cliquez",
"settings_cat_theme": "Basculer clair / sombre", "orca_profile_help_html": "Déposez un <b>ZIP</b> de votre dossier filament OrcaSlicer ou des fichiers <b>.json</b> individuels.<br>Dans OrcaSlicer : <i>Aide → Afficher le dossier de configuration → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "Mappage du profil de filament (par emplacement)",
"settings_filament_mapping_save": "Enregistrer le mappage",
"settings_visible_vendors": "Fabricants visibles (liste des profils)",
"settings_visible_vendors_hint": "Seuls ces fabricants apparaissent dans la liste des profils d'emplacement. Rien de sélectionné = tout afficher. « Generic » et vos propres profils sont toujours visibles.",
"settings_visible_vendors_save": "Enregistrer la sélection",
"progress_action_print": "Imprimer",
"progress_action_slots": "Affecter les emplacements",
"progress_action_clear": "Vider",
"settings_version": "Version",
"settings_save": "Enregistrer et redémarrer",
"settings_printer_name": "Nom de l'imprimante",
"settings_printer_ip": "IP de l'imprimante",
"settings_mqtt_port": "Port MQTT",
"settings_username": "Nom d'utilisateur MQTT",
"settings_password": "Mot de passe MQTT",
"settings_device_id": "ID de l'appareil",
"settings_mode_id": "ID du mode",
"hint_ip_no_port": "Adresse IP uniquement, sans port (ex. 192.168.1.102)",
"settings_default_slot": "Slot par défaut (couleur unique)",
"settings_slot_auto": "Auto (tous les slots chargés)",
"settings_auto_leveling": "Mise à niveau auto avant impression",
"settings_camera_on_print": "Activer la caméra au démarrage de l'impression",
"settings_web_upload_warning": "Afficher un avertissement lors de l'impression de fichiers web",
"update_check": "Vérifier les mises à jour",
"update_checking": "Vérification…",
"update_available": "disponible",
"update_none": "Déjà à jour",
"update_apply": "Installer maintenant",
"update_applying": "Téléchargement…",
"update_restarting": "Redémarrage…",
"update_error": "Erreur",
"btn_connect": "⚡ Connecter",
"btn_disconnect": "✕ Déconnecter",
"lbl_conn_error": "Erreur de connexion :",
"slot_edit_title": "Modifier le slot",
"slot_edit_color": "Couleur",
"slot_edit_material": "Matériau",
"slot_edit_load": "⬇ Charger",
"slot_edit_unload": "⬆ Décharger",
"slot_edit_save": "💾 Enregistrer",
"slot_edit_custom": "ex. PLA, PETG, ABS…",
"slot_edit_ok": "Slot AMS",
"slot_edit_profile": "Profil OrcaSlicer",
"slot_edit_profile_hint": "Envoyé lors de la synchronisation OrcaSlicer comme marque spécifique au lieu de \"Générique\"",
"slot_edit_profile_default": "— Générique (défaut) —",
"orca_profile_section": "Profils OrcaSlicer",
"orca_profile_hint": "Importez vos propres profils de filament OrcaSlicer (ouvrez le dossier utilisateur via Aide → Afficher le dossier de configuration)", "orca_profile_hint": "Importez vos propres profils de filament OrcaSlicer (ouvrez le dossier utilisateur via Aide → Afficher le dossier de configuration)",
"orca_profile_import_btn": "Importer des profils", "orca_profile_import_btn": "Importer des profils",
"orca_profile_import_link": "★ Importer mes profils…", "orca_profile_import_link": "★ Importer mes profils…",
"orca_profile_import_title": "Importer vos profils OrcaSlicer", "orca_profile_import_title": "Importer vos profils OrcaSlicer",
"orca_profile_help_html": "Déposez un <b>ZIP</b> de votre dossier filament OrcaSlicer ou des fichiers <b>.json</b> individuels.<br>Dans OrcaSlicer : <i>Aide → Afficher le dossier de configuration → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "Déposez ici ou cliquez",
"orca_profile_list_label": "Profils importés", "orca_profile_list_label": "Profils importés",
"orca_profile_user_label": "Mes profils", "orca_profile_section": "Profils OrcaSlicer",
"orca_profile_user_empty": " aucun ",
"orca_profile_uploading": "Envoi en cours…",
"orca_profile_done": "Importé",
"orca_profile_skipped": "ignoré", "orca_profile_skipped": "ignoré",
"log_dir_all": "Tout", "orca_profile_uploading": "Envoi en cours…",
"log_lvl_label": "Niveau :", "orca_profile_user_empty": " aucun ",
"file_ready_btn": "▶ Lancer l'impression", "orca_profile_user_label": "Mes profils",
"file_slots_btn": "🎨 Choisir les slots", "panel_ams_title": "Filament",
"file_cancel_btn": "✕ Annuler", "panel_browser_title": "Explorateur de fichiers",
"nav_printers": "Imprimantes", "panel_console_title": "Journal d'événements",
"skip_title": "✂ Ignorer des objets", "panel_extras_camera": "Caméra",
"skip_hint": "Décochez les objets que vous ne souhaitez plus imprimer :", "panel_extras_fan": "Ventilateur",
"skip_btn_label": "Objets", "panel_extras_light": "Lumière",
"skip_no_objects": "Aucun objet dans cette impression.", "panel_motion_xy": "Axes XY",
"panel_motion_z": "Axe Z",
"panel_print_btn_cancel": "✕ Annuler",
"panel_print_btn_pause": "⏸ Pause",
"panel_print_btn_resume": "▶ Reprendre",
"panel_print_temps_live": "Températures (en direct)",
"panel_print_title": "Contrôle impression",
"panel_temps_bed": "Plateau chauffant",
"panel_temps_chart": "Historique (60 dernières valeurs)",
"panel_temps_nozzle": "Buse",
"print_auto_leveling": "Mise à niveau auto pour cette impression",
"printers_active": "● actif",
"printers_current": "Imprimante actuelle",
"printers_empty_hint": "Aucune imprimante configurée.",
"printers_loading": "Chargement…",
"printers_none": "Aucune imprimante configurée.",
"printers_remove": "Supprimer l'imprimante",
"printers_remove_confirm": "Supprimer l'imprimante \"{name}\" ? Le bridge va redémarrer.",
"printers_switch": "Changer →",
"progress_action_clear": "Vider",
"progress_action_print": "Imprimer",
"progress_action_slots": "Affecter les emplacements",
"settings_auto_leveling": "Mise à niveau auto avant impression",
"settings_auto_leveling_label": "Mise à niveau auto avant impression",
"settings_btn_tooltip": "Paramètres",
"settings_camera_on_print": "Activer la caméra au démarrage de l'impression",
"settings_cat_connection": "Connexion",
"settings_cat_display": "Apparence",
"settings_cat_filament": "Filament",
"settings_cat_language": "Langue",
"settings_cat_printer": "Imprimante",
"settings_cat_system": "Système",
"settings_cat_theme": "Basculer clair / sombre",
"settings_connection": "Connexion",
"settings_default_slot": "Slot par défaut (couleur unique)",
"settings_device_id": "ID de l'appareil",
"settings_device_id_hint": "32 caractères hexadécimaux",
"settings_device_id_placeholder": "32 caractères hexadécimaux",
"settings_filament_mapping": "Mappage du profil de filament (par emplacement)",
"settings_filament_mapping_hint": "Profil Orca fixe par emplacement AMS. Lors de la synchronisation du slicer, le bridge envoie ce profil au lieu de « Generic ».",
"settings_filament_mapping_label": "Mappage du profil de filament (par emplacement)",
"settings_filament_mapping_save": "Enregistrer le mappage",
"settings_filament_mapping_save_label": "Enregistrer le mappage",
"settings_file_ready_banner": "Barre d'impression",
"settings_file_ready_dialog": "Dialogue d'impression",
"settings_file_ready_mode": "Après téléchargement : Comportement de démarrage d'impression",
"settings_language": "Langue",
"settings_mode_id": "ID du mode",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "Port MQTT",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "Importer des profils",
"settings_orca_profiles_label": "Profils OrcaSlicer",
"settings_password": "Mot de passe MQTT",
"settings_poll": "Intervalle de sondage (secondes)",
"settings_poll_interval_hint": "Fréquence à laquelle le bridge interroge l'état de l'imprimante",
"settings_poll_interval_label": "Intervalle de sondage (secondes)",
"settings_print": "Paramètres d'impression",
"settings_printer_ip": "IP de l'imprimante",
"settings_printer_name": "Nom de l'imprimante",
"settings_printer_name_placeholder": "p. ex. Kobra X Salon",
"settings_save": "Enregistrer et redémarrer",
"settings_slot_auto": "Auto (tous les slots chargés)",
"settings_theme_toggle": "Basculer clair / sombre",
"settings_title": "Paramètres",
"settings_username": "Nom d'utilisateur MQTT",
"settings_vendor_filter_placeholder": "Rechercher des fabricants…",
"settings_version": "Version",
"settings_visible_vendors": "Fabricants visibles (liste des profils)",
"settings_visible_vendors_hint": "Seuls ces fabricants apparaissent dans la liste des profils d'emplacement. Rien de sélectionné = tout afficher. « Generic » et vos propres profils sont toujours visibles.",
"settings_visible_vendors_label": "Fabricants visibles (liste des profils)",
"settings_visible_vendors_save": "Enregistrer la sélection",
"settings_visible_vendors_save_label": "Enregistrer la sélection",
"settings_web_upload_warning": "Afficher un avertissement lors de l'impression de fichiers web",
"sf_all": "Tout",
"sf_err": "✗ Échoués",
"sf_new": "Nouveau",
"sf_ok": "✓ Terminés",
"skip_already": "ignoré", "skip_already": "ignoré",
"skip_btn_label": "Objets",
"skip_cancel": "Annuler",
"skip_confirm": "Ignorer",
"skip_confirm_btn": "Ignorer",
"skip_hint": "Décochez les objets que vous ne souhaitez plus imprimer :",
"skip_no_objects": "Aucun objet dans cette impression.",
"skip_select_at_least_one": "Veuillez sélectionner au moins un objet.", "skip_select_at_least_one": "Veuillez sélectionner au moins un objet.",
"skip_sending": "Envoi …", "skip_sending": "Envoi …",
"skip_success": "Les objets seront ignorés.", "skip_success": "Les objets seront ignorés.",
"fd_objects_hint": "Ignorer des objets (optionnel) :", "skip_title": "Ignorer des objets",
"fd_objects_toggle": "Ignorer des objets", "slot_edit_color": "Couleur",
"fd_slots_hint": "Associer le canal GCode au slot AMS :", "slot_edit_custom": "ex. PLA, PETG, ABS…",
"fd_cancel": "Annuler", "slot_edit_load": "⬇ Charger",
"fd_print": "▶ Imprimer", "slot_edit_material": "Matériau",
"fd_no_slots_msg": "Aucun slot AMS chargé.{br}Lancer l'impression quand même ?", "slot_edit_ok": "Slot AMS",
"fd_slot": "Slot", "slot_edit_profile": "Profil OrcaSlicer",
"fd_no_matching_material": "Aucun matériau correspondant", "slot_edit_profile_default": "— Générique (défaut) —",
"fd_used": "UTILISÉ", "slot_edit_profile_hint": "Envoyé lors de la synchronisation OrcaSlicer comme marque spécifique au lieu de \"Générique\"",
"add_printer": "Ajouter une imprimante", "slot_edit_save": "💾 Enregistrer",
"apd_lbl_ip": "IP de l'imprimante", "slot_edit_title": "Modifier le slot",
"apd_lbl_name": "Nom (optionnel)", "slot_edit_unload": "⬆ Décharger",
"apd_placeholder_name": "ex. Kobra X Salon", "speed_normal": "⚡ Normal",
"apd_cancel": "Annuler", "speed_silent": "🐢 Silencieux",
"apd_confirm": "Ajouter", "speed_sport": "🚀 Sport",
"apd_fetching": "Récupération des données de l'imprimante…",
"apd_success": "Imprimante ajoutée, redémarrage du bridge…",
"apd_err_ip": "Veuillez saisir une adresse IP",
"printers_remove": "Supprimer l'imprimante",
"printers_remove_confirm": "Supprimer l'imprimante \"{name}\" ? Le bridge va redémarrer.",
"printers_active": "● actif",
"printers_switch": "Changer →",
"printers_current": "Imprimante actuelle",
"printers_loading": "Chargement…",
"printers_none": "Aucune imprimante configurée.",
"printers_empty_hint": "Aucune imprimante configurée.",
"nav_browser": "Navigateur",
"panel_browser_title": "Explorateur de fichiers",
"store_search_placeholder": "🔍 Rechercher…",
"store_empty": "Aucun fichier uploadé.",
"store_refresh": "↻ Actualiser",
"store_print": "▶ Imprimer",
"store_download": "⬇ Télécharger",
"store_delete_confirm": "Supprimer le fichier ?",
"store_print_confirm": "Imprimer le fichier ?",
"store_web_verify_title": "Vérifier le fichier",
"store_web_verify_msg": "Veuillez vérifier que ce fichier a été créé pour l'Anycubic Kobra X.",
"store_web_verify_confirm": "Confirmer",
"store_web_verify_abort": "Annuler",
"store_no_results": "Aucun fichier trouvé.",
"store_never": "jamais imprimé",
"store_estimate": "Estimation",
"store_upload_label_prefix": "Déposez un GCode ici ou ",
"store_upload_label_browse": "parcourir",
"store_upload_busy": "⏳ Envoi en cours…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ Seuls les fichiers GCode sont autorisés (.gcode, .3mf, .bgcode)",
"sf_all": "Tout",
"sf_ok": "✓ Terminés",
"sf_err": "✗ Échoués",
"sf_new": "Nouveau",
"ss_date": "↓ Date", "ss_date": "↓ Date",
"ss_name": "AZ Nom",
"ss_dur": "⏱ Durée d'impression", "ss_dur": "⏱ Durée d'impression",
"ace_dry_preset_pla": "PLA", "ss_name": "AZ Nom",
"ace_dry_preset_pla_plus": "PLA+", "store_delete_confirm": "Supprimer le fichier ?",
"ace_dry_preset_petg": "PETG", "store_download": "⬇ Télécharger",
"ace_dry_preset_tpu": "TPU", "store_empty": "Aucun fichier uploadé.",
"ace_dry_preset_abs_asa": "ABS / ASA", "store_estimate": "Estimation",
"ace_dry_preset_pa_pc": "PA / PC", "store_never": "jamais imprimé",
"ace_dry_preset_custom": "Personnalisé", "store_no_results": "Aucun fichier trouvé.",
"fd_options_title": "Options", "store_print": "▶ Imprimer",
"print_auto_leveling": "Mise à niveau auto pour cette impression", "store_print_confirm": "Imprimer le fichier ?",
"settings_file_ready_mode": "Démarrer le dialogue d'impression", "store_refresh": "↻ Actualiser",
"settings_file_ready_banner": "Barre d'impression", "store_search_placeholder": "🔍 Rechercher…",
"settings_file_ready_dialog": "Dialogue d'impression", "store_upload_busy": "⏳ Envoi en cours…",
"log_dir_rx": "RX", "store_upload_error": "✗ {error}",
"log_dir_tx": "TX", "store_upload_label_browse": "parcourir",
"log_dir_label": "Sens :", "store_upload_label_prefix": "Déposez un GCode ici ou ",
"log_lvl_err": "⛔ Erreurs", "store_upload_only_gcode": "✗ Seuls les fichiers GCode sont autorisés (.gcode, .3mf, .bgcode)",
"log_lvl_warn": "⚠ Avert.", "store_upload_success": "✓ {file}",
"log_topic_label": "Sujet :", "store_web_verify_abort": "Annuler",
"log_topic_ams": "AMS", "store_web_verify_confirm": "Confirmer",
"log_topic_print": "Impression", "store_web_verify_msg": "Veuillez vérifier que ce fichier a été créé pour Anycubic Kobra X.",
"log_topic_info": "Info", "store_web_verify_title": "Vérifier le fichier",
"log_topic_status": "Statut", "update_apply": "Installer maintenant",
"log_download": "Télécharger", "update_applying": "Téléchargement…",
"log_auto": "⬇ Auto", "update_available": "disponible",
"log_clear": "✕ Effacer", "update_check": "Vérifier les mises à jour",
"log_filter_placeholder": "Filtrer…", "update_checking": "Vérification…",
"skip_cancel": "Annuler", "update_error": "Erreur",
"skip_confirm": "Ignorer" "update_none": "Déjà à jour",
"update_restarting": "Redémarrage…"
} }

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "Pronto", "ace_dry_auto_refill": "Ricarica automatica",
"header_status_printing": "In stampa", "ace_dry_chart": "Cronologia (Temp/Umidità)",
"header_status_complete": "Completato", "ace_dry_current_temp": "Temperatura",
"header_status_error": "Errore", "ace_dry_dialog_cancel": "Annulla",
"kobra_free": "Pronto", "ace_dry_dialog_confirm": "Conferma",
"kobra_busy": "Occupato", "ace_dry_dialog_custom_name": "Nome personalizzato",
"kobra_printing": "In stampa", "ace_dry_dialog_reset_default": "Ripristina predefiniti",
"kobra_preheating": "Preriscaldamento", "ace_dry_dialog_save_restart": "Salva e riavvia",
"kobra_auto_leveling": "Livellamento automatico", "ace_dry_dialog_temp": "Temperatura (30-80°C)",
"kobra_checking": "Verifica", "ace_dry_dialog_time": "Tempo rim. (h:m:s)",
"kobra_updated": "Aggiornamento", "ace_dry_dialog_title": "Impostazioni Temp/Tempo essiccatore",
"kobra_init": "Inizializzazione",
"kobra_pausing": "Pausa in corso...",
"kobra_paused": "In pausa",
"kobra_resuming": "Ripresa...",
"kobra_resumed": "Ripreso",
"kobra_stopping": "Arresto...",
"kobra_stoped": "Arrestato",
"kobra_finished": "Finito",
"kobra_failed": "Errore",
"kobra_canceled": "Annullato",
"kobra_offline": "Offline",
"nav_dashboard": "Dashboard",
"nav_print": "Stampa",
"nav_temps": "Temperature",
"nav_motion": "Movimento",
"nav_ams": "AMS",
"nav_extras": "Luce / Ventola",
"nav_console": "Console",
"card_progress": "Avanzamento",
"card_temps": "Temperature",
"card_light_fan": "Ventola",
"card_speed": "Velocità di stampa",
"card_cam": "Camera",
"lbl_elapsed": "Trascorso:",
"lbl_remaining": "Rimanente:",
"lbl_slicer_time": "Stima slicer:",
"lbl_layers": "Layer",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 Silenzioso",
"speed_normal": "⚡ Normale",
"speed_sport": "🚀 Sport",
"lbl_light": "💡 Luce",
"lbl_feed": "Carica",
"lbl_unload": "Rimuovi",
"card_ace_dry": "Essiccazione ACE",
"ace_dry_dryer": "Essiccatore", "ace_dry_dryer": "Essiccatore",
"ace_dry_duration": "Durata (min)",
"ace_dry_enable": "Abilita essiccazione",
"ace_dry_humidity": "Umidità",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "Personalizzato",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ Avvia",
"ace_dry_status_off": "Stato: Spento", "ace_dry_status_off": "Stato: Spento",
"ace_dry_status_on": "Stato: Attivo", "ace_dry_status_on": "Stato: Attivo",
"ace_dry_status_remaining": "Rimanente", "ace_dry_status_remaining": "Rimanente",
"ace_dry_humidity": "Umidità",
"ace_dry_current_temp": "Temperatura",
"ace_dry_chart": "Cronologia (Temp/Umidità)",
"ace_dry_temp": "Temperatura (°C)",
"ace_dry_duration": "Durata (min)",
"ace_dry_start": "▶ Avvia",
"ace_dry_stop": "■ Ferma", "ace_dry_stop": "■ Ferma",
"ace_dry_auto_refill": "Ricarica automatica", "ace_dry_temp": "Temperatura (°C)",
"ace_dry_enable": "Abilita essiccazione",
"ace_dry_temp_line": "Temperatura di essiccazione", "ace_dry_temp_line": "Temperatura di essiccazione",
"ace_dry_time_line": "Tempo di essiccazione", "ace_dry_time_line": "Tempo di essiccazione",
"ace_dry_ui_pending": "(Solo interfaccia, backend a seguire)", "ace_dry_ui_pending": "(Solo interfaccia, backend a seguire)",
"ace_dry_dialog_title": "Impostazioni Temp/Tempo essiccatore", "add_printer": "Aggiungi stampante",
"ace_dry_dialog_temp": "Temperatura (30-80°C)", "ams_empty": "Vuoto",
"ace_dry_dialog_time": "Tempo rim. (h:m:s)", "ams_no_data": "Nessun dato ricevuto dall' AMS",
"ace_dry_dialog_confirm": "Conferma", "apd_cancel": "Annulla",
"ace_dry_dialog_cancel": "Annulla", "apd_confirm": "Aggiungi",
"ace_dry_dialog_save_restart": "Salva e riavvia", "apd_err_ip": "Inserisci un indirizzo IP",
"ace_dry_dialog_custom_name": "Nome personalizzato", "apd_fetching": "Recupero dati dalla stampante…",
"ace_dry_dialog_reset_default": "Ripristina predefiniti", "apd_lbl_ip": "IP stampante",
"ace_dry_preset_pla": "PLA", "apd_lbl_name": "Nome (opzionale)",
"ace_dry_preset_pla_plus": "PLA+", "apd_placeholder_name": "es. Kobra X Soggiorno",
"ace_dry_preset_petg": "PETG", "apd_success": "Stampante aggiunta, riavvio del bridge in corso…",
"ace_dry_preset_tpu": "TPU", "apd_title": "Aggiungi stampante",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_custom": "Personalizzato",
"cam_placeholder": "📷 Camera non avviata",
"cam_stream_unavailable": "Flusso video non disponibile",
"btn_cam_start": "▶ Camera", "btn_cam_start": "▶ Camera",
"btn_cam_start2": "▶ Avvia",
"btn_cam_stop": "◼ Camera", "btn_cam_stop": "◼ Camera",
"btn_cam_stop2": "◼ Ferma",
"btn_cancel": "✕ Stop",
"btn_cancel_generic": "Annulla",
"btn_confirm_generic": "Conferma",
"btn_connect": "⚡ Connetti",
"btn_delete": "Elimina",
"btn_disable_motors": "Spegni motori",
"btn_disconnect": "✕ Disconnetti",
"btn_home_all": "Home generale",
"btn_home_xy": "Home XY",
"btn_home_z": "Home Z",
"btn_pause": "⏸ Pausa", "btn_pause": "⏸ Pausa",
"btn_resume": "▶ Riprendi", "btn_resume": "▶ Riprendi",
"btn_cancel": "✕ Stop", "cam_placeholder": "📷 Camera non avviata",
"label_nozzle": "Ugello", "cam_stream_unavailable": "Flusso video non disponibile",
"card_ace_dry": "Essiccazione ACE",
"card_ams": "Filamento",
"card_cam": "Camera",
"card_light_fan": "Ventola",
"card_progress": "Avanzamento",
"card_speed": "Velocità di stampa",
"card_temps": "Temperature",
"confirm_cancel": "Annullare davvero la stampa?",
"fd_cancel": "Annulla",
"fd_no_matching_material": "Nessun materiale corrispondente",
"fd_no_slots_msg": "Nessuno slot AMS caricato.{br}Avviare comunque la stampa?",
"fd_objects_hint": "Salta oggetti (opzionale):",
"fd_objects_toggle": "Salta oggetti",
"fd_options_title": "Opzioni di stampa",
"fd_print": "▶ Stampa",
"fd_slot": "Slot",
"fd_slots_hint": "Assegna il canale GCode allo slot AMS:",
"fd_title": "Assegnazione slot",
"fd_used": "USATO",
"file_cancel_btn": "✕ Annulla",
"file_ready_btn": "▶ Avvia stampa",
"file_slots_btn": "🎨 Seleziona slot",
"header_status_complete": "Completato",
"header_status_error": "Errore",
"header_status_printing": "In stampa",
"header_status_standby": "Pronto",
"hint_ip_no_port": "Solo indirizzo IP, senza porta (es. 192.168.1.102)",
"kobra_auto_leveling": "Livellamento automatico",
"kobra_busy": "Occupato",
"kobra_canceled": "Annullato",
"kobra_checking": "Verifica",
"kobra_failed": "Errore",
"kobra_finished": "Finito",
"kobra_free": "Pronto",
"kobra_init": "Inizializzazione",
"kobra_offline": "Offline",
"kobra_paused": "In pausa",
"kobra_pausing": "Pausa in corso...",
"kobra_preheating": "Preriscaldamento",
"kobra_printing": "In stampa",
"kobra_resumed": "Ripreso",
"kobra_resuming": "Ripresa...",
"kobra_stoped": "Arrestato",
"kobra_stopping": "Arresto...",
"kobra_updated": "Aggiornamento",
"label_bed": "Piatto", "label_bed": "Piatto",
"label_fan": "🌀 Ventola", "label_fan": "🌀 Ventola",
"label_light": "💡 Luce", "label_light": "💡 Luce",
"label_on_off": "On / Off", "label_nozzle": "Ugello",
"label_speed": "Velocità",
"panel_print_title": "Controllo stampa",
"panel_print_btn_pause": "⏸ Pausa",
"panel_print_btn_resume": "▶ Riprendi",
"panel_print_btn_cancel": "✕ Annulla",
"panel_print_temps_live": "Temperature (In tempo reale)",
"label_set": "Imposta",
"label_off": "Off", "label_off": "Off",
"panel_temps_nozzle": "Ugello", "label_on_off": "On / Off",
"panel_temps_bed": "Piatto riscaldato", "label_set": "Imposta",
"panel_temps_chart": "Cronologia (ultime 60 letture)",
"label_target_c": "Target:",
"panel_motion_xy": "Assi XY",
"panel_motion_z": "Asse Z",
"label_step": "Ampiezza passo:",
"btn_home_z": "Home Z",
"btn_home_xy": "Home XY",
"btn_home_all": "Home generale",
"btn_disable_motors": "Spegni motori",
"panel_ams_title": "Filamento",
"card_ams": "Filamento",
"ams_no_data": "Nessun dato ricevuto dall' AMS",
"label_slot": "Slot", "label_slot": "Slot",
"ams_empty": "Vuoto", "label_speed": "Velocità",
"panel_extras_light": "Luce", "label_step": "Ampiezza passo:",
"panel_extras_fan": "Ventola", "label_target_c": "Target:",
"panel_extras_camera": "Camera", "lbl_conn_error": "Errore di connessione:",
"btn_cam_start2": "▶ Avvia", "lbl_elapsed": "Trascorso:",
"btn_cam_stop2": "◼ Ferma", "lbl_feed": "Carica",
"panel_console_title": "Registro eventi", "lbl_layers": "Layer",
"log_light_on": "Luce accesa", "lbl_light": "💡 Luce",
"log_light_off": "Luce spenta", "lbl_remaining": "Rimanente:",
"log_fan": "Ventola →", "lbl_slicer_time": "Stima slicer:",
"log_nozzle": "Ugello →", "lbl_unload": "Rimuovi",
"log_bed": "Piatto →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ Auto",
"log_axis": "Asse", "log_axis": "Asse",
"log_home": "Home", "log_bed": "Piatto →",
"log_home_all": "Home generale",
"log_cam_start": "Camera avviata:", "log_cam_start": "Camera avviata:",
"log_cam_stop": "Camera arrestata", "log_cam_stop": "Camera arrestata",
"log_poll_error": "Errore di sincronizzazione:", "log_clear": "✕ Cancella",
"log_delete_failed": "Eliminazione non riuscita",
"log_dir_all": "Tutti",
"log_dir_label": "Dir:",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ Scarica",
"log_error": "Errore:", "log_error": "Errore:",
"confirm_cancel": "Annullare davvero la stampa?", "log_fan": "Ventola →",
"settings_title": "Impostazioni", "log_filter_placeholder": "Filtra…",
"settings_connection": "Connessione", "log_home": "Home",
"settings_print": "Impostazioni di stampa", "log_home_all": "Home generale",
"settings_poll": "Intervallo di sincronizzazione (secondi)", "log_light_off": "Luce spenta",
"log_light_on": "Luce accesa",
"log_lvl_err": "⛔ Errori",
"log_lvl_label": "Livello:",
"log_lvl_warn": "⚠ Avvisi",
"log_nozzle": "Ugello →",
"log_poll_error": "Errore di sincronizzazione:",
"log_print_action": "Stampa:",
"log_print_start": "Inizio stampa:",
"log_topic_ams": "AMS",
"log_topic_info": "Info",
"log_topic_label": "Argomento:",
"log_topic_print": "Stampa",
"log_topic_status": "Stato",
"nav_ams": "AMS",
"nav_browser": "Browser",
"nav_console": "Console",
"nav_dashboard": "Dashboard",
"nav_extras": "Luce / Ventola",
"nav_motion": "Movimento",
"nav_print": "Stampa",
"nav_printers": "Stampanti",
"nav_settings": "Impostazioni", "nav_settings": "Impostazioni",
"settings_cat_display": "Aspetto", "nav_temps": "Temperature",
"settings_cat_filament": "Filamento", "orca_profile_done": "Importato",
"settings_cat_language": "Lingua", "orca_profile_dropmsg": "Trascina qui o fai clic",
"settings_cat_theme": "Alterna chiaro / scuro", "orca_profile_help_html": "Carica un file <b>ZIP</b> della tua cartella filamenti di OrcaSlicer o file singoli <b>.json</b>.<br>In OrcaSlicer: <i>Aiuto → Mostra cartella di configurazione → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "Mappatura profilo filamento (per slot)",
"settings_filament_mapping_save": "Salva mappatura",
"settings_visible_vendors": "Produttori visibili (menu del profilo)",
"settings_visible_vendors_hint": "Solo questi produttori appariranno nel menu del profilo dello slot. Se non selezioni nulla = mostra tutti. I profili \"Generici\" e i tuoi personali sono sempre visibili.",
"settings_visible_vendors_save": "Salva selezione",
"progress_action_print": "Stampa",
"progress_action_slots": "Mappa slot",
"progress_action_clear": "Cancella",
"settings_version": "Versione",
"settings_save": "Salva e riavvia",
"settings_printer_name": "Nome stampante",
"settings_printer_ip": "IP stampante",
"settings_mqtt_port": "Porta MQTT",
"settings_username": "Nome utente MQTT",
"settings_password": "Password MQTT",
"settings_device_id": "ID dispositivo",
"settings_mode_id": "ID modalità",
"hint_ip_no_port": "Solo indirizzo IP, senza porta (es. 192.168.1.102)",
"settings_default_slot": "Slot predefinito (colore singolo)",
"settings_slot_auto": "Auto (tutti gli slot caricati)",
"settings_auto_leveling": "Livellamento automatico predefinito",
"fd_options_title": "Opzioni di stampa",
"print_auto_leveling": "Livellamento automatico",
"settings_file_ready_mode": "Comportamento all'avvio stampa",
"settings_file_ready_banner": "Barra di stampa",
"settings_file_ready_dialog": "Finestra di dialogo di stampa",
"settings_camera_on_print": "Attiva la camera all'avvio della stampa",
"settings_web_upload_warning": "Mostra un avviso quando si stampano caricamenti web",
"update_check": "Controlla aggiornamenti",
"update_checking": "Verifica in corso...",
"update_available": "disponibile",
"update_none": "Già aggiornato",
"update_apply": "Installa ora",
"update_applying": "Download in corso...",
"update_restarting": "Riavvio in corso...",
"update_error": "Errore",
"btn_connect": "⚡ Connetti",
"btn_disconnect": "✕ Disconnetti",
"lbl_conn_error": "Errore di connessione:",
"slot_edit_title": "Modifica slot",
"slot_edit_color": "Colore",
"slot_edit_material": "Materiale",
"slot_edit_load": "⬇ Carica",
"slot_edit_unload": "⬆ Rimuovi",
"slot_edit_save": "💾 Salva",
"slot_edit_custom": "es. PLA, PETG, ABS…",
"slot_edit_ok": "Slot AMS",
"slot_edit_profile": "Profilo OrcaSlicer",
"slot_edit_profile_hint": "Inviato durante la sincronizzazione con OrcaSlicer come marchio specifico invece di un semplice \"Generico\"",
"slot_edit_profile_default": "— Generico (predefinito) —",
"orca_profile_section": "Profili OrcaSlicer",
"orca_profile_hint": "Importa i tuoi profili di filamento OrcaSlicer (apri la cartella utente tramite Aiuto → Mostra cartella di configurazione)", "orca_profile_hint": "Importa i tuoi profili di filamento OrcaSlicer (apri la cartella utente tramite Aiuto → Mostra cartella di configurazione)",
"orca_profile_import_btn": "Importa profili", "orca_profile_import_btn": "Importa profili",
"orca_profile_import_link": "★ Importa i tuoi profili…", "orca_profile_import_link": "★ Importa i tuoi profili…",
"orca_profile_import_title": "Importa i tuoi profili OrcaSlicer", "orca_profile_import_title": "Importa i tuoi profili OrcaSlicer",
"orca_profile_help_html": "Carica un file <b>ZIP</b> della tua cartella filamenti di OrcaSlicer o file singoli <b>.json</b>.<br>In OrcaSlicer: <i>Aiuto → Mostra cartella di configurazione → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "Trascina qui o fai clic",
"orca_profile_list_label": "Attualmente importati", "orca_profile_list_label": "Attualmente importati",
"orca_profile_user_label": "Profili personali", "orca_profile_section": "Profili OrcaSlicer",
"orca_profile_user_empty": " nessuno ",
"orca_profile_uploading": "Caricamento in corso…",
"orca_profile_done": "Importato",
"orca_profile_skipped": "saltato", "orca_profile_skipped": "saltato",
"log_dir_all": "Tutti", "orca_profile_uploading": "Caricamento in corso…",
"log_dir_rx": "RX", "orca_profile_user_empty": " nessuno ",
"log_dir_tx": "TX", "orca_profile_user_label": "Profili personali",
"log_dir_label": "Dir:", "panel_ams_title": "Filamento",
"log_lvl_label": "Livello:", "panel_browser_title": "Browser dei file",
"log_lvl_err": "⛔ Errori", "panel_console_title": "Registro eventi",
"log_lvl_warn": "⚠ Avvisi", "panel_extras_camera": "Camera",
"log_topic_label": "Argomento:", "panel_extras_fan": "Ventola",
"log_topic_ams": "AMS", "panel_extras_light": "Luce",
"log_topic_print": "Stampa", "panel_motion_xy": "Assi XY",
"log_topic_info": "Info", "panel_motion_z": "Asse Z",
"log_topic_status": "Stato", "panel_print_btn_cancel": "✕ Annulla",
"log_download": "⬇ Scarica", "panel_print_btn_pause": "⏸ Pausa",
"log_auto": "⬇ Auto", "panel_print_btn_resume": "▶ Riprendi",
"log_clear": "✕ Cancella", "panel_print_temps_live": "Temperature (In tempo reale)",
"log_filter_placeholder": "Filtra…", "panel_print_title": "Controllo stampa",
"file_ready_btn": "▶ Avvia stampa", "panel_temps_bed": "Piatto riscaldato",
"file_slots_btn": "🎨 Seleziona slot", "panel_temps_chart": "Cronologia (ultime 60 letture)",
"file_cancel_btn": "✕ Annulla", "panel_temps_nozzle": "Ugello",
"nav_printers": "Stampanti", "print_auto_leveling": "Livellamento automatico",
"skip_title": "✂ Salta oggetti", "printers_active": "● attiva",
"skip_hint": "Deseleziona gli oggetti che non vuoi più stampare:", "printers_current": "Stampante corrente",
"skip_btn_label": "Oggetti", "printers_empty_hint": "Nessuna stampante ancora configurata.",
"skip_no_objects": "Nessun oggetto in questa stampa.", "printers_loading": "Caricamento in corso…",
"printers_none": "Nessuna stampante configurata.",
"printers_remove": "Rimuovi stampante",
"printers_remove_confirm": "Rimuovere la stampante \"{name}\"? Il bridge si riavvierà.",
"printers_switch": "Cambia →",
"progress_action_clear": "Cancella",
"progress_action_print": "Stampa",
"progress_action_slots": "Mappa slot",
"settings_auto_leveling": "Livellamento automatico predefinito",
"settings_auto_leveling_label": "Livellamento automatico prima della stampa",
"settings_btn_tooltip": "Impostazioni",
"settings_camera_on_print": "Attiva la camera all'avvio della stampa",
"settings_cat_connection": "Connessione",
"settings_cat_display": "Aspetto",
"settings_cat_filament": "Filamento",
"settings_cat_language": "Lingua",
"settings_cat_printer": "Stampante",
"settings_cat_system": "Sistema",
"settings_cat_theme": "Alterna chiaro / scuro",
"settings_connection": "Connessione",
"settings_default_slot": "Slot predefinito (colore singolo)",
"settings_device_id": "ID dispositivo",
"settings_device_id_hint": "32 caratteri esadecimali",
"settings_device_id_placeholder": "32 caratteri esadecimali",
"settings_filament_mapping": "Mappatura profilo filamento (per slot)",
"settings_filament_mapping_hint": "Profilo Orca fisso per slot AMS. Durante la sincronizzazione dello slicer, il bridge invia questo profilo al posto di \"Generic\".",
"settings_filament_mapping_label": "Mappatura profilo filamento (per slot)",
"settings_filament_mapping_save": "Salva mappatura",
"settings_filament_mapping_save_label": "Salva mappatura",
"settings_file_ready_banner": "Barra di stampa",
"settings_file_ready_dialog": "Finestra di dialogo stampa",
"settings_file_ready_mode": "Dopo il caricamento: Comportamento di avvio stampa",
"settings_language": "Lingua",
"settings_mode_id": "ID modalità",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "Porta MQTT",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "Importa profili",
"settings_orca_profiles_label": "Profili OrcaSlicer",
"settings_password": "Password MQTT",
"settings_poll": "Intervallo di sincronizzazione (secondi)",
"settings_poll_interval_hint": "Con che frequenza il bridge interroga lo stato della stampante",
"settings_poll_interval_label": "Intervallo di sincronizzazione (secondi)",
"settings_print": "Impostazioni di stampa",
"settings_printer_ip": "IP stampante",
"settings_printer_name": "Nome stampante",
"settings_printer_name_placeholder": "p. es. Kobra X Sala",
"settings_save": "Salva e riavvia",
"settings_slot_auto": "Auto (tutti gli slot caricati)",
"settings_theme_toggle": "Attiva/disattiva chiaro / scuro",
"settings_title": "Impostazioni",
"settings_username": "Nome utente MQTT",
"settings_vendor_filter_placeholder": "Cerca produttori…",
"settings_version": "Versione",
"settings_visible_vendors": "Produttori visibili (menu del profilo)",
"settings_visible_vendors_hint": "Solo questi produttori appariranno nel menu del profilo dello slot. Se non selezioni nulla = mostra tutti. I profili \"Generici\" e i tuoi personali sono sempre visibili.",
"settings_visible_vendors_label": "Produttori visibili (menu del profilo)",
"settings_visible_vendors_save": "Salva selezione",
"settings_visible_vendors_save_label": "Salva selezione",
"settings_web_upload_warning": "Mostra un avviso quando si stampano caricamenti web",
"sf_all": "Tutti",
"sf_err": "✗ Fallito",
"sf_new": "Nuovo",
"sf_ok": "✓ Completato",
"skip_already": "saltato", "skip_already": "saltato",
"skip_btn_label": "Oggetti",
"skip_cancel": "Annulla", "skip_cancel": "Annulla",
"skip_confirm": "Salta", "skip_confirm": "Salta",
"skip_confirm_btn": "Salta",
"skip_hint": "Deseleziona gli oggetti che non vuoi più stampare:",
"skip_no_objects": "Nessun oggetto in questa stampa.",
"skip_select_at_least_one": "Seleziona almeno un oggetto.", "skip_select_at_least_one": "Seleziona almeno un oggetto.",
"skip_sending": "Invio in corso …", "skip_sending": "Invio in corso …",
"skip_success": "Gli oggetti verranno saltati.", "skip_success": "Gli oggetti verranno saltati.",
"fd_objects_hint": "Salta oggetti (opzionale):", "skip_title": "Salta oggetti",
"fd_objects_toggle": "Salta oggetti", "slot_edit_color": "Colore",
"fd_slots_hint": "Assegna il canale GCode allo slot AMS:", "slot_edit_custom": "es. PLA, PETG, ABS…",
"fd_cancel": "Annulla", "slot_edit_load": "⬇ Carica",
"fd_print": "▶ Stampa", "slot_edit_material": "Materiale",
"fd_no_slots_msg": "Nessuno slot AMS caricato.{br}Avviare comunque la stampa?", "slot_edit_ok": "Slot AMS",
"fd_slot": "Slot", "slot_edit_profile": "Profilo OrcaSlicer",
"fd_no_matching_material": "Nessun materiale corrispondente", "slot_edit_profile_default": "— Generico (predefinito) —",
"fd_used": "USATO", "slot_edit_profile_hint": "Inviato durante la sincronizzazione con OrcaSlicer come marchio specifico invece di un semplice \"Generico\"",
"add_printer": "Aggiungi stampante", "slot_edit_save": "💾 Salva",
"apd_lbl_ip": "IP stampante", "slot_edit_title": "Modifica slot",
"apd_lbl_name": "Nome (opzionale)", "slot_edit_unload": "⬆ Rimuovi",
"apd_placeholder_name": "es. Kobra X Soggiorno", "speed_normal": "⚡ Normale",
"apd_cancel": "Annulla", "speed_silent": "🐢 Silenzioso",
"apd_confirm": "Aggiungi", "speed_sport": "🚀 Sport",
"apd_fetching": "Recupero dati dalla stampante…",
"apd_success": "Stampante aggiunta, riavvio del bridge in corso…",
"apd_err_ip": "Inserisci un indirizzo IP",
"printers_remove": "Rimuovi stampante",
"printers_remove_confirm": "Rimuovere la stampante \"{name}\"? Il bridge si riavvierà.",
"printers_active": "● attiva",
"printers_switch": "Cambia →",
"printers_current": "Stampante corrente",
"printers_loading": "Caricamento in corso…",
"printers_none": "Nessuna stampante configurata.",
"printers_empty_hint": "Nessuna stampante ancora configurata.",
"nav_browser": "Browser",
"panel_browser_title": "Browser dei file",
"store_search_placeholder": "🔍 Cerca…",
"store_empty": "Nessun file caricato.",
"store_refresh": "↻ Aggiorna",
"store_print": "▶ Stampa",
"store_download": "⬇ Scarica",
"store_delete_confirm": "Eliminare il file?",
"store_print_confirm": "Stampare il file?",
"store_web_verify_title": "Verifica file",
"store_web_verify_msg": "Verifica che questo file sia stato creato per Anycubic Kobra X.",
"store_web_verify_confirm": "Conferma",
"store_web_verify_abort": "Interrompi",
"store_no_results": "Nessun file trovato.",
"store_never": "mai stampato",
"store_estimate": "Stima",
"store_upload_label_prefix": "Trascina il GCode qui o ",
"store_upload_label_browse": "sfoglia",
"store_upload_busy": "⏳ Caricamento in corso…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ Sono consentiti solo file GCode (.gcode, .3mf, .bgcode)",
"sf_all": "Tutti",
"sf_ok": "✓ Completato",
"sf_err": "✗ Fallito",
"sf_new": "Nuovo",
"ss_date": "↓ Data", "ss_date": "↓ Data",
"ss_dur": "⏱ Tempo di stampa",
"ss_name": "Nome AZ", "ss_name": "Nome AZ",
"ss_dur": "⏱ Tempo di stampa" "store_delete_confirm": "Eliminare il file?",
} "store_download": "⬇ Scarica",
"store_empty": "Nessun file caricato.",
"store_estimate": "Stima",
"store_never": "mai stampato",
"store_no_results": "Nessun file trovato.",
"store_print": "▶ Stampa",
"store_print_confirm": "Stampare il file?",
"store_refresh": "↻ Aggiorna",
"store_search_placeholder": "🔍 Cerca…",
"store_upload_busy": "⏳ Caricamento in corso…",
"store_upload_error": "✗ {error}",
"store_upload_label_browse": "sfoglia",
"store_upload_label_prefix": "Trascina il GCode qui o ",
"store_upload_only_gcode": "✗ Sono consentiti solo file GCode (.gcode, .3mf, .bgcode)",
"store_upload_success": "✓ {file}",
"store_web_verify_abort": "Annulla",
"store_web_verify_confirm": "Conferma",
"store_web_verify_msg": "Verifica che questo file sia stato creato per Anycubic Kobra X.",
"store_web_verify_title": "Verifica file",
"update_apply": "Installa ora",
"update_applying": "Download in corso...",
"update_available": "disponibile",
"update_check": "Controlla aggiornamenti",
"update_checking": "Verifica in corso...",
"update_error": "Errore",
"update_none": "Già aggiornato",
"update_restarting": "Riavvio in corso..."
}

View File

@@ -1,291 +1,322 @@
{ {
"header_status_standby": "就绪", "ace_dry_auto_refill": "自动补料",
"header_status_printing": "打印中", "ace_dry_chart": "历史 (温度/湿度)",
"header_status_complete": "完成", "ace_dry_current_temp": "温度",
"header_status_error": "错误", "ace_dry_dialog_cancel": "取消",
"kobra_free": "就绪", "ace_dry_dialog_confirm": "确认",
"kobra_busy": "忙碌", "ace_dry_dialog_custom_name": "自定义名称",
"kobra_printing": "打印中", "ace_dry_dialog_reset_default": "恢复默认",
"kobra_preheating": "预热中", "ace_dry_dialog_save_restart": "保存并重启",
"kobra_auto_leveling": "自动调平", "ace_dry_dialog_temp": "温度 (30-80°C)",
"kobra_checking": "检查中", "ace_dry_dialog_time": "剩余时间 (h:m:s)",
"kobra_updated": "更新中", "ace_dry_dialog_title": "烘干温度/时间设置",
"kobra_init": "初始化中",
"kobra_pausing": "暂停中...",
"kobra_paused": "已暂停",
"kobra_resuming": "恢复中...",
"kobra_resumed": "已恢复",
"kobra_stopping": "停止中...",
"kobra_stoped": "已停止",
"kobra_finished": "已完成",
"kobra_failed": "错误",
"kobra_canceled": "已取消",
"kobra_offline": "离线",
"nav_dashboard": "仪表盘",
"nav_print": "打印",
"nav_temps": "温度",
"nav_motion": "运动",
"nav_ams": "AMS",
"nav_extras": "灯光 / 风扇",
"nav_console": "控制台",
"card_progress": "进度",
"card_temps": "温度",
"card_light_fan": "风扇",
"card_speed": "打印速度",
"card_cam": "相机",
"lbl_elapsed": "已用时间:",
"lbl_remaining": "剩余时间:",
"lbl_slicer_time": "切片预估:",
"lbl_layers": "层",
"lbl_zpos": "Z (mm)",
"speed_silent": "🐢 静音",
"speed_normal": "⚡ 标准",
"speed_sport": "🚀 运动",
"lbl_light": "💡 灯光",
"lbl_feed": "进料",
"lbl_unload": "退料",
"card_ace_dry": "ACE 烘干",
"ace_dry_dryer": "烘干机", "ace_dry_dryer": "烘干机",
"ace_dry_duration": "时长 (分钟)",
"ace_dry_enable": "启用烘干",
"ace_dry_humidity": "湿度",
"ace_dry_preset_abs_asa": "ABS / ASA",
"ace_dry_preset_custom": "自定义",
"ace_dry_preset_pa_pc": "PA / PC",
"ace_dry_preset_petg": "PETG",
"ace_dry_preset_pla": "PLA",
"ace_dry_preset_pla_plus": "PLA+",
"ace_dry_preset_tpu": "TPU",
"ace_dry_start": "▶ 启动",
"ace_dry_status_off": "状态: 关闭", "ace_dry_status_off": "状态: 关闭",
"ace_dry_status_on": "状态: 运行中", "ace_dry_status_on": "状态: 运行中",
"ace_dry_status_remaining": "剩余", "ace_dry_status_remaining": "剩余",
"ace_dry_humidity": "湿度",
"ace_dry_current_temp": "温度",
"ace_dry_chart": "历史 (温度/湿度)",
"ace_dry_temp": "温度 (°C)",
"ace_dry_duration": "时长 (分钟)",
"ace_dry_start": "▶ 启动",
"ace_dry_stop": "■ 停止", "ace_dry_stop": "■ 停止",
"ace_dry_auto_refill": "自动补料", "ace_dry_temp": "温度 (°C)",
"ace_dry_enable": "启用烘干",
"ace_dry_temp_line": "烘干温度", "ace_dry_temp_line": "烘干温度",
"ace_dry_time_line": "烘干时间", "ace_dry_time_line": "烘干时间",
"ace_dry_ui_pending": "(仅 UI后端稍后支持)", "ace_dry_ui_pending": "(仅 UI后端稍后支持)",
"ace_dry_dialog_title": "烘干温度/时间设置", "add_printer": "添加打印机",
"ace_dry_dialog_temp": "温度 (30-80°C)", "ams_empty": "",
"ace_dry_dialog_time": "剩余时间 (h:m:s)", "ams_no_data": "未收到 AMS 数据",
"ace_dry_dialog_confirm": "确认", "apd_cancel": "取消",
"ace_dry_dialog_cancel": "取消", "apd_confirm": "添加",
"ace_dry_dialog_save_restart": "保存并重启", "apd_err_ip": "请输入 IP 地址",
"ace_dry_dialog_custom_name": "自定义名称", "apd_fetching": "正在从打印机获取数据…",
"ace_dry_dialog_reset_default": "恢复默认", "apd_lbl_ip": "打印机 IP",
"cam_placeholder": "📷 相机未启动", "apd_lbl_name": "名称 (可选)",
"cam_stream_unavailable": "视频流不可用", "apd_placeholder_name": "例如 Kobra X 客厅",
"apd_success": "打印机已添加Bridge 正在重启…",
"apd_title": "添加打印机",
"btn_cam_start": "▶ 相机", "btn_cam_start": "▶ 相机",
"btn_cam_start2": "▶ 启动",
"btn_cam_stop": "◼ 相机", "btn_cam_stop": "◼ 相机",
"btn_cam_stop2": "◼ 停止",
"btn_cancel": "✕ 停止",
"btn_cancel_generic": "取消",
"btn_confirm_generic": "确认",
"btn_connect": "⚡ 连接",
"btn_delete": "删除",
"btn_disable_motors": "关闭电机",
"btn_disconnect": "✕ 断开",
"btn_home_all": "全部回零",
"btn_home_xy": "回零 XY",
"btn_home_z": "回零 Z",
"btn_pause": "⏸ 暂停", "btn_pause": "⏸ 暂停",
"btn_resume": "▶ 继续", "btn_resume": "▶ 继续",
"btn_cancel": "✕ 停止", "cam_placeholder": "📷 相机未启动",
"label_nozzle": "喷嘴", "cam_stream_unavailable": "视频流不可用",
"card_ace_dry": "ACE 烘干",
"card_ams": "耗材",
"card_cam": "相机",
"card_light_fan": "风扇",
"card_progress": "进度",
"card_speed": "打印速度",
"card_temps": "温度",
"confirm_cancel": "确定要取消打印吗?",
"fd_cancel": "取消",
"fd_no_matching_material": "无匹配材料",
"fd_no_slots_msg": "没有已装载的 AMS 槽位。{br}仍要开始打印吗?",
"fd_objects_hint": "跳过对象 (可选):",
"fd_objects_toggle": "跳过对象",
"fd_options_title": "选项",
"fd_print": "▶ 打印",
"fd_slot": "槽位",
"fd_slots_hint": "将 GCode 通道分配到 AMS 槽位:",
"fd_title": "槽位分配",
"fd_used": "已用",
"file_cancel_btn": "✕ 取消",
"file_ready_btn": "▶ 开始打印",
"file_slots_btn": "🎨 选择槽位",
"header_status_complete": "完成",
"header_status_error": "错误",
"header_status_printing": "打印中",
"header_status_standby": "就绪",
"hint_ip_no_port": "仅填写 IP不要端口 (例如 192.168.1.102)",
"kobra_auto_leveling": "自动调平",
"kobra_busy": "忙碌",
"kobra_canceled": "已取消",
"kobra_checking": "检查中",
"kobra_failed": "错误",
"kobra_finished": "已完成",
"kobra_free": "就绪",
"kobra_init": "初始化中",
"kobra_offline": "离线",
"kobra_paused": "已暂停",
"kobra_pausing": "暂停中...",
"kobra_preheating": "预热中",
"kobra_printing": "打印中",
"kobra_resumed": "已恢复",
"kobra_resuming": "恢复中...",
"kobra_stoped": "已停止",
"kobra_stopping": "停止中...",
"kobra_updated": "更新中",
"label_bed": "热床", "label_bed": "热床",
"label_fan": "🌀 风扇", "label_fan": "🌀 风扇",
"label_light": "💡 灯光", "label_light": "💡 灯光",
"label_on_off": "开 / 关", "label_nozzle": "喷嘴",
"label_speed": "速度",
"panel_print_title": "打印控制",
"panel_print_btn_pause": "⏸ 暂停",
"panel_print_btn_resume": "▶ 继续",
"panel_print_btn_cancel": "✕ 取消",
"panel_print_temps_live": "温度 (实时)",
"label_set": "设置",
"label_off": "关闭", "label_off": "关闭",
"panel_temps_nozzle": "喷嘴", "label_on_off": "开 / 关",
"panel_temps_bed": "热床", "label_set": "设置",
"panel_temps_chart": "历史 (最近 60 次读数)",
"label_target_c": "目标:",
"panel_motion_xy": "XY 轴",
"panel_motion_z": "Z 轴",
"label_step": "步进:",
"btn_home_z": "回零 Z",
"btn_home_xy": "回零 XY",
"btn_home_all": "全部回零",
"btn_disable_motors": "关闭电机",
"panel_ams_title": "耗材",
"card_ams": "耗材",
"ams_no_data": "未收到 AMS 数据",
"label_slot": "槽位", "label_slot": "槽位",
"ams_empty": "", "label_speed": "速度",
"panel_extras_light": "灯光", "label_step": "步进:",
"panel_extras_fan": "风扇", "label_target_c": "目标:",
"panel_extras_camera": "相机", "lbl_conn_error": "连接错误:",
"btn_cam_start2": "▶ 启动", "lbl_elapsed": "已用时间:",
"btn_cam_stop2": "◼ 停止", "lbl_feed": "进料",
"panel_console_title": "事件日志", "lbl_layers": "",
"log_light_on": "灯光已开", "lbl_light": "💡 灯光",
"log_light_off": "灯光已关", "lbl_remaining": "剩余时间:",
"log_fan": "风扇 →", "lbl_slicer_time": "切片预估:",
"log_nozzle": "喷嘴 →", "lbl_unload": "退料",
"log_bed": "热床 →", "lbl_zpos": "Z (mm)",
"log_auto": "⬇ 自动",
"log_axis": "轴", "log_axis": "轴",
"log_home": "回零", "log_bed": "热床 →",
"log_home_all": "全部回零",
"log_cam_start": "相机已启动:", "log_cam_start": "相机已启动:",
"log_cam_stop": "相机已停止", "log_cam_stop": "相机已停止",
"log_poll_error": "轮询错误:", "log_clear": "✕ 清空",
"log_delete_failed": "删除失败",
"log_dir_all": "全部",
"log_dir_label": "方向:",
"log_dir_rx": "RX",
"log_dir_tx": "TX",
"log_download": "⬇ 下载",
"log_error": "错误:", "log_error": "错误:",
"confirm_cancel": "确定要取消打印吗?", "log_fan": "风扇 →",
"settings_title": "设置", "log_filter_placeholder": "筛选…",
"settings_connection": "连接", "log_home": "回零",
"settings_print": "打印设置", "log_home_all": "全部回零",
"settings_poll": "轮询间隔(秒)", "log_light_off": "灯光已关",
"log_light_on": "灯光已开",
"log_lvl_err": "⛔ 错误",
"log_lvl_label": "级别:",
"log_lvl_warn": "⚠ 警告",
"log_nozzle": "喷嘴 →",
"log_poll_error": "轮询错误:",
"log_print_action": "打印:",
"log_print_start": "打印开始:",
"log_topic_ams": "AMS",
"log_topic_info": "信息",
"log_topic_label": "主题:",
"log_topic_print": "打印",
"log_topic_status": "状态",
"nav_ams": "AMS",
"nav_browser": "浏览器",
"nav_console": "控制台",
"nav_dashboard": "仪表盘",
"nav_extras": "灯光 / 风扇",
"nav_motion": "运动",
"nav_print": "打印",
"nav_printers": "打印机",
"nav_settings": "设置", "nav_settings": "设置",
"settings_cat_display": "外观", "nav_temps": "温度",
"settings_cat_filament": "耗材", "orca_profile_done": "已导入",
"settings_cat_language": "语言", "orca_profile_dropmsg": "拖到此处或点击",
"settings_cat_theme": "切换浅色 / 深色", "orca_profile_help_html": "上传 OrcaSlicer 耗材文件夹的 <b>ZIP</b> 或单个 <b>.json</b> 文件。<br>在 OrcaSlicer 中: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"settings_filament_mapping": "耗材配置映射(每槽位)",
"settings_filament_mapping_save": "保存映射",
"settings_visible_vendors": "可见厂商(配置下拉框)",
"settings_visible_vendors_hint": "仅这些厂商会出现在槽位配置下拉框中。未选择 = 显示全部。“Generic”和您自己的配置始终可见。",
"settings_visible_vendors_save": "保存选择",
"progress_action_print": "打印",
"progress_action_slots": "分配槽位",
"progress_action_clear": "清除",
"settings_version": "版本",
"settings_save": "保存并重启",
"settings_printer_name": "打印机名称",
"settings_printer_ip": "打印机 IP",
"settings_mqtt_port": "MQTT 端口",
"settings_username": "MQTT 用户名",
"settings_password": "MQTT 密码",
"settings_device_id": "设备 ID",
"settings_mode_id": "模式 ID",
"hint_ip_no_port": "仅填写 IP不要端口 (例如 192.168.1.102)",
"settings_default_slot": "默认槽位 (单色)",
"settings_slot_auto": "自动 (所有已装载槽位)",
"settings_auto_leveling": "打印前自动调平",
"settings_camera_on_print": "打印开始时开启相机",
"settings_web_upload_warning": "打印网页上传文件时显示警告",
"update_check": "检查更新",
"update_checking": "检查中...",
"update_available": "可用",
"update_none": "已是最新版本",
"update_apply": "立即安装",
"update_applying": "下载中...",
"update_restarting": "重启中...",
"update_error": "错误",
"btn_connect": "⚡ 连接",
"btn_disconnect": "✕ 断开",
"lbl_conn_error": "连接错误:",
"slot_edit_title": "编辑槽位",
"slot_edit_color": "颜色",
"slot_edit_material": "材料",
"slot_edit_load": "⬇ 进料",
"slot_edit_unload": "⬆ 退料",
"slot_edit_save": "💾 保存",
"slot_edit_custom": "例如 PLA, PETG, ABS…",
"slot_edit_ok": "AMS 槽位",
"slot_edit_profile": "OrcaSlicer 配置",
"slot_edit_profile_hint": "在 OrcaSlicer 同步时发送具体品牌而不仅仅是“Generic”",
"slot_edit_profile_default": "— 通用 (默认) —",
"orca_profile_section": "OrcaSlicer 配置",
"orca_profile_hint": "导入你自己的 OrcaSlicer 耗材配置(在 Help → Show Configuration Folder 打开用户目录)", "orca_profile_hint": "导入你自己的 OrcaSlicer 耗材配置(在 Help → Show Configuration Folder 打开用户目录)",
"orca_profile_import_btn": "导入配置", "orca_profile_import_btn": "导入配置",
"orca_profile_import_link": "★ 导入自己的配置…", "orca_profile_import_link": "★ 导入自己的配置…",
"orca_profile_import_title": "导入你的 OrcaSlicer 配置", "orca_profile_import_title": "导入你的 OrcaSlicer 配置",
"orca_profile_help_html": "上传 OrcaSlicer 耗材文件夹的 <b>ZIP</b> 或单个 <b>.json</b> 文件。<br>在 OrcaSlicer 中: <i>Help → Show Configuration Folder → user/&lt;id&gt;/filament/</i>",
"orca_profile_dropmsg": "拖到此处或点击",
"orca_profile_list_label": "已导入", "orca_profile_list_label": "已导入",
"orca_profile_user_label": "自己的配置", "orca_profile_section": "OrcaSlicer 配置",
"orca_profile_user_empty": "",
"orca_profile_uploading": "上传中…",
"orca_profile_done": "已导入",
"orca_profile_skipped": "跳过", "orca_profile_skipped": "跳过",
"log_dir_all": "全部", "orca_profile_uploading": "上传中…",
"log_lvl_label": "级别:", "orca_profile_user_empty": "",
"file_ready_btn": "▶ 开始打印", "orca_profile_user_label": "自己的配置",
"file_slots_btn": "🎨 选择槽位", "panel_ams_title": "耗材",
"file_cancel_btn": "✕ 取消", "panel_browser_title": "文件浏览器",
"nav_printers": "打印机", "panel_console_title": "事件日志",
"skip_title": "✂ 跳过对象", "panel_extras_camera": "相机",
"skip_hint": "取消勾选不想继续打印的对象:", "panel_extras_fan": "风扇",
"skip_btn_label": "对象", "panel_extras_light": "灯光",
"skip_no_objects": "此打印任务没有对象。", "panel_motion_xy": "XY 轴",
"panel_motion_z": "Z 轴",
"panel_print_btn_cancel": "✕ 取消",
"panel_print_btn_pause": "⏸ 暂停",
"panel_print_btn_resume": "▶ 继续",
"panel_print_temps_live": "温度 (实时)",
"panel_print_title": "打印控制",
"panel_temps_bed": "热床",
"panel_temps_chart": "历史 (最近 60 次读数)",
"panel_temps_nozzle": "喷嘴",
"print_auto_leveling": "本次打印自动调平",
"printers_active": "● 活动",
"printers_current": "当前打印机",
"printers_empty_hint": "尚未设置打印机。",
"printers_loading": "加载中…",
"printers_none": "未配置打印机。",
"printers_remove": "移除打印机",
"printers_remove_confirm": "移除打印机 \"{name}\"? Bridge 将重启。",
"printers_switch": "切换 →",
"progress_action_clear": "清除",
"progress_action_print": "打印",
"progress_action_slots": "分配槽位",
"settings_auto_leveling": "打印前自动调平",
"settings_auto_leveling_label": "打印前自动调平",
"settings_btn_tooltip": "设置",
"settings_camera_on_print": "打印开始时开启相机",
"settings_cat_connection": "连接",
"settings_cat_display": "外观",
"settings_cat_filament": "耗材",
"settings_cat_language": "语言",
"settings_cat_printer": "打印机",
"settings_cat_system": "系统",
"settings_cat_theme": "切换浅色 / 深色",
"settings_connection": "连接",
"settings_default_slot": "默认槽位 (单色)",
"settings_device_id": "设备 ID",
"settings_device_id_hint": "32 个十六进制字符",
"settings_device_id_placeholder": "32 个十六进制字符",
"settings_filament_mapping": "耗材配置映射(每槽位)",
"settings_filament_mapping_hint": "每个 AMS 槽位的固定 Orca 配置。在切片器同步时Bridge 会发送此配置而不是“Generic”。",
"settings_filament_mapping_label": "耗材配置映射(每槽位)",
"settings_filament_mapping_save": "保存映射",
"settings_filament_mapping_save_label": "保存映射",
"settings_file_ready_banner": "打印栏",
"settings_file_ready_dialog": "打印对话框",
"settings_file_ready_mode": "上传后:开始打印行为",
"settings_language": "语言",
"settings_mode_id": "模式 ID",
"settings_mode_id_placeholder": "20030",
"settings_mqtt_port": "MQTT 端口",
"settings_mqtt_username_placeholder": "userXXXXXXXX",
"settings_orca_profiles_import": "导入配置文件",
"settings_orca_profiles_label": "OrcaSlicer 配置文件",
"settings_password": "MQTT 密码",
"settings_poll": "轮询间隔(秒)",
"settings_poll_interval_hint": "Bridge 查询打印机状态的频率",
"settings_poll_interval_label": "轮询间隔(秒)",
"settings_print": "打印设置",
"settings_printer_ip": "打印机 IP",
"settings_printer_name": "打印机名称",
"settings_printer_name_placeholder": "例如 Kobra X 左",
"settings_save": "保存并重启",
"settings_slot_auto": "自动 (所有已装载槽位)",
"settings_theme_toggle": "切换浅色 / 深色",
"settings_title": "设置",
"settings_username": "MQTT 用户名",
"settings_vendor_filter_placeholder": "搜索厂商…",
"settings_version": "版本",
"settings_visible_vendors": "可见厂商(配置下拉框)",
"settings_visible_vendors_hint": "仅这些厂商会出现在槽位配置下拉框中。未选择 = 显示全部。“Generic”和您自己的配置始终可见。",
"settings_visible_vendors_label": "可见厂商(配置下拉框)",
"settings_visible_vendors_save": "保存选择",
"settings_visible_vendors_save_label": "保存选择",
"settings_web_upload_warning": "打印网页上传文件时显示警告",
"sf_all": "全部",
"sf_err": "✗ 失败",
"sf_new": "新",
"sf_ok": "✓ 已完成",
"skip_already": "已跳过", "skip_already": "已跳过",
"skip_btn_label": "对象",
"skip_cancel": "取消",
"skip_confirm": "跳过",
"skip_confirm_btn": "跳过",
"skip_hint": "取消勾选不想继续打印的对象:",
"skip_no_objects": "此打印任务没有对象。",
"skip_select_at_least_one": "请至少选择一个对象。", "skip_select_at_least_one": "请至少选择一个对象。",
"skip_sending": "发送中 …", "skip_sending": "发送中 …",
"skip_success": "对象将被跳过。", "skip_success": "对象将被跳过。",
"fd_objects_hint": "跳过对象 (可选):", "skip_title": "跳过对象",
"fd_objects_toggle": "跳过对象", "slot_edit_color": "颜色",
"fd_slots_hint": "将 GCode 通道分配到 AMS 槽位:", "slot_edit_custom": "例如 PLA, PETG, ABS…",
"fd_cancel": "取消", "slot_edit_load": "⬇ 进料",
"fd_print": "▶ 打印", "slot_edit_material": "材料",
"fd_no_slots_msg": "没有已装载的 AMS 槽位。{br}仍要开始打印吗?", "slot_edit_ok": "AMS 槽位",
"fd_slot": "槽位", "slot_edit_profile": "OrcaSlicer 配置",
"fd_no_matching_material": "无匹配材料", "slot_edit_profile_default": "— 通用 (默认) —",
"fd_used": "已用", "slot_edit_profile_hint": "在 OrcaSlicer 同步时发送具体品牌而不仅仅是“Generic”",
"add_printer": "添加打印机", "slot_edit_save": "💾 保存",
"apd_lbl_ip": "打印机 IP", "slot_edit_title": "编辑槽位",
"apd_lbl_name": "名称 (可选)", "slot_edit_unload": "⬆ 退料",
"apd_placeholder_name": "例如 Kobra X 客厅", "speed_normal": "⚡ 标准",
"apd_cancel": "取消", "speed_silent": "🐢 静音",
"apd_confirm": "添加", "speed_sport": "🚀 运动",
"apd_fetching": "正在从打印机获取数据…",
"apd_success": "打印机已添加Bridge 正在重启…",
"apd_err_ip": "请输入 IP 地址",
"printers_remove": "移除打印机",
"printers_remove_confirm": "移除打印机 \"{name}\"? Bridge 将重启。",
"printers_active": "● 活动",
"printers_switch": "切换 →",
"printers_current": "当前打印机",
"printers_loading": "加载中…",
"printers_none": "未配置打印机。",
"printers_empty_hint": "尚未设置打印机。",
"nav_browser": "浏览器",
"panel_browser_title": "文件浏览器",
"store_search_placeholder": "🔍 搜索…",
"store_empty": "尚未上传文件。",
"store_refresh": "↻ 刷新",
"store_print": "▶ 打印",
"store_download": "⬇ 下载",
"store_delete_confirm": "删除文件?",
"store_print_confirm": "打印文件?",
"store_web_verify_title": "验证文件",
"store_web_verify_msg": "请确认此文件是为 Anycubic Kobra X 创建的。",
"store_web_verify_confirm": "确认",
"store_web_verify_abort": "取消",
"store_no_results": "未找到文件。",
"store_never": "从未打印",
"store_estimate": "估算",
"store_upload_label_prefix": "将 GCode 拖到这里或 ",
"store_upload_label_browse": "浏览",
"store_upload_busy": "⏳ 上传中…",
"store_upload_success": "✓ {file}",
"store_upload_error": "✗ {error}",
"store_upload_only_gcode": "✗ 仅允许 GCode 文件 (.gcode, .3mf, .bgcode)",
"sf_all": "全部",
"sf_ok": "✓ 已完成",
"sf_err": "✗ 失败",
"sf_new": "新",
"ss_date": "↓ 日期", "ss_date": "↓ 日期",
"ss_name": "AZ 名称",
"ss_dur": "⏱ 打印时间", "ss_dur": "⏱ 打印时间",
"ace_dry_preset_pla": "PLA", "ss_name": "AZ 名称",
"ace_dry_preset_pla_plus": "PLA+", "store_delete_confirm": "删除文件?",
"ace_dry_preset_petg": "PETG", "store_download": "⬇ 下载",
"ace_dry_preset_tpu": "TPU", "store_empty": "尚未上传文件。",
"ace_dry_preset_abs_asa": "ABS / ASA", "store_estimate": "估算",
"ace_dry_preset_pa_pc": "PA / PC", "store_never": "从未打印",
"ace_dry_preset_custom": "自定义", "store_no_results": "未找到文件。",
"fd_options_title": "选项", "store_print": "▶ 打印",
"print_auto_leveling": "本次打印自动调平", "store_print_confirm": "打印文件?",
"settings_file_ready_mode": "开始打印对话框", "store_refresh": "↻ 刷新",
"settings_file_ready_banner": "打印栏", "store_search_placeholder": "🔍 搜索…",
"settings_file_ready_dialog": "打印对话框", "store_upload_busy": "⏳ 上传中…",
"log_dir_rx": "RX", "store_upload_error": "✗ {error}",
"log_dir_tx": "TX", "store_upload_label_browse": "浏览",
"log_dir_label": "方向:", "store_upload_label_prefix": "将 GCode 拖到这里或 ",
"log_lvl_err": "⛔ 错误", "store_upload_only_gcode": "✗ 仅允许 GCode 文件 (.gcode, .3mf, .bgcode)",
"log_lvl_warn": "⚠ 警告", "store_upload_success": "✓ {file}",
"log_topic_label": "主题:", "store_web_verify_abort": "取消",
"log_topic_ams": "AMS", "store_web_verify_confirm": "确认",
"log_topic_print": "打印", "store_web_verify_msg": "请验证此文件是为Anycubic Kobra X创建的。",
"log_topic_info": "信息", "store_web_verify_title": "验证文件",
"log_topic_status": "状态", "update_apply": "立即安装",
"log_download": "下载", "update_applying": "下载中...",
"log_auto": "⬇ 自动", "update_available": "可用",
"log_clear": "✕ 清空", "update_check": "检查更新",
"log_filter_placeholder": "筛选…", "update_checking": "检查中...",
"skip_cancel": "取消", "update_error": "错误",
"skip_confirm": "跳过" "update_none": "已是最新版本",
"update_restarting": "重启中..."
} }