shared-ritm 1.2.137 → 1.2.139

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 (133) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +174 -166
  4. package/dist/shared-ritm.umd.js +38 -38
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/services/RepairsService.d.ts +1 -1
  7. package/dist/types/api/types/Api_Repairs.d.ts +8 -11
  8. package/dist/types/api/types/Api_Tasks.d.ts +1 -1
  9. package/package.json +64 -64
  10. package/src/App.vue +2461 -2461
  11. package/src/api/services/AuthService.ts +53 -53
  12. package/src/api/services/BrigadesService.ts +32 -32
  13. package/src/api/services/CommentsService.ts +24 -24
  14. package/src/api/services/ControlsService.ts +92 -92
  15. package/src/api/services/EquipmentService.ts +29 -29
  16. package/src/api/services/FileService.ts +17 -17
  17. package/src/api/services/GanttService.ts +17 -17
  18. package/src/api/services/InstrumentsService.ts +63 -63
  19. package/src/api/services/MetricsService.ts +110 -110
  20. package/src/api/services/ModulesService.ts +27 -27
  21. package/src/api/services/ProjectsService.ts +83 -83
  22. package/src/api/services/RepairsService.ts +124 -124
  23. package/src/api/services/ScheduleService.ts +69 -69
  24. package/src/api/services/SearchService.ts +22 -22
  25. package/src/api/services/TasksService.ts +145 -145
  26. package/src/api/services/UserService.ts +113 -113
  27. package/src/api/services/VideoService.ts +103 -103
  28. package/src/api/settings/ApiService.ts +124 -124
  29. package/src/api/types/Api_Auth.ts +86 -86
  30. package/src/api/types/Api_Brigades.ts +36 -36
  31. package/src/api/types/Api_Comment.ts +40 -40
  32. package/src/api/types/Api_Controls.ts +111 -111
  33. package/src/api/types/Api_Equipment.ts +3 -3
  34. package/src/api/types/Api_Files.ts +7 -7
  35. package/src/api/types/Api_Instruments.ts +136 -136
  36. package/src/api/types/Api_Modules.ts +21 -21
  37. package/src/api/types/Api_Projects.ts +61 -61
  38. package/src/api/types/Api_Repairs.ts +140 -138
  39. package/src/api/types/Api_Schedule.ts +64 -64
  40. package/src/api/types/Api_Search.ts +79 -79
  41. package/src/api/types/Api_Service.ts +9 -9
  42. package/src/api/types/Api_Tasks.ts +319 -319
  43. package/src/api/types/Api_User.ts +140 -140
  44. package/src/api/types/Api_Video.ts +145 -145
  45. package/src/common/app-button/AppButton.vue +173 -173
  46. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  47. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  48. package/src/common/app-datepicker/AppDatepicker.vue +176 -166
  49. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  50. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  51. package/src/common/app-icon/AppIcon.vue +108 -108
  52. package/src/common/app-input/AppInput.vue +148 -148
  53. package/src/common/app-input-new/AppInputNew.vue +175 -175
  54. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  55. package/src/common/app-layout/AppLayout.vue +84 -84
  56. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  57. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  58. package/src/common/app-loader/index.vue +43 -43
  59. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  60. package/src/common/app-select/AppSelect.vue +157 -157
  61. package/src/common/app-sheet/AppSheet.vue +120 -120
  62. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  63. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  64. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  65. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  66. package/src/common/app-table/AppTable.vue +308 -308
  67. package/src/common/app-table/AppTableLayout.vue +137 -137
  68. package/src/common/app-table/components/ModalSelect.vue +285 -285
  69. package/src/common/app-table/components/TableModal.vue +356 -356
  70. package/src/common/app-table/components/TablePagination.vue +152 -152
  71. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  72. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  73. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  74. package/src/common/app-toggle/AppToggle.vue +24 -24
  75. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  76. package/src/global.d.ts +1 -1
  77. package/src/icons/components/arrow-down-icon.vue +25 -25
  78. package/src/icons/components/arrow-frame-icon.vue +19 -19
  79. package/src/icons/components/arrow-square.vue +22 -22
  80. package/src/icons/components/table-filter-icon.vue +30 -30
  81. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  82. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  83. package/src/icons/header/NotificationIcon.vue +18 -18
  84. package/src/icons/header/PersonIcon.vue +11 -11
  85. package/src/icons/header/SettingIcon.vue +14 -14
  86. package/src/icons/header/flashIcon.vue +24 -24
  87. package/src/icons/header/searchStatusIcon.vue +24 -24
  88. package/src/icons/header/smallCapsIcon.vue +34 -34
  89. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  90. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  91. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  92. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  93. package/src/icons/sidebar/instruments-icon.vue +45 -45
  94. package/src/icons/sidebar/logo-icon.vue +15 -15
  95. package/src/icons/sidebar/logout-icon.vue +13 -13
  96. package/src/icons/sidebar/modules-icon.vue +16 -16
  97. package/src/icons/sidebar/notifications-icon.vue +24 -24
  98. package/src/icons/sidebar/order-icon.vue +44 -44
  99. package/src/icons/sidebar/pass-icon.vue +38 -38
  100. package/src/icons/sidebar/positions-icon.vue +42 -42
  101. package/src/icons/sidebar/preorder-icon.vue +19 -19
  102. package/src/icons/sidebar/projects-icon.vue +31 -31
  103. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  104. package/src/icons/sidebar/repairs-icon.vue +20 -20
  105. package/src/icons/sidebar/roles-icon.vue +26 -26
  106. package/src/icons/sidebar/status-history-icon.vue +24 -24
  107. package/src/icons/sidebar/tasks-icon.vue +28 -28
  108. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  109. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  110. package/src/icons/sidebar/teams-icon.vue +32 -32
  111. package/src/icons/sidebar/user-icon.vue +18 -18
  112. package/src/icons/sidebar/users-icon.vue +46 -46
  113. package/src/icons/sidebar/videosources-icon.vue +19 -19
  114. package/src/icons/sidebar/videowall-icon.vue +13 -13
  115. package/src/icons/sidebar/videozones-icon.vue +21 -21
  116. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  117. package/src/icons/sidebar/workshop-icon.vue +100 -100
  118. package/src/icons/sidebar/workzones-icon.vue +22 -22
  119. package/src/icons/task/attention-icon.vue +13 -13
  120. package/src/icons/task/clock-icon.vue +10 -10
  121. package/src/icons/task/delete-icon.vue +10 -10
  122. package/src/icons/task/fire-icon.vue +16 -16
  123. package/src/index.ts +126 -126
  124. package/src/main.ts +28 -28
  125. package/src/quasar-user-options.ts +17 -17
  126. package/src/router/index.ts +10 -10
  127. package/src/shared/styles/general.css +124 -124
  128. package/src/shims-vue.d.ts +5 -5
  129. package/src/styles/variables.sass +12 -12
  130. package/src/utils/confirm.ts +12 -12
  131. package/src/utils/faceApiHelper.ts +132 -132
  132. package/src/utils/helpers.ts +59 -59
  133. package/src/utils/notification.ts +9 -9
@@ -1,166 +1,176 @@
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="time ? `DD.MM.YYYY ${timeFormat}` : 'DD.MM.YYYY'"
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
- label: '',
54
- timeFormat: 'HH:mm',
55
- rules: () => [],
56
- disableRuleDates: undefined,
57
- modelValue: undefined,
58
- })
59
-
60
- defineEmits(['update:modelValue'])
61
-
62
- const model = defineModel<string | null | undefined>()
63
-
64
- const error = ref(false)
65
-
66
- const updateError = (state: boolean) => {
67
- if (props.required && !error.value && !model.value && !state) {
68
- error.value = true
69
- }
70
- }
71
-
72
- const disablePastDates = (date: string) => {
73
- if (!props.noPastDates && !props.disableRuleDates) return true
74
-
75
- const [year, month, day] = date.split('/')
76
- const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
77
-
78
- if (props.disableRuleDates) {
79
- const firstDate = new Date(props.disableRuleDates)
80
- return currentDate >= firstDate
81
- }
82
-
83
- const today = new Date()
84
- const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
85
-
86
- return currentDate >= todayDate
87
- }
88
-
89
- function getSelectedDate() {
90
- if (!model.value) return null
91
-
92
- return model.value.toString().substring(0, 10)
93
- }
94
-
95
- function getSelectedHour() {
96
- if (!model.value) return null
97
-
98
- const timePart = model.value.toString().split(' ')[1]
99
- return timePart ? Number(timePart.split(':')[0]) : null
100
- }
101
-
102
- function hourOptions(): number[] {
103
- const today = new Date()
104
- const selectedDate = getSelectedDate()
105
- const todayStr = today.toISOString().slice(0, 10)
106
-
107
- if (selectedDate !== todayStr) {
108
- return Array.from({ length: 24 }, (_, i) => i)
109
- }
110
-
111
- const currentHour = today.getHours()
112
- return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
113
- }
114
-
115
- function minuteOptions(): number[] {
116
- const today = new Date()
117
- const selectedDate = getSelectedDate()
118
- const todayStr = today.toISOString().slice(0, 10)
119
- const selectedHour = getSelectedHour()
120
-
121
- if (selectedDate !== todayStr) {
122
- return Array.from({ length: 60 }, (_, i) => i)
123
- }
124
-
125
- if (selectedHour === today.getHours()) {
126
- const currentMinutes = today.getMinutes()
127
- return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
128
- }
129
-
130
- return Array.from({ length: 60 }, (_, i) => i)
131
- }
132
- </script>
133
-
134
- <style scoped lang="scss">
135
- .datepicker {
136
- :deep(input),
137
- :deep(.q-field--readonly.q-field--float .q-field__native) {
138
- cursor: pointer;
139
- }
140
-
141
- &__label {
142
- font-size: 14px;
143
- font-weight: 700;
144
- color: #7d8592;
145
-
146
- .required {
147
- color: #f65160;
148
- font-weight: bold;
149
- }
150
- }
151
- }
152
- </style>
153
-
154
- <style lang="scss">
155
- .datepicker {
156
- &__wrapper {
157
- display: flex;
158
-
159
- .q-time,
160
- .q-date {
161
- box-shadow: none;
162
- border-radius: 0;
163
- }
164
- }
165
- }
166
- </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="time ? `DD.MM.YYYY ${timeFormat}` : 'DD.MM.YYYY'"
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 | string[]
46
+ time?: boolean
47
+ noPastDates?: boolean
48
+ disabled?: boolean
49
+ required?: boolean
50
+ timeFormat?: string
51
+ }
52
+ const props = withDefaults(defineProps<Props>(), {
53
+ label: '',
54
+ timeFormat: 'HH:mm',
55
+ rules: () => [],
56
+ disableRuleDates: undefined,
57
+ modelValue: undefined,
58
+ })
59
+
60
+ defineEmits(['update:modelValue'])
61
+
62
+ const model = defineModel<string | null | undefined>()
63
+
64
+ const error = ref(false)
65
+
66
+ const updateError = (state: boolean) => {
67
+ if (props.required && !error.value && !model.value && !state) {
68
+ error.value = true
69
+ }
70
+ }
71
+
72
+ const disablePastDates = (date: string) => {
73
+ if (!props.noPastDates && !props.disableRuleDates) return true
74
+
75
+ const [year, month, day] = date.split('/')
76
+ const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
77
+ currentDate.setHours(0, 0, 0, 0)
78
+
79
+ if (props.disableRuleDates) {
80
+ if (Array.isArray(props.disableRuleDates)) {
81
+ const firstDate = props.disableRuleDates[0] ? new Date(props.disableRuleDates[0]) : null
82
+ firstDate?.setHours(0, 0, 0, 0)
83
+ const lastDate = props.disableRuleDates[1] ? new Date(props.disableRuleDates[1]) : null
84
+ lastDate?.setHours(0, 0, 0, 0)
85
+
86
+ return (!firstDate || currentDate >= firstDate) && (!lastDate || currentDate <= lastDate)
87
+ } else {
88
+ const firstDate = new Date(props.disableRuleDates)
89
+ return currentDate >= firstDate
90
+ }
91
+ }
92
+
93
+ const today = new Date()
94
+ const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
95
+
96
+ return currentDate >= todayDate
97
+ }
98
+
99
+ function getSelectedDate() {
100
+ if (!model.value) return null
101
+
102
+ return model.value.toString().substring(0, 10)
103
+ }
104
+
105
+ function getSelectedHour() {
106
+ if (!model.value) return null
107
+
108
+ const timePart = model.value.toString().split(' ')[1]
109
+ return timePart ? Number(timePart.split(':')[0]) : null
110
+ }
111
+
112
+ function hourOptions(): number[] {
113
+ const today = new Date()
114
+ const selectedDate = getSelectedDate()
115
+ const todayStr = today.toISOString().slice(0, 10)
116
+
117
+ if (selectedDate !== todayStr) {
118
+ return Array.from({ length: 24 }, (_, i) => i)
119
+ }
120
+
121
+ const currentHour = today.getHours()
122
+ return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
123
+ }
124
+
125
+ function minuteOptions(): number[] {
126
+ const today = new Date()
127
+ const selectedDate = getSelectedDate()
128
+ const todayStr = today.toISOString().slice(0, 10)
129
+ const selectedHour = getSelectedHour()
130
+
131
+ if (selectedDate !== todayStr) {
132
+ return Array.from({ length: 60 }, (_, i) => i)
133
+ }
134
+
135
+ if (selectedHour === today.getHours()) {
136
+ const currentMinutes = today.getMinutes()
137
+ return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
138
+ }
139
+
140
+ return Array.from({ length: 60 }, (_, i) => i)
141
+ }
142
+ </script>
143
+
144
+ <style scoped lang="scss">
145
+ .datepicker {
146
+ :deep(input),
147
+ :deep(.q-field--readonly.q-field--float .q-field__native) {
148
+ cursor: pointer;
149
+ }
150
+
151
+ &__label {
152
+ font-size: 14px;
153
+ font-weight: 700;
154
+ color: #7d8592;
155
+
156
+ .required {
157
+ color: #f65160;
158
+ font-weight: bold;
159
+ }
160
+ }
161
+ }
162
+ </style>
163
+
164
+ <style lang="scss">
165
+ .datepicker {
166
+ &__wrapper {
167
+ display: flex;
168
+
169
+ .q-time,
170
+ .q-date {
171
+ box-shadow: none;
172
+ border-radius: 0;
173
+ }
174
+ }
175
+ }
176
+ </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,37 +1,37 @@
1
- <template>
2
- <q-btn-dropdown
3
- v-model="model"
4
- :color="color"
5
- :content-style="{ width: width || '200px', minWidth: height || '200px' }"
6
- >
7
- <template #label>
8
- <slot name="label">
9
- {{ label }}
10
- </slot>
11
- </template>
12
- <template #default>
13
- <slot name="content" />
14
- </template>
15
- </q-btn-dropdown>
16
- </template>
17
-
18
- <script setup lang="ts">
19
- interface Props {
20
- label?: string
21
- color?: string
22
- width?: number
23
- height?: number
24
- }
25
-
26
- const props = defineProps<Props>()
27
-
28
- const model = defineModel<boolean>()
29
- </script>
30
-
31
- <style scoped lang="scss">
32
- .q-btn {
33
- &:before {
34
- box-shadow: none;
35
- }
36
- }
37
- </style>
1
+ <template>
2
+ <q-btn-dropdown
3
+ v-model="model"
4
+ :color="color"
5
+ :content-style="{ width: width || '200px', minWidth: height || '200px' }"
6
+ >
7
+ <template #label>
8
+ <slot name="label">
9
+ {{ label }}
10
+ </slot>
11
+ </template>
12
+ <template #default>
13
+ <slot name="content" />
14
+ </template>
15
+ </q-btn-dropdown>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ interface Props {
20
+ label?: string
21
+ color?: string
22
+ width?: number
23
+ height?: number
24
+ }
25
+
26
+ const props = defineProps<Props>()
27
+
28
+ const model = defineModel<boolean>()
29
+ </script>
30
+
31
+ <style scoped lang="scss">
32
+ .q-btn {
33
+ &:before {
34
+ box-shadow: none;
35
+ }
36
+ }
37
+ </style>