matrix-react-sdk
Version:
SDK for matrix.org using React
114 lines (110 loc) • 15.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireDefault(require("react"));
var _Dropdown = _interopRequireDefault(require("../../views/elements/Dropdown"));
var _PlatformPeg = _interopRequireDefault(require("../../../PlatformPeg"));
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _languageHandler = require("../../../languageHandler");
var _Spinner = _interopRequireDefault(require("./Spinner"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
function languageMatchesSearchQuery(query, language) {
if (language.label.toUpperCase().includes(query.toUpperCase())) return true;
if (language.value.toUpperCase() === query.toUpperCase()) return true;
return false;
}
class SpellCheckLanguagesDropdown extends _react.default.Component {
constructor(props) {
super(props);
this.onSearchChange = this.onSearchChange.bind(this);
this.state = {
searchQuery: ""
};
}
componentDidMount() {
const plaf = _PlatformPeg.default.get();
if (plaf) {
const languageNames = new Intl.DisplayNames([(0, _languageHandler.getUserLanguage)()], {
type: "language",
style: "short"
});
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: languageNames.of(language),
value: language
});
});
this.setState({
languages: langs
});
}).catch(e => {
this.setState({
languages: [{
value: "en",
label: languageNames.of("en")
}]
});
});
}
}
onSearchChange(searchQuery) {
this.setState({
searchQuery
});
}
render() {
if (!this.state.languages) {
return /*#__PURE__*/_react.default.createElement(_Spinner.default, 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 propagating
let language = _SettingsStore.default.getValue("language", null, /*excludeDefault:*/true);
let value;
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_label"),
placeholder: (0, _languageHandler._t)("settings|general|spell_check_locale_placeholder")
}, options);
}
}
exports.default = SpellCheckLanguagesDropdown;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Dropdown","_PlatformPeg","_SettingsStore","_languageHandler","_Spinner","languageMatchesSearchQuery","query","language","label","toUpperCase","includes","value","SpellCheckLanguagesDropdown","React","Component","constructor","props","onSearchChange","bind","state","searchQuery","componentDidMount","plaf","PlatformPeg","get","languageNames","Intl","DisplayNames","getUserLanguage","type","style","getAvailableSpellCheckLanguages","then","languages","sort","a","b","langs","forEach","push","of","setState","catch","e","render","default","createElement","displayedLanguages","filter","lang","options","map","key","SettingsStore","getValue","navigator","userLanguage","id","className","onOptionChange","searchEnabled","_t","placeholder","exports"],"sources":["../../../../src/components/views/elements/SpellCheckLanguagesDropdown.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 Šimon Brandner <simon.bra.ag@gmail.com>\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { ReactElement } from \"react\";\n\nimport Dropdown from \"../../views/elements/Dropdown\";\nimport PlatformPeg from \"../../../PlatformPeg\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport { _t, getUserLanguage } from \"../../../languageHandler\";\nimport Spinner from \"./Spinner\";\nimport { NonEmptyArray } from \"../../../@types/common\";\n\ntype Languages = {\n    value: string;\n    label: string; // translated\n}[];\nfunction languageMatchesSearchQuery(query: string, language: Languages[0]): boolean {\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): void;\n}\n\ninterface SpellCheckLanguagesDropdownIState {\n    searchQuery: string;\n    languages?: Languages;\n}\n\nexport default class SpellCheckLanguagesDropdown extends React.Component<\n    SpellCheckLanguagesDropdownIProps,\n    SpellCheckLanguagesDropdownIState\n> {\n    public constructor(props: SpellCheckLanguagesDropdownIProps) {\n        super(props);\n        this.onSearchChange = this.onSearchChange.bind(this);\n\n        this.state = {\n            searchQuery: \"\",\n        };\n    }\n\n    public componentDidMount(): void {\n        const plaf = PlatformPeg.get();\n        if (plaf) {\n            const languageNames = new Intl.DisplayNames([getUserLanguage()], { type: \"language\", style: \"short\" });\n            plaf\n                .getAvailableSpellCheckLanguages()\n                ?.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: Languages = [];\n                    languages.forEach((language) => {\n                        langs.push({\n                            label: languageNames.of(language)!,\n                            value: language,\n                        });\n                    });\n                    this.setState({ languages: langs });\n                })\n                .catch((e) => {\n                    this.setState({\n                        languages: [\n                            {\n                                value: \"en\",\n                                label: languageNames.of(\"en\")!,\n                            },\n                        ],\n                    });\n                });\n        }\n    }\n\n    private onSearchChange(searchQuery: string): void {\n        this.setState({ searchQuery });\n    }\n\n    public render(): React.ReactNode {\n        if (!this.state.languages) {\n            return <Spinner />;\n        }\n\n        let displayedLanguages: Languages;\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}>{language.label}</div>;\n        }) as NonEmptyArray<ReactElement & { key: string }>;\n\n        // default value here too, otherwise we need to handle null / undefined;\n        // values between mounting and the initial value propagating\n        let language = SettingsStore.getValue<string | undefined>(\"language\", null, /*excludeDefault:*/ true);\n        let value: string | undefined;\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 (\n            <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_label\")}\n                placeholder={_t(\"settings|general|spell_check_locale_placeholder\")}\n            >\n                {options}\n            </Dropdown>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}