pl-fe: fix locale change
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
parent
b31cdb1878
commit
1893ec409d
6 changed files with 20 additions and 29 deletions
|
@ -2,7 +2,7 @@ import clsx from 'clsx';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { defineMessages, useIntl } from 'react-intl';
|
import { defineMessages, useIntl } from 'react-intl';
|
||||||
|
|
||||||
import { useLocale } from 'pl-fe/hooks/use-locale';
|
import { useLocale, useLocaleDirection } from 'pl-fe/hooks/use-locale';
|
||||||
import { getTextDirection } from 'pl-fe/utils/rtl';
|
import { getTextDirection } from 'pl-fe/utils/rtl';
|
||||||
|
|
||||||
import Icon from './icon';
|
import Icon from './icon';
|
||||||
|
@ -48,7 +48,7 @@ interface IInput extends Pick<React.InputHTMLAttributes<HTMLInputElement>, 'maxL
|
||||||
const Input = React.forwardRef<HTMLInputElement, IInput>(
|
const Input = React.forwardRef<HTMLInputElement, IInput>(
|
||||||
(props, ref) => {
|
(props, ref) => {
|
||||||
const intl = useIntl();
|
const intl = useIntl();
|
||||||
const locale = useLocale();
|
const direction = useLocaleDirection(useLocale());
|
||||||
|
|
||||||
const { type = 'text', icon, className, outerClassName, append, prepend, theme = 'normal', ...filteredProps } = props;
|
const { type = 'text', icon, className, outerClassName, append, prepend, theme = 'normal', ...filteredProps } = props;
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ const Input = React.forwardRef<HTMLInputElement, IInput>(
|
||||||
'pl-8': typeof icon !== 'undefined',
|
'pl-8': typeof icon !== 'undefined',
|
||||||
'pl-16': typeof prepend !== 'undefined',
|
'pl-16': typeof prepend !== 'undefined',
|
||||||
}, className)}
|
}, className)}
|
||||||
dir={typeof props.value === 'string' ? getTextDirection(props.value, { fallback: locale.direction }) : undefined}
|
dir={typeof props.value === 'string' ? getTextDirection(props.value, { fallback: direction }) : undefined}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
{append ? (
|
{append ? (
|
||||||
|
|
|
@ -2,7 +2,7 @@ import clsx from 'clsx';
|
||||||
import React, { useState } from 'react';
|
import React, { useState } from 'react';
|
||||||
import { FormattedMessage } from 'react-intl';
|
import { FormattedMessage } from 'react-intl';
|
||||||
|
|
||||||
import { useLocale } from 'pl-fe/hooks/use-locale';
|
import { useLocale, useLocaleDirection } from 'pl-fe/hooks/use-locale';
|
||||||
import { getTextDirection } from 'pl-fe/utils/rtl';
|
import { getTextDirection } from 'pl-fe/utils/rtl';
|
||||||
|
|
||||||
import Stack from './stack';
|
import Stack from './stack';
|
||||||
|
@ -56,7 +56,7 @@ const Textarea = React.forwardRef(({
|
||||||
}: ITextarea, ref: React.ForwardedRef<HTMLTextAreaElement>) => {
|
}: ITextarea, ref: React.ForwardedRef<HTMLTextAreaElement>) => {
|
||||||
const length = value?.length || 0;
|
const length = value?.length || 0;
|
||||||
const [rows, setRows] = useState<number>(autoGrow ? minRows : initialRows);
|
const [rows, setRows] = useState<number>(autoGrow ? minRows : initialRows);
|
||||||
const locale = useLocale();
|
const direction = useLocaleDirection(useLocale());
|
||||||
|
|
||||||
const handleChange = (event: React.ChangeEvent<HTMLTextAreaElement>) => {
|
const handleChange = (event: React.ChangeEvent<HTMLTextAreaElement>) => {
|
||||||
if (autoGrow) {
|
if (autoGrow) {
|
||||||
|
@ -99,7 +99,7 @@ const Textarea = React.forwardRef(({
|
||||||
'text-red-600 border-red-600': hasError,
|
'text-red-600 border-red-600': hasError,
|
||||||
'resize-none': !isResizeable,
|
'resize-none': !isResizeable,
|
||||||
})}
|
})}
|
||||||
dir={value?.length ? getTextDirection(value, { fallback: locale.direction }) : undefined}
|
dir={value?.length ? getTextDirection(value, { fallback: direction }) : undefined}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
{maxLength && (
|
{maxLength && (
|
||||||
|
|
|
@ -1,27 +1,16 @@
|
||||||
import { getLocale } from 'pl-fe/actions/settings';
|
import messages from 'pl-fe/messages';
|
||||||
|
import { useSettingsStore } from 'pl-fe/stores/settings';
|
||||||
|
|
||||||
/** Locales which should be presented in right-to-left. */
|
/** Locales which should be presented in right-to-left. */
|
||||||
const RTL_LOCALES = ['ar', 'ckb', 'fa', 'he'];
|
const RTL_LOCALES = ['ar', 'ckb', 'fa', 'he'];
|
||||||
|
|
||||||
interface UseLocaleResult {
|
|
||||||
locale: string;
|
|
||||||
direction: 'ltr' | 'rtl';
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Get valid locale from settings. */
|
/** Get valid locale from settings. */
|
||||||
const useLocale = (fallback = 'en'): UseLocaleResult => {
|
const useLocale = (fallback = 'en') => {
|
||||||
// TODO use useSettingsStore directly
|
const localeWithVariant = useSettingsStore().settings.locale.replace('_', '-');
|
||||||
const locale = getLocale(fallback);
|
const localeFirstPart = localeWithVariant.split('-')[0];
|
||||||
|
return Object.keys(messages).includes(localeWithVariant) ? localeWithVariant : Object.keys(messages).includes(localeFirstPart) ? localeFirstPart : fallback;
|
||||||
const direction: 'ltr' | 'rtl' =
|
|
||||||
RTL_LOCALES.includes(locale)
|
|
||||||
? 'rtl'
|
|
||||||
: 'ltr';
|
|
||||||
|
|
||||||
return {
|
|
||||||
locale,
|
|
||||||
direction,
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export { useLocale };
|
const useLocaleDirection = (locale = 'en') => RTL_LOCALES.includes(locale) ? 'rtl' : 'ltr';
|
||||||
|
|
||||||
|
export { useLocale, useLocaleDirection };
|
||||||
|
|
|
@ -2,7 +2,7 @@ import clsx from 'clsx';
|
||||||
import React, { useEffect } from 'react';
|
import React, { useEffect } from 'react';
|
||||||
import * as v from 'valibot';
|
import * as v from 'valibot';
|
||||||
|
|
||||||
import { useLocale } from 'pl-fe/hooks/use-locale';
|
import { useLocale, useLocaleDirection } from 'pl-fe/hooks/use-locale';
|
||||||
import { usePlFeConfig } from 'pl-fe/hooks/use-pl-fe-config';
|
import { usePlFeConfig } from 'pl-fe/hooks/use-pl-fe-config';
|
||||||
import { useSettings } from 'pl-fe/hooks/use-settings';
|
import { useSettings } from 'pl-fe/hooks/use-settings';
|
||||||
import { useTheme } from 'pl-fe/hooks/use-theme';
|
import { useTheme } from 'pl-fe/hooks/use-theme';
|
||||||
|
@ -15,7 +15,8 @@ const Helmet = React.lazy(() => import('pl-fe/components/helmet'));
|
||||||
|
|
||||||
/** Injects metadata into site head with Helmet. */
|
/** Injects metadata into site head with Helmet. */
|
||||||
const PlFeHead = () => {
|
const PlFeHead = () => {
|
||||||
const { locale, direction } = useLocale();
|
const locale = useLocale();
|
||||||
|
const direction = useLocaleDirection(locale);
|
||||||
const { demo, reduceMotion, underlineLinks, demetricator, systemFont } = useSettings();
|
const { demo, reduceMotion, underlineLinks, demetricator, systemFont } = useSettings();
|
||||||
const plFeConfig = usePlFeConfig();
|
const plFeConfig = usePlFeConfig();
|
||||||
const theme = useTheme();
|
const theme = useTheme();
|
||||||
|
|
|
@ -34,7 +34,7 @@ const PlFeLoad: React.FC<IPlFeLoad> = ({ children }) => {
|
||||||
|
|
||||||
const me = useAppSelector(state => state.me);
|
const me = useAppSelector(state => state.me);
|
||||||
const { account } = useOwnAccount();
|
const { account } = useOwnAccount();
|
||||||
const { locale } = useLocale();
|
const locale = useLocale();
|
||||||
|
|
||||||
const [messages, setMessages] = useState<Record<string, string>>({});
|
const [messages, setMessages] = useState<Record<string, string>>({});
|
||||||
const [localeLoading, setLocaleLoading] = useState(true);
|
const [localeLoading, setLocaleLoading] = useState(true);
|
||||||
|
|
|
@ -65,6 +65,7 @@ const useSettingsStore = create<State>()(mutative((set) => ({
|
||||||
changeSetting(state.userSettings, path, value);
|
changeSetting(state.userSettings, path, value);
|
||||||
|
|
||||||
mergeSettings(state);
|
mergeSettings(state);
|
||||||
|
console.log(JSON.parse(JSON.stringify(state.userSettings)));
|
||||||
}),
|
}),
|
||||||
|
|
||||||
rememberEmojiUse: (emoji: Emoji) => set((state: State) => {
|
rememberEmojiUse: (emoji: Emoji) => set((state: State) => {
|
||||||
|
|
Loading…
Reference in a new issue