2024-11-28 09:59:06 +00:00
|
|
|
var __defProp = Object.defineProperty;
|
|
|
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
2025-01-03 00:20:48 +00:00
|
|
|
import { d as defineComponent, c as computed, o as openBlock, f as createElementBlock, F as Fragment, E as renderList, N as createVNode, M as withCtx, aE as createTextVNode, X as toDisplayString, j as unref, aI as script, I as createCommentVNode, ab as ref, cn as FilterMatchMode, a$ as useKeybindingStore, a2 as useCommandStore, a1 as useI18n, af as normalizeI18nKey, w as watchEffect, bs as useToast, r as resolveDirective, k as createBlock, co as SearchBox, H as createBaseVNode, l as script$2, av as script$4, bM as withModifiers, bZ as script$5, aP as script$6, i as withDirectives, cp as _sfc_main$2, aL as pushScopeId, aM as popScopeId, cq as KeyComboImpl, cr as KeybindingImpl, _ as _export_sfc } from "./index-De3LoLTp.js";
|
|
|
|
import { s as script$1, a as script$3 } from "./index-BCSm_DIF.js";
|
|
|
|
import { u as useKeybindingService } from "./keybindingService-BlJ-gQG4.js";
|
|
|
|
import "./index-UBW0i6QV.js";
|
|
|
|
import "./index-BwVbIa1-.js";
|
2024-11-28 09:59:06 +00:00
|
|
|
const _hoisted_1$1 = {
|
|
|
|
key: 0,
|
|
|
|
class: "px-2"
|
|
|
|
};
|
|
|
|
const _sfc_main$1 = /* @__PURE__ */ defineComponent({
|
|
|
|
__name: "KeyComboDisplay",
|
|
|
|
props: {
|
|
|
|
keyCombo: {},
|
|
|
|
isModified: { type: Boolean, default: false }
|
|
|
|
},
|
|
|
|
setup(__props) {
|
|
|
|
const props = __props;
|
|
|
|
const keySequences = computed(() => props.keyCombo.getKeySequences());
|
|
|
|
return (_ctx, _cache) => {
|
|
|
|
return openBlock(), createElementBlock("span", null, [
|
|
|
|
(openBlock(true), createElementBlock(Fragment, null, renderList(keySequences.value, (sequence, index) => {
|
|
|
|
return openBlock(), createElementBlock(Fragment, { key: index }, [
|
|
|
|
createVNode(unref(script), {
|
|
|
|
severity: _ctx.isModified ? "info" : "secondary"
|
|
|
|
}, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
createTextVNode(toDisplayString(sequence), 1)
|
|
|
|
]),
|
|
|
|
_: 2
|
|
|
|
}, 1032, ["severity"]),
|
|
|
|
index < keySequences.value.length - 1 ? (openBlock(), createElementBlock("span", _hoisted_1$1, "+")) : createCommentVNode("", true)
|
|
|
|
], 64);
|
|
|
|
}), 128))
|
|
|
|
]);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
2025-01-02 21:18:54 +00:00
|
|
|
const _withScopeId = /* @__PURE__ */ __name((n) => (pushScopeId("data-v-2554ab36"), n = n(), popScopeId(), n), "_withScopeId");
|
2024-11-28 09:59:06 +00:00
|
|
|
const _hoisted_1 = { class: "actions invisible flex flex-row" };
|
|
|
|
const _hoisted_2 = ["title"];
|
|
|
|
const _hoisted_3 = { key: 1 };
|
|
|
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
|
__name: "KeybindingPanel",
|
|
|
|
setup(__props) {
|
|
|
|
const filters = ref({
|
|
|
|
global: { value: "", matchMode: FilterMatchMode.CONTAINS }
|
|
|
|
});
|
|
|
|
const keybindingStore = useKeybindingStore();
|
2025-01-02 21:18:54 +00:00
|
|
|
const keybindingService = useKeybindingService();
|
2024-11-28 09:59:06 +00:00
|
|
|
const commandStore = useCommandStore();
|
2024-12-16 19:38:24 +00:00
|
|
|
const { t } = useI18n();
|
2024-11-28 09:59:06 +00:00
|
|
|
const commandsData = computed(() => {
|
|
|
|
return Object.values(commandStore.commands).map((command) => ({
|
|
|
|
id: command.id,
|
2024-12-16 19:38:24 +00:00
|
|
|
label: t(`commands.${normalizeI18nKey(command.id)}.label`, command.label),
|
2024-11-28 09:59:06 +00:00
|
|
|
keybinding: keybindingStore.getKeybindingByCommandId(command.id)
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
const selectedCommandData = ref(null);
|
|
|
|
const editDialogVisible = ref(false);
|
|
|
|
const newBindingKeyCombo = ref(null);
|
|
|
|
const currentEditingCommand = ref(null);
|
|
|
|
const keybindingInput = ref(null);
|
|
|
|
const existingKeybindingOnCombo = computed(() => {
|
|
|
|
if (!currentEditingCommand.value) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (currentEditingCommand.value.keybinding?.combo?.equals(
|
|
|
|
newBindingKeyCombo.value
|
|
|
|
)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (!newBindingKeyCombo.value) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
return keybindingStore.getKeybinding(newBindingKeyCombo.value);
|
|
|
|
});
|
|
|
|
function editKeybinding(commandData) {
|
|
|
|
currentEditingCommand.value = commandData;
|
|
|
|
newBindingKeyCombo.value = commandData.keybinding ? commandData.keybinding.combo : null;
|
|
|
|
editDialogVisible.value = true;
|
|
|
|
}
|
|
|
|
__name(editKeybinding, "editKeybinding");
|
|
|
|
watchEffect(() => {
|
|
|
|
if (editDialogVisible.value) {
|
|
|
|
setTimeout(() => {
|
|
|
|
keybindingInput.value?.$el?.focus();
|
|
|
|
}, 300);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
function removeKeybinding(commandData) {
|
|
|
|
if (commandData.keybinding) {
|
|
|
|
keybindingStore.unsetKeybinding(commandData.keybinding);
|
2025-01-02 21:18:54 +00:00
|
|
|
keybindingService.persistUserKeybindings();
|
2024-11-28 09:59:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
__name(removeKeybinding, "removeKeybinding");
|
|
|
|
function captureKeybinding(event) {
|
|
|
|
const keyCombo = KeyComboImpl.fromEvent(event);
|
|
|
|
newBindingKeyCombo.value = keyCombo;
|
|
|
|
}
|
|
|
|
__name(captureKeybinding, "captureKeybinding");
|
|
|
|
function cancelEdit() {
|
|
|
|
editDialogVisible.value = false;
|
|
|
|
currentEditingCommand.value = null;
|
|
|
|
newBindingKeyCombo.value = null;
|
|
|
|
}
|
|
|
|
__name(cancelEdit, "cancelEdit");
|
|
|
|
function saveKeybinding() {
|
|
|
|
if (currentEditingCommand.value && newBindingKeyCombo.value) {
|
|
|
|
const updated = keybindingStore.updateKeybindingOnCommand(
|
|
|
|
new KeybindingImpl({
|
|
|
|
commandId: currentEditingCommand.value.id,
|
|
|
|
combo: newBindingKeyCombo.value
|
|
|
|
})
|
|
|
|
);
|
|
|
|
if (updated) {
|
2025-01-02 21:18:54 +00:00
|
|
|
keybindingService.persistUserKeybindings();
|
2024-11-28 09:59:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
cancelEdit();
|
|
|
|
}
|
|
|
|
__name(saveKeybinding, "saveKeybinding");
|
|
|
|
const toast = useToast();
|
|
|
|
async function resetKeybindings() {
|
|
|
|
keybindingStore.resetKeybindings();
|
2025-01-02 21:18:54 +00:00
|
|
|
await keybindingService.persistUserKeybindings();
|
2024-11-28 09:59:06 +00:00
|
|
|
toast.add({
|
|
|
|
severity: "info",
|
|
|
|
summary: "Info",
|
|
|
|
detail: "Keybindings reset",
|
|
|
|
life: 3e3
|
|
|
|
});
|
|
|
|
}
|
|
|
|
__name(resetKeybindings, "resetKeybindings");
|
|
|
|
return (_ctx, _cache) => {
|
|
|
|
const _directive_tooltip = resolveDirective("tooltip");
|
|
|
|
return openBlock(), createBlock(_sfc_main$2, {
|
|
|
|
value: "Keybinding",
|
|
|
|
class: "keybinding-panel"
|
|
|
|
}, {
|
|
|
|
header: withCtx(() => [
|
|
|
|
createVNode(SearchBox, {
|
|
|
|
modelValue: filters.value["global"].value,
|
|
|
|
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => filters.value["global"].value = $event),
|
2024-12-16 19:38:24 +00:00
|
|
|
placeholder: _ctx.$t("g.searchKeybindings") + "..."
|
2024-11-28 09:59:06 +00:00
|
|
|
}, null, 8, ["modelValue", "placeholder"])
|
|
|
|
]),
|
|
|
|
default: withCtx(() => [
|
|
|
|
createVNode(unref(script$3), {
|
|
|
|
value: commandsData.value,
|
|
|
|
selection: selectedCommandData.value,
|
|
|
|
"onUpdate:selection": _cache[1] || (_cache[1] = ($event) => selectedCommandData.value = $event),
|
|
|
|
"global-filter-fields": ["id"],
|
|
|
|
filters: filters.value,
|
|
|
|
selectionMode: "single",
|
|
|
|
stripedRows: "",
|
|
|
|
pt: {
|
|
|
|
header: "px-0"
|
|
|
|
}
|
|
|
|
}, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
createVNode(unref(script$1), {
|
|
|
|
field: "actions",
|
|
|
|
header: ""
|
|
|
|
}, {
|
|
|
|
body: withCtx((slotProps) => [
|
|
|
|
createBaseVNode("div", _hoisted_1, [
|
|
|
|
createVNode(unref(script$2), {
|
|
|
|
icon: "pi pi-pencil",
|
|
|
|
class: "p-button-text",
|
|
|
|
onClick: /* @__PURE__ */ __name(($event) => editKeybinding(slotProps.data), "onClick")
|
|
|
|
}, null, 8, ["onClick"]),
|
|
|
|
createVNode(unref(script$2), {
|
|
|
|
icon: "pi pi-trash",
|
|
|
|
class: "p-button-text p-button-danger",
|
|
|
|
onClick: /* @__PURE__ */ __name(($event) => removeKeybinding(slotProps.data), "onClick"),
|
|
|
|
disabled: !slotProps.data.keybinding
|
|
|
|
}, null, 8, ["onClick", "disabled"])
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
}),
|
|
|
|
createVNode(unref(script$1), {
|
|
|
|
field: "id",
|
2025-01-02 21:18:54 +00:00
|
|
|
header: _ctx.$t("g.command"),
|
2024-11-28 09:59:06 +00:00
|
|
|
sortable: "",
|
|
|
|
class: "max-w-64 2xl:max-w-full"
|
|
|
|
}, {
|
|
|
|
body: withCtx((slotProps) => [
|
|
|
|
createBaseVNode("div", {
|
|
|
|
class: "overflow-hidden text-ellipsis whitespace-nowrap",
|
|
|
|
title: slotProps.data.id
|
2024-12-16 19:38:24 +00:00
|
|
|
}, toDisplayString(slotProps.data.label), 9, _hoisted_2)
|
2024-11-28 09:59:06 +00:00
|
|
|
]),
|
|
|
|
_: 1
|
2025-01-02 21:18:54 +00:00
|
|
|
}, 8, ["header"]),
|
2024-11-28 09:59:06 +00:00
|
|
|
createVNode(unref(script$1), {
|
|
|
|
field: "keybinding",
|
2025-01-02 21:18:54 +00:00
|
|
|
header: _ctx.$t("g.keybinding")
|
2024-11-28 09:59:06 +00:00
|
|
|
}, {
|
|
|
|
body: withCtx((slotProps) => [
|
|
|
|
slotProps.data.keybinding ? (openBlock(), createBlock(_sfc_main$1, {
|
|
|
|
key: 0,
|
|
|
|
keyCombo: slotProps.data.keybinding.combo,
|
|
|
|
isModified: unref(keybindingStore).isCommandKeybindingModified(slotProps.data.id)
|
|
|
|
}, null, 8, ["keyCombo", "isModified"])) : (openBlock(), createElementBlock("span", _hoisted_3, "-"))
|
|
|
|
]),
|
|
|
|
_: 1
|
2025-01-02 21:18:54 +00:00
|
|
|
}, 8, ["header"])
|
2024-11-28 09:59:06 +00:00
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
}, 8, ["value", "selection", "filters"]),
|
|
|
|
createVNode(unref(script$6), {
|
|
|
|
class: "min-w-96",
|
|
|
|
visible: editDialogVisible.value,
|
|
|
|
"onUpdate:visible": _cache[2] || (_cache[2] = ($event) => editDialogVisible.value = $event),
|
|
|
|
modal: "",
|
|
|
|
header: currentEditingCommand.value?.id,
|
|
|
|
onHide: cancelEdit
|
|
|
|
}, {
|
|
|
|
footer: withCtx(() => [
|
|
|
|
createVNode(unref(script$2), {
|
|
|
|
label: "Save",
|
|
|
|
icon: "pi pi-check",
|
|
|
|
onClick: saveKeybinding,
|
|
|
|
disabled: !!existingKeybindingOnCombo.value,
|
|
|
|
autofocus: ""
|
|
|
|
}, null, 8, ["disabled"])
|
|
|
|
]),
|
|
|
|
default: withCtx(() => [
|
|
|
|
createBaseVNode("div", null, [
|
|
|
|
createVNode(unref(script$4), {
|
|
|
|
class: "mb-2 text-center",
|
|
|
|
ref_key: "keybindingInput",
|
|
|
|
ref: keybindingInput,
|
|
|
|
modelValue: newBindingKeyCombo.value?.toString() ?? "",
|
|
|
|
placeholder: "Press keys for new binding",
|
|
|
|
onKeydown: withModifiers(captureKeybinding, ["stop", "prevent"]),
|
|
|
|
autocomplete: "off",
|
|
|
|
fluid: "",
|
|
|
|
invalid: !!existingKeybindingOnCombo.value
|
|
|
|
}, null, 8, ["modelValue", "invalid"]),
|
|
|
|
existingKeybindingOnCombo.value ? (openBlock(), createBlock(unref(script$5), {
|
|
|
|
key: 0,
|
|
|
|
severity: "error"
|
|
|
|
}, {
|
|
|
|
default: withCtx(() => [
|
|
|
|
createTextVNode(" Keybinding already exists on "),
|
|
|
|
createVNode(unref(script), {
|
|
|
|
severity: "secondary",
|
|
|
|
value: existingKeybindingOnCombo.value.commandId
|
|
|
|
}, null, 8, ["value"])
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
})) : createCommentVNode("", true)
|
|
|
|
])
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
}, 8, ["visible", "header"]),
|
|
|
|
withDirectives(createVNode(unref(script$2), {
|
|
|
|
class: "mt-4",
|
2024-12-16 19:38:24 +00:00
|
|
|
label: _ctx.$t("g.reset"),
|
2024-11-28 09:59:06 +00:00
|
|
|
icon: "pi pi-trash",
|
|
|
|
severity: "danger",
|
|
|
|
fluid: "",
|
|
|
|
text: "",
|
|
|
|
onClick: resetKeybindings
|
|
|
|
}, null, 8, ["label"]), [
|
2024-12-16 19:38:24 +00:00
|
|
|
[_directive_tooltip, _ctx.$t("g.resetKeybindingsTooltip")]
|
2024-11-28 09:59:06 +00:00
|
|
|
])
|
|
|
|
]),
|
|
|
|
_: 1
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
2025-01-02 21:18:54 +00:00
|
|
|
const KeybindingPanel = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-2554ab36"]]);
|
2024-11-28 09:59:06 +00:00
|
|
|
export {
|
|
|
|
KeybindingPanel as default
|
|
|
|
};
|
2025-01-03 00:20:48 +00:00
|
|
|
//# sourceMappingURL=KeybindingPanel-BAf87LRH.js.map
|