| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  | import React from 'react'; | 
					
						
							| 
									
										
										
										
											2025-02-14 14:04:25 +08:00
										 |  |  | import { createRoot } from 'react-dom/client'; | 
					
						
							| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  | import { Button } from 'reactstrap'; | 
					
						
							|  |  |  | import { gettext } from './utils/constants'; | 
					
						
							|  |  |  | import Logo from './components/logo'; | 
					
						
							|  |  |  | import Account from './components/common/account'; | 
					
						
							|  |  |  | import TermsPreviewWidget from './components/terms-preview-widget'; | 
					
						
							| 
									
										
										
										
											2025-05-15 17:41:23 +08:00
										 |  |  | import { Utils } from './utils/utils'; | 
					
						
							| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | import './css/tc-accept.css'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const { csrfToken } = window.app.pageOptions; | 
					
						
							| 
									
										
										
										
											2020-11-02 13:56:35 +08:00
										 |  |  | const { | 
					
						
							| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  |   termsName, | 
					
						
							|  |  |  |   formAction, | 
					
						
							|  |  |  |   formTerms, | 
					
						
							|  |  |  |   formReturnTo, | 
					
						
							|  |  |  |   logoutURL, | 
					
						
							|  |  |  |   termsText | 
					
						
							|  |  |  | } = window.tc; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class TCAccept extends React.Component { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   render() { | 
					
						
							|  |  |  |     return ( | 
					
						
							|  |  |  |       <div className="h-100 d-flex flex-column"> | 
					
						
							|  |  |  |         <div className="top-header d-flex justify-content-between"> | 
					
						
							|  |  |  |           <Logo /> | 
					
						
							|  |  |  |           <Account /> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <div className="o-auto"> | 
					
						
							|  |  |  |           <div className="py-4 px-4 my-6 mx-auto content"> | 
					
						
							| 
									
										
										
										
											2025-05-15 17:41:23 +08:00
										 |  |  |             <h2 dangerouslySetInnerHTML={{ __html: Utils.HTMLescape(termsName) }}></h2> | 
					
						
							| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  |             <div className="article"> | 
					
						
							|  |  |  |               <TermsPreviewWidget content={termsText} /> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |             <form action={formAction} method="post"> | 
					
						
							|  |  |  |               <input type="hidden" name="csrfmiddlewaretoken" value={csrfToken} /> | 
					
						
							| 
									
										
										
										
											2024-07-18 11:58:42 +08:00
										 |  |  |               <div dangerouslySetInnerHTML={{ __html: formTerms }}></div> | 
					
						
							|  |  |  |               <div dangerouslySetInnerHTML={{ __html: formReturnTo }}></div> | 
					
						
							| 
									
										
										
										
											2019-11-21 11:34:08 +08:00
										 |  |  |               <Button type="submit">{gettext('Accept')}</Button> | 
					
						
							|  |  |  |               <a href={logoutURL} className="btn btn-secondary ml-2">{gettext('Cancel')}</a> | 
					
						
							|  |  |  |             </form> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-14 14:04:25 +08:00
										 |  |  | const root = createRoot(document.getElementById('wrapper')); | 
					
						
							|  |  |  | root.render(<TCAccept />); |