How to pass docx as byte[]

7 posts, 0 answers
  1. Stefania
    Stefania avatar
    107 posts
    Member since:
    May 2013

    Posted 09 Mar 2015 Link to this post

    Hi,
    How can I convert a radeditor into byte[]?
    I need to pass something to my webservice and then save it as docx.
    Is it possible?
    Thanks
  2. Ianko
    Admin
    Ianko avatar
    1535 posts

    Posted 11 Mar 2015 Link to this post

    Hi Stefania,

    The RadEditro's content always returns String value. Therefore, the answer is to convert the string into a byte array.

    This on other hand is a general .NET matter. I suggest looking for the answer in public forums and MSDN resources related to general C# or VB techniques. After a quick search, I found this thread, which might help you continue further your research--How to convert the string to byte in c# (https://social.msdn.microsoft.com/Forums/vstudio/en-US/08e4553e-690e-458a-87a4-9762d8d405a6/how-to-convert-the-string-to-byte-in-c-).

    Regards,
    Ianko
    Telerik
     

    Check out the Telerik Platform - the only platform that combines a rich set of UI tools with powerful cloud services to develop web, hybrid and native mobile apps.

     
  3. UI for ASP.NET Ajax is Ready for VS 2017
  4. Stefania
    Stefania avatar
    107 posts
    Member since:
    May 2013

    Posted 13 Mar 2015 in reply to Ianko Link to this post

    Hi,
    I tried to do this:

    <telerik:RadEditor ID="editor1" runat="server" EditModes="Design">   </telerik:RadEditor>

    On save button
    System.Text.ASCIIEncoding encoding = new System.Text.ASCIIEncoding();
    byte[] docBytes = encoding.GetBytes(editor1.Content);
    myService.Save(docByte);

    and then in my webservice
    using (FileStream fs = new FileStream(GetAttachmentsPath() + filename, FileMode.Create))
    {
            fs.Write(docBytes.Value, 0, docBytes.Value.Length);
            fs.Flush();
            fs.Close();
    }

    When I open the .docx this is the result

    <p>Test</p>
    <img alt="" src="

    .....
    />

  5. Stefania
    Stefania avatar
    107 posts
    Member since:
    May 2013

    Posted 16 Mar 2015 in reply to Stefania Link to this post

    Hi,
    I found the solution but I still have a problem with the copy and pasted image

    private Byte[] contentEditor ;
     
     protected void editor1_ExportContent(object sender, EditorExportingArgs e)
            {
               ExportType exportType = e.ExportType;
     
                if (exportType == ExportType.Word)
                {
                    string exportedOutput = e.ExportOutput;
                    Byte[] output = Encoding.Default.GetBytes(exportedOutput);
     
                    DocxFormatProvider docxProvider = new DocxFormatProvider();
                    RadFlowDocument document = docxProvider.Import(output);
     
                    Header defaultHeader = document.Sections.First().Headers.Add();
                    Paragraph defaultHeaderParagraph = defaultHeader.Blocks.AddParagraph();
                    defaultHeaderParagraph.TextAlignment = Alignment.Right;
                    defaultHeaderParagraph.Inlines.AddRun("This is a sample header.");
     
                    Footer defaultFooter = document.Sections.First().Footers.Add();
                    Paragraph defaultFooterParagraph = defaultFooter.Blocks.AddParagraph();
                    defaultFooterParagraph.TextAlignment = Alignment.Right;
                    defaultFooterParagraph.Inlines.AddRun("This is a sample footer.");
     
                   contentEditor = docxProvider.Export(document);
                }
                e.Cancel = true;
            }
     
     protected void SendButton_Click(object sender, EventArgs e)
            {
                Dictionary<string, byte[]> files = new Dictionary<string, byte[]>();         
                editor1.ExportToDocx();        
                files.Add(editor1.ExportSettings.FileName+".docx", contentEditor);
    etc...
    myService.Save(...);
    }

    I tried on your demo and it seems there is the same problem
    http://demos.telerik.com/aspnet-ajax/editor/examples/import-export/docx-import-export/defaultcs.aspx

    When you open the exported docx the image is 1px * 1px

    How can I keep the right size of the image?
    Thanks
  6. Ianko
    Admin
    Ianko avatar
    1535 posts

    Posted 16 Mar 2015 Link to this post

    Hi Stefania,

    On my end exporting of images occurs as expected.

    It would be helpful if you could provide more details about the the source of the pasted images, how it is pasted, and if possible to described the problem in steps, so to be able to accurately understand the situation.

    Regards,
    Ianko
    Telerik
     

    Check out the Telerik Platform - the only platform that combines a rich set of UI tools with powerful cloud services to develop web, hybrid and native mobile apps.

     
  7. Stefania
    Stefania avatar
    107 posts
    Member since:
    May 2013

    Posted 16 Mar 2015 in reply to Ianko Link to this post

    This is what I'm doing:
    - Press "stamp" on the keyboard
    - CTRL+V on the demo

    or instead of "stamp" button using the window capture instrument and then press the copy button

    - Export docx
    - open the saved file with word 2003 and 2007

  8. Ianko
    Admin
    Ianko avatar
    1535 posts

    Posted 19 Mar 2015 Link to this post

    Hello Stefania,

    Thank you for getting back with these details.

    The encountered situation is more or less expected. The browser can render the base64 image with proper size. Although, MS Word content needs specific width and height values to render the image. 

    Therefore, a possible solution is to implement either  Note that in order the image to be rendered in MS Word, the DOM Width and Height attributes should used.

    Regards,
    Ianko
    Telerik
     

    Check out the Telerik Platform - the only platform that combines a rich set of UI tools with powerful cloud services to develop web, hybrid and native mobile apps.

     
Back to Top
UI for ASP.NET Ajax is Ready for VS 2017