| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | import React, { Component, Fragment } from 'react'; | 
					
						
							|  |  |  | import { Utils } from '../../../utils/utils'; | 
					
						
							|  |  |  | import { seafileAPI } from '../../../utils/seafile-api'; | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  | import { gettext, mediaUrl, logoPath, orgID, orgEnableAdminCustomLogo, orgEnableAdminCustomName, enableMultiADFS } from '../../../utils/constants'; | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | import Loading from '../../../components/loading'; | 
					
						
							|  |  |  | import toaster from '../../../components/toast'; | 
					
						
							|  |  |  | import MainPanelTopbar from '../main-panel-topbar'; | 
					
						
							|  |  |  | import Section from './section'; | 
					
						
							|  |  |  | import InputItem from './input-item'; | 
					
						
							|  |  |  | import FileItem from './file-item'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import '../../../css/system-admin-web-settings.css'; | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  | import CheckboxItem from '../../sys-admin/web-settings/checkbox-item'; | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  | const { sysEnableUserCleanTrash, sysEnableEncryptedLibrary } = window.org.pageOptions; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  | class OrgWebSettings extends Component { | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   constructor(props) { | 
					
						
							|  |  |  |     super(props); | 
					
						
							|  |  |  |     this.state = { | 
					
						
							|  |  |  |       loading: true, | 
					
						
							|  |  |  |       errorMsg: '', | 
					
						
							|  |  |  |       config_dict: null, | 
					
						
							| 
									
										
										
										
											2023-10-24 14:09:57 +08:00
										 |  |  |       logoPath: logoPath, | 
					
						
							| 
									
										
										
										
											2023-09-13 08:40:50 +08:00
										 |  |  |       file_ext_white_list: '', | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  |       force_adfs_login: false, | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |       disable_org_encrypted_library: false, | 
					
						
							|  |  |  |       disable_org_user_clean_trash: false | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |     }; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-18 11:58:42 +08:00
										 |  |  |   componentDidMount() { | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |     seafileAPI.orgAdminGetOrgInfo().then((res) => { | 
					
						
							|  |  |  |       this.setState({ | 
					
						
							|  |  |  |         loading: false, | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |         config_dict: res.data, | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  |         file_ext_white_list: res.data.file_ext_white_list, | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |         force_adfs_login: res.data.force_adfs_login, | 
					
						
							|  |  |  |         disable_org_encrypted_library: res.data.disable_org_encrypted_library, | 
					
						
							|  |  |  |         disable_org_user_clean_trash: res.data.disable_org_user_clean_trash | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |       }); | 
					
						
							|  |  |  |     }).catch((error) => { | 
					
						
							|  |  |  |       this.setState({ | 
					
						
							|  |  |  |         loading: false, | 
					
						
							|  |  |  |         errorMsg: Utils.getErrorMsg(error, true) // true: show login tip if 403
 | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-18 11:58:42 +08:00
										 |  |  |   updateName = (key, newOrgName) => { | 
					
						
							| 
									
										
										
										
											2023-09-13 08:40:50 +08:00
										 |  |  |     seafileAPI.orgAdminUpdateName(orgID, newOrgName).then((res) => { | 
					
						
							|  |  |  |       this.setState({ | 
					
						
							|  |  |  |         config_dict: res.data | 
					
						
							|  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-16 14:09:14 +08:00
										 |  |  |       toaster.success(gettext('Name updated')); | 
					
						
							| 
									
										
										
										
											2023-09-13 08:40:50 +08:00
										 |  |  |     }).catch((error) => { | 
					
						
							|  |  |  |       let errMessage = Utils.getErrorMsg(error); | 
					
						
							|  |  |  |       toaster.danger(errMessage); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }; | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   updateLogo = (file) => { | 
					
						
							|  |  |  |     seafileAPI.orgAdminUpdateLogo(orgID, file).then((res) => { | 
					
						
							|  |  |  |       this.setState({ | 
					
						
							| 
									
										
										
										
											2023-10-24 14:09:57 +08:00
										 |  |  |         logoPath: res.data.logo_path | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-16 14:09:14 +08:00
										 |  |  |       toaster.success(gettext('Logo updated')); | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |     }).catch((error) => { | 
					
						
							|  |  |  |       let errMessage = Utils.getErrorMsg(error); | 
					
						
							|  |  |  |       toaster.danger(errMessage); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2023-09-13 08:40:50 +08:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |   orgSaveSetting = (key, value) => { | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |     seafileAPI.orgAdminSetSysSettingInfo(orgID, key, value).then((res) => { | 
					
						
							| 
									
										
										
										
											2024-10-16 14:09:14 +08:00
										 |  |  |       toaster.success(gettext('System settings updated')); | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |     }).catch((error) => { | 
					
						
							|  |  |  |       let errMessage = Utils.getErrorMsg(error); | 
					
						
							|  |  |  |       toaster.danger(errMessage); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2023-09-13 08:40:50 +08:00
										 |  |  |   }; | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |   render() { | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |     const { loading, errorMsg, config_dict, file_ext_white_list, force_adfs_login, disable_org_encrypted_library, disable_org_user_clean_trash } = this.state; | 
					
						
							| 
									
										
										
										
											2023-10-24 14:09:57 +08:00
										 |  |  |     let logoPath = this.state.logoPath; | 
					
						
							|  |  |  |     logoPath = logoPath.indexOf('image-view') != -1 ? logoPath : mediaUrl + logoPath; | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |     return ( | 
					
						
							|  |  |  |       <Fragment> | 
					
						
							|  |  |  |         <MainPanelTopbar {...this.props} /> | 
					
						
							|  |  |  |         <div className="main-panel-center flex-row"> | 
					
						
							|  |  |  |           <div className="cur-view-container"> | 
					
						
							|  |  |  |             <div className="cur-view-path"> | 
					
						
							|  |  |  |               <h3 className="sf-heading">{gettext('Settings')}</h3> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |             <div className="cur-view-content container mw-100"> | 
					
						
							|  |  |  |               {loading && <Loading />} | 
					
						
							|  |  |  |               {errorMsg && <p className="error text-center mt-4">{errorMsg}</p>} | 
					
						
							|  |  |  |               {(!loading && !errorMsg) && config_dict && | 
					
						
							|  |  |  |               <Fragment> | 
					
						
							|  |  |  |                 <p className="small text-secondary my-4"></p> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 <Section headingText={gettext('Info')}> | 
					
						
							|  |  |  |                   <Fragment> | 
					
						
							|  |  |  |                     <InputItem | 
					
						
							|  |  |  |                       saveSetting={this.updateName} | 
					
						
							|  |  |  |                       displayName={gettext('Team name')} | 
					
						
							|  |  |  |                       keyText='orgName' | 
					
						
							|  |  |  |                       value={config_dict['org_name']} | 
					
						
							|  |  |  |                       helpTip={''} | 
					
						
							|  |  |  |                       disabled={!orgEnableAdminCustomName} | 
					
						
							|  |  |  |                     /> | 
					
						
							|  |  |  |                     { orgEnableAdminCustomLogo && <FileItem | 
					
						
							|  |  |  |                       postFile={this.updateLogo} | 
					
						
							|  |  |  |                       displayName='Logo' | 
					
						
							|  |  |  |                       keyText='Logo' | 
					
						
							|  |  |  |                       filePath={logoPath} | 
					
						
							|  |  |  |                       fileWidth={256} | 
					
						
							|  |  |  |                       fileHeight={64} | 
					
						
							|  |  |  |                       helpTip='logo.png, 256px * 64px' | 
					
						
							|  |  |  |                     /> | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                   </Fragment> | 
					
						
							|  |  |  |                 </Section> | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |                 <Section headingText={gettext('File Upload')}> | 
					
						
							|  |  |  |                   <Fragment> | 
					
						
							|  |  |  |                     <InputItem | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |                       saveSetting={this.orgSaveSetting} | 
					
						
							| 
									
										
										
										
											2023-03-16 14:02:42 +08:00
										 |  |  |                       displayName={gettext('File extension white list')} | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |                       keyText='file_ext_white_list' | 
					
						
							|  |  |  |                       value={file_ext_white_list} | 
					
						
							| 
									
										
										
										
											2023-03-16 14:02:42 +08:00
										 |  |  |                       helpTip={gettext('File extension white list for file upload via web UI and API. For example, "md;txt;docx". Empty means no limit.')} | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  |                     /> | 
					
						
							|  |  |  |                   </Fragment> | 
					
						
							|  |  |  |                 </Section> | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  |                 {enableMultiADFS && | 
					
						
							|  |  |  |                   <Section headingText={gettext('User')}> | 
					
						
							|  |  |  |                     <CheckboxItem | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |                       saveSetting={this.orgSaveSetting} | 
					
						
							| 
									
										
										
										
											2024-08-01 17:54:31 +08:00
										 |  |  |                       displayName={gettext('Disable SAML user email / password login')} | 
					
						
							|  |  |  |                       keyText='force_adfs_login' | 
					
						
							|  |  |  |                       value={force_adfs_login} | 
					
						
							|  |  |  |                       helpTip={gettext('Force user to use SSO login if SAML account is bound')} | 
					
						
							|  |  |  |                     /> | 
					
						
							|  |  |  |                   </Section> | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2024-09-03 18:16:38 +08:00
										 |  |  |                 {(sysEnableUserCleanTrash || sysEnableEncryptedLibrary) && | 
					
						
							|  |  |  |                   <Section headingText={gettext('Library')}> | 
					
						
							|  |  |  |                     <Fragment> | 
					
						
							|  |  |  |                       {sysEnableEncryptedLibrary && | 
					
						
							|  |  |  |                         <CheckboxItem | 
					
						
							|  |  |  |                           saveSetting={this.orgSaveSetting} | 
					
						
							|  |  |  |                           displayName='Encrypted library' | 
					
						
							|  |  |  |                           keyText='disable_org_encrypted_library' | 
					
						
							|  |  |  |                           value={disable_org_encrypted_library} | 
					
						
							|  |  |  |                           helpTip={gettext('Not allow user to create encrypted libraries')} | 
					
						
							|  |  |  |                         /> | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                       {sysEnableUserCleanTrash && | 
					
						
							|  |  |  |                         <CheckboxItem | 
					
						
							|  |  |  |                           saveSetting={this.orgSaveSetting} | 
					
						
							|  |  |  |                           displayName='Disable user clean trash' | 
					
						
							|  |  |  |                           keyText='disable_org_user_clean_trash' | 
					
						
							|  |  |  |                           value={disable_org_user_clean_trash} | 
					
						
							|  |  |  |                           helpTip={gettext('Not allow user to clean library trash')} | 
					
						
							|  |  |  |                         /> | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                     </Fragment> | 
					
						
							|  |  |  |                   </Section> | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2023-03-07 18:11:33 +08:00
										 |  |  |               </Fragment> | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </Fragment> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-11 13:07:00 +08:00
										 |  |  | export default OrgWebSettings; |