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.
- package/dist/index.css +1 -1
- package/dist/shared-ritm.es.js +13 -13
- package/dist/shared-ritm.umd.js +3 -3
- package/package.json +70 -70
- package/src/App.vue +2461 -2461
- package/src/api/services/AuthService.ts +67 -67
- package/src/api/services/ControlsService.ts +96 -96
- package/src/api/services/EquipmentService.ts +52 -52
- package/src/api/services/MetricsService.ts +143 -143
- package/src/api/services/RepairsService.ts +111 -111
- package/src/api/services/UserIssueService.ts +32 -32
- package/src/api/services/UserService.ts +129 -129
- package/src/api/services/VideoService.ts +118 -118
- package/src/api/settings/ApiService.ts +4 -2
- package/src/api/types/Api_Auth.ts +121 -121
- package/src/api/types/Api_Equipment.ts +13 -13
- package/src/api/types/Api_Metrics.ts +51 -51
- package/src/api/types/Api_Repairs.ts +187 -187
- package/src/api/types/Api_Search.ts +81 -81
- package/src/api/types/Api_Tasks.ts +376 -376
- package/src/api/types/Api_User.ts +157 -157
- package/src/api/types/Api_User_Issue.ts +36 -36
- package/src/api/types/Api_Video.ts +244 -244
- package/src/common/app-button/Button.stories.ts +369 -369
- package/src/common/app-checkbox/AppCheckbox.vue +31 -31
- package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
- package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
- package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
- package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
- package/src/common/app-dialogs/Confirm.stories.ts +93 -93
- package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
- package/src/common/app-file/File.stories.ts +104 -104
- package/src/common/app-icon/AppIcon.vue +110 -110
- package/src/common/app-icon/Icon.stories.ts +91 -91
- package/src/common/app-input/Input.stories.ts +160 -160
- package/src/common/app-input-new/AppInputNew.vue +181 -181
- package/src/common/app-input-new/InputNew.stories.ts +240 -240
- package/src/common/app-input-search/InputSearch.stories.ts +149 -149
- package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
- package/src/common/app-loader/Loader.stories.ts +114 -114
- package/src/common/app-select/AppSelect.vue +159 -159
- package/src/common/app-select/Select.stories.ts +155 -155
- package/src/common/app-sidebar/AppSidebar.vue +174 -174
- package/src/common/app-table/AppTable.vue +313 -313
- package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
- package/src/common/app-table/components/ModalSelect.vue +302 -302
- package/src/common/app-table/components/TableModal.vue +367 -367
- package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
- package/src/common/app-table/controllers/useTableModel.ts +97 -97
- package/src/common/app-toggle/AppToggle.vue +12 -12
- package/src/common/app-toggle/Toggle.stories.ts +245 -245
- package/src/common/app-wrapper/AppWrapper.vue +31 -31
- package/src/configs/storybook.ts +14 -14
- package/src/icons/sidebar/user-requests-icon.vue +23 -23
- package/src/index.ts +134 -134
- package/src/shared/styles/general.css +140 -140
- package/src/styles/variables.sass +12 -12
- package/src/utils/files.ts +38 -38
- package/src/utils/helpers.ts +59 -59
- package/dist/types/api/services/PhotoService.d.ts +0 -40
- package/dist/types/stories/Button.stories.d.ts +0 -13
- package/dist/types/stories/Checkbox.stories.d.ts +0 -7
- package/dist/types/stories/Confirm.stories.d.ts +0 -8
- package/dist/types/stories/DatePicker.stories.d.ts +0 -8
- package/dist/types/stories/Dropdown.stories.d.ts +0 -8
- package/dist/types/stories/File.stories.d.ts +0 -8
- package/dist/types/stories/Icon.stories.d.ts +0 -7
- package/dist/types/stories/Input.stories.d.ts +0 -11
- package/dist/types/stories/InputNew.stories.d.ts +0 -12
- package/dist/types/stories/InputSearch.stories.d.ts +0 -10
- package/dist/types/stories/Loader.stories.d.ts +0 -8
- package/dist/types/stories/Select.stories.d.ts +0 -7
- package/dist/types/stories/Toggle.stories.d.ts +0 -8
|
@@ -1,66 +1,66 @@
|
|
|
1
|
-
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
-
import DatePicker from '@/common/app-date-picker/AppDatePicker.vue'
|
|
3
|
-
|
|
4
|
-
const meta: Meta<typeof DatePicker> = {
|
|
5
|
-
title: 'Components/DatePicker',
|
|
6
|
-
component: DatePicker,
|
|
7
|
-
tags: ['autodocs'],
|
|
8
|
-
argTypes: {
|
|
9
|
-
label: {
|
|
10
|
-
control: 'text',
|
|
11
|
-
},
|
|
12
|
-
modelValue: {
|
|
13
|
-
control: 'text',
|
|
14
|
-
description: 'Выбранная дата в формате YYYY-MM-DD.',
|
|
15
|
-
},
|
|
16
|
-
disabled: {
|
|
17
|
-
control: 'boolean',
|
|
18
|
-
},
|
|
19
|
-
disableRuleDates: {
|
|
20
|
-
control: 'text',
|
|
21
|
-
description: 'Минимальная дата в формате YYYY-MM-DD. Если не указана — ограничение "не раньше сегодня".',
|
|
22
|
-
},
|
|
23
|
-
},
|
|
24
|
-
args: {
|
|
25
|
-
label: 'Дата начала',
|
|
26
|
-
modelValue: '',
|
|
27
|
-
disabled: false,
|
|
28
|
-
disableRuleDates: '',
|
|
29
|
-
},
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export default meta
|
|
33
|
-
|
|
34
|
-
type Story = StoryObj<typeof DatePicker>
|
|
35
|
-
|
|
36
|
-
export const Default: Story = {}
|
|
37
|
-
|
|
38
|
-
export const States: Story = {
|
|
39
|
-
render: () => ({
|
|
40
|
-
components: { DatePicker },
|
|
41
|
-
template: `
|
|
42
|
-
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
43
|
-
<div>
|
|
44
|
-
<DatePicker v-model="date1" label="Не ранее сегодня" />
|
|
45
|
-
</div>
|
|
46
|
-
<div>
|
|
47
|
-
<DatePicker v-model="date2" label="С 01.01.2026" disable-rule-dates="2026-01-01" />
|
|
48
|
-
</div>
|
|
49
|
-
<div>
|
|
50
|
-
<DatePicker v-model="disabledDate" label="Отключён" :disabled="true" />
|
|
51
|
-
</div>
|
|
52
|
-
<div>
|
|
53
|
-
<DatePicker v-model="selectedDate" label="С датой" />
|
|
54
|
-
</div>
|
|
55
|
-
</div>
|
|
56
|
-
`,
|
|
57
|
-
data() {
|
|
58
|
-
return {
|
|
59
|
-
date1: '',
|
|
60
|
-
date2: '',
|
|
61
|
-
disabledDate: '',
|
|
62
|
-
selectedDate: '2025-12-25',
|
|
63
|
-
}
|
|
64
|
-
},
|
|
65
|
-
}),
|
|
66
|
-
}
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
+
import DatePicker from '@/common/app-date-picker/AppDatePicker.vue'
|
|
3
|
+
|
|
4
|
+
const meta: Meta<typeof DatePicker> = {
|
|
5
|
+
title: 'Components/DatePicker',
|
|
6
|
+
component: DatePicker,
|
|
7
|
+
tags: ['autodocs'],
|
|
8
|
+
argTypes: {
|
|
9
|
+
label: {
|
|
10
|
+
control: 'text',
|
|
11
|
+
},
|
|
12
|
+
modelValue: {
|
|
13
|
+
control: 'text',
|
|
14
|
+
description: 'Выбранная дата в формате YYYY-MM-DD.',
|
|
15
|
+
},
|
|
16
|
+
disabled: {
|
|
17
|
+
control: 'boolean',
|
|
18
|
+
},
|
|
19
|
+
disableRuleDates: {
|
|
20
|
+
control: 'text',
|
|
21
|
+
description: 'Минимальная дата в формате YYYY-MM-DD. Если не указана — ограничение "не раньше сегодня".',
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
args: {
|
|
25
|
+
label: 'Дата начала',
|
|
26
|
+
modelValue: '',
|
|
27
|
+
disabled: false,
|
|
28
|
+
disableRuleDates: '',
|
|
29
|
+
},
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export default meta
|
|
33
|
+
|
|
34
|
+
type Story = StoryObj<typeof DatePicker>
|
|
35
|
+
|
|
36
|
+
export const Default: Story = {}
|
|
37
|
+
|
|
38
|
+
export const States: Story = {
|
|
39
|
+
render: () => ({
|
|
40
|
+
components: { DatePicker },
|
|
41
|
+
template: `
|
|
42
|
+
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
43
|
+
<div>
|
|
44
|
+
<DatePicker v-model="date1" label="Не ранее сегодня" />
|
|
45
|
+
</div>
|
|
46
|
+
<div>
|
|
47
|
+
<DatePicker v-model="date2" label="С 01.01.2026" disable-rule-dates="2026-01-01" />
|
|
48
|
+
</div>
|
|
49
|
+
<div>
|
|
50
|
+
<DatePicker v-model="disabledDate" label="Отключён" :disabled="true" />
|
|
51
|
+
</div>
|
|
52
|
+
<div>
|
|
53
|
+
<DatePicker v-model="selectedDate" label="С датой" />
|
|
54
|
+
</div>
|
|
55
|
+
</div>
|
|
56
|
+
`,
|
|
57
|
+
data() {
|
|
58
|
+
return {
|
|
59
|
+
date1: '',
|
|
60
|
+
date2: '',
|
|
61
|
+
disabledDate: '',
|
|
62
|
+
selectedDate: '2025-12-25',
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
}),
|
|
66
|
+
}
|
|
@@ -1,145 +1,145 @@
|
|
|
1
|
-
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
-
import AppDatepicker from './AppDatepicker.vue'
|
|
3
|
-
|
|
4
|
-
const meta: Meta<typeof AppDatepicker> = {
|
|
5
|
-
title: 'Components/AppDatepicker',
|
|
6
|
-
component: AppDatepicker,
|
|
7
|
-
tags: ['autodocs'],
|
|
8
|
-
argTypes: {
|
|
9
|
-
label: {
|
|
10
|
-
control: 'text',
|
|
11
|
-
description: 'Подпись над полем.',
|
|
12
|
-
},
|
|
13
|
-
modelValue: {
|
|
14
|
-
control: 'text',
|
|
15
|
-
description: 'Выбранная дата в формате DD.MM.YYYY (или с временем).',
|
|
16
|
-
},
|
|
17
|
-
required: {
|
|
18
|
-
control: 'boolean',
|
|
19
|
-
description: 'Показывает звёздочку и включает валидацию при закрытии календаря.',
|
|
20
|
-
},
|
|
21
|
-
rules: {
|
|
22
|
-
table: { disable: true },
|
|
23
|
-
description: 'Массив функций валидации.',
|
|
24
|
-
},
|
|
25
|
-
|
|
26
|
-
time: {
|
|
27
|
-
control: 'boolean',
|
|
28
|
-
description: 'Включить выбор времени (в дополнение к дате).',
|
|
29
|
-
},
|
|
30
|
-
noPastDates: {
|
|
31
|
-
control: 'boolean',
|
|
32
|
-
description: 'Запретить выбор дат в прошлом (относительно сегодня).',
|
|
33
|
-
},
|
|
34
|
-
disableRuleDates: {
|
|
35
|
-
control: 'object',
|
|
36
|
-
description: 'Минимальная дата (строка "YYYY-MM-DD") или диапазон [min, max].',
|
|
37
|
-
},
|
|
38
|
-
|
|
39
|
-
disabled: {
|
|
40
|
-
control: 'boolean',
|
|
41
|
-
description: 'Отключает поле и календарь.',
|
|
42
|
-
},
|
|
43
|
-
|
|
44
|
-
timeFormat: {
|
|
45
|
-
control: 'text',
|
|
46
|
-
description: 'Формат отображения времени (например, "HH:mm" или "HH:mm:ss").',
|
|
47
|
-
},
|
|
48
|
-
},
|
|
49
|
-
args: {
|
|
50
|
-
label: 'Дата события',
|
|
51
|
-
modelValue: '',
|
|
52
|
-
required: false,
|
|
53
|
-
time: false,
|
|
54
|
-
noPastDates: false,
|
|
55
|
-
disableRuleDates: undefined,
|
|
56
|
-
disabled: false,
|
|
57
|
-
timeFormat: 'HH:mm',
|
|
58
|
-
},
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export default meta
|
|
62
|
-
|
|
63
|
-
type Story = StoryObj<typeof AppDatepicker>
|
|
64
|
-
|
|
65
|
-
export const Default: Story = {}
|
|
66
|
-
|
|
67
|
-
export const DateTimeModes: Story = {
|
|
68
|
-
render: () => ({
|
|
69
|
-
components: { AppDatepicker },
|
|
70
|
-
template: `
|
|
71
|
-
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
72
|
-
<AppDatepicker v-model="dateOnly" label="Дата" />
|
|
73
|
-
<AppDatepicker v-model="dateTime" label="Дата и время" :time="true" />
|
|
74
|
-
</div>
|
|
75
|
-
`,
|
|
76
|
-
data() {
|
|
77
|
-
return {
|
|
78
|
-
dateOnly: '15.12.2025',
|
|
79
|
-
dateTime: '15.12.2025 14:30',
|
|
80
|
-
}
|
|
81
|
-
},
|
|
82
|
-
}),
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
export const DateRestrictions: Story = {
|
|
86
|
-
render: () => ({
|
|
87
|
-
components: { AppDatepicker },
|
|
88
|
-
template: `
|
|
89
|
-
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
90
|
-
<AppDatepicker v-model="date1" label="С сегодняшнего дня" :no-past-dates="true" />
|
|
91
|
-
<AppDatepicker
|
|
92
|
-
v-model="date2"
|
|
93
|
-
label="Только 2026"
|
|
94
|
-
:disable-rule-dates="['2026-01-01', '2026-12-31']"
|
|
95
|
-
/>
|
|
96
|
-
<AppDatepicker v-model="date3" label="С июня 2025" disable-rule-dates="2025-05-31" />
|
|
97
|
-
</div>
|
|
98
|
-
`,
|
|
99
|
-
data() {
|
|
100
|
-
return {
|
|
101
|
-
date1: '',
|
|
102
|
-
date2: '',
|
|
103
|
-
date3: '',
|
|
104
|
-
}
|
|
105
|
-
},
|
|
106
|
-
}),
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
export const States: Story = {
|
|
110
|
-
render: () => ({
|
|
111
|
-
components: { AppDatepicker },
|
|
112
|
-
template: `
|
|
113
|
-
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
114
|
-
<AppDatepicker v-model="normal" label="Активное поле" />
|
|
115
|
-
<AppDatepicker v-model="disabledVal" label="Отключено" :disabled="true" />
|
|
116
|
-
<AppDatepicker v-model="empty" label="Обязательное" required />
|
|
117
|
-
</div>
|
|
118
|
-
`,
|
|
119
|
-
data() {
|
|
120
|
-
return {
|
|
121
|
-
normal: '10.11.2025',
|
|
122
|
-
disabledVal: '20.11.2025',
|
|
123
|
-
empty: '',
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
}),
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
export const TimeFormat: Story = {
|
|
130
|
-
render: () => ({
|
|
131
|
-
components: { AppDatepicker },
|
|
132
|
-
template: `
|
|
133
|
-
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
134
|
-
<AppDatepicker v-model="time1" label="Стандартный формат" :time="true" />
|
|
135
|
-
<AppDatepicker v-model="time2" label="С секундами" :time="true" time-format="HH:mm:ss" />
|
|
136
|
-
</div>
|
|
137
|
-
`,
|
|
138
|
-
data() {
|
|
139
|
-
return {
|
|
140
|
-
time1: '25.11.2025 09:45',
|
|
141
|
-
time2: '25.11.2025 16:30:22',
|
|
142
|
-
}
|
|
143
|
-
},
|
|
144
|
-
}),
|
|
145
|
-
}
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/vue3'
|
|
2
|
+
import AppDatepicker from './AppDatepicker.vue'
|
|
3
|
+
|
|
4
|
+
const meta: Meta<typeof AppDatepicker> = {
|
|
5
|
+
title: 'Components/AppDatepicker',
|
|
6
|
+
component: AppDatepicker,
|
|
7
|
+
tags: ['autodocs'],
|
|
8
|
+
argTypes: {
|
|
9
|
+
label: {
|
|
10
|
+
control: 'text',
|
|
11
|
+
description: 'Подпись над полем.',
|
|
12
|
+
},
|
|
13
|
+
modelValue: {
|
|
14
|
+
control: 'text',
|
|
15
|
+
description: 'Выбранная дата в формате DD.MM.YYYY (или с временем).',
|
|
16
|
+
},
|
|
17
|
+
required: {
|
|
18
|
+
control: 'boolean',
|
|
19
|
+
description: 'Показывает звёздочку и включает валидацию при закрытии календаря.',
|
|
20
|
+
},
|
|
21
|
+
rules: {
|
|
22
|
+
table: { disable: true },
|
|
23
|
+
description: 'Массив функций валидации.',
|
|
24
|
+
},
|
|
25
|
+
|
|
26
|
+
time: {
|
|
27
|
+
control: 'boolean',
|
|
28
|
+
description: 'Включить выбор времени (в дополнение к дате).',
|
|
29
|
+
},
|
|
30
|
+
noPastDates: {
|
|
31
|
+
control: 'boolean',
|
|
32
|
+
description: 'Запретить выбор дат в прошлом (относительно сегодня).',
|
|
33
|
+
},
|
|
34
|
+
disableRuleDates: {
|
|
35
|
+
control: 'object',
|
|
36
|
+
description: 'Минимальная дата (строка "YYYY-MM-DD") или диапазон [min, max].',
|
|
37
|
+
},
|
|
38
|
+
|
|
39
|
+
disabled: {
|
|
40
|
+
control: 'boolean',
|
|
41
|
+
description: 'Отключает поле и календарь.',
|
|
42
|
+
},
|
|
43
|
+
|
|
44
|
+
timeFormat: {
|
|
45
|
+
control: 'text',
|
|
46
|
+
description: 'Формат отображения времени (например, "HH:mm" или "HH:mm:ss").',
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
args: {
|
|
50
|
+
label: 'Дата события',
|
|
51
|
+
modelValue: '',
|
|
52
|
+
required: false,
|
|
53
|
+
time: false,
|
|
54
|
+
noPastDates: false,
|
|
55
|
+
disableRuleDates: undefined,
|
|
56
|
+
disabled: false,
|
|
57
|
+
timeFormat: 'HH:mm',
|
|
58
|
+
},
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export default meta
|
|
62
|
+
|
|
63
|
+
type Story = StoryObj<typeof AppDatepicker>
|
|
64
|
+
|
|
65
|
+
export const Default: Story = {}
|
|
66
|
+
|
|
67
|
+
export const DateTimeModes: Story = {
|
|
68
|
+
render: () => ({
|
|
69
|
+
components: { AppDatepicker },
|
|
70
|
+
template: `
|
|
71
|
+
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
72
|
+
<AppDatepicker v-model="dateOnly" label="Дата" />
|
|
73
|
+
<AppDatepicker v-model="dateTime" label="Дата и время" :time="true" />
|
|
74
|
+
</div>
|
|
75
|
+
`,
|
|
76
|
+
data() {
|
|
77
|
+
return {
|
|
78
|
+
dateOnly: '15.12.2025',
|
|
79
|
+
dateTime: '15.12.2025 14:30',
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
}),
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export const DateRestrictions: Story = {
|
|
86
|
+
render: () => ({
|
|
87
|
+
components: { AppDatepicker },
|
|
88
|
+
template: `
|
|
89
|
+
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
90
|
+
<AppDatepicker v-model="date1" label="С сегодняшнего дня" :no-past-dates="true" />
|
|
91
|
+
<AppDatepicker
|
|
92
|
+
v-model="date2"
|
|
93
|
+
label="Только 2026"
|
|
94
|
+
:disable-rule-dates="['2026-01-01', '2026-12-31']"
|
|
95
|
+
/>
|
|
96
|
+
<AppDatepicker v-model="date3" label="С июня 2025" disable-rule-dates="2025-05-31" />
|
|
97
|
+
</div>
|
|
98
|
+
`,
|
|
99
|
+
data() {
|
|
100
|
+
return {
|
|
101
|
+
date1: '',
|
|
102
|
+
date2: '',
|
|
103
|
+
date3: '',
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
}),
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
export const States: Story = {
|
|
110
|
+
render: () => ({
|
|
111
|
+
components: { AppDatepicker },
|
|
112
|
+
template: `
|
|
113
|
+
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
114
|
+
<AppDatepicker v-model="normal" label="Активное поле" />
|
|
115
|
+
<AppDatepicker v-model="disabledVal" label="Отключено" :disabled="true" />
|
|
116
|
+
<AppDatepicker v-model="empty" label="Обязательное" required />
|
|
117
|
+
</div>
|
|
118
|
+
`,
|
|
119
|
+
data() {
|
|
120
|
+
return {
|
|
121
|
+
normal: '10.11.2025',
|
|
122
|
+
disabledVal: '20.11.2025',
|
|
123
|
+
empty: '',
|
|
124
|
+
}
|
|
125
|
+
},
|
|
126
|
+
}),
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export const TimeFormat: Story = {
|
|
130
|
+
render: () => ({
|
|
131
|
+
components: { AppDatepicker },
|
|
132
|
+
template: `
|
|
133
|
+
<div style="display: flex; flex-direction: column; gap: 20px;">
|
|
134
|
+
<AppDatepicker v-model="time1" label="Стандартный формат" :time="true" />
|
|
135
|
+
<AppDatepicker v-model="time2" label="С секундами" :time="true" time-format="HH:mm:ss" />
|
|
136
|
+
</div>
|
|
137
|
+
`,
|
|
138
|
+
data() {
|
|
139
|
+
return {
|
|
140
|
+
time1: '25.11.2025 09:45',
|
|
141
|
+
time2: '25.11.2025 16:30:22',
|
|
142
|
+
}
|
|
143
|
+
},
|
|
144
|
+
}),
|
|
145
|
+
}
|
|
@@ -1,109 +1,109 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<q-dialog ref="dialogRef" persistent transition-show="slide-up" transition-hide="slide-down" :class="$style.dialog">
|
|
3
|
-
<q-card :class="$style.modal">
|
|
4
|
-
<q-card-section :class="$style['modal__content']">
|
|
5
|
-
<div :class="$style['modal__content__header']">
|
|
6
|
-
<safety-icon v-if="type === 'edit'" />
|
|
7
|
-
<remove-icon v-if="type === 'delete'" />
|
|
8
|
-
</div>
|
|
9
|
-
<p>{{ content }}</p>
|
|
10
|
-
</q-card-section>
|
|
11
|
-
<q-card-section :class="$style.footer">
|
|
12
|
-
<app-button
|
|
13
|
-
data-test="confirm-button"
|
|
14
|
-
:class="$style['footer__btn--ok']"
|
|
15
|
-
label="Подтвердить"
|
|
16
|
-
@click="onDialogOK"
|
|
17
|
-
/>
|
|
18
|
-
<app-button
|
|
19
|
-
data-test="close-button"
|
|
20
|
-
:class="$style['footer__btn--cancel']"
|
|
21
|
-
label="Отменить"
|
|
22
|
-
@click="onDialogHide"
|
|
23
|
-
/>
|
|
24
|
-
</q-card-section>
|
|
25
|
-
</q-card>
|
|
26
|
-
</q-dialog>
|
|
27
|
-
</template>
|
|
28
|
-
|
|
29
|
-
<script setup lang="ts">
|
|
30
|
-
import { useDialogPluginComponent } from 'quasar'
|
|
31
|
-
import AppButton from '@/common/app-button/AppButton.vue'
|
|
32
|
-
import SafetyIcon from '@/icons/dialogs/SafetyIcon.vue'
|
|
33
|
-
import RemoveIcon from '@/icons/dialogs/RemoveIcon.vue'
|
|
34
|
-
|
|
35
|
-
const { onDialogHide, onDialogOK, dialogRef } = useDialogPluginComponent()
|
|
36
|
-
|
|
37
|
-
interface Props {
|
|
38
|
-
content: string
|
|
39
|
-
type: 'delete' | 'edit'
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
const props = defineProps<Props>()
|
|
43
|
-
</script>
|
|
44
|
-
|
|
45
|
-
<style lang="scss" module>
|
|
46
|
-
.modal {
|
|
47
|
-
font-family: NunitoSansFont, sans-serif;
|
|
48
|
-
display: flex;
|
|
49
|
-
flex-direction: column;
|
|
50
|
-
width: 400px;
|
|
51
|
-
border-radius: 8px !important;
|
|
52
|
-
justify-content: space-between;
|
|
53
|
-
&__content {
|
|
54
|
-
margin: 0 auto;
|
|
55
|
-
padding: 0;
|
|
56
|
-
flex-grow: 1;
|
|
57
|
-
&__header {
|
|
58
|
-
width: 100%;
|
|
59
|
-
display: flex;
|
|
60
|
-
align-items: center;
|
|
61
|
-
justify-content: center;
|
|
62
|
-
flex-direction: column;
|
|
63
|
-
gap: 16px;
|
|
64
|
-
padding-top: 18px;
|
|
65
|
-
h4 {
|
|
66
|
-
font-size: 24px;
|
|
67
|
-
font-weight: 600;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
p {
|
|
72
|
-
margin: 0;
|
|
73
|
-
font-size: 16px;
|
|
74
|
-
text-align: center;
|
|
75
|
-
padding: 18px;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
.footer {
|
|
80
|
-
display: flex;
|
|
81
|
-
gap: 12px;
|
|
82
|
-
align-items: center;
|
|
83
|
-
justify-content: center;
|
|
84
|
-
border-radius: 0px 0px 2px 2px;
|
|
85
|
-
background: #f4f9fd;
|
|
86
|
-
padding: 18px 12px;
|
|
87
|
-
&__btn--ok,
|
|
88
|
-
&__btn--cancel {
|
|
89
|
-
background-color: #3f8cff;
|
|
90
|
-
border-radius: 4px;
|
|
91
|
-
color: white;
|
|
92
|
-
font-size: 16px;
|
|
93
|
-
font-weight: bold;
|
|
94
|
-
width: 165px;
|
|
95
|
-
height: 48px;
|
|
96
|
-
cursor: pointer;
|
|
97
|
-
span {
|
|
98
|
-
color: white;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
&__btn--cancel {
|
|
102
|
-
background-color: white;
|
|
103
|
-
border: 1px solid #3f8cff;
|
|
104
|
-
span {
|
|
105
|
-
color: #3f8cff;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<q-dialog ref="dialogRef" persistent transition-show="slide-up" transition-hide="slide-down" :class="$style.dialog">
|
|
3
|
+
<q-card :class="$style.modal">
|
|
4
|
+
<q-card-section :class="$style['modal__content']">
|
|
5
|
+
<div :class="$style['modal__content__header']">
|
|
6
|
+
<safety-icon v-if="type === 'edit'" />
|
|
7
|
+
<remove-icon v-if="type === 'delete'" />
|
|
8
|
+
</div>
|
|
9
|
+
<p>{{ content }}</p>
|
|
10
|
+
</q-card-section>
|
|
11
|
+
<q-card-section :class="$style.footer">
|
|
12
|
+
<app-button
|
|
13
|
+
data-test="confirm-button"
|
|
14
|
+
:class="$style['footer__btn--ok']"
|
|
15
|
+
label="Подтвердить"
|
|
16
|
+
@click="onDialogOK"
|
|
17
|
+
/>
|
|
18
|
+
<app-button
|
|
19
|
+
data-test="close-button"
|
|
20
|
+
:class="$style['footer__btn--cancel']"
|
|
21
|
+
label="Отменить"
|
|
22
|
+
@click="onDialogHide"
|
|
23
|
+
/>
|
|
24
|
+
</q-card-section>
|
|
25
|
+
</q-card>
|
|
26
|
+
</q-dialog>
|
|
27
|
+
</template>
|
|
28
|
+
|
|
29
|
+
<script setup lang="ts">
|
|
30
|
+
import { useDialogPluginComponent } from 'quasar'
|
|
31
|
+
import AppButton from '@/common/app-button/AppButton.vue'
|
|
32
|
+
import SafetyIcon from '@/icons/dialogs/SafetyIcon.vue'
|
|
33
|
+
import RemoveIcon from '@/icons/dialogs/RemoveIcon.vue'
|
|
34
|
+
|
|
35
|
+
const { onDialogHide, onDialogOK, dialogRef } = useDialogPluginComponent()
|
|
36
|
+
|
|
37
|
+
interface Props {
|
|
38
|
+
content: string
|
|
39
|
+
type: 'delete' | 'edit'
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const props = defineProps<Props>()
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
<style lang="scss" module>
|
|
46
|
+
.modal {
|
|
47
|
+
font-family: NunitoSansFont, sans-serif;
|
|
48
|
+
display: flex;
|
|
49
|
+
flex-direction: column;
|
|
50
|
+
width: 400px;
|
|
51
|
+
border-radius: 8px !important;
|
|
52
|
+
justify-content: space-between;
|
|
53
|
+
&__content {
|
|
54
|
+
margin: 0 auto;
|
|
55
|
+
padding: 0;
|
|
56
|
+
flex-grow: 1;
|
|
57
|
+
&__header {
|
|
58
|
+
width: 100%;
|
|
59
|
+
display: flex;
|
|
60
|
+
align-items: center;
|
|
61
|
+
justify-content: center;
|
|
62
|
+
flex-direction: column;
|
|
63
|
+
gap: 16px;
|
|
64
|
+
padding-top: 18px;
|
|
65
|
+
h4 {
|
|
66
|
+
font-size: 24px;
|
|
67
|
+
font-weight: 600;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
p {
|
|
72
|
+
margin: 0;
|
|
73
|
+
font-size: 16px;
|
|
74
|
+
text-align: center;
|
|
75
|
+
padding: 18px;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.footer {
|
|
80
|
+
display: flex;
|
|
81
|
+
gap: 12px;
|
|
82
|
+
align-items: center;
|
|
83
|
+
justify-content: center;
|
|
84
|
+
border-radius: 0px 0px 2px 2px;
|
|
85
|
+
background: #f4f9fd;
|
|
86
|
+
padding: 18px 12px;
|
|
87
|
+
&__btn--ok,
|
|
88
|
+
&__btn--cancel {
|
|
89
|
+
background-color: #3f8cff;
|
|
90
|
+
border-radius: 4px;
|
|
91
|
+
color: white;
|
|
92
|
+
font-size: 16px;
|
|
93
|
+
font-weight: bold;
|
|
94
|
+
width: 165px;
|
|
95
|
+
height: 48px;
|
|
96
|
+
cursor: pointer;
|
|
97
|
+
span {
|
|
98
|
+
color: white;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
&__btn--cancel {
|
|
102
|
+
background-color: white;
|
|
103
|
+
border: 1px solid #3f8cff;
|
|
104
|
+
span {
|
|
105
|
+
color: #3f8cff;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
</style>
|