shared-ritm 1.3.123 → 1.3.124

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 (82) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +17 -14
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/dist/types/api/services/MetricsService.d.ts +1 -0
  5. package/package.json +70 -70
  6. package/src/App.vue +2461 -2461
  7. package/src/api/services/AuthService.ts +67 -67
  8. package/src/api/services/ControlsService.ts +100 -100
  9. package/src/api/services/EquipmentService.ts +68 -68
  10. package/src/api/services/GanttService.ts +58 -58
  11. package/src/api/services/InstrumentsService.ts +76 -76
  12. package/src/api/services/MetricsService.ts +3 -0
  13. package/src/api/services/RepairsService.ts +111 -111
  14. package/src/api/services/TasksService.ts +165 -165
  15. package/src/api/services/UserIssueService.ts +32 -32
  16. package/src/api/services/UserService.ts +129 -129
  17. package/src/api/services/VideoService.ts +118 -118
  18. package/src/api/settings/ApiService.ts +185 -185
  19. package/src/api/types/Api_Auth.ts +121 -121
  20. package/src/api/types/Api_Controls.ts +112 -112
  21. package/src/api/types/Api_Equipment.ts +54 -54
  22. package/src/api/types/Api_Instruments.ts +182 -182
  23. package/src/api/types/Api_Metrics.ts +89 -89
  24. package/src/api/types/Api_Repairs.ts +200 -200
  25. package/src/api/types/Api_Search.ts +81 -81
  26. package/src/api/types/Api_Tasks.ts +378 -378
  27. package/src/api/types/Api_User.ts +161 -161
  28. package/src/api/types/Api_User_Issue.ts +36 -36
  29. package/src/api/types/Api_Video.ts +244 -244
  30. package/src/common/app-button/Button.stories.ts +369 -369
  31. package/src/common/app-checkbox/AppCheckbox.vue +31 -31
  32. package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
  33. package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
  34. package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
  35. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  36. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  37. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  38. package/src/common/app-file/File.stories.ts +104 -104
  39. package/src/common/app-icon/AppIcon.vue +110 -110
  40. package/src/common/app-icon/Icon.stories.ts +91 -91
  41. package/src/common/app-input/AppInput.vue +150 -150
  42. package/src/common/app-input/Input.stories.ts +160 -160
  43. package/src/common/app-input-new/AppInputNew.vue +181 -181
  44. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  45. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  46. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  47. package/src/common/app-loader/Loader.stories.ts +114 -114
  48. package/src/common/app-modal/index.vue +101 -101
  49. package/src/common/app-select/AppSelect.vue +159 -159
  50. package/src/common/app-select/Select.stories.ts +155 -155
  51. package/src/common/app-sheet-new/AppSheetNew.vue +254 -254
  52. package/src/common/app-sidebar/AppSidebar.vue +177 -177
  53. package/src/common/app-table/AppTable.vue +313 -313
  54. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  55. package/src/common/app-table/components/ModalSelect.vue +302 -302
  56. package/src/common/app-table/components/TableModal.vue +369 -369
  57. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  58. package/src/common/app-table/controllers/useTableModel.ts +98 -98
  59. package/src/common/app-toggle/AppToggle.vue +12 -12
  60. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  61. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  62. package/src/configs/storybook.ts +14 -14
  63. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  64. package/src/index.ts +134 -134
  65. package/src/shared/styles/general.css +140 -140
  66. package/src/styles/variables.sass +12 -12
  67. package/src/utils/files.ts +38 -38
  68. package/src/utils/helpers.ts +59 -59
  69. package/dist/types/api/services/PhotoService.d.ts +0 -40
  70. package/dist/types/stories/Button.stories.d.ts +0 -13
  71. package/dist/types/stories/Checkbox.stories.d.ts +0 -7
  72. package/dist/types/stories/Confirm.stories.d.ts +0 -8
  73. package/dist/types/stories/DatePicker.stories.d.ts +0 -8
  74. package/dist/types/stories/Dropdown.stories.d.ts +0 -8
  75. package/dist/types/stories/File.stories.d.ts +0 -8
  76. package/dist/types/stories/Icon.stories.d.ts +0 -7
  77. package/dist/types/stories/Input.stories.d.ts +0 -11
  78. package/dist/types/stories/InputNew.stories.d.ts +0 -12
  79. package/dist/types/stories/InputSearch.stories.d.ts +0 -10
  80. package/dist/types/stories/Loader.stories.d.ts +0 -8
  81. package/dist/types/stories/Select.stories.d.ts +0 -7
  82. package/dist/types/stories/Toggle.stories.d.ts +0 -8
@@ -1,289 +1,289 @@
1
- <template>
2
- <q-header :class="[$style.header, { [$style[`header-full`]]: fullWidth }]">
3
- <q-toolbar :class="$style.toolbar">
4
- <h1>{{ pageTitle }}</h1>
5
- <div :class="$style['action-buttons']">
6
- <div v-if="settingsMenuItems?.find(x => x.name === 'root-on' && x.isShow)" :class="$style['root-mode']">
7
- <h1>Включен Root-режим</h1>
8
- </div>
9
-
10
- <div :class="$style['person']" @click="clickProfile">
11
- <app-icon name="person-icon" />
12
- <div :class="$style['person__info']">
13
- <p style="font-weight: 700; font-size: 14px">{{ shortName }}</p>
14
- <p style="font-weight: 300; font-size: 12px">{{ positionName }}</p>
15
- </div>
16
- </div>
17
- <div :class="$style['action-wrapper']">
18
- <!-- <q-btn :class="$style['notification']" flat padding="sm" :ripple="false" @click="clickNotification">-->
19
- <!-- <app-icon color="white" size="28px" name="notifications-icon" />-->
20
- <!-- </q-btn>-->
21
- <q-separator color="white" vertical size="1px" />
22
- <q-btn
23
- ref="refMenuSettings"
24
- flat
25
- padding="sm"
26
- :ripple="false"
27
- :class="[$style['settings'], { [$style['settings__open']]: isSettingsOpened }]"
28
- @click="openSettingsMenu"
29
- >
30
- <app-icon size="28px" name="setting-icon" />
31
- <q-menu max-height="160px" :offset="[-18, 4]" :class="$style['settings-menu']">
32
- <q-list v-for="item in settingsMenuItems" :key="item.name" :class="$style['settings-menu__list']">
33
- <q-item
34
- v-show="item.isShow"
35
- v-close-popup
36
- :class="$style['settings-menu__item']"
37
- clickable
38
- @click="clickSettingsMenuItem(item)"
39
- >{{ item.label }}</q-item
40
- >
41
- </q-list>
42
- </q-menu>
43
- </q-btn>
44
- </div>
45
-
46
- <!-- <app-button icon="person" text-color="black" :label="shortName" rounded :class="$style['button-person']" />-->
47
- </div>
48
- </q-toolbar>
49
- </q-header>
50
- </template>
51
-
52
- <script lang="ts" setup>
53
- import { computed, defineProps, ref, withDefaults } from 'vue'
54
- import { onClickOutside } from '@vueuse/core'
55
- import AppIcon from '@/common/app-icon/AppIcon.vue'
56
-
57
- interface Props {
58
- userData: any
59
- fullWidth?: boolean
60
- pageTitle?: string
61
- settingsMenuItems?: { label: string; name: string; isShow: boolean }[]
62
- }
63
-
64
- const emits = defineEmits(['clickSettingsMenuItem', 'clickNotification', 'clickProfile'])
65
-
66
- const props = withDefaults(defineProps<Props>(), {
67
- pageTitle: '',
68
- })
69
-
70
- const refMenuSettings = ref(null)
71
- const isSettingsOpened = ref(false)
72
-
73
- // const settingsMenuItems = ref([
74
- // { label: 'Поиск инструментов', name: 'instrument-search', isShow: true },
75
- // { label: 'Мониторинг оборудования', name: 'equipment-monitoring', isShow: true },
76
- // { label: 'Root-режим выключен', name: 'root-off', isShow: true },
77
- // { label: 'Root-режим включен', name: 'root-on', isShow: false },
78
- // ])
79
-
80
- const shortName = computed(() => {
81
- if (!props.userData?.full_name) return ''
82
-
83
- const [lastName, name, patronymic] = props.userData.full_name.split(' ')
84
-
85
- const mainPart = `${lastName} ${name}`
86
-
87
- if (!patronymic) return mainPart
88
-
89
- return `${mainPart} ${patronymic[0]}.`
90
- })
91
-
92
- const positionName = computed(() => props.userData?.positions?.[0]?.display_name)
93
-
94
- const openSettingsMenu = () => {
95
- return (isSettingsOpened.value = !isSettingsOpened.value)
96
- }
97
-
98
- const clickProfile = () => emits('clickProfile')
99
- const clickSettingsMenuItem = (item: any) => emits('clickSettingsMenuItem', item.name)
100
- const clickNotification = () => emits('clickNotification')
101
-
102
- onClickOutside(refMenuSettings, () => (isSettingsOpened.value = false))
103
- </script>
104
-
105
- <style lang="scss" module>
106
- .header {
107
- height: 100px;
108
- background: transparent;
109
- margin: 0 auto;
110
- max-width: 1300px;
111
- }
112
- .header-full {
113
- max-width: 100%;
114
- padding-right: 30px;
115
- padding-left: 30px;
116
- }
117
- .toolbar {
118
- padding: 0;
119
- min-height: 100%;
120
- h1 {
121
- font-weight: 600;
122
- font-size: 28px;
123
- line-height: 100%;
124
- font-family: Montserrat, sans-serif;
125
- }
126
- }
127
-
128
- .header-search {
129
- width: 412px;
130
- font-size: 16px;
131
- }
132
-
133
- .action-buttons {
134
- flex: 1;
135
- position: relative;
136
- display: flex;
137
- align-items: center;
138
- column-gap: 16px;
139
- justify-content: end;
140
- }
141
-
142
- .button {
143
- padding: 12px;
144
- background: white;
145
- transition:
146
- all 0.3s ease,
147
- color 0.3s ease;
148
- }
149
-
150
- .button-person {
151
- padding: 10px 14px;
152
- background: white;
153
- }
154
-
155
- .root-mode {
156
- display: flex;
157
- align-items: center;
158
- background-color: red;
159
- padding: 14px;
160
- border-radius: 10px;
161
- box-shadow:
162
- 0 1px 5px rgba(0, 0, 0, 0.2),
163
- 0 2px 2px rgba(0, 0, 0, 0.14),
164
- 0 3px 1px -2px rgba(0, 0, 0, 0.12);
165
- cursor: pointer;
166
- user-select: none;
167
- h1 {
168
- font-size: 16px;
169
- font-weight: 600;
170
- font-family: 'Nunito Sans', sans-serif;
171
- }
172
- &:active {
173
- box-shadow:
174
- 0 2px 8px rgba(0, 0, 0, 0.3),
175
- 0 4px 4px rgba(0, 0, 0, 0.2),
176
- 0 6px 2px -5px rgba(0, 0, 0, 0.2);
177
- }
178
- }
179
-
180
- .person {
181
- display: flex;
182
- align-items: center;
183
- gap: 6px;
184
- padding: 20px 12px;
185
- height: 44px;
186
- border-radius: 10px;
187
- cursor: pointer;
188
- background-color: white;
189
- box-shadow:
190
- 0 1px 5px rgba(0, 0, 0, 0.2),
191
- 0 2px 2px rgba(0, 0, 0, 0.14),
192
- 0 3px 1px -2px rgba(0, 0, 0, 0.12);
193
- transition: all 0.3s ease;
194
- &__info {
195
- display: flex;
196
- flex-direction: column;
197
- user-select: none;
198
- p {
199
- line-height: 1.2;
200
- margin: 0;
201
- padding: 0;
202
- font-family: 'Nunito Sans', sans-serif;
203
- color: rgb(63, 140, 255);
204
- }
205
- }
206
- &:hover {
207
- background-color: #e1e0e0;
208
- transform: scale(1.01);
209
- }
210
- &:active {
211
- box-shadow:
212
- 0 2px 8px rgba(0, 0, 0, 0.3),
213
- 0 4px 4px rgba(0, 0, 0, 0.2),
214
- 0 6px 2px -5px rgba(0, 0, 0, 0.2);
215
- }
216
- }
217
-
218
- .notification {
219
- cursor: pointer;
220
- transition: transform 0.3s ease;
221
- &:hover {
222
- transform: scale(1.1);
223
- }
224
- :global(.q-focus-helper) {
225
- display: none;
226
- }
227
- }
228
-
229
- .settings {
230
- cursor: pointer;
231
- transition: transform 0.3s ease;
232
- &__open {
233
- transform: rotate(90deg);
234
- }
235
- :global(.q-focus-helper) {
236
- display: none;
237
- }
238
- }
239
-
240
- .settings-menu {
241
- min-width: 210px;
242
- border-radius: 8px;
243
- &__list {
244
- min-width: 210px;
245
- }
246
- &__item {
247
- align-items: center;
248
- font-family: 'Nunito Sans', sans-serif;
249
- color: rgb(63, 140, 255);
250
- }
251
- }
252
-
253
- .action-wrapper {
254
- height: 32px;
255
- justify-content: space-between;
256
- align-items: center;
257
- display: flex;
258
- gap: 12px;
259
- }
260
-
261
- @media (max-width: 1440px) {
262
- .header {
263
- height: 100px;
264
- background: transparent;
265
- margin: 0 auto;
266
- }
267
- .header-search {
268
- width: 343px;
269
- font-size: 16px;
270
- }
271
- .action-buttons {
272
- position: relative;
273
- display: flex;
274
- align-items: center;
275
- column-gap: 8px;
276
- }
277
- .button {
278
- padding: 10px;
279
- background: white;
280
- transition:
281
- all 0.3s ease,
282
- color 0.3s ease;
283
- }
284
- .button-person {
285
- padding: 8px 10px;
286
- background: white;
287
- }
288
- }
289
- </style>
1
+ <template>
2
+ <q-header :class="[$style.header, { [$style[`header-full`]]: fullWidth }]">
3
+ <q-toolbar :class="$style.toolbar">
4
+ <h1>{{ pageTitle }}</h1>
5
+ <div :class="$style['action-buttons']">
6
+ <div v-if="settingsMenuItems?.find(x => x.name === 'root-on' && x.isShow)" :class="$style['root-mode']">
7
+ <h1>Включен Root-режим</h1>
8
+ </div>
9
+
10
+ <div :class="$style['person']" @click="clickProfile">
11
+ <app-icon name="person-icon" />
12
+ <div :class="$style['person__info']">
13
+ <p style="font-weight: 700; font-size: 14px">{{ shortName }}</p>
14
+ <p style="font-weight: 300; font-size: 12px">{{ positionName }}</p>
15
+ </div>
16
+ </div>
17
+ <div :class="$style['action-wrapper']">
18
+ <!-- <q-btn :class="$style['notification']" flat padding="sm" :ripple="false" @click="clickNotification">-->
19
+ <!-- <app-icon color="white" size="28px" name="notifications-icon" />-->
20
+ <!-- </q-btn>-->
21
+ <q-separator color="white" vertical size="1px" />
22
+ <q-btn
23
+ ref="refMenuSettings"
24
+ flat
25
+ padding="sm"
26
+ :ripple="false"
27
+ :class="[$style['settings'], { [$style['settings__open']]: isSettingsOpened }]"
28
+ @click="openSettingsMenu"
29
+ >
30
+ <app-icon size="28px" name="setting-icon" />
31
+ <q-menu max-height="160px" :offset="[-18, 4]" :class="$style['settings-menu']">
32
+ <q-list v-for="item in settingsMenuItems" :key="item.name" :class="$style['settings-menu__list']">
33
+ <q-item
34
+ v-show="item.isShow"
35
+ v-close-popup
36
+ :class="$style['settings-menu__item']"
37
+ clickable
38
+ @click="clickSettingsMenuItem(item)"
39
+ >{{ item.label }}</q-item
40
+ >
41
+ </q-list>
42
+ </q-menu>
43
+ </q-btn>
44
+ </div>
45
+
46
+ <!-- <app-button icon="person" text-color="black" :label="shortName" rounded :class="$style['button-person']" />-->
47
+ </div>
48
+ </q-toolbar>
49
+ </q-header>
50
+ </template>
51
+
52
+ <script lang="ts" setup>
53
+ import { computed, defineProps, ref, withDefaults } from 'vue'
54
+ import { onClickOutside } from '@vueuse/core'
55
+ import AppIcon from '@/common/app-icon/AppIcon.vue'
56
+
57
+ interface Props {
58
+ userData: any
59
+ fullWidth?: boolean
60
+ pageTitle?: string
61
+ settingsMenuItems?: { label: string; name: string; isShow: boolean }[]
62
+ }
63
+
64
+ const emits = defineEmits(['clickSettingsMenuItem', 'clickNotification', 'clickProfile'])
65
+
66
+ const props = withDefaults(defineProps<Props>(), {
67
+ pageTitle: '',
68
+ })
69
+
70
+ const refMenuSettings = ref(null)
71
+ const isSettingsOpened = ref(false)
72
+
73
+ // const settingsMenuItems = ref([
74
+ // { label: 'Поиск инструментов', name: 'instrument-search', isShow: true },
75
+ // { label: 'Мониторинг оборудования', name: 'equipment-monitoring', isShow: true },
76
+ // { label: 'Root-режим выключен', name: 'root-off', isShow: true },
77
+ // { label: 'Root-режим включен', name: 'root-on', isShow: false },
78
+ // ])
79
+
80
+ const shortName = computed(() => {
81
+ if (!props.userData?.full_name) return ''
82
+
83
+ const [lastName, name, patronymic] = props.userData.full_name.split(' ')
84
+
85
+ const mainPart = `${lastName} ${name}`
86
+
87
+ if (!patronymic) return mainPart
88
+
89
+ return `${mainPart} ${patronymic[0]}.`
90
+ })
91
+
92
+ const positionName = computed(() => props.userData?.positions?.[0]?.display_name)
93
+
94
+ const openSettingsMenu = () => {
95
+ return (isSettingsOpened.value = !isSettingsOpened.value)
96
+ }
97
+
98
+ const clickProfile = () => emits('clickProfile')
99
+ const clickSettingsMenuItem = (item: any) => emits('clickSettingsMenuItem', item.name)
100
+ const clickNotification = () => emits('clickNotification')
101
+
102
+ onClickOutside(refMenuSettings, () => (isSettingsOpened.value = false))
103
+ </script>
104
+
105
+ <style lang="scss" module>
106
+ .header {
107
+ height: 100px;
108
+ background: transparent;
109
+ margin: 0 auto;
110
+ max-width: 1300px;
111
+ }
112
+ .header-full {
113
+ max-width: 100%;
114
+ padding-right: 30px;
115
+ padding-left: 30px;
116
+ }
117
+ .toolbar {
118
+ padding: 0;
119
+ min-height: 100%;
120
+ h1 {
121
+ font-weight: 600;
122
+ font-size: 28px;
123
+ line-height: 100%;
124
+ font-family: Montserrat, sans-serif;
125
+ }
126
+ }
127
+
128
+ .header-search {
129
+ width: 412px;
130
+ font-size: 16px;
131
+ }
132
+
133
+ .action-buttons {
134
+ flex: 1;
135
+ position: relative;
136
+ display: flex;
137
+ align-items: center;
138
+ column-gap: 16px;
139
+ justify-content: end;
140
+ }
141
+
142
+ .button {
143
+ padding: 12px;
144
+ background: white;
145
+ transition:
146
+ all 0.3s ease,
147
+ color 0.3s ease;
148
+ }
149
+
150
+ .button-person {
151
+ padding: 10px 14px;
152
+ background: white;
153
+ }
154
+
155
+ .root-mode {
156
+ display: flex;
157
+ align-items: center;
158
+ background-color: red;
159
+ padding: 14px;
160
+ border-radius: 10px;
161
+ box-shadow:
162
+ 0 1px 5px rgba(0, 0, 0, 0.2),
163
+ 0 2px 2px rgba(0, 0, 0, 0.14),
164
+ 0 3px 1px -2px rgba(0, 0, 0, 0.12);
165
+ cursor: pointer;
166
+ user-select: none;
167
+ h1 {
168
+ font-size: 16px;
169
+ font-weight: 600;
170
+ font-family: 'Nunito Sans', sans-serif;
171
+ }
172
+ &:active {
173
+ box-shadow:
174
+ 0 2px 8px rgba(0, 0, 0, 0.3),
175
+ 0 4px 4px rgba(0, 0, 0, 0.2),
176
+ 0 6px 2px -5px rgba(0, 0, 0, 0.2);
177
+ }
178
+ }
179
+
180
+ .person {
181
+ display: flex;
182
+ align-items: center;
183
+ gap: 6px;
184
+ padding: 20px 12px;
185
+ height: 44px;
186
+ border-radius: 10px;
187
+ cursor: pointer;
188
+ background-color: white;
189
+ box-shadow:
190
+ 0 1px 5px rgba(0, 0, 0, 0.2),
191
+ 0 2px 2px rgba(0, 0, 0, 0.14),
192
+ 0 3px 1px -2px rgba(0, 0, 0, 0.12);
193
+ transition: all 0.3s ease;
194
+ &__info {
195
+ display: flex;
196
+ flex-direction: column;
197
+ user-select: none;
198
+ p {
199
+ line-height: 1.2;
200
+ margin: 0;
201
+ padding: 0;
202
+ font-family: 'Nunito Sans', sans-serif;
203
+ color: rgb(63, 140, 255);
204
+ }
205
+ }
206
+ &:hover {
207
+ background-color: #e1e0e0;
208
+ transform: scale(1.01);
209
+ }
210
+ &:active {
211
+ box-shadow:
212
+ 0 2px 8px rgba(0, 0, 0, 0.3),
213
+ 0 4px 4px rgba(0, 0, 0, 0.2),
214
+ 0 6px 2px -5px rgba(0, 0, 0, 0.2);
215
+ }
216
+ }
217
+
218
+ .notification {
219
+ cursor: pointer;
220
+ transition: transform 0.3s ease;
221
+ &:hover {
222
+ transform: scale(1.1);
223
+ }
224
+ :global(.q-focus-helper) {
225
+ display: none;
226
+ }
227
+ }
228
+
229
+ .settings {
230
+ cursor: pointer;
231
+ transition: transform 0.3s ease;
232
+ &__open {
233
+ transform: rotate(90deg);
234
+ }
235
+ :global(.q-focus-helper) {
236
+ display: none;
237
+ }
238
+ }
239
+
240
+ .settings-menu {
241
+ min-width: 210px;
242
+ border-radius: 8px;
243
+ &__list {
244
+ min-width: 210px;
245
+ }
246
+ &__item {
247
+ align-items: center;
248
+ font-family: 'Nunito Sans', sans-serif;
249
+ color: rgb(63, 140, 255);
250
+ }
251
+ }
252
+
253
+ .action-wrapper {
254
+ height: 32px;
255
+ justify-content: space-between;
256
+ align-items: center;
257
+ display: flex;
258
+ gap: 12px;
259
+ }
260
+
261
+ @media (max-width: 1440px) {
262
+ .header {
263
+ height: 100px;
264
+ background: transparent;
265
+ margin: 0 auto;
266
+ }
267
+ .header-search {
268
+ width: 343px;
269
+ font-size: 16px;
270
+ }
271
+ .action-buttons {
272
+ position: relative;
273
+ display: flex;
274
+ align-items: center;
275
+ column-gap: 8px;
276
+ }
277
+ .button {
278
+ padding: 10px;
279
+ background: white;
280
+ transition:
281
+ all 0.3s ease,
282
+ color 0.3s ease;
283
+ }
284
+ .button-person {
285
+ padding: 8px 10px;
286
+ background: white;
287
+ }
288
+ }
289
+ </style>