mirror of
https://github.com/hexastack/hexabot
synced 2025-04-05 13:35:20 +00:00
fix: widget FileButton to use mime types
This commit is contained in:
parent
0f5a67c2ce
commit
b534e47edd
@ -1,14 +1,16 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright © 2024 Hexastack. All rights reserved.
|
* Copyright © 2025 Hexastack. All rights reserved.
|
||||||
*
|
*
|
||||||
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
||||||
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
||||||
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import React, { ChangeEvent } from "react";
|
|
||||||
|
import React, { ChangeEvent, useMemo } from "react";
|
||||||
|
|
||||||
import { useChat } from "../../providers/ChatProvider";
|
import { useChat } from "../../providers/ChatProvider";
|
||||||
|
import { MIME_TYPES } from "../../utils/attachment";
|
||||||
import FileInputIcon from "../icons/FileInputIcon";
|
import FileInputIcon from "../icons/FileInputIcon";
|
||||||
|
|
||||||
import "./FileButton.scss";
|
import "./FileButton.scss";
|
||||||
@ -23,12 +25,17 @@ const FileButton: React.FC = () => {
|
|||||||
setFile && setFile(e.target.files[0]);
|
setFile && setFile(e.target.files[0]);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
const acceptedMimeTypes = useMemo(
|
||||||
|
() => Object.values(MIME_TYPES).flat().join(""),
|
||||||
|
[],
|
||||||
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="sc-user-input--file-wrapper">
|
<div className="sc-user-input--file-wrapper">
|
||||||
<button className="sc-user-input--file-icon-wrapper" type="button">
|
<button className="sc-user-input--file-icon-wrapper" type="button">
|
||||||
<FileInputIcon />
|
<FileInputIcon />
|
||||||
<input
|
<input
|
||||||
|
accept={acceptedMimeTypes}
|
||||||
type="file"
|
type="file"
|
||||||
id="file-input"
|
id="file-input"
|
||||||
onChange={handleChange}
|
onChange={handleChange}
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright © 2024 Hexastack. All rights reserved.
|
* Copyright © 2025 Hexastack. All rights reserved.
|
||||||
*
|
*
|
||||||
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
|
||||||
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
|
||||||
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
import { FileType } from "../types/message.types";
|
import { FileType } from "../types/message.types";
|
||||||
|
|
||||||
export function getFileType(mimeType: string): FileType {
|
export function getFileType(mimeType: string): FileType {
|
||||||
@ -19,3 +20,41 @@ export function getFileType(mimeType: string): FileType {
|
|||||||
return FileType.file;
|
return FileType.file;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const MIME_TYPES = {
|
||||||
|
images: ["image/jpeg", "image/png", "image/webp", "image/bmp"],
|
||||||
|
videos: [
|
||||||
|
"video/mp4",
|
||||||
|
"video/webm",
|
||||||
|
"video/ogg",
|
||||||
|
"video/quicktime", // common in apple devices
|
||||||
|
"video/x-msvideo", // AVI
|
||||||
|
"video/x-matroska", // MKV
|
||||||
|
],
|
||||||
|
audios: [
|
||||||
|
"audio/mpeg", // MP3
|
||||||
|
"audio/mp3", // Explicit MP3 type
|
||||||
|
"audio/ogg",
|
||||||
|
"audio/wav",
|
||||||
|
"audio/aac", // common in apple devices
|
||||||
|
"audio/x-wav",
|
||||||
|
],
|
||||||
|
documents: [
|
||||||
|
"application/pdf",
|
||||||
|
"application/msword", // older ms Word format
|
||||||
|
"application/vnd.openxmlformats-officedocument.wordprocessingml.document", // newer ms word format
|
||||||
|
"application/vnd.openxmlformats-officedocument.wordprocessingml.document",
|
||||||
|
"application/vnd.ms-excel", // older excel format
|
||||||
|
"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", // newer excel format
|
||||||
|
"application/vnd.ms-powerpoint",
|
||||||
|
"application/vnd.openxmlformats-officedocument.presentationml.presentation",
|
||||||
|
"text/plain",
|
||||||
|
"application/rtf",
|
||||||
|
"application/epub+zip",
|
||||||
|
"application/x-7z-compressed",
|
||||||
|
"application/zip",
|
||||||
|
"application/x-rar-compressed",
|
||||||
|
"application/json",
|
||||||
|
"text/csv",
|
||||||
|
],
|
||||||
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user