bfg-common 1.5.662 → 1.5.664

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 (106) 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 +3778 -3769
  7. package/assets/localization/local_en.json +3782 -3773
  8. package/assets/localization/local_hy.json +3782 -3773
  9. package/assets/localization/local_kk.json +11 -2
  10. package/assets/localization/local_ru.json +11 -2
  11. package/assets/localization/local_zh.json +3779 -3770
  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/theHeader/TheHeaderNew.vue +315 -315
  24. package/components/common/layout/theHeader/TheHeaderOld.vue +262 -262
  25. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  26. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  27. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +99 -99
  28. package/components/common/layout/theHeader/userMenu/modals/changePassword/New.vue +193 -193
  29. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +144 -144
  30. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  31. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Old.vue +210 -210
  32. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Security.vue +31 -31
  33. package/components/common/pages/backups/DetailView.vue +52 -52
  34. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  35. package/components/common/pages/backups/modals/Modals.vue +243 -243
  36. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  37. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  38. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  39. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  40. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  41. package/components/common/pages/hardwareHealth/toolsPanel/lib/config/actionsPanel.ts +4 -4
  42. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  43. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  44. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  45. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  46. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  47. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  48. package/components/common/qrcode/Qrcode.vue +56 -0
  49. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  50. package/components/common/select/radio/RadioGroup.vue +137 -137
  51. package/components/common/spiceConsole/Drawer.vue +420 -420
  52. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  53. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  54. package/components/common/tools/Actions.vue +207 -207
  55. package/components/common/treeView/TreeView.vue +52 -52
  56. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  57. package/components/common/vm/actions/clone/new/New.vue +438 -438
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  60. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  61. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  62. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  63. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  64. package/components/common/vm/actions/common/select/options/Old.vue +110 -110
  65. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  66. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  67. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  68. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  69. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  70. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  71. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  72. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  73. package/components/common/wizards/common/compatibility/New.vue +99 -99
  74. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  75. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  76. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  77. package/components/common/wizards/common/steps/name/New.vue +221 -221
  78. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  79. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  80. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  81. package/components/common/wizards/datastore/add/Add.vue +228 -228
  82. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  83. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  84. package/composables/useAppVersion.ts +21 -21
  85. package/composables/useLocal.ts +6 -6
  86. package/composables/useLocalCommon.ts +39 -39
  87. package/package.json +3 -2
  88. package/plugins/console.ts +21 -21
  89. package/plugins/mouse.ts +21 -21
  90. package/plugins/panelStates.ts +70 -70
  91. package/plugins/text.ts +59 -59
  92. package/public/spice-console/application/clientgui.js +854 -854
  93. package/public/spice-console/application/packetfactory.js +211 -211
  94. package/public/spice-console/application/virtualmouse.js +147 -147
  95. package/public/spice-console/lib/images/bitmap.js +203 -203
  96. package/public/spice-console/network/spicechannel.js +440 -440
  97. package/public/spice-console/process/cursorprocess.js +128 -128
  98. package/public/spice-console/process/inputprocess.js +227 -227
  99. package/public/spice-console/process/mainprocess.js +212 -212
  100. package/public/spice-console/run.js +210 -210
  101. package/store/main/mutations.ts +7 -7
  102. package/store/main/state.ts +7 -7
  103. package/store/tasks/actions.ts +165 -165
  104. package/store/tasks/mappers/recentTasks.ts +123 -123
  105. package/store/tasks/mutations.ts +82 -82
  106. package/components/common/qr/Qr.vue +0 -57
@@ -1,79 +1,79 @@
1
- <template>
2
- <Teleport to="body">
3
- <common-layout-the-header-help-menu-about-new
4
- v-if="isNewView"
5
- :title="title"
6
- :subtitle="subtitle"
7
- :about-heading-text="aboutHeadingText"
8
- :about-desc-one="aboutDesc1"
9
- :about-desc-second="aboutDesc2"
10
- :project-name="props.projectName"
11
- :url="companyWebSitePath"
12
- @hide="emits('hide')"
13
- />
14
-
15
- <common-layout-the-header-help-menu-about-old
16
- v-else
17
- :title="title"
18
- :subtitle="subtitle"
19
- :about-heading-text="aboutHeadingText"
20
- :about-desc-one="aboutDesc1"
21
- :about-desc-second="aboutDesc2"
22
- :project-name="props.projectName"
23
- :url="companyWebSitePath"
24
- @hide="emits('hide')"
25
- />
26
- </Teleport>
27
- </template>
28
-
29
- <script lang="ts" setup>
30
- import type { UI_I_Localization } from '~/lib/models/interfaces'
31
-
32
- const props = defineProps<{
33
- version: string
34
- projectName: string
35
- }>()
36
- const emits = defineEmits<{
37
- (event: 'hide'): void
38
- }>()
39
-
40
- const localization = computed<UI_I_Localization>(() => useLocal())
41
- const { $store }: any = useNuxtApp()
42
- const config = useRuntimeConfig()
43
-
44
- const companyName = computed<string>(
45
- () => config.public[`COMPANY_NAME_${useEnvLanguage()}`]
46
- )
47
- const brandName = computed<string>(
48
- () => config.public[`TRADEMARK_${useEnvLanguage()}`]
49
- )
50
-
51
- const companyWebSitePath = ref<string>(config.public.SUPPORT_SITE)
52
-
53
- const title = computed<string>(() => `${brandName.value}® ${props.projectName}`)
54
- const subtitle = computed<string>(() =>
55
- localization.value.layout.aboutWebClientVersion
56
- .replace('{0}', props.projectName)
57
- .replace('{1}', props.version)
58
- )
59
-
60
- const aboutHeadingText = computed<string>(() =>
61
- localization.value.layout.aboutHeading.replace(
62
- '{companyName}',
63
- companyName.value
64
- ).replace(
65
- '{year}',
66
- new Date().getFullYear() + ''
67
- )
68
- )
69
-
70
- const aboutDesc = computed<string[]>(() =>
71
- localization.value.layout.aboutDesc
72
- .replaceAll('{companyName}', companyName.value)
73
- .replaceAll('{trademark}', brandName.value).split('{url}')
74
- )
75
- const aboutDesc1 = computed<string>(() => aboutDesc.value[0])
76
- const aboutDesc2 = computed<string>(() => aboutDesc.value[1])
77
-
78
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
79
- </script>
1
+ <template>
2
+ <Teleport to="body">
3
+ <common-layout-the-header-help-menu-about-new
4
+ v-if="isNewView"
5
+ :title="title"
6
+ :subtitle="subtitle"
7
+ :about-heading-text="aboutHeadingText"
8
+ :about-desc-one="aboutDesc1"
9
+ :about-desc-second="aboutDesc2"
10
+ :project-name="props.projectName"
11
+ :url="companyWebSitePath"
12
+ @hide="emits('hide')"
13
+ />
14
+
15
+ <common-layout-the-header-help-menu-about-old
16
+ v-else
17
+ :title="title"
18
+ :subtitle="subtitle"
19
+ :about-heading-text="aboutHeadingText"
20
+ :about-desc-one="aboutDesc1"
21
+ :about-desc-second="aboutDesc2"
22
+ :project-name="props.projectName"
23
+ :url="companyWebSitePath"
24
+ @hide="emits('hide')"
25
+ />
26
+ </Teleport>
27
+ </template>
28
+
29
+ <script lang="ts" setup>
30
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
31
+
32
+ const props = defineProps<{
33
+ version: string
34
+ projectName: string
35
+ }>()
36
+ const emits = defineEmits<{
37
+ (event: 'hide'): void
38
+ }>()
39
+
40
+ const localization = computed<UI_I_Localization>(() => useLocal())
41
+ const { $store }: any = useNuxtApp()
42
+ const config = useRuntimeConfig()
43
+
44
+ const companyName = computed<string>(
45
+ () => config.public[`COMPANY_NAME_${useEnvLanguage()}`]
46
+ )
47
+ const brandName = computed<string>(
48
+ () => config.public[`TRADEMARK_${useEnvLanguage()}`]
49
+ )
50
+
51
+ const companyWebSitePath = ref<string>(config.public.SUPPORT_SITE)
52
+
53
+ const title = computed<string>(() => `${brandName.value}® ${props.projectName}`)
54
+ const subtitle = computed<string>(() =>
55
+ localization.value.layout.aboutWebClientVersion
56
+ .replace('{0}', props.projectName)
57
+ .replace('{1}', props.version)
58
+ )
59
+
60
+ const aboutHeadingText = computed<string>(() =>
61
+ localization.value.layout.aboutHeading.replace(
62
+ '{companyName}',
63
+ companyName.value
64
+ ).replace(
65
+ '{year}',
66
+ new Date().getFullYear() + ''
67
+ )
68
+ )
69
+
70
+ const aboutDesc = computed<string[]>(() =>
71
+ localization.value.layout.aboutDesc
72
+ .replaceAll('{companyName}', companyName.value)
73
+ .replaceAll('{trademark}', brandName.value).split('{url}')
74
+ )
75
+ const aboutDesc1 = computed<string>(() => aboutDesc.value[0])
76
+ const aboutDesc2 = computed<string>(() => aboutDesc.value[1])
77
+
78
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
79
+ </script>
@@ -1,79 +1,79 @@
1
- <template>
2
- <Teleport to="body">
3
- <atoms-modal :title="props.title" show width="864px" test-id="about-modal">
4
- <template #modalHeader>
5
- <div class="flex-align-center">
6
- <h3 class="modal-title">{{ brandName }}® {{ props.projectName }}</h3>
7
- <span class="separator" />
8
- <h4 class="secondary-title">
9
- {{ props.subtitle }}
10
- </h4>
11
- </div>
12
- <button id="about-modal-button-close" class="close">
13
- <atoms-the-icon
14
- data-id="about-modal-button-close-icon"
15
- class="close-icon"
16
- name="close"
17
- @click="() => emits('hide')"
18
- />
19
- </button>
20
- </template>
21
-
22
- <template #modalBody>
23
- <div class="about-vsphere-dialog-legal-section">
24
- <p>{{ props.aboutHeadingText }}</p>
25
- <p>{{ localization.layout.aboutSubtitle }}</p>
26
- </div>
27
-
28
- <div class="about-vsphere-dialog-legal-section description">
29
- {{ props.aboutDescOne }}<a
30
- id="about-description-link"
31
- :href="url"
32
- data-id="about-description-link"
33
- target="_blank"
34
- >{{ props.url }}</a
35
- >{{ props.aboutDescSecond }}
36
- </div>
37
- </template>
38
-
39
- <template #modalFooter>
40
- <span></span>
41
- </template>
42
- </atoms-modal>
43
- </Teleport>
44
- </template>
45
-
46
- <script lang="ts" setup>
47
- import type { UI_I_Localization } from '~/lib/models/interfaces'
48
-
49
- const props = defineProps<{
50
- title: string
51
- subtitle: string
52
- aboutHeadingText: string
53
- aboutDescOne: string
54
- aboutDescSecond: string
55
- projectName: string
56
- url: string
57
- }>()
58
- const emits = defineEmits<{
59
- (event: 'hide'): void
60
- }>()
61
-
62
- const localization = computed<UI_I_Localization>(() => useLocal())
63
- const config = useRuntimeConfig()
64
-
65
- const brandName = computed<string>(
66
- () => config.public[`TRADEMARK_${useEnvLanguage()}`]
67
- )
68
- </script>
69
-
70
- <style lang="scss" scoped>
71
- .modal-title {
72
- color: var(--main-color-mode);
73
- }
74
- .description {
75
- padding-top: 10px;
76
- font-size: 13px;
77
- line-height: 19px;
78
- }
79
- </style>
1
+ <template>
2
+ <Teleport to="body">
3
+ <atoms-modal :title="props.title" show width="864px" test-id="about-modal">
4
+ <template #modalHeader>
5
+ <div class="flex-align-center">
6
+ <h3 class="modal-title">{{ brandName }}® {{ props.projectName }}</h3>
7
+ <span class="separator" />
8
+ <h4 class="secondary-title">
9
+ {{ props.subtitle }}
10
+ </h4>
11
+ </div>
12
+ <button id="about-modal-button-close" class="close">
13
+ <atoms-the-icon
14
+ data-id="about-modal-button-close-icon"
15
+ class="close-icon"
16
+ name="close"
17
+ @click="() => emits('hide')"
18
+ />
19
+ </button>
20
+ </template>
21
+
22
+ <template #modalBody>
23
+ <div class="about-vsphere-dialog-legal-section">
24
+ <p>{{ props.aboutHeadingText }}</p>
25
+ <p>{{ localization.layout.aboutSubtitle }}</p>
26
+ </div>
27
+
28
+ <div class="about-vsphere-dialog-legal-section description">
29
+ {{ props.aboutDescOne }}<a
30
+ id="about-description-link"
31
+ :href="url"
32
+ data-id="about-description-link"
33
+ target="_blank"
34
+ >{{ props.url }}</a
35
+ >{{ props.aboutDescSecond }}
36
+ </div>
37
+ </template>
38
+
39
+ <template #modalFooter>
40
+ <span></span>
41
+ </template>
42
+ </atoms-modal>
43
+ </Teleport>
44
+ </template>
45
+
46
+ <script lang="ts" setup>
47
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
48
+
49
+ const props = defineProps<{
50
+ title: string
51
+ subtitle: string
52
+ aboutHeadingText: string
53
+ aboutDescOne: string
54
+ aboutDescSecond: string
55
+ projectName: string
56
+ url: string
57
+ }>()
58
+ const emits = defineEmits<{
59
+ (event: 'hide'): void
60
+ }>()
61
+
62
+ const localization = computed<UI_I_Localization>(() => useLocal())
63
+ const config = useRuntimeConfig()
64
+
65
+ const brandName = computed<string>(
66
+ () => config.public[`TRADEMARK_${useEnvLanguage()}`]
67
+ )
68
+ </script>
69
+
70
+ <style lang="scss" scoped>
71
+ .modal-title {
72
+ color: var(--main-color-mode);
73
+ }
74
+ .description {
75
+ padding-top: 10px;
76
+ font-size: 13px;
77
+ line-height: 19px;
78
+ }
79
+ </style>
@@ -1,99 +1,99 @@
1
- <template>
2
- <component
3
- :is="currentComponent"
4
- v-model="form"
5
- :subtitle="props.hostname"
6
- :project="props.project"
7
- :first-time="props.firstTime"
8
- @change-password="onChangePassword"
9
- @hide="onHideModal"
10
- />
11
- </template>
12
-
13
- <script setup lang="ts">
14
- import type { UI_I_Localization } from '~/lib/models/interfaces'
15
- import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
16
- import type {
17
- UI_I_ChangePasswordBodyRequest, UI_I_ChangePasswordFirstTimeBodyRequest,
18
- UI_I_ChangePasswordForm,
19
- } from '~/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces'
20
- import type { UI_T_Project } from '~/lib/models/types'
21
- // import {} from '#build/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces'
22
-
23
- const props = withDefaults(
24
- defineProps<{
25
- hostname: string
26
- project: UI_T_Project
27
- firstTime?: boolean
28
- }>(),
29
- { firstTime: false }
30
- )
31
- const isShowModalLocal = defineModel<boolean>({ required: true })
32
-
33
- const localization = computed<UI_I_Localization>(() => useLocal())
34
- const { $store }: any = useNuxtApp()
35
-
36
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
37
- const currentComponent = computed(() =>
38
- isNewView.value
39
- ? defineAsyncComponent(() => import('./New.vue'))
40
- : defineAsyncComponent(() => import('./Old.vue'))
41
- )
42
-
43
- const form = ref<UI_I_ChangePasswordForm>({
44
- current_password: '',
45
- new_password: '',
46
- confirm_password: '',
47
- })
48
-
49
- const onChangePassword = async (): Promise<void> => {
50
- const { current_password, new_password } = form.value
51
-
52
- onHideModal()
53
-
54
- let sendData: UI_I_ChangePasswordBodyRequest | UI_I_ChangePasswordFirstTimeBodyRequest = {
55
- current_password,
56
- new_password,
57
- }
58
-
59
- let url = ''
60
- if (props.project === 'sphere') {
61
- const { id } = useLocalStorage('userData')
62
-
63
- url = `ui/users/${id}/passwd`
64
- } else if (props.project === 'procurator') {
65
- url = '/ui/passwd'
66
- }
67
-
68
- if (props.firstTime) {
69
- sendData = {
70
- password: new_password
71
- }
72
- url = 'ui/users/current/change_password'
73
- }
74
-
75
- const { error } = await useMyFetch<never, API_UI_I_Error>(url, {
76
- method: 'POST',
77
- body: sendData,
78
- key: Date.now().toString(),
79
- })
80
-
81
- if (error.value?.data && error.value.data.error_code !== 0) {
82
- const errorText = error.value.data?.error_message || error.value.data
83
-
84
- $store.dispatch('main/A_SHOW_NOTIFICATION', {
85
- status: 'error',
86
- headline: localization.value.common.operationFailed,
87
- messages: [
88
- {
89
- title: localization.value.common.error,
90
- descriptions: [errorText],
91
- },
92
- ],
93
- })
94
- }
95
- }
96
- const onHideModal = (): void => {
97
- isShowModalLocal.value = false
98
- }
99
- </script>
1
+ <template>
2
+ <component
3
+ :is="currentComponent"
4
+ v-model="form"
5
+ :subtitle="props.hostname"
6
+ :project="props.project"
7
+ :first-time="props.firstTime"
8
+ @change-password="onChangePassword"
9
+ @hide="onHideModal"
10
+ />
11
+ </template>
12
+
13
+ <script setup lang="ts">
14
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
15
+ import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
16
+ import type {
17
+ UI_I_ChangePasswordBodyRequest, UI_I_ChangePasswordFirstTimeBodyRequest,
18
+ UI_I_ChangePasswordForm,
19
+ } from '~/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces'
20
+ import type { UI_T_Project } from '~/lib/models/types'
21
+ // import {} from '#build/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces'
22
+
23
+ const props = withDefaults(
24
+ defineProps<{
25
+ hostname: string
26
+ project: UI_T_Project
27
+ firstTime?: boolean
28
+ }>(),
29
+ { firstTime: false }
30
+ )
31
+ const isShowModalLocal = defineModel<boolean>({ required: true })
32
+
33
+ const localization = computed<UI_I_Localization>(() => useLocal())
34
+ const { $store }: any = useNuxtApp()
35
+
36
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
37
+ const currentComponent = computed(() =>
38
+ isNewView.value
39
+ ? defineAsyncComponent(() => import('./New.vue'))
40
+ : defineAsyncComponent(() => import('./Old.vue'))
41
+ )
42
+
43
+ const form = ref<UI_I_ChangePasswordForm>({
44
+ current_password: '',
45
+ new_password: '',
46
+ confirm_password: '',
47
+ })
48
+
49
+ const onChangePassword = async (): Promise<void> => {
50
+ const { current_password, new_password } = form.value
51
+
52
+ onHideModal()
53
+
54
+ let sendData: UI_I_ChangePasswordBodyRequest | UI_I_ChangePasswordFirstTimeBodyRequest = {
55
+ current_password,
56
+ new_password,
57
+ }
58
+
59
+ let url = ''
60
+ if (props.project === 'sphere') {
61
+ const { id } = useLocalStorage('userData')
62
+
63
+ url = `ui/users/${id}/passwd`
64
+ } else if (props.project === 'procurator') {
65
+ url = '/ui/passwd'
66
+ }
67
+
68
+ if (props.firstTime) {
69
+ sendData = {
70
+ password: new_password
71
+ }
72
+ url = 'ui/users/current/change_password'
73
+ }
74
+
75
+ const { error } = await useMyFetch<never, API_UI_I_Error>(url, {
76
+ method: 'POST',
77
+ body: sendData,
78
+ key: Date.now().toString(),
79
+ })
80
+
81
+ if (error.value?.data && error.value.data.error_code !== 0) {
82
+ const errorText = error.value.data?.error_message || error.value.data
83
+
84
+ $store.dispatch('main/A_SHOW_NOTIFICATION', {
85
+ status: 'error',
86
+ headline: localization.value.common.operationFailed,
87
+ messages: [
88
+ {
89
+ title: localization.value.common.error,
90
+ descriptions: [errorText],
91
+ },
92
+ ],
93
+ })
94
+ }
95
+ }
96
+ const onHideModal = (): void => {
97
+ isShowModalLocal.value = false
98
+ }
99
+ </script>