Merge branch 'master' of github.com:vector-im/riot-web into set_default_federate_by_settings
5
.gitignore
vendored
|
@ -5,6 +5,8 @@
|
||||||
/key.pem
|
/key.pem
|
||||||
/lib
|
/lib
|
||||||
/node_modules
|
/node_modules
|
||||||
|
/electron_app/node_modules
|
||||||
|
/electron_app/dist
|
||||||
/packages/
|
/packages/
|
||||||
/webapp
|
/webapp
|
||||||
/.npmrc
|
/.npmrc
|
||||||
|
@ -12,3 +14,6 @@
|
||||||
npm-debug.log
|
npm-debug.log
|
||||||
electron/dist
|
electron/dist
|
||||||
electron/pub
|
electron/pub
|
||||||
|
/.idea
|
||||||
|
/config.json
|
||||||
|
/src/component-index.js
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
"test/css/flexbox",
|
"test/css/flexbox",
|
||||||
"test/es5/specification",
|
"test/es5/specification",
|
||||||
"test/css/objectfit",
|
"test/css/objectfit",
|
||||||
"test/storage/localstorage"
|
"test/storage/localstorage",
|
||||||
|
"test/workers/webworkers",
|
||||||
|
"test/indexeddb"
|
||||||
]
|
]
|
||||||
}
|
}
|
23
.travis.yml
|
@ -1,7 +1,22 @@
|
||||||
language: node_js
|
language: node_js
|
||||||
node_js:
|
node_js:
|
||||||
- 6 # node v6, to match jenkins
|
# make sure we work with a range of node versions.
|
||||||
|
# As of the time of writing:
|
||||||
|
# - 4.x is still in LTS (until April 2018), but some of our deps (notably
|
||||||
|
# extract-zip) don't work with it
|
||||||
|
# - 5.x has been EOLed for nearly a year.
|
||||||
|
# - 6.x is the current 'LTS' version
|
||||||
|
# - 7.x is the current 'current' version (until October 2017)
|
||||||
|
#
|
||||||
|
# see: https://github.com/nodejs/LTS/
|
||||||
|
#
|
||||||
|
# anything before 6.3 ships with npm 3.9 or earlier, which had problems
|
||||||
|
# with symlinks in node_modules (see
|
||||||
|
# https://github.com/npm/npm/releases/tag/v3.10.0 'FIXES AND REFACTORING').
|
||||||
|
- 6.3
|
||||||
|
- 6
|
||||||
|
- 7
|
||||||
install:
|
install:
|
||||||
- npm install
|
# clone the deps with depth 1: we know we will only ever need that one
|
||||||
- (cd node_modules/matrix-js-sdk && npm install)
|
# commit.
|
||||||
- (cd node_modules/matrix-react-sdk && npm install)
|
- scripts/fetch-develop.deps.sh --depth 1 && npm install
|
||||||
|
|
430
CHANGELOG.md
|
@ -1,3 +1,433 @@
|
||||||
|
Changes in [0.11.4](https://github.com/vector-im/riot-web/releases/tag/v0.11.4) (2017-06-22)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.3...v0.11.4)
|
||||||
|
|
||||||
|
* Update matrix-js-sdk and react-sdk to fix a regression where the
|
||||||
|
background indexedb worker was disabled, failures to open indexeddb
|
||||||
|
causing the app to fail to start, a race when starting that could break
|
||||||
|
switching to rooms, and the inability to to invite user with mixed case
|
||||||
|
usernames.
|
||||||
|
|
||||||
|
Changes in [0.11.3](https://github.com/vector-im/riot-web/releases/tag/v0.11.3) (2017-06-20)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.2...v0.11.3)
|
||||||
|
|
||||||
|
* Update to matrix-react-sdk 0.9.6 to fix infinite spinner bugs
|
||||||
|
and some parts of the app that had missed translation.
|
||||||
|
|
||||||
|
Changes in [0.11.2](https://github.com/vector-im/riot-web/releases/tag/v0.11.2) (2017-06-19)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.2-rc.2...v0.11.2)
|
||||||
|
|
||||||
|
* Add more languages and translations
|
||||||
|
* Add a 'register' button
|
||||||
|
|
||||||
|
Changes in [0.11.2-rc.2](https://github.com/vector-im/riot-web/releases/tag/v0.11.2-rc.2) (2017-06-16)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.2-rc.1...v0.11.2-rc.2)
|
||||||
|
|
||||||
|
* Update react-sdk to pull in fixes for URL previews, CAS
|
||||||
|
login, h2 in markdown and CAPTCHA forms.
|
||||||
|
* Enable Korean translation
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4323](https://github.com/vector-im/riot-web/pull/4323)
|
||||||
|
* Fix h2 in markdown being weird
|
||||||
|
[\#4332](https://github.com/vector-im/riot-web/pull/4332)
|
||||||
|
|
||||||
|
Changes in [0.11.2-rc.1](https://github.com/vector-im/riot-web/releases/tag/v0.11.2-rc.1) (2017-06-15)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.1...v0.11.2-rc.1)
|
||||||
|
|
||||||
|
* Attempts to deflakify the joining test
|
||||||
|
[\#4313](https://github.com/vector-im/riot-web/pull/4313)
|
||||||
|
* Add a test for the login flow when there is a teamserver
|
||||||
|
[\#4315](https://github.com/vector-im/riot-web/pull/4315)
|
||||||
|
* Remove onload simulator from loading test
|
||||||
|
[\#4314](https://github.com/vector-im/riot-web/pull/4314)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4305](https://github.com/vector-im/riot-web/pull/4305)
|
||||||
|
* Test that we handle stored mx_last_room_id correctly
|
||||||
|
[\#4292](https://github.com/vector-im/riot-web/pull/4292)
|
||||||
|
* Ask for email address after setting password for the first time
|
||||||
|
[\#4301](https://github.com/vector-im/riot-web/pull/4301)
|
||||||
|
* i18n for setting email after password flow
|
||||||
|
[\#4299](https://github.com/vector-im/riot-web/pull/4299)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4290](https://github.com/vector-im/riot-web/pull/4290)
|
||||||
|
* Don't show the tooltips when filtering rooms
|
||||||
|
[\#4282](https://github.com/vector-im/riot-web/pull/4282)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4272](https://github.com/vector-im/riot-web/pull/4272)
|
||||||
|
* Add missing VOIP Dropdown width
|
||||||
|
[\#4266](https://github.com/vector-im/riot-web/pull/4266)
|
||||||
|
* Update import and directory path in the Translations dev guide
|
||||||
|
[\#4261](https://github.com/vector-im/riot-web/pull/4261)
|
||||||
|
* Use Thai string for Thai in Language-Chooser
|
||||||
|
[\#4260](https://github.com/vector-im/riot-web/pull/4260)
|
||||||
|
|
||||||
|
Changes in [0.11.1](https://github.com/vector-im/riot-web/releases/tag/v0.11.1) (2017-06-14)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.0...v0.11.1)
|
||||||
|
|
||||||
|
* Update to react-sdk 0.9.4 to prompt to set an
|
||||||
|
email address when setting a password and make
|
||||||
|
DM guessing smarter.
|
||||||
|
|
||||||
|
Changes in [0.11.0](https://github.com/vector-im/riot-web/releases/tag/v0.11.0) (2017-06-12)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.0-rc.2...v0.11.0)
|
||||||
|
|
||||||
|
* More translations & minor fixes
|
||||||
|
|
||||||
|
Changes in [0.11.0-rc.2](https://github.com/vector-im/riot-web/releases/tag/v0.11.0-rc.2) (2017-06-09)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.11.0-rc.1...v0.11.0-rc.2)
|
||||||
|
|
||||||
|
* Update to matrix-react-sdk rc.2 which fixes the flux
|
||||||
|
dependency version and an issue with the conference
|
||||||
|
call bar translation.
|
||||||
|
|
||||||
|
|
||||||
|
Changes in [0.11.0-rc.1](https://github.com/vector-im/riot-web/releases/tag/v0.11.0-rc.1) (2017-06-09)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.10.2...v0.11.0-rc.1)
|
||||||
|
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4258](https://github.com/vector-im/riot-web/pull/4258)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4254](https://github.com/vector-im/riot-web/pull/4254)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4253](https://github.com/vector-im/riot-web/pull/4253)
|
||||||
|
* Expect to see HTTP /join/#some:alias when we the view knows it
|
||||||
|
[\#4252](https://github.com/vector-im/riot-web/pull/4252)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4250](https://github.com/vector-im/riot-web/pull/4250)
|
||||||
|
* add explicit import to utf8 polyfill and rip out unused imports
|
||||||
|
[\#4169](https://github.com/vector-im/riot-web/pull/4169)
|
||||||
|
* Added styling for copy to clipboard button
|
||||||
|
[\#4204](https://github.com/vector-im/riot-web/pull/4204)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4231](https://github.com/vector-im/riot-web/pull/4231)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4218](https://github.com/vector-im/riot-web/pull/4218)
|
||||||
|
* Update CSS for ChatInviteDialog
|
||||||
|
[\#4226](https://github.com/vector-im/riot-web/pull/4226)
|
||||||
|
* change electron -> electron_app which was previously missed
|
||||||
|
[\#4212](https://github.com/vector-im/riot-web/pull/4212)
|
||||||
|
* New guest access
|
||||||
|
[\#4039](https://github.com/vector-im/riot-web/pull/4039)
|
||||||
|
* Align message timestamp centrally about the avatar mid-point
|
||||||
|
[\#4219](https://github.com/vector-im/riot-web/pull/4219)
|
||||||
|
* Remove '/' from homepage URL
|
||||||
|
[\#4221](https://github.com/vector-im/riot-web/pull/4221)
|
||||||
|
* Chop off 'origin/'
|
||||||
|
[\#4220](https://github.com/vector-im/riot-web/pull/4220)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4214](https://github.com/vector-im/riot-web/pull/4214)
|
||||||
|
* adjust alignment of message menu button in compact layout
|
||||||
|
[\#4211](https://github.com/vector-im/riot-web/pull/4211)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4207](https://github.com/vector-im/riot-web/pull/4207)
|
||||||
|
* Fix Tests in ILAG
|
||||||
|
[\#4209](https://github.com/vector-im/riot-web/pull/4209)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4197](https://github.com/vector-im/riot-web/pull/4197)
|
||||||
|
* Fix tests for new-guest-access
|
||||||
|
[\#4201](https://github.com/vector-im/riot-web/pull/4201)
|
||||||
|
* i18n for SetPasswordDialog
|
||||||
|
[\#4198](https://github.com/vector-im/riot-web/pull/4198)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4193](https://github.com/vector-im/riot-web/pull/4193)
|
||||||
|
* to make the windows volume mixer not explode as it can't resize icons.
|
||||||
|
[\#4183](https://github.com/vector-im/riot-web/pull/4183)
|
||||||
|
* provide react devtools in electron dev runs
|
||||||
|
[\#4186](https://github.com/vector-im/riot-web/pull/4186)
|
||||||
|
* Fix DeprecationWarning
|
||||||
|
[\#4184](https://github.com/vector-im/riot-web/pull/4184)
|
||||||
|
* room link should be a matrix.to one
|
||||||
|
[\#4178](https://github.com/vector-im/riot-web/pull/4178)
|
||||||
|
* Update home.html
|
||||||
|
[\#4163](https://github.com/vector-im/riot-web/pull/4163)
|
||||||
|
* Add missing translation for room directory
|
||||||
|
[\#4160](https://github.com/vector-im/riot-web/pull/4160)
|
||||||
|
* i18n welcome
|
||||||
|
[\#4129](https://github.com/vector-im/riot-web/pull/4129)
|
||||||
|
* Tom welcome page
|
||||||
|
[\#4038](https://github.com/vector-im/riot-web/pull/4038)
|
||||||
|
* Fix some tests that expect Directory (they should expect HomePage)
|
||||||
|
[\#4076](https://github.com/vector-im/riot-web/pull/4076)
|
||||||
|
* Add "Login" button to RHS when user is a guest
|
||||||
|
[\#4037](https://github.com/vector-im/riot-web/pull/4037)
|
||||||
|
* Rejig the PaswordNagBar
|
||||||
|
[\#4026](https://github.com/vector-im/riot-web/pull/4026)
|
||||||
|
* Allow team server config to be missing
|
||||||
|
[\#4024](https://github.com/vector-im/riot-web/pull/4024)
|
||||||
|
* Remove GuestWarningBar
|
||||||
|
[\#4020](https://github.com/vector-im/riot-web/pull/4020)
|
||||||
|
* Make left panel better for new users (mk III)
|
||||||
|
[\#4023](https://github.com/vector-im/riot-web/pull/4023)
|
||||||
|
* Implement default welcome page and allow custom URL /w config
|
||||||
|
[\#4015](https://github.com/vector-im/riot-web/pull/4015)
|
||||||
|
* Add warm-fuzzy for successful password entry
|
||||||
|
[\#3989](https://github.com/vector-im/riot-web/pull/3989)
|
||||||
|
* autoFocus new password input in SetPasswordDialog
|
||||||
|
[\#3982](https://github.com/vector-im/riot-web/pull/3982)
|
||||||
|
* Implement dialog to set password
|
||||||
|
[\#3921](https://github.com/vector-im/riot-web/pull/3921)
|
||||||
|
* Replace NeedToRegister with SetMxId dialog
|
||||||
|
[\#3924](https://github.com/vector-im/riot-web/pull/3924)
|
||||||
|
* Add welcomeUserId to sample config
|
||||||
|
[\#3906](https://github.com/vector-im/riot-web/pull/3906)
|
||||||
|
* CSS for mxIdDialog redesign
|
||||||
|
[\#3885](https://github.com/vector-im/riot-web/pull/3885)
|
||||||
|
* Implement PasswordNagBar
|
||||||
|
[\#3817](https://github.com/vector-im/riot-web/pull/3817)
|
||||||
|
* CSS for new SetMxIdDialog
|
||||||
|
[\#3762](https://github.com/vector-im/riot-web/pull/3762)
|
||||||
|
|
||||||
|
Changes in [0.10.2](https://github.com/vector-im/riot-web/releases/tag/v0.10.2) (2017-06-06)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.10.1...v0.10.2)
|
||||||
|
|
||||||
|
* Hotfix for bugs where navigating straight to a URL like /#/login and
|
||||||
|
and /#/forgot_password
|
||||||
|
|
||||||
|
|
||||||
|
Changes in [0.10.1](https://github.com/vector-im/riot-web/releases/tag/v0.10.1) (2017-06-02)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.10.0...v0.10.1)
|
||||||
|
|
||||||
|
* Update to matrix-react-sdk 0.9.1 to fix i18n error which broke start chat in some circumstances
|
||||||
|
|
||||||
|
Changes in [0.10.0](https://github.com/vector-im/riot-web/releases/tag/v0.10.0) (2017-06-02)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.10.0-rc.2...v0.10.0)
|
||||||
|
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4152](https://github.com/vector-im/riot-web/pull/4152)
|
||||||
|
|
||||||
|
Changes in [0.10.0-rc.2](https://github.com/vector-im/riot-web/releases/tag/v0.10.0-rc.2) (2017-06-02)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.10.0-rc.1...v0.10.0-rc.2)
|
||||||
|
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4150](https://github.com/vector-im/riot-web/pull/4150)
|
||||||
|
* styling for webrtc settings
|
||||||
|
[\#4019](https://github.com/vector-im/riot-web/pull/4019)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4140](https://github.com/vector-im/riot-web/pull/4140)
|
||||||
|
* add styles for compact layout
|
||||||
|
[\#4132](https://github.com/vector-im/riot-web/pull/4132)
|
||||||
|
* Various tweaks to fetch-develop-deps
|
||||||
|
[\#4147](https://github.com/vector-im/riot-web/pull/4147)
|
||||||
|
* Don't try to build with node 6.0
|
||||||
|
[\#4145](https://github.com/vector-im/riot-web/pull/4145)
|
||||||
|
* Support 12hr time on DateSeparator
|
||||||
|
[\#4143](https://github.com/vector-im/riot-web/pull/4143)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4137](https://github.com/vector-im/riot-web/pull/4137)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4105](https://github.com/vector-im/riot-web/pull/4105)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4094](https://github.com/vector-im/riot-web/pull/4094)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4091](https://github.com/vector-im/riot-web/pull/4091)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4089](https://github.com/vector-im/riot-web/pull/4089)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4083](https://github.com/vector-im/riot-web/pull/4083)
|
||||||
|
|
||||||
|
Changes in [0.10.0-rc.1](https://github.com/vector-im/riot-web/releases/tag/v0.10.0-rc.1) (2017-06-01)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.9.10...v0.10.0-rc.1)
|
||||||
|
|
||||||
|
* basic electron profile support
|
||||||
|
[\#4030](https://github.com/vector-im/riot-web/pull/4030)
|
||||||
|
* Finish translations for vector-im/riot-web
|
||||||
|
[\#4122](https://github.com/vector-im/riot-web/pull/4122)
|
||||||
|
* Translate src/vector
|
||||||
|
[\#4119](https://github.com/vector-im/riot-web/pull/4119)
|
||||||
|
* electron flashFrame was way too annoying
|
||||||
|
[\#4128](https://github.com/vector-im/riot-web/pull/4128)
|
||||||
|
* auto-launch support [Electron]
|
||||||
|
[\#4012](https://github.com/vector-im/riot-web/pull/4012)
|
||||||
|
* Show 12hr time on hover too
|
||||||
|
[\#4092](https://github.com/vector-im/riot-web/pull/4092)
|
||||||
|
* Translate src/notifications
|
||||||
|
[\#4087](https://github.com/vector-im/riot-web/pull/4087)
|
||||||
|
* Translate src/components/structures
|
||||||
|
[\#4084](https://github.com/vector-im/riot-web/pull/4084)
|
||||||
|
* Smaller font size on timestamp to better fit in the available space
|
||||||
|
[\#4085](https://github.com/vector-im/riot-web/pull/4085)
|
||||||
|
* Make travis run the build with several versions of node
|
||||||
|
[\#4079](https://github.com/vector-im/riot-web/pull/4079)
|
||||||
|
* Piwik Analytics
|
||||||
|
[\#4056](https://github.com/vector-im/riot-web/pull/4056)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4077](https://github.com/vector-im/riot-web/pull/4077)
|
||||||
|
* managed to eat the eventStatus check, can't redact a local-echo etc
|
||||||
|
[\#4078](https://github.com/vector-im/riot-web/pull/4078)
|
||||||
|
* show redact in context menu only if has PL to/sent message
|
||||||
|
[\#3925](https://github.com/vector-im/riot-web/pull/3925)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4064](https://github.com/vector-im/riot-web/pull/4064)
|
||||||
|
* Change redact -> remove to improve clarity
|
||||||
|
[\#3722](https://github.com/vector-im/riot-web/pull/3722)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4058](https://github.com/vector-im/riot-web/pull/4058)
|
||||||
|
* Message Forwarding
|
||||||
|
[\#3688](https://github.com/vector-im/riot-web/pull/3688)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4057](https://github.com/vector-im/riot-web/pull/4057)
|
||||||
|
* Fixed an input field's background color in dark theme
|
||||||
|
[\#4053](https://github.com/vector-im/riot-web/pull/4053)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4051](https://github.com/vector-im/riot-web/pull/4051)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4049](https://github.com/vector-im/riot-web/pull/4049)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4048](https://github.com/vector-im/riot-web/pull/4048)
|
||||||
|
* Update from Weblate.
|
||||||
|
[\#4040](https://github.com/vector-im/riot-web/pull/4040)
|
||||||
|
* Update translating.md: Minor suggestions
|
||||||
|
[\#4041](https://github.com/vector-im/riot-web/pull/4041)
|
||||||
|
* tidy electron files, they weren't pwetty
|
||||||
|
[\#3993](https://github.com/vector-im/riot-web/pull/3993)
|
||||||
|
* Prevent Power Save when in call (Electron)
|
||||||
|
[\#3992](https://github.com/vector-im/riot-web/pull/3992)
|
||||||
|
* Translations!
|
||||||
|
[\#4035](https://github.com/vector-im/riot-web/pull/4035)
|
||||||
|
* Kieran gould/12hourtimestamp
|
||||||
|
[\#3961](https://github.com/vector-im/riot-web/pull/3961)
|
||||||
|
* Don't include src in the test resolve root
|
||||||
|
[\#4033](https://github.com/vector-im/riot-web/pull/4033)
|
||||||
|
* add moar context menus [Electron]
|
||||||
|
[\#4021](https://github.com/vector-im/riot-web/pull/4021)
|
||||||
|
* Add `Chat` to Linux app categories
|
||||||
|
[\#4022](https://github.com/vector-im/riot-web/pull/4022)
|
||||||
|
* add menu category for linux build of app
|
||||||
|
[\#3975](https://github.com/vector-im/riot-web/pull/3975)
|
||||||
|
* Electron Tray Improvements
|
||||||
|
[\#3909](https://github.com/vector-im/riot-web/pull/3909)
|
||||||
|
* More riot-web test deflakification
|
||||||
|
[\#3966](https://github.com/vector-im/riot-web/pull/3966)
|
||||||
|
* Script to fetch corresponding branches of dependent projects
|
||||||
|
[\#3945](https://github.com/vector-im/riot-web/pull/3945)
|
||||||
|
* Add type="text/css" to SVG logos
|
||||||
|
[\#3964](https://github.com/vector-im/riot-web/pull/3964)
|
||||||
|
* Fix some setState-after-unmount in roomdirectory
|
||||||
|
[\#3958](https://github.com/vector-im/riot-web/pull/3958)
|
||||||
|
* Attempt to deflakify joining test
|
||||||
|
[\#3956](https://github.com/vector-im/riot-web/pull/3956)
|
||||||
|
|
||||||
|
Changes in [0.9.10](https://github.com/vector-im/riot-web/releases/tag/v0.9.10) (2017-05-22)
|
||||||
|
============================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.9.10-rc.1...v0.9.10)
|
||||||
|
|
||||||
|
* No changes
|
||||||
|
|
||||||
|
|
||||||
|
Changes in [0.9.10-rc.1](https://github.com/vector-im/riot-web/releases/tag/v0.9.10-rc.1) (2017-05-19)
|
||||||
|
======================================================================================================
|
||||||
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.9.9...v0.9.10-rc.1)
|
||||||
|
|
||||||
|
* CSS for left_aligned Dropdowns, and adjustments for Country dd in Login
|
||||||
|
[\#3959](https://github.com/vector-im/riot-web/pull/3959)
|
||||||
|
* Add square flag pngs /w genflags.sh script
|
||||||
|
[\#3953](https://github.com/vector-im/riot-web/pull/3953)
|
||||||
|
* Add config for riot-bot on desktop app build
|
||||||
|
[\#3954](https://github.com/vector-im/riot-web/pull/3954)
|
||||||
|
* Desktop: 'copy link address'
|
||||||
|
[\#3952](https://github.com/vector-im/riot-web/pull/3952)
|
||||||
|
* Reduce rageshake log size to 1MB
|
||||||
|
[\#3943](https://github.com/vector-im/riot-web/pull/3943)
|
||||||
|
* CSS for putting country dd on same line as phone input
|
||||||
|
[\#3942](https://github.com/vector-im/riot-web/pull/3942)
|
||||||
|
* fix #3894
|
||||||
|
[\#3919](https://github.com/vector-im/riot-web/pull/3919)
|
||||||
|
* change vector->riot on the surface
|
||||||
|
[\#3894](https://github.com/vector-im/riot-web/pull/3894)
|
||||||
|
* move manifest.json outward so it is scoped properly
|
||||||
|
[\#3888](https://github.com/vector-im/riot-web/pull/3888)
|
||||||
|
* add to manifest
|
||||||
|
[\#3799](https://github.com/vector-im/riot-web/pull/3799)
|
||||||
|
* Automatically update component-index
|
||||||
|
[\#3886](https://github.com/vector-im/riot-web/pull/3886)
|
||||||
|
* move electron -> electron_app because npm smart
|
||||||
|
[\#3877](https://github.com/vector-im/riot-web/pull/3877)
|
||||||
|
* Fix bug report endpoint in config.sample.json.
|
||||||
|
[\#3863](https://github.com/vector-im/riot-web/pull/3863)
|
||||||
|
* Update 2 missed icons to the new icon
|
||||||
|
[\#3851](https://github.com/vector-im/riot-web/pull/3851)
|
||||||
|
* Make left panel better for new users (mk II)
|
||||||
|
[\#3804](https://github.com/vector-im/riot-web/pull/3804)
|
||||||
|
* match primary package.json
|
||||||
|
[\#3839](https://github.com/vector-im/riot-web/pull/3839)
|
||||||
|
* Re-add productName
|
||||||
|
[\#3829](https://github.com/vector-im/riot-web/pull/3829)
|
||||||
|
* Remove leading v in /version file, for SemVer and to match Electron ver
|
||||||
|
[\#3683](https://github.com/vector-im/riot-web/pull/3683)
|
||||||
|
* Fix scope of callback
|
||||||
|
[\#3790](https://github.com/vector-im/riot-web/pull/3790)
|
||||||
|
* Remember and Recall window layout/position state
|
||||||
|
[\#3622](https://github.com/vector-im/riot-web/pull/3622)
|
||||||
|
* Remove babelcheck
|
||||||
|
[\#3808](https://github.com/vector-im/riot-web/pull/3808)
|
||||||
|
* Include MXID and device id in rageshakes
|
||||||
|
[\#3809](https://github.com/vector-im/riot-web/pull/3809)
|
||||||
|
* import Modal
|
||||||
|
[\#3791](https://github.com/vector-im/riot-web/pull/3791)
|
||||||
|
* Pin filesize ver to fix break upstream
|
||||||
|
[\#3775](https://github.com/vector-im/riot-web/pull/3775)
|
||||||
|
* Improve Room Directory Look & Feel
|
||||||
|
[\#3751](https://github.com/vector-im/riot-web/pull/3751)
|
||||||
|
* Fix emote RRs alignment
|
||||||
|
[\#3742](https://github.com/vector-im/riot-web/pull/3742)
|
||||||
|
* Remove unused `placeholder` prop on RoomDropTarget
|
||||||
|
[\#3741](https://github.com/vector-im/riot-web/pull/3741)
|
||||||
|
* Modify CSS for matrix-org/matrix-react-sdk#833
|
||||||
|
[\#3732](https://github.com/vector-im/riot-web/pull/3732)
|
||||||
|
* Warn when exiting due to single-instance
|
||||||
|
[\#3727](https://github.com/vector-im/riot-web/pull/3727)
|
||||||
|
* Electron forgets it was maximized when you click on a notification
|
||||||
|
[\#3709](https://github.com/vector-im/riot-web/pull/3709)
|
||||||
|
* CSS to make h1 and h2 the same size as h1.
|
||||||
|
[\#3719](https://github.com/vector-im/riot-web/pull/3719)
|
||||||
|
* Prevent long room names/topics from pushing UI of the screen
|
||||||
|
[\#3721](https://github.com/vector-im/riot-web/pull/3721)
|
||||||
|
* Disable dropdown highlight on focus
|
||||||
|
[\#3717](https://github.com/vector-im/riot-web/pull/3717)
|
||||||
|
* Escape HTML Tags from Linux Notifications (electron)
|
||||||
|
[\#3564](https://github.com/vector-im/riot-web/pull/3564)
|
||||||
|
* styling for spoilerized access token view in Settings
|
||||||
|
[\#3651](https://github.com/vector-im/riot-web/pull/3651)
|
||||||
|
* Fix Webpack conf
|
||||||
|
[\#3690](https://github.com/vector-im/riot-web/pull/3690)
|
||||||
|
* Add config.json to .gitignore
|
||||||
|
[\#3599](https://github.com/vector-im/riot-web/pull/3599)
|
||||||
|
* add command line arg (--hidden) for electron app
|
||||||
|
[\#3641](https://github.com/vector-im/riot-web/pull/3641)
|
||||||
|
* fix ImageView Download functionality
|
||||||
|
[\#3640](https://github.com/vector-im/riot-web/pull/3640)
|
||||||
|
* Add cross-env into the mix
|
||||||
|
[\#3693](https://github.com/vector-im/riot-web/pull/3693)
|
||||||
|
* Remember acceptance for unsupported browsers.
|
||||||
|
[\#3694](https://github.com/vector-im/riot-web/pull/3694)
|
||||||
|
* Cosmetics to go with matrix-org/matrix-react-sdk#811
|
||||||
|
[\#3692](https://github.com/vector-im/riot-web/pull/3692)
|
||||||
|
* Cancel quicksearch on ESC
|
||||||
|
[\#3680](https://github.com/vector-im/riot-web/pull/3680)
|
||||||
|
* Optimise RoomList and implement quick-search functionality on it.
|
||||||
|
[\#3654](https://github.com/vector-im/riot-web/pull/3654)
|
||||||
|
* Progress updates for rageshake uploads
|
||||||
|
[\#3648](https://github.com/vector-im/riot-web/pull/3648)
|
||||||
|
* Factor out rageshake upload to a separate file
|
||||||
|
[\#3645](https://github.com/vector-im/riot-web/pull/3645)
|
||||||
|
* rageshake: fix race when collecting logs
|
||||||
|
[\#3644](https://github.com/vector-im/riot-web/pull/3644)
|
||||||
|
* Fix a flaky test
|
||||||
|
[\#3649](https://github.com/vector-im/riot-web/pull/3649)
|
||||||
|
|
||||||
Changes in [0.9.9](https://github.com/vector-im/riot-web/releases/tag/v0.9.9) (2017-04-25)
|
Changes in [0.9.9](https://github.com/vector-im/riot-web/releases/tag/v0.9.9) (2017-04-25)
|
||||||
==========================================================================================
|
==========================================================================================
|
||||||
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.9.9-rc.2...v0.9.9)
|
[Full Changelog](https://github.com/vector-im/riot-web/compare/v0.9.9-rc.2...v0.9.9)
|
||||||
|
|
56
README.md
|
@ -55,32 +55,41 @@ Building From Source
|
||||||
Riot is a modular webapp built with modern ES6 and requires a npm build system
|
Riot is a modular webapp built with modern ES6 and requires a npm build system
|
||||||
to build.
|
to build.
|
||||||
|
|
||||||
1. Install or update `node.js` so that your `npm` is at least at version `2.0.0`
|
1. Install or update `node.js` so that your `node` is at least v6.3.0 (and `npm`
|
||||||
1. Clone the repo: `git clone https://github.com/vector-im/riot-web.git`
|
is at least v3.10.x).
|
||||||
1. Switch to the riot-web directory: `cd riot-web`
|
1. Clone the repo: `git clone https://github.com/vector-im/riot-web.git`.
|
||||||
1. Install the prerequisites: `npm install`
|
1. Switch to the riot-web directory: `cd riot-web`.
|
||||||
1. If you are using the `develop` branch of vector-web, you will probably need
|
1. If you're using the `develop` branch, install the develop versions of the
|
||||||
to rebuild some of the dependencies, due to
|
dependencies, as the released ones will be too old:
|
||||||
https://github.com/npm/npm/issues/3055:
|
|
||||||
|
|
||||||
```
|
```
|
||||||
(cd node_modules/matrix-js-sdk && npm install)
|
scripts/fetch-develop-deps.sh
|
||||||
(cd node_modules/matrix-react-sdk && npm install)
|
|
||||||
```
|
```
|
||||||
Whenever you git pull on riot-web you will also probably need to force an update
|
Whenever you git pull on riot-web you will also probably need to force an update
|
||||||
to these dependencies - the easiest way is probably:
|
to these dependencies - the simplest way is to re-run the script, but you can also
|
||||||
|
manually update and rebuild them:
|
||||||
```
|
```
|
||||||
rm -rf node_modules/matrjx-{js,react}-sdk && npm i
|
cd matrix-js-sdk
|
||||||
(cd node_modules/matrix-js-sdk && npm install)
|
git pull
|
||||||
(cd node_modules/matrix-react-sdk && npm install)
|
npm install # re-run to pull in any new dependencies
|
||||||
|
# Depending on your version of npm, npm run build may happen as part of
|
||||||
|
# the npm install above (https://docs.npmjs.com/misc/scripts#prepublish-and-prepare)
|
||||||
|
# If in doubt, run it anyway:
|
||||||
|
npm run build
|
||||||
|
cd ../matrix-react-sdk
|
||||||
|
git pull
|
||||||
|
npm install
|
||||||
|
npm run build
|
||||||
```
|
```
|
||||||
However, we recommend setting up a proper development environment (see "Setting
|
However, we recommend setting up a proper development environment (see "Setting
|
||||||
up a development environment" below) if you want to run your own copy of the
|
up a development environment" below) if you want to run your own copy of the
|
||||||
`develop` branch, as it makes it much easier to keep these dependencies
|
`develop` branch, as it makes it much easier to keep these dependencies
|
||||||
up-to-date. Or just use https://riot.im/develop - the continuous integration
|
up-to-date. Or just use https://riot.im/develop - the continuous integration
|
||||||
release of the develop branch.
|
release of the develop branch.
|
||||||
|
(Note that we don't reference the develop versions in git directly due to
|
||||||
|
https://github.com/npm/npm/issues/3055.)
|
||||||
|
1. Install the prerequisites: `npm install`.
|
||||||
1. Configure the app by copying `config.sample.json` to `config.json` and
|
1. Configure the app by copying `config.sample.json` to `config.json` and
|
||||||
modifying it (see below for details)
|
modifying it (see below for details).
|
||||||
1. `npm run dist` to build a tarball to deploy. Untaring this file will give
|
1. `npm run dist` to build a tarball to deploy. Untaring this file will give
|
||||||
a version-specific directory containing all the files that need to go on your
|
a version-specific directory containing all the files that need to go on your
|
||||||
web server.
|
web server.
|
||||||
|
@ -125,7 +134,7 @@ Running as a Desktop app
|
||||||
|
|
||||||
Riot can also be run as a desktop app, wrapped in electron. You can download a
|
Riot can also be run as a desktop app, wrapped in electron. You can download a
|
||||||
pre-built version from https://riot.im/desktop.html or, if you prefer,
|
pre-built version from https://riot.im/desktop.html or, if you prefer,
|
||||||
built it yourself.
|
build it yourself. Requires Electron >=1.6.0
|
||||||
|
|
||||||
To run as a desktop app:
|
To run as a desktop app:
|
||||||
|
|
||||||
|
@ -135,7 +144,7 @@ To run as a desktop app:
|
||||||
|
|
||||||
```
|
```
|
||||||
npm install electron
|
npm install electron
|
||||||
node_modules/.bin/electron .
|
npm run electron
|
||||||
```
|
```
|
||||||
|
|
||||||
To build packages, use electron-builder. This is configured to output:
|
To build packages, use electron-builder. This is configured to output:
|
||||||
|
@ -273,6 +282,19 @@ If any of these steps error with, `file table overflow`, you are probably on a m
|
||||||
which has a very low limit on max open files. Run `ulimit -Sn 1024` and try again.
|
which has a very low limit on max open files. Run `ulimit -Sn 1024` and try again.
|
||||||
You'll need to do this in each new terminal you open before building Riot.
|
You'll need to do this in each new terminal you open before building Riot.
|
||||||
|
|
||||||
|
How to add a new translation?
|
||||||
|
=============================
|
||||||
|
|
||||||
|
[<img src="https://translate.riot.im/widgets/riot-web/-/multi-auto.svg" alt="translationsstatus" width="340">](https://translate.riot.im/engage/riot-web/?utm_source=widget)
|
||||||
|
|
||||||
|
|
||||||
|
Head to the [translating doc](docs/translating.md)
|
||||||
|
|
||||||
|
Adding Strings to the translations (Developer Guide)
|
||||||
|
====================================================
|
||||||
|
|
||||||
|
Head to the [translating dev doc](docs/translating-dev.md)
|
||||||
|
|
||||||
Triaging issues
|
Triaging issues
|
||||||
===============
|
===============
|
||||||
|
|
||||||
|
|
|
@ -4,12 +4,17 @@
|
||||||
"brand": "Riot",
|
"brand": "Riot",
|
||||||
"integrations_ui_url": "https://scalar.vector.im/",
|
"integrations_ui_url": "https://scalar.vector.im/",
|
||||||
"integrations_rest_url": "https://scalar.vector.im/api",
|
"integrations_rest_url": "https://scalar.vector.im/api",
|
||||||
"bug_report_endpoint_url": "https://vector.im/bugs",
|
"bug_report_endpoint_url": "https://riot.im/bugreports/submit",
|
||||||
"enableLabs": true,
|
"enableLabs": true,
|
||||||
"default_federate": true,
|
"default_federate": true,
|
||||||
"roomDirectory": {
|
"roomDirectory": {
|
||||||
"servers": [
|
"servers": [
|
||||||
"matrix.org"
|
"matrix.org"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
"welcomeUserId": "@riot-bot:matrix.org",
|
||||||
|
"piwik": {
|
||||||
|
"url": "https://piwik.riot.im/",
|
||||||
|
"siteId": 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
26
docs/translating-dev.md
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# How to translate riot-web (Dev Guide)
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
- A working [Development Setup](../../#setting-up-a-dev-environment)
|
||||||
|
- Be able to understand English
|
||||||
|
- Be able to understand the language you want to translate riot-web into
|
||||||
|
|
||||||
|
## Adding new strings
|
||||||
|
|
||||||
|
1. Check if the import ``import { _t } from 'matrix-react-sdk/lib/languageHandler';`` is present. If not add it to the other import statements.
|
||||||
|
2. Add ``_t()`` to your string. (Don't forget curly braces when you assign an expression to JSX attributes in the render method)
|
||||||
|
3. Add the String to the ``en_EN.json`` file in ``src/i18n/strings`` (respect which repository you are on).
|
||||||
|
|
||||||
|
## Adding variables inside a string.
|
||||||
|
|
||||||
|
1. Extend your ``_t()`` call. Instead of ``_t(STRING)`` use ``_t(STRING, {})``
|
||||||
|
2. Decide how to name it. Please think about if the person who has to translate it can understand what it does.
|
||||||
|
3. Add it to the array in ``_t`` for example ``_t(STRING, {variable: this.variable})``
|
||||||
|
4. Add the variable inside the string. The syntax for variables is ``%(variable)s``. Please note the s at the end. The name of the variable has to match the previous used name.
|
||||||
|
|
||||||
|
## Things to know/Style Guides
|
||||||
|
|
||||||
|
- Do not use it inside ``getDefaultProps`` at the point where ``getDefaultProps`` is initialized the translations aren't loaded yet and it causes missing translations.
|
||||||
|
- If using translated strings as constants, translated strings can't be in constants loaded at class-load time since the translations won't be loaded.
|
||||||
|
- If a string is presented in the UI with punctuation like a full stop, include this in the translation strings, since punctuation varies between languages too.
|
64
docs/translating.md
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
# How to translate riot-web
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
- Web Browser
|
||||||
|
- Be able to understand English
|
||||||
|
- Be able to understand the language you want to translate riot-web into
|
||||||
|
|
||||||
|
## Step 0: Join #riotweb-translations:matrix.org
|
||||||
|
|
||||||
|
1. Come and join https://matrix.to/#/#riotweb-translations:matrix.org
|
||||||
|
2. Read scrollback and/or ask if anyone else is working on your language, and co-ordinate if needed. In general little-or-no coordination is needed though :)
|
||||||
|
|
||||||
|
## Step 1: Preparing your Weblate Profile
|
||||||
|
|
||||||
|
1. Head to https://translate.riot.im and register either via Github or email
|
||||||
|
2. After registering check if you got an email to verify your account and click the link (if there is none head to step 1.4)
|
||||||
|
3. Log into weblate
|
||||||
|
4. Head to https://translate.riot.im/accounts/profile/ and select the languages you know and maybe another language you know too.
|
||||||
|
6. Head to https://translate.riot.im/accounts/profile/#subscriptions and select Riot Web as Project
|
||||||
|
|
||||||
|
## How to check if your language already is being translated
|
||||||
|
|
||||||
|
Go to https://translate.riot.im/projects/riot-web/ and visit the 2 sub-projects.
|
||||||
|
If your language is listed go to Step 2a and if not go to Step 2b
|
||||||
|
|
||||||
|
## Step 2a: Helping on existing languages.
|
||||||
|
|
||||||
|
1. Head to one of the projects listed https://translate.riot.im/projects/riot-web/
|
||||||
|
2. Click on the ``translate`` button on the right side of your language
|
||||||
|
3. Fill in the translations in the writeable field. You will see the original English string and the string of your second language above.
|
||||||
|
|
||||||
|
Head to the explanations under Steb 2b
|
||||||
|
|
||||||
|
## Step 2b: Adding a new language
|
||||||
|
|
||||||
|
1. Go to one of the projects listed https://translate.riot.im/projects/riot-web/
|
||||||
|
2. Click the ``Start new language`` button at the bottom
|
||||||
|
3. Select a language
|
||||||
|
4. Start translating like in 2a.3
|
||||||
|
5. Repeat these steps for the other projects which are listed at the link of step 2b.1
|
||||||
|
|
||||||
|
### What means the green button under the text field?
|
||||||
|
|
||||||
|
The green button let you save our translations directly. Please only use it if you are 100% sure about that translation. If you do not know a translation please DO NOT click that button. Use the arrows above the translations field and click to the right.
|
||||||
|
|
||||||
|
### What means the yellow button under the text field?
|
||||||
|
|
||||||
|
The yellow button has to be used if you are unsure about the translation but you have a rough idea. It adds a new suggestion to the string which can than be reviewed by others.
|
||||||
|
|
||||||
|
### What are "%(something)s"?
|
||||||
|
|
||||||
|
These things are variables that are expanded when displayed by Riot. They can be room names, usernames or similar. If you find one, you can move to the right place for your language, but not delete it as the variable will be missing if you do.
|
||||||
|
|
||||||
|
A special case is `%(urlStart)s` and `%(urlEnd)s` which are used to mark the beginning of a hyperlink (i.e. `<a href="/somewhere">` and `</a>`. You must keep these markers surrounding the equivalent string in your language that needs to be hyperlinked.
|
||||||
|
|
||||||
|
### "I want to come back to this string. How?"
|
||||||
|
|
||||||
|
You can use inside the translation field "Review needed" checkbox. It will be shown as Strings that need to be reviewed.
|
||||||
|
|
||||||
|
|
||||||
|
### Further reading
|
||||||
|
|
||||||
|
The official Weblate doc provides some more in-deepth explanation on how to do translations and talks about do and don'ts. You can find it at: https://docs.weblate.org/en/latest/user/translating.html
|
Before Width: | Height: | Size: 21 KiB |
Before Width: | Height: | Size: 14 KiB |
|
@ -1,73 +0,0 @@
|
||||||
{
|
|
||||||
"update_base_url": "https://riot.im/download/desktop/update/",
|
|
||||||
"default_hs_url": "https://matrix.org",
|
|
||||||
"default_is_url": "https://vector.im",
|
|
||||||
"brand": "Riot",
|
|
||||||
"integrations_ui_url": "https://scalar.vector.im/",
|
|
||||||
"integrations_rest_url": "https://scalar.vector.im/api",
|
|
||||||
"bug_report_endpoint_url": "https://riot.im/bugreports/submit",
|
|
||||||
"enableLabs": true,
|
|
||||||
"roomDirectory": {
|
|
||||||
"servers": [
|
|
||||||
"matrix.org"
|
|
||||||
],
|
|
||||||
"serverConfig": {
|
|
||||||
"matrix.org": {
|
|
||||||
"networks": [
|
|
||||||
"_matrix",
|
|
||||||
"gitter",
|
|
||||||
"irc:freenode",
|
|
||||||
"irc:mozilla",
|
|
||||||
"irc:snoonet",
|
|
||||||
"irc:oftc"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"networks": {
|
|
||||||
"gitter": {
|
|
||||||
"protocol": "gitter",
|
|
||||||
"portalRoomPattern": "#gitter_.*:matrix.org",
|
|
||||||
"name": "Gitter",
|
|
||||||
"icon": "https://gitter.im/favicon.ico",
|
|
||||||
"example": "org/community",
|
|
||||||
"nativePattern": "[^\\s]+/[^\\s]+$"
|
|
||||||
},
|
|
||||||
"irc:freenode": {
|
|
||||||
"protocol": "irc",
|
|
||||||
"domain": "chat.freenode.net",
|
|
||||||
"portalRoomPattern": "#freenode_.*:matrix.org",
|
|
||||||
"name": "Freenode",
|
|
||||||
"icon": "https://matrix.org/_matrix/media/v1/download/matrix.org/DHLHpDDgWNNejFmrewvwEAHX",
|
|
||||||
"example": "#channel",
|
|
||||||
"nativePattern": "^#[^\\s]+$"
|
|
||||||
},
|
|
||||||
"irc:mozilla": {
|
|
||||||
"protocol": "irc",
|
|
||||||
"domain": "chat.freenode.net",
|
|
||||||
"portalRoomPattern": "#mozilla_.*:matrix.org",
|
|
||||||
"name": "Mozilla",
|
|
||||||
"icon": "https://matrix.org/_matrix/media/v1/download/matrix.org/DHLHpDDgWNNejFmrewvwEAHX",
|
|
||||||
"example": "#channel",
|
|
||||||
"nativePattern": "^#[^\\s]+$"
|
|
||||||
},
|
|
||||||
"irc:snoonet": {
|
|
||||||
"protocol": "irc",
|
|
||||||
"domain": "ipv6-irc.snoonet.org",
|
|
||||||
"portalRoomPattern": "#_snoonet_.*:matrix.org",
|
|
||||||
"name": "Snoonet",
|
|
||||||
"icon": "https://matrix.org/_matrix/media/v1/download/matrix.org/DHLHpDDgWNNejFmrewvwEAHX",
|
|
||||||
"example": "#channel",
|
|
||||||
"nativePattern": "^#[^\\s]+$"
|
|
||||||
},
|
|
||||||
"irc:oftc": {
|
|
||||||
"protocol": "irc",
|
|
||||||
"domain": "irc.oftc.net",
|
|
||||||
"portalRoomPattern": "#_oftc_.*:matrix.org",
|
|
||||||
"name": "OFTC",
|
|
||||||
"icon": "https://matrix.org/_matrix/media/v1/download/matrix.org/DHLHpDDgWNNejFmrewvwEAHX",
|
|
||||||
"example": "#channel",
|
|
||||||
"nativePattern": "^#[^\\s]+$"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,67 +0,0 @@
|
||||||
/*
|
|
||||||
Copyright 2017 Karl Glatz <karl@glatz.biz>
|
|
||||||
Copyright 2017 OpenMarket Ltd
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const path = require('path');
|
|
||||||
const electron = require('electron');
|
|
||||||
|
|
||||||
const app = electron.app;
|
|
||||||
const Tray = electron.Tray;
|
|
||||||
const MenuItem = electron.MenuItem;
|
|
||||||
|
|
||||||
let trayIcon = null;
|
|
||||||
|
|
||||||
exports.hasTray = function hasTray() {
|
|
||||||
return (trayIcon !== null);
|
|
||||||
}
|
|
||||||
|
|
||||||
exports.create = function (win, config) {
|
|
||||||
// no trays on darwin
|
|
||||||
if (process.platform === 'darwin' || trayIcon) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const toggleWin = function () {
|
|
||||||
if (win.isVisible() && !win.isMinimized()) {
|
|
||||||
win.hide();
|
|
||||||
} else {
|
|
||||||
if (win.isMinimized()) win.restore();
|
|
||||||
if (!win.isVisible()) win.show();
|
|
||||||
win.focus();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const contextMenu = electron.Menu.buildFromTemplate([
|
|
||||||
{
|
|
||||||
label: 'Show/Hide ' + config.brand,
|
|
||||||
click: toggleWin
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Quit',
|
|
||||||
click: function () {
|
|
||||||
app.quit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]);
|
|
||||||
|
|
||||||
trayIcon = new Tray(config.icon_path);
|
|
||||||
trayIcon.setToolTip(config.brand);
|
|
||||||
trayIcon.setContextMenu(contextMenu);
|
|
||||||
trayIcon.on('click', toggleWin);
|
|
||||||
};
|
|
|
@ -1,197 +0,0 @@
|
||||||
/*
|
|
||||||
Copyright 2016 OpenMarket Ltd
|
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
you may not use this file except in compliance with the License.
|
|
||||||
You may obtain a copy of the License at
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
See the License for the specific language governing permissions and
|
|
||||||
limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const electron = require('electron');
|
|
||||||
|
|
||||||
// Menu template from http://electron.atom.io/docs/api/menu/, edited
|
|
||||||
const template = [
|
|
||||||
{
|
|
||||||
label: 'Edit',
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
role: 'undo'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'redo'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'cut'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'copy'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'paste'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'pasteandmatchstyle'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'delete'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'selectall'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'View',
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'resetzoom'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'zoomin'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'zoomout'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'togglefullscreen'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'toggledevtools'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'window',
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
role: 'minimize'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'close'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'help',
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
label: 'riot.im',
|
|
||||||
click () { electron.shell.openExternal('https://riot.im/') }
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
// macOS has specific menu conventions...
|
|
||||||
if (process.platform === 'darwin') {
|
|
||||||
// first macOS menu is the name of the app
|
|
||||||
const name = electron.app.getName()
|
|
||||||
template.unshift({
|
|
||||||
label: name,
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
role: 'about'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'services',
|
|
||||||
submenu: []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'hide'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'hideothers'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'unhide'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'quit'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
})
|
|
||||||
// Edit menu.
|
|
||||||
// This has a 'speech' section on macOS
|
|
||||||
template[1].submenu.push(
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Speech',
|
|
||||||
submenu: [
|
|
||||||
{
|
|
||||||
role: 'startspeaking'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
role: 'stopspeaking'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
)
|
|
||||||
// Window menu.
|
|
||||||
// This also has specific functionality on macOS
|
|
||||||
template[3].submenu = [
|
|
||||||
{
|
|
||||||
label: 'Close',
|
|
||||||
accelerator: 'CmdOrCtrl+W',
|
|
||||||
role: 'close'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Minimize',
|
|
||||||
accelerator: 'CmdOrCtrl+M',
|
|
||||||
role: 'minimize'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Zoom',
|
|
||||||
role: 'zoom'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'separator'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'Bring All to Front',
|
|
||||||
role: 'front'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
} else {
|
|
||||||
template.unshift({
|
|
||||||
label: 'File',
|
|
||||||
submenu: [
|
|
||||||
// For some reason, 'about' does not seem to work on windows.
|
|
||||||
/*{
|
|
||||||
role: 'about'
|
|
||||||
},*/
|
|
||||||
{
|
|
||||||
role: 'quit'
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = electron.Menu.buildFromTemplate(template)
|
|
||||||
|
|
Before Width: | Height: | Size: 102 KiB After Width: | Height: | Size: 102 KiB |
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 7.2 KiB |
Before Width: | Height: | Size: 673 B After Width: | Height: | Size: 673 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 14 KiB After Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 2.6 KiB After Width: | Height: | Size: 2.6 KiB |
Before Width: | Height: | Size: 30 KiB After Width: | Height: | Size: 30 KiB |
Before Width: | Height: | Size: 3.6 KiB After Width: | Height: | Size: 3.6 KiB |
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 5.5 KiB |
Before Width: | Height: | Size: 4.4 KiB After Width: | Height: | Size: 4.4 KiB |
BIN
electron_app/img/riot.ico
Normal file
After Width: | Height: | Size: 102 KiB |
BIN
electron_app/img/riot.png
Normal file
After Width: | Height: | Size: 10 KiB |
14
electron_app/package.json
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
{
|
||||||
|
"name": "riot-web",
|
||||||
|
"productName": "Riot",
|
||||||
|
"main": "src/electron-main.js",
|
||||||
|
"version": "0.11.4",
|
||||||
|
"description": "A feature-rich client for Matrix.org",
|
||||||
|
"author": "Vector Creations Ltd.",
|
||||||
|
"dependencies": {
|
||||||
|
"auto-launch": "^5.0.1",
|
||||||
|
"electron-window-state": "^4.1.0",
|
||||||
|
"minimist": "^1.2.0",
|
||||||
|
"png-to-ico": "^1.0.2"
|
||||||
|
}
|
||||||
|
}
|
20
electron_app/riot.im/config.json
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{
|
||||||
|
"update_base_url": "https://riot.im/download/desktop/update/",
|
||||||
|
"default_hs_url": "https://matrix.org",
|
||||||
|
"default_is_url": "https://vector.im",
|
||||||
|
"brand": "Riot",
|
||||||
|
"integrations_ui_url": "https://scalar.vector.im/",
|
||||||
|
"integrations_rest_url": "https://scalar.vector.im/api",
|
||||||
|
"bug_report_endpoint_url": "https://riot.im/bugreports/submit",
|
||||||
|
"welcomeUserId": "@riot-bot:matrix.org",
|
||||||
|
"enableLabs": true,
|
||||||
|
"roomDirectory": {
|
||||||
|
"servers": [
|
||||||
|
"matrix.org"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"piwik": {
|
||||||
|
"url": "https://piwik.riot.im/",
|
||||||
|
"siteId": 1
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,8 +1,7 @@
|
||||||
// @flow
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Copyright 2016 Aviral Dasgupta
|
Copyright 2016 Aviral Dasgupta
|
||||||
Copyright 2016 OpenMarket Ltd
|
Copyright 2016 OpenMarket Ltd
|
||||||
|
Copyright 2017 Michael Telatynski <7t3chguy@gmail.com>
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
|
@ -20,15 +19,22 @@ limitations under the License.
|
||||||
// Squirrel on windows starts the app with various flags
|
// Squirrel on windows starts the app with various flags
|
||||||
// as hooks to tell us when we've been installed/uninstalled
|
// as hooks to tell us when we've been installed/uninstalled
|
||||||
// etc.
|
// etc.
|
||||||
const check_squirrel_hooks = require('./squirrelhooks');
|
const checkSquirrelHooks = require('./squirrelhooks');
|
||||||
if (check_squirrel_hooks()) return;
|
if (checkSquirrelHooks()) return;
|
||||||
|
|
||||||
|
const argv = require('minimist')(process.argv);
|
||||||
const electron = require('electron');
|
const electron = require('electron');
|
||||||
const url = require('url');
|
const AutoLaunch = require('auto-launch');
|
||||||
|
|
||||||
const tray = require('./tray');
|
const tray = require('./tray');
|
||||||
|
const vectorMenu = require('./vectormenu');
|
||||||
|
const webContentsHandler = require('./webcontents-handler');
|
||||||
|
|
||||||
const VectorMenu = require('./vectormenu');
|
const windowStateKeeper = require('electron-window-state');
|
||||||
|
|
||||||
|
if (argv.profile) {
|
||||||
|
electron.app.setPath('userData', `${electron.app.getPath('userData')}-${argv.profile}`);
|
||||||
|
}
|
||||||
|
|
||||||
let vectorConfig = {};
|
let vectorConfig = {};
|
||||||
try {
|
try {
|
||||||
|
@ -40,54 +46,12 @@ try {
|
||||||
// Continue with the defaults (ie. an empty config)
|
// Continue with the defaults (ie. an empty config)
|
||||||
}
|
}
|
||||||
|
|
||||||
const PERMITTED_URL_SCHEMES = [
|
|
||||||
'http:',
|
|
||||||
'https:',
|
|
||||||
'mailto:',
|
|
||||||
];
|
|
||||||
|
|
||||||
const UPDATE_POLL_INTERVAL_MS = 60 * 60 * 1000;
|
const UPDATE_POLL_INTERVAL_MS = 60 * 60 * 1000;
|
||||||
const INITIAL_UPDATE_DELAY_MS = 30 * 1000;
|
const INITIAL_UPDATE_DELAY_MS = 30 * 1000;
|
||||||
|
|
||||||
let mainWindow = null;
|
let mainWindow = null;
|
||||||
let appQuitting = false;
|
let appQuitting = false;
|
||||||
|
|
||||||
function safeOpenURL(target) {
|
|
||||||
// openExternal passes the target to open/start/xdg-open,
|
|
||||||
// so put fairly stringent limits on what can be opened
|
|
||||||
// (for instance, open /bin/sh does indeed open a terminal
|
|
||||||
// with a shell, albeit with no arguments)
|
|
||||||
const parsed_url = url.parse(target);
|
|
||||||
if (PERMITTED_URL_SCHEMES.indexOf(parsed_url.protocol) > -1) {
|
|
||||||
// explicitly use the URL re-assembled by the url library,
|
|
||||||
// so we know the url parser has understood all the parts
|
|
||||||
// of the input string
|
|
||||||
const new_target = url.format(parsed_url);
|
|
||||||
electron.shell.openExternal(new_target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function onWindowOrNavigate(ev, target) {
|
|
||||||
// always prevent the default: if something goes wrong,
|
|
||||||
// we don't want to end up opening it in the electron
|
|
||||||
// app, as we could end up opening any sort of random
|
|
||||||
// url in a window that has node scripting access.
|
|
||||||
ev.preventDefault();
|
|
||||||
safeOpenURL(target);
|
|
||||||
}
|
|
||||||
|
|
||||||
function onLinkContextMenu(ev, params) {
|
|
||||||
const popup_menu = new electron.Menu();
|
|
||||||
popup_menu.append(new electron.MenuItem({
|
|
||||||
label: params.linkURL,
|
|
||||||
click() {
|
|
||||||
safeOpenURL(params.linkURL);
|
|
||||||
},
|
|
||||||
}));
|
|
||||||
popup_menu.popup();
|
|
||||||
ev.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
function installUpdate() {
|
function installUpdate() {
|
||||||
// for some reason, quitAndInstall does not fire the
|
// for some reason, quitAndInstall does not fire the
|
||||||
// before-quit event, so we need to set the flag here.
|
// before-quit event, so we need to set the flag here.
|
||||||
|
@ -99,13 +63,13 @@ function pollForUpdates() {
|
||||||
try {
|
try {
|
||||||
electron.autoUpdater.checkForUpdates();
|
electron.autoUpdater.checkForUpdates();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.log("Couldn't check for update", e);
|
console.log('Couldn\'t check for update', e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function startAutoUpdate(update_base_url) {
|
function startAutoUpdate(updateBaseUrl) {
|
||||||
if (update_base_url.slice(-1) !== '/') {
|
if (updateBaseUrl.slice(-1) !== '/') {
|
||||||
update_base_url = update_base_url + '/';
|
updateBaseUrl = updateBaseUrl + '/';
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
// For reasons best known to Squirrel, the way it checks for updates
|
// For reasons best known to Squirrel, the way it checks for updates
|
||||||
|
@ -113,7 +77,7 @@ function startAutoUpdate(update_base_url) {
|
||||||
// hits a URL that either gives it a 200 with some json or
|
// hits a URL that either gives it a 200 with some json or
|
||||||
// 204 No Content. On windows it takes a base path and looks for
|
// 204 No Content. On windows it takes a base path and looks for
|
||||||
// files under that path.
|
// files under that path.
|
||||||
if (process.platform == 'darwin') {
|
if (process.platform === 'darwin') {
|
||||||
// include the current version in the URL we hit. Electron doesn't add
|
// include the current version in the URL we hit. Electron doesn't add
|
||||||
// it anywhere (apart from the User-Agent) so it's up to us. We could
|
// it anywhere (apart from the User-Agent) so it's up to us. We could
|
||||||
// (and previously did) just use the User-Agent, but this doesn't
|
// (and previously did) just use the User-Agent, but this doesn't
|
||||||
|
@ -121,16 +85,15 @@ function startAutoUpdate(update_base_url) {
|
||||||
// and also acts as a convenient cache-buster to ensure that when the
|
// and also acts as a convenient cache-buster to ensure that when the
|
||||||
// app updates it always gets a fresh value to avoid update-looping.
|
// app updates it always gets a fresh value to avoid update-looping.
|
||||||
electron.autoUpdater.setFeedURL(
|
electron.autoUpdater.setFeedURL(
|
||||||
update_base_url +
|
`${updateBaseUrl}macos/?localVersion=${encodeURIComponent(electron.app.getVersion())}`);
|
||||||
'macos/?localVersion=' + encodeURIComponent(electron.app.getVersion())
|
|
||||||
);
|
} else if (process.platform === 'win32') {
|
||||||
} else if (process.platform == 'win32') {
|
electron.autoUpdater.setFeedURL(`${updateBaseUrl}win32/${process.arch}/`);
|
||||||
electron.autoUpdater.setFeedURL(update_base_url + 'win32/' + process.arch + '/');
|
|
||||||
} else {
|
} else {
|
||||||
// Squirrel / electron only supports auto-update on these two platforms.
|
// Squirrel / electron only supports auto-update on these two platforms.
|
||||||
// I'm not even going to try to guess which feed style they'd use if they
|
// I'm not even going to try to guess which feed style they'd use if they
|
||||||
// implemented it on Linux, or if it would be different again.
|
// implemented it on Linux, or if it would be different again.
|
||||||
console.log("Auto update not supported on this platform");
|
console.log('Auto update not supported on this platform');
|
||||||
}
|
}
|
||||||
// We check for updates ourselves rather than using 'updater' because we need to
|
// We check for updates ourselves rather than using 'updater' because we need to
|
||||||
// do it in the main process (and we don't really need to check every 10 minutes:
|
// do it in the main process (and we don't really need to check every 10 minutes:
|
||||||
|
@ -143,7 +106,7 @@ function startAutoUpdate(update_base_url) {
|
||||||
setInterval(pollForUpdates, UPDATE_POLL_INTERVAL_MS);
|
setInterval(pollForUpdates, UPDATE_POLL_INTERVAL_MS);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
// will fail if running in debug mode
|
// will fail if running in debug mode
|
||||||
console.log("Couldn't enable update checking", err);
|
console.log('Couldn\'t enable update checking', err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,11 +117,48 @@ function startAutoUpdate(update_base_url) {
|
||||||
// Assuming we generally run from the console when developing,
|
// Assuming we generally run from the console when developing,
|
||||||
// this is far preferable.
|
// this is far preferable.
|
||||||
process.on('uncaughtException', function(error) {
|
process.on('uncaughtException', function(error) {
|
||||||
console.log("Unhandled exception", error);
|
console.log('Unhandled exception', error);
|
||||||
});
|
});
|
||||||
|
|
||||||
electron.ipcMain.on('install_update', installUpdate);
|
electron.ipcMain.on('install_update', installUpdate);
|
||||||
|
|
||||||
|
let focusHandlerAttached = false;
|
||||||
|
electron.ipcMain.on('setBadgeCount', function(ev, count) {
|
||||||
|
electron.app.setBadgeCount(count);
|
||||||
|
if (count === 0) {
|
||||||
|
mainWindow.flashFrame(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
electron.ipcMain.on('loudNotification', function() {
|
||||||
|
if (process.platform === 'win32' && mainWindow && !mainWindow.isFocused() && !focusHandlerAttached) {
|
||||||
|
mainWindow.flashFrame(true);
|
||||||
|
mainWindow.once('focus', () => {
|
||||||
|
mainWindow.flashFrame(false);
|
||||||
|
focusHandlerAttached = false;
|
||||||
|
});
|
||||||
|
focusHandlerAttached = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
let powerSaveBlockerId;
|
||||||
|
electron.ipcMain.on('app_onAction', function(ev, payload) {
|
||||||
|
switch (payload.action) {
|
||||||
|
case 'call_state':
|
||||||
|
if (powerSaveBlockerId && powerSaveBlockerId.isStarted(powerSaveBlockerId)) {
|
||||||
|
if (payload.state === 'ended') {
|
||||||
|
electron.powerSaveBlocker.stop(powerSaveBlockerId);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (payload.state === 'connected') {
|
||||||
|
powerSaveBlockerId = electron.powerSaveBlocker.start('prevent-display-sleep');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
electron.app.commandLine.appendSwitch('--enable-usermedia-screen-capturing');
|
electron.app.commandLine.appendSwitch('--enable-usermedia-screen-capturing');
|
||||||
|
|
||||||
const shouldQuit = electron.app.makeSingleInstance((commandLine, workingDirectory) => {
|
const shouldQuit = electron.app.makeSingleInstance((commandLine, workingDirectory) => {
|
||||||
|
@ -171,44 +171,115 @@ const shouldQuit = electron.app.makeSingleInstance((commandLine, workingDirector
|
||||||
});
|
});
|
||||||
|
|
||||||
if (shouldQuit) {
|
if (shouldQuit) {
|
||||||
electron.app.quit()
|
console.log('Other instance detected: exiting');
|
||||||
|
electron.app.exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const launcher = new AutoLaunch({
|
||||||
|
name: vectorConfig.brand || 'Riot',
|
||||||
|
isHidden: true,
|
||||||
|
mac: {
|
||||||
|
useLaunchAgent: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const settings = {
|
||||||
|
'auto-launch': {
|
||||||
|
get: launcher.isEnabled,
|
||||||
|
set: function(bool) {
|
||||||
|
if (bool) {
|
||||||
|
return launcher.enable();
|
||||||
|
} else {
|
||||||
|
return launcher.disable();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
electron.ipcMain.on('settings_get', async function(ev) {
|
||||||
|
const data = {};
|
||||||
|
|
||||||
|
try {
|
||||||
|
await Promise.all(Object.keys(settings).map(async function (setting) {
|
||||||
|
data[setting] = await settings[setting].get();
|
||||||
|
}));
|
||||||
|
|
||||||
|
ev.sender.send('settings', data);
|
||||||
|
} catch(e) { console.error(e); }
|
||||||
|
});
|
||||||
|
|
||||||
|
electron.ipcMain.on('settings_set', function(ev, key, value) {
|
||||||
|
console.log(key, value);
|
||||||
|
if (settings[key] && settings[key].set) {
|
||||||
|
settings[key].set(value);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
electron.app.on('ready', () => {
|
electron.app.on('ready', () => {
|
||||||
if (vectorConfig.update_base_url) {
|
|
||||||
console.log("Starting auto update with base URL: " + vectorConfig.update_base_url);
|
if (argv.devtools) {
|
||||||
startAutoUpdate(vectorConfig.update_base_url);
|
try {
|
||||||
} else {
|
const { default: installExtension, REACT_DEVELOPER_TOOLS, REACT_PERF } = require('electron-devtools-installer');
|
||||||
console.log("No update_base_url is defined: auto update is disabled");
|
installExtension(REACT_DEVELOPER_TOOLS)
|
||||||
|
.then((name) => console.log(`Added Extension: ${name}`))
|
||||||
|
.catch((err) => console.log('An error occurred: ', err));
|
||||||
|
installExtension(REACT_PERF)
|
||||||
|
.then((name) => console.log(`Added Extension: ${name}`))
|
||||||
|
.catch((err) => console.log('An error occurred: ', err));
|
||||||
|
} catch(e) {console.log(e);}
|
||||||
}
|
}
|
||||||
|
|
||||||
const icon_path = `${__dirname}/../img/riot.` + (
|
|
||||||
process.platform == 'win32' ? 'ico' : 'png'
|
if (vectorConfig.update_base_url) {
|
||||||
);
|
console.log(`Starting auto update with base URL: ${vectorConfig.update_base_url}`);
|
||||||
|
startAutoUpdate(vectorConfig.update_base_url);
|
||||||
|
} else {
|
||||||
|
console.log('No update_base_url is defined: auto update is disabled');
|
||||||
|
}
|
||||||
|
|
||||||
|
const iconPath = `${__dirname}/../img/riot.${process.platform === 'win32' ? 'ico' : 'png'}`;
|
||||||
|
|
||||||
|
// Load the previous window state with fallback to defaults
|
||||||
|
const mainWindowState = windowStateKeeper({
|
||||||
|
defaultWidth: 1024,
|
||||||
|
defaultHeight: 768,
|
||||||
|
});
|
||||||
|
|
||||||
mainWindow = new electron.BrowserWindow({
|
mainWindow = new electron.BrowserWindow({
|
||||||
icon: icon_path,
|
icon: iconPath,
|
||||||
width: 1024, height: 768,
|
|
||||||
show: false,
|
show: false,
|
||||||
autoHideMenuBar: true,
|
autoHideMenuBar: true,
|
||||||
|
|
||||||
|
x: mainWindowState.x,
|
||||||
|
y: mainWindowState.y,
|
||||||
|
width: mainWindowState.width,
|
||||||
|
height: mainWindowState.height,
|
||||||
});
|
});
|
||||||
mainWindow.loadURL(`file://${__dirname}/../../webapp/index.html`);
|
mainWindow.loadURL(`file://${__dirname}/../../webapp/index.html`);
|
||||||
electron.Menu.setApplicationMenu(VectorMenu);
|
electron.Menu.setApplicationMenu(vectorMenu);
|
||||||
|
|
||||||
|
// explicitly hide because setApplicationMenu on Linux otherwise shows...
|
||||||
|
// https://github.com/electron/electron/issues/9621
|
||||||
|
mainWindow.hide();
|
||||||
|
|
||||||
// Create trayIcon icon
|
// Create trayIcon icon
|
||||||
tray.create(mainWindow, {
|
tray.create(mainWindow, {
|
||||||
icon_path: icon_path,
|
icon_path: iconPath,
|
||||||
brand: vectorConfig.brand || 'Riot'
|
brand: vectorConfig.brand || 'Riot',
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (!argv.hidden) {
|
||||||
mainWindow.once('ready-to-show', () => {
|
mainWindow.once('ready-to-show', () => {
|
||||||
mainWindow.show();
|
mainWindow.show();
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
mainWindow.on('closed', () => {
|
mainWindow.on('closed', () => {
|
||||||
mainWindow = null;
|
mainWindow = null;
|
||||||
});
|
});
|
||||||
mainWindow.on('close', (e) => {
|
mainWindow.on('close', (e) => {
|
||||||
if (!appQuitting && (tray.hasTray() || process.platform == 'darwin')) {
|
if (!appQuitting && (tray.hasTray() || process.platform === 'darwin')) {
|
||||||
// On Mac, closing the window just hides it
|
// On Mac, closing the window just hides it
|
||||||
// (this is generally how single-window Mac apps
|
// (this is generally how single-window Mac apps
|
||||||
// behave, eg. Mail.app)
|
// behave, eg. Mail.app)
|
||||||
|
@ -218,14 +289,8 @@ electron.app.on('ready', () => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
mainWindow.webContents.on('new-window', onWindowOrNavigate);
|
webContentsHandler(mainWindow.webContents);
|
||||||
mainWindow.webContents.on('will-navigate', onWindowOrNavigate);
|
mainWindowState.manage(mainWindow);
|
||||||
|
|
||||||
mainWindow.webContents.on('context-menu', function(ev, params) {
|
|
||||||
if (params.linkURL) {
|
|
||||||
onLinkContextMenu(ev, params);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
electron.app.on('window-all-closed', () => {
|
electron.app.on('window-all-closed', () => {
|
|
@ -16,30 +16,30 @@ limitations under the License.
|
||||||
|
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const spawn = require('child_process').spawn;
|
const spawn = require('child_process').spawn;
|
||||||
const app = require('electron').app;
|
const {app} = require('electron');
|
||||||
|
|
||||||
function run_update_exe(args, done) {
|
function runUpdateExe(args, done) {
|
||||||
// Invokes Squirrel's Update.exe which will do things for us like create shortcuts
|
// Invokes Squirrel's Update.exe which will do things for us like create shortcuts
|
||||||
// Note that there's an Update.exe in the app-x.x.x directory and one in the parent
|
// Note that there's an Update.exe in the app-x.x.x directory and one in the parent
|
||||||
// directory: we need to run the one in the parent directory, because it discovers
|
// directory: we need to run the one in the parent directory, because it discovers
|
||||||
// information about the app by inspecting the directory it's run from.
|
// information about the app by inspecting the directory it's run from.
|
||||||
const updateExe = path.resolve(path.dirname(process.execPath), '..', 'Update.exe');
|
const updateExe = path.resolve(path.dirname(process.execPath), '..', 'Update.exe');
|
||||||
console.log('Spawning `%s` with args `%s`', updateExe, args);
|
console.log(`Spawning '${updateExe}' with args '${args}'`);
|
||||||
spawn(updateExe, args, {
|
spawn(updateExe, args, {
|
||||||
detached: true
|
detached: true,
|
||||||
}).on('close', done);
|
}).on('close', done);
|
||||||
};
|
}
|
||||||
|
|
||||||
function check_squirrel_hooks() {
|
function checkSquirrelHooks() {
|
||||||
if (process.platform != 'win32') return false;
|
if (process.platform !== 'win32') return false;
|
||||||
|
|
||||||
const cmd = process.argv[1];
|
const cmd = process.argv[1];
|
||||||
const target = path.basename(process.execPath);
|
const target = path.basename(process.execPath);
|
||||||
if (cmd === '--squirrel-install' || cmd === '--squirrel-updated') {
|
if (cmd === '--squirrel-install' || cmd === '--squirrel-updated') {
|
||||||
run_update_exe(['--createShortcut=' + target + ''], app.quit);
|
runUpdateExe(['--createShortcut=' + target + ''], app.quit);
|
||||||
return true;
|
return true;
|
||||||
} else if (cmd === '--squirrel-uninstall') {
|
} else if (cmd === '--squirrel-uninstall') {
|
||||||
run_update_exe(['--removeShortcut=' + target + ''], app.quit);
|
runUpdateExe(['--removeShortcut=' + target + ''], app.quit);
|
||||||
return true;
|
return true;
|
||||||
} else if (cmd === '--squirrel-obsolete') {
|
} else if (cmd === '--squirrel-obsolete') {
|
||||||
app.quit();
|
app.quit();
|
||||||
|
@ -48,4 +48,4 @@ function check_squirrel_hooks() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = check_squirrel_hooks;
|
module.exports = checkSquirrelHooks;
|
94
electron_app/src/tray.js
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
/*
|
||||||
|
Copyright 2017 Karl Glatz <karl@glatz.biz>
|
||||||
|
Copyright 2017 OpenMarket Ltd
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
const {app, Tray, Menu, nativeImage} = require('electron');
|
||||||
|
const pngToIco = require('png-to-ico');
|
||||||
|
const path = require('path');
|
||||||
|
const fs = require('fs');
|
||||||
|
|
||||||
|
let trayIcon = null;
|
||||||
|
|
||||||
|
exports.hasTray = function hasTray() {
|
||||||
|
return (trayIcon !== null);
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.create = function(win, config) {
|
||||||
|
// no trays on darwin
|
||||||
|
if (process.platform === 'darwin' || trayIcon) return;
|
||||||
|
|
||||||
|
const toggleWin = function() {
|
||||||
|
if (win.isVisible() && !win.isMinimized()) {
|
||||||
|
win.hide();
|
||||||
|
} else {
|
||||||
|
if (win.isMinimized()) win.restore();
|
||||||
|
if (!win.isVisible()) win.show();
|
||||||
|
win.focus();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const contextMenu = Menu.buildFromTemplate([
|
||||||
|
{
|
||||||
|
label: `Show/Hide ${config.brand}`,
|
||||||
|
click: toggleWin,
|
||||||
|
},
|
||||||
|
{ type: 'separator' },
|
||||||
|
{
|
||||||
|
label: 'Quit',
|
||||||
|
click: function() {
|
||||||
|
app.quit();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
|
||||||
|
trayIcon = new Tray(config.icon_path);
|
||||||
|
trayIcon.setToolTip(config.brand);
|
||||||
|
trayIcon.setContextMenu(contextMenu);
|
||||||
|
trayIcon.on('click', toggleWin);
|
||||||
|
|
||||||
|
let lastFavicon = null;
|
||||||
|
win.webContents.on('page-favicon-updated', async function(ev, favicons) {
|
||||||
|
let newFavicon = config.icon_path;
|
||||||
|
if (favicons && favicons.length > 0 && favicons[0].startsWith('data:')) {
|
||||||
|
newFavicon = favicons[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
// No need to change, shortcut
|
||||||
|
if (newFavicon === lastFavicon) return;
|
||||||
|
lastFavicon = newFavicon;
|
||||||
|
|
||||||
|
// if its not default we have to construct into nativeImage
|
||||||
|
if (newFavicon !== config.icon_path) {
|
||||||
|
newFavicon = nativeImage.createFromDataURL(favicons[0]);
|
||||||
|
|
||||||
|
if (process.platform === 'win32') {
|
||||||
|
try {
|
||||||
|
const icoPath = path.join(app.getPath('temp'), 'win32_riot_icon.ico')
|
||||||
|
const icoBuf = await pngToIco(newFavicon.toPNG());
|
||||||
|
fs.writeFileSync(icoPath, icoBuf);
|
||||||
|
newFavicon = icoPath;
|
||||||
|
} catch (e) {console.error(e);}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
trayIcon.setImage(newFavicon);
|
||||||
|
win.setIcon(newFavicon);
|
||||||
|
});
|
||||||
|
|
||||||
|
win.webContents.on('page-title-updated', function(ev, title) {
|
||||||
|
trayIcon.setToolTip(title);
|
||||||
|
});
|
||||||
|
};
|
137
electron_app/src/vectormenu.js
Normal file
|
@ -0,0 +1,137 @@
|
||||||
|
/*
|
||||||
|
Copyright 2016 OpenMarket Ltd
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
const {app, shell, Menu} = require('electron');
|
||||||
|
|
||||||
|
// Menu template from http://electron.atom.io/docs/api/menu/, edited
|
||||||
|
const template = [
|
||||||
|
{
|
||||||
|
label: 'Edit',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'undo' },
|
||||||
|
{ role: 'redo' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'cut' },
|
||||||
|
{ role: 'copy' },
|
||||||
|
{ role: 'paste' },
|
||||||
|
{ role: 'pasteandmatchstyle' },
|
||||||
|
{ role: 'delete' },
|
||||||
|
{ role: 'selectall' },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'View',
|
||||||
|
submenu: [
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'resetzoom' },
|
||||||
|
{ role: 'zoomin' },
|
||||||
|
{ role: 'zoomout' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'togglefullscreen' },
|
||||||
|
{ role: 'toggledevtools' },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
role: 'window',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'minimize' },
|
||||||
|
{ role: 'close' },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
role: 'help',
|
||||||
|
submenu: [
|
||||||
|
{
|
||||||
|
label: 'riot.im',
|
||||||
|
click() { shell.openExternal('https://riot.im/'); },
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
// macOS has specific menu conventions...
|
||||||
|
if (process.platform === 'darwin') {
|
||||||
|
// first macOS menu is the name of the app
|
||||||
|
const name = app.getName();
|
||||||
|
template.unshift({
|
||||||
|
label: name,
|
||||||
|
submenu: [
|
||||||
|
{ role: 'about' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{
|
||||||
|
role: 'services',
|
||||||
|
submenu: [],
|
||||||
|
},
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'hide' },
|
||||||
|
{ role: 'hideothers' },
|
||||||
|
{ role: 'unhide' },
|
||||||
|
{ type: 'separator' },
|
||||||
|
{ role: 'quit' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
// Edit menu.
|
||||||
|
// This has a 'speech' section on macOS
|
||||||
|
template[1].submenu.push(
|
||||||
|
{ type: 'separator' },
|
||||||
|
{
|
||||||
|
label: 'Speech',
|
||||||
|
submenu: [
|
||||||
|
{ role: 'startspeaking' },
|
||||||
|
{ role: 'stopspeaking' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
// Window menu.
|
||||||
|
// This also has specific functionality on macOS
|
||||||
|
template[3].submenu = [
|
||||||
|
{
|
||||||
|
label: 'Close',
|
||||||
|
accelerator: 'CmdOrCtrl+W',
|
||||||
|
role: 'close',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Minimize',
|
||||||
|
accelerator: 'CmdOrCtrl+M',
|
||||||
|
role: 'minimize',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Zoom',
|
||||||
|
role: 'zoom',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'separator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Bring All to Front',
|
||||||
|
role: 'front',
|
||||||
|
},
|
||||||
|
];
|
||||||
|
} else {
|
||||||
|
template.unshift({
|
||||||
|
label: 'File',
|
||||||
|
submenu: [
|
||||||
|
// For some reason, 'about' does not seem to work on windows.
|
||||||
|
/*{
|
||||||
|
role: 'about'
|
||||||
|
},*/
|
||||||
|
{ role: 'quit' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Menu.buildFromTemplate(template);
|
||||||
|
|
122
electron_app/src/webcontents-handler.js
Normal file
|
@ -0,0 +1,122 @@
|
||||||
|
const {clipboard, nativeImage, Menu, MenuItem, shell} = require('electron');
|
||||||
|
const url = require('url');
|
||||||
|
|
||||||
|
const PERMITTED_URL_SCHEMES = [
|
||||||
|
'http:',
|
||||||
|
'https:',
|
||||||
|
'mailto:',
|
||||||
|
];
|
||||||
|
|
||||||
|
function safeOpenURL(target) {
|
||||||
|
// openExternal passes the target to open/start/xdg-open,
|
||||||
|
// so put fairly stringent limits on what can be opened
|
||||||
|
// (for instance, open /bin/sh does indeed open a terminal
|
||||||
|
// with a shell, albeit with no arguments)
|
||||||
|
const parsedUrl = url.parse(target);
|
||||||
|
if (PERMITTED_URL_SCHEMES.indexOf(parsedUrl.protocol) > -1) {
|
||||||
|
// explicitly use the URL re-assembled by the url library,
|
||||||
|
// so we know the url parser has understood all the parts
|
||||||
|
// of the input string
|
||||||
|
const newTarget = url.format(parsedUrl);
|
||||||
|
shell.openExternal(newTarget);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onWindowOrNavigate(ev, target) {
|
||||||
|
// always prevent the default: if something goes wrong,
|
||||||
|
// we don't want to end up opening it in the electron
|
||||||
|
// app, as we could end up opening any sort of random
|
||||||
|
// url in a window that has node scripting access.
|
||||||
|
ev.preventDefault();
|
||||||
|
safeOpenURL(target);
|
||||||
|
}
|
||||||
|
|
||||||
|
function onLinkContextMenu(ev, params) {
|
||||||
|
const url = params.linkURL || params.srcURL;
|
||||||
|
|
||||||
|
const popupMenu = new Menu();
|
||||||
|
popupMenu.append(new MenuItem({
|
||||||
|
label: url,
|
||||||
|
click() {
|
||||||
|
safeOpenURL(url);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
|
||||||
|
if (params.mediaType && params.mediaType === 'image' && !url.startsWith('file://')) {
|
||||||
|
popupMenu.append(new MenuItem({
|
||||||
|
label: 'Copy Image',
|
||||||
|
click() {
|
||||||
|
if (url.startsWith('data:')) {
|
||||||
|
clipboard.writeImage(nativeImage.createFromDataURL(url));
|
||||||
|
} else {
|
||||||
|
ev.sender.copyImageAt(params.x, params.y);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
popupMenu.append(new MenuItem({
|
||||||
|
label: 'Copy Link Address',
|
||||||
|
click() {
|
||||||
|
clipboard.writeText(url);
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
popupMenu.popup();
|
||||||
|
ev.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
function _CutCopyPasteSelectContextMenus(params) {
|
||||||
|
return [{
|
||||||
|
role: 'cut',
|
||||||
|
enabled: params.editFlags.canCut,
|
||||||
|
}, {
|
||||||
|
role: 'copy',
|
||||||
|
enabled: params.editFlags.canCopy,
|
||||||
|
}, {
|
||||||
|
role: 'paste',
|
||||||
|
enabled: params.editFlags.canPaste,
|
||||||
|
}, {
|
||||||
|
role: 'pasteandmatchstyle',
|
||||||
|
enabled: params.editFlags.canPaste,
|
||||||
|
}, {
|
||||||
|
role: 'selectall',
|
||||||
|
enabled: params.editFlags.canSelectAll,
|
||||||
|
}];
|
||||||
|
}
|
||||||
|
|
||||||
|
function onSelectedContextMenu(ev, params) {
|
||||||
|
const items = _CutCopyPasteSelectContextMenus(params);
|
||||||
|
const popupMenu = Menu.buildFromTemplate(items);
|
||||||
|
|
||||||
|
popupMenu.popup();
|
||||||
|
ev.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
function onEditableContextMenu(ev, params) {
|
||||||
|
const items = [
|
||||||
|
{ role: 'undo' },
|
||||||
|
{ role: 'redo', enabled: params.editFlags.canRedo },
|
||||||
|
{ type: 'separator' },
|
||||||
|
].concat(_CutCopyPasteSelectContextMenus(params));
|
||||||
|
|
||||||
|
const popupMenu = Menu.buildFromTemplate(items);
|
||||||
|
|
||||||
|
popupMenu.popup();
|
||||||
|
ev.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = (webContents) => {
|
||||||
|
webContents.on('new-window', onWindowOrNavigate);
|
||||||
|
webContents.on('will-navigate', onWindowOrNavigate);
|
||||||
|
|
||||||
|
webContents.on('context-menu', function(ev, params) {
|
||||||
|
if (params.linkURL || params.srcURL) {
|
||||||
|
onLinkContextMenu(ev, params);
|
||||||
|
} else if (params.selectionText) {
|
||||||
|
onSelectedContextMenu(ev, params);
|
||||||
|
} else if (params.isEditable) {
|
||||||
|
onEditableContextMenu(ev, params);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
|
@ -47,7 +47,6 @@ webpack_config.module.noParse.push(/sinon\/pkg\/sinon\.js$/);
|
||||||
webpack_config.resolve.alias['sinon'] = 'sinon/pkg/sinon.js';
|
webpack_config.resolve.alias['sinon'] = 'sinon/pkg/sinon.js';
|
||||||
|
|
||||||
webpack_config.resolve.root = [
|
webpack_config.resolve.root = [
|
||||||
path.resolve('./src'),
|
|
||||||
path.resolve('./test'),
|
path.resolve('./test'),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
63
package.json
|
@ -1,8 +1,8 @@
|
||||||
{
|
{
|
||||||
"name": "riot-web",
|
"name": "riot-web",
|
||||||
"productName": "Riot",
|
"productName": "Riot",
|
||||||
"main": "electron/src/electron-main.js",
|
"main": "electron_app/src/electron-main.js",
|
||||||
"version": "0.9.9",
|
"version": "0.11.4",
|
||||||
"description": "A feature-rich client for Matrix.org",
|
"description": "A feature-rich client for Matrix.org",
|
||||||
"author": "Vector Creations Ltd.",
|
"author": "Vector Creations Ltd.",
|
||||||
"repository": {
|
"repository": {
|
||||||
|
@ -27,23 +27,26 @@
|
||||||
"matrix-react-parent": "matrix-react-sdk",
|
"matrix-react-parent": "matrix-react-sdk",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"reskindex": "reskindex -h src/header",
|
"reskindex": "reskindex -h src/header",
|
||||||
|
"reskindex:watch": "reskindex -h src/header -w",
|
||||||
"build:res": "node scripts/copy-res.js",
|
"build:res": "node scripts/copy-res.js",
|
||||||
"build:modernizr": "modernizr -c .modernizr.json -d src/vector/modernizr.js",
|
"build:modernizr": "modernizr -c .modernizr.json -d src/vector/modernizr.js",
|
||||||
"build:compile": "babel --source-maps -d lib src",
|
"build:compile": "npm run reskindex && babel --source-maps -d lib src",
|
||||||
"build:bundle": "NODE_ENV=production webpack -p --progress",
|
"build:bundle": "cross-env NODE_ENV=production webpack -p --progress",
|
||||||
"build:bundle:dev": "webpack --optimize-occurence-order --progress",
|
"build:bundle:dev": "webpack --optimize-occurence-order --progress",
|
||||||
"build:electron": "npm run clean && npm run build && build -wml --ia32 --x64",
|
"build:electron": "npm run clean && npm run build && npm run install:electron && build -wml --ia32 --x64",
|
||||||
"build": "node scripts/babelcheck.js && npm run build:res && npm run build:bundle",
|
"build": "npm run reskindex && npm run build:res && npm run build:bundle",
|
||||||
"build:dev": "node scripts/babelcheck.js && npm run build:res && npm run build:bundle:dev",
|
"build:dev": "npm run reskindex && npm run build:res && npm run build:bundle:dev",
|
||||||
"dist": "scripts/package.sh",
|
"dist": "scripts/package.sh",
|
||||||
|
"install:electron": "install-app-deps",
|
||||||
|
"electron": "npm run install:electron && electron .",
|
||||||
"start:res": "node scripts/copy-res.js -w",
|
"start:res": "node scripts/copy-res.js -w",
|
||||||
"start:js": "webpack-dev-server --output-filename=bundles/_dev_/[name].js --output-chunk-file=bundles/_dev_/[name].js -w --progress",
|
"start:js": "webpack-dev-server --output-filename=bundles/_dev_/[name].js --output-chunk-file=bundles/_dev_/[name].js -w --progress",
|
||||||
"start:js:prod": "NODE_ENV=production webpack-dev-server -w --progress",
|
"start:js:prod": "cross-env NODE_ENV=production webpack-dev-server -w --progress",
|
||||||
"start": "node scripts/babelcheck.js && parallelshell \"npm run start:res\" \"npm run start:js\"",
|
"start": "parallelshell \"npm run reskindex:watch\" \"npm run start:res\" \"npm run start:js\"",
|
||||||
"start:prod": "parallelshell \"npm run start:res\" \"npm run start:js:prod\"",
|
"start:prod": "parallelshell \"npm run reskindex:watch\" \"npm run start:res\" \"npm run start:js:prod\"",
|
||||||
"lint": "eslint src/",
|
"lint": "eslint src/",
|
||||||
"lintall": "eslint src/ test/",
|
"lintall": "eslint src/ test/",
|
||||||
"clean": "rimraf lib webapp electron/dist",
|
"clean": "rimraf lib webapp electron_app/dist",
|
||||||
"prepublish": "npm run build:compile",
|
"prepublish": "npm run build:compile",
|
||||||
"test": "karma start --single-run=true --autoWatch=false --browsers PhantomJS --colors=false",
|
"test": "karma start --single-run=true --autoWatch=false --browsers PhantomJS --colors=false",
|
||||||
"test-multi": "karma start"
|
"test-multi": "karma start"
|
||||||
|
@ -56,15 +59,16 @@
|
||||||
"draft-js": "^0.8.1",
|
"draft-js": "^0.8.1",
|
||||||
"extract-text-webpack-plugin": "^0.9.1",
|
"extract-text-webpack-plugin": "^0.9.1",
|
||||||
"favico.js": "^0.3.10",
|
"favico.js": "^0.3.10",
|
||||||
"filesize": "^3.1.2",
|
"filesize": "3.5.6",
|
||||||
"flux": "~2.0.3",
|
"flux": "2.1.1",
|
||||||
"gemini-scrollbar": "matrix-org/gemini-scrollbar#b302279",
|
"gemini-scrollbar": "matrix-org/gemini-scrollbar#b302279",
|
||||||
"gfm.css": "^1.1.1",
|
"gfm.css": "^1.1.1",
|
||||||
"highlight.js": "^9.0.0",
|
"highlight.js": "^9.0.0",
|
||||||
"linkifyjs": "^2.1.3",
|
"linkifyjs": "^2.1.3",
|
||||||
"matrix-js-sdk": "0.7.7",
|
"matrix-js-sdk": "0.7.13",
|
||||||
"matrix-react-sdk": "0.8.8",
|
"matrix-react-sdk": "0.9.7",
|
||||||
"modernizr": "^3.1.0",
|
"modernizr": "^3.1.0",
|
||||||
|
"pako": "^1.0.5",
|
||||||
"q": "^1.4.1",
|
"q": "^1.4.1",
|
||||||
"react": "^15.4.0",
|
"react": "^15.4.0",
|
||||||
"react-dnd": "^2.1.4",
|
"react-dnd": "^2.1.4",
|
||||||
|
@ -72,8 +76,10 @@
|
||||||
"react-dom": "^15.4.0",
|
"react-dom": "^15.4.0",
|
||||||
"react-gemini-scrollbar": "matrix-org/react-gemini-scrollbar#5e97aef",
|
"react-gemini-scrollbar": "matrix-org/react-gemini-scrollbar#5e97aef",
|
||||||
"sanitize-html": "^1.11.1",
|
"sanitize-html": "^1.11.1",
|
||||||
|
"text-encoding-utf-8": "^1.0.1",
|
||||||
"ua-parser-js": "^0.7.10",
|
"ua-parser-js": "^0.7.10",
|
||||||
"url": "^0.11.0"
|
"url": "^0.11.0",
|
||||||
|
"velocity-vector": "vector-im/velocity#059e3b2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"autoprefixer": "^6.6.0",
|
"autoprefixer": "^6.6.0",
|
||||||
|
@ -93,12 +99,15 @@
|
||||||
"babel-preset-stage-2": "^6.17.0",
|
"babel-preset-stage-2": "^6.17.0",
|
||||||
"chokidar": "^1.6.1",
|
"chokidar": "^1.6.1",
|
||||||
"cpx": "^1.3.2",
|
"cpx": "^1.3.2",
|
||||||
|
"cross-env": "^4.0.0",
|
||||||
"css-raw-loader": "^0.1.1",
|
"css-raw-loader": "^0.1.1",
|
||||||
"electron-builder": "^11.2.4",
|
"electron-builder": "^11.2.4",
|
||||||
"electron-builder-squirrel-windows": "^11.2.1",
|
"electron-builder-squirrel-windows": "^11.2.1",
|
||||||
|
"electron-devtools-installer": "^2.2.0",
|
||||||
"emojione": "^2.2.7",
|
"emojione": "^2.2.7",
|
||||||
"eslint": "^3.14.0",
|
"eslint": "^3.14.0",
|
||||||
"eslint-config-google": "^0.7.1",
|
"eslint-config-google": "^0.7.1",
|
||||||
|
"eslint-plugin-babel": "^4.1.1",
|
||||||
"eslint-plugin-flowtype": "^2.30.0",
|
"eslint-plugin-flowtype": "^2.30.0",
|
||||||
"eslint-plugin-react": "^6.9.0",
|
"eslint-plugin-react": "^6.9.0",
|
||||||
"expect": "^1.16.0",
|
"expect": "^1.16.0",
|
||||||
|
@ -138,30 +147,34 @@
|
||||||
"build": {
|
"build": {
|
||||||
"appId": "im.riot.app",
|
"appId": "im.riot.app",
|
||||||
"category": "Network",
|
"category": "Network",
|
||||||
"electronVersion": "1.6.2",
|
"electronVersion": "1.6.8",
|
||||||
"//asar=false": "https://github.com/electron-userland/electron-builder/issues/675",
|
"//asar=false": "https://github.com/electron-userland/electron-builder/issues/675",
|
||||||
"asar": false,
|
"asar": false,
|
||||||
"dereference": true,
|
"dereference": true,
|
||||||
"//files": "We bundle everything, so we only need to include webapp/",
|
"//files": "We bundle everything, so we only need to include webapp/",
|
||||||
"files": [
|
"files": [
|
||||||
"electron/src/**",
|
"node_modules/**",
|
||||||
"electron/img/**",
|
"src/**",
|
||||||
"webapp/**",
|
"img/**"
|
||||||
"package.json"
|
],
|
||||||
|
"extraResources": [
|
||||||
|
"webapp/**/*"
|
||||||
],
|
],
|
||||||
"linux": {
|
"linux": {
|
||||||
"target": "deb",
|
"target": "deb",
|
||||||
|
"category": "Network;InstantMessaging;Chat",
|
||||||
"maintainer": "support@riot.im",
|
"maintainer": "support@riot.im",
|
||||||
"desktop": {
|
"desktop": {
|
||||||
"StartupWMClass": "riot-web"
|
"StartupWMClass": "riot"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"win": {
|
"win": {
|
||||||
"target": "squirrel"
|
"target": "squirrel"
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"directories": {
|
"directories": {
|
||||||
"buildResources": "electron/build",
|
"buildResources": "electron_app/build",
|
||||||
"output": "electron/dist"
|
"output": "electron_app/dist",
|
||||||
|
"app": "electron_app"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
31
release.sh
|
@ -1,4 +1,4 @@
|
||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# Script to perform a release of vector-web.
|
# Script to perform a release of vector-web.
|
||||||
#
|
#
|
||||||
|
@ -9,4 +9,33 @@ set -e
|
||||||
|
|
||||||
cd `dirname $0`
|
cd `dirname $0`
|
||||||
|
|
||||||
|
for i in matrix-js-sdk matrix-react-sdk
|
||||||
|
do
|
||||||
|
depver=`cat package.json | jq -r .dependencies.\"$i\"`
|
||||||
|
latestver=`npm show $i version`
|
||||||
|
if [ "$depver" != "$latestver" ]
|
||||||
|
then
|
||||||
|
echo "The latest version of $i is $latestver but package.json depends on $depver"
|
||||||
|
echo -n "Type 'Yes' to continue anyway: "
|
||||||
|
read resp
|
||||||
|
if [ "$resp" != "Yes" ]
|
||||||
|
then
|
||||||
|
echo "OK, never mind."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# bump Electron's package.json first
|
||||||
|
release="${1#v}"
|
||||||
|
tag="v${release}"
|
||||||
|
echo "electron npm version"
|
||||||
|
|
||||||
|
cd electron_app
|
||||||
|
npm version --no-git-tag-version "$release"
|
||||||
|
git commit package.json -m "$tag"
|
||||||
|
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
|
||||||
exec ./node_modules/matrix-js-sdk/release.sh -z "$@"
|
exec ./node_modules/matrix-js-sdk/release.sh -z "$@"
|
||||||
|
|
BIN
res/flags/AD.png
Normal file
After Width: | Height: | Size: 2.5 KiB |
BIN
res/flags/AE.png
Normal file
After Width: | Height: | Size: 1,015 B |
BIN
res/flags/AF.png
Normal file
After Width: | Height: | Size: 2.5 KiB |
BIN
res/flags/AG.png
Normal file
After Width: | Height: | Size: 4.1 KiB |
BIN
res/flags/AI.png
Normal file
After Width: | Height: | Size: 4.7 KiB |
BIN
res/flags/AL.png
Normal file
After Width: | Height: | Size: 3 KiB |
BIN
res/flags/AM.png
Normal file
After Width: | Height: | Size: 654 B |
BIN
res/flags/AO.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
res/flags/AQ.png
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
res/flags/AR.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
res/flags/AS.png
Normal file
After Width: | Height: | Size: 3.9 KiB |
BIN
res/flags/AT.png
Normal file
After Width: | Height: | Size: 655 B |
BIN
res/flags/AU.png
Normal file
After Width: | Height: | Size: 5.1 KiB |
BIN
res/flags/AW.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
res/flags/AX.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
res/flags/AZ.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
res/flags/BA.png
Normal file
After Width: | Height: | Size: 3 KiB |
BIN
res/flags/BB.png
Normal file
After Width: | Height: | Size: 2 KiB |
BIN
res/flags/BD.png
Normal file
After Width: | Height: | Size: 2.8 KiB |
BIN
res/flags/BE.png
Normal file
After Width: | Height: | Size: 558 B |
BIN
res/flags/BF.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
res/flags/BG.png
Normal file
After Width: | Height: | Size: 659 B |
BIN
res/flags/BH.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
BIN
res/flags/BI.png
Normal file
After Width: | Height: | Size: 5.5 KiB |
BIN
res/flags/BJ.png
Normal file
After Width: | Height: | Size: 811 B |
BIN
res/flags/BL.png
Normal file
After Width: | Height: | Size: 566 B |
BIN
res/flags/BM.png
Normal file
After Width: | Height: | Size: 5.2 KiB |
BIN
res/flags/BN.png
Normal file
After Width: | Height: | Size: 5.2 KiB |
BIN
res/flags/BO.png
Normal file
After Width: | Height: | Size: 668 B |
BIN
res/flags/BQ.png
Normal file
After Width: | Height: | Size: 672 B |
BIN
res/flags/BR.png
Normal file
After Width: | Height: | Size: 4.7 KiB |
BIN
res/flags/BS.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
BIN
res/flags/BT.png
Normal file
After Width: | Height: | Size: 4.8 KiB |
BIN
res/flags/BV.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
res/flags/BW.png
Normal file
After Width: | Height: | Size: 669 B |
BIN
res/flags/BY.png
Normal file
After Width: | Height: | Size: 2 KiB |
BIN
res/flags/BZ.png
Normal file
After Width: | Height: | Size: 5.2 KiB |
BIN
res/flags/CA.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
BIN
res/flags/CC.png
Normal file
After Width: | Height: | Size: 3.6 KiB |
BIN
res/flags/CD.png
Normal file
After Width: | Height: | Size: 3.6 KiB |
BIN
res/flags/CF.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
res/flags/CG.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
BIN
res/flags/CH.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
res/flags/CI.png
Normal file
After Width: | Height: | Size: 568 B |
BIN
res/flags/CK.png
Normal file
After Width: | Height: | Size: 5.9 KiB |
BIN
res/flags/CL.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
res/flags/CM.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
res/flags/CN.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
BIN
res/flags/CO.png
Normal file
After Width: | Height: | Size: 668 B |
BIN
res/flags/CR.png
Normal file
After Width: | Height: | Size: 785 B |
BIN
res/flags/CU.png
Normal file
After Width: | Height: | Size: 3 KiB |
BIN
res/flags/CV.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
res/flags/CW.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
res/flags/CX.png
Normal file
After Width: | Height: | Size: 5 KiB |
BIN
res/flags/CY.png
Normal file
After Width: | Height: | Size: 3.5 KiB |
BIN
res/flags/CZ.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
res/flags/DE.png
Normal file
After Width: | Height: | Size: 568 B |
BIN
res/flags/DJ.png
Normal file
After Width: | Height: | Size: 3.5 KiB |
BIN
res/flags/DK.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
BIN
res/flags/DM.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
res/flags/DO.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
res/flags/DZ.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
res/flags/EC.png
Normal file
After Width: | Height: | Size: 2.8 KiB |