Merge branches 'develop' and 't3chguy/remove_bluebird' of https://github.com/vector-im/riot-web into t3chguy/remove_bluebird
						commit
						eac6c46d28
					
				
							
								
								
									
										72
									
								
								CHANGELOG.md
								
								
								
								
							
							
						
						
									
										72
									
								
								CHANGELOG.md
								
								
								
								
							|  | @ -1,3 +1,75 @@ | |||
| Changes in [1.5.3](https://github.com/vector-im/riot-web/releases/tag/v1.5.3) (2019-11-06) | ||||
| ========================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.2...v1.5.3) | ||||
| 
 | ||||
|  * Remove the 'auto hide menu bar' option on Mac | ||||
|    [\#11326](https://github.com/vector-im/riot-web/pull/11326) | ||||
|  * Expose feature_user_info_panel on riot.im/develop | ||||
|    [\#11304](https://github.com/vector-im/riot-web/pull/11304) | ||||
|  * Upgrade electron-notarize | ||||
|    [\#11312](https://github.com/vector-im/riot-web/pull/11312) | ||||
|  * Fix close window behaviour on Macos | ||||
|    [\#11309](https://github.com/vector-im/riot-web/pull/11309) | ||||
|  * Merge: Add dependency to eslint-plugin-react-hooks as react-sdk did | ||||
|    [\#11307](https://github.com/vector-im/riot-web/pull/11307) | ||||
|  * Add dependency to eslint-plugin-react-hooks as react-sdk did | ||||
|    [\#11306](https://github.com/vector-im/riot-web/pull/11306) | ||||
|  * Update from Weblate | ||||
|    [\#11300](https://github.com/vector-im/riot-web/pull/11300) | ||||
| 
 | ||||
| Changes in [1.5.2](https://github.com/vector-im/riot-web/releases/tag/v1.5.2) (2019-11-04) | ||||
| ========================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.1...v1.5.2) | ||||
| 
 | ||||
|  * Fix close window behaviour on Macos | ||||
|    [\#11311](https://github.com/vector-im/riot-web/pull/11311) | ||||
| 
 | ||||
| Changes in [1.5.1](https://github.com/vector-im/riot-web/releases/tag/v1.5.1) (2019-11-04) | ||||
| ========================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.1-rc.2...v1.5.1) | ||||
| 
 | ||||
|  * No changes since rc.2 | ||||
| 
 | ||||
| Changes in [1.5.1-rc.2](https://github.com/vector-im/riot-web/releases/tag/v1.5.1-rc.2) (2019-11-01) | ||||
| ==================================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.1-rc.1...v1.5.1-rc.2) | ||||
| 
 | ||||
|  * Updated react-sdk with fix for bug that caused room filtering to | ||||
|    omit results. | ||||
| 
 | ||||
| Changes in [1.5.1-rc.1](https://github.com/vector-im/riot-web/releases/tag/v1.5.1-rc.1) (2019-10-30) | ||||
| ==================================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.0...v1.5.1-rc.1) | ||||
| 
 | ||||
|  * Add ability to hide tray icon on non-Mac (which has no tray icon) | ||||
|    [\#11258](https://github.com/vector-im/riot-web/pull/11258) | ||||
|  * Fix bug preventing display from sleeping after a call | ||||
|    [\#11264](https://github.com/vector-im/riot-web/pull/11264) | ||||
|  * Remove mention of CI scripts from docs | ||||
|    [\#11257](https://github.com/vector-im/riot-web/pull/11257) | ||||
|  * Fix skinning replaces being broken since being rewritten as React FC's | ||||
|    [\#11254](https://github.com/vector-im/riot-web/pull/11254) | ||||
|  * Update config docs about identity servers | ||||
|    [\#11249](https://github.com/vector-im/riot-web/pull/11249) | ||||
|  * Remove unneeded help about identity servers | ||||
|    [\#11248](https://github.com/vector-im/riot-web/pull/11248) | ||||
|  * Update from Weblate | ||||
|    [\#11243](https://github.com/vector-im/riot-web/pull/11243) | ||||
|  * Update sample config for new matrix.org CS API URL | ||||
|    [\#11207](https://github.com/vector-im/riot-web/pull/11207) | ||||
|  * clarify where the e2e tests are located | ||||
|    [\#11115](https://github.com/vector-im/riot-web/pull/11115) | ||||
|  * Update from Weblate | ||||
|    [\#11171](https://github.com/vector-im/riot-web/pull/11171) | ||||
|  * Prevent referrers from being sent | ||||
|    [\#6155](https://github.com/vector-im/riot-web/pull/6155) | ||||
|  * Add darkModeSupport to allow dark themed title bar. | ||||
|    [\#11140](https://github.com/vector-im/riot-web/pull/11140) | ||||
|  * Fix the label of Turkish language | ||||
|    [\#11124](https://github.com/vector-im/riot-web/pull/11124) | ||||
|  * Update default HS config to match well-known | ||||
|    [\#11112](https://github.com/vector-im/riot-web/pull/11112) | ||||
| 
 | ||||
| Changes in [1.5.0](https://github.com/vector-im/riot-web/releases/tag/v1.5.0) (2019-10-18) | ||||
| ========================================================================================== | ||||
| [Full Changelog](https://github.com/vector-im/riot-web/compare/v1.5.0-rc.1...v1.5.0) | ||||
|  |  | |||
|  | @ -22,9 +22,10 @@ For a good example, see https://riot.im/develop/config.json. | |||
|      `default_hs_url` is specified. When multiple sources are specified, it is unclear | ||||
|      which should take priority and therefore the application cannot continue. | ||||
|    * As of Riot 1.4.0, identity servers are optional. See [Identity servers](#identity-servers) below. | ||||
| 1. `features`: Lookup of optional features that may be `enable`d, `disable`d, or exposed to the user | ||||
|    in the `labs` section of settings.  The available optional experimental features vary from | ||||
|    release to release. The available features are described in [labs.md](labs.md). | ||||
| 1. `features`: Lookup of optional features that may be `enable`d, `disable`d, or | ||||
|    exposed to the user in the `labs` section of settings. The available | ||||
|    optional experimental features vary from release to release and are [documented](labs.md). The feature flag process is | ||||
|    [documented](feature-flags.md) as well. | ||||
| 1. `showLabsSettings`: Shows the "labs" tab of user settings even when no `features` are enabled | ||||
|    or present. Useful for getting at settings which may be otherwise hidden. | ||||
| 1. `brand`: String to pass to your homeserver when configuring email notifications, to let the | ||||
|  |  | |||
|  | @ -0,0 +1,112 @@ | |||
| # Feature flags | ||||
| 
 | ||||
| When developing new features for Riot, we use feature flags to give us more | ||||
| flexibility and control over when and where those features are enabled. | ||||
| 
 | ||||
| For example, flags make the following things possible: | ||||
| 
 | ||||
| * Extended testing of a feature via labs on develop | ||||
| * Enabling features when ready instead of the first moment the code is released | ||||
| * Testing a feature with a specific set of users (by enabling only on a specific | ||||
|   Riot instance) | ||||
| 
 | ||||
| The size of the feature controlled by a feature flag may vary widely: it could | ||||
| be a large project like reactions or a smaller change to an existing algorithm. | ||||
| A large project might use several feature flags if it's useful to control the | ||||
| deployment of different portions independently. | ||||
| 
 | ||||
| Everyone involved in a feature (engineering, design, product, reviewers) should | ||||
| think about its deployment plan up front as best as possible so we can have the | ||||
| right feature flags in place from the start. | ||||
| 
 | ||||
| ## Interaction with spec process | ||||
| 
 | ||||
| Historically, we have often used feature flags to guard client features that | ||||
| depend on unstable spec features. Unfortunately, there was never clear agreement | ||||
| about how long such a flag should live for, when it should be removed, etc. | ||||
| 
 | ||||
| Under the [new spec | ||||
| process](https://github.com/matrix-org/matrix-doc/pull/2324), server-side | ||||
| unstable features can be used by clients and enabled by default as long as | ||||
| clients commit to doing the associated clean up work once a feature stabilises. | ||||
| 
 | ||||
| ## Starting work on a feature | ||||
| 
 | ||||
| When starting work on a feature, we should create a matching feature flag: | ||||
| 
 | ||||
| 1. Add a new | ||||
|    [setting](https://github.com/matrix-org/matrix-react-sdk/blob/develop/src/settings/Settings.js) | ||||
|    of the form: | ||||
| ```js | ||||
|     "feature_cats": { | ||||
|         isFeature: true, | ||||
|         displayName: _td("Adds cats everywhere"), | ||||
|         supportedLevels: LEVELS_FEATURE, | ||||
|         default: false, | ||||
|     }, | ||||
| ``` | ||||
| 2. Check whether the feature is enabled as appropriate: | ||||
| ```js | ||||
|     SettingsStore.isFeatureEnabled("feature_cats") | ||||
| ``` | ||||
| 3. Add the feature to the [set of labs on develop](https://github.com/vector-im/riot-web/blob/develop/riot.im/develop/config.json): | ||||
| ```json | ||||
|     "features": { | ||||
|         "feature_cats": "labs" | ||||
|     }, | ||||
| ``` | ||||
| 4. Document the feature in the [labs documentation](https://github.com/vector-im/riot-web/blob/develop/docs/labs.md) | ||||
| 
 | ||||
| With these steps completed, the feature is disabled by default, but can be | ||||
| enabled on develop by interested users for testing. | ||||
| 
 | ||||
| Different features may have different deployment plans for when to enable where. | ||||
| The following lists a few common options. | ||||
| 
 | ||||
| ## Enabling by default on develop | ||||
| 
 | ||||
| Set the feature to `enable` in the [develop config](https://github.com/vector-im/riot-web/blob/develop/riot.im/develop/config.json): | ||||
| 
 | ||||
| ```json | ||||
|     "features": { | ||||
|         "feature_cats": "enable" | ||||
|     }, | ||||
| ``` | ||||
| 
 | ||||
| ## Enabling by default on staging and app | ||||
| 
 | ||||
| Set the feature to `enable` in the [app | ||||
| config](https://github.com/vector-im/riot-web/blob/develop/riot.im/app/config.json). | ||||
| 
 | ||||
| ## Feature deployed successfully | ||||
| 
 | ||||
| Once we're confident that a feature is working well, we should remove the flag: | ||||
| 
 | ||||
| 1. Remove the [setting](https://github.com/matrix-org/matrix-react-sdk/blob/develop/src/settings/Settings.js) | ||||
| 2. Remove all `isFeatureEnabled` lines that test for the feature's setting | ||||
| 3. Remove the feature from the [labs documentation](https://github.com/vector-im/riot-web/blob/develop/docs/labs.md) | ||||
| 4. Remove feature state from | ||||
|    [develop](https://github.com/vector-im/riot-web/blob/develop/riot.im/develop/config.json) | ||||
|    and [app](https://github.com/vector-im/riot-web/blob/develop/riot.im/app/config.json) | ||||
|    configs | ||||
| 5. Celebrate! 🥳 | ||||
| 
 | ||||
| ## Convert to a regular setting (optional) | ||||
| 
 | ||||
| Sometimes we decide a feature should always be user-controllable as a setting | ||||
| even after it has been fully deployed. In that case, we would craft a new, | ||||
| regular setting: | ||||
| 
 | ||||
| 1. Remove the feature flag from | ||||
|    [settings](https://github.com/matrix-org/matrix-react-sdk/blob/develop/src/settings/Settings.js) | ||||
|    and add a regular setting with the appropriate levels for your feature | ||||
| 2. Replace the `isFeatureEnabled` lines with `getValue` or similar calls | ||||
|    according to the [settings | ||||
|    docs](https://github.com/matrix-org/matrix-react-sdk/blob/develop/docs/settings.md) | ||||
|    (checking carefully, as we may want a different mix of code paths when the | ||||
|    feature is always present but gated by a setting) | ||||
| 3. Remove the feature from the [labs documentation](https://github.com/vector-im/riot-web/blob/develop/docs/labs.md) | ||||
| 4. Remove feature state from | ||||
|    [develop](https://github.com/vector-im/riot-web/blob/develop/riot.im/develop/config.json) | ||||
|    and [app](https://github.com/vector-im/riot-web/blob/develop/riot.im/app/config.json) | ||||
|    configs | ||||
							
								
								
									
										22
									
								
								docs/labs.md
								
								
								
								
							
							
						
						
									
										22
									
								
								docs/labs.md
								
								
								
								
							|  | @ -49,3 +49,25 @@ That's it. Now should see your new counter under the header. | |||
| ## Multiple integration managers (`feature_many_integration_managers`) | ||||
| 
 | ||||
| Exposes a way to access all the integration managers known to Riot. This is an implementation of [MSC1957](https://github.com/matrix-org/matrix-doc/pull/1957). | ||||
| 
 | ||||
| ## New ways to ignore people (`feature_mjolnir`) | ||||
| 
 | ||||
| When enabled, a new settings tab appears for users to be able to manage their ban lists. | ||||
| This is a different kind of ignoring where the ignored user's messages still get rendered, | ||||
| but are hidden by default. | ||||
| 
 | ||||
| Ban lists are rooms within Matrix, proposed as [MSC2313](https://github.com/matrix-org/matrix-doc/pull/2313). | ||||
| [Mjolnir](https://github.com/matrix-org/mjolnir) is a set of moderation tools which support | ||||
| ban lists. | ||||
| 
 | ||||
| ## Verifications in DMs (`feature_dm_verification`) | ||||
| 
 | ||||
| An implementation of [MSC2241](https://github.com/matrix-org/matrix-doc/pull/2241). When enabled, verification might not work with devices which don't support MSC2241. | ||||
| 
 | ||||
| This also includes a new implementation of the user & member info panel, designed to share more code between showing community members & room members. Built on top of this new panel is also a new UX for verification from the member panel. | ||||
| 
 | ||||
| ## Cross-signing (`feature_cross_signing`) | ||||
| 
 | ||||
| Cross-signing ([MSC1756](https://github.com/matrix-org/matrix-doc/pull/1756)) | ||||
| improves the device verification experience by allowing you to verify a user | ||||
| instead of verifying each of their devices. | ||||
|  |  | |||
|  | @ -11,11 +11,11 @@ As of Jan 2017, skins are not fully supported; riot is the only available skin. | |||
| To define a theme for Riot: | ||||
| 
 | ||||
|  1. Pick a name, e.g. `teal`. at time of writing we have `light` and `dark`. | ||||
|  2. Fork `src/skins/vector/css/themes/dark.scss` to be teal.scss | ||||
|  3. Fork `src/skins/vector/css/themes/_base.scss` to be _teal.scss | ||||
|  4. Override variables in _teal.scss as desired. You may wish to delete ones | ||||
|     which don't differ from _base.scss, to make it clear which are being | ||||
|     overridden. If every single colour is being changed (as per _dark.scss) | ||||
|  2. Fork `src/skins/vector/css/themes/dark.scss` to be `teal.scss` | ||||
|  3. Fork `src/skins/vector/css/themes/_base.scss` to be `_teal.scss` | ||||
|  4. Override variables in `_teal.scss` as desired. You may wish to delete ones | ||||
|     which don't differ from `_base.scss`, to make it clear which are being | ||||
|     overridden. If every single colour is being changed (as per `_dark.scss`) | ||||
|     then you might as well keep them all. | ||||
|  5. Add the theme to the list of entrypoints in webpack.config.js | ||||
|  6. Add the theme to the list of themes in matrix-react-sdk's UserSettings.js | ||||
|  | @ -23,3 +23,58 @@ To define a theme for Riot: | |||
| 
 | ||||
| In future, the assets for a theme will probably be gathered together into a | ||||
| single directory tree. | ||||
| 
 | ||||
| Custom Themes | ||||
| ============= | ||||
| 
 | ||||
| Themes derived from the built in themes may also be defined in settings. | ||||
| 
 | ||||
| To avoid name collisions, the internal name of a theme is | ||||
| `custom-${theme.name}`. So if you want to set the custom theme below as the | ||||
| default theme, you would use `default_theme: "custom-Electric Blue"`. | ||||
| 
 | ||||
| eg. in config.json: | ||||
| 
 | ||||
| ``` | ||||
| "settingDefaults": { | ||||
|         "custom_themes": [ | ||||
|             { | ||||
|                 "name": "Electric Blue", | ||||
|                 "is_dark": false, | ||||
|                 "colors": { | ||||
|                     "accent-color": "#3596fc", | ||||
|                     "primary-color": "#368bd6", | ||||
|                     "warning-color": "#ff4b55", | ||||
|                     "sidebar-color": "#27303a", | ||||
|                     "roomlist-background-color": "#f3f8fd", | ||||
|                     "roomlist-text-color": "#2e2f32", | ||||
|                     "roomlist-text-secondary-color": "#61708b", | ||||
|                     "roomlist-highlights-color": "#ffffff", | ||||
|                     "roomlist-separator-color": "#e3e8f0", | ||||
|                     "timeline-background-color": "#ffffff", | ||||
|                     "timeline-text-color": "#2e2f32", | ||||
|                     "timeline-text-secondary-color": "#61708b", | ||||
|                     "timeline-highlights-color": "#f3f8fd" | ||||
|                 } | ||||
|             }, { | ||||
|                 "name": "Deep Purple", | ||||
|                 "is_dark": true, | ||||
|                 "colors": { | ||||
|                     "accent-color": "#6503b3", | ||||
|                     "primary-color": "#368bd6", | ||||
|                     "warning-color": "#b30356", | ||||
|                     "sidebar-color": "#15171B", | ||||
|                     "roomlist-background-color": "#22262E", | ||||
|                     "roomlist-text-color": "#A1B2D1", | ||||
|                     "roomlist-text-secondary-color": "#EDF3FF", | ||||
|                     "roomlist-highlights-color": "#343A46", | ||||
|                     "roomlist-separator-color": "#a1b2d1", | ||||
|                     "timeline-background-color": "#181b21", | ||||
|                     "timeline-text-color": "#EDF3FF", | ||||
|                     "timeline-text-secondary-color": "#A1B2D1", | ||||
|                     "timeline-highlights-color": "#22262E" | ||||
|                 } | ||||
|             } | ||||
|         ] | ||||
|     } | ||||
| ``` | ||||
|  |  | |||
|  | @ -0,0 +1,25 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | ||||
| <plist version="1.0"> | ||||
| <dict> | ||||
|     <!-- Entitlements from electron-builder's defaults | ||||
|          (https://github.com/electron-userland/electron-builder/blob/master/packages/app-builder-lib/templates/entitlements.mac.plist) | ||||
|          nb. This does *not* include the app sandbox: at the time of adding this file, | ||||
|          we were using electron-builder 21.2.0 which does not have the sandbox entitlement. | ||||
|          Latest electron-builder does, but it appears to be causing issues: | ||||
|          (https://github.com/electron-userland/electron-builder/issues/4390) | ||||
|     --> | ||||
|     <key>com.apple.security.cs.allow-unsigned-executable-memory</key> | ||||
|     <true/> | ||||
|     <!-- https://github.com/electron-userland/electron-builder/issues/3940 --> | ||||
|     <key>com.apple.security.cs.disable-library-validation</key> | ||||
|     <true/> | ||||
| 
 | ||||
|     <!-- Our own additional entitlements (we need to access the camera and | ||||
|         mic for VoIP calls --> | ||||
|     <key>com.apple.security.device.camera</key> | ||||
|     <true/> | ||||
|     <key>com.apple.security.device.audio-input</key> | ||||
|     <true/> | ||||
| </dict> | ||||
| </plist> | ||||
|  | @ -2,7 +2,7 @@ | |||
|   "name": "riot-web", | ||||
|   "productName": "Riot", | ||||
|   "main": "src/electron-main.js", | ||||
|   "version": "1.5.0", | ||||
|   "version": "1.5.3", | ||||
|   "description": "A feature-rich client for Matrix.org", | ||||
|   "author": "New Vector Ltd.", | ||||
|   "dependencies": { | ||||
|  |  | |||
|  | @ -77,6 +77,18 @@ try { | |||
| try { | ||||
|     // Load local config and use it to override values from the one baked with the build
 | ||||
|     const localConfig = require(path.join(app.getPath('userData'), 'config.json')); | ||||
| 
 | ||||
|     // If the local config has a homeserver defined, don't use the homeserver from the build
 | ||||
|     // config. This is to avoid a problem where Riot thinks there are multiple homeservers
 | ||||
|     // defined, and panics as a result.
 | ||||
|     const homeserverProps = ['default_is_url', 'default_hs_url', 'default_server_name', 'default_server_config']; | ||||
|     if (Object.keys(localConfig).find(k => homeserverProps.includes(k))) { | ||||
|         // Rip out all the homeserver options from the vector config
 | ||||
|         vectorConfig = Object.keys(vectorConfig) | ||||
|             .filter(k => !homeserverProps.includes(k)) | ||||
|             .reduce((obj, key) => {obj[key] = vectorConfig[key]; return obj;}, {}); | ||||
|     } | ||||
| 
 | ||||
|     vectorConfig = Object.assign(vectorConfig, localConfig); | ||||
| } catch (e) { | ||||
|     // Could not load local config, this is expected in most cases.
 | ||||
|  | @ -393,7 +405,7 @@ app.on('ready', () => { | |||
|     }); | ||||
|     mainWindow.on('close', (e) => { | ||||
|         // If we are not quitting and have a tray icon then minimize to tray
 | ||||
|         if (!global.appQuitting && tray.hasTray()) { | ||||
|         if (!global.appQuitting && (tray.hasTray() || process.platform === 'darwin')) { | ||||
|             // On Mac, closing the window just hides it
 | ||||
|             // (this is generally how single-window Mac apps
 | ||||
|             // behave, eg. Mail.app)
 | ||||
|  |  | |||
							
								
								
									
										12
									
								
								package.json
								
								
								
								
							
							
						
						
									
										12
									
								
								package.json
								
								
								
								
							|  | @ -2,7 +2,7 @@ | |||
|   "name": "riot-web", | ||||
|   "productName": "Riot", | ||||
|   "main": "electron_app/src/electron-main.js", | ||||
|   "version": "1.5.0", | ||||
|   "version": "1.5.3", | ||||
|   "description": "A feature-rich client for Matrix.org", | ||||
|   "author": "New Vector Ltd.", | ||||
|   "repository": { | ||||
|  | @ -73,8 +73,8 @@ | |||
|     "gemini-scrollbar": "github:matrix-org/gemini-scrollbar#91e1e566", | ||||
|     "gfm.css": "^1.1.2", | ||||
|     "highlight.js": "^9.13.1", | ||||
|     "matrix-js-sdk": "github:matrix-org/matrix-js-sdk#develop", | ||||
|     "matrix-react-sdk": "github:matrix-org/matrix-react-sdk#develop", | ||||
|     "matrix-js-sdk": "2.4.3", | ||||
|     "matrix-react-sdk": "1.7.2", | ||||
|     "modernizr": "^3.6.0", | ||||
|     "olm": "https://packages.matrix.org/npm/olm/olm-3.1.4.tgz", | ||||
|     "prop-types": "^15.7.2", | ||||
|  | @ -109,12 +109,14 @@ | |||
|     "electron-builder": "^21.2.0", | ||||
|     "electron-builder-squirrel-windows": "^21.2.0", | ||||
|     "electron-devtools-installer": "^2.2.4", | ||||
|     "electron-notarize": "^0.1.1", | ||||
|     "electron-notarize": "^0.2.0", | ||||
|     "eslint": "^5.8.0", | ||||
|     "eslint-config-google": "^0.7.1", | ||||
|     "eslint-plugin-babel": "^4.1.2", | ||||
|     "eslint-plugin-jest": "^23.0.4", | ||||
|     "eslint-plugin-flowtype": "^2.50.3", | ||||
|     "eslint-plugin-react": "^7.11.1", | ||||
|     "eslint-plugin-react-hooks": "^2.2.0", | ||||
|     "expect": "^1.16.0", | ||||
|     "file-loader": "^3.0.1", | ||||
|     "fs-extra": "^0.30.0", | ||||
|  | @ -152,7 +154,7 @@ | |||
|   }, | ||||
|   "build": { | ||||
|     "appId": "im.riot.app", | ||||
|     "electronVersion": "6.1.12", | ||||
|     "electronVersion": "7.1.2", | ||||
|     "files": [ | ||||
|       "node_modules/**", | ||||
|       "src/**" | ||||
|  |  | |||
|  | @ -25,8 +25,6 @@ | |||
|         } | ||||
|     }, | ||||
|     "features": { | ||||
|         "feature_lazyloading": "enable", | ||||
|         "feature_room_breadcrumbs": "labs" | ||||
|     }, | ||||
|     "roomDirectory": { | ||||
|         "servers": [ | ||||
|  |  | |||
|  | @ -13,21 +13,14 @@ | |||
|     "hosting_signup_link": "https://modular.im/?utm_source=riot-web&utm_medium=web", | ||||
|     "bug_report_endpoint_url": "https://riot.im/bugreports/submit", | ||||
|     "features": { | ||||
|         "feature_rich_quoting": "labs", | ||||
|         "feature_pinning": "labs", | ||||
|         "feature_presence_management": "labs", | ||||
|         "feature_sticker_messages": "labs", | ||||
|         "feature_jitsi": "labs", | ||||
|         "feature_tag_panel": "enable", | ||||
|         "feature_keybackup": "labs", | ||||
|         "feature_custom_status": "labs", | ||||
|         "feature_custom_tags": "labs", | ||||
|         "feature_lazyloading": "enable", | ||||
|         "feature_tabbed_settings": "labs", | ||||
|         "feature_sas": "labs", | ||||
|         "feature_room_breadcrumbs": "labs", | ||||
|         "feature_state_counters": "labs", | ||||
|         "feature_many_integration_managers": "labs" | ||||
|         "feature_many_integration_managers": "labs", | ||||
|         "feature_mjolnir": "labs", | ||||
|         "feature_dm_verification": "labs", | ||||
|         "feature_cross_signing": "labs" | ||||
|     }, | ||||
|     "welcomeUserId": "@riot-bot:matrix.org", | ||||
|     "piwik": { | ||||
|  |  | |||
|  | @ -13,7 +13,7 @@ exports.default = async function(context) { | |||
|         // from the keychain, so we need to get it from the environment.
 | ||||
|         const userId = process.env.NOTARIZE_APPLE_ID; | ||||
|         if (userId === undefined) { | ||||
|             throw new Exception("User ID not found. Set NOTARIZE_APPLE_ID."); | ||||
|             throw new Error("User ID not found. Set NOTARIZE_APPLE_ID."); | ||||
|         } | ||||
| 
 | ||||
|         console.log("Notarising macOS app. This may be some time."); | ||||
|  |  | |||
|  | @ -41,6 +41,13 @@ | |||
|     "Sign In": "Přihlásit se", | ||||
|     "Create Account": "Vytvořit účet", | ||||
|     "Need help?": "Chcete pomoct?", | ||||
|     "Explore rooms": "Objevit místnosti", | ||||
|     "Room Directory": "Adresář místností" | ||||
|     "Explore rooms": "Prohlížet místnosti", | ||||
|     "Room Directory": "Adresář místností", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Konfigurace Riotu obsahuje neplatný JSON. Opravte prosím tento problém a obnovte stránku.", | ||||
|     "The message from the parser is: %(message)s": "Zpráva z parseru je: %(message)s", | ||||
|     "Invalid JSON": "Neplatný JSON", | ||||
|     "Your Riot is misconfigured": "Riot je špatně nakonfigurován", | ||||
|     "Unexpected error preparing the app. See console for details.": "Neočekávaná chyba při přípravě aplikace. V konzoli je více informací.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Neplatná konfigurace: je možné specifikovat pouze jednu volbu z default_server_config, default_server_name, nebo default_hs_url.", | ||||
|     "Invalid configuration: no default server specified.": "Neplatná konfigurace: není zadán výchozí server." | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,25 @@ | |||
| { | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Mae eich gosodiadau Riot yn cynnwys JSON annilys. Cywirwch y broblem ac ail-lwythwch y dudalen.", | ||||
|     "The message from the parser is: %(message)s": "Y neges gan y dosrannudd yn: %(message)s", | ||||
|     "Invalid JSON": "JSON annilys", | ||||
|     "Your Riot is misconfigured": "Mae eich Riot wedi'i gamosod", | ||||
|     "Unexpected error preparing the app. See console for details.": "Gwall annisgwyl wrth baratoi'r app. Gweler y consol am fanylion.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Gosodiad annilys: dim ond un o default_server_config, default_server_name, neu default_hs_url y gall ei nodi.", | ||||
|     "Invalid configuration: no default server specified.": "Gosodiad annilys: ni nodwyd gweinydd diofyn.", | ||||
|     "Riot Desktop on %(platformName)s": "Riot Cyfrifiadur ar %(platformName)s", | ||||
|     "Unknown device": "Dyfais anhysbys", | ||||
|     "%(appName)s via %(browserName)s on %(osName)s": "%(appName)s trwy %(browserName)s ar %(osName)s", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "Mae angen i chi fod yn defnyddio HTTPS i osod galwad rhannu sgrin.", | ||||
|     "powered by Matrix": "pwerwyd gan Matrix", | ||||
|     "Custom Server Options": "Opsiynau Gweinydd Addasadwy", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different homeserver URL. This allows you to use Riot with an existing Matrix account on a different homeserver.": "Gallwch ddefnyddio'r opsiynau gweinydd addasadwy i mewngofnodi i mewn i weinyddion Matrix eraill trwy rhoi URL hafanweinydd gwahanol. Mae hyn yn caniatáu ichi ddefnyddio Riot gyda chyfrif Matrix sy'n bodoli eisoes ar hafanweinydd gwahanol.", | ||||
|     "Dismiss": "Wfftio", | ||||
|     "Welcome to Riot.im": "Croeso i Riot.im", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "Sgwrsio a chydweithredu datganoledig a amgryptiedig â phwerwyd gan [matrix]", | ||||
|     "Sign In": "Mewngofnodi", | ||||
|     "Create Account": "Creu Cyfrif", | ||||
|     "Need help?": "Angen cymorth?", | ||||
|     "Chat with Riot Bot": "Sgwrsio gyda Riot Bot", | ||||
|     "Explore rooms": "Archwilio Ystafelloedd", | ||||
|     "Room Directory": "Cyfeiriadur Ystafelloedd" | ||||
| } | ||||
|  | @ -4,11 +4,11 @@ | |||
|     "Dismiss": "Απόρριψη", | ||||
|     "Riot Desktop on %(platformName)s": "Riot Desktop σε %(platformName)s", | ||||
|     "Unknown device": "Άγνωστη συσκευή", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "Απαιτείται η χρήση HTTPS για το διαμοιρασμό της επιφάνειας εργασίας μέσω κλήσης.", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "Απαιτείται η χρήση HTTPS για την πραγματοποίηση κλήσης διαμοιρασμού επιφάνειας εργασίας.", | ||||
|     "Riot is not supported on mobile web. Install the app?": "Το Riot δεν υποστηρίζεται από περιηγητές κινητών. Θέλετε να εγκαταστήσετε την εφαρμογή;", | ||||
|     "powered by Matrix": "με τη βοήθεια του Matrix", | ||||
|     "powered by Matrix": "λειτουργεί με το Matrix", | ||||
|     "Welcome to Riot.im": "Καλώς ήλθατε στο Riot.im", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "Αποκεντρωμένη, κρυπτογραφημένη συνομιλία & συνεργασία με τη βοήθεια του [matrix]", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "Αποκεντρωμένη, κρυπτογραφημένη συνομιλία και συνεργασία χρησιμοποιώντας το [matrix]", | ||||
|     "Search the room directory": "Αναζήτηση στο ευρετήριο δωματίων", | ||||
|     "Chat with Riot Bot": "Συνομιλία με το Riot Bot", | ||||
|     "Get started with some tips from Riot Bot!": "Ξεκινήστε με μερικές συμβουλές από το Riot Bot!", | ||||
|  | @ -39,5 +39,14 @@ | |||
|     "Sign In": "Σύνδεση", | ||||
|     "Create Account": "Δημιουργία Λογαριασμού", | ||||
|     "Need help?": "Χρειάζεστε βοήθεια;", | ||||
|     "Room Directory": "Ευρετήριο δωματίων" | ||||
|     "Room Directory": "Ευρετήριο δωματίων", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Η ρύθμιση παραμέτρων σας του Riot περιλαμβάνει μη έγκυρο JSON. Παρακαλώ διορθώστε το πρόβλημα και επαναφορτώστε την σελίδα.", | ||||
|     "The message from the parser is: %(message)s": "Το μήνυμα από τον αναλυτή είναι: %(message)s", | ||||
|     "Invalid JSON": "Μη έγκυρο JSON", | ||||
|     "Your Riot is misconfigured": "Οι παράμετροι του Riot σας είναι λανθασμένα ρυθμισμένοι", | ||||
|     "Unexpected error preparing the app. See console for details.": "Απρόοπτο σφάλμα κατά την προετοιμασία της εφαρμογής. Δείτε το τερματικό για λεπτομέρειες.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Μη έγκυρη ρύθμιση παραμέτρων: δυνατότητα ορισμού μόνο ένα από τα default_server_config, default_server_name, ή default_hs_url.", | ||||
|     "Invalid configuration: no default server specified.": "Μη έγκυρη ρύθμιση παραμέτρων: δεν έχει οριστεί προκαθορισμένος διακομιστής.", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different homeserver URL. This allows you to use Riot with an existing Matrix account on a different homeserver.": "Μπορείτε να χρησιμοποιήσετε τις επιλογές προσαρμοσμένου διακομιστή για να κάνετε σύνδεση σε άλλους διακομιστές Matrix με το να ορίσετε διαφορετικό URL διακομιστή φιλοξενίας. Αυτό σας επιτρέπει να χρησιμοποιήσετε το Riot με έναν υπάρχον λογαριασμό Matrix σε ένα διαφορετικό διακομιστή φιλοξενίας.", | ||||
|     "Explore rooms": "Εξερευνήστε δωμάτια" | ||||
| } | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ | |||
|     "powered by Matrix": "Matrix の支援により活動しています。", | ||||
|     "Riot Desktop on %(platformName)s": "%(platformName)s向けデスクトップ版Riot", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "画面共有通話を行うにはHTTPS通信を使う必要があります。", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "分散型の、暗号化された会話とコラボレーション。[matrix]で動作しています", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "[matrix] による、分散型で暗号化された会話とコラボレーション", | ||||
|     "Lots of rooms already exist in Matrix, linked to existing networks (Slack, IRC, Gitter etc) or independent. Check out the directory!": "既にたくさんの部屋が、既存のネットワーク(Slack、IRC、Gitter等)に接続して、または独立的にMatrixに存在します。ディレクトリを検索してください!", | ||||
|     "Chat with Riot Bot": "Riot Botと会話", | ||||
|     "Get started with some tips from Riot Bot!": "Riot Botにヒントをもらって始めましょう!", | ||||
|  | @ -37,11 +37,16 @@ | |||
|     "Dev chat for the Dendrite dev team": "Dendrite開発者チームのための開発者チャット", | ||||
|     "Co-ordination for Riot translators": "Riot 翻訳者による共同作業", | ||||
|     "Unexpected error preparing the app. See console for details.": "アプリケーションの準備中に予期しないエラーが発生しました。詳細はコンソールを参照してください。", | ||||
|     "Your Riot is misconfigured": "あなたの Riot は間違って設定されています。", | ||||
|     "Your Riot is misconfigured": "あなたのRiotは設定が間違っています", | ||||
|     "Invalid configuration: no default server specified.": "不正な設定です:デフォルトのサーバーが設定されていません。", | ||||
|     "Sign In": "サインイン", | ||||
|     "Create Account": "アカウントを作成する", | ||||
|     "Need help?": "助けが必要ですか?", | ||||
|     "Explore rooms": "部屋を探索する", | ||||
|     "Room Directory": "部屋のディレクトリー" | ||||
|     "Room Directory": "部屋のディレクトリー", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Riotの設定に妥当でないJSONが含まれています。問題を修正してページを再読みしてください。", | ||||
|     "The message from the parser is: %(message)s": "パーザーのメッセージ: %(message)s", | ||||
|     "Invalid JSON": "妥当でないJSON", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "無効な設定: default_server_config、default_server_name、または default_hs_urlのいずれか一つのみが指定できます。", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different homeserver URL. This allows you to use Riot with an existing Matrix account on a different homeserver.": "サーバーのカスタムオプションに別のホームサーバーURLを指定することで他のMatrixサーバーにサインインすることができます。これにより別のホームサーバー上で既にあるMatrixのアカウントでRiotを使うことができます。" | ||||
| } | ||||
|  |  | |||
|  | @ -8,8 +8,8 @@ | |||
|     "Riot is not supported on mobile web. Install the app?": "Riot nėra palaikoma naršant svetainėje mobiliaisiais įrenginiais. Įdiegti programėlę?", | ||||
|     "Riot Desktop on %(platformName)s": "Riot Desktop, naudojant %(platformName)s", | ||||
|     "%(appName)s via %(browserName)s on %(osName)s": "%(appName)s per %(browserName)s, naudojant %(osName)s", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "Norint skambinti su ekrano bendrinimo funkcija būtina naudoti HTTPS.", | ||||
|     "Custom Server Options": "Tinkinto serverio parametrai", | ||||
|     "You need to be using HTTPS to place a screen-sharing call.": "Norint skambinti naudojant ekrano vaizdo dalijimosi funkciją, jūs turite naudoti HTTPS.", | ||||
|     "Custom Server Options": "Pasirinktiniai Serverio Nustatymai", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different Home server URL.<br/>This allows you to use Riot with an existing Matrix account on a different home server.<br/><br/>You can also set a custom identity server but you won't be able to invite users by email address, or be invited by email address yourself.": "Norėdami prisijungti prie kito nei Matrix serverio, galite naudoti tinkinto serverio parametrus ir nurodyti kito serverio URL adresą.<br/>Tai leis jums naudoti Riot su esama Matrix paskyra kituose serveriuose.<br/><br/>Taip pat galite nustatyti tinkintą tapatybės serverį, tačiau tuomet negalėsite pakviesti kitus naudotojus pagal el. paštą, o taip pat ir jie negalės pakviesti jūsų.", | ||||
|     "Dismiss": "Atmesti", | ||||
|     "Decentralised, encrypted chat & collaboration powered by [matrix]": "Decentralizuoti, šifruoti pokalbiai ir bendradarbiavimas, veikiantis su [matrix]", | ||||
|  | @ -40,5 +40,13 @@ | |||
|     "Create Account": "Sukurti paskyrą", | ||||
|     "Need help?": "Reikia pagalbos?", | ||||
|     "Explore rooms": "Peržiūrėti kambarius", | ||||
|     "Room Directory": "Kambarių katalogas" | ||||
|     "Room Directory": "Kambarių katalogas", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Jūsų Riot konfigūracijoje yra klaidingas JSON. Prašome pataisyti problemą ir iš naujo užkrauti puslapį.", | ||||
|     "The message from the parser is: %(message)s": "Analizatoriaus žinutė yra: %(message)s", | ||||
|     "Invalid JSON": "Klaidingas JSON", | ||||
|     "Your Riot is misconfigured": "Jūsų Riot yra neteisingai sukonfigūruotas", | ||||
|     "Unexpected error preparing the app. See console for details.": "Netikėta klaida ruošiant programą. Norėdami sužinoti daugiau detalių, žiūrėkite konsolę.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Klaidinga konfigūracija: galima nurodyti tik vieną iš default_server_config, default_server_name, arba default_hs_url.", | ||||
|     "Invalid configuration: no default server specified.": "Klaidinga konfigūracija: nenurodytas numatytasis serveris.", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different homeserver URL. This allows you to use Riot with an existing Matrix account on a different homeserver.": "Jūs galite naudoti pasirinktinius serverio nustatymus, kad prisijungtumėte prie kitų Matrix serverių, nurodydami kito serverio URL. Tai leidžia jums naudotis Riot su esama Matrix paskyra kitame serveryje." | ||||
| } | ||||
|  |  | |||
|  | @ -30,5 +30,7 @@ | |||
|     "Create Account": "Lag konto", | ||||
|     "Need help?": "Trenger du hjelp?", | ||||
|     "Room Directory": "Alle rom", | ||||
|     "Explore rooms": "Se alle rom" | ||||
|     "Explore rooms": "Se alle rom", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Riot-konfigurasjonen din inneholder ugyldig JSON. Vennligst fiks problemet og oppdater siden.", | ||||
|     "The message from the parser is: %(message)s": "Meldingen fra parseren er: %(message)s" | ||||
| } | ||||
|  |  | |||
|  | @ -35,5 +35,18 @@ | |||
|     "Dev chat for the Dendrite dev team": "Conversa de desenvolvimento para a equipa do Dendrite", | ||||
|     "Lots of rooms already exist in Matrix, linked to existing networks (Slack, IRC, Gitter etc) or independent. Check out the directory!": "Já existem muitas salas no Matrix, ligadas a redes já existentes (Slack, IRC, Gitter, etc) ou independentes. Dê uma vista de olhos no diretório!", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different Home server URL.<br/>This allows you to use Riot with an existing Matrix account on a different home server.<br/><br/>You can also set a custom identity server but you won't be able to invite users by email address, or be invited by email address yourself.": "Você pode usar as opções de servidor personalizado para entrar em outros servidores Matrix, especificando um diferente URL de servidor doméstico.<br/>Isto permite que você utilize Riot com uma conta Matrix existente em um servidor doméstico diferente.<br/><br/>Você também pode definir um servidor de identidade personalizado, porém não poderá convidar usuários por endereço de e-mail nem ser convidado por endereço de e-mail.", | ||||
|     "Co-ordination for Riot translators": "Coordenação para tradutores do Riot" | ||||
|     "Co-ordination for Riot translators": "Coordenação para tradutores do Riot", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "A sua configuração do RIOT contém JSON inválido. Por favor corriga o erro e recarregue a página.", | ||||
|     "The message from the parser is: %(message)s": "A mensagem do parser é:\n%(message)s", | ||||
|     "Invalid JSON": "JSON inválido.", | ||||
|     "Your Riot is misconfigured": "A sua configuração do RIOT está incorrecta.", | ||||
|     "Unexpected error preparing the app. See console for details.": "Erro inesperado, na preparação da aplicação. Veja consola, para mais detalhes.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Configuração inválida: só pode especificar uma das default_server_config, default_server_name,\nor default_hs_url.", | ||||
|     "Invalid configuration: no default server specified.": "Configuração inválida: não existe especificação de servidor padrão.", | ||||
|     "You can use the custom server options to sign into other Matrix servers by specifying a different homeserver URL. This allows you to use Riot with an existing Matrix account on a different homeserver.": "Pode usar as opções de custom server, para iniciar sessão noutros servidores Matrix.org, especificando o URL do homeserver diferente. Isto ira lhe atorizar a usar RIOT com a sua conta Matrix num servidor diferente", | ||||
|     "Sign In": "Iniciar sessão", | ||||
|     "Create Account": "Criar conta", | ||||
|     "Need help?": "Ajuda?", | ||||
|     "Explore rooms": "Explorar rooms", | ||||
|     "Room Directory": "Diretório de rooms" | ||||
| } | ||||
|  |  | |||
|  | @ -40,10 +40,14 @@ | |||
|     "You can also set a custom identity server, but you won't be able to invite users by email address, or be invited by email address yourself.": "Ви також можете встановити власний сервер ідентифікації, але Ви не зможете запрошувати користувачів (або бути запрошеним самому) за адресою електронної пошти.", | ||||
|     "Need help?": "Допомогти?", | ||||
|     "Sign In": "Вхід", | ||||
|     "Create Account": "Створити аккаунт", | ||||
|     "Create Account": "Створити акаунт", | ||||
|     "Explore rooms": "Дослідити кімнати", | ||||
|     "Room Directory": "Каталог кімнат", | ||||
|     "Unexpected error preparing the app. See console for details.": "Неочікувана помилка при підготовці програми. Дивіться деталі у виводі консолі.", | ||||
|     "Invalid configuration: can only specify one of default_server_config, default_server_name, or default_hs_url.": "Невірна конфігурація: можна вказати лише default_server_config, default_server_name або default_hs_url.", | ||||
|     "Invalid configuration: no default server specified.": "Невірна конфігурація: не вказано сервер за замовчуванням." | ||||
|     "Invalid configuration: no default server specified.": "Невірна конфігурація: не вказано сервер за замовчуванням.", | ||||
|     "Your Riot configuration contains invalid JSON. Please correct the problem and reload the page.": "Ваша конфігурація Riot містить некоректний JSON. Виправте проблему та оновіть сторінку.", | ||||
|     "The message from the parser is: %(message)s": "Повідомлення від парсера: %(message)s", | ||||
|     "Invalid JSON": "Хибний JSON", | ||||
|     "Your Riot is misconfigured": "Ваш Riot налаштовано неправильно" | ||||
| } | ||||
|  |  | |||
|  | @ -43,6 +43,7 @@ | |||
|     <script src="<%= htmlWebpackPlugin.files.chunks['bundle'].entry %>"></script> | ||||
|     <img src="<%= require('matrix-react-sdk/res/img/warning.svg') %>" width="24" height="23" style="visibility: hidden; position: absolute; top: 0px; left: 0px;"/> | ||||
|     <img src="<%= require('matrix-react-sdk/res/img/e2e/warning.svg') %>" width="24" height="23" style="visibility: hidden; position: absolute; top: 0px; left: 0px;"/> | ||||
|     <img src="<%= require('matrix-react-sdk/res/img/feather-customised/warning-triangle.svg') %>" width="24" height="23" style="visibility: hidden; position: absolute; top: 0px; left: 0px;"/> | ||||
|     <audio id="messageAudio"> | ||||
|         <source src="media/message.ogg" type="audio/ogg" /> | ||||
|         <source src="media/message.mp3" type="audio/mpeg" /> | ||||
|  |  | |||
|  | @ -55,8 +55,8 @@ import WebPlatform from './platform/WebPlatform'; | |||
| 
 | ||||
| import MatrixClientPeg from 'matrix-react-sdk/lib/MatrixClientPeg'; | ||||
| import SettingsStore from "matrix-react-sdk/lib/settings/SettingsStore"; | ||||
| import Tinter from 'matrix-react-sdk/lib/Tinter'; | ||||
| import SdkConfig from "matrix-react-sdk/lib/SdkConfig"; | ||||
| import {setTheme} from "matrix-react-sdk/lib/theme"; | ||||
| 
 | ||||
| import Olm from 'olm'; | ||||
| 
 | ||||
|  | @ -250,50 +250,7 @@ async function loadApp() { | |||
|     } | ||||
| 
 | ||||
|     // as quickly as we possibly can, set a default theme...
 | ||||
|     let a; | ||||
|     const theme = SettingsStore.getValue("theme"); | ||||
|     for (let i = 0; (a = document.getElementsByTagName("link")[i]); i++) { | ||||
|         const href = a.getAttribute("href"); | ||||
|         if (!href) continue; | ||||
|         // shouldn't we be using the 'title' tag rather than the href?
 | ||||
|         const match = href.match(/^bundles\/.*\/theme-(.*)\.css$/); | ||||
|         if (match) { | ||||
|             if (match[1] === theme) { | ||||
|                 // remove the disabled flag off the stylesheet
 | ||||
| 
 | ||||
|                 // Firefox requires setting the attribute to false, so do
 | ||||
|                 // that instead of removing it. Related:
 | ||||
|                 // https://bugzilla.mozilla.org/show_bug.cgi?id=1281135
 | ||||
|                 a.disabled = false; | ||||
| 
 | ||||
|                 // in case the Tinter.tint() in MatrixChat fires before the
 | ||||
|                 // CSS has actually loaded (which in practice happens)...
 | ||||
| 
 | ||||
|                 // This if fixes Tinter.setTheme to not fire on Firefox
 | ||||
|                 // in case it is the first time loading Riot.
 | ||||
|                 // `InstallTrigger` is a Object which only exists on Firefox
 | ||||
|                 // (it is used for their Plugins) and can be used as a
 | ||||
|                 // feature check.
 | ||||
|                 // Firefox loads css always before js. This is why we dont use
 | ||||
|                 // onload or it's EventListener as thoose will never trigger.
 | ||||
|                 if (typeof InstallTrigger !== 'undefined') { | ||||
|                     Tinter.setTheme(theme); | ||||
|                 } else { | ||||
|                     // FIXME: we should probably block loading the app or even
 | ||||
|                     // showing a spinner until the theme is loaded, to avoid
 | ||||
|                     // flashes of unstyled content.
 | ||||
|                     a.onload = () => { | ||||
|                         Tinter.setTheme(theme); | ||||
|                     }; | ||||
|                 } | ||||
|             } else { | ||||
|                 // Firefox requires this to not be done via `setAttribute`
 | ||||
|                 // or via HTML.
 | ||||
|                 // https://bugzilla.mozilla.org/show_bug.cgi?id=1281135
 | ||||
|                 a.disabled = true; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     await setTheme(); | ||||
| 
 | ||||
|     // Now that we've loaded the theme (CSS), display the config syntax error if needed.
 | ||||
|     if (configSyntaxError) { | ||||
|  |  | |||
|  | @ -199,7 +199,8 @@ export default class ElectronPlatform extends VectorBasePlatform { | |||
|     } | ||||
| 
 | ||||
|     supportsAutoHideMenuBar(): boolean { | ||||
|         return true; | ||||
|         // This is irelevant on Mac as Menu bars don't live in the app window
 | ||||
|         return !navigator.platform.toUpperCase().includes('MAC'); | ||||
|     } | ||||
| 
 | ||||
|     async getAutoHideMenuBarEnabled(): boolean { | ||||
|  |  | |||
|  | @ -85,9 +85,29 @@ export default class VectorBasePlatform extends BasePlatform { | |||
|                 bgColor = "#f00"; | ||||
|             } | ||||
| 
 | ||||
|             this.favicon.badge(notif, { | ||||
|                 bgColor: bgColor, | ||||
|             }); | ||||
|             const doUpdate = () => { | ||||
|                 this.favicon.badge(notif, { | ||||
|                     bgColor: bgColor, | ||||
|                 }); | ||||
|             }; | ||||
| 
 | ||||
|             doUpdate(); | ||||
| 
 | ||||
|             // HACK: Workaround for Chrome 78+ and dependency incompatibility.
 | ||||
|             // The library we use doesn't appear to work in Chrome 78, likely due to their
 | ||||
|             // changes surrounding tab behaviour. Tabs went through a bit of a redesign and
 | ||||
|             // restructuring in Chrome 78, so it's not terribly surprising that the library
 | ||||
|             // doesn't work correctly. The library we use hasn't been updated in years and
 | ||||
|             // does not look easy to fix/fork ourselves - we might as well write our own that
 | ||||
|             // doesn't include animation/webcam/etc support. However, that's a bit difficult
 | ||||
|             // so for now we'll just trigger the update twice.
 | ||||
|             //
 | ||||
|             // Note that trying to reproduce the problem in isolation doesn't seem to work:
 | ||||
|             // see https://gist.github.com/turt2live/5ab87919918adbfd7cfb8f1ad10f2409 for
 | ||||
|             // an example (you'll need your own web server to host that).
 | ||||
|             if (window.chrome) { | ||||
|                 doUpdate(); | ||||
|             } | ||||
|         } catch (e) { | ||||
|             console.warn(`Failed to set badge count: ${e.message}`); | ||||
|         } | ||||
|  |  | |||
							
								
								
									
										105
									
								
								yarn.lock
								
								
								
								
							
							
						
						
									
										105
									
								
								yarn.lock
								
								
								
								
							|  | @ -177,6 +177,11 @@ | |||
|     "@types/minimatch" "*" | ||||
|     "@types/node" "*" | ||||
| 
 | ||||
| "@types/json-schema@^7.0.3": | ||||
|   version "7.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.3.tgz#bdfd69d61e464dcc81b25159c270d75a73c1a636" | ||||
|   integrity sha512-Il2DtDVRGDcqjDtE+rF8iqg1CArehSK84HZJCT7AMITlyXRBpuPhqGLDQMowraqqu1coEaimg4ZOqggt6L6L+A== | ||||
| 
 | ||||
| "@types/minimatch@*": | ||||
|   version "3.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.3.tgz#3dca0e3f33b200fc7d1139c0cd96c1268cadfd9d" | ||||
|  | @ -187,6 +192,28 @@ | |||
|   resolved "https://registry.yarnpkg.com/@types/node/-/node-12.7.8.tgz#cb1bf6800238898bc2ff6ffa5702c3cadd350708" | ||||
|   integrity sha512-FMdVn84tJJdV+xe+53sYiZS4R5yn1mAIxfj+DVoNiQjTYz1+OYmjwEZr1ev9nU0axXwda0QDbYl06QHanRVH3A== | ||||
| 
 | ||||
| "@typescript-eslint/experimental-utils@^2.5.0": | ||||
|   version "2.8.0" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/experimental-utils/-/experimental-utils-2.8.0.tgz#208b4164d175587e9b03ce6fea97d55f19c30ca9" | ||||
|   integrity sha512-jZ05E4SxCbbXseQGXOKf3ESKcsGxT8Ucpkp1jiVp55MGhOvZB2twmWKf894PAuVQTCgbPbJz9ZbRDqtUWzP8xA== | ||||
|   dependencies: | ||||
|     "@types/json-schema" "^7.0.3" | ||||
|     "@typescript-eslint/typescript-estree" "2.8.0" | ||||
|     eslint-scope "^5.0.0" | ||||
| 
 | ||||
| "@typescript-eslint/typescript-estree@2.8.0": | ||||
|   version "2.8.0" | ||||
|   resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-2.8.0.tgz#fcc3fe6532840085d29b75432c8a59895876aeca" | ||||
|   integrity sha512-ksvjBDTdbAQ04cR5JyFSDX113k66FxH1tAXmi+dj6hufsl/G0eMc/f1GgLjEVPkYClDbRKv+rnBFuE5EusomUw== | ||||
|   dependencies: | ||||
|     debug "^4.1.1" | ||||
|     eslint-visitor-keys "^1.1.0" | ||||
|     glob "^7.1.6" | ||||
|     is-glob "^4.0.1" | ||||
|     lodash.unescape "4.0.1" | ||||
|     semver "^6.3.0" | ||||
|     tsutils "^3.17.1" | ||||
| 
 | ||||
| "@webassemblyjs/ast@1.8.5": | ||||
|   version "1.8.5" | ||||
|   resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.8.5.tgz#51b1c5fe6576a34953bf4b253df9f0d490d9e359" | ||||
|  | @ -3124,13 +3151,13 @@ electron-devtools-installer@^2.2.4: | |||
|     rimraf "^2.5.2" | ||||
|     semver "^5.3.0" | ||||
| 
 | ||||
| electron-notarize@^0.1.1: | ||||
|   version "0.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/electron-notarize/-/electron-notarize-0.1.1.tgz#c3563d70c5e7b3315f44e8495b30050a8c408b91" | ||||
|   integrity sha512-TpKfJcz4LXl5jiGvZTs5fbEx+wUFXV5u8voeG5WCHWfY/cdgdD8lDZIZRqLVOtR3VO+drgJ9aiSHIO9TYn/fKg== | ||||
| electron-notarize@^0.2.0: | ||||
|   version "0.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/electron-notarize/-/electron-notarize-0.2.0.tgz#676c71688ee84149bab27b22426d0a9452e7e262" | ||||
|   integrity sha512-u3KdEMOEcGMF9yCML8ej4ZF+O29VmGYIjrs/DoOi23neTWOMiIc5YCeFs4vxq3JG496omcw7Y5pimPm0sH9A7g== | ||||
|   dependencies: | ||||
|     debug "^4.1.1" | ||||
|     fs-extra "^8.0.1" | ||||
|     fs-extra "^8.1.0" | ||||
| 
 | ||||
| electron-publish@21.2.0: | ||||
|   version "21.2.0" | ||||
|  | @ -3354,6 +3381,18 @@ eslint-plugin-flowtype@^2.50.3: | |||
|   dependencies: | ||||
|     lodash "^4.17.10" | ||||
| 
 | ||||
| eslint-plugin-jest@^23.0.4: | ||||
|   version "23.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-23.0.4.tgz#1ab81ffe3b16c5168efa72cbd4db14d335092aa0" | ||||
|   integrity sha512-OaP8hhT8chJNodUPvLJ6vl8gnalcsU/Ww1t9oR3HnGdEWjm/DdCCUXLOral+IPGAeWu/EwgVQCK/QtxALpH1Yw== | ||||
|   dependencies: | ||||
|     "@typescript-eslint/experimental-utils" "^2.5.0" | ||||
| 
 | ||||
| eslint-plugin-react-hooks@^2.2.0: | ||||
|   version "2.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-2.2.0.tgz#078264e9e388da6929ace09d6abe92c85963aff4" | ||||
|   integrity sha512-jSlnBjV2cmyIeL555H/FbvuSbQ1AtpHjLMHuPrQnt1eVA6lX8yufdygh7AArI2m8ct7ChHGx2uOaCuxq2MUn6g== | ||||
| 
 | ||||
| eslint-plugin-react@^7.11.1: | ||||
|   version "7.14.3" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.14.3.tgz#911030dd7e98ba49e1b2208599571846a66bdf13" | ||||
|  | @ -3385,6 +3424,14 @@ eslint-scope@^4.0.3: | |||
|     esrecurse "^4.1.0" | ||||
|     estraverse "^4.1.1" | ||||
| 
 | ||||
| eslint-scope@^5.0.0: | ||||
|   version "5.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.0.0.tgz#e87c8887c73e8d1ec84f1ca591645c358bfc8fb9" | ||||
|   integrity sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw== | ||||
|   dependencies: | ||||
|     esrecurse "^4.1.0" | ||||
|     estraverse "^4.1.1" | ||||
| 
 | ||||
| eslint-utils@^1.3.1: | ||||
|   version "1.4.2" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-1.4.2.tgz#166a5180ef6ab7eb462f162fd0e6f2463d7309ab" | ||||
|  | @ -3392,7 +3439,7 @@ eslint-utils@^1.3.1: | |||
|   dependencies: | ||||
|     eslint-visitor-keys "^1.0.0" | ||||
| 
 | ||||
| eslint-visitor-keys@^1.0.0: | ||||
| eslint-visitor-keys@^1.0.0, eslint-visitor-keys@^1.1.0: | ||||
|   version "1.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz#e2a82cea84ff246ad6fb57f9bde5b46621459ec2" | ||||
|   integrity sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A== | ||||
|  | @ -4081,7 +4128,7 @@ fs-extra@^0.30.0: | |||
|     path-is-absolute "^1.0.0" | ||||
|     rimraf "^2.2.8" | ||||
| 
 | ||||
| fs-extra@^8.0.1, fs-extra@^8.1.0: | ||||
| fs-extra@^8.1.0: | ||||
|   version "8.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" | ||||
|   integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== | ||||
|  | @ -4286,6 +4333,18 @@ glob@^7.0.3, glob@^7.0.5, glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4: | |||
|     once "^1.3.0" | ||||
|     path-is-absolute "^1.0.0" | ||||
| 
 | ||||
| glob@^7.1.6: | ||||
|   version "7.1.6" | ||||
|   resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" | ||||
|   integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== | ||||
|   dependencies: | ||||
|     fs.realpath "^1.0.0" | ||||
|     inflight "^1.0.4" | ||||
|     inherits "2" | ||||
|     minimatch "^3.0.4" | ||||
|     once "^1.3.0" | ||||
|     path-is-absolute "^1.0.0" | ||||
| 
 | ||||
| global-dirs@^0.1.0: | ||||
|   version "0.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-0.1.1.tgz#b319c0dd4607f353f3be9cca4c72fc148c49f445" | ||||
|  | @ -5149,7 +5208,7 @@ is-glob@^3.1.0: | |||
|   dependencies: | ||||
|     is-extglob "^2.1.0" | ||||
| 
 | ||||
| is-glob@^4.0.0: | ||||
| is-glob@^4.0.0, is-glob@^4.0.1: | ||||
|   version "4.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" | ||||
|   integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== | ||||
|  | @ -5800,6 +5859,11 @@ lodash.mergewith@^4.6.1: | |||
|   resolved "https://registry.yarnpkg.com/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz#617121f89ac55f59047c7aec1ccd6654c6590f55" | ||||
|   integrity sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ== | ||||
| 
 | ||||
| lodash.unescape@4.0.1: | ||||
|   version "4.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/lodash.unescape/-/lodash.unescape-4.0.1.tgz#bf2249886ce514cda112fae9218cdc065211fc9c" | ||||
|   integrity sha1-vyJJiGzlFM2hEvrpIYzcBlIR/Jw= | ||||
| 
 | ||||
| lodash.union@^4.6.0: | ||||
|   version "4.6.0" | ||||
|   resolved "https://registry.yarnpkg.com/lodash.union/-/lodash.union-4.6.0.tgz#48bb5088409f16f1821666641c44dd1aaae3cd88" | ||||
|  | @ -5940,9 +6004,10 @@ math-random@^1.0.1: | |||
|   resolved "https://registry.yarnpkg.com/math-random/-/math-random-1.0.4.tgz#5dd6943c938548267016d4e34f057583080c514c" | ||||
|   integrity sha512-rUxjysqif/BZQH2yhd5Aaq7vXMSx9NdEsQcyA07uEzIvxgI7zIr33gGsh+RU0/XjmQpCW7RsVof1vlkvQVCK5A== | ||||
| 
 | ||||
| "matrix-js-sdk@github:matrix-org/matrix-js-sdk#develop": | ||||
|   version "2.4.2" | ||||
|   resolved "https://codeload.github.com/matrix-org/matrix-js-sdk/tar.gz/46d7e4c7075386f1330d6a49941e9979fc26be0a" | ||||
| matrix-js-sdk@2.4.3: | ||||
|   version "2.4.3" | ||||
|   resolved "https://registry.yarnpkg.com/matrix-js-sdk/-/matrix-js-sdk-2.4.3.tgz#23b78cc707a02eb0ce7eecb3aa50129e46dd5b6e" | ||||
|   integrity sha512-8qTqILd/NmTWF24tpaxmDIzkTk/bZhPD5N8h69PlvJ5Y6kMFctpRj+Tud5zZjl5/yhO07+g+JCyDzg+AagiM/A== | ||||
|   dependencies: | ||||
|     another-json "^0.2.0" | ||||
|     babel-runtime "^6.26.0" | ||||
|  | @ -5963,9 +6028,10 @@ matrix-mock-request@^1.2.3: | |||
|     bluebird "^3.5.0" | ||||
|     expect "^1.20.2" | ||||
| 
 | ||||
| "matrix-react-sdk@github:matrix-org/matrix-react-sdk#develop": | ||||
|   version "1.7.0" | ||||
|   resolved "https://codeload.github.com/matrix-org/matrix-react-sdk/tar.gz/53332018234fc9067c6200babb794ab3538a0791" | ||||
| matrix-react-sdk@1.7.2: | ||||
|   version "1.7.2" | ||||
|   resolved "https://registry.yarnpkg.com/matrix-react-sdk/-/matrix-react-sdk-1.7.2.tgz#4c16fa6c2d188311ecb5163773dfdf7ca92b7ecc" | ||||
|   integrity sha512-CWCr41sRBeUChlvec6eJxmY02g+Re6PN3lt9tR7TkqGKyUu++Y72WPfirM+0t11QVtVyZ5Wo1WIzpropLBFyYw== | ||||
|   dependencies: | ||||
|     babel-plugin-syntax-dynamic-import "^6.18.0" | ||||
|     babel-runtime "^6.26.0" | ||||
|  | @ -5996,7 +6062,7 @@ matrix-mock-request@^1.2.3: | |||
|     linkifyjs "^2.1.6" | ||||
|     lodash "^4.17.14" | ||||
|     lolex "4.2" | ||||
|     matrix-js-sdk "github:matrix-org/matrix-js-sdk#develop" | ||||
|     matrix-js-sdk "2.4.3" | ||||
|     optimist "^0.6.1" | ||||
|     pako "^1.0.5" | ||||
|     png-chunks-extract "^1.0.0" | ||||
|  | @ -9047,11 +9113,18 @@ truncate-utf8-bytes@^1.0.0: | |||
|   dependencies: | ||||
|     utf8-byte-length "^1.0.1" | ||||
| 
 | ||||
| tslib@^1.9.0: | ||||
| tslib@^1.8.1, tslib@^1.9.0: | ||||
|   version "1.10.0" | ||||
|   resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.10.0.tgz#c3c19f95973fb0a62973fb09d90d961ee43e5c8a" | ||||
|   integrity sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ== | ||||
| 
 | ||||
| tsutils@^3.17.1: | ||||
|   version "3.17.1" | ||||
|   resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.17.1.tgz#ed719917f11ca0dee586272b2ac49e015a2dd759" | ||||
|   integrity sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g== | ||||
|   dependencies: | ||||
|     tslib "^1.8.1" | ||||
| 
 | ||||
| tty-browserify@0.0.0: | ||||
|   version "0.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6" | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Michael Telatynski
						Michael Telatynski