Squashed commit message
Some checks failed
Telegram Mini App Shop Builder / Compute version metadata (push) Has been cancelled
Telegram Mini App Shop Builder / Run Frontend tests (push) Has been cancelled
Telegram Mini App Shop Builder / Run Backend tests (push) Has been cancelled
Telegram Mini App Shop Builder / Run PHP_CodeSniffer (push) Has been cancelled
Telegram Mini App Shop Builder / Build module. (push) Has been cancelled
Telegram Mini App Shop Builder / release (push) Has been cancelled

This commit is contained in:
2026-03-11 22:08:41 +03:00
commit f329bfa9d9
585 changed files with 65605 additions and 0 deletions

View File

@@ -0,0 +1,66 @@
<template>
<div>
<input
type="search"
name="category"
:value="`${category?.name || ''}`"
placeholder="Начните вводить название категории..."
class="form-control"
ref="categoryRef"
/>
</div>
</template>
<script setup>
import {onMounted, onUnmounted, ref} from "vue";
const category = defineModel();
const categoryRef = ref(null);
onMounted(() => {
const input = categoryRef.value;
if (!input) {
return;
}
$(input).autocomplete({
'source': function (request, response) {
if ($(input).val().length === 0) {
$(input).val(null);
}
$.ajax({
url: `index.php?route=catalog/category/autocomplete&user_token=${window.AcmeShop.user_token}&filter_name=` + encodeURIComponent(request),
dataType: 'json',
success: function (json) {
response($.map(json, function (item) {
return {
label: item['name'],
value: item['category_id']
}
}));
}
});
},
'select': function (item) {
category.value = {
category_id: Number(item['value']),
name: item['label'],
};
}
});
});
onUnmounted(() => {
const input = categoryRef.value;
if (!input) {
return;
}
$(input).autocomplete('destroy');
});
</script>
<style scoped lang="scss">
</style>