2 Commits

Author SHA1 Message Date
fc25246594 1.9.10 2026-02-12 13:58:44 +01:00
d7e104c17a fix: priorytet ESC i zatrzymanie propagacji w modalach 2026-02-12 13:58:28 +01:00
6 changed files with 25 additions and 16 deletions

4
package-lock.json generated
View File

@@ -1,12 +1,12 @@
{ {
"name": "vue-nonograms-solid", "name": "vue-nonograms-solid",
"version": "1.9.9", "version": "1.9.10",
"lockfileVersion": 3, "lockfileVersion": 3,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "vue-nonograms-solid", "name": "vue-nonograms-solid",
"version": "1.9.9", "version": "1.9.10",
"dependencies": { "dependencies": {
"fireworks-js": "^2.10.8", "fireworks-js": "^2.10.8",
"flag-icons": "^7.5.0", "flag-icons": "^7.5.0",

View File

@@ -1,6 +1,6 @@
{ {
"name": "vue-nonograms-solid", "name": "vue-nonograms-solid",
"version": "1.9.9", "version": "1.9.10",
"type": "module", "type": "module",
"scripts": { "scripts": {
"dev": "vite", "dev": "vite",

View File

@@ -28,6 +28,21 @@ const appVersion = __APP_VERSION__;
let displayModeMedia = null; let displayModeMedia = null;
let prefersColorSchemeMedia = null; let prefersColorSchemeMedia = null;
const onKeyDownGlobal = (e) => {
if (e.key !== 'Escape') return;
if (showSimulation.value) {
showSimulation.value = false;
return;
}
if (showCustomModal.value) {
showCustomModal.value = false;
return;
}
if (store.isGameWon) {
store.closeWinModal();
}
};
const installLabel = computed(() => { const installLabel = computed(() => {
return isCoarsePointer.value ? t('pwa.installMobile') : t('pwa.installDesktop'); return isCoarsePointer.value ? t('pwa.installMobile') : t('pwa.installDesktop');
}); });
@@ -114,6 +129,7 @@ onMounted(() => {
} else if (displayModeMedia?.addListener) { } else if (displayModeMedia?.addListener) {
displayModeMedia.addListener(updateStandalone); displayModeMedia.addListener(updateStandalone);
} }
window.addEventListener('keydown', onKeyDownGlobal);
} }
}); });
@@ -131,6 +147,7 @@ onUnmounted(() => {
} else if (displayModeMedia?.removeListener) { } else if (displayModeMedia?.removeListener) {
displayModeMedia.removeListener(updateStandalone); displayModeMedia.removeListener(updateStandalone);
} }
window.removeEventListener('keydown', onKeyDownGlobal);
}); });
</script> </script>
@@ -279,4 +296,4 @@ onUnmounted(() => {
border-top: 1px solid var(--panel-border); border-top: 1px solid var(--panel-border);
z-index: 90; z-index: 90;
} }
</style> </style>

View File

@@ -156,7 +156,6 @@ const stopDrag = () => {
onUnmounted(() => { onUnmounted(() => {
window.removeEventListener('mousemove', onDrag); window.removeEventListener('mousemove', onDrag);
window.removeEventListener('mouseup', stopDrag); window.removeEventListener('mouseup', stopDrag);
window.removeEventListener('keydown', onKeyDown);
}); });
const showAdvanced = ref(false); const showAdvanced = ref(false);
@@ -170,16 +169,6 @@ const toggleAdvanced = () => {
} }
}; };
const handleClose = () => {
emit('close');
};
const onKeyDown = (e) => {
if (e.key === 'Escape') {
handleClose();
}
};
onMounted(() => { onMounted(() => {
const savedSize = localStorage.getItem('nonograms_custom_size'); const savedSize = localStorage.getItem('nonograms_custom_size');
if (savedSize && !isNaN(savedSize)) { if (savedSize && !isNaN(savedSize)) {
@@ -192,7 +181,6 @@ onMounted(() => {
} }
// Don't draw map initially if hidden // Don't draw map initially if hidden
window.addEventListener('keydown', onKeyDown);
}); });
watch([customSize, fillRate], () => { watch([customSize, fillRate], () => {

View File

@@ -23,6 +23,8 @@ let stopRequested = false;
const onKeyDown = (e) => { const onKeyDown = (e) => {
if (e.key === 'Escape') { if (e.key === 'Escape') {
e.stopImmediatePropagation?.();
e.preventDefault?.();
emit('close'); emit('close');
} }
}; };

View File

@@ -28,6 +28,8 @@ const handleClose = () => {
const handleKeyDown = (e) => { const handleKeyDown = (e) => {
if (e.key === 'Escape') { if (e.key === 'Escape') {
e.stopImmediatePropagation?.();
e.preventDefault?.();
handleClose(); handleClose();
} }
}; };