shared-ritm 1.3.83 → 1.3.85

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 (73) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +13 -13
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/package.json +70 -70
  5. package/src/App.vue +2461 -2461
  6. package/src/api/services/AuthService.ts +67 -67
  7. package/src/api/services/ControlsService.ts +96 -96
  8. package/src/api/services/EquipmentService.ts +52 -52
  9. package/src/api/services/MetricsService.ts +143 -143
  10. package/src/api/services/RepairsService.ts +111 -111
  11. package/src/api/services/UserIssueService.ts +32 -32
  12. package/src/api/services/UserService.ts +129 -129
  13. package/src/api/services/VideoService.ts +118 -118
  14. package/src/api/settings/ApiService.ts +4 -2
  15. package/src/api/types/Api_Auth.ts +121 -121
  16. package/src/api/types/Api_Equipment.ts +13 -13
  17. package/src/api/types/Api_Metrics.ts +51 -51
  18. package/src/api/types/Api_Repairs.ts +187 -187
  19. package/src/api/types/Api_Search.ts +81 -81
  20. package/src/api/types/Api_Tasks.ts +376 -376
  21. package/src/api/types/Api_User.ts +157 -157
  22. package/src/api/types/Api_User_Issue.ts +36 -36
  23. package/src/api/types/Api_Video.ts +244 -244
  24. package/src/common/app-button/Button.stories.ts +369 -369
  25. package/src/common/app-checkbox/AppCheckbox.vue +31 -31
  26. package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
  27. package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
  28. package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
  29. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  30. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  31. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  32. package/src/common/app-file/File.stories.ts +104 -104
  33. package/src/common/app-icon/AppIcon.vue +110 -110
  34. package/src/common/app-icon/Icon.stories.ts +91 -91
  35. package/src/common/app-input/Input.stories.ts +160 -160
  36. package/src/common/app-input-new/AppInputNew.vue +181 -181
  37. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  38. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  39. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  40. package/src/common/app-loader/Loader.stories.ts +114 -114
  41. package/src/common/app-select/AppSelect.vue +159 -159
  42. package/src/common/app-select/Select.stories.ts +155 -155
  43. package/src/common/app-sidebar/AppSidebar.vue +174 -174
  44. package/src/common/app-table/AppTable.vue +313 -313
  45. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  46. package/src/common/app-table/components/ModalSelect.vue +302 -302
  47. package/src/common/app-table/components/TableModal.vue +367 -367
  48. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  49. package/src/common/app-table/controllers/useTableModel.ts +97 -97
  50. package/src/common/app-toggle/AppToggle.vue +12 -12
  51. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  52. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  53. package/src/configs/storybook.ts +14 -14
  54. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  55. package/src/index.ts +134 -134
  56. package/src/shared/styles/general.css +140 -140
  57. package/src/styles/variables.sass +12 -12
  58. package/src/utils/files.ts +38 -38
  59. package/src/utils/helpers.ts +59 -59
  60. package/dist/types/api/services/PhotoService.d.ts +0 -40
  61. package/dist/types/stories/Button.stories.d.ts +0 -13
  62. package/dist/types/stories/Checkbox.stories.d.ts +0 -7
  63. package/dist/types/stories/Confirm.stories.d.ts +0 -8
  64. package/dist/types/stories/DatePicker.stories.d.ts +0 -8
  65. package/dist/types/stories/Dropdown.stories.d.ts +0 -8
  66. package/dist/types/stories/File.stories.d.ts +0 -8
  67. package/dist/types/stories/Icon.stories.d.ts +0 -7
  68. package/dist/types/stories/Input.stories.d.ts +0 -11
  69. package/dist/types/stories/InputNew.stories.d.ts +0 -12
  70. package/dist/types/stories/InputSearch.stories.d.ts +0 -10
  71. package/dist/types/stories/Loader.stories.d.ts +0 -8
  72. package/dist/types/stories/Select.stories.d.ts +0 -7
  73. package/dist/types/stories/Toggle.stories.d.ts +0 -8
@@ -1,114 +1,114 @@
1
- import type { Meta, StoryObj } from '@storybook/vue3'
2
- import AppLoader from '@/common/app-loader/index.vue'
3
-
4
- const meta: Meta<typeof AppLoader> = {
5
- title: 'Components/AppLoader',
6
- component: AppLoader,
7
- tags: ['autodocs'],
8
- argTypes: {
9
- loading: {
10
- control: 'boolean',
11
- description: 'Показывать ли спиннер',
12
- },
13
- backdrop: {
14
- control: 'boolean',
15
- description: 'Показывать затемнение фона при загрузке',
16
- table: { disable: true },
17
- },
18
- size: {
19
- control: 'select',
20
- options: ['xs', 'sm', 'md', 'lg', 'xl'],
21
- description: 'Размер спиннера',
22
- },
23
- thickness: {
24
- control: 'number',
25
- description: 'Толщина линии спиннера (в px)',
26
- },
27
- },
28
- args: {
29
- loading: true,
30
- backdrop: false,
31
- size: 'md',
32
- thickness: 2,
33
- },
34
- }
35
-
36
- export default meta
37
- type Story = StoryObj<typeof AppLoader>
38
-
39
- export const GlobalLoader: Story = {
40
- render: args => ({
41
- components: { AppLoader },
42
- setup() {
43
- return { args }
44
- },
45
- template: `
46
- <div style="position: relative; height: 300px;">
47
- <app-loader v-bind="args" />
48
-
49
- <h2>Контент страницы</h2>
50
- </div>
51
- `,
52
- }),
53
- args: {
54
- loading: true,
55
- backdrop: true,
56
- size: 'lg',
57
- },
58
- }
59
-
60
- export const Size: Story = {
61
- render: () => ({
62
- components: { AppLoader },
63
- template: `
64
- <div style="display: flex; flex-wrap: wrap; gap: 32px; padding: 24px; background: white;">
65
- <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
66
- <app-loader :loading="true" size="xs" />
67
- <div style="margin-top: 8px; font-size: 12px; color: #666;">xs</div>
68
- </div>
69
- <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
70
- <app-loader :loading="true" size="sm" />
71
- <div style="margin-top: 8px; font-size: 12px; color: #666;">sm</div>
72
- </div>
73
- <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
74
- <app-loader :loading="true" size="md" />
75
- <div style="margin-top: 8px; font-size: 12px; color: #666;">md</div>
76
- </div>
77
- <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
78
- <app-loader :loading="true" size="lg" />
79
- <div style="margin-top: 8px; font-size: 12px; color: #666;">lg</div>
80
- </div>
81
- <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
82
- <app-loader :loading="true" size="xl" />
83
- <div style="margin-top: 8px; font-size: 12px; color: #666;">xl</div>
84
- </div>
85
- </div>
86
- `,
87
- }),
88
- }
89
-
90
- export const Thickness: Story = {
91
- render: () => ({
92
- components: { AppLoader },
93
- template: `
94
- <div style="display: flex; flex-wrap: wrap; gap: 32px; padding: 24px; background: white;">
95
- <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
96
- <app-loader :loading="true" size="lg" :thickness="1" />
97
- <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=1</div>
98
- </div>
99
- <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
100
- <app-loader :loading="true" size="lg" :thickness="2" />
101
- <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=2</div>
102
- </div>
103
- <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
104
- <app-loader :loading="true" size="lg" :thickness="3" />
105
- <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=3</div>
106
- </div>
107
- <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
108
- <app-loader :loading="true" size="lg" :thickness="5" />
109
- <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=5</div>
110
- </div>
111
- </div>
112
- `,
113
- }),
114
- }
1
+ import type { Meta, StoryObj } from '@storybook/vue3'
2
+ import AppLoader from '@/common/app-loader/index.vue'
3
+
4
+ const meta: Meta<typeof AppLoader> = {
5
+ title: 'Components/AppLoader',
6
+ component: AppLoader,
7
+ tags: ['autodocs'],
8
+ argTypes: {
9
+ loading: {
10
+ control: 'boolean',
11
+ description: 'Показывать ли спиннер',
12
+ },
13
+ backdrop: {
14
+ control: 'boolean',
15
+ description: 'Показывать затемнение фона при загрузке',
16
+ table: { disable: true },
17
+ },
18
+ size: {
19
+ control: 'select',
20
+ options: ['xs', 'sm', 'md', 'lg', 'xl'],
21
+ description: 'Размер спиннера',
22
+ },
23
+ thickness: {
24
+ control: 'number',
25
+ description: 'Толщина линии спиннера (в px)',
26
+ },
27
+ },
28
+ args: {
29
+ loading: true,
30
+ backdrop: false,
31
+ size: 'md',
32
+ thickness: 2,
33
+ },
34
+ }
35
+
36
+ export default meta
37
+ type Story = StoryObj<typeof AppLoader>
38
+
39
+ export const GlobalLoader: Story = {
40
+ render: args => ({
41
+ components: { AppLoader },
42
+ setup() {
43
+ return { args }
44
+ },
45
+ template: `
46
+ <div style="position: relative; height: 300px;">
47
+ <app-loader v-bind="args" />
48
+
49
+ <h2>Контент страницы</h2>
50
+ </div>
51
+ `,
52
+ }),
53
+ args: {
54
+ loading: true,
55
+ backdrop: true,
56
+ size: 'lg',
57
+ },
58
+ }
59
+
60
+ export const Size: Story = {
61
+ render: () => ({
62
+ components: { AppLoader },
63
+ template: `
64
+ <div style="display: flex; flex-wrap: wrap; gap: 32px; padding: 24px; background: white;">
65
+ <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
66
+ <app-loader :loading="true" size="xs" />
67
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">xs</div>
68
+ </div>
69
+ <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
70
+ <app-loader :loading="true" size="sm" />
71
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">sm</div>
72
+ </div>
73
+ <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
74
+ <app-loader :loading="true" size="md" />
75
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">md</div>
76
+ </div>
77
+ <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
78
+ <app-loader :loading="true" size="lg" />
79
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">lg</div>
80
+ </div>
81
+ <div style="text-align: center; width: 100px; height: 100px; position: relative; border: 1px solid #eee; border-radius: 8px;">
82
+ <app-loader :loading="true" size="xl" />
83
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">xl</div>
84
+ </div>
85
+ </div>
86
+ `,
87
+ }),
88
+ }
89
+
90
+ export const Thickness: Story = {
91
+ render: () => ({
92
+ components: { AppLoader },
93
+ template: `
94
+ <div style="display: flex; flex-wrap: wrap; gap: 32px; padding: 24px; background: white;">
95
+ <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
96
+ <app-loader :loading="true" size="lg" :thickness="1" />
97
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=1</div>
98
+ </div>
99
+ <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
100
+ <app-loader :loading="true" size="lg" :thickness="2" />
101
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=2</div>
102
+ </div>
103
+ <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
104
+ <app-loader :loading="true" size="lg" :thickness="3" />
105
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=3</div>
106
+ </div>
107
+ <div style="text-align: center; width: 120px; height: 120px; position: relative; border: 1px solid #eee; border-radius: 8px;">
108
+ <app-loader :loading="true" size="lg" :thickness="5" />
109
+ <div style="margin-top: 8px; font-size: 12px; color: #666;">thickness=5</div>
110
+ </div>
111
+ </div>
112
+ `,
113
+ }),
114
+ }
@@ -1,159 +1,159 @@
1
- <template>
2
- <q-select
3
- ref="select"
4
- v-model="selected"
5
- :data-test="dataTest"
6
- :options="filteredOptions"
7
- :option-value="optionValue"
8
- :option-label="optionLabel"
9
- emit-value
10
- map-options
11
- :disable="isDisabled"
12
- :multiple="multiple"
13
- outlined
14
- stack-label
15
- :use-input="search"
16
- :class="[$style.select]"
17
- :label="label"
18
- input-debounce="100"
19
- :popup-content-class="$style['app-select__menu']"
20
- :clearable="clearable"
21
- rounded
22
- autocomplete=""
23
- @filter="filterFn"
24
- >
25
- <template v-if="multiple" #selected-item="scope">
26
- <q-chip
27
- v-if="scope.opt"
28
- removable
29
- class="q-ma-none"
30
- dense
31
- :tabindex="scope.tabindex"
32
- color="white"
33
- text-color="secondary"
34
- @remove="scope.removeAtIndex(scope.index)"
35
- >
36
- {{ scope.opt[`${optionLabel}`] }}
37
- </q-chip>
38
- </template>
39
- <template #no-option>
40
- <q-item>{{ emptyText }}</q-item>
41
- </template>
42
- <q-item v-if="!lcText && type()">{{ placeholder }}</q-item>
43
- </q-select>
44
- </template>
45
- <script setup lang="ts">
46
- import { computed, defineEmits, defineProps, ref, Ref } from 'vue'
47
-
48
- import { QSelect } from 'quasar'
49
-
50
- type Option = Record<string, any>
51
-
52
- interface AppQSelectProps {
53
- modelValue: any
54
- options: Option[]
55
- placeholder: string
56
- emptyText: string
57
- optionLabel?: string
58
- optionValue?: string
59
- label?: string
60
- multiple?: boolean
61
- borderColor: string
62
- isDisabled?: boolean
63
- clearable?: boolean
64
- search?: boolean
65
- dataTest?: string
66
- }
67
-
68
- const props = defineProps<AppQSelectProps>()
69
- const select = ref({})
70
- const emit = defineEmits(['update:modelValue'])
71
- const selected = computed({
72
- get() {
73
- return props.modelValue
74
- },
75
- set(value) {
76
- emit('update:modelValue', value)
77
- },
78
- })
79
-
80
- const type = () => {
81
- if (Array.isArray(selected.value) && !selected.value.length) return true
82
- return typeof selected.value === 'string' && !selected.value
83
- }
84
-
85
- const lcText: Ref<string> = ref('')
86
- const filteredOptions = computed(() => {
87
- return props.options.filter(x => x[props?.optionLabel || 'label'].toLowerCase().includes(lcText.value))
88
- })
89
-
90
- function filterFn(val: string, update: (arg0: () => void) => void) {
91
- update(() => {
92
- lcText.value = val.toLowerCase()
93
- })
94
- }
95
- </script>
96
- <style module lang="scss">
97
- .wrap {
98
- position: relative;
99
-
100
- &:global(.--option-tree) {
101
- cursor: pointer;
102
- }
103
- }
104
-
105
- .select {
106
- &:global(.q-field--outlined.q-field--rounded .q-field__control) {
107
- border-radius: 14px;
108
- }
109
- &:global(.q-field--outlined .q-field__control:before) {
110
- border-color: v-bind(borderColor);
111
- }
112
- &:global(.q-select .q-field__input) {
113
- padding: 0 6px;
114
- }
115
- //&:global(.q-field--filled .q-field__control) {
116
- // //color: red;
117
- //}
118
- //&:global(.q-field--filled.q-field--focused .q-field__control) {
119
- //}
120
- //&:global(.q-field--filled .q-field__control:after) {
121
- // left: 8px;
122
- // right: 8px;
123
- //}
124
- &:global(.q-field--outlined .q-item) {
125
- color: #1d1d1d;
126
- position: absolute;
127
- padding: 0 4px;
128
- top: 18px;
129
- left: 0;
130
- }
131
- }
132
-
133
- .append-wrapper {
134
- display: flex;
135
- align-items: center;
136
- column-gap: 4px;
137
- }
138
-
139
- .menu-wrap {
140
- padding: 8px;
141
- }
142
-
143
- .search-wrapper {
144
- position: sticky;
145
- top: 0;
146
- padding: 4px;
147
- background: var(--main-bg);
148
- z-index: 1;
149
- }
150
- .app-select__menu {
151
- border-radius: 14px;
152
- .q-item__label {
153
- word-break: break-word;
154
- }
155
- &:global(.q-menu) {
156
- max-height: 200px !important;
157
- }
158
- }
159
- </style>
1
+ <template>
2
+ <q-select
3
+ ref="select"
4
+ v-model="selected"
5
+ :data-test="dataTest"
6
+ :options="filteredOptions"
7
+ :option-value="optionValue"
8
+ :option-label="optionLabel"
9
+ emit-value
10
+ map-options
11
+ :disable="isDisabled"
12
+ :multiple="multiple"
13
+ outlined
14
+ stack-label
15
+ :use-input="search"
16
+ :class="[$style.select]"
17
+ :label="label"
18
+ input-debounce="100"
19
+ :popup-content-class="$style['app-select__menu']"
20
+ :clearable="clearable"
21
+ rounded
22
+ autocomplete=""
23
+ @filter="filterFn"
24
+ >
25
+ <template v-if="multiple" #selected-item="scope">
26
+ <q-chip
27
+ v-if="scope.opt"
28
+ removable
29
+ class="q-ma-none"
30
+ dense
31
+ :tabindex="scope.tabindex"
32
+ color="white"
33
+ text-color="secondary"
34
+ @remove="scope.removeAtIndex(scope.index)"
35
+ >
36
+ {{ scope.opt[`${optionLabel}`] }}
37
+ </q-chip>
38
+ </template>
39
+ <template #no-option>
40
+ <q-item>{{ emptyText }}</q-item>
41
+ </template>
42
+ <q-item v-if="!lcText && type()">{{ placeholder }}</q-item>
43
+ </q-select>
44
+ </template>
45
+ <script setup lang="ts">
46
+ import { computed, defineEmits, defineProps, ref, Ref } from 'vue'
47
+
48
+ import { QSelect } from 'quasar'
49
+
50
+ type Option = Record<string, any>
51
+
52
+ interface AppQSelectProps {
53
+ modelValue: any
54
+ options: Option[]
55
+ placeholder: string
56
+ emptyText: string
57
+ optionLabel?: string
58
+ optionValue?: string
59
+ label?: string
60
+ multiple?: boolean
61
+ borderColor: string
62
+ isDisabled?: boolean
63
+ clearable?: boolean
64
+ search?: boolean
65
+ dataTest?: string
66
+ }
67
+
68
+ const props = defineProps<AppQSelectProps>()
69
+ const select = ref({})
70
+ const emit = defineEmits(['update:modelValue'])
71
+ const selected = computed({
72
+ get() {
73
+ return props.modelValue
74
+ },
75
+ set(value) {
76
+ emit('update:modelValue', value)
77
+ },
78
+ })
79
+
80
+ const type = () => {
81
+ if (Array.isArray(selected.value) && !selected.value.length) return true
82
+ return typeof selected.value === 'string' && !selected.value
83
+ }
84
+
85
+ const lcText: Ref<string> = ref('')
86
+ const filteredOptions = computed(() => {
87
+ return props.options.filter(x => x[props?.optionLabel || 'label'].toLowerCase().includes(lcText.value))
88
+ })
89
+
90
+ function filterFn(val: string, update: (arg0: () => void) => void) {
91
+ update(() => {
92
+ lcText.value = val.toLowerCase()
93
+ })
94
+ }
95
+ </script>
96
+ <style module lang="scss">
97
+ .wrap {
98
+ position: relative;
99
+
100
+ &:global(.--option-tree) {
101
+ cursor: pointer;
102
+ }
103
+ }
104
+
105
+ .select {
106
+ &:global(.q-field--outlined.q-field--rounded .q-field__control) {
107
+ border-radius: 14px;
108
+ }
109
+ &:global(.q-field--outlined .q-field__control:before) {
110
+ border-color: v-bind(borderColor);
111
+ }
112
+ &:global(.q-select .q-field__input) {
113
+ padding: 0 6px;
114
+ }
115
+ //&:global(.q-field--filled .q-field__control) {
116
+ // //color: red;
117
+ //}
118
+ //&:global(.q-field--filled.q-field--focused .q-field__control) {
119
+ //}
120
+ //&:global(.q-field--filled .q-field__control:after) {
121
+ // left: 8px;
122
+ // right: 8px;
123
+ //}
124
+ &:global(.q-field--outlined .q-item) {
125
+ color: #1d1d1d;
126
+ position: absolute;
127
+ padding: 0 4px;
128
+ top: 18px;
129
+ left: 0;
130
+ }
131
+ }
132
+
133
+ .append-wrapper {
134
+ display: flex;
135
+ align-items: center;
136
+ column-gap: 4px;
137
+ }
138
+
139
+ .menu-wrap {
140
+ padding: 8px;
141
+ }
142
+
143
+ .search-wrapper {
144
+ position: sticky;
145
+ top: 0;
146
+ padding: 4px;
147
+ background: var(--main-bg);
148
+ z-index: 1;
149
+ }
150
+ .app-select__menu {
151
+ border-radius: 14px;
152
+ .q-item__label {
153
+ word-break: break-word;
154
+ }
155
+ &:global(.q-menu) {
156
+ max-height: 200px !important;
157
+ }
158
+ }
159
+ </style>