shared-ritm 1.2.80 → 1.2.81
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/README.md +103 -103
- package/dist/index.css +1 -1
- package/dist/shared-ritm.es.js +9409 -8849
- package/dist/shared-ritm.umd.js +520 -520
- package/dist/types/api/services/UserService.d.ts +10 -1
- package/dist/types/api/types/Api_Service.d.ts +1 -1
- package/dist/types/api/types/Api_User.d.ts +11 -0
- package/dist/types/common/app-table/controllers/useTableModel.d.ts +1 -1
- package/dist/types/index.d.ts +41 -40
- package/package.json +64 -64
- package/src/api/services/PhotoService.ts +137 -137
- package/src/api/services/RepairsService.ts +119 -119
- package/src/api/services/UserService.ts +32 -19
- package/src/api/types/Api_Controls.ts +72 -72
- package/src/api/types/Api_Files.ts +1 -1
- package/src/api/types/Api_Instruments.ts +98 -98
- package/src/api/types/Api_Projects.ts +55 -55
- package/src/api/types/Api_Repairs.ts +115 -115
- package/src/api/types/Api_Service.ts +1 -1
- package/src/api/types/Api_User.ts +57 -44
- package/src/common/app-checkbox/AppCheckbox.vue +26 -26
- package/src/common/app-datepicker/AppDatepicker.vue +165 -165
- package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
- package/src/common/app-dropdown/AppDropdown.vue +31 -31
- package/src/common/app-input/AppInput.vue +148 -148
- package/src/common/app-input-new/AppInputNew.vue +152 -152
- package/src/common/app-select/AppSelect.vue +157 -157
- package/src/common/app-sheet/AppSheet.vue +120 -120
- package/src/common/app-sheet-new/AppSheetNew.vue +255 -0
- package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
- package/src/common/app-table/AppTable.vue +301 -297
- package/src/common/app-table/AppTableLayout.vue +126 -111
- package/src/common/app-table/components/ModalSelect.vue +270 -270
- package/src/common/app-table/components/TableModal.vue +329 -329
- package/src/common/app-table/components/TablePagination.vue +152 -152
- package/src/common/app-table/components/TableSearch.vue +76 -76
- package/src/common/app-table/controllers/useBaseTable.ts +42 -42
- package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
- package/src/common/app-table/controllers/useTableModel.ts +93 -93
- package/src/common/app-toggle/AppToggle.vue +24 -24
- package/src/common/app-wrapper/AppWrapper.vue +28 -28
- package/src/icons/components/table-filter-icon.vue +30 -30
- package/src/icons/dialogs/RemoveIcon.vue +12 -12
- package/src/icons/dialogs/SafetyIcon.vue +12 -12
- package/src/icons/task/attention-icon.vue +13 -13
- package/src/icons/task/clock-icon.vue +10 -10
- package/src/icons/task/delete-icon.vue +10 -10
- package/src/icons/task/fire-icon.vue +16 -16
- package/src/index.ts +41 -39
- package/src/main.ts +28 -28
- package/src/shared/styles/general.css +125 -125
- package/src/styles/variables.sass +12 -12
- package/src/utils/confirm.ts +12 -12
- package/src/utils/helpers.ts +58 -58
- package/src/utils/notification.ts +9 -9
- package/dist/types/api/types/Api_Users.d.ts +0 -43
|
@@ -1,165 +1,165 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="datepicker">
|
|
3
|
-
<app-input-new
|
|
4
|
-
v-model="model"
|
|
5
|
-
readonly
|
|
6
|
-
input-class="cursor-pointer"
|
|
7
|
-
:label="label"
|
|
8
|
-
:required="required"
|
|
9
|
-
:rules="rules"
|
|
10
|
-
:error="error"
|
|
11
|
-
:disable="disabled"
|
|
12
|
-
placeholder="Выберите дату"
|
|
13
|
-
>
|
|
14
|
-
<q-popup-proxy v-if="!disabled" class="datepicker__wrapper" @update:model-value="updateError">
|
|
15
|
-
<q-date
|
|
16
|
-
v-model="model"
|
|
17
|
-
:mask="`DD.MM.YYYY ${timeFormat}`"
|
|
18
|
-
:options="disablePastDates"
|
|
19
|
-
@update:model-value="error = false"
|
|
20
|
-
/>
|
|
21
|
-
<q-time
|
|
22
|
-
v-if="time"
|
|
23
|
-
v-model="model"
|
|
24
|
-
:mask="`DD.MM.YYYY ${timeFormat}`"
|
|
25
|
-
format24h
|
|
26
|
-
:hour-options="hourOptions()"
|
|
27
|
-
:minute-options="minuteOptions()"
|
|
28
|
-
/>
|
|
29
|
-
</q-popup-proxy>
|
|
30
|
-
<template #append>
|
|
31
|
-
<q-icon name="event" class="cursor-pointer"></q-icon>
|
|
32
|
-
</template>
|
|
33
|
-
</app-input-new>
|
|
34
|
-
</div>
|
|
35
|
-
</template>
|
|
36
|
-
|
|
37
|
-
<script setup lang="ts">
|
|
38
|
-
import AppInputNew from '@/common/app-input-new/AppInputNew.vue'
|
|
39
|
-
import { ref, withDefaults, defineEmits, defineProps, defineModel } from 'vue'
|
|
40
|
-
|
|
41
|
-
interface Props {
|
|
42
|
-
label: string
|
|
43
|
-
modelValue?: string
|
|
44
|
-
rules?: ((val?: string | number | null) => boolean | string)[]
|
|
45
|
-
disableRuleDates?: string
|
|
46
|
-
time?: boolean
|
|
47
|
-
noPastDates?: boolean
|
|
48
|
-
disabled?: boolean
|
|
49
|
-
required?: boolean
|
|
50
|
-
timeFormat?: string
|
|
51
|
-
}
|
|
52
|
-
const props = withDefaults(defineProps<Props>(), {
|
|
53
|
-
timeFormat: 'HH:mm',
|
|
54
|
-
rules: () => [],
|
|
55
|
-
disableRuleDates: undefined,
|
|
56
|
-
modelValue: undefined,
|
|
57
|
-
})
|
|
58
|
-
|
|
59
|
-
defineEmits(['update:modelValue'])
|
|
60
|
-
|
|
61
|
-
const model = defineModel<string | null | undefined>()
|
|
62
|
-
|
|
63
|
-
const error = ref(false)
|
|
64
|
-
|
|
65
|
-
const updateError = (state: boolean) => {
|
|
66
|
-
if (!error.value && !model.value && !state) {
|
|
67
|
-
error.value = true
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
const disablePastDates = (date: string) => {
|
|
72
|
-
if (!props.noPastDates && !props.disableRuleDates) return true
|
|
73
|
-
|
|
74
|
-
const [year, month, day] = date.split('/')
|
|
75
|
-
const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
|
|
76
|
-
|
|
77
|
-
if (props.disableRuleDates) {
|
|
78
|
-
const firstDate = new Date(props.disableRuleDates)
|
|
79
|
-
return currentDate >= firstDate
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
const today = new Date()
|
|
83
|
-
const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
|
|
84
|
-
|
|
85
|
-
return currentDate >= todayDate
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
function getSelectedDate() {
|
|
89
|
-
if (!model.value) return null
|
|
90
|
-
|
|
91
|
-
return model.value.toString().substring(0, 10)
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
function getSelectedHour() {
|
|
95
|
-
if (!model.value) return null
|
|
96
|
-
|
|
97
|
-
const timePart = model.value.toString().split(' ')[1]
|
|
98
|
-
return timePart ? Number(timePart.split(':')[0]) : null
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
function hourOptions(): number[] {
|
|
102
|
-
const today = new Date()
|
|
103
|
-
const selectedDate = getSelectedDate()
|
|
104
|
-
const todayStr = today.toISOString().slice(0, 10)
|
|
105
|
-
|
|
106
|
-
if (selectedDate !== todayStr) {
|
|
107
|
-
return Array.from({ length: 24 }, (_, i) => i)
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
const currentHour = today.getHours()
|
|
111
|
-
return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
function minuteOptions(): number[] {
|
|
115
|
-
const today = new Date()
|
|
116
|
-
const selectedDate = getSelectedDate()
|
|
117
|
-
const todayStr = today.toISOString().slice(0, 10)
|
|
118
|
-
const selectedHour = getSelectedHour()
|
|
119
|
-
|
|
120
|
-
if (selectedDate !== todayStr) {
|
|
121
|
-
return Array.from({ length: 60 }, (_, i) => i)
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
if (selectedHour === today.getHours()) {
|
|
125
|
-
const currentMinutes = today.getMinutes()
|
|
126
|
-
return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
return Array.from({ length: 60 }, (_, i) => i)
|
|
130
|
-
}
|
|
131
|
-
</script>
|
|
132
|
-
|
|
133
|
-
<style scoped lang="scss">
|
|
134
|
-
.datepicker {
|
|
135
|
-
:deep(input),
|
|
136
|
-
:deep(.q-field--readonly.q-field--float .q-field__native) {
|
|
137
|
-
cursor: pointer;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
&__label {
|
|
141
|
-
font-size: 14px;
|
|
142
|
-
font-weight: 700;
|
|
143
|
-
color: #7d8592;
|
|
144
|
-
|
|
145
|
-
.required {
|
|
146
|
-
color: #f65160;
|
|
147
|
-
font-weight: bold;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
</style>
|
|
152
|
-
|
|
153
|
-
<style lang="scss">
|
|
154
|
-
.datepicker {
|
|
155
|
-
&__wrapper {
|
|
156
|
-
display: flex;
|
|
157
|
-
|
|
158
|
-
.q-time,
|
|
159
|
-
.q-date {
|
|
160
|
-
box-shadow: none;
|
|
161
|
-
border-radius: 0;
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="datepicker">
|
|
3
|
+
<app-input-new
|
|
4
|
+
v-model="model"
|
|
5
|
+
readonly
|
|
6
|
+
input-class="cursor-pointer"
|
|
7
|
+
:label="label"
|
|
8
|
+
:required="required"
|
|
9
|
+
:rules="rules"
|
|
10
|
+
:error="error"
|
|
11
|
+
:disable="disabled"
|
|
12
|
+
placeholder="Выберите дату"
|
|
13
|
+
>
|
|
14
|
+
<q-popup-proxy v-if="!disabled" class="datepicker__wrapper" @update:model-value="updateError">
|
|
15
|
+
<q-date
|
|
16
|
+
v-model="model"
|
|
17
|
+
:mask="`DD.MM.YYYY ${timeFormat}`"
|
|
18
|
+
:options="disablePastDates"
|
|
19
|
+
@update:model-value="error = false"
|
|
20
|
+
/>
|
|
21
|
+
<q-time
|
|
22
|
+
v-if="time"
|
|
23
|
+
v-model="model"
|
|
24
|
+
:mask="`DD.MM.YYYY ${timeFormat}`"
|
|
25
|
+
format24h
|
|
26
|
+
:hour-options="hourOptions()"
|
|
27
|
+
:minute-options="minuteOptions()"
|
|
28
|
+
/>
|
|
29
|
+
</q-popup-proxy>
|
|
30
|
+
<template #append>
|
|
31
|
+
<q-icon name="event" class="cursor-pointer"></q-icon>
|
|
32
|
+
</template>
|
|
33
|
+
</app-input-new>
|
|
34
|
+
</div>
|
|
35
|
+
</template>
|
|
36
|
+
|
|
37
|
+
<script setup lang="ts">
|
|
38
|
+
import AppInputNew from '@/common/app-input-new/AppInputNew.vue'
|
|
39
|
+
import { ref, withDefaults, defineEmits, defineProps, defineModel } from 'vue'
|
|
40
|
+
|
|
41
|
+
interface Props {
|
|
42
|
+
label: string
|
|
43
|
+
modelValue?: string
|
|
44
|
+
rules?: ((val?: string | number | null) => boolean | string)[]
|
|
45
|
+
disableRuleDates?: string
|
|
46
|
+
time?: boolean
|
|
47
|
+
noPastDates?: boolean
|
|
48
|
+
disabled?: boolean
|
|
49
|
+
required?: boolean
|
|
50
|
+
timeFormat?: string
|
|
51
|
+
}
|
|
52
|
+
const props = withDefaults(defineProps<Props>(), {
|
|
53
|
+
timeFormat: 'HH:mm',
|
|
54
|
+
rules: () => [],
|
|
55
|
+
disableRuleDates: undefined,
|
|
56
|
+
modelValue: undefined,
|
|
57
|
+
})
|
|
58
|
+
|
|
59
|
+
defineEmits(['update:modelValue'])
|
|
60
|
+
|
|
61
|
+
const model = defineModel<string | null | undefined>()
|
|
62
|
+
|
|
63
|
+
const error = ref(false)
|
|
64
|
+
|
|
65
|
+
const updateError = (state: boolean) => {
|
|
66
|
+
if (!error.value && !model.value && !state) {
|
|
67
|
+
error.value = true
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const disablePastDates = (date: string) => {
|
|
72
|
+
if (!props.noPastDates && !props.disableRuleDates) return true
|
|
73
|
+
|
|
74
|
+
const [year, month, day] = date.split('/')
|
|
75
|
+
const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
|
|
76
|
+
|
|
77
|
+
if (props.disableRuleDates) {
|
|
78
|
+
const firstDate = new Date(props.disableRuleDates)
|
|
79
|
+
return currentDate >= firstDate
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const today = new Date()
|
|
83
|
+
const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
|
|
84
|
+
|
|
85
|
+
return currentDate >= todayDate
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
function getSelectedDate() {
|
|
89
|
+
if (!model.value) return null
|
|
90
|
+
|
|
91
|
+
return model.value.toString().substring(0, 10)
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function getSelectedHour() {
|
|
95
|
+
if (!model.value) return null
|
|
96
|
+
|
|
97
|
+
const timePart = model.value.toString().split(' ')[1]
|
|
98
|
+
return timePart ? Number(timePart.split(':')[0]) : null
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
function hourOptions(): number[] {
|
|
102
|
+
const today = new Date()
|
|
103
|
+
const selectedDate = getSelectedDate()
|
|
104
|
+
const todayStr = today.toISOString().slice(0, 10)
|
|
105
|
+
|
|
106
|
+
if (selectedDate !== todayStr) {
|
|
107
|
+
return Array.from({ length: 24 }, (_, i) => i)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
const currentHour = today.getHours()
|
|
111
|
+
return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
function minuteOptions(): number[] {
|
|
115
|
+
const today = new Date()
|
|
116
|
+
const selectedDate = getSelectedDate()
|
|
117
|
+
const todayStr = today.toISOString().slice(0, 10)
|
|
118
|
+
const selectedHour = getSelectedHour()
|
|
119
|
+
|
|
120
|
+
if (selectedDate !== todayStr) {
|
|
121
|
+
return Array.from({ length: 60 }, (_, i) => i)
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
if (selectedHour === today.getHours()) {
|
|
125
|
+
const currentMinutes = today.getMinutes()
|
|
126
|
+
return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
return Array.from({ length: 60 }, (_, i) => i)
|
|
130
|
+
}
|
|
131
|
+
</script>
|
|
132
|
+
|
|
133
|
+
<style scoped lang="scss">
|
|
134
|
+
.datepicker {
|
|
135
|
+
:deep(input),
|
|
136
|
+
:deep(.q-field--readonly.q-field--float .q-field__native) {
|
|
137
|
+
cursor: pointer;
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
&__label {
|
|
141
|
+
font-size: 14px;
|
|
142
|
+
font-weight: 700;
|
|
143
|
+
color: #7d8592;
|
|
144
|
+
|
|
145
|
+
.required {
|
|
146
|
+
color: #f65160;
|
|
147
|
+
font-weight: bold;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
</style>
|
|
152
|
+
|
|
153
|
+
<style lang="scss">
|
|
154
|
+
.datepicker {
|
|
155
|
+
&__wrapper {
|
|
156
|
+
display: flex;
|
|
157
|
+
|
|
158
|
+
.q-time,
|
|
159
|
+
.q-date {
|
|
160
|
+
box-shadow: none;
|
|
161
|
+
border-radius: 0;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
</style>
|
|
@@ -1,99 +1,99 @@
|
|
|
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 :class="$style['footer__btn--ok']" label="Подтвердить" @click="onDialogOK" />
|
|
13
|
-
<app-button :class="$style['footer__btn--cancel']" label="Отменить" @click="onDialogHide" />
|
|
14
|
-
</q-card-section>
|
|
15
|
-
</q-card>
|
|
16
|
-
</q-dialog>
|
|
17
|
-
</template>
|
|
18
|
-
|
|
19
|
-
<script setup lang="ts">
|
|
20
|
-
import { useDialogPluginComponent } from 'quasar'
|
|
21
|
-
import AppButton from '@/common/app-button/AppButton.vue'
|
|
22
|
-
import SafetyIcon from '@/icons/dialogs/SafetyIcon.vue'
|
|
23
|
-
import RemoveIcon from '@/icons/dialogs/RemoveIcon.vue'
|
|
24
|
-
|
|
25
|
-
const { onDialogHide, onDialogOK, dialogRef } = useDialogPluginComponent()
|
|
26
|
-
|
|
27
|
-
interface Props {
|
|
28
|
-
content: string
|
|
29
|
-
type: 'delete' | 'edit'
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const props = defineProps<Props>()
|
|
33
|
-
</script>
|
|
34
|
-
|
|
35
|
-
<style lang="scss" module>
|
|
36
|
-
.modal {
|
|
37
|
-
font-family: NunitoSansFont, sans-serif;
|
|
38
|
-
display: flex;
|
|
39
|
-
flex-direction: column;
|
|
40
|
-
width: 400px;
|
|
41
|
-
border-radius: 8px !important;
|
|
42
|
-
justify-content: space-between;
|
|
43
|
-
&__content {
|
|
44
|
-
margin: 0 auto;
|
|
45
|
-
padding: 0;
|
|
46
|
-
flex-grow: 1;
|
|
47
|
-
&__header {
|
|
48
|
-
width: 100%;
|
|
49
|
-
display: flex;
|
|
50
|
-
align-items: center;
|
|
51
|
-
justify-content: center;
|
|
52
|
-
flex-direction: column;
|
|
53
|
-
gap: 16px;
|
|
54
|
-
padding-top: 18px;
|
|
55
|
-
h4 {
|
|
56
|
-
font-size: 24px;
|
|
57
|
-
font-weight: 600;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
p {
|
|
62
|
-
margin: 0;
|
|
63
|
-
font-size: 16px;
|
|
64
|
-
text-align: center;
|
|
65
|
-
padding: 18px;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
.footer {
|
|
70
|
-
display: flex;
|
|
71
|
-
gap: 12px;
|
|
72
|
-
align-items: center;
|
|
73
|
-
justify-content: center;
|
|
74
|
-
border-radius: 0px 0px 2px 2px;
|
|
75
|
-
background: #F4F9FD;
|
|
76
|
-
padding: 18px 12px;
|
|
77
|
-
&__btn--ok,
|
|
78
|
-
&__btn--cancel {
|
|
79
|
-
background-color: #3f8cff;
|
|
80
|
-
border-radius: 4px;
|
|
81
|
-
color: white;
|
|
82
|
-
font-size: 16px;
|
|
83
|
-
font-weight: bold;
|
|
84
|
-
width: 165px;
|
|
85
|
-
height: 48px;
|
|
86
|
-
cursor: pointer;
|
|
87
|
-
span {
|
|
88
|
-
color: white;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
&__btn--cancel {
|
|
92
|
-
background-color: white;
|
|
93
|
-
border: 1px solid #3f8cff;
|
|
94
|
-
span {
|
|
95
|
-
color: #3f8cff;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
</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 :class="$style['footer__btn--ok']" label="Подтвердить" @click="onDialogOK" />
|
|
13
|
+
<app-button :class="$style['footer__btn--cancel']" label="Отменить" @click="onDialogHide" />
|
|
14
|
+
</q-card-section>
|
|
15
|
+
</q-card>
|
|
16
|
+
</q-dialog>
|
|
17
|
+
</template>
|
|
18
|
+
|
|
19
|
+
<script setup lang="ts">
|
|
20
|
+
import { useDialogPluginComponent } from 'quasar'
|
|
21
|
+
import AppButton from '@/common/app-button/AppButton.vue'
|
|
22
|
+
import SafetyIcon from '@/icons/dialogs/SafetyIcon.vue'
|
|
23
|
+
import RemoveIcon from '@/icons/dialogs/RemoveIcon.vue'
|
|
24
|
+
|
|
25
|
+
const { onDialogHide, onDialogOK, dialogRef } = useDialogPluginComponent()
|
|
26
|
+
|
|
27
|
+
interface Props {
|
|
28
|
+
content: string
|
|
29
|
+
type: 'delete' | 'edit'
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const props = defineProps<Props>()
|
|
33
|
+
</script>
|
|
34
|
+
|
|
35
|
+
<style lang="scss" module>
|
|
36
|
+
.modal {
|
|
37
|
+
font-family: NunitoSansFont, sans-serif;
|
|
38
|
+
display: flex;
|
|
39
|
+
flex-direction: column;
|
|
40
|
+
width: 400px;
|
|
41
|
+
border-radius: 8px !important;
|
|
42
|
+
justify-content: space-between;
|
|
43
|
+
&__content {
|
|
44
|
+
margin: 0 auto;
|
|
45
|
+
padding: 0;
|
|
46
|
+
flex-grow: 1;
|
|
47
|
+
&__header {
|
|
48
|
+
width: 100%;
|
|
49
|
+
display: flex;
|
|
50
|
+
align-items: center;
|
|
51
|
+
justify-content: center;
|
|
52
|
+
flex-direction: column;
|
|
53
|
+
gap: 16px;
|
|
54
|
+
padding-top: 18px;
|
|
55
|
+
h4 {
|
|
56
|
+
font-size: 24px;
|
|
57
|
+
font-weight: 600;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
p {
|
|
62
|
+
margin: 0;
|
|
63
|
+
font-size: 16px;
|
|
64
|
+
text-align: center;
|
|
65
|
+
padding: 18px;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.footer {
|
|
70
|
+
display: flex;
|
|
71
|
+
gap: 12px;
|
|
72
|
+
align-items: center;
|
|
73
|
+
justify-content: center;
|
|
74
|
+
border-radius: 0px 0px 2px 2px;
|
|
75
|
+
background: #F4F9FD;
|
|
76
|
+
padding: 18px 12px;
|
|
77
|
+
&__btn--ok,
|
|
78
|
+
&__btn--cancel {
|
|
79
|
+
background-color: #3f8cff;
|
|
80
|
+
border-radius: 4px;
|
|
81
|
+
color: white;
|
|
82
|
+
font-size: 16px;
|
|
83
|
+
font-weight: bold;
|
|
84
|
+
width: 165px;
|
|
85
|
+
height: 48px;
|
|
86
|
+
cursor: pointer;
|
|
87
|
+
span {
|
|
88
|
+
color: white;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
&__btn--cancel {
|
|
92
|
+
background-color: white;
|
|
93
|
+
border: 1px solid #3f8cff;
|
|
94
|
+
span {
|
|
95
|
+
color: #3f8cff;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
</style>
|
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<q-btn-dropdown :color="color" :content-style="{ width: width || '200px', minWidth: height || '200px' }">
|
|
3
|
-
<template #label>
|
|
4
|
-
<slot name="label">
|
|
5
|
-
{{ label }}
|
|
6
|
-
</slot>
|
|
7
|
-
</template>
|
|
8
|
-
<template #default>
|
|
9
|
-
<slot name="content" />
|
|
10
|
-
</template>
|
|
11
|
-
</q-btn-dropdown>
|
|
12
|
-
</template>
|
|
13
|
-
|
|
14
|
-
<script setup lang="ts">
|
|
15
|
-
interface Props {
|
|
16
|
-
label?: string
|
|
17
|
-
color?: string
|
|
18
|
-
width?: number
|
|
19
|
-
height?: number
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
const props = defineProps<Props>()
|
|
23
|
-
</script>
|
|
24
|
-
|
|
25
|
-
<style scoped lang="scss">
|
|
26
|
-
.q-btn {
|
|
27
|
-
&:before {
|
|
28
|
-
box-shadow: none;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<q-btn-dropdown :color="color" :content-style="{ width: width || '200px', minWidth: height || '200px' }">
|
|
3
|
+
<template #label>
|
|
4
|
+
<slot name="label">
|
|
5
|
+
{{ label }}
|
|
6
|
+
</slot>
|
|
7
|
+
</template>
|
|
8
|
+
<template #default>
|
|
9
|
+
<slot name="content" />
|
|
10
|
+
</template>
|
|
11
|
+
</q-btn-dropdown>
|
|
12
|
+
</template>
|
|
13
|
+
|
|
14
|
+
<script setup lang="ts">
|
|
15
|
+
interface Props {
|
|
16
|
+
label?: string
|
|
17
|
+
color?: string
|
|
18
|
+
width?: number
|
|
19
|
+
height?: number
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const props = defineProps<Props>()
|
|
23
|
+
</script>
|
|
24
|
+
|
|
25
|
+
<style scoped lang="scss">
|
|
26
|
+
.q-btn {
|
|
27
|
+
&:before {
|
|
28
|
+
box-shadow: none;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
</style>
|