Using WebView2 in DataFlex
Lesson 2 - Preparations
In the last series we looked at the properties that enable us to functionally style the WebVie2Browser control. During this course we will essentially be building a new Windows control based on a web technology… which requires some preparation. So, let’s start setting up our DataFlex workspace!
DEMONSTRATION
Create MDI Project
- First, I am going to open up the 20.1 studio
- Then I create a new workspace… We’ll name it “QuillEditorSample” and I am going to place it in my dev folder. Just let me create a new directory in here naming it the same
data:image/s3,"s3://crabby-images/d13f6/d13f642732b27240b3caeb78f6bf93693916dad0" alt=""
- Then create a new windows project naming it the same
data:image/s3,"s3://crabby-images/7c1d3/7c1d3f432e2f5170bc67163acc7542932e9ce67e" alt=""
- Lastly a new view naming it exactly the same again
data:image/s3,"s3://crabby-images/a3357/a335713b45d72f07be44d6cb5844a1d9b6452e05" alt=""
- And then if we press F5 we can see we got that up and running
data:image/s3,"s3://crabby-images/10fe7/10fe75cad4a48c20fded2d6c6f2584db4fe3e1b2" alt=""
Adding QuillJS
- Now we need to add QuillJS, as you can see, I have their Git page open here… we’ll go into releases…
data:image/s3,"s3://crabby-images/3ed39/3ed3994928141f77421dae29a7208fb6b747e59a" alt=""
- And, download the latest release from there. I am going to open it… and then extract that to the local AppHtml directory in our workspace.
data:image/s3,"s3://crabby-images/bdd6b/bdd6b1c3faa68d4df8caf56dcb863f3ad88d9d13" alt=""
- Now… let me move to our AppHtml directory and as you can see, we have the quill directory with a snow themed css and the minified core which we will need in a second.
data:image/s3,"s3://crabby-images/77f89/77f8960325a907df6ff240cb6494d9ffc95696fa" alt=""
- We are going to create a new index.html file. And, open that with Visual Studio Code. Then start off with the HTML5 doctype. And create entities for the header and body.
data:image/s3,"s3://crabby-images/fc721/fc721069d8d59de1d99ca307b6b3210eda527c90" alt=""
- Then we’ll add the snow themed css entry using a link stylesheet. And, we’ll need to add the minified-version of quill.js.
data:image/s3,"s3://crabby-images/a6a9b/a6a9b082fa1ede4c73d9a01e85d6e06d714d70cc" alt=""
Adding Class
- Now we are going to create a new class for our QuillEditor control. So, first I’ll stop debugging our application…
- And… start of by creating our new class, for now based of the cObject superclass. And, we’ll name it ‘cQuillEditor’.
data:image/s3,"s3://crabby-images/7389f/7389ff7c3716262574c8f7b6197c29f0e352f149" alt=""
- Change that ‘Use UI’ to ‘Use cWebView2Browser’ and let’s copy and paste that to the base class too.
- Lastly, we won’t need that End_Construct_Object so let’s get rid of that.
data:image/s3,"s3://crabby-images/8ca40/8ca401f51f92bfdb0129d3331b38204a6d0d4358" alt=""
- Then create a new object, but first include the new QuillEditor package….
- I’ll create a new object, and let’s steal the size for now…
- Going back to the designer, let me change the size… no… I guess we’ll just size it to the container for now.
data:image/s3,"s3://crabby-images/e2678/e267868fefc68737a640c61336f5cf8bb22cb6ad" alt=""
- And… saving that we can now see if I start debugging that literally nothing appeared
- We’ll get into that by the next part so I hope you’ll stay with me.