UNPKG

matrix-react-sdk

Version:
250 lines (211 loc) 35.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _languageHandler = require("../../../../../languageHandler"); var _LabelledToggleSwitch = _interopRequireDefault(require("../../../elements/LabelledToggleSwitch")); var _SettingsStore = _interopRequireDefault(require("../../../../../settings/SettingsStore")); var _Field = _interopRequireDefault(require("../../../elements/Field")); var sdk = _interopRequireWildcard(require("../../../../..")); var _PlatformPeg = _interopRequireDefault(require("../../../../../PlatformPeg")); var _SettingLevel = require("../../../../../settings/SettingLevel"); var _replaceableComponent = require("../../../../../utils/replaceableComponent"); var _dec, _class, _class2, _temp; let PreferencesUserSettingsTab = (_dec = (0, _replaceableComponent.replaceableComponent)("views.settings.tabs.user.PreferencesUserSettingsTab"), _dec(_class = (_temp = _class2 = class PreferencesUserSettingsTab extends _react.default.Component /*:: <{}, IState>*/ { constructor(props) { super(props); (0, _defineProperty2.default)(this, "onAutoLaunchChange", (checked /*: boolean*/ ) => { _PlatformPeg.default.get().setAutoLaunchEnabled(checked).then(() => this.setState({ autoLaunch: checked })); }); (0, _defineProperty2.default)(this, "onWarnBeforeExitChange", (checked /*: boolean*/ ) => { _PlatformPeg.default.get().setWarnBeforeExit(checked).then(() => this.setState({ warnBeforeExit: checked })); }); (0, _defineProperty2.default)(this, "onAlwaysShowMenuBarChange", (checked /*: boolean*/ ) => { _PlatformPeg.default.get().setAutoHideMenuBarEnabled(!checked).then(() => this.setState({ alwaysShowMenuBar: checked })); }); (0, _defineProperty2.default)(this, "onMinimizeToTrayChange", (checked /*: boolean*/ ) => { _PlatformPeg.default.get().setMinimizeToTrayEnabled(checked).then(() => this.setState({ minimizeToTray: checked })); }); (0, _defineProperty2.default)(this, "onAutocompleteDelayChange", (e /*: React.ChangeEvent<HTMLInputElement>*/ ) => { this.setState({ autocompleteDelay: e.target.value }); _SettingsStore.default.setValue("autocompleteDelay", null, _SettingLevel.SettingLevel.DEVICE, e.target.value); }); (0, _defineProperty2.default)(this, "onReadMarkerInViewThresholdMs", (e /*: React.ChangeEvent<HTMLInputElement>*/ ) => { this.setState({ readMarkerInViewThresholdMs: e.target.value }); _SettingsStore.default.setValue("readMarkerInViewThresholdMs", null, _SettingLevel.SettingLevel.DEVICE, e.target.value); }); (0, _defineProperty2.default)(this, "onReadMarkerOutOfViewThresholdMs", (e /*: React.ChangeEvent<HTMLInputElement>*/ ) => { this.setState({ readMarkerOutOfViewThresholdMs: e.target.value }); _SettingsStore.default.setValue("readMarkerOutOfViewThresholdMs", null, _SettingLevel.SettingLevel.DEVICE, e.target.value); }); this.state = { autoLaunch: false, autoLaunchSupported: false, warnBeforeExit: true, warnBeforeExitSupported: false, alwaysShowMenuBar: true, alwaysShowMenuBarSupported: false, minimizeToTray: true, minimizeToTraySupported: false, autocompleteDelay: _SettingsStore.default.getValueAt(_SettingLevel.SettingLevel.DEVICE, 'autocompleteDelay').toString(10), readMarkerInViewThresholdMs: _SettingsStore.default.getValueAt(_SettingLevel.SettingLevel.DEVICE, 'readMarkerInViewThresholdMs').toString(10), readMarkerOutOfViewThresholdMs: _SettingsStore.default.getValueAt(_SettingLevel.SettingLevel.DEVICE, 'readMarkerOutOfViewThresholdMs').toString(10) }; } async componentDidMount() { const platform = _PlatformPeg.default.get(); const autoLaunchSupported = await platform.supportsAutoLaunch(); let autoLaunch = false; if (autoLaunchSupported) { autoLaunch = await platform.getAutoLaunchEnabled(); } const warnBeforeExitSupported = await platform.supportsWarnBeforeExit(); let warnBeforeExit = false; if (warnBeforeExitSupported) { warnBeforeExit = await platform.shouldWarnBeforeExit(); } const alwaysShowMenuBarSupported = await platform.supportsAutoHideMenuBar(); let alwaysShowMenuBar = true; if (alwaysShowMenuBarSupported) { alwaysShowMenuBar = !(await platform.getAutoHideMenuBarEnabled()); } const minimizeToTraySupported = await platform.supportsMinimizeToTray(); let minimizeToTray = true; if (minimizeToTraySupported) { minimizeToTray = await platform.getMinimizeToTrayEnabled(); } this.setState({ autoLaunch, autoLaunchSupported, warnBeforeExit, warnBeforeExitSupported, alwaysShowMenuBarSupported, alwaysShowMenuBar, minimizeToTraySupported, minimizeToTray }); } renderGroup(settingIds /*: string[]*/ ) /*: React.ReactNodeArray*/ { const SettingsFlag = sdk.getComponent("views.elements.SettingsFlag"); return settingIds.filter(_SettingsStore.default.isEnabled).map(i => { return /*#__PURE__*/_react.default.createElement(SettingsFlag, { key: i, name: i, level: _SettingLevel.SettingLevel.ACCOUNT }); }); } render() { let autoLaunchOption = null; if (this.state.autoLaunchSupported) { autoLaunchOption = /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { value: this.state.autoLaunch, onChange: this.onAutoLaunchChange, label: (0, _languageHandler._t)('Start automatically after system login') }); } let warnBeforeExitOption = null; if (this.state.warnBeforeExitSupported) { warnBeforeExitOption = /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { value: this.state.warnBeforeExit, onChange: this.onWarnBeforeExitChange, label: (0, _languageHandler._t)('Warn before quitting') }); } let autoHideMenuOption = null; if (this.state.alwaysShowMenuBarSupported) { autoHideMenuOption = /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { value: this.state.alwaysShowMenuBar, onChange: this.onAlwaysShowMenuBarChange, label: (0, _languageHandler._t)('Always show the window menu bar') }); } let minimizeToTrayOption = null; if (this.state.minimizeToTraySupported) { minimizeToTrayOption = /*#__PURE__*/_react.default.createElement(_LabelledToggleSwitch.default, { value: this.state.minimizeToTray, onChange: this.onMinimizeToTrayChange, label: (0, _languageHandler._t)('Show tray icon and minimize window to it on close') }); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab mx_PreferencesUserSettingsTab" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab_heading" }, (0, _languageHandler._t)("Preferences")), /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab_section" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_SettingsTab_subheading" }, (0, _languageHandler._t)("Room list")), this.renderGroup(PreferencesUserSettingsTab.ROOM_LIST_SETTINGS)), /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab_section" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_SettingsTab_subheading" }, (0, _languageHandler._t)("Composer")), this.renderGroup(PreferencesUserSettingsTab.COMPOSER_SETTINGS)), /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab_section" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_SettingsTab_subheading" }, (0, _languageHandler._t)("Timeline")), this.renderGroup(PreferencesUserSettingsTab.TIMELINE_SETTINGS)), /*#__PURE__*/_react.default.createElement("div", { className: "mx_SettingsTab_section" }, /*#__PURE__*/_react.default.createElement("span", { className: "mx_SettingsTab_subheading" }, (0, _languageHandler._t)("General")), this.renderGroup(PreferencesUserSettingsTab.GENERAL_SETTINGS), minimizeToTrayOption, autoHideMenuOption, autoLaunchOption, warnBeforeExitOption, /*#__PURE__*/_react.default.createElement(_Field.default, { label: (0, _languageHandler._t)('Autocomplete delay (ms)'), type: "number", value: this.state.autocompleteDelay, onChange: this.onAutocompleteDelayChange }), /*#__PURE__*/_react.default.createElement(_Field.default, { label: (0, _languageHandler._t)('Read Marker lifetime (ms)'), type: "number", value: this.state.readMarkerInViewThresholdMs, onChange: this.onReadMarkerInViewThresholdMs }), /*#__PURE__*/_react.default.createElement(_Field.default, { label: (0, _languageHandler._t)('Read Marker off-screen lifetime (ms)'), type: "number", value: this.state.readMarkerOutOfViewThresholdMs, onChange: this.onReadMarkerOutOfViewThresholdMs }))); } }, (0, _defineProperty2.default)(_class2, "ROOM_LIST_SETTINGS", ['breadcrumbs']), (0, _defineProperty2.default)(_class2, "COMPOSER_SETTINGS", ['MessageComposerInput.autoReplaceEmoji', 'MessageComposerInput.suggestEmoji', 'sendTypingNotifications', 'MessageComposerInput.ctrlEnterToSend', 'MessageComposerInput.showStickersButton']), (0, _defineProperty2.default)(_class2, "TIMELINE_SETTINGS", ['showTypingNotifications', 'autoplayGifsAndVideos', 'urlPreviewsEnabled', 'TextualBody.enableBigEmoji', 'showReadReceipts', 'showTwelveHourTimestamps', 'alwaysShowTimestamps', 'showRedactions', 'enableSyntaxHighlightLanguageDetection', 'expandCodeByDefault', 'scrollToBottomOnMessageSent', 'showCodeLineNumbers', 'showJoinLeaves', 'showAvatarChanges', 'showDisplaynameChanges', 'showImages', 'showChatEffects', 'Pill.shouldShowPillAvatar', 'ctrlFForSearch']), (0, _defineProperty2.default)(_class2, "GENERAL_SETTINGS", ['TagPanel.enableTagPanel', 'promptBeforeInviteUnknownUsers' // Start automatically after startup (electron-only) // Autocomplete delay (niche text box) ]), _temp)) || _class); exports.default = PreferencesUserSettingsTab; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/components/views/settings/tabs/user/PreferencesUserSettingsTab.tsx"],"names":["PreferencesUserSettingsTab","React","Component","constructor","props","checked","PlatformPeg","get","setAutoLaunchEnabled","then","setState","autoLaunch","setWarnBeforeExit","warnBeforeExit","setAutoHideMenuBarEnabled","alwaysShowMenuBar","setMinimizeToTrayEnabled","minimizeToTray","e","autocompleteDelay","target","value","SettingsStore","setValue","SettingLevel","DEVICE","readMarkerInViewThresholdMs","readMarkerOutOfViewThresholdMs","state","autoLaunchSupported","warnBeforeExitSupported","alwaysShowMenuBarSupported","minimizeToTraySupported","getValueAt","toString","componentDidMount","platform","supportsAutoLaunch","getAutoLaunchEnabled","supportsWarnBeforeExit","shouldWarnBeforeExit","supportsAutoHideMenuBar","getAutoHideMenuBarEnabled","supportsMinimizeToTray","getMinimizeToTrayEnabled","renderGroup","settingIds","SettingsFlag","sdk","getComponent","filter","isEnabled","map","i","ACCOUNT","render","autoLaunchOption","onAutoLaunchChange","warnBeforeExitOption","onWarnBeforeExitChange","autoHideMenuOption","onAlwaysShowMenuBarChange","minimizeToTrayOption","onMinimizeToTrayChange","ROOM_LIST_SETTINGS","COMPOSER_SETTINGS","TIMELINE_SETTINGS","GENERAL_SETTINGS","onAutocompleteDelayChange","onReadMarkerInViewThresholdMs","onReadMarkerOutOfViewThresholdMs"],"mappings":";;;;;;;;;;;;;AAiBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;IAiBqBA,0B,WADpB,gDAAqB,qDAArB,C,mCAAD,MACqBA,0BADrB,SACwDC,eAAMC;AAD9D;AACoF;AA0ChFC,EAAAA,WAAW,CAACC,KAAD,EAAQ;AACf,UAAMA,KAAN;AADe,8DA4DU,CAACC;AAAD;AAAA,SAAsB;AAC/CC,2BAAYC,GAAZ,GAAkBC,oBAAlB,CAAuCH,OAAvC,EAAgDI,IAAhD,CAAqD,MAAM,KAAKC,QAAL,CAAc;AAACC,QAAAA,UAAU,EAAEN;AAAb,OAAd,CAA3D;AACH,KA9DkB;AAAA,kEAgEc,CAACA;AAAD;AAAA,SAAsB;AACnDC,2BAAYC,GAAZ,GAAkBK,iBAAlB,CAAoCP,OAApC,EAA6CI,IAA7C,CAAkD,MAAM,KAAKC,QAAL,CAAc;AAACG,QAAAA,cAAc,EAAER;AAAjB,OAAd,CAAxD;AACH,KAlEkB;AAAA,qEAoEiB,CAACA;AAAD;AAAA,SAAsB;AACtDC,2BAAYC,GAAZ,GAAkBO,yBAAlB,CAA4C,CAACT,OAA7C,EAAsDI,IAAtD,CAA2D,MAAM,KAAKC,QAAL,CAAc;AAACK,QAAAA,iBAAiB,EAAEV;AAApB,OAAd,CAAjE;AACH,KAtEkB;AAAA,kEAwEc,CAACA;AAAD;AAAA,SAAsB;AACnDC,2BAAYC,GAAZ,GAAkBS,wBAAlB,CAA2CX,OAA3C,EAAoDI,IAApD,CAAyD,MAAM,KAAKC,QAAL,CAAc;AAACO,QAAAA,cAAc,EAAEZ;AAAjB,OAAd,CAA/D;AACH,KA1EkB;AAAA,qEA4EiB,CAACa;AAAD;AAAA,SAA4C;AAC5E,WAAKR,QAAL,CAAc;AAACS,QAAAA,iBAAiB,EAAED,CAAC,CAACE,MAAF,CAASC;AAA7B,OAAd;;AACAC,6BAAcC,QAAd,CAAuB,mBAAvB,EAA4C,IAA5C,EAAkDC,2BAAaC,MAA/D,EAAuEP,CAAC,CAACE,MAAF,CAASC,KAAhF;AACH,KA/EkB;AAAA,yEAiFqB,CAACH;AAAD;AAAA,SAA4C;AAChF,WAAKR,QAAL,CAAc;AAACgB,QAAAA,2BAA2B,EAAER,CAAC,CAACE,MAAF,CAASC;AAAvC,OAAd;;AACAC,6BAAcC,QAAd,CAAuB,6BAAvB,EAAsD,IAAtD,EAA4DC,2BAAaC,MAAzE,EAAiFP,CAAC,CAACE,MAAF,CAASC,KAA1F;AACH,KApFkB;AAAA,4EAsFwB,CAACH;AAAD;AAAA,SAA4C;AACnF,WAAKR,QAAL,CAAc;AAACiB,QAAAA,8BAA8B,EAAET,CAAC,CAACE,MAAF,CAASC;AAA1C,OAAd;;AACAC,6BAAcC,QAAd,CAAuB,gCAAvB,EAAyD,IAAzD,EAA+DC,2BAAaC,MAA5E,EAAoFP,CAAC,CAACE,MAAF,CAASC,KAA7F;AACH,KAzFkB;AAGf,SAAKO,KAAL,GAAa;AACTjB,MAAAA,UAAU,EAAE,KADH;AAETkB,MAAAA,mBAAmB,EAAE,KAFZ;AAGThB,MAAAA,cAAc,EAAE,IAHP;AAITiB,MAAAA,uBAAuB,EAAE,KAJhB;AAKTf,MAAAA,iBAAiB,EAAE,IALV;AAMTgB,MAAAA,0BAA0B,EAAE,KANnB;AAOTd,MAAAA,cAAc,EAAE,IAPP;AAQTe,MAAAA,uBAAuB,EAAE,KARhB;AASTb,MAAAA,iBAAiB,EACbG,uBAAcW,UAAd,CAAyBT,2BAAaC,MAAtC,EAA8C,mBAA9C,EAAmES,QAAnE,CAA4E,EAA5E,CAVK;AAWTR,MAAAA,2BAA2B,EACvBJ,uBAAcW,UAAd,CAAyBT,2BAAaC,MAAtC,EAA8C,6BAA9C,EAA6ES,QAA7E,CAAsF,EAAtF,CAZK;AAaTP,MAAAA,8BAA8B,EAC1BL,uBAAcW,UAAd,CAAyBT,2BAAaC,MAAtC,EAA8C,gCAA9C,EAAgFS,QAAhF,CAAyF,EAAzF;AAdK,KAAb;AAgBH;;AAED,QAAMC,iBAAN,GAA0B;AACtB,UAAMC,QAAQ,GAAG9B,qBAAYC,GAAZ,EAAjB;;AAEA,UAAMsB,mBAAmB,GAAG,MAAMO,QAAQ,CAACC,kBAAT,EAAlC;AACA,QAAI1B,UAAU,GAAG,KAAjB;;AACA,QAAIkB,mBAAJ,EAAyB;AACrBlB,MAAAA,UAAU,GAAG,MAAMyB,QAAQ,CAACE,oBAAT,EAAnB;AACH;;AAED,UAAMR,uBAAuB,GAAG,MAAMM,QAAQ,CAACG,sBAAT,EAAtC;AACA,QAAI1B,cAAc,GAAG,KAArB;;AACA,QAAIiB,uBAAJ,EAA6B;AACzBjB,MAAAA,cAAc,GAAG,MAAMuB,QAAQ,CAACI,oBAAT,EAAvB;AACH;;AAED,UAAMT,0BAA0B,GAAG,MAAMK,QAAQ,CAACK,uBAAT,EAAzC;AACA,QAAI1B,iBAAiB,GAAG,IAAxB;;AACA,QAAIgB,0BAAJ,EAAgC;AAC5BhB,MAAAA,iBAAiB,GAAG,EAAC,MAAMqB,QAAQ,CAACM,yBAAT,EAAP,CAApB;AACH;;AAED,UAAMV,uBAAuB,GAAG,MAAMI,QAAQ,CAACO,sBAAT,EAAtC;AACA,QAAI1B,cAAc,GAAG,IAArB;;AACA,QAAIe,uBAAJ,EAA6B;AACzBf,MAAAA,cAAc,GAAG,MAAMmB,QAAQ,CAACQ,wBAAT,EAAvB;AACH;;AAED,SAAKlC,QAAL,CAAc;AACVC,MAAAA,UADU;AAEVkB,MAAAA,mBAFU;AAGVhB,MAAAA,cAHU;AAIViB,MAAAA,uBAJU;AAKVC,MAAAA,0BALU;AAMVhB,MAAAA,iBANU;AAOViB,MAAAA,uBAPU;AAQVf,MAAAA;AARU,KAAd;AAUH;;AAiCO4B,EAAAA,WAAR,CAAoBC;AAApB;AAAA;AAAA;AAAgE;AAC5D,UAAMC,YAAY,GAAGC,GAAG,CAACC,YAAJ,CAAiB,6BAAjB,CAArB;AACA,WAAOH,UAAU,CAACI,MAAX,CAAkB5B,uBAAc6B,SAAhC,EAA2CC,GAA3C,CAA+CC,CAAC,IAAI;AACvD,0BAAO,6BAAC,YAAD;AAAc,QAAA,GAAG,EAAEA,CAAnB;AAAsB,QAAA,IAAI,EAAEA,CAA5B;AAA+B,QAAA,KAAK,EAAE7B,2BAAa8B;AAAnD,QAAP;AACH,KAFM,CAAP;AAGH;;AAEDC,EAAAA,MAAM,GAAG;AACL,QAAIC,gBAAgB,GAAG,IAAvB;;AACA,QAAI,KAAK5B,KAAL,CAAWC,mBAAf,EAAoC;AAChC2B,MAAAA,gBAAgB,gBAAG,6BAAC,6BAAD;AACf,QAAA,KAAK,EAAE,KAAK5B,KAAL,CAAWjB,UADH;AAEf,QAAA,QAAQ,EAAE,KAAK8C,kBAFA;AAGf,QAAA,KAAK,EAAE,yBAAG,wCAAH;AAHQ,QAAnB;AAIH;;AAED,QAAIC,oBAAoB,GAAG,IAA3B;;AACA,QAAI,KAAK9B,KAAL,CAAWE,uBAAf,EAAwC;AACpC4B,MAAAA,oBAAoB,gBAAG,6BAAC,6BAAD;AACnB,QAAA,KAAK,EAAE,KAAK9B,KAAL,CAAWf,cADC;AAEnB,QAAA,QAAQ,EAAE,KAAK8C,sBAFI;AAGnB,QAAA,KAAK,EAAE,yBAAG,sBAAH;AAHY,QAAvB;AAIH;;AAED,QAAIC,kBAAkB,GAAG,IAAzB;;AACA,QAAI,KAAKhC,KAAL,CAAWG,0BAAf,EAA2C;AACvC6B,MAAAA,kBAAkB,gBAAG,6BAAC,6BAAD;AACjB,QAAA,KAAK,EAAE,KAAKhC,KAAL,CAAWb,iBADD;AAEjB,QAAA,QAAQ,EAAE,KAAK8C,yBAFE;AAGjB,QAAA,KAAK,EAAE,yBAAG,iCAAH;AAHU,QAArB;AAIH;;AAED,QAAIC,oBAAoB,GAAG,IAA3B;;AACA,QAAI,KAAKlC,KAAL,CAAWI,uBAAf,EAAwC;AACpC8B,MAAAA,oBAAoB,gBAAG,6BAAC,6BAAD;AACnB,QAAA,KAAK,EAAE,KAAKlC,KAAL,CAAWX,cADC;AAEnB,QAAA,QAAQ,EAAE,KAAK8C,sBAFI;AAGnB,QAAA,KAAK,EAAE,yBAAG,mDAAH;AAHY,QAAvB;AAIH;;AAED,wBACI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAK,MAAA,SAAS,EAAC;AAAf,OAAyC,yBAAG,aAAH,CAAzC,CADJ,eAGI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAM,MAAA,SAAS,EAAC;AAAhB,OAA6C,yBAAG,WAAH,CAA7C,CADJ,EAEK,KAAKlB,WAAL,CAAiB7C,0BAA0B,CAACgE,kBAA5C,CAFL,CAHJ,eAQI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAM,MAAA,SAAS,EAAC;AAAhB,OAA6C,yBAAG,UAAH,CAA7C,CADJ,EAEK,KAAKnB,WAAL,CAAiB7C,0BAA0B,CAACiE,iBAA5C,CAFL,CARJ,eAaI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAM,MAAA,SAAS,EAAC;AAAhB,OAA6C,yBAAG,UAAH,CAA7C,CADJ,EAEK,KAAKpB,WAAL,CAAiB7C,0BAA0B,CAACkE,iBAA5C,CAFL,CAbJ,eAkBI;AAAK,MAAA,SAAS,EAAC;AAAf,oBACI;AAAM,MAAA,SAAS,EAAC;AAAhB,OAA6C,yBAAG,SAAH,CAA7C,CADJ,EAEK,KAAKrB,WAAL,CAAiB7C,0BAA0B,CAACmE,gBAA5C,CAFL,EAGKL,oBAHL,EAIKF,kBAJL,EAKKJ,gBALL,EAMKE,oBANL,eAOI,6BAAC,cAAD;AACI,MAAA,KAAK,EAAE,yBAAG,yBAAH,CADX;AAEI,MAAA,IAAI,EAAC,QAFT;AAGI,MAAA,KAAK,EAAE,KAAK9B,KAAL,CAAWT,iBAHtB;AAII,MAAA,QAAQ,EAAE,KAAKiD;AAJnB,MAPJ,eAYI,6BAAC,cAAD;AACI,MAAA,KAAK,EAAE,yBAAG,2BAAH,CADX;AAEI,MAAA,IAAI,EAAC,QAFT;AAGI,MAAA,KAAK,EAAE,KAAKxC,KAAL,CAAWF,2BAHtB;AAII,MAAA,QAAQ,EAAE,KAAK2C;AAJnB,MAZJ,eAiBI,6BAAC,cAAD;AACI,MAAA,KAAK,EAAE,yBAAG,sCAAH,CADX;AAEI,MAAA,IAAI,EAAC,QAFT;AAGI,MAAA,KAAK,EAAE,KAAKzC,KAAL,CAAWD,8BAHtB;AAII,MAAA,QAAQ,EAAE,KAAK2C;AAJnB,MAjBJ,CAlBJ,CADJ;AA4CH;;AAzN+E,C,+DACpD,CACxB,aADwB,C,+DAID,CACvB,uCADuB,EAEvB,mCAFuB,EAGvB,yBAHuB,EAIvB,sCAJuB,EAKvB,yCALuB,C,+DAQA,CACvB,yBADuB,EAEvB,uBAFuB,EAGvB,oBAHuB,EAIvB,4BAJuB,EAKvB,kBALuB,EAMvB,0BANuB,EAOvB,sBAPuB,EAQvB,gBARuB,EASvB,wCATuB,EAUvB,qBAVuB,EAWvB,6BAXuB,EAYvB,qBAZuB,EAavB,gBAbuB,EAcvB,mBAduB,EAevB,wBAfuB,EAgBvB,YAhBuB,EAiBvB,iBAjBuB,EAkBvB,2BAlBuB,EAmBvB,gBAnBuB,C,8DAsBD,CACtB,yBADsB,EAEtB,gCAFsB,CAGtB;AACA;AAJsB,C","sourcesContent":["/*\nCopyright 2019-2021 The Matrix.org Foundation C.I.C.\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from 'react';\nimport {_t} from \"../../../../../languageHandler\";\nimport LabelledToggleSwitch from \"../../../elements/LabelledToggleSwitch\";\nimport SettingsStore from \"../../../../../settings/SettingsStore\";\nimport Field from \"../../../elements/Field\";\nimport * as sdk from \"../../../../..\";\nimport PlatformPeg from \"../../../../../PlatformPeg\";\nimport {SettingLevel} from \"../../../../../settings/SettingLevel\";\nimport { replaceableComponent } from \"../../../../../utils/replaceableComponent\";\n\ninterface IState {\n    autoLaunch: boolean;\n    autoLaunchSupported: boolean;\n    warnBeforeExit: boolean;\n    warnBeforeExitSupported: boolean;\n    alwaysShowMenuBarSupported: boolean;\n    alwaysShowMenuBar: boolean;\n    minimizeToTraySupported: boolean;\n    minimizeToTray: boolean;\n    autocompleteDelay: string;\n    readMarkerInViewThresholdMs: string;\n    readMarkerOutOfViewThresholdMs: string;\n}\n\n@replaceableComponent(\"views.settings.tabs.user.PreferencesUserSettingsTab\")\nexport default class PreferencesUserSettingsTab extends React.Component<{}, IState> {\n    static ROOM_LIST_SETTINGS = [\n        'breadcrumbs',\n    ];\n\n    static COMPOSER_SETTINGS = [\n        'MessageComposerInput.autoReplaceEmoji',\n        'MessageComposerInput.suggestEmoji',\n        'sendTypingNotifications',\n        'MessageComposerInput.ctrlEnterToSend',\n        'MessageComposerInput.showStickersButton',\n    ];\n\n    static TIMELINE_SETTINGS = [\n        'showTypingNotifications',\n        'autoplayGifsAndVideos',\n        'urlPreviewsEnabled',\n        'TextualBody.enableBigEmoji',\n        'showReadReceipts',\n        'showTwelveHourTimestamps',\n        'alwaysShowTimestamps',\n        'showRedactions',\n        'enableSyntaxHighlightLanguageDetection',\n        'expandCodeByDefault',\n        'scrollToBottomOnMessageSent',\n        'showCodeLineNumbers',\n        'showJoinLeaves',\n        'showAvatarChanges',\n        'showDisplaynameChanges',\n        'showImages',\n        'showChatEffects',\n        'Pill.shouldShowPillAvatar',\n        'ctrlFForSearch',\n    ];\n\n    static GENERAL_SETTINGS = [\n        'TagPanel.enableTagPanel',\n        'promptBeforeInviteUnknownUsers',\n        // Start automatically after startup (electron-only)\n        // Autocomplete delay (niche text box)\n    ];\n\n    constructor(props) {\n        super(props);\n\n        this.state = {\n            autoLaunch: false,\n            autoLaunchSupported: false,\n            warnBeforeExit: true,\n            warnBeforeExitSupported: false,\n            alwaysShowMenuBar: true,\n            alwaysShowMenuBarSupported: false,\n            minimizeToTray: true,\n            minimizeToTraySupported: false,\n            autocompleteDelay:\n                SettingsStore.getValueAt(SettingLevel.DEVICE, 'autocompleteDelay').toString(10),\n            readMarkerInViewThresholdMs:\n                SettingsStore.getValueAt(SettingLevel.DEVICE, 'readMarkerInViewThresholdMs').toString(10),\n            readMarkerOutOfViewThresholdMs:\n                SettingsStore.getValueAt(SettingLevel.DEVICE, 'readMarkerOutOfViewThresholdMs').toString(10),\n        };\n    }\n\n    async componentDidMount() {\n        const platform = PlatformPeg.get();\n\n        const autoLaunchSupported = await platform.supportsAutoLaunch();\n        let autoLaunch = false;\n        if (autoLaunchSupported) {\n            autoLaunch = await platform.getAutoLaunchEnabled();\n        }\n\n        const warnBeforeExitSupported = await platform.supportsWarnBeforeExit();\n        let warnBeforeExit = false;\n        if (warnBeforeExitSupported) {\n            warnBeforeExit = await platform.shouldWarnBeforeExit();\n        }\n\n        const alwaysShowMenuBarSupported = await platform.supportsAutoHideMenuBar();\n        let alwaysShowMenuBar = true;\n        if (alwaysShowMenuBarSupported) {\n            alwaysShowMenuBar = !await platform.getAutoHideMenuBarEnabled();\n        }\n\n        const minimizeToTraySupported = await platform.supportsMinimizeToTray();\n        let minimizeToTray = true;\n        if (minimizeToTraySupported) {\n            minimizeToTray = await platform.getMinimizeToTrayEnabled();\n        }\n\n        this.setState({\n            autoLaunch,\n            autoLaunchSupported,\n            warnBeforeExit,\n            warnBeforeExitSupported,\n            alwaysShowMenuBarSupported,\n            alwaysShowMenuBar,\n            minimizeToTraySupported,\n            minimizeToTray,\n        });\n    }\n\n    private onAutoLaunchChange = (checked: boolean) => {\n        PlatformPeg.get().setAutoLaunchEnabled(checked).then(() => this.setState({autoLaunch: checked}));\n    };\n\n    private onWarnBeforeExitChange = (checked: boolean) => {\n        PlatformPeg.get().setWarnBeforeExit(checked).then(() => this.setState({warnBeforeExit: checked}));\n    }\n\n    private onAlwaysShowMenuBarChange = (checked: boolean) => {\n        PlatformPeg.get().setAutoHideMenuBarEnabled(!checked).then(() => this.setState({alwaysShowMenuBar: checked}));\n    };\n\n    private onMinimizeToTrayChange = (checked: boolean) => {\n        PlatformPeg.get().setMinimizeToTrayEnabled(checked).then(() => this.setState({minimizeToTray: checked}));\n    };\n\n    private onAutocompleteDelayChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n        this.setState({autocompleteDelay: e.target.value});\n        SettingsStore.setValue(\"autocompleteDelay\", null, SettingLevel.DEVICE, e.target.value);\n    };\n\n    private onReadMarkerInViewThresholdMs = (e: React.ChangeEvent<HTMLInputElement>) => {\n        this.setState({readMarkerInViewThresholdMs: e.target.value});\n        SettingsStore.setValue(\"readMarkerInViewThresholdMs\", null, SettingLevel.DEVICE, e.target.value);\n    };\n\n    private onReadMarkerOutOfViewThresholdMs = (e: React.ChangeEvent<HTMLInputElement>) => {\n        this.setState({readMarkerOutOfViewThresholdMs: e.target.value});\n        SettingsStore.setValue(\"readMarkerOutOfViewThresholdMs\", null, SettingLevel.DEVICE, e.target.value);\n    };\n\n    private renderGroup(settingIds: string[]): React.ReactNodeArray {\n        const SettingsFlag = sdk.getComponent(\"views.elements.SettingsFlag\");\n        return settingIds.filter(SettingsStore.isEnabled).map(i => {\n            return <SettingsFlag key={i} name={i} level={SettingLevel.ACCOUNT} />;\n        });\n    }\n\n    render() {\n        let autoLaunchOption = null;\n        if (this.state.autoLaunchSupported) {\n            autoLaunchOption = <LabelledToggleSwitch\n                value={this.state.autoLaunch}\n                onChange={this.onAutoLaunchChange}\n                label={_t('Start automatically after system login')} />;\n        }\n\n        let warnBeforeExitOption = null;\n        if (this.state.warnBeforeExitSupported) {\n            warnBeforeExitOption = <LabelledToggleSwitch\n                value={this.state.warnBeforeExit}\n                onChange={this.onWarnBeforeExitChange}\n                label={_t('Warn before quitting')} />;\n        }\n\n        let autoHideMenuOption = null;\n        if (this.state.alwaysShowMenuBarSupported) {\n            autoHideMenuOption = <LabelledToggleSwitch\n                value={this.state.alwaysShowMenuBar}\n                onChange={this.onAlwaysShowMenuBarChange}\n                label={_t('Always show the window menu bar')} />;\n        }\n\n        let minimizeToTrayOption = null;\n        if (this.state.minimizeToTraySupported) {\n            minimizeToTrayOption = <LabelledToggleSwitch\n                value={this.state.minimizeToTray}\n                onChange={this.onMinimizeToTrayChange}\n                label={_t('Show tray icon and minimize window to it on close')} />;\n        }\n\n        return (\n            <div className=\"mx_SettingsTab mx_PreferencesUserSettingsTab\">\n                <div className=\"mx_SettingsTab_heading\">{_t(\"Preferences\")}</div>\n\n                <div className=\"mx_SettingsTab_section\">\n                    <span className=\"mx_SettingsTab_subheading\">{_t(\"Room list\")}</span>\n                    {this.renderGroup(PreferencesUserSettingsTab.ROOM_LIST_SETTINGS)}\n                </div>\n\n                <div className=\"mx_SettingsTab_section\">\n                    <span className=\"mx_SettingsTab_subheading\">{_t(\"Composer\")}</span>\n                    {this.renderGroup(PreferencesUserSettingsTab.COMPOSER_SETTINGS)}\n                </div>\n\n                <div className=\"mx_SettingsTab_section\">\n                    <span className=\"mx_SettingsTab_subheading\">{_t(\"Timeline\")}</span>\n                    {this.renderGroup(PreferencesUserSettingsTab.TIMELINE_SETTINGS)}\n                </div>\n\n                <div className=\"mx_SettingsTab_section\">\n                    <span className=\"mx_SettingsTab_subheading\">{_t(\"General\")}</span>\n                    {this.renderGroup(PreferencesUserSettingsTab.GENERAL_SETTINGS)}\n                    {minimizeToTrayOption}\n                    {autoHideMenuOption}\n                    {autoLaunchOption}\n                    {warnBeforeExitOption}\n                    <Field\n                        label={_t('Autocomplete delay (ms)')}\n                        type='number'\n                        value={this.state.autocompleteDelay}\n                        onChange={this.onAutocompleteDelayChange} />\n                    <Field\n                        label={_t('Read Marker lifetime (ms)')}\n                        type='number'\n                        value={this.state.readMarkerInViewThresholdMs}\n                        onChange={this.onReadMarkerInViewThresholdMs} />\n                    <Field\n                        label={_t('Read Marker off-screen lifetime (ms)')}\n                        type='number'\n                        value={this.state.readMarkerOutOfViewThresholdMs}\n                        onChange={this.onReadMarkerOutOfViewThresholdMs} />\n                </div>\n            </div>\n        );\n    }\n}\n"]}