2022-01-30 18:49:01 +03:00
|
|
|
<script lang="ts">
|
|
|
|
import { _ } from 'svelte-i18n';
|
|
|
|
|
|
|
|
import { Configs } from '../empathize';
|
|
|
|
|
|
|
|
export let visible: boolean = false;
|
|
|
|
|
2022-01-30 23:48:34 +03:00
|
|
|
export let valueChanged: (field: 'width' | 'height', value: string) => void = () => {};
|
2022-01-30 18:49:01 +03:00
|
|
|
|
2022-01-30 23:48:34 +03:00
|
|
|
let virtual_desktop = {
|
|
|
|
width: 0,
|
|
|
|
height: 0
|
|
|
|
};
|
|
|
|
|
|
|
|
Configs.get('wine.virtual_desktop').then((desktop) => virtual_desktop = desktop as typeof virtual_desktop);
|
2022-01-30 18:49:01 +03:00
|
|
|
|
2022-01-30 23:48:34 +03:00
|
|
|
const inputHandler = (event: KeyboardEvent, field: 'width' | 'height') => {
|
|
|
|
const input = event.srcElement as HTMLInputElement;
|
2022-01-30 18:49:01 +03:00
|
|
|
|
2022-01-30 23:48:34 +03:00
|
|
|
const content = input.value
|
2022-01-30 18:49:01 +03:00
|
|
|
.replace(/\b0+/g, '')
|
|
|
|
.replace(/[^0-9.]/g, '')
|
|
|
|
.replace(/(\..*?)\..*/g, '$1')
|
|
|
|
.replace(/([0-9]{0,6}(\.[0-9]{0,2})?).*/g, '$1');
|
|
|
|
|
|
|
|
valueChanged(field, content);
|
|
|
|
};
|
|
|
|
</script>
|
2022-01-30 23:48:34 +03:00
|
|
|
|
2022-01-30 18:49:01 +03:00
|
|
|
<div style="display: {visible ? 'block' : 'none'}">
|
2022-02-10 15:22:45 +03:00
|
|
|
<h3>{$_('settings.enhancements.wine.items.winevd.settings.title')}</h3>
|
2022-01-30 18:49:01 +03:00
|
|
|
|
2022-01-30 23:48:34 +03:00
|
|
|
<table class="table" style="margin: 16px 0">
|
2022-01-30 18:49:01 +03:00
|
|
|
<tr>
|
|
|
|
<td>
|
2022-02-10 15:22:45 +03:00
|
|
|
<span>{$_('settings.enhancements.wine.items.winevd.settings.items.width')}</span>
|
2022-01-30 18:49:01 +03:00
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2022-01-30 23:48:34 +03:00
|
|
|
<input value={virtual_desktop.width} on:keyup={(e) => inputHandler(e, 'width')} />
|
2022-01-30 18:49:01 +03:00
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td>
|
2022-02-10 15:22:45 +03:00
|
|
|
<span>{$_('settings.enhancements.wine.items.winevd.settings.items.height')}</span>
|
2022-01-30 18:49:01 +03:00
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2022-01-30 23:48:34 +03:00
|
|
|
<input value={virtual_desktop.height} on:keyup={(e) => inputHandler(e, 'height')} />
|
2022-01-30 18:49:01 +03:00
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<style lang="sass">
|
|
|
|
table.table
|
|
|
|
td:last-child
|
|
|
|
display: inline-flex
|
|
|
|
align-items: center
|
|
|
|
|
|
|
|
width: 100%
|
|
|
|
</style>
|