mirror of
https://github.com/docmost/docmost.git
synced 2025-11-14 00:21:14 +10:00
fix translation
* fix filesize formatting
This commit is contained in:
@ -3,7 +3,7 @@ import { uploadFile } from "@/features/page/services/page-service.ts";
|
|||||||
import { notifications } from "@mantine/notifications";
|
import { notifications } from "@mantine/notifications";
|
||||||
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
||||||
import { formatBytes } from "@/lib";
|
import { formatBytes } from "@/lib";
|
||||||
import i18n from "i18next";
|
import i18n from "@/i18n.ts";
|
||||||
|
|
||||||
export const uploadAttachmentAction = handleAttachmentUpload({
|
export const uploadAttachmentAction = handleAttachmentUpload({
|
||||||
onUpload: async (file: File, pageId: string): Promise<any> => {
|
onUpload: async (file: File, pageId: string): Promise<any> => {
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { useEffect, useState } from "react";
|
|||||||
import mermaid from "mermaid";
|
import mermaid from "mermaid";
|
||||||
import { v4 as uuidv4 } from "uuid";
|
import { v4 as uuidv4 } from "uuid";
|
||||||
import classes from "./code-block.module.css";
|
import classes from "./code-block.module.css";
|
||||||
import { t } from "i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
|
|
||||||
mermaid.initialize({
|
mermaid.initialize({
|
||||||
startOnLoad: false,
|
startOnLoad: false,
|
||||||
@ -15,6 +15,7 @@ interface MermaidViewProps {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function MermaidView({ props }: MermaidViewProps) {
|
export default function MermaidView({ props }: MermaidViewProps) {
|
||||||
|
const { t } = useTranslation();
|
||||||
const { node } = props;
|
const { node } = props;
|
||||||
const [preview, setPreview] = useState<string>("");
|
const [preview, setPreview] = useState<string>("");
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { uploadFile } from "@/features/page/services/page-service.ts";
|
|||||||
import { notifications } from "@mantine/notifications";
|
import { notifications } from "@mantine/notifications";
|
||||||
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
||||||
import { formatBytes } from "@/lib";
|
import { formatBytes } from "@/lib";
|
||||||
import i18n from "i18next";
|
import i18n from "@/i18n.ts";
|
||||||
|
|
||||||
export const uploadImageAction = handleImageUpload({
|
export const uploadImageAction = handleImageUpload({
|
||||||
onUpload: async (file: File, pageId: string): Promise<any> => {
|
onUpload: async (file: File, pageId: string): Promise<any> => {
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { uploadFile } from "@/features/page/services/page-service.ts";
|
|||||||
import { notifications } from "@mantine/notifications";
|
import { notifications } from "@mantine/notifications";
|
||||||
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
import { getFileUploadSizeLimit } from "@/lib/config.ts";
|
||||||
import { formatBytes } from "@/lib";
|
import { formatBytes } from "@/lib";
|
||||||
import i18n from "i18next";
|
import i18n from "@/i18n.ts";
|
||||||
|
|
||||||
export const uploadVideoAction = handleVideoUpload({
|
export const uploadVideoAction = handleVideoUpload({
|
||||||
onUpload: async (file: File, pageId: string): Promise<any> => {
|
onUpload: async (file: File, pageId: string): Promise<any> => {
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
import { IRoleData, SpaceRole } from "@/lib/types.ts";
|
import { IRoleData, SpaceRole } from "@/lib/types.ts";
|
||||||
import i18n from "i18next";
|
import i18n from "@/i18n.ts";
|
||||||
|
|
||||||
export const spaceRoleData: IRoleData[] = [
|
export const spaceRoleData: IRoleData[] = [
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
import { formatDistanceStrict } from "date-fns";
|
import { formatDistanceStrict } from "date-fns";
|
||||||
import { format, isToday, isYesterday } from "date-fns";
|
import { format, isToday, isYesterday } from "date-fns";
|
||||||
import i18n from "i18next";
|
import i18n from "@/i18n.ts";
|
||||||
|
|
||||||
export function timeAgo(date: Date) {
|
export function timeAgo(date: Date) {
|
||||||
return formatDistanceStrict(new Date(date), new Date(), { addSuffix: true });
|
return formatDistanceStrict(new Date(date), new Date(), { addSuffix: true });
|
||||||
|
|||||||
@ -28,14 +28,10 @@ export const computeSpaceSlug = (name: string) => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
export const formatBytes = (
|
export const formatBytes = (bytes: number): string => {
|
||||||
bytes: number,
|
|
||||||
decimalPlaces: number = 2,
|
|
||||||
): string => {
|
|
||||||
if (bytes === 0) return "0.0 KB";
|
if (bytes === 0) return "0.0 KB";
|
||||||
|
|
||||||
const unitSize = 1024;
|
const unitSize = 1024;
|
||||||
const precision = decimalPlaces < 0 ? 0 : decimalPlaces;
|
|
||||||
const units = ["KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
|
const units = ["KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
|
||||||
|
|
||||||
const kilobytes = bytes / unitSize;
|
const kilobytes = bytes / unitSize;
|
||||||
@ -44,6 +40,9 @@ export const formatBytes = (
|
|||||||
const adjustedUnitIndex = Math.max(unitIndex, 0);
|
const adjustedUnitIndex = Math.max(unitIndex, 0);
|
||||||
const adjustedSize = kilobytes / Math.pow(unitSize, adjustedUnitIndex);
|
const adjustedSize = kilobytes / Math.pow(unitSize, adjustedUnitIndex);
|
||||||
|
|
||||||
|
// Use one decimal for KB and no decimals for MB or higher
|
||||||
|
const precision = adjustedUnitIndex === 0 ? 1 : 0;
|
||||||
|
|
||||||
return `${adjustedSize.toFixed(precision)} ${units[adjustedUnitIndex]}`;
|
return `${adjustedSize.toFixed(precision)} ${units[adjustedUnitIndex]}`;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -66,9 +65,9 @@ function decodeBase64(base64: string): string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function decodeBase64ToSvgString(base64Data: string): string {
|
export function decodeBase64ToSvgString(base64Data: string): string {
|
||||||
const base64Prefix = 'data:image/svg+xml;base64,';
|
const base64Prefix = "data:image/svg+xml;base64,";
|
||||||
if (base64Data.startsWith(base64Prefix)) {
|
if (base64Data.startsWith(base64Prefix)) {
|
||||||
base64Data = base64Data.replace(base64Prefix, '');
|
base64Data = base64Data.replace(base64Prefix, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
return decodeBase64(base64Data);
|
return decodeBase64(base64Data);
|
||||||
|
|||||||
Reference in New Issue
Block a user