matrix-react-sdk
Version:
SDK for matrix.org using React
99 lines (96 loc) • 14.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.ExistingSpellCheckLanguage = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _SpellCheckLanguagesDropdown = _interopRequireDefault(require("../../../components/views/elements/SpellCheckLanguagesDropdown"));
var _AccessibleButton = _interopRequireDefault(require("../../../components/views/elements/AccessibleButton"));
var _languageHandler = require("../../../languageHandler");
/*
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.
*/
class ExistingSpellCheckLanguage extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "onRemove", e => {
e.stopPropagation();
e.preventDefault();
return this.props.onRemoved(this.props.language);
});
}
render() {
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ExistingSpellCheckLanguage"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ExistingSpellCheckLanguage_language"
}, this.props.label ?? this.props.language), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onRemove,
kind: "danger_sm"
}, (0, _languageHandler._t)("action|remove")));
}
}
exports.ExistingSpellCheckLanguage = ExistingSpellCheckLanguage;
class SpellCheckLanguages extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onRemoved", language => {
const languages = this.props.languages.filter(e => e !== language);
this.props.onLanguagesChange(languages);
});
(0, _defineProperty2.default)(this, "onAddClick", e => {
e.stopPropagation();
e.preventDefault();
const language = this.state.newLanguage;
this.setState({
newLanguage: ""
});
if (!language) return;
if (this.props.languages.includes(language)) return;
this.props.languages.push(language);
this.props.onLanguagesChange(this.props.languages);
});
(0, _defineProperty2.default)(this, "onNewLanguageChange", language => {
if (this.state.newLanguage === language) return;
this.setState({
newLanguage: language
});
});
this.state = {
newLanguage: ""
};
}
render() {
const intl = new Intl.DisplayNames([(0, _languageHandler.getUserLanguage)()], {
type: "language",
style: "short"
});
const existingSpellCheckLanguages = this.props.languages.map(e => {
return /*#__PURE__*/_react.default.createElement(ExistingSpellCheckLanguage, {
language: e,
label: intl.of(e),
onRemoved: this.onRemoved,
key: e
});
});
const addButton = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onAddClick,
kind: "primary"
}, (0, _languageHandler._t)("action|add"));
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, existingSpellCheckLanguages, /*#__PURE__*/_react.default.createElement("form", {
onSubmit: this.onAddClick,
noValidate: true
}, /*#__PURE__*/_react.default.createElement(_SpellCheckLanguagesDropdown.default, {
className: "mx_GeneralUserSettingsTab_spellCheckLanguageInput",
value: this.state.newLanguage,
onOptionChange: this.onNewLanguageChange
}), addButton));
}
}
exports.default = SpellCheckLanguages;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_SpellCheckLanguagesDropdown","_AccessibleButton","_languageHandler","ExistingSpellCheckLanguage","React","Component","constructor","args","_defineProperty2","default","e","stopPropagation","preventDefault","props","onRemoved","language","render","createElement","className","label","onClick","onRemove","kind","_t","exports","SpellCheckLanguages","languages","filter","onLanguagesChange","state","newLanguage","setState","includes","push","intl","Intl","DisplayNames","getUserLanguage","type","style","existingSpellCheckLanguages","map","of","key","addButton","onAddClick","Fragment","onSubmit","noValidate","value","onOptionChange","onNewLanguageChange"],"sources":["../../../../src/components/views/settings/SpellCheckSettings.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 from \"react\";\n\nimport SpellCheckLanguagesDropdown from \"../../../components/views/elements/SpellCheckLanguagesDropdown\";\nimport AccessibleButton, { ButtonEvent } from \"../../../components/views/elements/AccessibleButton\";\nimport { _t, getUserLanguage } from \"../../../languageHandler\";\n\ninterface ExistingSpellCheckLanguageIProps {\n    language: string;\n    /**\n     * The label to render on the component. If not provided, the language code will be used.\n     */\n    label?: string;\n    onRemoved(language: string): void;\n}\n\ninterface SpellCheckLanguagesIProps {\n    languages: Array<string>;\n    onLanguagesChange(languages: Array<string>): void;\n}\n\ninterface SpellCheckLanguagesIState {\n    newLanguage: string;\n}\n\nexport class ExistingSpellCheckLanguage extends React.Component<ExistingSpellCheckLanguageIProps> {\n    private onRemove = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        return this.props.onRemoved(this.props.language);\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <div className=\"mx_ExistingSpellCheckLanguage\">\n                <span className=\"mx_ExistingSpellCheckLanguage_language\">\n                    {this.props.label ?? this.props.language}\n                </span>\n                <AccessibleButton onClick={this.onRemove} kind=\"danger_sm\">\n                    {_t(\"action|remove\")}\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n\nexport default class SpellCheckLanguages extends React.Component<SpellCheckLanguagesIProps, SpellCheckLanguagesIState> {\n    public constructor(props: SpellCheckLanguagesIProps) {\n        super(props);\n        this.state = {\n            newLanguage: \"\",\n        };\n    }\n\n    private onRemoved = (language: string): void => {\n        const languages = this.props.languages.filter((e) => e !== language);\n        this.props.onLanguagesChange(languages);\n    };\n\n    private onAddClick = (e: ButtonEvent): void => {\n        e.stopPropagation();\n        e.preventDefault();\n\n        const language = this.state.newLanguage;\n        this.setState({ newLanguage: \"\" });\n\n        if (!language) return;\n        if (this.props.languages.includes(language)) return;\n\n        this.props.languages.push(language);\n        this.props.onLanguagesChange(this.props.languages);\n    };\n\n    private onNewLanguageChange = (language: string): void => {\n        if (this.state.newLanguage === language) return;\n        this.setState({ newLanguage: language });\n    };\n\n    public render(): React.ReactNode {\n        const intl = new Intl.DisplayNames([getUserLanguage()], { type: \"language\", style: \"short\" });\n        const existingSpellCheckLanguages = this.props.languages.map((e) => {\n            return <ExistingSpellCheckLanguage language={e} label={intl.of(e)} onRemoved={this.onRemoved} key={e} />;\n        });\n\n        const addButton = (\n            <AccessibleButton onClick={this.onAddClick} kind=\"primary\">\n                {_t(\"action|add\")}\n            </AccessibleButton>\n        );\n\n        return (\n            <>\n                {existingSpellCheckLanguages}\n                <form onSubmit={this.onAddClick} noValidate={true}>\n                    <SpellCheckLanguagesDropdown\n                        className=\"mx_GeneralUserSettingsTab_spellCheckLanguageInput\"\n                        value={this.state.newLanguage}\n                        onOptionChange={this.onNewLanguageChange}\n                    />\n                    {addButton}\n                </form>\n            </>\n        );\n    }\n}\n"],"mappings":";;;;;;;;AAQA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,4BAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,iBAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,gBAAA,GAAAH,OAAA;AAZA;AACA;AACA;AACA;AACA;AACA;AACA;;AA0BO,MAAMI,0BAA0B,SAASC,cAAK,CAACC,SAAS,CAAmC;EAAAC,YAAA,GAAAC,IAAA;IAAA,SAAAA,IAAA;IAAA,IAAAC,gBAAA,CAAAC,OAAA,oBAC1EC,CAAc,IAAW;MACzCA,CAAC,CAACC,eAAe,CAAC,CAAC;MACnBD,CAAC,CAACE,cAAc,CAAC,CAAC;MAElB,OAAO,IAAI,CAACC,KAAK,CAACC,SAAS,CAAC,IAAI,CAACD,KAAK,CAACE,QAAQ,CAAC;IACpD,CAAC;EAAA;EAEMC,MAAMA,CAAA,EAAoB;IAC7B,oBACInB,MAAA,CAAAY,OAAA,CAAAQ,aAAA;MAAKC,SAAS,EAAC;IAA+B,gBAC1CrB,MAAA,CAAAY,OAAA,CAAAQ,aAAA;MAAMC,SAAS,EAAC;IAAwC,GACnD,IAAI,CAACL,KAAK,CAACM,KAAK,IAAI,IAAI,CAACN,KAAK,CAACE,QAC9B,CAAC,eACPlB,MAAA,CAAAY,OAAA,CAAAQ,aAAA,CAAChB,iBAAA,CAAAQ,OAAgB;MAACW,OAAO,EAAE,IAAI,CAACC,QAAS;MAACC,IAAI,EAAC;IAAW,GACrD,IAAAC,mBAAE,EAAC,eAAe,CACL,CACjB,CAAC;EAEd;AACJ;AAACC,OAAA,CAAArB,0BAAA,GAAAA,0BAAA;AAEc,MAAMsB,mBAAmB,SAASrB,cAAK,CAACC,SAAS,CAAuD;EAC5GC,WAAWA,CAACO,KAAgC,EAAE;IACjD,KAAK,CAACA,KAAK,CAAC;IAAC,IAAAL,gBAAA,CAAAC,OAAA,qBAMIM,QAAgB,IAAW;MAC5C,MAAMW,SAAS,GAAG,IAAI,CAACb,KAAK,CAACa,SAAS,CAACC,MAAM,CAAEjB,CAAC,IAAKA,CAAC,KAAKK,QAAQ,CAAC;MACpE,IAAI,CAACF,KAAK,CAACe,iBAAiB,CAACF,SAAS,CAAC;IAC3C,CAAC;IAAA,IAAAlB,gBAAA,CAAAC,OAAA,sBAEqBC,CAAc,IAAW;MAC3CA,CAAC,CAACC,eAAe,CAAC,CAAC;MACnBD,CAAC,CAACE,cAAc,CAAC,CAAC;MAElB,MAAMG,QAAQ,GAAG,IAAI,CAACc,KAAK,CAACC,WAAW;MACvC,IAAI,CAACC,QAAQ,CAAC;QAAED,WAAW,EAAE;MAAG,CAAC,CAAC;MAElC,IAAI,CAACf,QAAQ,EAAE;MACf,IAAI,IAAI,CAACF,KAAK,CAACa,SAAS,CAACM,QAAQ,CAACjB,QAAQ,CAAC,EAAE;MAE7C,IAAI,CAACF,KAAK,CAACa,SAAS,CAACO,IAAI,CAAClB,QAAQ,CAAC;MACnC,IAAI,CAACF,KAAK,CAACe,iBAAiB,CAAC,IAAI,CAACf,KAAK,CAACa,SAAS,CAAC;IACtD,CAAC;IAAA,IAAAlB,gBAAA,CAAAC,OAAA,+BAE8BM,QAAgB,IAAW;MACtD,IAAI,IAAI,CAACc,KAAK,CAACC,WAAW,KAAKf,QAAQ,EAAE;MACzC,IAAI,CAACgB,QAAQ,CAAC;QAAED,WAAW,EAAEf;MAAS,CAAC,CAAC;IAC5C,CAAC;IA3BG,IAAI,CAACc,KAAK,GAAG;MACTC,WAAW,EAAE;IACjB,CAAC;EACL;EA0BOd,MAAMA,CAAA,EAAoB;IAC7B,MAAMkB,IAAI,GAAG,IAAIC,IAAI,CAACC,YAAY,CAAC,CAAC,IAAAC,gCAAe,EAAC,CAAC,CAAC,EAAE;MAAEC,IAAI,EAAE,UAAU;MAAEC,KAAK,EAAE;IAAQ,CAAC,CAAC;IAC7F,MAAMC,2BAA2B,GAAG,IAAI,CAAC3B,KAAK,CAACa,SAAS,CAACe,GAAG,CAAE/B,CAAC,IAAK;MAChE,oBAAOb,MAAA,CAAAY,OAAA,CAAAQ,aAAA,CAACd,0BAA0B;QAACY,QAAQ,EAAEL,CAAE;QAACS,KAAK,EAAEe,IAAI,CAACQ,EAAE,CAAChC,CAAC,CAAE;QAACI,SAAS,EAAE,IAAI,CAACA,SAAU;QAAC6B,GAAG,EAAEjC;MAAE,CAAE,CAAC;IAC5G,CAAC,CAAC;IAEF,MAAMkC,SAAS,gBACX/C,MAAA,CAAAY,OAAA,CAAAQ,aAAA,CAAChB,iBAAA,CAAAQ,OAAgB;MAACW,OAAO,EAAE,IAAI,CAACyB,UAAW;MAACvB,IAAI,EAAC;IAAS,GACrD,IAAAC,mBAAE,EAAC,YAAY,CACF,CACrB;IAED,oBACI1B,MAAA,CAAAY,OAAA,CAAAQ,aAAA,CAAApB,MAAA,CAAAY,OAAA,CAAAqC,QAAA,QACKN,2BAA2B,eAC5B3C,MAAA,CAAAY,OAAA,CAAAQ,aAAA;MAAM8B,QAAQ,EAAE,IAAI,CAACF,UAAW;MAACG,UAAU,EAAE;IAAK,gBAC9CnD,MAAA,CAAAY,OAAA,CAAAQ,aAAA,CAACjB,4BAAA,CAAAS,OAA2B;MACxBS,SAAS,EAAC,mDAAmD;MAC7D+B,KAAK,EAAE,IAAI,CAACpB,KAAK,CAACC,WAAY;MAC9BoB,cAAc,EAAE,IAAI,CAACC;IAAoB,CAC5C,CAAC,EACDP,SACC,CACR,CAAC;EAEX;AACJ;AAACpB,OAAA,CAAAf,OAAA,GAAAgB,mBAAA","ignoreList":[]}