mirror of
				https://github.com/vector-im/element-web.git
				synced 2025-10-24 22:01:46 +02:00 
			
		
		
		
	Merge remote-tracking branch 'origin/develop' into develop
This commit is contained in:
		
						commit
						b57fc50620
					
				| @ -7,11 +7,8 @@ src/component-index.js | ||||
| src/components/structures/BottomLeftMenu.js | ||||
| src/components/structures/CompatibilityPage.js | ||||
| src/components/structures/CreateRoom.js | ||||
| src/components/structures/HomePage.js | ||||
| src/components/structures/LeftPanel.js | ||||
| src/components/structures/LoggedInView.js | ||||
| src/components/structures/login/ForgotPassword.js | ||||
| src/components/structures/LoginBox.js | ||||
| src/components/structures/MessagePanel.js | ||||
| src/components/structures/NotificationPanel.js | ||||
| src/components/structures/RoomDirectory.js | ||||
| @ -22,22 +19,17 @@ src/components/structures/SearchBox.js | ||||
| src/components/structures/TimelinePanel.js | ||||
| src/components/structures/UploadBar.js | ||||
| src/components/structures/UserSettings.js | ||||
| src/components/structures/ViewSource.js | ||||
| src/components/views/avatars/BaseAvatar.js | ||||
| src/components/views/avatars/MemberAvatar.js | ||||
| src/components/views/create_room/RoomAlias.js | ||||
| src/components/views/dialogs/ChangelogDialog.js | ||||
| src/components/views/dialogs/DeactivateAccountDialog.js | ||||
| src/components/views/dialogs/SetPasswordDialog.js | ||||
| src/components/views/dialogs/UnknownDeviceDialog.js | ||||
| src/components/views/directory/NetworkDropdown.js | ||||
| src/components/views/elements/AddressSelector.js | ||||
| src/components/views/elements/DeviceVerifyButtons.js | ||||
| src/components/views/elements/DirectorySearchBox.js | ||||
| src/components/views/elements/ImageView.js | ||||
| src/components/views/elements/InlineSpinner.js | ||||
| src/components/views/elements/MemberEventListSummary.js | ||||
| src/components/views/elements/Spinner.js | ||||
| src/components/views/elements/TintableSvg.js | ||||
| src/components/views/elements/UserSelector.js | ||||
| src/components/views/globals/MatrixToolbar.js | ||||
| @ -90,7 +82,6 @@ src/MatrixClientPeg.js | ||||
| src/Modal.js | ||||
| src/notifications/ContentRules.js | ||||
| src/notifications/PushRuleVectorState.js | ||||
| src/notifications/StandardActions.js | ||||
| src/notifications/VectorPushRulesDefinitions.js | ||||
| src/Notifier.js | ||||
| src/PlatformPeg.js | ||||
| @ -111,7 +102,6 @@ src/utils/MultiInviter.js | ||||
| src/utils/Receipt.js | ||||
| src/VectorConferenceHandler.js | ||||
| src/Velociraptor.js | ||||
| src/VelocityBounce.js | ||||
| src/WhoIsTyping.js | ||||
| src/wrappers/withMatrixClient.js | ||||
| test/components/structures/login/Registration-test.js | ||||
|  | ||||
| @ -101,7 +101,7 @@ | ||||
|   "devDependencies": { | ||||
|     "babel-cli": "^6.26.0", | ||||
|     "babel-core": "^6.26.3", | ||||
|     "babel-eslint": "^6.1.2", | ||||
|     "babel-eslint": "^10.0.1", | ||||
|     "babel-loader": "^7.1.5", | ||||
|     "babel-plugin-add-module-exports": "^0.2.1", | ||||
|     "babel-plugin-transform-async-to-bluebird": "^1.1.1", | ||||
| @ -115,9 +115,9 @@ | ||||
|     "babel-preset-react": "^6.24.1", | ||||
|     "chokidar": "^1.6.1", | ||||
|     "concurrently": "^4.0.1", | ||||
|     "eslint": "^3.13.1", | ||||
|     "eslint": "^5.8.0", | ||||
|     "eslint-config-google": "^0.7.1", | ||||
|     "eslint-plugin-babel": "^4.1.2", | ||||
|     "eslint-plugin-babel": "^5.2.1", | ||||
|     "eslint-plugin-flowtype": "^2.30.0", | ||||
|     "eslint-plugin-react": "^7.7.0", | ||||
|     "estree-walker": "^0.5.0", | ||||
|  | ||||
| @ -22,7 +22,6 @@ import _clamp from 'lodash/clamp'; | ||||
| type MessageFormat = 'rich' | 'markdown'; | ||||
| 
 | ||||
| class HistoryItem { | ||||
| 
 | ||||
|     // We store history items in their native format to ensure history is accurate
 | ||||
|     // and then convert them if our RTE has subsequently changed format.
 | ||||
|     value: Value; | ||||
|  | ||||
| @ -78,7 +78,6 @@ class MemberEntity extends Entity { | ||||
| } | ||||
| 
 | ||||
| class UserEntity extends Entity { | ||||
| 
 | ||||
|     constructor(model, showInviteButton, inviteFn) { | ||||
|         super(model); | ||||
|         this.showInviteButton = Boolean(showInviteButton); | ||||
|  | ||||
| @ -64,7 +64,7 @@ export function containsEmoji(str) { | ||||
|  * because we want to include emoji shortnames in title text | ||||
|  */ | ||||
| function unicodeToImage(str) { | ||||
|     let replaceWith, unicode, alt, short, fname; | ||||
|     let replaceWith; let unicode; let alt; let short; let fname; | ||||
|     const mappedUnicode = emojione.mapUnicodeToShort(); | ||||
| 
 | ||||
|     str = str.replace(emojione.regUnicode, function(unicodeChar) { | ||||
|  | ||||
| @ -25,7 +25,6 @@ import { _t } from './languageHandler'; | ||||
|  * API on the homeserver in question with the new password. | ||||
|  */ | ||||
| class PasswordReset { | ||||
| 
 | ||||
|     /** | ||||
|      * Configure the endpoints for password resetting. | ||||
|      * @param {string} homeserverUrl The URL to the HS which has the account to reset. | ||||
|  | ||||
| @ -23,7 +23,6 @@ const UNAVAILABLE_TIME_MS = 3 * 60 * 1000; // 3 mins | ||||
| const PRESENCE_STATES = ["online", "offline", "unavailable"]; | ||||
| 
 | ||||
| class Presence { | ||||
| 
 | ||||
|     /** | ||||
|      * Start listening the user activity to evaluate his presence state. | ||||
|      * Any state change will be sent to the Home Server. | ||||
|  | ||||
| @ -32,7 +32,6 @@ export function getDisplayAliasForRoom(room) { | ||||
|  * return the other one. Otherwise, return null. | ||||
|  */ | ||||
| export function getOnlyOtherMember(room, myUserId) { | ||||
| 
 | ||||
|     if (room.currentState.getJoinedMemberCount() === 2) { | ||||
|         return room.getJoinedMembers().filter(function(m) { | ||||
|             return m.userId !== myUserId; | ||||
| @ -103,7 +102,7 @@ export function guessAndSetDMRoom(room, isDirect) { | ||||
|     let newTarget; | ||||
|     if (isDirect) { | ||||
|         const guessedUserId = guessDMRoomTargetId( | ||||
|             room, MatrixClientPeg.get().getUserId() | ||||
|             room, MatrixClientPeg.get().getUserId(), | ||||
|         ); | ||||
|         newTarget = guessedUserId; | ||||
|     } else { | ||||
|  | ||||
| @ -22,7 +22,6 @@ const SdkConfig = require('./SdkConfig'); | ||||
| const MatrixClientPeg = require('./MatrixClientPeg'); | ||||
| 
 | ||||
| class ScalarAuthClient { | ||||
| 
 | ||||
|     constructor() { | ||||
|         this.scalarToken = null; | ||||
|     } | ||||
|  | ||||
| @ -24,7 +24,6 @@ const DEFAULTS = { | ||||
| }; | ||||
| 
 | ||||
| class SdkConfig { | ||||
| 
 | ||||
|     static get() { | ||||
|         return global.mxReactSdkConfig || {}; | ||||
|     } | ||||
|  | ||||
| @ -25,7 +25,6 @@ const CURRENTLY_ACTIVE_THRESHOLD_MS = 2000; | ||||
|  * with the app (but at a much lower frequency than mouse move events) | ||||
|  */ | ||||
| class UserActivity { | ||||
| 
 | ||||
|     /** | ||||
|      * Start listening to user activity | ||||
|      */ | ||||
|  | ||||
| @ -3,8 +3,8 @@ const Velocity = require('velocity-vector'); | ||||
| // courtesy of https://github.com/julianshapiro/velocity/issues/283
 | ||||
| // We only use easeOutBounce (easeInBounce is just sort of nonsensical)
 | ||||
| function bounce( p ) { | ||||
|     let pow2, | ||||
|         bounce = 4; | ||||
|     let pow2; | ||||
|     let bounce = 4; | ||||
| 
 | ||||
|     while ( p < ( ( pow2 = Math.pow( 2, --bounce ) ) - 1 ) / 11 ) { | ||||
|         // just sets pow2
 | ||||
|  | ||||
| @ -85,7 +85,7 @@ export default class Autocompleter { | ||||
|                 provider | ||||
|                     .getCompletions(query, selection, force) | ||||
|                     .timeout(PROVIDER_COMPLETION_TIMEOUT) | ||||
|                     .reflect() | ||||
|                     .reflect(), | ||||
|             ), | ||||
|         ); | ||||
| 
 | ||||
|  | ||||
| @ -26,7 +26,6 @@ import { Block } from 'slate'; | ||||
|  */ | ||||
| 
 | ||||
| class PlainWithPillsSerializer { | ||||
| 
 | ||||
|     /* | ||||
|      * @param {String} options.pillFormat - either 'md', 'plain', 'id' | ||||
|      */ | ||||
|  | ||||
| @ -145,7 +145,7 @@ module.exports = React.createClass({ | ||||
|     // Get the label/tooltip to show
 | ||||
|     getLabel: function(label, show) { | ||||
|         if (show) { | ||||
|             var RoomTooltip = sdk.getComponent("rooms.RoomTooltip"); | ||||
|             const RoomTooltip = sdk.getComponent("rooms.RoomTooltip"); | ||||
|             return <RoomTooltip className="mx_BottomLeftMenu_tooltip" label={label} />; | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| @ -16,18 +16,18 @@ limitations under the License. | ||||
| 
 | ||||
| 'use strict'; | ||||
| 
 | ||||
| var React = require('react'); | ||||
| const React = require('react'); | ||||
| import { _t } from '../../languageHandler'; | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'CompatibilityPage', | ||||
|     propTypes: { | ||||
|         onAccept: React.PropTypes.func | ||||
|         onAccept: React.PropTypes.func, | ||||
|     }, | ||||
| 
 | ||||
|     getDefaultProps: function() { | ||||
|         return { | ||||
|             onAccept: function() {} // NOP
 | ||||
|             onAccept: function() {}, // NOP
 | ||||
|         }; | ||||
|     }, | ||||
| 
 | ||||
| @ -36,7 +36,6 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
| 
 | ||||
|         return ( | ||||
|         <div className="mx_CompatibilityPage"> | ||||
|             <div className="mx_CompatibilityPage_box"> | ||||
| @ -69,5 +68,5 @@ module.exports = React.createClass({ | ||||
|             </div> | ||||
|         </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -52,15 +52,14 @@ class HomePage extends React.Component { | ||||
| 
 | ||||
|         if (this.props.teamToken && this.props.teamServerUrl) { | ||||
|             this.setState({ | ||||
|                 iframeSrc: `${this.props.teamServerUrl}/static/${this.props.teamToken}/home.html` | ||||
|                 iframeSrc: `${this.props.teamServerUrl}/static/${this.props.teamToken}/home.html`, | ||||
|             }); | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             // we use request() to inline the homepage into the react component
 | ||||
|             // so that it can inherit CSS and theming easily rather than mess around
 | ||||
|             // with iframes and trying to synchronise document.stylesheets.
 | ||||
| 
 | ||||
|             let src = this.props.homePageUrl || 'home.html'; | ||||
|             const src = this.props.homePageUrl || 'home.html'; | ||||
| 
 | ||||
|             request( | ||||
|                 { method: "GET", url: src }, | ||||
| @ -77,7 +76,7 @@ class HomePage extends React.Component { | ||||
| 
 | ||||
|                     body = body.replace(/_t\(['"]([\s\S]*?)['"]\)/mg, (match, g1)=>this.translate(g1)); | ||||
|                     this.setState({ page: body }); | ||||
|                 } | ||||
|                 }, | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
| @ -93,8 +92,7 @@ class HomePage extends React.Component { | ||||
|                     <iframe src={ this.state.iframeSrc } /> | ||||
|                 </div> | ||||
|             ); | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             const GeminiScrollbarWrapper = sdk.getComponent("elements.GeminiScrollbarWrapper"); | ||||
|             return ( | ||||
|                 <GeminiScrollbarWrapper autoshow={true} className="mx_HomePage"> | ||||
|  | ||||
| @ -28,7 +28,7 @@ import VectorConferenceHandler from '../../VectorConferenceHandler'; | ||||
| import SettingsStore from '../../settings/SettingsStore'; | ||||
| 
 | ||||
| 
 | ||||
| var LeftPanel = React.createClass({ | ||||
| const LeftPanel = React.createClass({ | ||||
|     displayName: 'LeftPanel', | ||||
| 
 | ||||
|     // NB. If you add props, don't forget to update
 | ||||
| @ -218,7 +218,7 @@ var LeftPanel = React.createClass({ | ||||
|                 </aside> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
| 
 | ||||
| module.exports = LeftPanel; | ||||
|  | ||||
| @ -53,5 +53,5 @@ module.exports = React.createClass({ | ||||
|                 { loginButton } | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -16,18 +16,18 @@ limitations under the License. | ||||
| 
 | ||||
| 'use strict'; | ||||
| 
 | ||||
| var React = require('react'); | ||||
| const React = require('react'); | ||||
| 
 | ||||
| var MatrixClientPeg = require('../../MatrixClientPeg'); | ||||
| var ContentRepo = require("matrix-js-sdk").ContentRepo; | ||||
| var Modal = require('../../Modal'); | ||||
| var sdk = require('../../index'); | ||||
| var dis = require('../../dispatcher'); | ||||
| const MatrixClientPeg = require('../../MatrixClientPeg'); | ||||
| const ContentRepo = require("matrix-js-sdk").ContentRepo; | ||||
| const Modal = require('../../Modal'); | ||||
| const sdk = require('../../index'); | ||||
| const dis = require('../../dispatcher'); | ||||
| 
 | ||||
| var linkify = require('linkifyjs'); | ||||
| var linkifyString = require('linkifyjs/string'); | ||||
| var linkifyMatrix = require('../../linkify-matrix'); | ||||
| var sanitizeHtml = require('sanitize-html'); | ||||
| const linkify = require('linkifyjs'); | ||||
| const linkifyString = require('linkifyjs/string'); | ||||
| const linkifyMatrix = require('../../linkify-matrix'); | ||||
| const sanitizeHtml = require('sanitize-html'); | ||||
| import Promise from 'bluebird'; | ||||
| 
 | ||||
| import { _t } from '../../languageHandler'; | ||||
| @ -46,7 +46,7 @@ module.exports = React.createClass({ | ||||
|     getDefaultProps: function() { | ||||
|         return { | ||||
|             config: {}, | ||||
|         } | ||||
|         }; | ||||
|     }, | ||||
| 
 | ||||
|     getInitialState: function() { | ||||
| @ -58,7 +58,7 @@ module.exports = React.createClass({ | ||||
|             includeAll: false, | ||||
|             roomServer: null, | ||||
|             filterString: null, | ||||
|         } | ||||
|         }; | ||||
|     }, | ||||
| 
 | ||||
|     componentWillMount: function() { | ||||
| @ -139,8 +139,7 @@ module.exports = React.createClass({ | ||||
|             if ( | ||||
|                 my_filter_string != this.state.filterString || | ||||
|                 my_server != this.state.roomServer || | ||||
|                 my_next_batch != this.nextBatch) | ||||
|             { | ||||
|                 my_next_batch != this.nextBatch) { | ||||
|                 // if the filter or server has changed since this request was sent,
 | ||||
|                 // throw away the result (don't even clear the busy flag
 | ||||
|                 // since we must still have a request in flight)
 | ||||
| @ -163,8 +162,7 @@ module.exports = React.createClass({ | ||||
|             if ( | ||||
|                 my_filter_string != this.state.filterString || | ||||
|                 my_server != this.state.roomServer || | ||||
|                 my_next_batch != this.nextBatch) | ||||
|             { | ||||
|                 my_next_batch != this.nextBatch) { | ||||
|                 // as above: we don't care about errors for old
 | ||||
|                 // requests either
 | ||||
|                 return; | ||||
| @ -177,10 +175,10 @@ module.exports = React.createClass({ | ||||
| 
 | ||||
|             this.setState({ loading: false }); | ||||
|             console.error("Failed to get publicRooms: %s", JSON.stringify(err)); | ||||
|             var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|             const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|             Modal.createTrackedDialog('Failed to get public room list', '', ErrorDialog, { | ||||
|                 title: _t('Failed to get public room list'), | ||||
|                 description: ((err && err.message) ? err.message : _t('The server may be unavailable or overloaded')) | ||||
|                 description: ((err && err.message) ? err.message : _t('The server may be unavailable or overloaded')), | ||||
|             }); | ||||
|         }); | ||||
|     }, | ||||
| @ -193,13 +191,13 @@ module.exports = React.createClass({ | ||||
|      * this needs SPEC-417. | ||||
|      */ | ||||
|     removeFromDirectory: function(room) { | ||||
|         var alias = get_display_alias_for_room(room); | ||||
|         var name = room.name || alias || _t('Unnamed room'); | ||||
|         const alias = get_display_alias_for_room(room); | ||||
|         const name = room.name || alias || _t('Unnamed room'); | ||||
| 
 | ||||
|         var QuestionDialog = sdk.getComponent("dialogs.QuestionDialog"); | ||||
|         var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|         const QuestionDialog = sdk.getComponent("dialogs.QuestionDialog"); | ||||
|         const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
| 
 | ||||
|         var desc; | ||||
|         let desc; | ||||
|         if (alias) { | ||||
|             desc = _t('Delete the room alias %(alias)s and remove %(name)s from the directory?', {alias: alias, name: name}); | ||||
|         } else { | ||||
| @ -212,9 +210,9 @@ module.exports = React.createClass({ | ||||
|             onFinished: (should_delete) => { | ||||
|                 if (!should_delete) return; | ||||
| 
 | ||||
|                 var Loader = sdk.getComponent("elements.Spinner"); | ||||
|                 var modal = Modal.createDialog(Loader); | ||||
|                 var step = _t('remove %(name)s from the directory.', {name: name}); | ||||
|                 const Loader = sdk.getComponent("elements.Spinner"); | ||||
|                 const modal = Modal.createDialog(Loader); | ||||
|                 let step = _t('remove %(name)s from the directory.', {name: name}); | ||||
| 
 | ||||
|                 MatrixClientPeg.get().setRoomDirectoryVisibility(room.room_id, 'private').then(() => { | ||||
|                     if (!alias) return; | ||||
| @ -229,10 +227,10 @@ module.exports = React.createClass({ | ||||
|                     console.error("Failed to " + step + ": " + err); | ||||
|                     Modal.createTrackedDialog('Remove from Directory Error', '', ErrorDialog, { | ||||
|                         title: _t('Error'), | ||||
|                         description: ((err && err.message) ? err.message : _t('The server may be unavailable or overloaded')) | ||||
|                         description: ((err && err.message) ? err.message : _t('The server may be unavailable or overloaded')), | ||||
|                     }); | ||||
|                 }); | ||||
|             } | ||||
|             }, | ||||
|         }); | ||||
|     }, | ||||
| 
 | ||||
| @ -347,7 +345,7 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     showRoom: function(room, room_alias) { | ||||
|         var payload = {action: 'view_room'}; | ||||
|         const payload = {action: 'view_room'}; | ||||
|         if (room) { | ||||
|             // Don't let the user view a room they won't be able to either
 | ||||
|             // peek or join: fail earlier so they don't have to click back
 | ||||
| @ -383,16 +381,16 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     getRows: function() { | ||||
|         var BaseAvatar = sdk.getComponent('avatars.BaseAvatar'); | ||||
|         const BaseAvatar = sdk.getComponent('avatars.BaseAvatar'); | ||||
| 
 | ||||
|         if (!this.state.publicRooms) return []; | ||||
| 
 | ||||
|         var rooms = this.state.publicRooms; | ||||
|         var rows = []; | ||||
|         var self = this; | ||||
|         var guestRead, guestJoin, perms; | ||||
|         for (var i = 0; i < rooms.length; i++) { | ||||
|             var name = rooms[i].name || get_display_alias_for_room(rooms[i]) || _t('Unnamed room'); | ||||
|         const rooms = this.state.publicRooms; | ||||
|         const rows = []; | ||||
|         const self = this; | ||||
|         let guestRead; let guestJoin; let perms; | ||||
|         for (let i = 0; i < rooms.length; i++) { | ||||
|             const name = rooms[i].name || get_display_alias_for_room(rooms[i]) || _t('Unnamed room'); | ||||
|             guestRead = null; | ||||
|             guestJoin = null; | ||||
| 
 | ||||
| @ -412,7 +410,7 @@ module.exports = React.createClass({ | ||||
|                 perms = <div className="mx_RoomDirectory_perms">{guestRead}{guestJoin}</div>; | ||||
|             } | ||||
| 
 | ||||
|             var topic = rooms[i].topic || ''; | ||||
|             let topic = rooms[i].topic || ''; | ||||
|             topic = linkifyString(sanitizeHtml(topic)); | ||||
| 
 | ||||
|             rows.push( | ||||
| @ -432,14 +430,14 @@ module.exports = React.createClass({ | ||||
|                         <div className="mx_RoomDirectory_name">{ name }</div>  | ||||
|                         { perms } | ||||
|                         <div className="mx_RoomDirectory_topic" | ||||
|                              onClick={ function(e) { e.stopPropagation() } } | ||||
|                              onClick={ function(e) { e.stopPropagation(); } } | ||||
|                              dangerouslySetInnerHTML={{ __html: topic }} /> | ||||
|                         <div className="mx_RoomDirectory_alias">{ get_display_alias_for_room(rooms[i]) }</div> | ||||
|                     </td> | ||||
|                     <td className="mx_RoomDirectory_roomMemberCount"> | ||||
|                         { rooms[i].num_joined_members } | ||||
|                     </td> | ||||
|                 </tr> | ||||
|                 </tr>, | ||||
|             ); | ||||
|         } | ||||
|         return rows; | ||||
| @ -577,7 +575,7 @@ module.exports = React.createClass({ | ||||
|                 </div> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
| 
 | ||||
| // Similar to matrix-react-sdk's MatrixTools.getDisplayAliasForRoom
 | ||||
|  | ||||
| @ -37,7 +37,7 @@ function getUnsentMessages(room) { | ||||
|     return room.getPendingEvents().filter(function(ev) { | ||||
|         return ev.status === Matrix.EventStatus.NOT_SENT; | ||||
|     }); | ||||
| }; | ||||
| } | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'RoomStatusBar', | ||||
| @ -303,7 +303,7 @@ module.exports = React.createClass({ | ||||
|         const errorIsMauError = Boolean( | ||||
|             this.state.syncStateData && | ||||
|             this.state.syncStateData.error && | ||||
|             this.state.syncStateData.error.errcode === 'M_RESOURCE_LIMIT_EXCEEDED' | ||||
|             this.state.syncStateData.error.errcode === 'M_RESOURCE_LIMIT_EXCEEDED', | ||||
|         ); | ||||
|         return this.state.syncState === "ERROR" && !errorIsMauError; | ||||
|     }, | ||||
|  | ||||
| @ -1673,7 +1673,7 @@ module.exports = React.createClass({ | ||||
|             </AuxPanel> | ||||
|         ); | ||||
| 
 | ||||
|         let messageComposer, searchInfo; | ||||
|         let messageComposer; let searchInfo; | ||||
|         const canSpeak = ( | ||||
|             // joined and not showing search results
 | ||||
|             myMembership === 'join' && !this.state.searchResults | ||||
| @ -1706,7 +1706,7 @@ module.exports = React.createClass({ | ||||
|         } | ||||
| 
 | ||||
|         if (inCall) { | ||||
|             let zoomButton, voiceMuteButton, videoMuteButton; | ||||
|             let zoomButton; let voiceMuteButton; let videoMuteButton; | ||||
| 
 | ||||
|             if (call.type === "video") { | ||||
|                 zoomButton = ( | ||||
|  | ||||
| @ -72,7 +72,7 @@ module.exports = React.createClass({ | ||||
|         function() { | ||||
|             this.props.onSearch(this.refs.search.value); | ||||
|         }, | ||||
|         100 | ||||
|         100, | ||||
|     ), | ||||
| 
 | ||||
|     onToggleCollapse: function(show) { | ||||
| @ -80,8 +80,7 @@ module.exports = React.createClass({ | ||||
|             dis.dispatch({ | ||||
|                 action: 'show_left_panel', | ||||
|             }); | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             dis.dispatch({ | ||||
|                 action: 'hide_left_panel', | ||||
|             }); | ||||
| @ -103,25 +102,24 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
|         var TintableSvg = sdk.getComponent('elements.TintableSvg'); | ||||
|         const TintableSvg = sdk.getComponent('elements.TintableSvg'); | ||||
| 
 | ||||
|         var collapseTabIndex = this.refs.search && this.refs.search.value !== "" ? "-1" : "0"; | ||||
|         const collapseTabIndex = this.refs.search && this.refs.search.value !== "" ? "-1" : "0"; | ||||
| 
 | ||||
|         var toggleCollapse; | ||||
|         let toggleCollapse; | ||||
|         if (this.props.collapsed) { | ||||
|             toggleCollapse = | ||||
|                 <AccessibleButton className="mx_SearchBox_maximise" tabIndex={collapseTabIndex} onClick={ this.onToggleCollapse.bind(this, true) }> | ||||
|                     <TintableSvg src="img/maximise.svg" width="10" height="16" alt={ _t("Expand panel") } /> | ||||
|                 </AccessibleButton> | ||||
|         } | ||||
|         else { | ||||
|                 </AccessibleButton>; | ||||
|         } else { | ||||
|             toggleCollapse = | ||||
|                 <AccessibleButton className="mx_SearchBox_minimise" tabIndex={collapseTabIndex} onClick={ this.onToggleCollapse.bind(this, false) }> | ||||
|                     <TintableSvg src="img/minimise.svg" width="10" height="16" alt={ _t("Collapse panel") } /> | ||||
|                 </AccessibleButton> | ||||
|                 </AccessibleButton>; | ||||
|         } | ||||
| 
 | ||||
|         var searchControls; | ||||
|         let searchControls; | ||||
|         if (!this.props.collapsed) { | ||||
|             searchControls = [ | ||||
|                     this.state.searchTerm.length > 0 ? | ||||
| @ -148,16 +146,16 @@ module.exports = React.createClass({ | ||||
|                         onChange={ this.onChange } | ||||
|                         onKeyDown={ this._onKeyDown } | ||||
|                         placeholder={ _t('Filter room names') } | ||||
|                     /> | ||||
|                     />, | ||||
|                 ]; | ||||
|         } | ||||
| 
 | ||||
|         var self = this; | ||||
|         const self = this; | ||||
|         return ( | ||||
|             <div className="mx_SearchBox"> | ||||
|                 { searchControls } | ||||
|                 { toggleCollapse } | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -53,5 +53,5 @@ module.exports = React.createClass({ | ||||
|                 </SyntaxHighlight> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -79,7 +79,7 @@ module.exports = React.createClass({ | ||||
|         const BaseAvatar = sdk.getComponent("avatars.BaseAvatar"); | ||||
| 
 | ||||
|         let {member, fallbackUserId, onClick, viewUserOnClick, ...otherProps} = this.props; | ||||
|         let userId = member ? member.userId : fallbackUserId; | ||||
|         const userId = member ? member.userId : fallbackUserId; | ||||
| 
 | ||||
|         if (viewUserOnClick) { | ||||
|             onClick = () => { | ||||
|  | ||||
| @ -66,7 +66,7 @@ export default class ChangelogDialog extends React.Component { | ||||
|                     {this.state[repo].map(this._elementsForCommit)} | ||||
|                     </ul> | ||||
|                 </div> | ||||
|             ) | ||||
|             ); | ||||
|         }); | ||||
| 
 | ||||
|         const content = ( | ||||
| @ -83,7 +83,7 @@ export default class ChangelogDialog extends React.Component { | ||||
|                 button={_t("Update")} | ||||
|                 onFinished={this.props.onFinished} | ||||
|                 /> | ||||
|         ) | ||||
|         ); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -26,7 +26,6 @@ import Unread from '../../../Unread'; | ||||
| import classNames from 'classnames'; | ||||
| 
 | ||||
| export default class ChatCreateOrReuseDialog extends React.Component { | ||||
| 
 | ||||
|     constructor(props) { | ||||
|         super(props); | ||||
|         this.onFinished = this.onFinished.bind(this); | ||||
|  | ||||
| @ -57,7 +57,7 @@ export default React.createClass({ | ||||
|         let error = null; | ||||
|         if (!this.state.groupId) { | ||||
|             error = _t("Community IDs cannot be empty."); | ||||
|         } else if (!/^[a-z0-9=_\-\.\/]*$/.test(this.state.groupId)) { | ||||
|         } else if (!/^[a-z0-9=_\-./]*$/.test(this.state.groupId)) { | ||||
|             error = _t("Community IDs may only contain characters a-z, 0-9, or '=_-./'"); | ||||
|         } | ||||
|         this.setState({ | ||||
|  | ||||
| @ -153,8 +153,8 @@ export default class NetworkDropdown extends React.Component { | ||||
| 
 | ||||
|                         const sortedInstances = this.props.protocols[proto].instances; | ||||
|                         sortedInstances.sort(function(x, y) { | ||||
|                             const a = x.desc | ||||
|                             const b = y.desc | ||||
|                             const a = x.desc; | ||||
|                             const b = y.desc; | ||||
|                             if (a < b) { | ||||
|                                 return -1; | ||||
|                             } else if (a > b) { | ||||
| @ -208,7 +208,7 @@ export default class NetworkDropdown extends React.Component { | ||||
|         return <div key={key} className="mx_NetworkDropdown_networkoption" onClick={click_handler}> | ||||
|             {icon} | ||||
|             <span className="mx_NetworkDropdown_menu_network">{name}</span> | ||||
|         </div> | ||||
|         </div>; | ||||
|     } | ||||
| 
 | ||||
|     render() { | ||||
| @ -223,11 +223,11 @@ export default class NetworkDropdown extends React.Component { | ||||
|             current_value = <input type="text" className="mx_NetworkDropdown_networkoption" | ||||
|                 ref={this.collectInputTextBox} onKeyUp={this.onInputKeyUp} | ||||
|                 placeholder="matrix.org" // 'matrix.org' as an example of an HS name
 | ||||
|             /> | ||||
|             />; | ||||
|         } else { | ||||
|             const instance = instanceForInstanceId(this.props.protocols, this.state.selectedInstanceId); | ||||
|             current_value = this._makeMenuOption( | ||||
|                 this.state.selectedServer, instance, this.state.includeAll, false | ||||
|                 this.state.selectedServer, instance, this.state.includeAll, false, | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|  | ||||
| @ -78,7 +78,7 @@ export default React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
|         let blacklistButton = null, verifyButton = null; | ||||
|         let blacklistButton = null; let verifyButton = null; | ||||
| 
 | ||||
|         if (this.state.device.isBlocked()) { | ||||
|             blacklistButton = ( | ||||
|  | ||||
| @ -122,7 +122,6 @@ export default class EditableTextContainer extends React.Component { | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| EditableTextContainer.propTypes = { | ||||
|  | ||||
| @ -16,13 +16,13 @@ limitations under the License. | ||||
| 
 | ||||
| 'use strict'; | ||||
| 
 | ||||
| var React = require('react'); | ||||
| const React = require('react'); | ||||
| 
 | ||||
| var MatrixClientPeg = require('../../../MatrixClientPeg'); | ||||
| const MatrixClientPeg = require('../../../MatrixClientPeg'); | ||||
| 
 | ||||
| import {formatDate} from '../../../DateUtils'; | ||||
| var filesize = require('filesize'); | ||||
| var AccessibleButton = require('../../../components/views/elements/AccessibleButton'); | ||||
| const filesize = require('filesize'); | ||||
| const AccessibleButton = require('../../../components/views/elements/AccessibleButton'); | ||||
| const Modal = require('../../../Modal'); | ||||
| const sdk = require('../../../index'); | ||||
| import { _t } from '../../../languageHandler'; | ||||
| @ -69,24 +69,24 @@ module.exports = React.createClass({ | ||||
|         Modal.createTrackedDialog('Confirm Redact Dialog', 'Image View', ConfirmRedactDialog, { | ||||
|             onFinished: (proceed) => { | ||||
|                 if (!proceed) return; | ||||
|                 var self = this; | ||||
|                 const self = this; | ||||
|                 MatrixClientPeg.get().redactEvent( | ||||
|                     this.props.mxEvent.getRoomId(), this.props.mxEvent.getId() | ||||
|                     this.props.mxEvent.getRoomId(), this.props.mxEvent.getId(), | ||||
|                 ).catch(function(e) { | ||||
|                     var ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|                     const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|                     // display error message stating you couldn't delete this.
 | ||||
|                     var code = e.errcode || e.statusCode; | ||||
|                     const code = e.errcode || e.statusCode; | ||||
|                     Modal.createTrackedDialog('You cannot delete this image.', '', ErrorDialog, { | ||||
|                         title: _t('Error'), | ||||
|                         description: _t('You cannot delete this image. (%(code)s)', {code: code}) | ||||
|                         description: _t('You cannot delete this image. (%(code)s)', {code: code}), | ||||
|                     }); | ||||
|                 }).done(); | ||||
|             } | ||||
|             }, | ||||
|         }); | ||||
|     }, | ||||
| 
 | ||||
|     getName: function() { | ||||
|         var name = this.props.name; | ||||
|         let name = this.props.name; | ||||
|         if (name && this.props.link) { | ||||
|             name = <a href={ this.props.link } target="_blank" rel="noopener">{ name }</a>; | ||||
|         } | ||||
| @ -94,7 +94,6 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
| 
 | ||||
| /* | ||||
|         // In theory max-width: 80%, max-height: 80% on the CSS should work
 | ||||
|         // but in practice, it doesn't, so do it manually:
 | ||||
| @ -123,7 +122,7 @@ module.exports = React.createClass({ | ||||
|             height: displayHeight | ||||
|         }; | ||||
| */ | ||||
|         var style, res; | ||||
|         let style; let res; | ||||
| 
 | ||||
|         if (this.props.width && this.props.height) { | ||||
|             style = { | ||||
| @ -133,22 +132,21 @@ module.exports = React.createClass({ | ||||
|             res = style.width + "x" + style.height + "px"; | ||||
|         } | ||||
| 
 | ||||
|         var size; | ||||
|         let size; | ||||
|         if (this.props.fileSize) { | ||||
|             size = filesize(this.props.fileSize); | ||||
|         } | ||||
| 
 | ||||
|         var size_res; | ||||
|         let size_res; | ||||
|         if (size && res) { | ||||
|             size_res = size + ", " + res; | ||||
|         } | ||||
|         else { | ||||
|         } else { | ||||
|             size_res = size || res; | ||||
|         } | ||||
| 
 | ||||
|         var showEventMeta = !!this.props.mxEvent; | ||||
|         const showEventMeta = !!this.props.mxEvent; | ||||
| 
 | ||||
|         var eventMeta; | ||||
|         let eventMeta; | ||||
|         if (showEventMeta) { | ||||
|             // Figure out the sender, defaulting to mxid
 | ||||
|             let sender = this.props.mxEvent.getSender(); | ||||
| @ -163,7 +161,7 @@ module.exports = React.createClass({ | ||||
|             </div>); | ||||
|         } | ||||
| 
 | ||||
|         var eventRedact; | ||||
|         let eventRedact; | ||||
|         if (showEventMeta) { | ||||
|             eventRedact = (<div className="mx_ImageView_button" onClick={this.onRedactClick}> | ||||
|                 { _t('Remove') } | ||||
| @ -201,5 +199,5 @@ module.exports = React.createClass({ | ||||
|                 </div> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -20,14 +20,14 @@ module.exports = React.createClass({ | ||||
|     displayName: 'InlineSpinner', | ||||
| 
 | ||||
|     render: function() { | ||||
|         var w = this.props.w || 16; | ||||
|         var h = this.props.h || 16; | ||||
|         var imgClass = this.props.imgClassName || ""; | ||||
|         const w = this.props.w || 16; | ||||
|         const h = this.props.h || 16; | ||||
|         const imgClass = this.props.imgClassName || ""; | ||||
| 
 | ||||
|         return ( | ||||
|             <div className="mx_InlineSpinner"> | ||||
|                 <img src="img/spinner.gif" width={w} height={h} className={imgClass} /> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -54,7 +54,6 @@ function getOrCreateContainer(containerId) { | ||||
|  * bounding rect as the parent of PE. | ||||
|  */ | ||||
| export default class PersistedElement extends React.Component { | ||||
| 
 | ||||
|     static propTypes = { | ||||
|         // Unique identifier for this PersistedElement instance
 | ||||
|         // Any PersistedElements with the same persistKey will use
 | ||||
|  | ||||
| @ -29,7 +29,7 @@ const REGEX_MATRIXTO = new RegExp(MATRIXTO_URL_PATTERN); | ||||
| 
 | ||||
| // For URLs of matrix.to links in the timeline which have been reformatted by
 | ||||
| // HttpUtils transformTags to relative links. This excludes event URLs (with `[^\/]*`)
 | ||||
| const REGEX_LOCAL_MATRIXTO = /^#\/(?:user|room|group)\/(([#!@+])[^\/]*)$/; | ||||
| const REGEX_LOCAL_MATRIXTO = /^#\/(?:user|room|group)\/(([#!@+])[^/]*)$/; | ||||
| 
 | ||||
| const Pill = React.createClass({ | ||||
|     statics: { | ||||
|  | ||||
| @ -16,19 +16,19 @@ limitations under the License. | ||||
| 
 | ||||
| 'use strict'; | ||||
| 
 | ||||
| var React = require('react'); | ||||
| const React = require('react'); | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'Spinner', | ||||
| 
 | ||||
|     render: function() { | ||||
|         var w = this.props.w || 32; | ||||
|         var h = this.props.h || 32; | ||||
|         var imgClass = this.props.imgClassName || ""; | ||||
|         const w = this.props.w || 32; | ||||
|         const h = this.props.h || 32; | ||||
|         const imgClass = this.props.imgClassName || ""; | ||||
|         return ( | ||||
|             <div className="mx_Spinner"> | ||||
|                 <img src="img/spinner.gif" width={w} height={h} className={imgClass} /> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -20,7 +20,6 @@ import TintableSvg from './TintableSvg'; | ||||
| import AccessibleButton from './AccessibleButton'; | ||||
| 
 | ||||
| export default class TintableSvgButton extends React.Component { | ||||
| 
 | ||||
|     constructor(props) { | ||||
|         super(props); | ||||
|     } | ||||
|  | ||||
| @ -48,7 +48,7 @@ export default React.createClass({ | ||||
|                 if (update && PlatformPeg.get()) { | ||||
|                     PlatformPeg.get().installUpdate(); | ||||
|                 } | ||||
|             } | ||||
|             }, | ||||
|         }); | ||||
|     }, | ||||
| 
 | ||||
| @ -61,7 +61,7 @@ export default React.createClass({ | ||||
|                 if (update && PlatformPeg.get()) { | ||||
|                     PlatformPeg.get().installUpdate(); | ||||
|                 } | ||||
|             } | ||||
|             }, | ||||
|         }); | ||||
|     }, | ||||
| 
 | ||||
| @ -103,5 +103,5 @@ export default React.createClass({ | ||||
|                 {action_button} | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -32,7 +32,7 @@ export default React.createClass({ | ||||
|     getDefaultProps: function() { | ||||
|         return { | ||||
|             detail: '', | ||||
|         } | ||||
|         }; | ||||
|     }, | ||||
| 
 | ||||
|     getStatusText: function() { | ||||
| @ -59,7 +59,7 @@ export default React.createClass({ | ||||
|         const message = this.getStatusText(); | ||||
|         const warning = _t('Warning'); | ||||
| 
 | ||||
|         if (!'getUpdateCheckStatusEnum' in PlatformPeg.get()) { | ||||
|         if (!('getUpdateCheckStatusEnum' in PlatformPeg.get())) { | ||||
|             return <div></div>; | ||||
|         } | ||||
| 
 | ||||
| @ -87,5 +87,5 @@ export default React.createClass({ | ||||
|                 </AccessibleButton> | ||||
|             </div> | ||||
|         ); | ||||
|     } | ||||
|     }, | ||||
| }); | ||||
|  | ||||
| @ -296,7 +296,7 @@ export const TermsAuthEntry = React.createClass({ | ||||
|             return <Loader />; | ||||
|         } | ||||
| 
 | ||||
|         let checkboxes = []; | ||||
|         const checkboxes = []; | ||||
|         let allChecked = true; | ||||
|         for (const policy of this.state.policies) { | ||||
|             const checked = this.state.toggledPolicies[policy.id]; | ||||
| @ -306,7 +306,7 @@ export const TermsAuthEntry = React.createClass({ | ||||
|                 <label key={"policy_checkbox_" + policy.id}> | ||||
|                     <input type="checkbox" onClick={() => this._trySubmit(policy.id)} checked={checked} /> | ||||
|                     <a href={policy.url} target="_blank" rel="noopener">{ policy.name }</a> | ||||
|                 </label> | ||||
|                 </label>, | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|  | ||||
| @ -103,7 +103,7 @@ module.exports = React.createClass({ | ||||
|             oldCanonicalAlias = this.props.canonicalAliasEvent.getContent().alias; | ||||
|         } | ||||
| 
 | ||||
|         let newCanonicalAlias = this.state.canonicalAlias; | ||||
|         const newCanonicalAlias = this.state.canonicalAlias; | ||||
| 
 | ||||
|         if (this.props.canSetCanonicalAlias && oldCanonicalAlias !== newCanonicalAlias) { | ||||
|             console.log("AliasSettings: Updating canonical alias"); | ||||
| @ -167,7 +167,7 @@ module.exports = React.createClass({ | ||||
| 
 | ||||
|         if (!this.props.canonicalAlias) { | ||||
|             this.setState({ | ||||
|                 canonicalAlias: alias | ||||
|                 canonicalAlias: alias, | ||||
|             }); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
| @ -22,7 +22,7 @@ import { _t } from '../../../languageHandler'; | ||||
| import Modal from '../../../Modal'; | ||||
| import isEqual from 'lodash/isEqual'; | ||||
| 
 | ||||
| const GROUP_ID_REGEX = /\+\S+\:\S+/; | ||||
| const GROUP_ID_REGEX = /\+\S+:\S+/; | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'RelatedGroupSettings', | ||||
|  | ||||
| @ -33,7 +33,6 @@ import Autocompleter from '../../../autocomplete/Autocompleter'; | ||||
| const COMPOSER_SELECTED = 0; | ||||
| 
 | ||||
| export default class Autocomplete extends React.Component { | ||||
| 
 | ||||
|     constructor(props) { | ||||
|         super(props); | ||||
| 
 | ||||
|  | ||||
| @ -107,7 +107,7 @@ module.exports = React.createClass({ | ||||
| 
 | ||||
|         // FIXME: do we want to factor out all image displaying between this and MImageBody - especially for lightboxing?
 | ||||
|         let image = p["og:image"]; | ||||
|         let imageMaxWidth = 100, imageMaxHeight = 100; | ||||
|         const imageMaxWidth = 100; const imageMaxHeight = 100; | ||||
|         if (image && image.startsWith("mxc://")) { | ||||
|             image = MatrixClientPeg.get().mxcUrlToHttp(image, imageMaxWidth, imageMaxHeight); | ||||
|         } | ||||
|  | ||||
| @ -269,7 +269,7 @@ export default class MessageComposer extends React.Component { | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|         let e2eImg, e2eTitle, e2eClass; | ||||
|         let e2eImg; let e2eTitle; let e2eClass; | ||||
|         const roomIsEncrypted = MatrixClientPeg.get().isRoomEncrypted(this.props.room.roomId); | ||||
|         if (roomIsEncrypted) { | ||||
|             // FIXME: show a /!\ if there are untrusted devices in the room...
 | ||||
| @ -429,7 +429,7 @@ export default class MessageComposer extends React.Component { | ||||
|                              className="mx_MessageComposer_formatbar_cancel mx_filterFlipColor" | ||||
|                              src="img/icon-text-cancel.svg" /> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                 </div>; | ||||
|         } | ||||
| 
 | ||||
|         return ( | ||||
|  | ||||
| @ -67,7 +67,7 @@ const EMOJI_UNICODE_TO_SHORTNAME = mapUnicodeToShort(); | ||||
| const REGEX_EMOJI_WHITESPACE = new RegExp('(?:^|\\s)(' + asciiRegexp + ')\\s$'); | ||||
| const EMOJI_REGEX = new RegExp(unicodeRegexp, 'g'); | ||||
| 
 | ||||
| const TYPING_USER_TIMEOUT = 10000, TYPING_SERVER_TIMEOUT = 30000; | ||||
| const TYPING_USER_TIMEOUT = 10000; const TYPING_SERVER_TIMEOUT = 30000; | ||||
| 
 | ||||
| const ENTITY_TYPES = { | ||||
|     AT_ROOM_PILL: 'ATROOMPILL', | ||||
| @ -1078,7 +1078,7 @@ export default class MessageComposerInput extends React.Component { | ||||
| 
 | ||||
|         // only look for commands if the first block contains simple unformatted text
 | ||||
|         // i.e. no pills or rich-text formatting and begins with a /.
 | ||||
|         let cmd, commandText; | ||||
|         let cmd; let commandText; | ||||
|         const firstChild = editorState.document.nodes.get(0); | ||||
|         const firstGrandChild = firstChild && firstChild.nodes.get(0); | ||||
|         if (firstChild && firstGrandChild && | ||||
|  | ||||
| @ -93,7 +93,7 @@ module.exports = React.createClass({ | ||||
|     }, | ||||
| 
 | ||||
|     render: function() { | ||||
|         let joinBlock, previewBlock; | ||||
|         let joinBlock; let previewBlock; | ||||
| 
 | ||||
|         if (this.props.spinner || this.state.busy) { | ||||
|             const Spinner = sdk.getComponent("elements.Spinner"); | ||||
|  | ||||
| @ -657,31 +657,31 @@ module.exports = React.createClass({ | ||||
|         const userLevels = powerLevels.users || {}; | ||||
| 
 | ||||
|         const powerLevelDescriptors = { | ||||
|             users_default: { | ||||
|             "users_default": { | ||||
|                 desc: _t('The default role for new room members is'), | ||||
|                 defaultValue: 0, | ||||
|             }, | ||||
|             events_default: { | ||||
|             "events_default": { | ||||
|                 desc: _t('To send messages, you must be a'), | ||||
|                 defaultValue: 0, | ||||
|             }, | ||||
|             invite: { | ||||
|             "invite": { | ||||
|                 desc: _t('To invite users into the room, you must be a'), | ||||
|                 defaultValue: 50, | ||||
|             }, | ||||
|             state_default: { | ||||
|             "state_default": { | ||||
|                 desc: _t('To configure the room, you must be a'), | ||||
|                 defaultValue: 50, | ||||
|             }, | ||||
|             kick: { | ||||
|             "kick": { | ||||
|                 desc: _t('To kick users, you must be a'), | ||||
|                 defaultValue: 50, | ||||
|             }, | ||||
|             ban: { | ||||
|             "ban": { | ||||
|                 desc: _t('To ban users, you must be a'), | ||||
|                 defaultValue: 50, | ||||
|             }, | ||||
|             redact: { | ||||
|             "redact": { | ||||
|                 desc: _t('To remove other users\' messages, you must be a'), | ||||
|                 defaultValue: 50, | ||||
|             }, | ||||
|  | ||||
| @ -290,7 +290,7 @@ module.exports = React.createClass({ | ||||
|         for (const i in this.state.vectorContentRules.rules) { | ||||
|             const rule = this.state.vectorContentRules.rules[i]; | ||||
| 
 | ||||
|             let enabled, actions; | ||||
|             let enabled; let actions; | ||||
|             switch (newPushRuleVectorState) { | ||||
|                 case PushRuleVectorState.ON: | ||||
|                     if (rule.actions.length !== 1) { | ||||
|  | ||||
| @ -16,9 +16,9 @@ limitations under the License. | ||||
| 
 | ||||
| 'use strict'; | ||||
| 
 | ||||
| var NotificationUtils = require('./NotificationUtils'); | ||||
| const NotificationUtils = require('./NotificationUtils'); | ||||
| 
 | ||||
| var encodeActions = NotificationUtils.encodeActions; | ||||
| const encodeActions = NotificationUtils.encodeActions; | ||||
| 
 | ||||
| module.exports = { | ||||
|     ACTION_NOTIFY: encodeActions({notify: true}), | ||||
|  | ||||
| @ -14,7 +14,7 @@ See the License for the specific language governing permissions and | ||||
| limitations under the License. | ||||
| */ | ||||
| 
 | ||||
| const PHONE_NUMBER_REGEXP = /^[0-9 -\.]+$/; | ||||
| const PHONE_NUMBER_REGEXP = /^[0-9 -.]+$/; | ||||
| 
 | ||||
| /* | ||||
|  * Do basic validation to determine if the given input could be | ||||
|  | ||||
| @ -23,7 +23,6 @@ limitations under the License. | ||||
|  * intended to handle environmental factors for specific settings. | ||||
|  */ | ||||
| export default class SettingController { | ||||
| 
 | ||||
|     /** | ||||
|      * Gets the overridden value for the setting, if any. This must return null if the | ||||
|      * value is not to be overridden, otherwise it must return the new value. | ||||
|  | ||||
| @ -23,7 +23,6 @@ import Unread from '../Unread'; | ||||
|  * the RoomList. | ||||
|  */ | ||||
| class RoomListStore extends Store { | ||||
| 
 | ||||
|     static _listOrders = { | ||||
|         "m.favourite": "manual", | ||||
|         "im.vector.fake.invite": "recent", | ||||
|  | ||||
| @ -77,7 +77,7 @@ const ALLOWED_BLOB_MIMETYPES = { | ||||
|     'audio/x-pn-wav': true, | ||||
|     'audio/flac': true, | ||||
|     'audio/x-flac': true, | ||||
| } | ||||
| }; | ||||
| 
 | ||||
| /** | ||||
|  * Decrypt a file attached to a matrix event. | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user