bfg-common 1.5.727 → 1.5.728

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 (112) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +2 -0
  7. package/assets/localization/local_en.json +2 -0
  8. package/assets/localization/local_hy.json +2 -0
  9. package/assets/localization/local_kk.json +2 -0
  10. package/assets/localization/local_ru.json +2 -0
  11. package/assets/localization/local_zh.json +2 -0
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  16. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  17. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  18. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  19. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  20. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  21. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  22. package/components/common/diagramMain/port/Port.vue +580 -580
  23. package/components/common/layout/console/Console.vue +70 -70
  24. package/components/common/layout/theHeader/New.vue +301 -301
  25. package/components/common/layout/theHeader/Old.vue +252 -252
  26. package/components/common/layout/theHeader/TheHeader.vue +152 -152
  27. package/components/common/layout/theHeader/userMenu/UserMenu.vue +104 -104
  28. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  29. package/components/common/pages/backups/DetailView.vue +52 -52
  30. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  31. package/components/common/pages/backups/modals/Modals.vue +243 -243
  32. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  33. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  34. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  35. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  36. package/components/common/pages/backups/modals/restore/Restore.vue +289 -303
  37. package/components/common/pages/backups/modals/restore/lib/config/readyToCompleteOptions.ts +84 -84
  38. package/components/common/pages/backups/modals/restore/lib/config/restoreCodes.ts +2 -1
  39. package/components/common/pages/backups/modals/restore/lib/config/steps.ts +121 -113
  40. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  41. package/components/common/pages/backups/modals/restore/types/{TypesNew.vue → New.vue} +95 -95
  42. package/components/common/pages/backups/modals/restore/types/{TypesOld.vue → Old.vue} +62 -61
  43. package/components/common/pages/backups/modals/restore/types/Types.vue +31 -19
  44. package/components/common/pages/backups/modals/restore/types/lib/config/descriptions.ts +1 -0
  45. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +5 -0
  46. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  47. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  48. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  49. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  50. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  51. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  52. package/components/common/pages/tasks/Tasks.vue +125 -125
  53. package/components/common/pages/tasks/table/Table.vue +373 -373
  54. package/components/common/pages/tasks/table/lib/config/config.ts +279 -279
  55. package/components/common/pages/tasks/table/lib/models/interfaces.ts +9 -9
  56. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  57. package/components/common/select/radio/RadioGroup.vue +137 -137
  58. package/components/common/spiceConsole/Drawer.vue +420 -420
  59. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  60. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  61. package/components/common/tools/Actions.vue +207 -207
  62. package/components/common/treeView/TreeView.vue +52 -52
  63. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  64. package/components/common/vm/actions/clone/new/New.vue +438 -438
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  67. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  68. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  69. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  70. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  71. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  72. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  73. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  74. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  75. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  76. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  77. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  78. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  79. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  80. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  81. package/components/common/wizards/common/steps/name/New.vue +221 -221
  82. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  83. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  84. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  85. package/components/common/wizards/datastore/add/Add.vue +228 -228
  86. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  87. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  88. package/composables/useAppVersion.ts +21 -21
  89. package/composables/useBrowse.ts +24 -24
  90. package/composables/useLocal.ts +6 -6
  91. package/composables/useLocalCommon.ts +39 -39
  92. package/lib/models/types.ts +59 -59
  93. package/package.json +2 -2
  94. package/plugins/console.ts +21 -21
  95. package/plugins/mouse.ts +21 -21
  96. package/plugins/panelStates.ts +70 -70
  97. package/plugins/text.ts +59 -59
  98. package/public/spice-console/application/clientgui.js +854 -854
  99. package/public/spice-console/application/packetfactory.js +211 -211
  100. package/public/spice-console/application/virtualmouse.js +147 -147
  101. package/public/spice-console/lib/images/bitmap.js +203 -203
  102. package/public/spice-console/network/spicechannel.js +440 -440
  103. package/public/spice-console/process/cursorprocess.js +128 -128
  104. package/public/spice-console/process/inputprocess.js +227 -227
  105. package/public/spice-console/process/mainprocess.js +212 -212
  106. package/public/spice-console/run.js +210 -210
  107. package/store/main/mutations.ts +7 -7
  108. package/store/main/state.ts +7 -7
  109. package/store/tasks/mappers/recentTasks.ts +123 -123
  110. package/store/tasks/mutations.ts +82 -82
  111. /package/components/common/pages/backups/modals/restore/{RestoreNew.vue → New.vue} +0 -0
  112. /package/components/common/pages/backups/modals/restore/{RestoreOld.vue → Old.vue} +0 -0
@@ -1,252 +1,252 @@
1
- <template>
2
- <div class="main-nav">
3
- <header class="header header-7">
4
- <div class="header-nav">
5
- <div class="nav-link">
6
- <button
7
- id="inventory-menu-trigger"
8
- data-id="inventory-menu-toggle-button"
9
- class="inventory-menu-trigger"
10
- @click="emits('toggle-main-menu')"
11
- >
12
- <span class="inventory-menu-link">
13
- <span class="nav-icon">
14
- <atoms-the-icon class="menu-icon" name="menu" />
15
- </span>
16
- </span>
17
- </button>
18
- </div>
19
- </div>
20
- <div class="branding">
21
- <nuxt-link
22
- id="header-shortcuts-link"
23
- data-id="header-shortcuts-link"
24
- to="/shortcuts"
25
- >
26
- <span class="title pointer"
27
- >{{ props.companyName }}<sup><b>®</b></sup>
28
- {{ props.projectName }}</span
29
- >
30
- </nuxt-link>
31
- </div>
32
- <form>
33
- <atoms-input-search />
34
- </form>
35
-
36
- <div class="settings header-actions">
37
- <div class="divider" />
38
- <a
39
- id="global-refresh-button"
40
- data-id="global-refresh-button"
41
- class="nav-link tid-global-refresh-button"
42
- @click="emits('global-refresh')"
43
- >
44
- <span class="nav-icon">
45
- <atoms-the-icon
46
- v-show="!props.globalRefreshLoading"
47
- class="reset-icon"
48
- name="reset"
49
- />
50
- <span
51
- :class="[
52
- 'spinner spinner-inline spinner-inverse global-refresh-active',
53
- { 'spinner-paused': !props.globalRefreshLoading },
54
- ]"
55
- ></span>
56
- </span>
57
- </a>
58
- <div class="divider" />
59
-
60
- <common-layout-the-header-user-menu
61
- v-model:security="security"
62
- v-model:new-view-local="newViewLocal"
63
- v-model:time-format="timeFormat"
64
- v-model:console-value="consoleValue"
65
- v-model:vm-in-hosts-clusters="vmInHostsClusters"
66
- v-model:is-dark-theme="isDarkTheme"
67
- :hostname="props.hostname"
68
- :is-preference="props.isPreference"
69
- :selected-language-type="props.selectedLanguageType"
70
- :selected-language="props.selectedLang.value"
71
- :new-view="props.newView"
72
- :project="props.project"
73
- :security-loader="props.securityLoader"
74
- :recovery="props.recovery"
75
- @show-preference="emits('show-preference')"
76
- @hide-preference="emits('hide-preference')"
77
- @update-language="onUpdateLanguage"
78
- @update-is-browser="emits('update-is-browser', $event)"
79
- @security-confirm="emits('security-confirm', $event)"
80
- @submit-preferences="emits('submit-preferences')"
81
- />
82
-
83
- <div class="divider" />
84
-
85
- <common-layout-the-header-feedback
86
- :is-show-feedback="isShowFeedback"
87
- @show="isShowFeedback = true"
88
- @hide="isShowFeedback = false"
89
- />
90
-
91
- <div class="divider" />
92
-
93
- <common-layout-the-header-help-menu :project-name="props.projectName" />
94
-
95
- <div class="divider" />
96
- </div>
97
- </header>
98
- </div>
99
- </template>
100
-
101
- <script setup lang="ts">
102
- import type { UI_I_Dropdown } from '~/node_modules/bfg-uikit/components/ui/dropdown/models/interfaces'
103
- import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
104
- import type { UI_T_Project } from '~/lib/models/types'
105
- import type { UI_I_Recovery } from '~/components/common/layout/theHeader/userMenu/modals/preferences/security/lib/models/interfaces'
106
- import { findInLocals } from '~/components/common/selectLanguage/lib/utils/utils'
107
-
108
- const security = defineModel<boolean>('security')
109
- const newViewLocal = defineModel<boolean>('newViewLocal')
110
- const timeFormat = defineModel<UI_T_TimeValue>('timeFormat')
111
- const consoleValue = defineModel<string>('consoleValue')
112
- const vmInHostsClusters = defineModel<boolean>('vmInHostsClusters')
113
- const isDarkTheme = defineModel<boolean>('isDarkTheme')
114
-
115
- const props = defineProps<{
116
- companyName: string
117
- betaText: string
118
- globalRefreshLoading: boolean
119
- project: UI_T_Project
120
- projectName: string
121
- hostname: string
122
- isPreference: boolean
123
- selectedLanguageType: string
124
- selectedLang: UI_I_Dropdown
125
- newView: boolean
126
- securityLoader: boolean // для Сферы
127
- recovery: UI_I_Recovery | null // для Сферы
128
- }>()
129
-
130
- const emits = defineEmits<{
131
- (event: 'toggle-main-menu'): void
132
- (event: 'global-refresh'): void
133
- (event: 'show-preference'): void
134
- (event: 'hide-preference'): void
135
- (event: 'update-language', value: UI_I_Dropdown): void
136
- (event: 'update-is-browser', value: string): void
137
- (event: 'security-confirm', value: boolean): void
138
- (event: 'submit-preferences'): void
139
- }>()
140
-
141
- const onUpdateLanguage = (language: string): void => {
142
- const languageObj = findInLocals(language)
143
- emits('update-language', languageObj)
144
- }
145
-
146
- const isShowFeedback = ref<boolean>(false)
147
- </script>
148
-
149
- <style scoped lang="scss">
150
- .main-nav {
151
- position: relative;
152
- left: 0;
153
-
154
- header {
155
- height: 62px;
156
- align-items: center;
157
- padding-left: 0;
158
-
159
- .nav-link::before,
160
- .nav-link::after {
161
- display: none !important;
162
- }
163
-
164
- .inventory-menu-trigger {
165
- padding: 0 0 0 60px;
166
- background: transparent;
167
- border: none;
168
- cursor: pointer;
169
- position: relative;
170
- outline: none;
171
-
172
- .nav-icon {
173
- padding: 0;
174
- width: auto;
175
- font-size: inherit;
176
- display: flex;
177
- align-items: center;
178
- background: transparent;
179
- border: none;
180
-
181
- .menu-icon {
182
- position: absolute;
183
- top: 50%;
184
- left: 50%;
185
- transform: translate(-50%, -50%);
186
- height: 24px;
187
- width: 24px;
188
- fill: #fafafa;
189
- display: inline-block;
190
- margin: 0;
191
- vertical-align: middle;
192
- }
193
- }
194
- }
195
-
196
- .branding {
197
- width: auto;
198
- min-width: auto;
199
- padding-left: 9px;
200
- padding-right: 20px;
201
-
202
- a {
203
- position: relative;
204
- padding-right: 4px;
205
- }
206
- }
207
-
208
- .settings {
209
- align-items: center;
210
-
211
- a.nav-link {
212
- display: flex;
213
- padding: 0;
214
- cursor: pointer;
215
-
216
- .reset-icon {
217
- width: 24px;
218
- height: 24px;
219
- position: absolute;
220
- top: 50%;
221
- left: 50%;
222
- transform: translate(-50%, -50%);
223
- fill: #fafafa;
224
- }
225
-
226
- .spinner {
227
- line-height: 24px;
228
- vertical-align: middle;
229
- height: 24px;
230
- width: 24px;
231
- min-height: 24px;
232
- min-width: 24px;
233
- z-index: var(--z-fixed);
234
-
235
- &.spinner-paused {
236
- animation-play-state: paused;
237
- display: none;
238
- }
239
- }
240
- }
241
- .divider {
242
- height: 40px;
243
- display: flex;
244
- flex: 0 0 auto;
245
- width: 1px;
246
- background: #fafafa;
247
- opacity: 0.15;
248
- }
249
- }
250
- }
251
- }
252
- </style>
1
+ <template>
2
+ <div class="main-nav">
3
+ <header class="header header-7">
4
+ <div class="header-nav">
5
+ <div class="nav-link">
6
+ <button
7
+ id="inventory-menu-trigger"
8
+ data-id="inventory-menu-toggle-button"
9
+ class="inventory-menu-trigger"
10
+ @click="emits('toggle-main-menu')"
11
+ >
12
+ <span class="inventory-menu-link">
13
+ <span class="nav-icon">
14
+ <atoms-the-icon class="menu-icon" name="menu" />
15
+ </span>
16
+ </span>
17
+ </button>
18
+ </div>
19
+ </div>
20
+ <div class="branding">
21
+ <nuxt-link
22
+ id="header-shortcuts-link"
23
+ data-id="header-shortcuts-link"
24
+ to="/shortcuts"
25
+ >
26
+ <span class="title pointer"
27
+ >{{ props.companyName }}<sup><b>®</b></sup>
28
+ {{ props.projectName }}</span
29
+ >
30
+ </nuxt-link>
31
+ </div>
32
+ <form>
33
+ <atoms-input-search />
34
+ </form>
35
+
36
+ <div class="settings header-actions">
37
+ <div class="divider" />
38
+ <a
39
+ id="global-refresh-button"
40
+ data-id="global-refresh-button"
41
+ class="nav-link tid-global-refresh-button"
42
+ @click="emits('global-refresh')"
43
+ >
44
+ <span class="nav-icon">
45
+ <atoms-the-icon
46
+ v-show="!props.globalRefreshLoading"
47
+ class="reset-icon"
48
+ name="reset"
49
+ />
50
+ <span
51
+ :class="[
52
+ 'spinner spinner-inline spinner-inverse global-refresh-active',
53
+ { 'spinner-paused': !props.globalRefreshLoading },
54
+ ]"
55
+ ></span>
56
+ </span>
57
+ </a>
58
+ <div class="divider" />
59
+
60
+ <common-layout-the-header-user-menu
61
+ v-model:security="security"
62
+ v-model:new-view-local="newViewLocal"
63
+ v-model:time-format="timeFormat"
64
+ v-model:console-value="consoleValue"
65
+ v-model:vm-in-hosts-clusters="vmInHostsClusters"
66
+ v-model:is-dark-theme="isDarkTheme"
67
+ :hostname="props.hostname"
68
+ :is-preference="props.isPreference"
69
+ :selected-language-type="props.selectedLanguageType"
70
+ :selected-language="props.selectedLang.value"
71
+ :new-view="props.newView"
72
+ :project="props.project"
73
+ :security-loader="props.securityLoader"
74
+ :recovery="props.recovery"
75
+ @show-preference="emits('show-preference')"
76
+ @hide-preference="emits('hide-preference')"
77
+ @update-language="onUpdateLanguage"
78
+ @update-is-browser="emits('update-is-browser', $event)"
79
+ @security-confirm="emits('security-confirm', $event)"
80
+ @submit-preferences="emits('submit-preferences')"
81
+ />
82
+
83
+ <div class="divider" />
84
+
85
+ <common-layout-the-header-feedback
86
+ :is-show-feedback="isShowFeedback"
87
+ @show="isShowFeedback = true"
88
+ @hide="isShowFeedback = false"
89
+ />
90
+
91
+ <div class="divider" />
92
+
93
+ <common-layout-the-header-help-menu :project-name="props.projectName" />
94
+
95
+ <div class="divider" />
96
+ </div>
97
+ </header>
98
+ </div>
99
+ </template>
100
+
101
+ <script setup lang="ts">
102
+ import type { UI_I_Dropdown } from '~/node_modules/bfg-uikit/components/ui/dropdown/models/interfaces'
103
+ import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
104
+ import type { UI_T_Project } from '~/lib/models/types'
105
+ import type { UI_I_Recovery } from '~/components/common/layout/theHeader/userMenu/modals/preferences/security/lib/models/interfaces'
106
+ import { findInLocals } from '~/components/common/selectLanguage/lib/utils/utils'
107
+
108
+ const security = defineModel<boolean>('security')
109
+ const newViewLocal = defineModel<boolean>('newViewLocal')
110
+ const timeFormat = defineModel<UI_T_TimeValue>('timeFormat')
111
+ const consoleValue = defineModel<string>('consoleValue')
112
+ const vmInHostsClusters = defineModel<boolean>('vmInHostsClusters')
113
+ const isDarkTheme = defineModel<boolean>('isDarkTheme')
114
+
115
+ const props = defineProps<{
116
+ companyName: string
117
+ betaText: string
118
+ globalRefreshLoading: boolean
119
+ project: UI_T_Project
120
+ projectName: string
121
+ hostname: string
122
+ isPreference: boolean
123
+ selectedLanguageType: string
124
+ selectedLang: UI_I_Dropdown
125
+ newView: boolean
126
+ securityLoader: boolean // для Сферы
127
+ recovery: UI_I_Recovery | null // для Сферы
128
+ }>()
129
+
130
+ const emits = defineEmits<{
131
+ (event: 'toggle-main-menu'): void
132
+ (event: 'global-refresh'): void
133
+ (event: 'show-preference'): void
134
+ (event: 'hide-preference'): void
135
+ (event: 'update-language', value: UI_I_Dropdown): void
136
+ (event: 'update-is-browser', value: string): void
137
+ (event: 'security-confirm', value: boolean): void
138
+ (event: 'submit-preferences'): void
139
+ }>()
140
+
141
+ const onUpdateLanguage = (language: string): void => {
142
+ const languageObj = findInLocals(language)
143
+ emits('update-language', languageObj)
144
+ }
145
+
146
+ const isShowFeedback = ref<boolean>(false)
147
+ </script>
148
+
149
+ <style scoped lang="scss">
150
+ .main-nav {
151
+ position: relative;
152
+ left: 0;
153
+
154
+ header {
155
+ height: 62px;
156
+ align-items: center;
157
+ padding-left: 0;
158
+
159
+ .nav-link::before,
160
+ .nav-link::after {
161
+ display: none !important;
162
+ }
163
+
164
+ .inventory-menu-trigger {
165
+ padding: 0 0 0 60px;
166
+ background: transparent;
167
+ border: none;
168
+ cursor: pointer;
169
+ position: relative;
170
+ outline: none;
171
+
172
+ .nav-icon {
173
+ padding: 0;
174
+ width: auto;
175
+ font-size: inherit;
176
+ display: flex;
177
+ align-items: center;
178
+ background: transparent;
179
+ border: none;
180
+
181
+ .menu-icon {
182
+ position: absolute;
183
+ top: 50%;
184
+ left: 50%;
185
+ transform: translate(-50%, -50%);
186
+ height: 24px;
187
+ width: 24px;
188
+ fill: #fafafa;
189
+ display: inline-block;
190
+ margin: 0;
191
+ vertical-align: middle;
192
+ }
193
+ }
194
+ }
195
+
196
+ .branding {
197
+ width: auto;
198
+ min-width: auto;
199
+ padding-left: 9px;
200
+ padding-right: 20px;
201
+
202
+ a {
203
+ position: relative;
204
+ padding-right: 4px;
205
+ }
206
+ }
207
+
208
+ .settings {
209
+ align-items: center;
210
+
211
+ a.nav-link {
212
+ display: flex;
213
+ padding: 0;
214
+ cursor: pointer;
215
+
216
+ .reset-icon {
217
+ width: 24px;
218
+ height: 24px;
219
+ position: absolute;
220
+ top: 50%;
221
+ left: 50%;
222
+ transform: translate(-50%, -50%);
223
+ fill: #fafafa;
224
+ }
225
+
226
+ .spinner {
227
+ line-height: 24px;
228
+ vertical-align: middle;
229
+ height: 24px;
230
+ width: 24px;
231
+ min-height: 24px;
232
+ min-width: 24px;
233
+ z-index: var(--z-fixed);
234
+
235
+ &.spinner-paused {
236
+ animation-play-state: paused;
237
+ display: none;
238
+ }
239
+ }
240
+ }
241
+ .divider {
242
+ height: 40px;
243
+ display: flex;
244
+ flex: 0 0 auto;
245
+ width: 1px;
246
+ background: #fafafa;
247
+ opacity: 0.15;
248
+ }
249
+ }
250
+ }
251
+ }
252
+ </style>