Skip to content
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 12 additions & 16 deletions lib/src/file-input/FileInput.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@ export default {
component: DxcFileInput,
};

const picPreview =
"";
const picPreview = "https://cdn.mos.cms.futurecdn.net/CAZ6JXi6huSuN4QGE627NR.jpg"

const file1 = new File(["file1"], "file.pdf", { type: "text/plain" });
const file2 = new File(["file2"], "file2.mp3", {
Expand All @@ -22,7 +21,7 @@ const file3 = new File(["file3"], "file3.png", {
const file4 = new File(["file4"], "file4file4file4file4file4file4file4file4file4.mp4", {
type: "video",
});
const file5 = new File(["file4"], "file5file5file5file5file5file5file5file5file5.mp4", {
const file5 = new File(["file5"], "file5file5file5file5file5file5file5file5file5.mp4", {
type: "video",
});

Expand Down Expand Up @@ -54,7 +53,7 @@ const filesExamples = [
file: file4,
},
{
error: "Error message error message error message error message",
error: "This error message is a multiline paragraph for testing.",
file: file5,
},
{
Expand All @@ -70,11 +69,10 @@ export const Chromatic = () => (
<ExampleContainer pseudoState="pseudo-hover">
<Title title="Hovered" theme="light" level={4} />
<FileItem
mode="dropzone"
multiple={true}
name="file"
fileName="file"
error=""
singleFileMode={false}
showPreview={false}
numFiles={1}
preview={picPreview}
type="image/png"
onDelete={() => {}}
Expand All @@ -84,11 +82,10 @@ export const Chromatic = () => (
<ExampleContainer pseudoState="pseudo-focus">
<Title title="Focused" theme="light" level={4} />
<FileItem
mode="dropzone"
multiple={true}
name="file"
fileName="file"
error=""
singleFileMode={false}
showPreview={false}
numFiles={1}
preview={picPreview}
type="image/png"
onDelete={() => {}}
Expand All @@ -98,11 +95,10 @@ export const Chromatic = () => (
<ExampleContainer pseudoState="pseudo-active">
<Title title="Actived" theme="light" level={4} />
<FileItem
mode="dropzone"
multiple={true}
name="file"
fileName="file"
error=""
singleFileMode={false}
showPreview={false}
numFiles={1}
preview={picPreview}
type="image/png"
onDelete={() => {}}
Expand Down
112 changes: 54 additions & 58 deletions lib/src/file-input/FileInput.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
// @ts-nocheck
//@ts-nocheck
import React, { useState, useEffect, useCallback } from "react";
import styled, { ThemeProvider } from "styled-components";
import { v4 as uuidv4 } from "uuid";
import { spaces } from "../common/variables.js";
import useTheme from "../useTheme";
import useTranslatedLabels from "../useTranslatedLabels";
import DxcButton from "../button/Button";
import FileItem from "./FileItem";
import FileInputPropsType from "./types";
import FileItem from "./FileItem";

const audioIcon = (
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="currentColor">
Expand Down Expand Up @@ -168,7 +168,7 @@ const DxcFileInput = ({
</Label>
<HelperText disabled={disabled}>{helperText}</HelperText>
{mode === "file" ? (
<FileContainer multiple={multiple} files={files}>
<FileContainer multiple={multiple}>
<ValueInput
id={fileInputId}
type="file"
Expand All @@ -193,22 +193,22 @@ const DxcFileInput = ({
size="fitContent"
tabIndex={tabIndex}
/>
<FileItemListContainer mode={mode} multiple={multiple} files={files}>
{files.map((file) => (
<FileItem
mode={mode}
multiple={multiple}
name={file.file.name}
error={file.error}
showPreview={mode === "file" && !multiple ? false : showPreview}
numFiles={files.length}
preview={file.preview}
type={file.file.type}
onDelete={onDelete}
tabIndex={tabIndex}
/>
))}
</FileItemListContainer>
{files.length > 0 && (
<FileItemListContainer>
{files.map((file) => (
<FileItem
fileName={file.file.name}
error={file.error}
singleFileMode={!multiple}
showPreview={mode === "file" && !multiple ? false : showPreview}
preview={file.preview}
type={file.file.type}
onDelete={onDelete}
tabIndex={tabIndex}
/>
))}
</FileItemListContainer>
)}
</FileContainer>
) : (
<Container>
Expand All @@ -232,15 +232,13 @@ const DxcFileInput = ({
onDragOver={handleDrag}
onDragLeave={handleDragOut}
>
<ButtonContainer mode={mode}>
<DxcButton
mode="secondary"
label={buttonLabel ?? translatedLabels.fileInput.dropAreaButtonLabelDefault}
onClick={handleClick}
disabled={disabled}
size="fitContent"
/>
</ButtonContainer>
<DxcButton
mode="secondary"
label={buttonLabel ?? translatedLabels.fileInput.dropAreaButtonLabelDefault}
onClick={handleClick}
disabled={disabled}
size="fitContent"
/>
{mode === "dropzone" ? (
<DropzoneLabel disabled={disabled}>
{dropAreaLabel ??
Expand All @@ -257,26 +255,27 @@ const DxcFileInput = ({
</FiledropLabel>
)}
</DragDropArea>
<FileItemListContainer mode={mode} multiple={multiple} files={files}>
{files.map((file) => (
<FileItem
mode={mode}
multiple={multiple}
name={file.file.name}
error={file.error}
showPreview={showPreview}
numFiles={files.length}
preview={file.preview}
type={file.file.type}
onDelete={onDelete}
tabIndex={tabIndex}
/>
))}
</FileItemListContainer>
{files.length > 0 && (
<FileItemListContainer>
{files.map((file) => (
<FileItem
fileName={file.file.name}
error={file.error}
singleFileMode={false}
showPreview={showPreview}
preview={file.preview}
type={file.file.type}
onDelete={onDelete}
tabIndex={tabIndex}
/>
))}
</FileItemListContainer>
)}
</Container>
)}
{files.length === 1 &&
files.map((file) => file.error && mode === "file" && !multiple && <ErrorMessage>{file.error}</ErrorMessage>)}
{mode === "file" && !multiple && files.length === 1 && files[0].error && (
<ErrorMessage>{files[0].error}</ErrorMessage>
)}
</FileInputContainer>
</ThemeProvider>
);
Expand Down Expand Up @@ -316,9 +315,7 @@ const HelperText = styled.span`
const FileContainer = styled.div`
display: flex;
${(props) =>
props.multiple || props.files.length > 1
? "flex-direction: column; row-gap: 0.25rem;"
: "flex-direction: row; column-gap: 0.25rem;"}
props.multiple ? "flex-direction: column; row-gap: 0.25rem;" : "flex-direction: row; column-gap: 0.25rem;"}
margin-top: 0.25rem;
`;

Expand All @@ -342,11 +339,16 @@ const Container = styled.div`
const DragDropArea = styled.div`
box-sizing: border-box;
display: flex;
flex-direction: ${(props) => (props.mode === "filedrop" ? "row" : "column")};
${(props) => props.mode === "dropzone" && "justify-content: center; padding: 1rem;"};
${(props) =>
props.mode === "filedrop"
? "flex-direction: row; column-gap: 0.75rem; height: 48px;"
: "justify-content: center; flex-direction: column; row-gap: 0.5rem; height: 160px;"}
align-items: center;
height: ${(props) => (props.mode === "filedrop" ? "48px" : "160px")};
width: 320px;
padding: ${(props) =>
props.mode === "filedrop"
? `calc(4px - ${props.theme.dropBorderThickness}) 1rem calc(4px - ${props.theme.dropBorderThickness}) calc(4px - ${props.theme.dropBorderThickness})`
: "1rem"};
overflow: hidden;
box-shadow: 0 0 0 2px transparent;
border-radius: ${(props) => props.theme.dropBorderRadius};
Expand All @@ -365,18 +367,13 @@ const DragDropArea = styled.div`
cursor: ${(props) => props.disabled && "not-allowed"};
`;

const ButtonContainer = styled.div`
${(props) => props.mode === "filedrop" && "padding: 2px 12px 2px 3px"};
`;

const DropzoneLabel = styled.div`
display: -webkit-box;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
-webkit-line-clamp: 3;
text-align: center;
margin-top: 0.5rem;
color: ${(props) => (props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor)};
font-family: ${(props) => props.theme.dropLabelFontFamily};
font-size: ${(props) => props.theme.dropLabelFontSize};
Expand All @@ -391,7 +388,6 @@ const FiledropLabel = styled.span`
font-family: ${(props) => props.theme.dropLabelFontFamily};
font-size: ${(props) => props.theme.dropLabelFontSize};
font-weight: ${(props) => props.theme.dropLabelFontWeight};
margin-right: 1rem;
`;

const ErrorMessage = styled.div`
Expand Down
Loading