shared-ritm 1.3.123 → 1.3.125

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 (82) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +20 -14
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/dist/types/api/services/MetricsService.d.ts +2 -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 +6 -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 +89 -89
  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 +378 -378
  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 +31 -31
  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/Datepicker.stories.ts +145 -145
  35. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  36. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  37. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  38. package/src/common/app-file/File.stories.ts +104 -104
  39. package/src/common/app-icon/AppIcon.vue +110 -110
  40. package/src/common/app-icon/Icon.stories.ts +91 -91
  41. package/src/common/app-input/AppInput.vue +150 -150
  42. package/src/common/app-input/Input.stories.ts +160 -160
  43. package/src/common/app-input-new/AppInputNew.vue +181 -181
  44. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  45. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  46. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  47. package/src/common/app-loader/Loader.stories.ts +114 -114
  48. package/src/common/app-modal/index.vue +101 -101
  49. package/src/common/app-select/AppSelect.vue +159 -159
  50. package/src/common/app-select/Select.stories.ts +155 -155
  51. package/src/common/app-sheet-new/AppSheetNew.vue +254 -254
  52. package/src/common/app-sidebar/AppSidebar.vue +177 -177
  53. package/src/common/app-table/AppTable.vue +313 -313
  54. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  55. package/src/common/app-table/components/ModalSelect.vue +302 -302
  56. package/src/common/app-table/components/TableModal.vue +369 -369
  57. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  58. package/src/common/app-table/controllers/useTableModel.ts +98 -98
  59. package/src/common/app-toggle/AppToggle.vue +12 -12
  60. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  61. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  62. package/src/configs/storybook.ts +14 -14
  63. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  64. package/src/index.ts +134 -134
  65. package/src/shared/styles/general.css +140 -140
  66. package/src/styles/variables.sass +12 -12
  67. package/src/utils/files.ts +38 -38
  68. package/src/utils/helpers.ts +59 -59
  69. package/dist/types/api/services/PhotoService.d.ts +0 -40
  70. package/dist/types/stories/Button.stories.d.ts +0 -13
  71. package/dist/types/stories/Checkbox.stories.d.ts +0 -7
  72. package/dist/types/stories/Confirm.stories.d.ts +0 -8
  73. package/dist/types/stories/DatePicker.stories.d.ts +0 -8
  74. package/dist/types/stories/Dropdown.stories.d.ts +0 -8
  75. package/dist/types/stories/File.stories.d.ts +0 -8
  76. package/dist/types/stories/Icon.stories.d.ts +0 -7
  77. package/dist/types/stories/Input.stories.d.ts +0 -11
  78. package/dist/types/stories/InputNew.stories.d.ts +0 -12
  79. package/dist/types/stories/InputSearch.stories.d.ts +0 -10
  80. package/dist/types/stories/Loader.stories.d.ts +0 -8
  81. package/dist/types/stories/Select.stories.d.ts +0 -7
  82. 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>