shared-ritm 1.2.130 → 1.2.131

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 (135) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +3042 -2991
  4. package/dist/shared-ritm.umd.js +146 -146
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/services/ScheduleService.d.ts +13 -0
  7. package/dist/types/api/services/VideoService.d.ts +18 -9
  8. package/dist/types/api/types/Api_Schedule.d.ts +26 -0
  9. package/dist/types/api/types/Api_Video.d.ts +4 -0
  10. package/dist/types/index.d.ts +3 -1
  11. package/package.json +64 -64
  12. package/src/App.vue +2461 -2461
  13. package/src/api/services/AuthService.ts +53 -53
  14. package/src/api/services/BrigadesService.ts +32 -32
  15. package/src/api/services/CommentsService.ts +24 -24
  16. package/src/api/services/ControlsService.ts +73 -73
  17. package/src/api/services/EquipmentService.ts +29 -29
  18. package/src/api/services/FileService.ts +17 -17
  19. package/src/api/services/GanttService.ts +17 -17
  20. package/src/api/services/InstrumentsService.ts +63 -63
  21. package/src/api/services/MetricsService.ts +110 -110
  22. package/src/api/services/ModulesService.ts +27 -27
  23. package/src/api/services/ProjectsService.ts +83 -83
  24. package/src/api/services/RepairsService.ts +123 -123
  25. package/src/api/services/ScheduleService.ts +34 -0
  26. package/src/api/services/SearchService.ts +22 -22
  27. package/src/api/services/TasksService.ts +145 -145
  28. package/src/api/services/UserService.ts +101 -101
  29. package/src/api/services/VideoService.ts +103 -71
  30. package/src/api/settings/ApiService.ts +124 -124
  31. package/src/api/types/Api_Auth.ts +86 -86
  32. package/src/api/types/Api_Brigades.ts +36 -36
  33. package/src/api/types/Api_Comment.ts +40 -40
  34. package/src/api/types/Api_Controls.ts +93 -93
  35. package/src/api/types/Api_Equipment.ts +3 -3
  36. package/src/api/types/Api_Files.ts +7 -7
  37. package/src/api/types/Api_Instruments.ts +136 -136
  38. package/src/api/types/Api_Modules.ts +21 -21
  39. package/src/api/types/Api_Projects.ts +60 -60
  40. package/src/api/types/Api_Repairs.ts +117 -117
  41. package/src/api/types/Api_Schedule.ts +29 -0
  42. package/src/api/types/Api_Search.ts +77 -77
  43. package/src/api/types/Api_Service.ts +9 -9
  44. package/src/api/types/Api_Tasks.ts +319 -319
  45. package/src/api/types/Api_User.ts +117 -117
  46. package/src/api/types/Api_Video.ts +145 -140
  47. package/src/common/app-button/AppButton.vue +173 -173
  48. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  49. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  50. package/src/common/app-datepicker/AppDatepicker.vue +165 -165
  51. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  52. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  53. package/src/common/app-icon/AppIcon.vue +108 -108
  54. package/src/common/app-input/AppInput.vue +148 -148
  55. package/src/common/app-input-new/AppInputNew.vue +175 -175
  56. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  57. package/src/common/app-layout/AppLayout.vue +84 -84
  58. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  59. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  60. package/src/common/app-loader/index.vue +43 -43
  61. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  62. package/src/common/app-select/AppSelect.vue +157 -157
  63. package/src/common/app-sheet/AppSheet.vue +120 -120
  64. package/src/common/app-sheet-new/AppSheetNew.vue +246 -246
  65. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  66. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  67. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  68. package/src/common/app-table/AppTable.vue +308 -308
  69. package/src/common/app-table/AppTableLayout.vue +137 -137
  70. package/src/common/app-table/components/ModalSelect.vue +281 -281
  71. package/src/common/app-table/components/TableModal.vue +356 -356
  72. package/src/common/app-table/components/TablePagination.vue +152 -152
  73. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  74. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  75. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  76. package/src/common/app-toggle/AppToggle.vue +24 -24
  77. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  78. package/src/global.d.ts +1 -1
  79. package/src/icons/components/arrow-down-icon.vue +25 -25
  80. package/src/icons/components/arrow-frame-icon.vue +19 -19
  81. package/src/icons/components/arrow-square.vue +22 -22
  82. package/src/icons/components/table-filter-icon.vue +30 -30
  83. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  84. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  85. package/src/icons/header/NotificationIcon.vue +18 -18
  86. package/src/icons/header/PersonIcon.vue +11 -11
  87. package/src/icons/header/SettingIcon.vue +14 -14
  88. package/src/icons/header/flashIcon.vue +24 -24
  89. package/src/icons/header/searchStatusIcon.vue +24 -24
  90. package/src/icons/header/smallCapsIcon.vue +34 -34
  91. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  92. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  93. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  94. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  95. package/src/icons/sidebar/instruments-icon.vue +45 -45
  96. package/src/icons/sidebar/logo-icon.vue +15 -15
  97. package/src/icons/sidebar/logout-icon.vue +13 -13
  98. package/src/icons/sidebar/modules-icon.vue +16 -16
  99. package/src/icons/sidebar/notifications-icon.vue +24 -24
  100. package/src/icons/sidebar/order-icon.vue +44 -44
  101. package/src/icons/sidebar/pass-icon.vue +38 -38
  102. package/src/icons/sidebar/positions-icon.vue +42 -42
  103. package/src/icons/sidebar/preorder-icon.vue +19 -19
  104. package/src/icons/sidebar/projects-icon.vue +31 -31
  105. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  106. package/src/icons/sidebar/repairs-icon.vue +20 -20
  107. package/src/icons/sidebar/roles-icon.vue +26 -26
  108. package/src/icons/sidebar/status-history-icon.vue +24 -24
  109. package/src/icons/sidebar/tasks-icon.vue +28 -28
  110. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  111. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  112. package/src/icons/sidebar/teams-icon.vue +32 -32
  113. package/src/icons/sidebar/user-icon.vue +18 -18
  114. package/src/icons/sidebar/users-icon.vue +46 -46
  115. package/src/icons/sidebar/videosources-icon.vue +19 -19
  116. package/src/icons/sidebar/videowall-icon.vue +13 -13
  117. package/src/icons/sidebar/videozones-icon.vue +21 -21
  118. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  119. package/src/icons/sidebar/workshop-icon.vue +100 -100
  120. package/src/icons/sidebar/workzones-icon.vue +22 -22
  121. package/src/icons/task/attention-icon.vue +13 -13
  122. package/src/icons/task/clock-icon.vue +10 -10
  123. package/src/icons/task/delete-icon.vue +10 -10
  124. package/src/icons/task/fire-icon.vue +16 -16
  125. package/src/index.ts +126 -123
  126. package/src/main.ts +28 -28
  127. package/src/quasar-user-options.ts +17 -17
  128. package/src/router/index.ts +10 -10
  129. package/src/shared/styles/general.css +124 -124
  130. package/src/shims-vue.d.ts +5 -5
  131. package/src/styles/variables.sass +12 -12
  132. package/src/utils/confirm.ts +12 -12
  133. package/src/utils/faceApiHelper.ts +132 -132
  134. package/src/utils/helpers.ts +59 -59
  135. package/src/utils/notification.ts +9 -9
@@ -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="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
- 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 (props.required && !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="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
+ 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 (props.required && !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,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>