-
Notifications
You must be signed in to change notification settings - Fork 312
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
onUploadSuccess not triggered #5800
Comments
Hi @nam-truong-le, thanks for submitting this issue. Unfortunately, we have not been able to reproduce this behavior with the FileUploader in a Next.js app. We will need more information to figure out why you're experiencing this. To confirm, is this the template you're using for your app? https://github.com/aws-samples/amplify-next-template Additionally, would you be able to share your |
Yes, https://github.com/aws-samples/amplify-next-template is the template. My {
"name": "aws-amplify-gen2",
"version": "0.3.0",
"private": true,
"scripts": {
"dev": "NODE_ENV=development next dev -p 3999",
"build": "next build",
"start": "next start",
"lint": "next lint",
"format": "prettier --write .",
"format:check": "prettier --check .",
"sandbox": "env-cmd -f .env.development ampx sandbox --stream-function-logs --profile vs2 --identifier truong",
"sandbox:delete": "ampx sandbox delete --profile vs2 --identifier truong"
},
"dependencies": {
"@aws-amplify/adapter-nextjs": "1.2.17",
"@aws-amplify/ui-react": "6.1.13",
"@aws-amplify/ui-react-storage": "3.3.2",
"@emotion/react": "11.13.3",
"@emotion/styled": "11.13.0",
"@fontsource/roboto": "5.1.0",
"@mui/icons-material": "6.1.0",
"@mui/material": "6.1.0",
"@mui/material-nextjs": "5.16.6",
"@mui/types": "7.2.15",
"@paypal/paypal-js": "8.1.0",
"@paypal/react-paypal-js": "8.6.0",
"@reduxjs/toolkit": "2.2.7",
"@vietnamvisa/vs2-react": "1.6.11",
"aws-amplify": "6.4.0",
"crypto-random-string": "5.0.0",
"dayjs": "1.11.13",
"lodash.concat": "4.5.0",
"lodash.difference": "4.5.0",
"lodash.filter": "4.6.0",
"lodash.groupby": "4.6.0",
"lodash.sortby": "4.7.0",
"lodash.sum": "4.0.2",
"lodash.sumby": "4.6.0",
"lodash.truncate": "4.4.2",
"next": "14.2.11",
"react": "^18",
"react-dom": "^18",
"react-redux": "9.1.2",
"schema-dts": "1.1.2"
},
"devDependencies": {
"@aws-amplify/backend": "1.2.1",
"@aws-amplify/backend-cli": "1.2.6",
"@types/lodash.concat": "4.5.9",
"@types/lodash.difference": "4.5.9",
"@types/lodash.filter": "4.6.9",
"@types/lodash.groupby": "4.6.9",
"@types/lodash.sortby": "4.7.9",
"@types/lodash.sum": "4.0.9",
"@types/lodash.sumby": "4.6.9",
"@types/lodash.truncate": "4.4.9",
"@types/node": "20.16.5",
"@types/react": "18.3.5",
"@types/react-dom": "18.3.0",
"ampx": "0.2.1",
"aws-cdk": "2.158.0",
"env-cmd": "10.1.0",
"eslint": "8.57.0",
"eslint-config-next": "14.2.11",
"eslint-config-prettier": "8.10.0",
"prettier": "3.3.3",
"typescript": "5.6.2"
},
"peerDependencies": {
"react": "^17.0.0 || ^18.0.0",
"react-dom": "^17.0.0 || ^18.0.0"
},
"packageManager": "[email protected]+sha512.73a29afa36a0d092ece5271de5177ecbf8318d454ecd701343131b8ebc0c1a91c487da46ab77c8e596d6acf1461e3594ced4becedf8921b074fbd8653ed7051c"
}
|
If I enable |
After some packages are updated, the other issue reported here got resolved #5801 But this issue still persist. This is the updated package.json: {
"name": "aws-amplify-gen2",
"version": "0.3.0",
"private": true,
"scripts": {
"dev": "NODE_ENV=development next dev -p 3999",
"build": "next build",
"start": "next start",
"lint": "next lint",
"format": "prettier --write .",
"format:check": "prettier --check .",
"sandbox": "env-cmd -f .env.development ampx sandbox --stream-function-logs --profile vs2 --identifier truong",
"sandbox:delete": "ampx sandbox delete --profile vs2 --identifier truong"
},
"dependencies": {
"@aws-amplify/adapter-nextjs": "1.2.18",
"@aws-amplify/ui-react": "6.3.1",
"@aws-amplify/ui-react-storage": "3.3.2",
"@emotion/react": "11.13.3",
"@emotion/styled": "11.13.0",
"@fontsource/roboto": "5.1.0",
"@mui/icons-material": "6.1.0",
"@mui/material": "6.1.0",
"@mui/material-nextjs": "6.1.0",
"@mui/types": "7.2.16",
"@paypal/paypal-js": "8.1.2",
"@paypal/react-paypal-js": "8.7.0",
"@reduxjs/toolkit": "2.2.7",
"@vietnamvisa/vs2-react": "1.6.11",
"aws-amplify": "6.6.1",
"crypto-random-string": "5.0.0",
"dayjs": "1.11.13",
"lodash.concat": "4.5.0",
"lodash.difference": "4.5.0",
"lodash.filter": "4.6.0",
"lodash.groupby": "4.6.0",
"lodash.sortby": "4.7.0",
"lodash.sum": "4.0.2",
"lodash.sumby": "4.6.0",
"lodash.truncate": "4.4.2",
"next": "14.2.11",
"react": "^18",
"react-dom": "^18",
"react-redux": "9.1.2",
"schema-dts": "1.1.2"
},
"devDependencies": {
"@aws-amplify/backend": "1.2.1",
"@aws-amplify/backend-cli": "1.2.6",
"@types/lodash.concat": "4.5.9",
"@types/lodash.difference": "4.5.9",
"@types/lodash.filter": "4.6.9",
"@types/lodash.groupby": "4.6.9",
"@types/lodash.sortby": "4.7.9",
"@types/lodash.sum": "4.0.9",
"@types/lodash.sumby": "4.6.9",
"@types/lodash.truncate": "4.4.9",
"@types/node": "20.16.5",
"@types/react": "18.3.6",
"@types/react-dom": "18.3.0",
"ampx": "0.2.1",
"aws-cdk": "2.158.0",
"env-cmd": "10.1.0",
"eslint": "8.57.1",
"eslint-config-next": "14.2.11",
"eslint-config-prettier": "8.10.0",
"prettier": "3.3.3",
"typescript": "5.6.2"
},
"peerDependencies": {
"react": "^17.0.0 || ^18.0.0",
"react-dom": "^17.0.0 || ^18.0.0"
},
"packageManager": "[email protected]+sha512.73a29afa36a0d092ece5271de5177ecbf8318d454ecd701343131b8ebc0c1a91c487da46ab77c8e596d6acf1461e3594ced4becedf8921b074fbd8653ed7051c"
}
|
Hey @nam-truong-le thanks for all the detailed information! I tried reproducing this with a simplified version of your It's possible this is related to the |
I switched to this simple callbacks, without const onUploadStart = () => {
debugger;
// dispatch(setStatus("loading"));
console.log("uploading");
};
const onUploadSuccess = () => {
debugger;
// dispatch(setStatus("idle"));
console.log("uploaded");
};
const onUploadFailure = () => {
debugger;
// dispatch(setStatus("failed"));
};
<FileUploader
onUploadStart={() => onUploadStart()}
onUploadSuccess={() => onUploadSuccess()}
onUploadError={() => onUploadFailure()}
maxFileCount={1}
path={`applicant-photos/${today}/`}
acceptedFileTypes={["image/*"]}
/> But it's still not working. |
Now I see that the component uploads the file twice to S3 and then somehow the two parallel processes breaking the whole thing? |
Since Logically, it also makes sense to flag the file as "uploading" as soon as |
I made this change #5808 locally and tested and it works perfectly. |
@nam-truong-le thanks for digging into this issue and creating a PR. We'll review as a team and follow up. In the meantime, I'm still curious why the file is being uploaded twice to S3. Can you provide your backend configuration (your call to Additionally, can you try uploading a file without the import React from 'react';
import { uploadData } from 'aws-amplify/storage';
function App() {
const [file, setFile] = React.useState();
const handleChange = (event: any) => {
setFile(event.target.files[0]);
};
return (
<div>
<input type="file" onChange={handleChange} />
<button
onClick={async () => {
try {
const result = await uploadData({
path: `applicant-photos/${today}/${file.name}`,
data: file,
}).result;
console.log("Uploaded file: ", result);
} catch (error) {
console.error("Error uploading file: ", error);
}
}}
>
Upload
</button>
</div>
);
} |
This is my storage config: import { defineStorage } from "@aws-amplify/backend";
export const storage = defineStorage({
name: `shopAppStorage-${process.env.AWS_BRANCH}`,
access: (allow) => ({
"applicant-photos/*": [allow.guest.to(["write", "read"]), allow.authenticated.to(["write", "read"])],
}),
}); |
I think it happens because the file gets sent to S3 and marked as "uploading" a bit too late. Before that happens, React triggers the hook again (for some reason I'm not sure of), and at that point, the file still shows as "queued." and it gets sent again. |
@nam-truong-le thanks for the information. Since you're consistently seeing this error, would you be able to provide a minimal reproduction? This ideally would be a Github repository that contains the minimum amount of code/dependencies that still results in this behavior. Make sure to remove any sensitive information, and let us know if you need further guidance with that. This will help us narrow down the cause and validate potential solutions since we haven't been able to reproduce on our end. |
Is it possible to get the pre-signed URL for a PUT request so that I can test the upload with e.g. fetch instead of xhr? |
My workaround:
It works well. |
@nam-truong-le we recently released a patch which should fix the duplicate upload issue which may be related to this issue, could you try upgrading and let us know if you're still seeing the issue? - https://www.npmjs.com/package/@aws-amplify/ui-react-storage/v/3.3.5 |
@nam-truong-le are you still experiencing this issue? |
Closing this issue as we have not heard back from you. If you are still experiencing this, please feel free to reply back and provide any information previously requested and we'd be happy to re-open the issue. Thank you! |
Before creating a new issue, please confirm:
On which framework/platform are you having an issue?
React
Which UI component?
Storage
How is your app built?
amplify gen2 nextjs template
What browsers are you seeing the problem on?
Chrome
Which region are you seeing the problem in?
Frankfurt
Please describe your bug.
In my app
onUploadStart
is fired butonUploadSuccess
not. Upload succeeds.What's the expected behaviour?
onUploadSuccess
should be fired.Help us reproduce the bug!
Please check the code snippet.
Code Snippet
Console log output
No response
Additional information and screenshots
No response
The text was updated successfully, but these errors were encountered: