Ckeditor | Ckeditor with mvc | Ckeditor with mvc .net | easy way to add the ckeditor in the Asp.net mvc
As we know that blogging website is very easy to develop. But if you want to use text editor for blog post. It will be very tricky to work with this. Simply Blog post are written in plain text for storing on the database. If you want some dynamic type of Blog posts then you would make sure that you have a text editor like ckeditor. Editor helps to put the data into a format and then you can put it in a post as it is. So here you are able to use the given code for storing the ckeditor data into database. Keep in mind you will face many errors. So don't give up. try try again at last you will get achievement.
So let's start
Controller
// POST: Blogs/Create
[ValidateInput(false)]
[HttpPost]
public ActionResult Create(BlogTable blogTable)
{
if (ModelState.IsValid)
{
try
{
// TODO: Add insert logic here
db.BlogTables.Add(blogTable);
db.SaveChanges();
return RedirectToAction("Index");
}
catch
{
return View();
}
}
else
{
return View();
}
}
View for Creating Post or Insertion
@using (Html.BeginForm("Create", "Blogs", FormMethod.Post, new { @id = "CreateForm"}))
{
@Html.AntiForgeryToken()
//
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
}
BlogTable
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
@Html.LabelFor(model => model.BlogTitle, htmlAttributes: new { @class = "control-label col-md-2" })
@Html.EditorFor(model => model.BlogTitle, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.BlogTitle, "", new { @class = "text-danger" })
@Html.LabelFor(model => model.BlogDescription, htmlAttributes: new { @class = "control-label col-md-2" })
@Html.TextAreaFor(model => model.BlogDescription, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.BlogDescription, "", new { @class = "text-danger" })
<script>
$(document).ready(function () {
CKEDITOR.replace('BlogDescription');
$('#CreateForm').on('submit', function () {
//get each instance of ckeditor
for (instance in CKEDITOR.instances) {
//update element
CKEDITOR.instances[instance].updateElement();
}
//set updated value in textarea
$('#BlogDescription').val(CKEDITOR.instances["BlogDescription"].getData());
});
});
class MyUploadAdapter {
constructor(loader) {
// The file loader instance to use during the upload. It sounds scary but do not
// worry — the loader will be passed into the adapter later on in this guide.
this.loader = loader;
}
upload() {
return this.loader.file
.then(file => new Promise((resolve, reject) => {
this._initRequest();
this._initListeners(resolve, reject, file);
this._sendRequest(file);
}));
}
// Aborts the upload process.
abort() {
if (this.xhr) {
this.xhr.abort();
}
}
// Initializes the XMLHttpRequest object using the URL passed to the constructor.
_initRequest() {
const xhr = this.xhr = new XMLHttpRequest();
// Note that your request may look different. It is up to you and your editor
// integration to choose the right communication channel. This example uses
// a POST request with JSON as a data structure but your configuration
// could be different.
xhr.open('POST', '@Url.Action("Uploadlmage", "Blogs",new { enctype = "multipart/form-data" })', true);
xhr.responseType = 'json';
}
// Initializes XMLHttpRequest listeners.
_initListeners(resolve, reject, file) {
const xhr = this.xhr;
const loader = this.loader;
const genericErrorText = `Couldn't upload file: ${file.name}.`;
xhr.addEventListener('error', () => reject(genericErrorText));
xhr.addEventListener('abort', () => reject());
xhr.addEventListener('load', () => {
const response = xhr.response;
// This example assumes the XHR server's "response" object will come with
// an "error" which has its own "message" that can be passed to reject()
// in the upload promise.
//
// Your integration may handle upload errors in a different way so make sure
// it is done properly. The reject() function must be called when the upload fails.
if (!response || response.error) {
return reject(response && response.error ? response.error.message : genericErrorText);
}
// If the upload is successful, resolve the upload promise with an object containing
// at least the "default" URL, pointing to the image on the server.
// This URL will be used to display the image in the content. Learn more in the
// UploadAdapter#upload documentation.
resolve({
default: response.url
});
});
// Upload progress when it is supported. The file loader has the #uploadTotal and #uploaded
// properties which are used e.g. to display the upload progress bar in the editor
// user interface.
if (xhr.upload) {
xhr.upload.addEventListener('progress', evt => {
if (evt.lengthComputable) {
loader.uploadTotal = evt.total;
loader.uploaded = evt.loaded;
}
});
}
}
// Prepares the data and sends the request.
_sendRequest(file) {
// Prepare the form data.
const data = new FormData();
data.append('upload', file);
// Important note: This is the right place to implement security mechanisms
// like authentication and CSRF protection. For instance, you can use
// XMLHttpRequest.setRequestHeader() to set the request headers containing
// the CSRF token generated earlier by your application.
// Send the request.
this.xhr.send(data);
}
}
function MyCustomUploadAdapterPlugin(editor) {
editor.plugins.get('FileRepository').createUploadAdapter = (loader) => {
// Configure the URL to the upload script in your back-end here!
return new MyUploadAdapter(loader);
};
}
ClassicEditor
.create(document.querySelector('#BlogDescription'), {
extraPlugins: [MyCustomUploadAdapterPlugin],
})
.then(editor => {
window.editor = editor;
})
.catch(err => {
console.error(err.stack);
});
@*class MyUploadAdapter {
constructor(loader) {
// The file loader instance to use during the upload.
this.loader = loader;
}
// Starts the upload process.
upload() {
return this.loader.file
.then(file => new Promise((resolve, reject) => {
this._initRequest();
this._initListeners(resolve, reject, file);
console.log(file);
this._sendRequest(file);
}));
}
// Aborts the upload process.
abort() {
if (this.xhr) {
this.xhr.abort();
}
}
// Initializes the XMLHttpRequest object using the URL passed to the constructor.
_initRequest() {
const xhr = this.xhr = new XMLHttpRequest();
// Note that your request may look different. It is up to you and your editor
// integration to choose the right communication channel. This example uses
// a POST request with JSON as a data structure but your configuration
// could be different.
xhr.open('POST', '@Url.Action("Uploadlmage","Blogs")', true);
xhr.responseType = 'json';
}
// Initializes XMLHttpRequest listeners.
_initListeners(resolve, reject, file) {
const xhr = this.xhr;
const loader = this.loader;
const genericErrorText = `Couldn't upload file: ${file.name}.`;
xhr.addEventListener('error', () => reject(genericErrorText));
xhr.addEventListener('abort', () => reject());
xhr.addEventListener('load', () => {
const response = xhr.response;
// This example assumes the XHR server's "response" object will come with
// an "error" which has its own "message" that can be passed to reject()
// in the upload promise.
//
// Your integration may handle upload errors in a different way so make sure
// it is done properly. The reject() function must be called when the upload fails.
if (!response || response.error) {
return reject(response && response.error ? response.error.message : genericErrorText);
}
// If the upload is successful, resolve the upload promise with an object containing
// at least the "default" URL, pointing to the image on the server.
// This URL will be used to display the image in the content. Learn more in the
// UploadAdapter#upload documentation.
resolve({
default: response.url
});
});
// Upload progress when it is supported. The file loader has the #uploadTotal and #uploaded
// properties which are used e.g. to display the upload progress bar in the editor
// user interface.
if (xhr.upload) {
xhr.upload.addEventListener('progress', evt => {
if (evt.lengthComputable) {
loader.uploadTotal = evt.total;
loader.uploaded = evt.loaded;
}
});
}
}
// Prepares the data and sends the request.
_sendRequest(file) {
// Prepare the form data.
const data = new FormData();
data.append('upload', file);
// Important note: This is the right place to implement security mechanisms
// like authentication and CSRF protection. For instance, you can use
// XMLHttpRequest.setRequestHeader() to set the request headers containing
// the CSRF token generated earlier by your application.
// Send the request.
this.xhr.send(data);
}
}
// ...
function MyCustomUploadAdapterPlugin(editor) {
editor.plugins.get('FileRepository').createUploadAdapter = (loader) => {
// Configure the URL to the upload script in your back-end here!
return new MyUploadAdapter(loader);
};
}
// ...
ClassicEditor
.create(document.querySelector('#BlogDescription'), {
extraPlugins: [MyCustomUploadAdapterPlugin],
// ...
})
.catch(error => {
console.log(error);
});*@
</script>
Comments
Post a Comment