bfg-common 1.5.431 → 1.5.433

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 (194) 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/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/perPage/PerPage.vue +58 -58
  9. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  10. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  11. package/components/atoms/wizard/Wizard.vue +2 -2
  12. package/components/atoms/wizard/lib/models/enums.ts +8 -0
  13. package/components/atoms/wizard/lib/models/interfaces.ts +59 -0
  14. package/components/atoms/wizard/lib/utils/utils.ts +954 -0
  15. package/components/atoms/wizard/step/Step.vue +1 -1
  16. package/components/common/backup/storage/actions/add/Add.vue +5 -5
  17. package/components/common/backup/storage/actions/add/Old.vue +1 -1
  18. package/components/common/backup/storage/actions/add/lib/config/steps.ts +2 -2
  19. package/components/common/backup/storage/actions/add/lib/validations.ts +4 -4
  20. package/components/common/backup/storage/actions/add/steps/name/Name.vue +1 -1
  21. package/components/common/backup/storage/actions/add/steps/name/New.vue +1 -1
  22. package/components/common/backup/storage/actions/add/steps/name/Old.vue +1 -1
  23. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +1 -1
  24. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureNew.vue +1 -1
  25. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureOld.vue +1 -1
  26. package/components/common/browse/BrowseNew.vue +1 -0
  27. package/components/common/browse/blocks/Container.vue +235 -235
  28. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  29. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  30. package/components/common/browse/lib/models/interfaces.ts +5 -5
  31. package/components/common/context/lib/models/interfaces.ts +33 -33
  32. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  33. package/components/common/diagramMain/lib/models/types.ts +21 -21
  34. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  35. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  36. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  37. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  38. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  39. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  40. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  41. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +5 -5
  42. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +2 -2
  43. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +2 -2
  44. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  45. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +5 -5
  46. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +2 -2
  47. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  48. package/components/common/diagramMain/port/Port.vue +580 -580
  49. package/components/common/diagramMain/port/Ports.vue +47 -47
  50. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  51. package/components/common/pages/backups/Backups.vue +102 -102
  52. package/components/common/pages/backups/DetailView.vue +52 -52
  53. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  54. package/components/common/pages/backups/modals/Modals.vue +1 -1
  55. package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +2 -5
  56. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  57. package/components/common/pages/backups/modals/createBackup/configuration/backupWindow/BackupWindow.vue +26 -26
  58. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/MaxBandwidth.vue +66 -66
  59. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  60. package/components/common/pages/backups/modals/createBackup/configuration/strategy/Strategy.vue +35 -35
  61. package/components/common/pages/backups/modals/createBackup/datastores/Datastores.vue +59 -59
  62. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  63. package/components/common/pages/backups/modals/createBackup/disks/tableView/lib/config/table.ts +117 -117
  64. package/components/common/pages/backups/modals/createBackup/general/General.vue +135 -135
  65. package/components/common/pages/backups/modals/createBackup/lib/config/steps.ts +117 -117
  66. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  67. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  68. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  69. package/components/common/pages/backups/modals/restore/Restore.vue +417 -417
  70. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  71. package/components/common/pages/backups/modals/restore/disks/tableView/TableView.vue +102 -102
  72. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  73. package/components/common/pages/backups/modals/restore/lib/config/steps.ts +108 -108
  74. package/components/common/pages/backups/modals/restore/name/Name.vue +160 -160
  75. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  76. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  77. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  78. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  79. package/components/common/pages/backups/tools/Tools.vue +75 -75
  80. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
  81. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  82. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  83. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  84. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  85. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  86. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  87. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  88. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  89. package/components/common/select/radio/RadioGroup.vue +137 -137
  90. package/components/common/spiceConsole/Drawer.vue +381 -381
  91. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  92. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  93. package/components/common/tools/Actions.vue +207 -207
  94. package/components/common/treeView/TreeView.vue +52 -52
  95. package/components/common/vm/actions/add/Add.vue +5 -5
  96. package/components/common/vm/actions/add/New.vue +2 -2
  97. package/components/common/vm/actions/add/Old.vue +2 -2
  98. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  99. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  100. package/components/common/vm/actions/add/lib/config/steps.ts +2 -2
  101. package/components/common/vm/actions/clone/Clone.vue +5 -5
  102. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  103. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +5 -5
  104. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +2 -2
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/new/New.vue +1 -1
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -92
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  132. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  133. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  134. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  135. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  136. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  137. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  138. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  139. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  140. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  141. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  142. package/components/common/vm/actions/common/select/storage/new/New.vue +14 -14
  143. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  144. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  145. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  146. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  147. package/components/common/vmt/actions/add/Add.vue +5 -5
  148. package/components/common/vmt/actions/add/New.vue +3 -2
  149. package/components/common/vmt/actions/add/Old.vue +2 -2
  150. package/components/common/vmt/actions/add/lib/config/steps.ts +2 -2
  151. package/components/common/wizards/datastore/add/Add.vue +2 -2
  152. package/components/common/wizards/datastore/add/Old.vue +2 -2
  153. package/components/common/wizards/datastore/add/lib/config/steps.ts +2 -2
  154. package/components/common/wizards/datastore/add/lib/utils.ts +1 -1
  155. package/components/common/wizards/datastore/add/lib/validations.ts +3 -3
  156. package/components/common/wizards/datastore/add/steps/_local/Local.vue +1 -1
  157. package/components/common/wizards/datastore/add/steps/_local/createName/CreateName.vue +1 -1
  158. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigure.vue +1 -2
  159. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureNew.vue +1 -1
  160. package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureOld.vue +1 -1
  161. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDevice.vue +1 -1
  162. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +1 -1
  163. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +1 -1
  164. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  165. package/components/common/wizards/network/add/Add.vue +7 -7
  166. package/components/common/wizards/network/add/lib/config/steps.ts +5 -5
  167. package/components/common/wizards/network/add/steps/ConnectionSettings.vue +2 -2
  168. package/components/common/wizards/network/add/steps/IpFourSettings.vue +2 -2
  169. package/components/common/wizards/network/add/steps/PortProperties.vue +2 -2
  170. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +2 -2
  171. package/components/common/wizards/network/add/validations/connectionSettings.ts +5 -5
  172. package/components/common/wizards/network/add/validations/createStandardSwitch.ts +4 -4
  173. package/components/common/wizards/network/add/validations/ipFourSettings.ts +5 -5
  174. package/components/common/wizards/network/add/validations/networkValidation.ts +4 -4
  175. package/components/common/wizards/network/add/validations/physicalAdapter.ts +4 -4
  176. package/components/common/wizards/network/add/validations/portProperties.ts +2 -2
  177. package/components/common/wizards/network/add/validations/targetDevice.ts +5 -5
  178. package/components/common/wizards/vm/migrate/Migrate.vue +2 -2
  179. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  180. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  181. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  182. package/components/common/wizards/vm/migrate/select/targetServer/new/New.vue +1 -1
  183. package/components/common/wizards/vm/migrate/select/targetServer/targetServer.vue +1 -1
  184. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
  185. package/composables/productNameLocal.ts +30 -30
  186. package/composables/useAppVersion.ts +21 -21
  187. package/package.json +42 -42
  188. package/plugins/date.ts +233 -233
  189. package/plugins/panelStates.ts +70 -70
  190. package/plugins/text.ts +59 -59
  191. package/public/spice-console/lib/images/bitmap.js +203 -203
  192. package/public/spice-console/network/spicechannel.js +390 -390
  193. package/store/main/mutations.ts +7 -7
  194. package/store/main/state.ts +7 -7
package/CODE_STYLE.md CHANGED
@@ -1,109 +1,109 @@
1
- ![JavaScript](https://img.shields.io/badge/JavaScript-F7DF1E?style=for-the-badge&logo=javascript&logoColor=black)
2
- ## Javascript
3
-
4
- ### Название переменных
5
-
6
- Используем camelCase:
7
- ```javascript
8
- const theExample = 0
9
- ```
10
-
11
- Название переменных должно быть содержательным:
12
- ```javascript
13
- const desc = 'some description' // Плохо
14
-
15
- const description = 'some description' // Хорошо
16
- ```
17
-
18
- Если переменная типа boolean, используем префиксы is или has:
19
- ```javascript
20
- const isDisabled = true
21
-
22
- const hasName = false
23
- ```
24
-
25
- Приоритетно используем стрелочные функции:
26
- ```javascript
27
- const example = () => {...}
28
- ```
29
-
30
- ---
31
-
32
- ![TypeScript](https://img.shields.io/badge/TypeScript-007ACC?style=for-the-badge&logo=typescript&logoColor=white)
33
- ## Typescript
34
-
35
- ### Interface
36
- Название интерфейсов начинаем с префикса **I_** (также есть **API_**, **UI_**, подробно об этом написано в файле PROJECT_STRUCTURE.md):
37
- ```typescript
38
- interface I_Example
39
- ```
40
-
41
- ### Type
42
- Название типов начинаем с префикса **T_**:
43
- ```typescript
44
- type T_Example
45
- ```
46
-
47
- ### Enum
48
- Название enum начинаем с префикса **E_**:
49
- ```typescript
50
- enum E_Example
51
- ```
52
-
53
- P.S. Нужно писать как можно более понятные типы.
54
-
55
- ---
56
-
57
- ![Vue.js](https://img.shields.io/badge/Vue.js-35495E?style=for-the-badge&logo=vue.js&logoColor=4FC08D)
58
- ## Vue
59
-
60
- ### Название тегов
61
- Используем kebab-case:
62
- ```html
63
- <the-button>Button</the-button>
64
- ```
65
-
66
- ### Название тега
67
- Название тега не должно состоять из одного слова:
68
- ```html
69
- <example></example> // Плохо
70
-
71
- <the-example></the-example> // Хорошо
72
- ```
73
-
74
- ### Использование "the" в названии тега
75
- Если название тега, к примеру, icon, должно быть так:
76
- ```html
77
- <the-icon></the-icon>
78
- ```
79
-
80
- ### Использование самозакрывающихся тегов
81
- Если в тег ничего не передаем, то используем его как самозакрывающийся:
82
- ```html
83
- <the-icon/>
84
- ```
85
-
86
- ### Props / Emits
87
- Props пишем в kebab-case:
88
- ```html
89
- <the-example my-name="Name"/>
90
- ```
91
-
92
- Emits пишем в kebab-case, ключ первого аргумента всегда "event", а второго - "value":
93
- ```javascript
94
- const emits = defineEmits<{
95
- (event: 'change-name', value: string): void
96
- }>()
97
- ```
98
-
99
- ### Composition API
100
- Так как у нас используется Composition API, нужно весь код группировать по блокам:
101
- ```javascript
102
- const isShowModal = ref<boolean>(false)
103
- const toggleModal = (): void => isShowModal.value = !isShowModal.value
104
-
105
- const errors = ref<string[]>([])
106
- const updateErrors = (newErrors: string[]): void => {
107
- errors.value = newErrors
108
- }
109
- ```
1
+ ![JavaScript](https://img.shields.io/badge/JavaScript-F7DF1E?style=for-the-badge&logo=javascript&logoColor=black)
2
+ ## Javascript
3
+
4
+ ### Название переменных
5
+
6
+ Используем camelCase:
7
+ ```javascript
8
+ const theExample = 0
9
+ ```
10
+
11
+ Название переменных должно быть содержательным:
12
+ ```javascript
13
+ const desc = 'some description' // Плохо
14
+
15
+ const description = 'some description' // Хорошо
16
+ ```
17
+
18
+ Если переменная типа boolean, используем префиксы is или has:
19
+ ```javascript
20
+ const isDisabled = true
21
+
22
+ const hasName = false
23
+ ```
24
+
25
+ Приоритетно используем стрелочные функции:
26
+ ```javascript
27
+ const example = () => {...}
28
+ ```
29
+
30
+ ---
31
+
32
+ ![TypeScript](https://img.shields.io/badge/TypeScript-007ACC?style=for-the-badge&logo=typescript&logoColor=white)
33
+ ## Typescript
34
+
35
+ ### Interface
36
+ Название интерфейсов начинаем с префикса **I_** (также есть **API_**, **UI_**, подробно об этом написано в файле PROJECT_STRUCTURE.md):
37
+ ```typescript
38
+ interface I_Example
39
+ ```
40
+
41
+ ### Type
42
+ Название типов начинаем с префикса **T_**:
43
+ ```typescript
44
+ type T_Example
45
+ ```
46
+
47
+ ### Enum
48
+ Название enum начинаем с префикса **E_**:
49
+ ```typescript
50
+ enum E_Example
51
+ ```
52
+
53
+ P.S. Нужно писать как можно более понятные типы.
54
+
55
+ ---
56
+
57
+ ![Vue.js](https://img.shields.io/badge/Vue.js-35495E?style=for-the-badge&logo=vue.js&logoColor=4FC08D)
58
+ ## Vue
59
+
60
+ ### Название тегов
61
+ Используем kebab-case:
62
+ ```html
63
+ <the-button>Button</the-button>
64
+ ```
65
+
66
+ ### Название тега
67
+ Название тега не должно состоять из одного слова:
68
+ ```html
69
+ <example></example> // Плохо
70
+
71
+ <the-example></the-example> // Хорошо
72
+ ```
73
+
74
+ ### Использование "the" в названии тега
75
+ Если название тега, к примеру, icon, должно быть так:
76
+ ```html
77
+ <the-icon></the-icon>
78
+ ```
79
+
80
+ ### Использование самозакрывающихся тегов
81
+ Если в тег ничего не передаем, то используем его как самозакрывающийся:
82
+ ```html
83
+ <the-icon/>
84
+ ```
85
+
86
+ ### Props / Emits
87
+ Props пишем в kebab-case:
88
+ ```html
89
+ <the-example my-name="Name"/>
90
+ ```
91
+
92
+ Emits пишем в kebab-case, ключ первого аргумента всегда "event", а второго - "value":
93
+ ```javascript
94
+ const emits = defineEmits<{
95
+ (event: 'change-name', value: string): void
96
+ }>()
97
+ ```
98
+
99
+ ### Composition API
100
+ Так как у нас используется Composition API, нужно весь код группировать по блокам:
101
+ ```javascript
102
+ const isShowModal = ref<boolean>(false)
103
+ const toggleModal = (): void => isShowModal.value = !isShowModal.value
104
+
105
+ const errors = ref<string[]>([])
106
+ const updateErrors = (newErrors: string[]): void => {
107
+ errors.value = newErrors
108
+ }
109
+ ```