This plugin adds a button to your TinyMCE editor which uploads selected file to your Amazon S3 bucket.
Add dist/tinymce-aws-s3-upload-plugin.min.js
in to your html.
Or
npm i tinymce-aws-s3-upload-plugin
import 'tinymce-aws-s3-upload-plugin'
-You can skip this part if you done with the authentication to AWS.
Add https://cdnjs.cloudflare.com/ajax/libs/aws-sdk/2.858.0/aws-sdk.min.js
in to your html.
AWS doesn’t recommend to use them on front-end code(js) because if somebody take a look and get these keyId and secretKey they can reach your AWS resources.Here you can find more information.
{
"Version": "2012-10-17",
"Statement": [
{
"Action": [
"s3:PutObject",
"s3:PutObjectAcl"
],
"Effect": "Allow",
"Resource": [
"arn:aws:s3:::*"
]
}
]
}
tinymce.init({
selector: 'textarea',
height: 500,
menubar: false,
// Plugin configuration
plugins: 'AwsS3Upload',
toolbar: 'AwsS3UploadButton',
Awss3UploadSettings: {
buttonText: 'Upload to AWS S3', // optional
folderName: 'YOUR_FOLDERNAME', // optional
bucketName: 'YOUR_BUCKETNAME',
awsAuth: { // optional if auth done in html before
region: 'YOUR_BUCKET_REGION',// for example : 'us-east-1'
accessKeyId: 'YOUR_ACCESSKEYID',
secretAccessKey: 'YOUR_SECRETACCESSKEY'
},
progress: {
bar:true, // optional default=true
callback: progress => { // optional
console.log(progress)
},
errorCallback: err => { // optional
console.log(err)
},
successCallback:(editor,url) => { // optional
// For example
switch(url.split('.').pop()){
case 'png':
case 'jpg':
case 'jpeg':{
editor.execCommand('mceInsertContent', false, `<img src="${url}" style="display: block;margin: 0 auto;text-align: center; max-width:100%;" />`);
break;
}
default:{
editor.execCommand('mceInsertContent', false, `<a href="${url}">${url}</a>`);
}
}
}
},
secondFileSelectedBeforeFirstUpload:{ // optional
callback:()=>{
alert('You cannot upload because first upload is progressing');
}
}
}
});
Clone repo & navigate into it
npm i
npm run development
& browse http://localhost:3000
Thanks for reading.
Thanks for reading.