aboutsummaryrefslogtreecommitdiff
path: root/FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2023-09-14 23:47:16 +0800
committercrupest <crupest@outlook.com>2023-09-14 23:47:16 +0800
commit40b4871c3f7bfe04f332ae7fb687fd7d9ae34734 (patch)
treecba45fa30627a704c2fb5132eff3f936ba1dd54e /FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx
parentc1f79460d57a4daba75bdc34b7b7a3ea2d7254b3 (diff)
downloadtimeline-40b4871c3f7bfe04f332ae7fb687fd7d9ae34734.tar.gz
timeline-40b4871c3f7bfe04f332ae7fb687fd7d9ae34734.tar.bz2
timeline-40b4871c3f7bfe04f332ae7fb687fd7d9ae34734.zip
...
Diffstat (limited to 'FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx')
-rw-r--r--FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx36
1 files changed, 36 insertions, 0 deletions
diff --git a/FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx b/FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx
new file mode 100644
index 00000000..d25d04b4
--- /dev/null
+++ b/FrontEnd/src/pages/timeline/edit/ImagePostEdit.tsx
@@ -0,0 +1,36 @@
+import classNames from "classnames";
+
+import BlobImage from "~/src/components/BlobImage";
+
+interface TimelinePostEditImageProps {
+ file: File;
+ onChange: (file: File | null) => void;
+ disabled: boolean;
+ className?: string;
+}
+
+export default function ImagePostEdit(props: TimelinePostEditImageProps) {
+ const { file, onChange, disabled, className } = props;
+
+ return (
+ <div
+ className={classNames("timeline-post-create-edit-container", className)}
+ >
+ <input
+ type="file"
+ accept="image/*"
+ disabled={disabled}
+ onChange={(e) => {
+ const files = e.target.files;
+ if (files == null || files.length === 0) {
+ onChange(null);
+ } else {
+ onChange(files[0]);
+ }
+ }}
+ className="mx-3 my-1"
+ />
+ {file && <BlobImage src={file} className="timeline-post-create-image" />}
+ </div>
+ );
+}