@winchsa/ui 0.1.33 → 0.1.35
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Breadcrumbs.d.vue.ts +7 -0
- package/dist/components/Breadcrumbs.vue +46 -0
- package/dist/components/Breadcrumbs.vue.d.ts +7 -0
- package/dist/components/CustomizerSection.d.vue.ts +17 -0
- package/dist/components/CustomizerSection.vue +19 -0
- package/dist/components/CustomizerSection.vue.d.ts +17 -0
- package/dist/components/DialogCloseBtn.d.vue.ts +7 -0
- package/dist/components/DialogCloseBtn.vue +20 -0
- package/dist/components/DialogCloseBtn.vue.d.ts +7 -0
- package/dist/components/Drawer.d.vue.ts +28 -0
- package/dist/components/Drawer.vue +60 -0
- package/dist/components/Drawer.vue.d.ts +28 -0
- package/dist/components/IconBtn.d.vue.ts +18 -0
- package/dist/components/IconBtn.vue +24 -0
- package/dist/components/IconBtn.vue.d.ts +18 -0
- package/dist/components/LoadingBar.d.vue.ts +6 -0
- package/dist/components/LoadingBar.vue +31 -0
- package/dist/components/LoadingBar.vue.d.ts +6 -0
- package/dist/components/LoadingDialog.d.vue.ts +12 -0
- package/dist/components/LoadingDialog.vue +41 -0
- package/dist/components/LoadingDialog.vue.d.ts +12 -0
- package/dist/components/LoadingItem.d.vue.ts +25 -0
- package/dist/components/LoadingItem.vue +66 -0
- package/dist/components/LoadingItem.vue.d.ts +25 -0
- package/dist/components/Modal.d.vue.ts +50 -0
- package/dist/components/Modal.vue +155 -0
- package/dist/components/Modal.vue.d.ts +50 -0
- package/dist/components/MoreBtn.d.vue.ts +17 -0
- package/dist/components/MoreBtn.vue +28 -0
- package/dist/components/MoreBtn.vue.d.ts +17 -0
- package/dist/components/ScrollToTop.d.vue.ts +3 -0
- package/dist/components/ScrollToTop.vue +39 -0
- package/dist/components/ScrollToTop.vue.d.ts +3 -0
- package/dist/components/SiteTitle.d.vue.ts +3 -0
- package/dist/components/SiteTitle.vue +14 -0
- package/dist/components/SiteTitle.vue.d.ts +3 -0
- package/dist/components/Toaster.d.vue.ts +6 -0
- package/dist/components/Toaster.vue +19 -0
- package/dist/components/Toaster.vue.d.ts +6 -0
- package/dist/components/cards/AppCard.d.vue.ts +18 -0
- package/dist/components/cards/AppCard.vue +45 -0
- package/dist/components/cards/AppCard.vue.d.ts +18 -0
- package/dist/components/cards/AppCardActions.d.vue.ts +33 -0
- package/dist/components/cards/AppCardActions.vue +126 -0
- package/dist/components/cards/AppCardActions.vue.d.ts +33 -0
- package/dist/components/cards/CardStatisticsHorizontal.d.vue.ts +9 -0
- package/dist/components/cards/CardStatisticsHorizontal.vue +29 -0
- package/dist/components/cards/CardStatisticsHorizontal.vue.d.ts +9 -0
- package/dist/components/cards/CheckboxesCard.d.vue.ts +18 -0
- package/dist/components/cards/CheckboxesCard.vue +108 -0
- package/dist/components/cards/CheckboxesCard.vue.d.ts +18 -0
- package/dist/components/cards/HeaderCard.d.vue.ts +9 -0
- package/dist/components/cards/HeaderCard.vue +31 -0
- package/dist/components/cards/HeaderCard.vue.d.ts +9 -0
- package/dist/components/cards/ImageCard.d.vue.ts +33 -0
- package/dist/components/cards/ImageCard.vue +73 -0
- package/dist/components/cards/ImageCard.vue.d.ts +33 -0
- package/dist/components/cards/InputCard.d.vue.ts +21 -0
- package/dist/components/cards/InputCard.vue +60 -0
- package/dist/components/cards/InputCard.vue.d.ts +21 -0
- package/dist/components/cards/StaticCard.d.vue.ts +21 -0
- package/dist/components/cards/StaticCard.vue +37 -0
- package/dist/components/cards/StaticCard.vue.d.ts +21 -0
- package/dist/components/forms/Accordion.d.vue.ts +19 -0
- package/dist/components/forms/Accordion.vue +43 -0
- package/dist/components/forms/Accordion.vue.d.ts +19 -0
- package/dist/components/forms/AppBarSearch.d.vue.ts +43 -0
- package/dist/components/forms/AppBarSearch.vue +345 -0
- package/dist/components/forms/AppBarSearch.vue.d.ts +43 -0
- package/dist/components/forms/AppCombobox.d.vue.ts +13 -0
- package/dist/components/forms/AppCombobox.vue +60 -0
- package/dist/components/forms/AppCombobox.vue.d.ts +13 -0
- package/dist/components/forms/AppDrawerHeaderSection.d.vue.ts +20 -0
- package/dist/components/forms/AppDrawerHeaderSection.vue +21 -0
- package/dist/components/forms/AppDrawerHeaderSection.vue.d.ts +20 -0
- package/dist/components/forms/AppLabel.d.vue.ts +24 -0
- package/dist/components/forms/AppLabel.vue +47 -0
- package/dist/components/forms/AppLabel.vue.d.ts +24 -0
- package/dist/components/forms/AppLink.d.vue.ts +19 -0
- package/dist/components/forms/AppLink.vue +50 -0
- package/dist/components/forms/AppLink.vue.d.ts +19 -0
- package/dist/components/forms/AppNumberField.d.vue.ts +20 -0
- package/dist/components/forms/AppNumberField.vue +79 -0
- package/dist/components/forms/AppNumberField.vue.d.ts +20 -0
- package/dist/components/forms/AppOtpInput.d.vue.ts +13 -0
- package/dist/components/forms/AppOtpInput.vue +84 -0
- package/dist/components/forms/AppOtpInput.vue.d.ts +13 -0
- package/dist/components/forms/AppSearchHeader.d.vue.ts +8 -0
- package/dist/components/forms/AppSearchHeader.vue +72 -0
- package/dist/components/forms/AppSearchHeader.vue.d.ts +8 -0
- package/dist/components/forms/AppSelect.d.vue.ts +21 -0
- package/dist/components/forms/AppSelect.vue +94 -0
- package/dist/components/forms/AppSelect.vue.d.ts +21 -0
- package/dist/components/forms/AppStepper.d.vue.ts +21 -0
- package/dist/components/forms/AppStepper.vue +232 -0
- package/dist/components/forms/AppStepper.vue.d.ts +21 -0
- package/dist/components/forms/AppSwitch.d.vue.ts +18 -0
- package/dist/components/forms/AppSwitch.vue +60 -0
- package/dist/components/forms/AppSwitch.vue.d.ts +18 -0
- package/dist/components/forms/AppTextField.d.vue.ts +17 -0
- package/dist/components/forms/AppTextField.vue +62 -0
- package/dist/components/forms/AppTextField.vue.d.ts +17 -0
- package/dist/components/forms/AppTextarea.d.vue.ts +17 -0
- package/dist/components/forms/AppTextarea.vue +65 -0
- package/dist/components/forms/AppTextarea.vue.d.ts +17 -0
- package/dist/components/forms/AttachmentCropperInput.d.vue.ts +18 -0
- package/dist/components/forms/AttachmentCropperInput.vue +227 -0
- package/dist/components/forms/AttachmentCropperInput.vue.d.ts +18 -0
- package/dist/components/forms/AttachmentInput.d.vue.ts +16 -0
- package/dist/components/forms/AttachmentInput.vue +116 -0
- package/dist/components/forms/AttachmentInput.vue.d.ts +16 -0
- package/dist/components/forms/AutocompleteInput.d.vue.ts +86 -0
- package/dist/components/forms/AutocompleteInput.vue +778 -0
- package/dist/components/forms/AutocompleteInput.vue.d.ts +86 -0
- package/dist/components/forms/BankSelect.d.vue.ts +21 -0
- package/dist/components/forms/BankSelect.vue +43 -0
- package/dist/components/forms/BankSelect.vue.d.ts +21 -0
- package/dist/components/forms/BaseButton.d.vue.ts +20 -0
- package/dist/components/forms/BaseButton.vue +42 -0
- package/dist/components/forms/BaseButton.vue.d.ts +20 -0
- package/dist/components/forms/CounterInput.d.vue.ts +13 -0
- package/dist/components/forms/CounterInput.vue +71 -0
- package/dist/components/forms/CounterInput.vue.d.ts +13 -0
- package/dist/components/forms/CustomCheckboxes.d.vue.ts +25 -0
- package/dist/components/forms/CustomCheckboxes.vue +69 -0
- package/dist/components/forms/CustomCheckboxes.vue.d.ts +25 -0
- package/dist/components/forms/CustomCheckboxesWithIcon.d.vue.ts +25 -0
- package/dist/components/forms/CustomCheckboxesWithIcon.vue +80 -0
- package/dist/components/forms/CustomCheckboxesWithIcon.vue.d.ts +25 -0
- package/dist/components/forms/CustomCheckboxesWithImage.d.vue.ts +16 -0
- package/dist/components/forms/CustomCheckboxesWithImage.vue +67 -0
- package/dist/components/forms/CustomCheckboxesWithImage.vue.d.ts +16 -0
- package/dist/components/forms/CustomRadios.d.vue.ts +25 -0
- package/dist/components/forms/CustomRadios.vue +69 -0
- package/dist/components/forms/CustomRadios.vue.d.ts +25 -0
- package/dist/components/forms/CustomRadiosWithIcon.d.vue.ts +28 -0
- package/dist/components/forms/CustomRadiosWithIcon.vue +98 -0
- package/dist/components/forms/CustomRadiosWithIcon.vue.d.ts +28 -0
- package/dist/components/forms/CustomRadiosWithImage.d.vue.ts +35 -0
- package/dist/components/forms/CustomRadiosWithImage.vue +69 -0
- package/dist/components/forms/CustomRadiosWithImage.vue.d.ts +35 -0
- package/dist/components/forms/DatePicker.d.vue.ts +29 -0
- package/dist/components/forms/DatePicker.vue +392 -0
- package/dist/components/forms/DatePicker.vue.d.ts +29 -0
- package/dist/components/forms/DatePickerRange.d.vue.ts +24 -0
- package/dist/components/forms/DatePickerRange.vue +127 -0
- package/dist/components/forms/DatePickerRange.vue.d.ts +24 -0
- package/dist/components/forms/DraggedUploadFile.d.vue.ts +11 -0
- package/dist/components/forms/DraggedUploadFile.vue +120 -0
- package/dist/components/forms/DraggedUploadFile.vue.d.ts +11 -0
- package/dist/components/forms/ImageCardInput.d.vue.ts +35 -0
- package/dist/components/forms/ImageCardInput.vue +234 -0
- package/dist/components/forms/ImageCardInput.vue.d.ts +35 -0
- package/dist/components/forms/InputValidationWrapper.d.vue.ts +26 -0
- package/dist/components/forms/InputValidationWrapper.vue +24 -0
- package/dist/components/forms/InputValidationWrapper.vue.d.ts +26 -0
- package/dist/components/forms/LicensePlateInput.d.vue.ts +21 -0
- package/dist/components/forms/LicensePlateInput.vue +175 -0
- package/dist/components/forms/LicensePlateInput.vue.d.ts +21 -0
- package/dist/components/forms/ManualDate.d.vue.ts +20 -0
- package/dist/components/forms/ManualDate.vue +264 -0
- package/dist/components/forms/ManualDate.vue.d.ts +20 -0
- package/dist/components/forms/MobileInput.d.vue.ts +25 -0
- package/dist/components/forms/MobileInput.vue +118 -0
- package/dist/components/forms/MobileInput.vue.d.ts +25 -0
- package/dist/components/forms/PasswordInput.d.vue.ts +11 -0
- package/dist/components/forms/PasswordInput.vue +29 -0
- package/dist/components/forms/PasswordInput.vue.d.ts +11 -0
- package/dist/components/forms/RangeInput.d.vue.ts +10 -0
- package/dist/components/forms/RangeInput.vue +48 -0
- package/dist/components/forms/RangeInput.vue.d.ts +10 -0
- package/dist/components/forms/Tabs.d.vue.ts +23 -0
- package/dist/components/forms/Tabs.vue +35 -0
- package/dist/components/forms/Tabs.vue.d.ts +23 -0
- package/dist/components/forms/TimePicker.d.vue.ts +18 -0
- package/dist/components/forms/TimePicker.vue +370 -0
- package/dist/components/forms/TimePicker.vue.d.ts +18 -0
- package/dist/components/table/DataTable.d.vue.ts +70 -0
- package/dist/components/table/DataTable.vue +361 -0
- package/dist/components/table/DataTable.vue.d.ts +70 -0
- package/dist/components/table/EditableDataTable.d.vue.ts +21 -0
- package/dist/components/table/EditableDataTable.vue +330 -0
- package/dist/components/table/EditableDataTable.vue.d.ts +21 -0
- package/dist/components/table/EditableDataTableRow.d.vue.ts +20 -0
- package/dist/components/table/EditableDataTableRow.vue +252 -0
- package/dist/components/table/EditableDataTableRow.vue.d.ts +20 -0
- package/dist/components/table/FilterGenerator.d.vue.ts +13 -0
- package/dist/components/table/FilterGenerator.vue +231 -0
- package/dist/components/table/FilterGenerator.vue.d.ts +13 -0
- package/dist/components/table/StaticTable.d.vue.ts +34 -0
- package/dist/components/table/StaticTable.vue +152 -0
- package/dist/components/table/StaticTable.vue.d.ts +34 -0
- package/dist/components/table/TablePagination.d.vue.ts +15 -0
- package/dist/components/table/TablePagination.vue +73 -0
- package/dist/components/table/TablePagination.vue.d.ts +15 -0
- package/dist/composables/useIsMobile.d.ts +1 -0
- package/dist/composables/useIsMobile.js +10 -0
- package/dist/composables/useIsMobile.mjs +4 -0
- package/dist/composables/useTableFilters.d.ts +23 -0
- package/dist/composables/useTableFilters.js +197 -0
- package/dist/composables/useTableFilters.mjs +184 -0
- package/dist/images/avatar.png +0 -0
- package/dist/images/sa.svg +1 -0
- package/dist/index.d.ts +65 -0
- package/dist/index.js +454 -0
- package/dist/index.mjs +130 -0
- package/dist/lang/ar.json +54 -0
- package/dist/lang/en.json +54 -0
- package/dist/styles/assets/scss/variables/_template.scss +1 -0
- package/dist/styles/assets/scss/variables/_vuetify.scss +1 -0
- package/dist/styles/core/base/_components.scss +164 -0
- package/dist/styles/core/base/_dark.scss +16 -0
- package/dist/styles/core/base/_default-layout-w-vertical-nav.scss +106 -0
- package/dist/styles/core/base/_default-layout.scss +16 -0
- package/dist/styles/core/base/_index.scss +47 -0
- package/dist/styles/core/base/_layouts.scss +63 -0
- package/dist/styles/core/base/_misc.scss +20 -0
- package/dist/styles/core/base/_mixins.scss +84 -0
- package/dist/styles/core/base/_route-transitions.scss +70 -0
- package/dist/styles/core/base/_utilities.scss +418 -0
- package/dist/styles/core/base/_utils.scss +100 -0
- package/dist/styles/core/base/_variables.scss +190 -0
- package/dist/styles/core/base/_vertical-nav.scss +264 -0
- package/dist/styles/core/base/libs/_perfect-scrollbar.scss +35 -0
- package/dist/styles/core/base/libs/vuetify/_index.scss +1 -0
- package/dist/styles/core/base/libs/vuetify/_overrides.scss +380 -0
- package/dist/styles/core/base/libs/vuetify/_variables.scss +48 -0
- package/dist/styles/core/base/placeholders/_default-layout-vertical-nav.scss +48 -0
- package/dist/styles/core/base/placeholders/_default-layout.scss +3 -0
- package/dist/styles/core/base/placeholders/_index.scss +5 -0
- package/dist/styles/core/base/placeholders/_misc.scss +7 -0
- package/dist/styles/core/base/placeholders/_nav.scss +26 -0
- package/dist/styles/core/base/placeholders/_vertical-nav.scss +84 -0
- package/dist/styles/core/base/skins/_bordered.scss +60 -0
- package/dist/styles/core/base/skins/_index.scss +1 -0
- package/dist/styles/core/template/_components.scss +1044 -0
- package/dist/styles/core/template/_default-layout-w-vertical-nav.scss +20 -0
- package/dist/styles/core/template/_utilities.scss +20 -0
- package/dist/styles/core/template/_variables.scss +67 -0
- package/dist/styles/core/template/_vertical-nav.scss +41 -0
- package/dist/styles/core/template/index.css +18786 -0
- package/dist/styles/core/template/index.scss +15 -0
- package/dist/styles/core/template/libs/vuetify/_variables.scss +464 -0
- package/dist/styles/core/template/libs/vuetify/index.css +739 -0
- package/dist/styles/core/template/libs/vuetify/index.scss +1 -0
- package/dist/styles/core/template/pages/misc.css +16 -0
- package/dist/styles/core/template/pages/misc.scss +20 -0
- package/dist/styles/core/template/placeholders/_default-layout-vertical-nav.scss +9 -0
- package/dist/styles/core/template/placeholders/_index.scss +3 -0
- package/dist/styles/core/template/placeholders/_nav.scss +15 -0
- package/dist/styles/core/template/placeholders/_vertical-nav.scss +18 -0
- package/dist/styles/core/template/skins/_bordered.scss +36 -0
- package/dist/styles/core/template/skins/_index.scss +1 -0
- package/dist/styles/layouts/_classes.scss +3 -0
- package/dist/styles/layouts/_dashboard-layout.scss +43 -0
- package/dist/styles/layouts/_global.scss +10 -0
- package/dist/styles/layouts/_mixins.scss +28 -0
- package/dist/styles/layouts/_placeholders.scss +53 -0
- package/dist/styles/layouts/_rtl.scss +7 -0
- package/dist/styles/layouts/_variables.scss +22 -0
- package/dist/styles/layouts/index.css +14 -0
- package/dist/styles/layouts/index.scss +2 -0
- package/dist/types.d.ts +218 -0
- package/dist/utils/apiUrl.d.ts +1 -0
- package/dist/utils/apiUrl.js +15 -0
- package/dist/utils/apiUrl.mjs +8 -0
- package/dist/utils/client.d.ts +9 -0
- package/dist/utils/client.js +53 -0
- package/dist/utils/client.mjs +39 -0
- package/dist/utils/files.d.ts +2 -0
- package/dist/utils/files.js +35 -0
- package/dist/utils/files.mjs +22 -0
- package/dist/utils/formValidation.d.ts +7 -0
- package/dist/utils/formValidation.js +20 -0
- package/dist/utils/formValidation.mjs +13 -0
- package/dist/utils/formatters.d.ts +12 -0
- package/dist/utils/formatters.js +84 -0
- package/dist/utils/formatters.mjs +56 -0
- package/dist/utils/hijriDate.d.ts +58 -0
- package/dist/utils/hijriDate.js +168 -0
- package/dist/utils/hijriDate.mjs +1951 -0
- package/dist/utils/i18n.d.ts +8 -0
- package/dist/utils/i18n.js +36 -0
- package/dist/utils/i18n.mjs +27 -0
- package/dist/utils/index.d.ts +10 -0
- package/dist/utils/index.js +115 -0
- package/dist/utils/index.mjs +10 -0
- package/dist/utils/queryParams.d.ts +4 -0
- package/dist/utils/queryParams.js +26 -0
- package/dist/utils/queryParams.mjs +18 -0
- package/dist/utils/ruleValidator.d.ts +41 -0
- package/dist/utils/ruleValidator.js +210 -0
- package/dist/utils/ruleValidator.mjs +195 -0
- package/dist/utils/toaster.d.ts +12 -0
- package/dist/utils/toaster.js +68 -0
- package/dist/utils/toaster.mjs +58 -0
- package/dist/utils/utils.d.ts +9 -0
- package/dist/utils/utils.js +84 -0
- package/dist/utils/utils.mjs +67 -0
- package/package.json +67 -67
|
@@ -0,0 +1,231 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, ref, watch } from "vue";
|
|
3
|
+
import { VCol, VRow } from "vuetify/components";
|
|
4
|
+
import { useI18n } from "vue-i18n";
|
|
5
|
+
import { getErrorMessage } from "../../utils/formValidation";
|
|
6
|
+
import { useIsMobile } from "../../composables/useIsMobile";
|
|
7
|
+
import AutocompleteInput from "../forms/AutocompleteInput.vue";
|
|
8
|
+
import AppSelect from "../forms/AppSelect.vue";
|
|
9
|
+
import AppTextField from "../forms/AppTextField.vue";
|
|
10
|
+
import DatePicker from "../forms/DatePicker.vue";
|
|
11
|
+
import DatePickerRange from "../forms/DatePickerRange.vue";
|
|
12
|
+
import LicensePlateInput from "../forms/LicensePlateInput.vue";
|
|
13
|
+
import MobileInput from "../forms/MobileInput.vue";
|
|
14
|
+
import RangeInput from "../forms/RangeInput.vue";
|
|
15
|
+
import BankSelect from "../forms/BankSelect.vue";
|
|
16
|
+
const props = defineProps({
|
|
17
|
+
modelValue: { type: null, required: true },
|
|
18
|
+
forms: { type: Array, required: true },
|
|
19
|
+
errors: { type: Array, required: false, default: () => [] }
|
|
20
|
+
});
|
|
21
|
+
const emit = defineEmits(["update:modelValue"]);
|
|
22
|
+
const { t } = useI18n();
|
|
23
|
+
const formsFilters = ref(props.forms || []);
|
|
24
|
+
const filters = computed(() => {
|
|
25
|
+
return formsFilters.value.map((form) => {
|
|
26
|
+
const isSelectOrAutocomplete = ["select", "autocomplete", "autocompleteGroups"].includes(form.type ?? "");
|
|
27
|
+
const baseForm = {
|
|
28
|
+
...form,
|
|
29
|
+
clearable: form.clearable ?? true,
|
|
30
|
+
...isSelectOrAutocomplete && {
|
|
31
|
+
closableChips: form.closableChips ?? true,
|
|
32
|
+
itemLabel: form.itemLabel ?? "name",
|
|
33
|
+
trackBy: form.trackBy ?? "id"
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
if (form.hasLang && form.options) {
|
|
37
|
+
const translatedOptions = form.options.map((option) => ({
|
|
38
|
+
...option,
|
|
39
|
+
name: option?.allowTranslate && option.name ? t(option.name) : option.name
|
|
40
|
+
}));
|
|
41
|
+
return {
|
|
42
|
+
...baseForm,
|
|
43
|
+
options: translatedOptions
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return baseForm;
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
const placeholder = (form) => {
|
|
50
|
+
return form.placeholder ?? t(`inputs.${form.type === "text" || form.type === void 0 ? "placeholder_search" : "placeholder_select"}`, { name: t(form.label) });
|
|
51
|
+
};
|
|
52
|
+
const value = computed({
|
|
53
|
+
get() {
|
|
54
|
+
return props.modelValue;
|
|
55
|
+
},
|
|
56
|
+
set(value2) {
|
|
57
|
+
emit("update:modelValue", value2 || "");
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
watch(() => props.forms, (value2) => {
|
|
61
|
+
formsFilters.value = value2 || [];
|
|
62
|
+
});
|
|
63
|
+
watch(
|
|
64
|
+
() => props.forms,
|
|
65
|
+
(filter) => {
|
|
66
|
+
formsFilters.value = filter || [];
|
|
67
|
+
if (!filter) {
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
filter.forEach((item) => {
|
|
71
|
+
if (item?.value) {
|
|
72
|
+
value.value[item.name] = item.value;
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
deep: true,
|
|
78
|
+
immediate: true
|
|
79
|
+
}
|
|
80
|
+
);
|
|
81
|
+
</script>
|
|
82
|
+
|
|
83
|
+
<template>
|
|
84
|
+
<VRow :class="useIsMobile().value ? 'pt-8' : 'pt-4'">
|
|
85
|
+
<template
|
|
86
|
+
v-for="(form, key) in filters"
|
|
87
|
+
:key="key"
|
|
88
|
+
>
|
|
89
|
+
<VCol
|
|
90
|
+
v-if="form.type !== 'datepickerRange'"
|
|
91
|
+
cols="12"
|
|
92
|
+
sm="3"
|
|
93
|
+
class="py-0"
|
|
94
|
+
:class="{
|
|
95
|
+
'd-none': form.invisible
|
|
96
|
+
}"
|
|
97
|
+
>
|
|
98
|
+
<AppTextField
|
|
99
|
+
v-if="form.type === 'text' || form.type === undefined"
|
|
100
|
+
v-model="value[form.name]"
|
|
101
|
+
:label="form.label"
|
|
102
|
+
:placeholder="placeholder(form)"
|
|
103
|
+
density="compact"
|
|
104
|
+
:rules="form.rules"
|
|
105
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
106
|
+
:clearable="form.clearable"
|
|
107
|
+
:closable-chips="form.closableChips"
|
|
108
|
+
/>
|
|
109
|
+
|
|
110
|
+
<RangeInput
|
|
111
|
+
v-if="form.type === 'range'"
|
|
112
|
+
v-model="value[form.name]"
|
|
113
|
+
:label="form.label"
|
|
114
|
+
:class="form.class"
|
|
115
|
+
:rules="form.rules"
|
|
116
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
117
|
+
/>
|
|
118
|
+
|
|
119
|
+
<AppSelect
|
|
120
|
+
v-if="form.type === 'select'"
|
|
121
|
+
v-model="value[form.name]"
|
|
122
|
+
:label="form.label"
|
|
123
|
+
:placeholder="placeholder(form)"
|
|
124
|
+
:items="form?.options"
|
|
125
|
+
:item-title="form.itemLabel || 'name'"
|
|
126
|
+
:item-value="form.trackBy || 'id'"
|
|
127
|
+
:multiple="form.multiple"
|
|
128
|
+
:chips="form.multiple"
|
|
129
|
+
:clearable="form.clearable"
|
|
130
|
+
:closable-chips="form.closableChips"
|
|
131
|
+
:rules="form.rules"
|
|
132
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
133
|
+
clear-icon="tabler-x"
|
|
134
|
+
/>
|
|
135
|
+
|
|
136
|
+
<AutocompleteInput
|
|
137
|
+
v-if="form.type === 'autocomplete'"
|
|
138
|
+
v-model="value[form.name]"
|
|
139
|
+
:url="form.urlSearch"
|
|
140
|
+
:label="form.label"
|
|
141
|
+
:item-label="form.itemLabel || 'name'"
|
|
142
|
+
:track-by="form.trackBy || 'id'"
|
|
143
|
+
:track-by-value="form.trackByValue"
|
|
144
|
+
:search-internally="form.searchInternally"
|
|
145
|
+
:multiple="form.multiple"
|
|
146
|
+
:params="form.params"
|
|
147
|
+
:placeholder="placeholder(form)"
|
|
148
|
+
:required="form.rules && form.rules.length > 0"
|
|
149
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
150
|
+
searchable
|
|
151
|
+
:options="form.options"
|
|
152
|
+
/>
|
|
153
|
+
|
|
154
|
+
<AutocompleteInput
|
|
155
|
+
v-if="form.type === 'autocompleteGroups' && form.urlSearch"
|
|
156
|
+
v-model="value[form.name]"
|
|
157
|
+
:url="form.urlSearch"
|
|
158
|
+
:label="form.label"
|
|
159
|
+
:item-label="form.itemLabel || 'name'"
|
|
160
|
+
:track-by="form.trackBy || 'id'"
|
|
161
|
+
:track-by-value="form.trackByValue"
|
|
162
|
+
:params="form.params"
|
|
163
|
+
:multiple="form.multiple"
|
|
164
|
+
:placeholder="placeholder(form)"
|
|
165
|
+
:required="form.rules && form.rules.length > 0"
|
|
166
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
167
|
+
group-label="name"
|
|
168
|
+
group-values="children"
|
|
169
|
+
:search-internally="form.searchInternally"
|
|
170
|
+
grouped
|
|
171
|
+
searchable
|
|
172
|
+
/>
|
|
173
|
+
|
|
174
|
+
<MobileInput
|
|
175
|
+
v-if="form.type === 'mobile'"
|
|
176
|
+
v-model="value[form.name]"
|
|
177
|
+
:label="form.label"
|
|
178
|
+
:rules="form.rules"
|
|
179
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
180
|
+
/>
|
|
181
|
+
|
|
182
|
+
<BankSelect
|
|
183
|
+
v-if="form.type === 'bankSelect'"
|
|
184
|
+
v-model="value[form.name]"
|
|
185
|
+
:search-internally="form.searchInternally"
|
|
186
|
+
:track-by-value="form.trackByValue"
|
|
187
|
+
:multiple="form.multiple"
|
|
188
|
+
:params="form.params"
|
|
189
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
190
|
+
/>
|
|
191
|
+
|
|
192
|
+
<LicensePlateInput
|
|
193
|
+
v-if="form.type === 'licensePlate'"
|
|
194
|
+
v-model="value[form.name]"
|
|
195
|
+
:label="form.label"
|
|
196
|
+
:rules="form.rules"
|
|
197
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
198
|
+
/>
|
|
199
|
+
|
|
200
|
+
<DatePicker
|
|
201
|
+
v-if="form.type === 'datepicker'"
|
|
202
|
+
v-model="value[form.name]"
|
|
203
|
+
show-today
|
|
204
|
+
display-format="DD/MM/YYYY"
|
|
205
|
+
:label="form.label"
|
|
206
|
+
:rules="form.rules"
|
|
207
|
+
:clearable="form.clearable"
|
|
208
|
+
:min-date="form.fromMinDate"
|
|
209
|
+
:max-date="form.fromMaxDate"
|
|
210
|
+
:placeholder="placeholder(form)"
|
|
211
|
+
:error-messages="getErrorMessage(errors, form.name)"
|
|
212
|
+
/>
|
|
213
|
+
</VCol>
|
|
214
|
+
|
|
215
|
+
<template v-else>
|
|
216
|
+
<DatePickerRange
|
|
217
|
+
v-if="form.type === 'datepickerRange'"
|
|
218
|
+
v-model="value[form.name]"
|
|
219
|
+
:to-error-messages="getErrorMessage(errors, `${form.name}.0`)"
|
|
220
|
+
:from-error-messages="getErrorMessage(errors, `${form.name}.1`)"
|
|
221
|
+
:rules="form.rules"
|
|
222
|
+
:from-min-date="form.fromMinDate"
|
|
223
|
+
:to-min-date="form.toMinDate"
|
|
224
|
+
:from-max-date="form.fromMaxDate"
|
|
225
|
+
:to-max-date="form.toMaxDate"
|
|
226
|
+
clearable
|
|
227
|
+
/>
|
|
228
|
+
</template>
|
|
229
|
+
</template>
|
|
230
|
+
</VRow>
|
|
231
|
+
</template>
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { FormFilter, ErrorResponseFiled } from '../../types';
|
|
2
|
+
type __VLS_Props = {
|
|
3
|
+
modelValue: any;
|
|
4
|
+
forms: FormFilter[];
|
|
5
|
+
errors?: ErrorResponseFiled[];
|
|
6
|
+
};
|
|
7
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_Props, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
|
|
8
|
+
"update:modelValue": (value: unknown) => any;
|
|
9
|
+
}, string, import("vue").PublicProps, Readonly<__VLS_Props> & Readonly<{
|
|
10
|
+
"onUpdate:modelValue"?: ((value: unknown) => any) | undefined;
|
|
11
|
+
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
12
|
+
declare const _default: typeof __VLS_export;
|
|
13
|
+
export default _default;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
declare const __VLS_export: <T>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
|
|
2
|
+
props: __VLS_PrettifyLocal<{
|
|
3
|
+
items: T[];
|
|
4
|
+
subItemsKey?: string;
|
|
5
|
+
headers: {
|
|
6
|
+
key: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
grayColorWhenNull?: boolean;
|
|
9
|
+
type?: "number" | "string";
|
|
10
|
+
dashedWhenNull?: boolean;
|
|
11
|
+
}[];
|
|
12
|
+
}> & import("vue").PublicProps & (typeof globalThis extends {
|
|
13
|
+
__VLS_PROPS_FALLBACK: infer P;
|
|
14
|
+
} ? P : {});
|
|
15
|
+
expose: (exposed: {}) => void;
|
|
16
|
+
attrs: any;
|
|
17
|
+
slots: {
|
|
18
|
+
[x: string]: ((props: {
|
|
19
|
+
item: T;
|
|
20
|
+
}) => any) | undefined;
|
|
21
|
+
} & {
|
|
22
|
+
[x: string]: ((props: {
|
|
23
|
+
item: any;
|
|
24
|
+
}) => any) | undefined;
|
|
25
|
+
};
|
|
26
|
+
emit: {};
|
|
27
|
+
}>) => import("vue").VNode & {
|
|
28
|
+
__ctx?: Awaited<typeof __VLS_setup>;
|
|
29
|
+
};
|
|
30
|
+
declare const _default: typeof __VLS_export;
|
|
31
|
+
export default _default;
|
|
32
|
+
type __VLS_PrettifyLocal<T> = {
|
|
33
|
+
[K in keyof T as K]: T[K];
|
|
34
|
+
} & {};
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { computed, onMounted, onUpdated, ref } from "vue";
|
|
3
|
+
import { useRoute } from "vue-router";
|
|
4
|
+
import { useI18n } from "vue-i18n";
|
|
5
|
+
import { useIsMobile } from "../../composables/useIsMobile";
|
|
6
|
+
const { t } = useI18n();
|
|
7
|
+
const route = useRoute();
|
|
8
|
+
const props = defineProps({
|
|
9
|
+
items: { type: Array, required: true, default: () => [] },
|
|
10
|
+
subItemsKey: { type: String, required: false, default: "" },
|
|
11
|
+
headers: { type: Array, required: true, default: () => [] }
|
|
12
|
+
});
|
|
13
|
+
const activeCell = ref();
|
|
14
|
+
function getProperty(item, key) {
|
|
15
|
+
if (typeof item === "string" || item === void 0 || item === null) {
|
|
16
|
+
return item;
|
|
17
|
+
}
|
|
18
|
+
return key.split(".").reduce((value, k) => value && value[k] ? value[k] : null, item);
|
|
19
|
+
}
|
|
20
|
+
const headers = computed(() => props.headers.filter((e) => e.key !== "index").map((header) => {
|
|
21
|
+
return {
|
|
22
|
+
...header,
|
|
23
|
+
label: t(header.label)
|
|
24
|
+
};
|
|
25
|
+
}));
|
|
26
|
+
const indexHeader = computed(() => props.headers.find((e) => e.key === "index"));
|
|
27
|
+
const activeCellId = computed(() => {
|
|
28
|
+
return function(item) {
|
|
29
|
+
if (!!item.winch_id && !!activeCell.value && item.winch_id === activeCell.value) {
|
|
30
|
+
return "active-cell";
|
|
31
|
+
} else {
|
|
32
|
+
return void 0;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
onMounted(() => {
|
|
37
|
+
if (route.query.winch_id) {
|
|
38
|
+
activeCell.value = route.query.winch_id;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
onUpdated(() => {
|
|
42
|
+
const activeCellElement = document.getElementById("active-cell");
|
|
43
|
+
if (activeCellElement) {
|
|
44
|
+
const windowHeight = window.innerHeight;
|
|
45
|
+
const elementPosition = activeCellElement.getBoundingClientRect().top;
|
|
46
|
+
const offsetPosition = elementPosition - windowHeight / 2;
|
|
47
|
+
window.scrollTo({
|
|
48
|
+
top: offsetPosition,
|
|
49
|
+
behavior: "smooth"
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
</script>
|
|
54
|
+
|
|
55
|
+
<template>
|
|
56
|
+
<div class="secondary-table" :class="{
|
|
57
|
+
'responsive-table': useIsMobile().value
|
|
58
|
+
}">
|
|
59
|
+
<table>
|
|
60
|
+
<thead>
|
|
61
|
+
<tr>
|
|
62
|
+
<th key="index" class="static-table-header-first-column">
|
|
63
|
+
#
|
|
64
|
+
</th>
|
|
65
|
+
<th v-for="(header, index) in headers" :key="`header-${index}-${header.key}`">
|
|
66
|
+
{{ header.label }}
|
|
67
|
+
</th>
|
|
68
|
+
</tr>
|
|
69
|
+
</thead>
|
|
70
|
+
|
|
71
|
+
<tbody>
|
|
72
|
+
<template v-for="(item, index) in items" :key="`item-tr-${index}`">
|
|
73
|
+
<tr :id="activeCellId(item)">
|
|
74
|
+
<td :class="{
|
|
75
|
+
'active-cell': !!item.winch_id && !!activeCell && item.winch_id === activeCell
|
|
76
|
+
}">
|
|
77
|
+
{{ index + 1 }}
|
|
78
|
+
</td>
|
|
79
|
+
<td
|
|
80
|
+
v-for="header in headers"
|
|
81
|
+
:key="`item-td-${header.key}`"
|
|
82
|
+
:class="{
|
|
83
|
+
'bg-grayish-blue': header.grayColorWhenNull && getProperty(item, header.key) === null,
|
|
84
|
+
'active-cell': !!item.winch_id && !!activeCell && item.winch_id === activeCell
|
|
85
|
+
}"
|
|
86
|
+
>
|
|
87
|
+
<slot :name="header.key" :item="item">
|
|
88
|
+
{{ getProperty(item, header.key) !== null ? getProperty(item, header.key) : header?.type === "number" ? 0 : header?.dashedWhenNull === true || header?.dashedWhenNull === void 0 ? "-" : ""
|
|
89
|
+
}}
|
|
90
|
+
</slot>
|
|
91
|
+
</td>
|
|
92
|
+
</tr>
|
|
93
|
+
|
|
94
|
+
<tr v-for="(subItem, subIndex) in item[subItemsKey]" :key="`sub-item-tr-${subIndex}`">
|
|
95
|
+
<td :class="{
|
|
96
|
+
'bg-grayish-blue': indexHeader?.grayColorWhenNull
|
|
97
|
+
}" />
|
|
98
|
+
<td
|
|
99
|
+
v-for="header in headers"
|
|
100
|
+
:key="`item-td-${subIndex}-${header.key}`"
|
|
101
|
+
:class="{
|
|
102
|
+
'bg-grayish-blue': header.grayColorWhenNull && getProperty(subItem, header.key) === null
|
|
103
|
+
}"
|
|
104
|
+
>
|
|
105
|
+
<slot :name="header.key" :item="subItem">
|
|
106
|
+
{{ getProperty(subItem, header.key) !== null ? getProperty(subItem, header.key) : header?.type === "number" ? 0 : header?.dashedWhenNull === true || header?.dashedWhenNull === void 0 ? "-" : ""
|
|
107
|
+
}}
|
|
108
|
+
</slot>
|
|
109
|
+
</td>
|
|
110
|
+
</tr>
|
|
111
|
+
</template>
|
|
112
|
+
</tbody>
|
|
113
|
+
</table>
|
|
114
|
+
</div>
|
|
115
|
+
</template>
|
|
116
|
+
|
|
117
|
+
<style scoped>
|
|
118
|
+
.secondary-table table {
|
|
119
|
+
width: 100% !important;
|
|
120
|
+
border-collapse: collapse !important;
|
|
121
|
+
border-spacing: 0 !important;
|
|
122
|
+
border: 1px solid rgb(var(--v-theme-silver)) !important;
|
|
123
|
+
font-size: 13px !important;
|
|
124
|
+
}
|
|
125
|
+
.secondary-table table th {
|
|
126
|
+
padding: 12px 16px !important;
|
|
127
|
+
border: 1px solid rgb(var(--v-theme-silver)) !important;
|
|
128
|
+
background-color: rgb(var(--v-theme-gray-200)) !important;
|
|
129
|
+
text-align: start !important;
|
|
130
|
+
color: rgb(var(--v-theme-on-surface)) !important;
|
|
131
|
+
}
|
|
132
|
+
.secondary-table table td {
|
|
133
|
+
padding: 16px !important;
|
|
134
|
+
border: 1px solid rgb(var(--v-theme-silver)) !important;
|
|
135
|
+
text-align: start !important;
|
|
136
|
+
color: rgb(var(--v-theme-on-surface)) !important;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
.active-cell {
|
|
140
|
+
background-color: rgba(var(--v-theme-primary), 0.15) !important;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.responsive-table table th {
|
|
144
|
+
position: unset !important;
|
|
145
|
+
top: 0 !important;
|
|
146
|
+
z-index: 10 !important;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
.static-table-header-first-column {
|
|
150
|
+
width: 50px !important;
|
|
151
|
+
}
|
|
152
|
+
</style>
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
declare const __VLS_export: <T>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
|
|
2
|
+
props: __VLS_PrettifyLocal<{
|
|
3
|
+
items: T[];
|
|
4
|
+
subItemsKey?: string;
|
|
5
|
+
headers: {
|
|
6
|
+
key: string;
|
|
7
|
+
label?: string;
|
|
8
|
+
grayColorWhenNull?: boolean;
|
|
9
|
+
type?: "number" | "string";
|
|
10
|
+
dashedWhenNull?: boolean;
|
|
11
|
+
}[];
|
|
12
|
+
}> & import("vue").PublicProps & (typeof globalThis extends {
|
|
13
|
+
__VLS_PROPS_FALLBACK: infer P;
|
|
14
|
+
} ? P : {});
|
|
15
|
+
expose: (exposed: {}) => void;
|
|
16
|
+
attrs: any;
|
|
17
|
+
slots: {
|
|
18
|
+
[x: string]: ((props: {
|
|
19
|
+
item: T;
|
|
20
|
+
}) => any) | undefined;
|
|
21
|
+
} & {
|
|
22
|
+
[x: string]: ((props: {
|
|
23
|
+
item: any;
|
|
24
|
+
}) => any) | undefined;
|
|
25
|
+
};
|
|
26
|
+
emit: {};
|
|
27
|
+
}>) => import("vue").VNode & {
|
|
28
|
+
__ctx?: Awaited<typeof __VLS_setup>;
|
|
29
|
+
};
|
|
30
|
+
declare const _default: typeof __VLS_export;
|
|
31
|
+
export default _default;
|
|
32
|
+
type __VLS_PrettifyLocal<T> = {
|
|
33
|
+
[K in keyof T as K]: T[K];
|
|
34
|
+
} & {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Pagination } from '../../types';
|
|
2
|
+
type __VLS_Props = {
|
|
3
|
+
pagination: Pagination;
|
|
4
|
+
};
|
|
5
|
+
type __VLS_ModelProps = {
|
|
6
|
+
modelValue?: number;
|
|
7
|
+
};
|
|
8
|
+
type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
|
|
9
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
10
|
+
"update:modelValue": (value: number) => any;
|
|
11
|
+
}, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
|
|
12
|
+
"onUpdate:modelValue"?: ((value: number) => any) | undefined;
|
|
13
|
+
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
14
|
+
declare const _default: typeof __VLS_export;
|
|
15
|
+
export default _default;
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { VPagination, VBtn } from "vuetify/components";
|
|
3
|
+
import { useI18n } from "vue-i18n";
|
|
4
|
+
import { useIsMobile } from "../../composables/useIsMobile";
|
|
5
|
+
defineProps({
|
|
6
|
+
pagination: { type: Object, required: true }
|
|
7
|
+
});
|
|
8
|
+
const { t } = useI18n();
|
|
9
|
+
const currentPage = defineModel({ type: Number, ...{ default: 0 } });
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<template>
|
|
13
|
+
<div class="d-flex align-center justify-sm-space-between justify-center flex-wrap gap-3 pa-5 pt-5 mt-auto">
|
|
14
|
+
<p class="text-sm text-disabled mb-0">
|
|
15
|
+
{{
|
|
16
|
+
t('pagination.info', {
|
|
17
|
+
from: pagination.from > 0 ? pagination.from : 0,
|
|
18
|
+
to: pagination.to > 0 ? pagination.to : 0,
|
|
19
|
+
total: pagination.total > 0 ? pagination.total : 0,
|
|
20
|
+
})
|
|
21
|
+
}}
|
|
22
|
+
</p>
|
|
23
|
+
|
|
24
|
+
<VPagination
|
|
25
|
+
v-model="currentPage"
|
|
26
|
+
:length="pagination.last_page"
|
|
27
|
+
:total-visible="useIsMobile().value ? 3 : 5"
|
|
28
|
+
size="small"
|
|
29
|
+
>
|
|
30
|
+
<template #item="{ isActive, page, ...slotProps }">
|
|
31
|
+
<VBtn
|
|
32
|
+
v-bind="slotProps"
|
|
33
|
+
variant="tonal"
|
|
34
|
+
size="small"
|
|
35
|
+
density="comfortable"
|
|
36
|
+
:class="{
|
|
37
|
+
'text-primary': isActive
|
|
38
|
+
}"
|
|
39
|
+
:color="isActive ? 'primary' : 'on-surface'"
|
|
40
|
+
icon
|
|
41
|
+
:disabled="slotProps.props.disabled"
|
|
42
|
+
@click="currentPage = Number(page)"
|
|
43
|
+
>
|
|
44
|
+
{{ page }}
|
|
45
|
+
</VBtn>
|
|
46
|
+
</template>
|
|
47
|
+
|
|
48
|
+
<template #prev="slotProps">
|
|
49
|
+
<VBtn
|
|
50
|
+
variant="tonal"
|
|
51
|
+
color="default"
|
|
52
|
+
v-bind="slotProps"
|
|
53
|
+
size="small"
|
|
54
|
+
:icon="false"
|
|
55
|
+
>
|
|
56
|
+
{{ t("pagination.previous") }}
|
|
57
|
+
</VBtn>
|
|
58
|
+
</template>
|
|
59
|
+
|
|
60
|
+
<template #next="slotProps">
|
|
61
|
+
<VBtn
|
|
62
|
+
variant="tonal"
|
|
63
|
+
color="default"
|
|
64
|
+
v-bind="slotProps"
|
|
65
|
+
size="small"
|
|
66
|
+
:icon="false"
|
|
67
|
+
>
|
|
68
|
+
{{ t("pagination.next") }}
|
|
69
|
+
</VBtn>
|
|
70
|
+
</template>
|
|
71
|
+
</VPagination>
|
|
72
|
+
</div>
|
|
73
|
+
</template>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { Pagination } from '../../types';
|
|
2
|
+
type __VLS_Props = {
|
|
3
|
+
pagination: Pagination;
|
|
4
|
+
};
|
|
5
|
+
type __VLS_ModelProps = {
|
|
6
|
+
modelValue?: number;
|
|
7
|
+
};
|
|
8
|
+
type __VLS_PublicProps = __VLS_Props & __VLS_ModelProps;
|
|
9
|
+
declare const __VLS_export: import("vue").DefineComponent<__VLS_PublicProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
10
|
+
"update:modelValue": (value: number) => any;
|
|
11
|
+
}, string, import("vue").PublicProps, Readonly<__VLS_PublicProps> & Readonly<{
|
|
12
|
+
"onUpdate:modelValue"?: ((value: number) => any) | undefined;
|
|
13
|
+
}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
14
|
+
declare const _default: typeof __VLS_export;
|
|
15
|
+
export default _default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function useIsMobile(): import("vue").ComputedRef<boolean>;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { type ComputedRef } from 'vue';
|
|
2
|
+
import type { FormFilter } from '../types';
|
|
3
|
+
type TableFiltersOptions = {
|
|
4
|
+
formFilters: ComputedRef<FormFilter[]>;
|
|
5
|
+
syncFiltersWithUrl: boolean;
|
|
6
|
+
};
|
|
7
|
+
export declare function useTableFilters({ formFilters, syncFiltersWithUrl }: TableFiltersOptions): {
|
|
8
|
+
processedFormFilters: ComputedRef<FormFilter[]>;
|
|
9
|
+
filters: import("vue").Ref<Record<string, string | number | string[] | [] | number[] | object[] | (string | number | null)[] | null | undefined>, Record<string, string | number | string[] | [] | number[] | object[] | (string | number | null)[] | null | undefined>>;
|
|
10
|
+
urlQueryParams: ComputedRef<Record<string, string | number | string[] | [] | number[] | object[] | (string | number | null)[] | null | undefined>>;
|
|
11
|
+
};
|
|
12
|
+
type PaginationOptions = {
|
|
13
|
+
syncFiltersWithUrl: boolean;
|
|
14
|
+
defaultValues?: {
|
|
15
|
+
pageNumber?: number;
|
|
16
|
+
pageSize?: number;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
export declare function usePagination(options: PaginationOptions): {
|
|
20
|
+
currentPage: import("vue").Ref<number, number>;
|
|
21
|
+
itemsPerPage: import("vue").Ref<number, number>;
|
|
22
|
+
};
|
|
23
|
+
export {};
|