Merge pull request #3348 from matrix-org/travis/fix-discovery
Adjust copy and include identity server changing when terms are pendingpull/21833/head
						commit
						08339abd35
					
				|  | @ -16,6 +16,7 @@ limitations under the License. | |||
| 
 | ||||
| import url from 'url'; | ||||
| import React from 'react'; | ||||
| import PropTypes from 'prop-types'; | ||||
| import {_t} from "../../../languageHandler"; | ||||
| import sdk from '../../../index'; | ||||
| import MatrixClientPeg from "../../../MatrixClientPeg"; | ||||
|  | @ -55,6 +56,12 @@ async function checkIdentityServerUrl(u) { | |||
| } | ||||
| 
 | ||||
| export default class SetIdServer extends React.Component { | ||||
|     static propTypes = { | ||||
|         // Whether or not the ID server is missing terms. This affects the text
 | ||||
|         // shown to the user.
 | ||||
|         missingTerms: PropTypes.bool, | ||||
|     }; | ||||
| 
 | ||||
|     constructor() { | ||||
|         super(); | ||||
| 
 | ||||
|  | @ -274,6 +281,13 @@ export default class SetIdServer extends React.Component { | |||
|                 {}, | ||||
|                 { server: sub => <b>{abbreviateUrl(idServerUrl)}</b> }, | ||||
|             ); | ||||
|             if (this.props.missingTerms) { | ||||
|                 bodyText = _t( | ||||
|                     "If you don't want to use <server /> to discover and be discoverable by existing " + | ||||
|                     "contacts you know, enter another identity server below.", | ||||
|                     {}, {server: sub => <b>{abbreviateUrl(idServerUrl)}</b>}, | ||||
|                 ); | ||||
|             } | ||||
|         } else { | ||||
|             sectionTitle = _t("Identity Server"); | ||||
|             bodyText = _t( | ||||
|  | @ -286,16 +300,25 @@ export default class SetIdServer extends React.Component { | |||
|         let discoSection; | ||||
|         if (idServerUrl) { | ||||
|             let discoButtonContent = _t("Disconnect"); | ||||
|             let discoBodyText = _t( | ||||
|                 "Disconnecting from your identity server will mean you " + | ||||
|                 "won't be discoverable by other users and you won't be " + | ||||
|                 "able to invite others by email or phone.", | ||||
|             ); | ||||
|             if (this.props.missingTerms) { | ||||
|                 discoBodyText = _t( | ||||
|                     "Using an identity server is optional. If you choose not to " + | ||||
|                     "use an identity server, you won't be discoverable by other users " + | ||||
|                     "and you won't be able to invite others by email or phone.", | ||||
|                 ); | ||||
|                 discoButtonContent = _t("Do not use an identity server"); | ||||
|             } | ||||
|             if (this.state.disconnectBusy) { | ||||
|                 const InlineSpinner = sdk.getComponent('views.elements.InlineSpinner'); | ||||
|                 discoButtonContent = <InlineSpinner />; | ||||
|             } | ||||
|             discoSection = <div> | ||||
|                 <span className="mx_SettingsTab_subsectionText">{_t( | ||||
|                     "Disconnecting from your identity server will mean you " + | ||||
|                     "won't be discoverable by other users and you won't be " + | ||||
|                     "able to invite others by email or phone.", | ||||
|                 )}</span> | ||||
|                 <span className="mx_SettingsTab_subsectionText">{discoBodyText}</span> | ||||
|                 <AccessibleButton onClick={this._onDisconnectClicked} kind="danger_sm"> | ||||
|                     {discoButtonContent} | ||||
|                 </AccessibleButton> | ||||
|  |  | |||
|  | @ -249,6 +249,8 @@ export default class GeneralUserSettingsTab extends React.Component { | |||
|     } | ||||
| 
 | ||||
|     _renderDiscoverySection() { | ||||
|         const SetIdServer = sdk.getComponent("views.settings.SetIdServer"); | ||||
| 
 | ||||
|         if (this.state.requiredPolicyInfo.hasTerms) { | ||||
|             const InlineTermsAgreement = sdk.getComponent("views.terms.InlineTermsAgreement"); | ||||
|             const intro = <span className="mx_SettingsTab_subsectionText"> | ||||
|  | @ -258,17 +260,22 @@ export default class GeneralUserSettingsTab extends React.Component { | |||
|                     {serverName: this.state.idServerName}, | ||||
|                 )} | ||||
|             </span>; | ||||
|             return <InlineTermsAgreement | ||||
|                 policiesAndServicePairs={this.state.requiredPolicyInfo.policiesAndServices} | ||||
|                 agreedUrls={this.state.requiredPolicyInfo.agreedUrls} | ||||
|                 onFinished={this.state.requiredPolicyInfo.resolve} | ||||
|                 introElement={intro} | ||||
|             />; | ||||
|             return ( | ||||
|                 <div> | ||||
|                     <InlineTermsAgreement | ||||
|                         policiesAndServicePairs={this.state.requiredPolicyInfo.policiesAndServices} | ||||
|                         agreedUrls={this.state.requiredPolicyInfo.agreedUrls} | ||||
|                         onFinished={this.state.requiredPolicyInfo.resolve} | ||||
|                         introElement={intro} | ||||
|                     /> | ||||
|                     { /* has its own heading as it includes the current ID server */ } | ||||
|                     <SetIdServer missingTerms={true} /> | ||||
|                 </div> | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|         const EmailAddresses = sdk.getComponent("views.settings.discovery.EmailAddresses"); | ||||
|         const PhoneNumbers = sdk.getComponent("views.settings.discovery.PhoneNumbers"); | ||||
|         const SetIdServer = sdk.getComponent("views.settings.SetIdServer"); | ||||
| 
 | ||||
|         const threepidSection = this.state.haveIdServer ? <div className='mx_GeneralUserSettingsTab_discovery'> | ||||
|             <span className="mx_SettingsTab_subheading">{_t("Email addresses")}</span> | ||||
|  |  | |||
|  | @ -559,9 +559,12 @@ | |||
|     "Disconnect": "Disconnect", | ||||
|     "Identity Server (%(server)s)": "Identity Server (%(server)s)", | ||||
|     "You are currently using <server></server> to discover and be discoverable by existing contacts you know. You can change your identity server below.": "You are currently using <server></server> to discover and be discoverable by existing contacts you know. You can change your identity server below.", | ||||
|     "If you don't want to use <server /> to discover and be discoverable by existing contacts you know, enter another identity server below.": "If you don't want to use <server /> to discover and be discoverable by existing contacts you know, enter another identity server below.", | ||||
|     "Identity Server": "Identity Server", | ||||
|     "You are not currently using an identity server. To discover and be discoverable by existing contacts you know, add one below.": "You are not currently using an identity server. To discover and be discoverable by existing contacts you know, add one below.", | ||||
|     "Disconnecting from your identity server will mean you won't be discoverable by other users and you won't be able to invite others by email or phone.": "Disconnecting from your identity server will mean you won't be discoverable by other users and you won't be able to invite others by email or phone.", | ||||
|     "Using an identity server is optional. If you choose not to use an identity server, you won't be discoverable by other users and you won't be able to invite others by email or phone.": "Using an identity server is optional. If you choose not to use an identity server, you won't be discoverable by other users and you won't be able to invite others by email or phone.", | ||||
|     "Do not use an identity server": "Do not use an identity server", | ||||
|     "Enter a new identity server": "Enter a new identity server", | ||||
|     "Change": "Change", | ||||
|     "Failed to update integration manager": "Failed to update integration manager", | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Travis Ralston
						Travis Ralston