shared-ritm 1.3.14 → 1.3.15

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.
Files changed (136) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +4291 -4257
  4. package/dist/shared-ritm.umd.js +154 -154
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/services/RepairsService.d.ts +1 -1
  7. package/dist/types/api/settings/ApiService.d.ts +1 -1
  8. package/package.json +65 -65
  9. package/src/App.vue +2461 -2461
  10. package/src/api/services/AuthService.ts +53 -53
  11. package/src/api/services/BrigadesService.ts +32 -32
  12. package/src/api/services/CommentsService.ts +24 -24
  13. package/src/api/services/ControlsService.ts +96 -96
  14. package/src/api/services/EquipmentService.ts +29 -29
  15. package/src/api/services/FileService.ts +17 -17
  16. package/src/api/services/GanttService.ts +17 -17
  17. package/src/api/services/InstrumentsService.ts +68 -68
  18. package/src/api/services/MetricsService.ts +110 -110
  19. package/src/api/services/ModulesService.ts +27 -27
  20. package/src/api/services/ProjectsService.ts +83 -83
  21. package/src/api/services/RepairsService.ts +124 -124
  22. package/src/api/services/ScheduleService.ts +69 -69
  23. package/src/api/services/SearchService.ts +22 -22
  24. package/src/api/services/TasksService.ts +150 -150
  25. package/src/api/services/UserService.ts +119 -119
  26. package/src/api/services/VideoService.ts +108 -108
  27. package/src/api/settings/ApiService.ts +124 -124
  28. package/src/api/types/Api_Auth.ts +105 -105
  29. package/src/api/types/Api_Brigades.ts +36 -36
  30. package/src/api/types/Api_Comment.ts +40 -40
  31. package/src/api/types/Api_Controls.ts +111 -111
  32. package/src/api/types/Api_Equipment.ts +3 -3
  33. package/src/api/types/Api_Files.ts +7 -7
  34. package/src/api/types/Api_Instruments.ts +156 -156
  35. package/src/api/types/Api_Modules.ts +21 -21
  36. package/src/api/types/Api_Projects.ts +62 -62
  37. package/src/api/types/Api_Repairs.ts +140 -140
  38. package/src/api/types/Api_Schedule.ts +64 -64
  39. package/src/api/types/Api_Search.ts +80 -80
  40. package/src/api/types/Api_Service.ts +9 -9
  41. package/src/api/types/Api_Tasks.ts +371 -371
  42. package/src/api/types/Api_User.ts +146 -146
  43. package/src/api/types/Api_Video.ts +198 -198
  44. package/src/common/app-button/AppButton.vue +173 -173
  45. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  46. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  47. package/src/common/app-datepicker/AppDatepicker.vue +218 -218
  48. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  49. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  50. package/src/common/app-file/AppFile.vue +80 -80
  51. package/src/common/app-icon/AppIcon.vue +108 -108
  52. package/src/common/app-input/AppInput.vue +148 -148
  53. package/src/common/app-input-new/AppInputNew.vue +179 -179
  54. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  55. package/src/common/app-layout/AppLayout.vue +84 -84
  56. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  57. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  58. package/src/common/app-loader/index.vue +43 -43
  59. package/src/common/app-modal/index.vue +96 -96
  60. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  61. package/src/common/app-select/AppSelect.vue +157 -157
  62. package/src/common/app-sheet/AppSheet.vue +120 -120
  63. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  64. package/src/common/app-sidebar/AppSidebar.vue +174 -168
  65. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  66. package/src/common/app-sidebar/components/SidebarMenuItem.vue +149 -149
  67. package/src/common/app-table/AppTable.vue +308 -308
  68. package/src/common/app-table/AppTableLayout.vue +137 -137
  69. package/src/common/app-table/components/ModalSelect.vue +294 -294
  70. package/src/common/app-table/components/TableModal.vue +356 -356
  71. package/src/common/app-table/components/TablePagination.vue +152 -152
  72. package/src/common/app-table/components/TableSearch.vue +76 -76
  73. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  74. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  75. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  76. package/src/common/app-toggle/AppToggle.vue +24 -24
  77. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  78. package/src/global.d.ts +1 -1
  79. package/src/icons/components/arrow-down-icon.vue +25 -25
  80. package/src/icons/components/arrow-frame-icon.vue +19 -19
  81. package/src/icons/components/arrow-square.vue +22 -22
  82. package/src/icons/components/table-filter-icon.vue +30 -30
  83. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  84. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  85. package/src/icons/header/NotificationIcon.vue +18 -18
  86. package/src/icons/header/PersonIcon.vue +11 -11
  87. package/src/icons/header/SettingIcon.vue +14 -14
  88. package/src/icons/header/flashIcon.vue +24 -24
  89. package/src/icons/header/searchStatusIcon.vue +24 -24
  90. package/src/icons/header/smallCapsIcon.vue +34 -34
  91. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  92. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  93. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  94. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  95. package/src/icons/sidebar/instruments-icon.vue +45 -45
  96. package/src/icons/sidebar/logo-icon.vue +15 -15
  97. package/src/icons/sidebar/logout-icon.vue +13 -13
  98. package/src/icons/sidebar/modules-icon.vue +16 -16
  99. package/src/icons/sidebar/notifications-icon.vue +24 -24
  100. package/src/icons/sidebar/order-icon.vue +44 -44
  101. package/src/icons/sidebar/pass-icon.vue +38 -38
  102. package/src/icons/sidebar/positions-icon.vue +42 -42
  103. package/src/icons/sidebar/preorder-icon.vue +19 -19
  104. package/src/icons/sidebar/projects-icon.vue +31 -31
  105. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  106. package/src/icons/sidebar/repairs-icon.vue +20 -20
  107. package/src/icons/sidebar/roles-icon.vue +26 -26
  108. package/src/icons/sidebar/status-history-icon.vue +24 -24
  109. package/src/icons/sidebar/tasks-icon.vue +28 -28
  110. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  111. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  112. package/src/icons/sidebar/teams-icon.vue +32 -32
  113. package/src/icons/sidebar/user-icon.vue +18 -18
  114. package/src/icons/sidebar/users-icon.vue +46 -46
  115. package/src/icons/sidebar/videosources-icon.vue +19 -19
  116. package/src/icons/sidebar/videowall-icon.vue +13 -13
  117. package/src/icons/sidebar/videozones-icon.vue +21 -21
  118. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  119. package/src/icons/sidebar/workshop-icon.vue +100 -100
  120. package/src/icons/sidebar/workzones-icon.vue +22 -22
  121. package/src/icons/task/attention-icon.vue +13 -13
  122. package/src/icons/task/clock-icon.vue +10 -10
  123. package/src/icons/task/delete-icon.vue +10 -10
  124. package/src/icons/task/fire-icon.vue +16 -16
  125. package/src/index.ts +131 -131
  126. package/src/main.ts +28 -28
  127. package/src/quasar-user-options.ts +17 -17
  128. package/src/router/index.ts +10 -10
  129. package/src/shared/styles/general.css +124 -124
  130. package/src/shims-vue.d.ts +5 -5
  131. package/src/styles/variables.sass +12 -12
  132. package/src/utils/confirm.ts +12 -12
  133. package/src/utils/faceApiHelper.ts +132 -132
  134. package/src/utils/files.ts +19 -19
  135. package/src/utils/helpers.ts +59 -59
  136. package/src/utils/notification.ts +9 -9
@@ -1,152 +1,152 @@
1
- <template>
2
- <div class="table-pagination">
3
- <button class="arrow-button" :disabled="modelValue <= 1" @click="prevPage">
4
- <q-icon name="mdi-chevron-left" :color="modelValue <= 1 ? 'grey-4' : 'primary'" />
5
- </button>
6
-
7
- <div class="pages">
8
- <button
9
- v-for="page in pageArray"
10
- :key="page"
11
- class="page-button"
12
- :class="{ selected: page === modelValue, ellipsis: page === '...' }"
13
- :disabled="page === modelValue || page === '...'"
14
- @click="changePage(page)"
15
- >
16
- {{ page }}
17
- </button>
18
- </div>
19
-
20
- <button class="arrow-button" :disabled="modelValue >= totalPages" @click="nextPage">
21
- <q-icon name="mdi-chevron-right" :color="modelValue >= totalPages ? 'grey-4' : 'primary'" />
22
- </button>
23
- </div>
24
- </template>
25
- <script setup lang="ts">
26
- import { computed } from 'vue'
27
- import { defineProps, defineEmits } from 'vue'
28
-
29
- const props = defineProps<{
30
- modelValue: number
31
- totalPages: number
32
- }>()
33
-
34
- const emit = defineEmits<{
35
- (e: 'update:modelValue', value: number): void
36
- (e: 'page-change', value: number): void
37
- }>()
38
-
39
- const currentPage = computed({
40
- get: () => props.modelValue,
41
- set: (val: number) => {
42
- emit('update:modelValue', val)
43
- emit('page-change', val)
44
- },
45
- })
46
-
47
- const pageArray = computed(() => {
48
- const maxPagesToShow = 5
49
- let startPage = 1
50
- let endPage = props.totalPages
51
- const pages: (number | string)[] = []
52
-
53
- if (props.totalPages <= maxPagesToShow) {
54
- for (let i = 1; i <= props.totalPages; i++) pages.push(i)
55
- } else {
56
- if (props.modelValue <= 3) {
57
- startPage = 1
58
- endPage = maxPagesToShow - 1
59
- } else if (props.modelValue + 2 >= props.totalPages) {
60
- startPage = props.totalPages - (maxPagesToShow - 2)
61
- endPage = props.totalPages
62
- } else {
63
- startPage = props.modelValue - 2
64
- endPage = props.modelValue + 2
65
- }
66
-
67
- for (let i = startPage; i <= endPage; i++) pages.push(i)
68
-
69
- if (startPage > 1) {
70
- pages.unshift('...')
71
- pages.unshift(1)
72
- }
73
- if (endPage < props.totalPages) {
74
- pages.push('...')
75
- pages.push(props.totalPages)
76
- }
77
- }
78
-
79
- return pages
80
- })
81
-
82
- function changePage(page: number | string) {
83
- if (typeof page === 'number' && page !== props.modelValue) {
84
- currentPage.value = page
85
- }
86
- }
87
-
88
- function prevPage() {
89
- if (props.modelValue > 1) currentPage.value = props.modelValue - 1
90
- }
91
-
92
- function nextPage() {
93
- if (props.modelValue < props.totalPages) currentPage.value = props.modelValue + 1
94
- }
95
- </script>
96
-
97
- <style scoped lang="scss">
98
- .pages {
99
- display: flex;
100
- gap: 20px;
101
- }
102
- .table-pagination {
103
- display: flex;
104
- justify-content: start;
105
- align-items: center;
106
- gap: 20px;
107
- flex-wrap: wrap;
108
-
109
- .arrow-button,
110
- .page-button {
111
- display: flex;
112
- justify-content: center;
113
- align-items: center;
114
- width: 34px;
115
- height: 34px;
116
- border-radius: 4px;
117
- background: white;
118
- border: none;
119
- cursor: pointer;
120
- font-weight: 500;
121
- color: #3f8cff;
122
- font-size: 16px;
123
- transition: all 0.2s ease;
124
- }
125
-
126
- .page-button.selected {
127
- background: #3f8cff;
128
- color: white;
129
- cursor: not-allowed;
130
- }
131
-
132
- .page-button.ellipsis {
133
- cursor: default;
134
- color: #aab2c8;
135
- font-weight: 400;
136
- }
137
-
138
- .arrow-button:disabled {
139
- cursor: not-allowed;
140
- background: white;
141
- }
142
-
143
- @media (max-width: 768px) {
144
- .arrow-button,
145
- .page-button {
146
- width: 32px;
147
- height: 32px;
148
- font-size: 14px;
149
- }
150
- }
151
- }
152
- </style>
1
+ <template>
2
+ <div class="table-pagination">
3
+ <button class="arrow-button" :disabled="modelValue <= 1" @click="prevPage">
4
+ <q-icon name="mdi-chevron-left" :color="modelValue <= 1 ? 'grey-4' : 'primary'" />
5
+ </button>
6
+
7
+ <div class="pages">
8
+ <button
9
+ v-for="page in pageArray"
10
+ :key="page"
11
+ class="page-button"
12
+ :class="{ selected: page === modelValue, ellipsis: page === '...' }"
13
+ :disabled="page === modelValue || page === '...'"
14
+ @click="changePage(page)"
15
+ >
16
+ {{ page }}
17
+ </button>
18
+ </div>
19
+
20
+ <button class="arrow-button" :disabled="modelValue >= totalPages" @click="nextPage">
21
+ <q-icon name="mdi-chevron-right" :color="modelValue >= totalPages ? 'grey-4' : 'primary'" />
22
+ </button>
23
+ </div>
24
+ </template>
25
+ <script setup lang="ts">
26
+ import { computed } from 'vue'
27
+ import { defineProps, defineEmits } from 'vue'
28
+
29
+ const props = defineProps<{
30
+ modelValue: number
31
+ totalPages: number
32
+ }>()
33
+
34
+ const emit = defineEmits<{
35
+ (e: 'update:modelValue', value: number): void
36
+ (e: 'page-change', value: number): void
37
+ }>()
38
+
39
+ const currentPage = computed({
40
+ get: () => props.modelValue,
41
+ set: (val: number) => {
42
+ emit('update:modelValue', val)
43
+ emit('page-change', val)
44
+ },
45
+ })
46
+
47
+ const pageArray = computed(() => {
48
+ const maxPagesToShow = 5
49
+ let startPage = 1
50
+ let endPage = props.totalPages
51
+ const pages: (number | string)[] = []
52
+
53
+ if (props.totalPages <= maxPagesToShow) {
54
+ for (let i = 1; i <= props.totalPages; i++) pages.push(i)
55
+ } else {
56
+ if (props.modelValue <= 3) {
57
+ startPage = 1
58
+ endPage = maxPagesToShow - 1
59
+ } else if (props.modelValue + 2 >= props.totalPages) {
60
+ startPage = props.totalPages - (maxPagesToShow - 2)
61
+ endPage = props.totalPages
62
+ } else {
63
+ startPage = props.modelValue - 2
64
+ endPage = props.modelValue + 2
65
+ }
66
+
67
+ for (let i = startPage; i <= endPage; i++) pages.push(i)
68
+
69
+ if (startPage > 1) {
70
+ pages.unshift('...')
71
+ pages.unshift(1)
72
+ }
73
+ if (endPage < props.totalPages) {
74
+ pages.push('...')
75
+ pages.push(props.totalPages)
76
+ }
77
+ }
78
+
79
+ return pages
80
+ })
81
+
82
+ function changePage(page: number | string) {
83
+ if (typeof page === 'number' && page !== props.modelValue) {
84
+ currentPage.value = page
85
+ }
86
+ }
87
+
88
+ function prevPage() {
89
+ if (props.modelValue > 1) currentPage.value = props.modelValue - 1
90
+ }
91
+
92
+ function nextPage() {
93
+ if (props.modelValue < props.totalPages) currentPage.value = props.modelValue + 1
94
+ }
95
+ </script>
96
+
97
+ <style scoped lang="scss">
98
+ .pages {
99
+ display: flex;
100
+ gap: 20px;
101
+ }
102
+ .table-pagination {
103
+ display: flex;
104
+ justify-content: start;
105
+ align-items: center;
106
+ gap: 20px;
107
+ flex-wrap: wrap;
108
+
109
+ .arrow-button,
110
+ .page-button {
111
+ display: flex;
112
+ justify-content: center;
113
+ align-items: center;
114
+ width: 34px;
115
+ height: 34px;
116
+ border-radius: 4px;
117
+ background: white;
118
+ border: none;
119
+ cursor: pointer;
120
+ font-weight: 500;
121
+ color: #3f8cff;
122
+ font-size: 16px;
123
+ transition: all 0.2s ease;
124
+ }
125
+
126
+ .page-button.selected {
127
+ background: #3f8cff;
128
+ color: white;
129
+ cursor: not-allowed;
130
+ }
131
+
132
+ .page-button.ellipsis {
133
+ cursor: default;
134
+ color: #aab2c8;
135
+ font-weight: 400;
136
+ }
137
+
138
+ .arrow-button:disabled {
139
+ cursor: not-allowed;
140
+ background: white;
141
+ }
142
+
143
+ @media (max-width: 768px) {
144
+ .arrow-button,
145
+ .page-button {
146
+ width: 32px;
147
+ height: 32px;
148
+ font-size: 14px;
149
+ }
150
+ }
151
+ }
152
+ </style>
@@ -1,76 +1,76 @@
1
- <template>
2
- <q-input v-model="input" :placeholder="placeholder" dense outlined>
3
- <template v-if="input" #append>
4
- <q-icon name="✕" class="cursor-pointer" @click.stop="clearInput" />
5
- </template>
6
- </q-input>
7
- </template>
8
-
9
- <script setup lang="ts">
10
- import { defineProps, defineEmits, ref, watch } from 'vue'
11
-
12
- const props = defineProps<{
13
- modelValue: string
14
- placeholder: string
15
- }>()
16
-
17
- const emit = defineEmits<{
18
- (e: 'update:modelValue', value: string): void
19
- (e: 'search', value: string): void
20
- }>()
21
-
22
- const input = ref(props.modelValue)
23
- let debounceTimer: ReturnType<typeof setTimeout>
24
- const clearInput = () => {
25
- input.value = ''
26
- emit('search', '')
27
- }
28
- watch(
29
- () => props.modelValue,
30
- val => {
31
- input.value = val
32
- },
33
- )
34
-
35
- watch(input, val => {
36
- emit('update:modelValue', val)
37
- clearTimeout(debounceTimer)
38
- debounceTimer = setTimeout(() => {
39
- emit('search', val)
40
- }, 400)
41
- })
42
- </script>
43
-
44
- <style scoped lang="scss">
45
- .q-field {
46
- background: #fff;
47
- border-radius: 4px;
48
- outline: none;
49
- border-color: #f2f7fb;
50
-
51
- ::v-deep(.q-field__control) {
52
- height: 52px;
53
- display: flex;
54
- align-items: center;
55
- }
56
-
57
- ::v-deep(.q-field__native) {
58
- font-family: NunitoSansFont, sans-serif;
59
- color: #1d425d;
60
- padding-left: 8px;
61
- }
62
-
63
- ::v-deep(.q-field__native::placeholder) {
64
- color: rgba(184, 184, 184, 0.87);
65
- }
66
-
67
- ::v-deep(.q-icon.cursor-pointer) {
68
- color: #1d425d;
69
- font-size: 20px;
70
- line-height: 15px;
71
- }
72
- ::v-deep(.q-field__control:hover:before) {
73
- border-color: #3f8cff;
74
- }
75
- }
76
- </style>
1
+ <template>
2
+ <q-input v-model="input" :placeholder="placeholder" dense outlined>
3
+ <template v-if="input" #append>
4
+ <q-icon name="✕" class="cursor-pointer" @click.stop="clearInput" />
5
+ </template>
6
+ </q-input>
7
+ </template>
8
+
9
+ <script setup lang="ts">
10
+ import { defineProps, defineEmits, ref, watch } from 'vue'
11
+
12
+ const props = defineProps<{
13
+ modelValue: string
14
+ placeholder: string
15
+ }>()
16
+
17
+ const emit = defineEmits<{
18
+ (e: 'update:modelValue', value: string): void
19
+ (e: 'search', value: string): void
20
+ }>()
21
+
22
+ const input = ref(props.modelValue)
23
+ let debounceTimer: ReturnType<typeof setTimeout>
24
+ const clearInput = () => {
25
+ input.value = ''
26
+ emit('search', '')
27
+ }
28
+ watch(
29
+ () => props.modelValue,
30
+ val => {
31
+ input.value = val
32
+ },
33
+ )
34
+
35
+ watch(input, val => {
36
+ emit('update:modelValue', val)
37
+ clearTimeout(debounceTimer)
38
+ debounceTimer = setTimeout(() => {
39
+ emit('search', val)
40
+ }, 400)
41
+ })
42
+ </script>
43
+
44
+ <style scoped lang="scss">
45
+ .q-field {
46
+ background: #fff;
47
+ border-radius: 4px;
48
+ outline: none;
49
+ border-color: #f2f7fb;
50
+
51
+ ::v-deep(.q-field__control) {
52
+ height: 52px;
53
+ display: flex;
54
+ align-items: center;
55
+ }
56
+
57
+ ::v-deep(.q-field__native) {
58
+ font-family: NunitoSansFont, sans-serif;
59
+ color: #1d425d;
60
+ padding-left: 8px;
61
+ }
62
+
63
+ ::v-deep(.q-field__native::placeholder) {
64
+ color: rgba(184, 184, 184, 0.87);
65
+ }
66
+
67
+ ::v-deep(.q-icon.cursor-pointer) {
68
+ color: #1d425d;
69
+ font-size: 20px;
70
+ line-height: 15px;
71
+ }
72
+ ::v-deep(.q-field__control:hover:before) {
73
+ border-color: #3f8cff;
74
+ }
75
+ }
76
+ </style>
@@ -1,45 +1,45 @@
1
- import { ref, watch, onMounted, Ref } from 'vue'
2
-
3
- export function useBaseTable(model: {
4
- initialize: (params: { search: string; page: number }) => Promise<void>
5
- loading: Ref<boolean>
6
- columnFilters: Ref<Record<string, any>>
7
- }) {
8
- const search = ref('')
9
- const currentPage = ref(1)
10
-
11
- const loadTable = async (searchVal = '', pageVal = 1) => {
12
- await model.initialize({ search: searchVal, page: pageVal })
13
- }
14
-
15
- const handleSearch = async (val: string) => {
16
- search.value = val
17
- currentPage.value = 1
18
- await loadTable(val, currentPage.value)
19
- }
20
-
21
- const handlePageChange = async (page: number) => {
22
- currentPage.value = page
23
- await loadTable(search.value, page)
24
- }
25
-
26
- watch(
27
- () => model.columnFilters.value,
28
- async () => {
29
- currentPage.value = 1
30
- await loadTable(search.value, currentPage.value)
31
- },
32
- { deep: true },
33
- )
34
-
35
- onMounted(() => loadTable(search.value, currentPage.value))
36
-
37
- return {
38
- search,
39
- currentPage,
40
- loading: model.loading,
41
- handleSearch,
42
- handlePageChange,
43
- loadTable,
44
- }
45
- }
1
+ import { ref, watch, onMounted, Ref } from 'vue'
2
+
3
+ export function useBaseTable(model: {
4
+ initialize: (params: { search: string; page: number }) => Promise<void>
5
+ loading: Ref<boolean>
6
+ columnFilters: Ref<Record<string, any>>
7
+ }) {
8
+ const search = ref('')
9
+ const currentPage = ref(1)
10
+
11
+ const loadTable = async (searchVal = '', pageVal = 1) => {
12
+ await model.initialize({ search: searchVal, page: pageVal })
13
+ }
14
+
15
+ const handleSearch = async (val: string) => {
16
+ search.value = val
17
+ currentPage.value = 1
18
+ await loadTable(val, currentPage.value)
19
+ }
20
+
21
+ const handlePageChange = async (page: number) => {
22
+ currentPage.value = page
23
+ await loadTable(search.value, page)
24
+ }
25
+
26
+ watch(
27
+ () => model.columnFilters.value,
28
+ async () => {
29
+ currentPage.value = 1
30
+ await loadTable(search.value, currentPage.value)
31
+ },
32
+ { deep: true },
33
+ )
34
+
35
+ onMounted(() => loadTable(search.value, currentPage.value))
36
+
37
+ return {
38
+ search,
39
+ currentPage,
40
+ loading: model.loading,
41
+ handleSearch,
42
+ handlePageChange,
43
+ loadTable,
44
+ }
45
+ }
@@ -1,38 +1,38 @@
1
- import { computed, ref } from 'vue'
2
-
3
- export interface ColumnConfig {
4
- name: string
5
- label: string
6
- [key: string]: any
7
- }
8
-
9
- export function useColumnSelector(allColumns: ColumnConfig[], fixedColumnNames: string[] = []) {
10
- const selectedColumnNames = ref<string[]>([...new Set([...fixedColumnNames, ...allColumns.map(col => col.name)])])
11
-
12
- const visibleColumns = computed(() => allColumns.filter(col => selectedColumnNames.value.includes(col.name)))
13
-
14
- function openColumnSelectorDialog($q: any) {
15
- $q.dialog({
16
- title: 'Выберите колонки',
17
- options: {
18
- type: 'checkbox',
19
- model: [...selectedColumnNames.value],
20
- items: allColumns.map(col => ({
21
- label: col.label,
22
- value: col.name,
23
- disable: fixedColumnNames.includes(col.name),
24
- })),
25
- },
26
- cancel: true,
27
- persistent: true,
28
- }).onOk((val: string[]) => {
29
- selectedColumnNames.value = Array.from(new Set([...val, ...fixedColumnNames]))
30
- })
31
- }
32
-
33
- return {
34
- selectedColumnNames,
35
- visibleColumns,
36
- openColumnSelectorDialog,
37
- }
38
- }
1
+ import { computed, ref } from 'vue'
2
+
3
+ export interface ColumnConfig {
4
+ name: string
5
+ label: string
6
+ [key: string]: any
7
+ }
8
+
9
+ export function useColumnSelector(allColumns: ColumnConfig[], fixedColumnNames: string[] = []) {
10
+ const selectedColumnNames = ref<string[]>([...new Set([...fixedColumnNames, ...allColumns.map(col => col.name)])])
11
+
12
+ const visibleColumns = computed(() => allColumns.filter(col => selectedColumnNames.value.includes(col.name)))
13
+
14
+ function openColumnSelectorDialog($q: any) {
15
+ $q.dialog({
16
+ title: 'Выберите колонки',
17
+ options: {
18
+ type: 'checkbox',
19
+ model: [...selectedColumnNames.value],
20
+ items: allColumns.map(col => ({
21
+ label: col.label,
22
+ value: col.name,
23
+ disable: fixedColumnNames.includes(col.name),
24
+ })),
25
+ },
26
+ cancel: true,
27
+ persistent: true,
28
+ }).onOk((val: string[]) => {
29
+ selectedColumnNames.value = Array.from(new Set([...val, ...fixedColumnNames]))
30
+ })
31
+ }
32
+
33
+ return {
34
+ selectedColumnNames,
35
+ visibleColumns,
36
+ openColumnSelectorDialog,
37
+ }
38
+ }