sforkowany z mirror/soapbox
56 wiersze
1.5 KiB
TypeScript
56 wiersze
1.5 KiB
TypeScript
import React, { useMemo } from 'react';
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
import List, { ListItem } from 'soapbox/components/list';
|
|
import { Column, Toggle } from 'soapbox/components/ui';
|
|
import { useFeatures } from 'soapbox/hooks';
|
|
|
|
const messages = defineMessages({
|
|
title: { id: 'features.title', defaultMessage: 'Features' },
|
|
});
|
|
|
|
interface IFeaturesPanel {
|
|
features: Record<string, boolean>,
|
|
onChange?: (features: Record<string, boolean>) => void,
|
|
disabled?: boolean,
|
|
}
|
|
|
|
/** A UI for managing conditional feature flags. */
|
|
const FeaturesPanel: React.FC<IFeaturesPanel> = ({
|
|
features: userFeatures,
|
|
onChange,
|
|
disabled = false,
|
|
}) => {
|
|
const intl = useIntl();
|
|
const autoFeatures = useFeatures();
|
|
|
|
const features = useMemo(() => {
|
|
return Object.assign({ ...autoFeatures }, { ...userFeatures });
|
|
}, [userFeatures, autoFeatures]);
|
|
|
|
const handleChange = (key: string): React.ChangeEventHandler<HTMLInputElement> => {
|
|
return (e) => {
|
|
if (onChange) {
|
|
onChange({ ...userFeatures, [key]: e.target.checked });
|
|
}
|
|
};
|
|
};
|
|
|
|
return (
|
|
<Column label={intl.formatMessage(messages.title)}>
|
|
<List>
|
|
{Object.keys(autoFeatures).map(key => (
|
|
<ListItem label={key}>
|
|
<Toggle
|
|
checked={features[key]}
|
|
onChange={handleChange(key)}
|
|
disabled={disabled}
|
|
/>
|
|
</ListItem>
|
|
))}
|
|
</List>
|
|
</Column>
|
|
);
|
|
};
|
|
|
|
export default FeaturesPanel; |