bfg-common 1.5.214 → 1.5.216

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 (181) 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/perPage/PerPage.vue +58 -58
  8. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  9. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  10. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  11. package/components/common/backup/storage/actions/add/Add.vue +51 -36
  12. package/components/common/backup/storage/actions/add/temp/Add.vue +527 -508
  13. package/components/common/backup/storage/actions/add/temp/lib/config/stepItems.ts +236 -203
  14. package/components/common/backup/storage/actions/add/temp/lib/utils.ts +6 -5
  15. package/components/common/backup/storage/actions/add/temp/local/Local.vue +49 -31
  16. package/components/common/backup/storage/actions/add/temp/local/accessibility/Accessibility.vue +104 -0
  17. package/components/common/backup/storage/actions/add/temp/local/accessibility/lib/config/tabsPannel.ts +25 -0
  18. package/components/common/backup/storage/actions/add/temp/local/accessibility/lib/models/interfaces.ts +9 -0
  19. package/components/common/backup/storage/actions/add/temp/local/accessibility/lib/models/types.ts +5 -0
  20. package/components/common/backup/storage/actions/add/temp/local/accessibility/tablesView/TablesView.vue +141 -0
  21. package/components/common/backup/storage/actions/add/temp/local/accessibility/tablesView/lib/config/compatibleTable.ts +62 -0
  22. package/components/common/backup/storage/actions/add/temp/local/accessibility/tablesView/lib/config/hostsTableItems.ts +27 -0
  23. package/components/common/backup/storage/actions/add/temp/local/accessibility/tablesView/lib/config/incompatibleTable.ts +68 -0
  24. package/components/common/backup/storage/actions/add/temp/local/accessibility/tablesView/lib/config/tableKeys.ts +15 -0
  25. package/components/common/backup/storage/actions/add/temp/local/createName/CreateName.vue +160 -158
  26. package/components/common/backup/storage/actions/add/temp/nfs/Nfs.vue +106 -106
  27. package/components/common/backup/storage/actions/add/temp/nfs/accessibility/lib/models/types.ts +2 -2
  28. package/components/common/backup/storage/actions/add/temp/nfs/accessibility/tablesView/lib/config/hostsTableItems.ts +1 -27
  29. package/components/common/backup/storage/actions/add/temp/nfs/accessibility/tablesView/lib/config/tableKeys.ts +2 -2
  30. package/components/common/backup/storage/actions/add/temp/nfs/configuration/Configuration.vue +469 -469
  31. package/components/common/backup/storage/actions/add/temp/readyComplete/ReadyComplete.vue +1 -1
  32. package/components/common/backup/storage/actions/add/temp/readyComplete/lib/config/propertiesDetails.ts +33 -7
  33. package/components/common/backup/storage/actions/add/temp/samba/accessibility/lib/models/types.ts +2 -2
  34. package/components/common/backup/storage/actions/add/temp/samba/accessibility/tablesView/lib/config/tableKeys.ts +2 -2
  35. package/components/common/backup/storage/actions/add/temp/samba/configuration/Configuration.vue +1 -1
  36. package/components/common/backup/storage/actions/add/temp/sharedStorm/SharedStorm.vue +106 -80
  37. package/components/common/backup/storage/actions/add/temp/types/Types.vue +3 -2
  38. package/components/common/backup/storage/actions/add/temp/types/lib/config/typeOptions.ts +25 -15
  39. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  40. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  41. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  42. package/components/common/browse/lib/models/interfaces.ts +5 -5
  43. package/components/common/context/lib/models/interfaces.ts +31 -31
  44. package/components/common/diagramMain/DiagramMain.vue +897 -897
  45. package/components/common/diagramMain/Header.vue +214 -214
  46. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  47. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  48. package/components/common/diagramMain/lib/models/types.ts +21 -21
  49. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  50. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  51. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  52. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  53. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  54. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  55. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  56. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  57. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  58. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  59. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  60. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  61. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  62. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  63. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  64. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  65. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  66. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  67. package/components/common/diagramMain/port/Ports.vue +47 -47
  68. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  69. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  70. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  71. package/components/common/pages/home/headline/Headline.vue +45 -45
  72. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  73. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  74. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  75. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  76. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  77. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  78. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  79. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  80. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  81. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  82. package/components/common/pages/packages/Packages.vue +208 -208
  83. package/components/common/pages/shortcuts/block/BlockNew.vue +7 -2
  84. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  85. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  86. package/components/common/recursionTree/RecursionTree.vue +223 -223
  87. package/components/common/select/button/ButtonDropdown.vue +108 -108
  88. package/components/common/spiceConsole/Drawer.vue +377 -377
  89. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  90. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  91. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  92. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  93. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  94. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  95. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  96. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +337 -337
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +480 -480
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +190 -190
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +237 -237
  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/cpu/tooltip/TooltipNew.vue +154 -154
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +154 -154
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +382 -382
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +151 -151
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +73 -73
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +40 -40
  133. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  134. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +106 -106
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +81 -81
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +67 -67
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +149 -149
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  148. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  149. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  150. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  151. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  152. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  153. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  154. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  155. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  156. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  157. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  158. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  159. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  160. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  161. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  162. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  163. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  164. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  165. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  166. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  167. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  168. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -137
  169. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  170. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  171. package/composables/productNameLocal.ts +30 -30
  172. package/composables/useAppVersion.ts +21 -21
  173. package/package.json +1 -1
  174. package/plugins/date.ts +233 -233
  175. package/public/spice-console/lib/images/bitmap.js +203 -203
  176. package/public/spice-console/network/spicechannel.js +387 -387
  177. package/store/main/mutations.ts +7 -7
  178. package/store/main/state.ts +7 -7
  179. package/store/tasks/mappers/recentTasks.ts +64 -64
  180. package/components/common/backup/storage/actions/add/temp/sharedStorm/createName/CreateName.vue +0 -156
  181. package/components/common/backup/storage/actions/add/temp/sharedStorm/createName/lib/config/defaultForm.ts +0 -15
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
+ ```