matrix-react-sdk
Version:
SDK for matrix.org using React
130 lines (105 loc) • 14.2 kB
JavaScript
"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 _react = _interopRequireDefault(require("react"));
var _Dropdown = _interopRequireDefault(require("../../views/elements/Dropdown"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _PlatformPeg = _interopRequireDefault(require("../../../PlatformPeg"));
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _languageHandler = require("../../../languageHandler");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class;
function languageMatchesSearchQuery(query, language) {
if (language.label.toUpperCase().includes(query.toUpperCase())) return true;
if (language.value.toUpperCase() === query.toUpperCase()) return true;
return false;
}
let SpellCheckLanguagesDropdown = (_dec = (0, _replaceableComponent.replaceableComponent)("views.elements.SpellCheckLanguagesDropdown"), _dec(_class = class SpellCheckLanguagesDropdown extends _react.default.Component
/*:: <SpellCheckLanguagesDropdownIProps,
SpellCheckLanguagesDropdownIState>*/
{
constructor(props) {
super(props);
this._onSearchChange = this._onSearchChange.bind(this);
this.state = {
searchQuery: '',
languages: null
};
}
componentDidMount() {
const plaf = _PlatformPeg.default.get();
if (plaf) {
plaf.getAvailableSpellCheckLanguages().then(languages => {
languages.sort(function (a, b) {
if (a < b) return -1;
if (a > b) return 1;
return 0;
});
const langs = [];
languages.forEach(language => {
langs.push({
label: language,
value: language
});
});
this.setState({
languages: langs
});
}).catch(e => {
this.setState({
languages: ['en']
});
});
}
}
_onSearchChange(search) {
this.setState({
searchQuery: search
});
}
render() {
if (this.state.languages === null) {
const Spinner = sdk.getComponent('elements.Spinner');
return /*#__PURE__*/_react.default.createElement(Spinner, null);
}
let displayedLanguages;
if (this.state.searchQuery) {
displayedLanguages = this.state.languages.filter(lang => {
return languageMatchesSearchQuery(this.state.searchQuery, lang);
});
} else {
displayedLanguages = this.state.languages;
}
const options = displayedLanguages.map(language => {
return /*#__PURE__*/_react.default.createElement("div", {
key: language.value
}, language.label);
}); // default value here too, otherwise we need to handle null / undefined;
// values between mounting and the initial value propgating
let language = _SettingsStore.default.getValue("language", null,
/*excludeDefault:*/
true);
let value = null;
if (language) {
value = this.props.value || language;
} else {
language = navigator.language || navigator.userLanguage;
value = this.props.value || language;
}
return /*#__PURE__*/_react.default.createElement(_Dropdown.default, {
id: "mx_LanguageDropdown",
className: this.props.className,
onOptionChange: this.props.onOptionChange,
onSearchChange: this._onSearchChange,
searchEnabled: true,
value: value,
label: (0, _languageHandler._t)("Language Dropdown")
}, options);
}
}) || _class);
exports.default = SpellCheckLanguagesDropdown;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/elements/SpellCheckLanguagesDropdown.tsx"],"names":["languageMatchesSearchQuery","query","language","label","toUpperCase","includes","value","SpellCheckLanguagesDropdown","React","Component","constructor","props","_onSearchChange","bind","state","searchQuery","languages","componentDidMount","plaf","PlatformPeg","get","getAvailableSpellCheckLanguages","then","sort","a","b","langs","forEach","push","setState","catch","e","search","render","Spinner","sdk","getComponent","displayedLanguages","filter","lang","options","map","SettingsStore","getValue","navigator","userLanguage","className","onOptionChange"],"mappings":"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","sourcesContent":["/*\nCopyright 2021 Šimon Brandner <simon.bra.ag@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';\n\nimport Dropdown from \"../../views/elements/Dropdown\"\nimport * as sdk from '../../../index';\nimport PlatformPeg from \"../../../PlatformPeg\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { _t } from \"../../../languageHandler\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nfunction languageMatchesSearchQuery(query, language) {\n    if (language.label.toUpperCase().includes(query.toUpperCase())) return true;\n    if (language.value.toUpperCase() === query.toUpperCase()) return true;\n    return false;\n}\n\ninterface SpellCheckLanguagesDropdownIProps {\n    className: string,\n    value: string,\n    onOptionChange(language: string),\n}\n\ninterface SpellCheckLanguagesDropdownIState {\n    searchQuery: string,\n    languages: any,\n}\n\n@replaceableComponent(\"views.elements.SpellCheckLanguagesDropdown\")\nexport default class SpellCheckLanguagesDropdown extends React.Component<SpellCheckLanguagesDropdownIProps,\n                                                                         SpellCheckLanguagesDropdownIState> {\n    constructor(props) {\n        super(props);\n        this._onSearchChange = this._onSearchChange.bind(this);\n\n        this.state = {\n            searchQuery: '',\n            languages: null,\n        };\n    }\n\n    componentDidMount() {\n        const plaf = PlatformPeg.get();\n        if (plaf) {\n            plaf.getAvailableSpellCheckLanguages().then((languages) => {\n                languages.sort(function(a, b) {\n                    if (a < b) return -1;\n                    if (a > b) return 1;\n                    return 0;\n                });\n                const langs = [];\n                languages.forEach((language) => {\n                    langs.push({\n                        label: language,\n                        value: language,\n                    })\n                })\n                this.setState({languages: langs});\n            }).catch((e) => {\n                this.setState({languages: ['en']});\n            });\n        }\n    }\n\n    _onSearchChange(search) {\n        this.setState({\n            searchQuery: search,\n        });\n    }\n\n    render() {\n        if (this.state.languages === null) {\n            const Spinner = sdk.getComponent('elements.Spinner');\n            return <Spinner />;\n        }\n\n        let displayedLanguages;\n        if (this.state.searchQuery) {\n            displayedLanguages = this.state.languages.filter((lang) => {\n                return languageMatchesSearchQuery(this.state.searchQuery, lang);\n            });\n        } else {\n            displayedLanguages = this.state.languages;\n        }\n\n        const options = displayedLanguages.map((language) => {\n            return <div key={language.value}>\n                { language.label }\n            </div>;\n        });\n\n        // default value here too, otherwise we need to handle null / undefined;\n        // values between mounting and the initial value propgating\n        let language = SettingsStore.getValue(\"language\", null, /*excludeDefault:*/true);\n        let value = null;\n        if (language) {\n            value = this.props.value || language;\n        } else {\n            language = navigator.language || navigator.userLanguage;\n            value = this.props.value || language;\n        }\n\n        return <Dropdown\n            id=\"mx_LanguageDropdown\"\n            className={this.props.className}\n            onOptionChange={this.props.onOptionChange}\n            onSearchChange={this._onSearchChange}\n            searchEnabled={true}\n            value={value}\n            label={_t(\"Language Dropdown\")}>\n            { options }\n        </Dropdown>;\n    }\n}\n"]}