mirror of
https://github.com/outline/outline.git
synced 2026-06-13 03:14:59 +03:00
0139b91b5d
* chore: Replace lodash with es-toolkit Migrate all direct lodash imports to es-toolkit/compat for a smaller, faster, lodash-compatible utility library. Transitive lodash usage from other packages remains unchanged. * fix: Restore isPlainObject semantics in CanCan policy The lodash migration aliased `isObject` to `lodash/isPlainObject` and the codemod incorrectly mapped the local name to es-toolkit's `isObject`, which also returns true for arrays and functions. This caused condition objects in policy definitions to be skipped, breaking authorization checks across the codebase. * fix: Restore unicode-aware length counting in validators es-toolkit/compat's size() returns string.length, while lodash's _.size() counts unicode code points. Switch to [...value].length to preserve the previous behavior so multi-byte characters like emoji count as one.
51 lines
1.5 KiB
TypeScript
51 lines
1.5 KiB
TypeScript
import { Trans, useTranslation } from "react-i18next";
|
|
import ConfirmationDialog from "~/components/ConfirmationDialog";
|
|
import Text from "~/components/Text";
|
|
import type { IntegrationType } from "@shared/types";
|
|
import type Integration from "~/models/Integration";
|
|
import useStores from "~/hooks/useStores";
|
|
import { useHistory } from "react-router-dom";
|
|
import { settingsPath } from "~/utils/routeHelpers";
|
|
import { observer } from "mobx-react";
|
|
import { capitalize } from "es-toolkit/compat";
|
|
|
|
type Props = {
|
|
integration: Integration<IntegrationType.Analytics>;
|
|
};
|
|
|
|
export const DisconnectAnalyticsDialog = observer(({ integration }: Props) => {
|
|
const { t } = useTranslation();
|
|
const { dialogs } = useStores();
|
|
const history = useHistory();
|
|
|
|
const handleSubmit = async () => {
|
|
await integration.delete();
|
|
history.push(settingsPath("integrations"));
|
|
dialogs.closeAllModals();
|
|
};
|
|
|
|
return (
|
|
<ConfirmationDialog
|
|
onSubmit={handleSubmit}
|
|
submitText={t("Disconnect")}
|
|
savingText={`${t("Disconnecting")}…`}
|
|
danger
|
|
>
|
|
<Text as="p" type="secondary">
|
|
<Trans
|
|
defaults="Are you sure you want to disconnect the <em>{{ service }}</em> integration?"
|
|
values={{
|
|
service: capitalize(integration.service),
|
|
}}
|
|
components={{
|
|
em: <strong />,
|
|
}}
|
|
/>
|
|
</Text>
|
|
<Text as="p" type="secondary">
|
|
<Trans defaults="This will stop sending analytics events to the configured instance." />
|
|
</Text>
|
|
</ConfirmationDialog>
|
|
);
|
|
});
|