mirror of
https://github.com/element-hq/element-web.git
synced 2026-01-16 23:01:06 +00:00
* Make shared component build work in isolation * Add deps that were missing because they were getting picked up from element-web main but shared-components needs itself * Exclude test files from dts generation * Bump version * Change all the shared-component import to be the built artifact * Don't randomly inhale eslint configs in parent dirs please * maybe we don't need this anymore? * maybe fix build * Maybe fix docker build * More build faff * build:res on the parent as part of shared component prepare * link shared component repo inn docker build * 💅 * 💅x2 * Try converting the translation keys to a .d.ts file manually so it gets bundled rather than left as a relative import to the json file * add the script * Add this back for 2nd time now I think * Shouldn't need this anymore * patch-package on prepare because we're patching a dev dependency so it won't be there if we're installed as a dependency * Unused import * Prettier compliance * Only use counterpart from shared components as per comment * Import shared components CSS * Prettier * Call the one from shared components rather than recurse infinitely * Hopefully make tests work * wake up, comment goes before import * Fix lint errors * Fix dupe TranslationKey export * Update compound-web to fix type error An update to @types.react adds the 'hint' value to the enum of the 'popover' attribute and this version of compound-web uses the maching verson of @types/react so they don't conflict. * Maybe, hopefully, get the types working? Please? * Add copyright header to i18nkeys as eslint complains otherwise since it's now in src * prettier * stop running shared-component tests in EW * update snapshots because flex is now from an external stylesheet I guess * More snapshots * Manual class update * Avoid bundling compound bits Because a) it's silly and b) it means we end up bundling a copy of floating-ui too which causes absolute madness with its useDelayGroup contexts. * ignore test util files for coverage * Add !important because the styles are being applied in a different order now * Another !important because css order has changed * Try adding it here to make the test files ignored * More !important * commit yarn lock change * Add shared components coverage file * Update snapshots Because the line height was being overridden to 22.5px somehow by something I can't find, and now isn't: surely the normal 1.5rem is more sensible. * Update snapshots, attempt 2 * Another !important * More snapshot updates * Add test for i18n wrappers & add test script * lint * Prettier * Hopefully run shared component tests * don't need this bit for non-matrix * install ew deps * rigfht coverage location * Rename job here too * Try different coverage filename * Fix copyrights & comment * Typo Co-authored-by: Michael Telatynski <7t3chguy@gmail.com> --------- Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>
81 lines
2.6 KiB
TypeScript
81 lines
2.6 KiB
TypeScript
/*
|
|
Copyright 2025 New Vector Ltd.
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import React, { type JSX, useCallback, useId, useState } from "react";
|
|
import { _t } from "@element-hq/web-shared-components";
|
|
|
|
import SettingsStore from "../../../settings/SettingsStore";
|
|
import { type SettingLevel } from "../../../settings/SettingLevel";
|
|
import { SETTINGS, type StringSettingKey } from "../../../settings/Settings";
|
|
import { useSettingValueAt } from "../../../hooks/useSettings.ts";
|
|
import Dropdown, { type DropdownProps } from "./Dropdown.tsx";
|
|
|
|
interface Props {
|
|
settingKey: StringSettingKey;
|
|
level: SettingLevel;
|
|
roomId?: string; // for per-room settings
|
|
label?: string;
|
|
isExplicit?: boolean;
|
|
hideIfCannotSet?: boolean;
|
|
onChange?(option: string): void;
|
|
}
|
|
|
|
const SettingsDropdown = ({
|
|
settingKey,
|
|
roomId,
|
|
level,
|
|
label: specificLabel,
|
|
isExplicit,
|
|
hideIfCannotSet,
|
|
onChange,
|
|
}: Props): JSX.Element => {
|
|
const id = useId();
|
|
const settingValue = useSettingValueAt(level, settingKey, roomId ?? null, isExplicit);
|
|
const [value, setValue] = useState(settingValue);
|
|
const setting = SETTINGS[settingKey];
|
|
|
|
const onOptionChange = useCallback(
|
|
(value: string): void => {
|
|
setValue(value); // local echo
|
|
SettingsStore.setValue(settingKey, roomId ?? null, level, value);
|
|
onChange?.(value);
|
|
},
|
|
[settingKey, roomId, level, onChange],
|
|
);
|
|
|
|
const disabled = !SettingsStore.canSetValue(settingKey, roomId ?? null, level);
|
|
if (disabled && hideIfCannotSet) return <></>;
|
|
if (!setting.options) {
|
|
console.error("SettingsDropdown used for a setting with no `options`");
|
|
return <></>;
|
|
}
|
|
|
|
const label = specificLabel ?? SettingsStore.getDisplayName(settingKey, level)!;
|
|
const options = setting.options.map((option) => {
|
|
return <div key={option.value}>{_t(option.label)}</div>;
|
|
}) as DropdownProps["children"];
|
|
|
|
return (
|
|
<div className="mx_SettingsDropdown">
|
|
<label className="mx_SettingsDropdown_label" htmlFor={id}>
|
|
<span className="mx_SettingsDropdown_labelText">{label}</span>
|
|
</label>
|
|
<Dropdown
|
|
id={id}
|
|
onOptionChange={onOptionChange}
|
|
menuWidth={360} // matches CSS width
|
|
value={value}
|
|
disabled={disabled}
|
|
label={label}
|
|
>
|
|
{options}
|
|
</Dropdown>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default SettingsDropdown;
|