mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-24 23:34:51 +00:00 
			
		
		
		
	fix(ui): supported test email button in email smtp page (#13998)
* supported test email button in email smtp page * localization keys added
This commit is contained in:
		
							parent
							
								
									c92dabe004
								
							
						
					
					
						commit
						64bbdf5533
					
				| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "testfall", |     "test-case-lowercase": "testfall", | ||||||
|     "test-case-lowercase-plural": "testfälle", |     "test-case-lowercase-plural": "testfälle", | ||||||
|     "test-case-plural": "Testfälle", |     "test-case-plural": "Testfälle", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "{{entity}}-Test", |     "test-entity": "{{entity}}-Test", | ||||||
|     "test-plural": "Tests", |     "test-plural": "Tests", | ||||||
|     "test-suite": "Test-Suite", |     "test-suite": "Test-Suite", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "test case", |     "test-case-lowercase": "test case", | ||||||
|     "test-case-lowercase-plural": "test cases", |     "test-case-lowercase-plural": "test cases", | ||||||
|     "test-case-plural": "Test Cases", |     "test-case-plural": "Test Cases", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "Test {{entity}}", |     "test-entity": "Test {{entity}}", | ||||||
|     "test-plural": "Tests", |     "test-plural": "Tests", | ||||||
|     "test-suite": "Test Suite", |     "test-suite": "Test Suite", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "caso de prueba", |     "test-case-lowercase": "caso de prueba", | ||||||
|     "test-case-lowercase-plural": "test cases", |     "test-case-lowercase-plural": "test cases", | ||||||
|     "test-case-plural": "Casos de Prueba", |     "test-case-plural": "Casos de Prueba", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "Prueba {{entity}}", |     "test-entity": "Prueba {{entity}}", | ||||||
|     "test-plural": "Pruebas", |     "test-plural": "Pruebas", | ||||||
|     "test-suite": "Suite de Pruebas", |     "test-suite": "Suite de Pruebas", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "cas de test", |     "test-case-lowercase": "cas de test", | ||||||
|     "test-case-lowercase-plural": "cas de tests", |     "test-case-lowercase-plural": "cas de tests", | ||||||
|     "test-case-plural": "Cas de Tests", |     "test-case-plural": "Cas de Tests", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "Test {{entity}}", |     "test-entity": "Test {{entity}}", | ||||||
|     "test-plural": "Tests", |     "test-plural": "Tests", | ||||||
|     "test-suite": "Ensemble de Tests", |     "test-suite": "Ensemble de Tests", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "テストケース", |     "test-case-lowercase": "テストケース", | ||||||
|     "test-case-lowercase-plural": "test cases", |     "test-case-lowercase-plural": "test cases", | ||||||
|     "test-case-plural": "テストケース", |     "test-case-plural": "テストケース", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "テスト {{entity}}", |     "test-entity": "テスト {{entity}}", | ||||||
|     "test-plural": "テスト", |     "test-plural": "テスト", | ||||||
|     "test-suite": "テストスイート", |     "test-suite": "テストスイート", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "caso de teste", |     "test-case-lowercase": "caso de teste", | ||||||
|     "test-case-lowercase-plural": "test cases", |     "test-case-lowercase-plural": "test cases", | ||||||
|     "test-case-plural": "Casos de Teste", |     "test-case-plural": "Casos de Teste", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "Teste {{entity}}", |     "test-entity": "Teste {{entity}}", | ||||||
|     "test-plural": "Testes", |     "test-plural": "Testes", | ||||||
|     "test-suite": "Conjunto de Testes", |     "test-suite": "Conjunto de Testes", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "test case", |     "test-case-lowercase": "test case", | ||||||
|     "test-case-lowercase-plural": "test cases", |     "test-case-lowercase-plural": "test cases", | ||||||
|     "test-case-plural": "Test Cases", |     "test-case-plural": "Test Cases", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "Тест {{entity}}", |     "test-entity": "Тест {{entity}}", | ||||||
|     "test-plural": "Тесты", |     "test-plural": "Тесты", | ||||||
|     "test-suite": "Тестирование", |     "test-suite": "Тестирование", | ||||||
|  | |||||||
| @ -1035,6 +1035,7 @@ | |||||||
|     "test-case-lowercase": "测试用例", |     "test-case-lowercase": "测试用例", | ||||||
|     "test-case-lowercase-plural": "测试用例", |     "test-case-lowercase-plural": "测试用例", | ||||||
|     "test-case-plural": "测试用例", |     "test-case-plural": "测试用例", | ||||||
|  |     "test-email": "Test Email", | ||||||
|     "test-entity": "测试{{entity}}", |     "test-entity": "测试{{entity}}", | ||||||
|     "test-plural": "测试", |     "test-plural": "测试", | ||||||
|     "test-suite": "质控测试集", |     "test-suite": "质控测试集", | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| import Icon from '@ant-design/icons/lib/components/Icon'; | import Icon from '@ant-design/icons/lib/components/Icon'; | ||||||
| import { Button, Col, Row, Skeleton, Typography } from 'antd'; | import { Button, Col, Row, Skeleton, Space, Typography } from 'antd'; | ||||||
| import { AxiosError } from 'axios'; | import { AxiosError } from 'axios'; | ||||||
| import { isBoolean, isEmpty, isNumber, isUndefined } from 'lodash'; | import { isBoolean, isEmpty, isNumber, isUndefined } from 'lodash'; | ||||||
| import React, { useCallback, useEffect, useMemo, useState } from 'react'; | import React, { useCallback, useEffect, useMemo, useState } from 'react'; | ||||||
| @ -25,9 +25,12 @@ import { ROUTES } from '../../constants/constants'; | |||||||
| import { ERROR_PLACEHOLDER_TYPE } from '../../enums/common.enum'; | import { ERROR_PLACEHOLDER_TYPE } from '../../enums/common.enum'; | ||||||
| import { SMTPSettings } from '../../generated/email/smtpSettings'; | import { SMTPSettings } from '../../generated/email/smtpSettings'; | ||||||
| import { SettingType } from '../../generated/settings/settings'; | import { SettingType } from '../../generated/settings/settings'; | ||||||
| import { getSettingsConfigFromConfigType } from '../../rest/settingConfigAPI'; | import { | ||||||
|  |   getSettingsConfigFromConfigType, | ||||||
|  |   testEmailConnection, | ||||||
|  | } from '../../rest/settingConfigAPI'; | ||||||
| import { getEmailConfigFieldLabels } from '../../utils/EmailConfigUtils'; | import { getEmailConfigFieldLabels } from '../../utils/EmailConfigUtils'; | ||||||
| import { showErrorToast } from '../../utils/ToastUtils'; | import { showErrorToast, showSuccessToast } from '../../utils/ToastUtils'; | ||||||
| 
 | 
 | ||||||
| function EmailConfigSettingsPage() { | function EmailConfigSettingsPage() { | ||||||
|   const { t } = useTranslation(); |   const { t } = useTranslation(); | ||||||
| @ -61,6 +64,18 @@ function EmailConfigSettingsPage() { | |||||||
|     history.push(ROUTES.SETTINGS_EDIT_EMAIL_CONFIG); |     history.push(ROUTES.SETTINGS_EDIT_EMAIL_CONFIG); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  |   const handleTestEmailConnection = async () => { | ||||||
|  |     try { | ||||||
|  |       const res = await testEmailConnection( | ||||||
|  |         emailConfigValues?.senderMail ?? '' | ||||||
|  |       ); | ||||||
|  | 
 | ||||||
|  |       showSuccessToast(res.data); | ||||||
|  |     } catch (error) { | ||||||
|  |       showErrorToast(error as AxiosError); | ||||||
|  |     } | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   const configValues = useMemo(() => { |   const configValues = useMemo(() => { | ||||||
|     if (isUndefined(emailConfigValues)) { |     if (isUndefined(emailConfigValues)) { | ||||||
|       return null; |       return null; | ||||||
| @ -139,17 +154,23 @@ function EmailConfigSettingsPage() { | |||||||
|             /> |             /> | ||||||
|           </Col> |           </Col> | ||||||
|           <Col> |           <Col> | ||||||
|             <Button |             <Space> | ||||||
|               icon={ |               <Button type="primary" onClick={handleTestEmailConnection}> | ||||||
|                 !isUndefined(emailConfigValues) && ( |                 {t('label.test-email')} | ||||||
|                   <Icon component={IconEdit} size={12} /> |               </Button> | ||||||
|                 ) | 
 | ||||||
|               } |               <Button | ||||||
|               onClick={handleEditClick}> |                 icon={ | ||||||
|               {isUndefined(emailConfigValues) |                   !isUndefined(emailConfigValues) && ( | ||||||
|                 ? t('label.add') |                     <Icon component={IconEdit} size={12} /> | ||||||
|                 : t('label.edit')} |                   ) | ||||||
|             </Button> |                 } | ||||||
|  |                 onClick={handleEditClick}> | ||||||
|  |                 {isUndefined(emailConfigValues) | ||||||
|  |                   ? t('label.add') | ||||||
|  |                   : t('label.edit')} | ||||||
|  |               </Button> | ||||||
|  |             </Space> | ||||||
|           </Col> |           </Col> | ||||||
|         </Row> |         </Row> | ||||||
|       </Col> |       </Col> | ||||||
|  | |||||||
| @ -48,3 +48,17 @@ export const getLoginConfig = async () => { | |||||||
| 
 | 
 | ||||||
|   return response.data; |   return response.data; | ||||||
| }; | }; | ||||||
|  | 
 | ||||||
|  | export const testEmailConnection = async (email: string) => { | ||||||
|  |   const configOptions = { | ||||||
|  |     headers: { 'Content-type': 'application/json' }, | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   const response = await axiosClient.put<string>( | ||||||
|  |     '/system/email/test', | ||||||
|  |     email, | ||||||
|  |     configOptions | ||||||
|  |   ); | ||||||
|  | 
 | ||||||
|  |   return response; | ||||||
|  | }; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Ashish Gupta
						Ashish Gupta