shared-ritm 1.3.125 → 1.3.126

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 +502 -484
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/dist/types/api/services/MetricsService.d.ts +0 -1
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/stories/Button.stories.d.ts +13 -0
  7. package/dist/types/stories/Checkbox.stories.d.ts +7 -0
  8. package/dist/types/stories/Confirm.stories.d.ts +8 -0
  9. package/dist/types/stories/DatePicker.stories.d.ts +8 -0
  10. package/dist/types/stories/Dropdown.stories.d.ts +8 -0
  11. package/dist/types/stories/File.stories.d.ts +8 -0
  12. package/dist/types/stories/Icon.stories.d.ts +7 -0
  13. package/dist/types/stories/Input.stories.d.ts +11 -0
  14. package/dist/types/stories/InputNew.stories.d.ts +12 -0
  15. package/dist/types/stories/InputSearch.stories.d.ts +10 -0
  16. package/dist/types/stories/Loader.stories.d.ts +8 -0
  17. package/dist/types/stories/Select.stories.d.ts +7 -0
  18. package/dist/types/stories/Toggle.stories.d.ts +8 -0
  19. package/package.json +70 -70
  20. package/src/App.vue +2461 -2461
  21. package/src/api/services/AuthService.ts +67 -67
  22. package/src/api/services/ControlsService.ts +100 -100
  23. package/src/api/services/EquipmentService.ts +68 -68
  24. package/src/api/services/GanttService.ts +58 -58
  25. package/src/api/services/InstrumentsService.ts +76 -76
  26. package/src/api/services/MetricsService.ts +0 -3
  27. package/src/api/services/RepairsService.ts +111 -111
  28. package/src/api/services/TasksService.ts +165 -165
  29. package/src/api/services/UserIssueService.ts +32 -32
  30. package/src/api/services/UserService.ts +129 -129
  31. package/src/api/services/VideoService.ts +118 -118
  32. package/src/api/settings/ApiService.ts +185 -185
  33. package/src/api/types/Api_Auth.ts +121 -121
  34. package/src/api/types/Api_Controls.ts +112 -112
  35. package/src/api/types/Api_Equipment.ts +54 -54
  36. package/src/api/types/Api_Instruments.ts +182 -182
  37. package/src/api/types/Api_Metrics.ts +89 -89
  38. package/src/api/types/Api_Repairs.ts +200 -200
  39. package/src/api/types/Api_Search.ts +81 -81
  40. package/src/api/types/Api_Tasks.ts +378 -378
  41. package/src/api/types/Api_User.ts +161 -161
  42. package/src/api/types/Api_User_Issue.ts +36 -36
  43. package/src/api/types/Api_Video.ts +244 -244
  44. package/src/common/app-button/Button.stories.ts +369 -369
  45. package/src/common/app-checkbox/AppCheckbox.vue +33 -31
  46. package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
  47. package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
  48. package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
  49. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  50. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  51. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  52. package/src/common/app-file/File.stories.ts +104 -104
  53. package/src/common/app-icon/AppIcon.vue +110 -110
  54. package/src/common/app-icon/Icon.stories.ts +91 -91
  55. package/src/common/app-input/AppInput.vue +150 -150
  56. package/src/common/app-input/Input.stories.ts +160 -160
  57. package/src/common/app-input-new/AppInputNew.vue +181 -181
  58. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  59. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  60. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  61. package/src/common/app-loader/Loader.stories.ts +114 -114
  62. package/src/common/app-modal/index.vue +101 -101
  63. package/src/common/app-select/AppSelect.vue +159 -159
  64. package/src/common/app-select/Select.stories.ts +155 -155
  65. package/src/common/app-sheet-new/AppSheetNew.vue +254 -254
  66. package/src/common/app-sidebar/AppSidebar.vue +177 -177
  67. package/src/common/app-table/AppTable.vue +313 -313
  68. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  69. package/src/common/app-table/components/ModalSelect.vue +311 -302
  70. package/src/common/app-table/components/TableModal.vue +369 -369
  71. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  72. package/src/common/app-table/controllers/useTableModel.ts +98 -98
  73. package/src/common/app-toggle/AppToggle.vue +12 -12
  74. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  75. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  76. package/src/configs/storybook.ts +14 -14
  77. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  78. package/src/index.ts +134 -134
  79. package/src/shared/styles/general.css +140 -140
  80. package/src/styles/variables.sass +12 -12
  81. package/src/utils/files.ts +38 -38
  82. package/src/utils/helpers.ts +59 -59
@@ -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>