shared-ritm 1.3.130 → 1.3.132

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 (83) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +18 -15
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/dist/types/api/services/MetricsService.d.ts +1 -0
  5. package/package.json +70 -70
  6. package/src/App.vue +2461 -2461
  7. package/src/api/services/AuthService.ts +67 -67
  8. package/src/api/services/ControlsService.ts +100 -100
  9. package/src/api/services/EquipmentService.ts +68 -68
  10. package/src/api/services/GanttService.ts +58 -58
  11. package/src/api/services/InstrumentsService.ts +76 -76
  12. package/src/api/services/MetricsService.ts +3 -0
  13. package/src/api/services/RepairsService.ts +111 -111
  14. package/src/api/services/TasksService.ts +165 -165
  15. package/src/api/services/UserIssueService.ts +32 -32
  16. package/src/api/services/UserService.ts +129 -129
  17. package/src/api/services/VideoService.ts +118 -118
  18. package/src/api/settings/ApiService.ts +185 -185
  19. package/src/api/types/Api_Auth.ts +121 -121
  20. package/src/api/types/Api_Controls.ts +112 -112
  21. package/src/api/types/Api_Equipment.ts +54 -54
  22. package/src/api/types/Api_Instruments.ts +182 -182
  23. package/src/api/types/Api_Metrics.ts +112 -112
  24. package/src/api/types/Api_Repairs.ts +200 -200
  25. package/src/api/types/Api_Search.ts +81 -81
  26. package/src/api/types/Api_Tasks.ts +385 -385
  27. package/src/api/types/Api_User.ts +161 -161
  28. package/src/api/types/Api_User_Issue.ts +36 -36
  29. package/src/api/types/Api_Video.ts +244 -244
  30. package/src/common/app-button/Button.stories.ts +369 -369
  31. package/src/common/app-checkbox/AppCheckbox.vue +33 -33
  32. package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
  33. package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
  34. package/src/common/app-datepicker/AppDatepicker.vue +221 -221
  35. package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
  36. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  37. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  38. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  39. package/src/common/app-file/File.stories.ts +104 -104
  40. package/src/common/app-icon/AppIcon.vue +110 -110
  41. package/src/common/app-icon/Icon.stories.ts +91 -91
  42. package/src/common/app-input/AppInput.vue +150 -150
  43. package/src/common/app-input/Input.stories.ts +160 -160
  44. package/src/common/app-input-new/AppInputNew.vue +186 -186
  45. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  46. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  47. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  48. package/src/common/app-loader/Loader.stories.ts +114 -114
  49. package/src/common/app-modal/index.vue +101 -101
  50. package/src/common/app-select/AppSelect.vue +167 -167
  51. package/src/common/app-select/Select.stories.ts +155 -155
  52. package/src/common/app-sheet-new/AppSheetNew.vue +254 -254
  53. package/src/common/app-sidebar/AppSidebar.vue +177 -177
  54. package/src/common/app-table/AppTable.vue +313 -313
  55. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  56. package/src/common/app-table/components/ModalSelect.vue +311 -311
  57. package/src/common/app-table/components/TableModal.vue +369 -369
  58. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  59. package/src/common/app-table/controllers/useTableModel.ts +98 -98
  60. package/src/common/app-toggle/AppToggle.vue +12 -12
  61. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  62. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  63. package/src/configs/storybook.ts +14 -14
  64. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  65. package/src/index.ts +134 -134
  66. package/src/shared/styles/general.css +140 -140
  67. package/src/styles/variables.sass +12 -12
  68. package/src/utils/files.ts +38 -38
  69. package/src/utils/helpers.ts +59 -59
  70. package/dist/types/api/services/PhotoService.d.ts +0 -40
  71. package/dist/types/stories/Button.stories.d.ts +0 -13
  72. package/dist/types/stories/Checkbox.stories.d.ts +0 -7
  73. package/dist/types/stories/Confirm.stories.d.ts +0 -8
  74. package/dist/types/stories/DatePicker.stories.d.ts +0 -8
  75. package/dist/types/stories/Dropdown.stories.d.ts +0 -8
  76. package/dist/types/stories/File.stories.d.ts +0 -8
  77. package/dist/types/stories/Icon.stories.d.ts +0 -7
  78. package/dist/types/stories/Input.stories.d.ts +0 -11
  79. package/dist/types/stories/InputNew.stories.d.ts +0 -12
  80. package/dist/types/stories/InputSearch.stories.d.ts +0 -10
  81. package/dist/types/stories/Loader.stories.d.ts +0 -8
  82. package/dist/types/stories/Select.stories.d.ts +0 -7
  83. package/dist/types/stories/Toggle.stories.d.ts +0 -8
@@ -1,45 +1,45 @@
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.checkboxLabel ?? col.label,
22
- value: col.name,
23
- disable: fixedColumnNames.includes(col.name),
24
- })),
25
- },
26
- cancel: {
27
- label: 'Отмена',
28
- 'data-test': 'cancel-button',
29
- },
30
- ok: {
31
- label: 'Ок',
32
- 'data-test': 'ok-button',
33
- },
34
- persistent: true,
35
- }).onOk((val: string[]) => {
36
- selectedColumnNames.value = Array.from(new Set([...val, ...fixedColumnNames]))
37
- })
38
- }
39
-
40
- return {
41
- selectedColumnNames,
42
- visibleColumns,
43
- openColumnSelectorDialog,
44
- }
45
- }
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.checkboxLabel ?? col.label,
22
+ value: col.name,
23
+ disable: fixedColumnNames.includes(col.name),
24
+ })),
25
+ },
26
+ cancel: {
27
+ label: 'Отмена',
28
+ 'data-test': 'cancel-button',
29
+ },
30
+ ok: {
31
+ label: 'Ок',
32
+ 'data-test': 'ok-button',
33
+ },
34
+ persistent: true,
35
+ }).onOk((val: string[]) => {
36
+ selectedColumnNames.value = Array.from(new Set([...val, ...fixedColumnNames]))
37
+ })
38
+ }
39
+
40
+ return {
41
+ selectedColumnNames,
42
+ visibleColumns,
43
+ openColumnSelectorDialog,
44
+ }
45
+ }
@@ -1,98 +1,98 @@
1
- import { Ref, computed, ref } from 'vue'
2
-
3
- export interface TableColumn {
4
- name: string
5
- label: string
6
- style?: string
7
- headerStyle?: string
8
- field?: string | ((row: any) => any)
9
- sortable?: boolean
10
- filterType?: 'single' | 'multi' | null
11
- align?: 'left' | 'center' | 'right'
12
- badge?: {
13
- true?: string
14
- false?: string
15
- colorTrue?: string
16
- colorFalse?: string
17
- }
18
- format?: (val: any) => any
19
- html?: boolean
20
- checkboxLabel?: string
21
- }
22
-
23
- export interface FilterOption {
24
- id: string
25
- name: string
26
- }
27
-
28
- export interface TableModel<T = any> {
29
- columns: TableColumn[]
30
- rows: T[] | Ref<T[]>
31
- filtersOptions?: Ref<Record<string, FilterOption[]>>
32
- }
33
-
34
- export const useTableModel = <T = any>(model: TableModel<T>) => {
35
- const columnFilters = ref<Record<string, string | string[] | undefined>>({})
36
- const filterMenus = ref<Record<string, boolean>>({})
37
-
38
- model.columns.forEach(({ name, filterType }) => {
39
- if (filterType) {
40
- columnFilters.value[name] = filterType === 'multi' ? [] : undefined
41
- filterMenus.value[name] = false
42
- }
43
- })
44
-
45
- const resolvedRows = computed(() => (Array.isArray(model.rows) ? model.rows : model.rows.value))
46
-
47
- const toggleFilterValue = (colName: string, value: string) => {
48
- const col = model.columns.find(c => c.name === colName)
49
- if (col?.filterType === 'multi') {
50
- const current = columnFilters.value[colName] as string[]
51
- const index = current.indexOf(value)
52
- index > -1 ? current.splice(index, 1) : current.push(value)
53
- columnFilters.value[colName] = [...current]
54
- } else {
55
- columnFilters.value[colName] = value
56
- filterMenus.value[colName] = false
57
- }
58
- }
59
-
60
- const selectedFilters = computed(() => {
61
- const result: Record<string, string[]> = {}
62
- for (const col of model.columns) {
63
- const filter = columnFilters.value[col.name]
64
- const options = model.filtersOptions?.value[col.name] || []
65
-
66
- if (filter) {
67
- let selectedIds: string[] = []
68
- if (Array.isArray(filter)) {
69
- selectedIds = options.filter(opt => filter.includes(opt.name)).map(opt => opt.id)
70
- } else {
71
- selectedIds = options.filter(opt => opt.name === filter).map(opt => opt.id)
72
- }
73
- result[col.name] = Array.from(new Set(selectedIds))
74
- }
75
- }
76
- return result
77
- })
78
-
79
- const clearFilter = (colName: string) => {
80
- const col = model.columns.find(c => c.name === colName)
81
- columnFilters.value[colName] = col?.filterType === 'multi' ? [] : undefined
82
- }
83
-
84
- const openFilterMenu = (colName: string, isOpen: boolean) => {
85
- filterMenus.value[colName] = isOpen
86
- }
87
-
88
- return {
89
- rows: resolvedRows,
90
- columns: computed(() => model.columns),
91
- columnFilters,
92
- filterMenus,
93
- toggleFilterValue,
94
- clearFilter,
95
- openFilterMenu,
96
- selectedFilters,
97
- }
98
- }
1
+ import { Ref, computed, ref } from 'vue'
2
+
3
+ export interface TableColumn {
4
+ name: string
5
+ label: string
6
+ style?: string
7
+ headerStyle?: string
8
+ field?: string | ((row: any) => any)
9
+ sortable?: boolean
10
+ filterType?: 'single' | 'multi' | null
11
+ align?: 'left' | 'center' | 'right'
12
+ badge?: {
13
+ true?: string
14
+ false?: string
15
+ colorTrue?: string
16
+ colorFalse?: string
17
+ }
18
+ format?: (val: any) => any
19
+ html?: boolean
20
+ checkboxLabel?: string
21
+ }
22
+
23
+ export interface FilterOption {
24
+ id: string
25
+ name: string
26
+ }
27
+
28
+ export interface TableModel<T = any> {
29
+ columns: TableColumn[]
30
+ rows: T[] | Ref<T[]>
31
+ filtersOptions?: Ref<Record<string, FilterOption[]>>
32
+ }
33
+
34
+ export const useTableModel = <T = any>(model: TableModel<T>) => {
35
+ const columnFilters = ref<Record<string, string | string[] | undefined>>({})
36
+ const filterMenus = ref<Record<string, boolean>>({})
37
+
38
+ model.columns.forEach(({ name, filterType }) => {
39
+ if (filterType) {
40
+ columnFilters.value[name] = filterType === 'multi' ? [] : undefined
41
+ filterMenus.value[name] = false
42
+ }
43
+ })
44
+
45
+ const resolvedRows = computed(() => (Array.isArray(model.rows) ? model.rows : model.rows.value))
46
+
47
+ const toggleFilterValue = (colName: string, value: string) => {
48
+ const col = model.columns.find(c => c.name === colName)
49
+ if (col?.filterType === 'multi') {
50
+ const current = columnFilters.value[colName] as string[]
51
+ const index = current.indexOf(value)
52
+ index > -1 ? current.splice(index, 1) : current.push(value)
53
+ columnFilters.value[colName] = [...current]
54
+ } else {
55
+ columnFilters.value[colName] = value
56
+ filterMenus.value[colName] = false
57
+ }
58
+ }
59
+
60
+ const selectedFilters = computed(() => {
61
+ const result: Record<string, string[]> = {}
62
+ for (const col of model.columns) {
63
+ const filter = columnFilters.value[col.name]
64
+ const options = model.filtersOptions?.value[col.name] || []
65
+
66
+ if (filter) {
67
+ let selectedIds: string[] = []
68
+ if (Array.isArray(filter)) {
69
+ selectedIds = options.filter(opt => filter.includes(opt.name)).map(opt => opt.id)
70
+ } else {
71
+ selectedIds = options.filter(opt => opt.name === filter).map(opt => opt.id)
72
+ }
73
+ result[col.name] = Array.from(new Set(selectedIds))
74
+ }
75
+ }
76
+ return result
77
+ })
78
+
79
+ const clearFilter = (colName: string) => {
80
+ const col = model.columns.find(c => c.name === colName)
81
+ columnFilters.value[colName] = col?.filterType === 'multi' ? [] : undefined
82
+ }
83
+
84
+ const openFilterMenu = (colName: string, isOpen: boolean) => {
85
+ filterMenus.value[colName] = isOpen
86
+ }
87
+
88
+ return {
89
+ rows: resolvedRows,
90
+ columns: computed(() => model.columns),
91
+ columnFilters,
92
+ filterMenus,
93
+ toggleFilterValue,
94
+ clearFilter,
95
+ openFilterMenu,
96
+ selectedFilters,
97
+ }
98
+ }
@@ -1,12 +1,12 @@
1
- <template>
2
- <div>
3
- <q-toggle v-bind="$props" />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import { defineProps } from 'vue'
9
- import { QToggleProps } from 'quasar'
10
-
11
- defineProps<QToggleProps>()
12
- </script>
1
+ <template>
2
+ <div>
3
+ <q-toggle v-bind="$props" />
4
+ </div>
5
+ </template>
6
+
7
+ <script setup lang="ts">
8
+ import { defineProps } from 'vue'
9
+ import { QToggleProps } from 'quasar'
10
+
11
+ defineProps<QToggleProps>()
12
+ </script>