/OutStagram

Apache License 2.0Apache-2.0

OutStagram

この演習では、Instagramと同様の機能を持つアプリを作成します。

必要なライブラリ

このアプリを作成するためには、いくつかのライブラリをインストールする必要があります。 Service Studio のウィンドウ上部に forge というタブがあり、OutSystems のオープンソースコンポーネントリポジトリにアクセスすることができます。 この forge から "camera" を検索して、プラグインをインストールします。

画像1 画像2 画像3

いくつかのアプリがインストールされているのが確認できるはずです。 アプリが表示されていない場合も、非表示オプションが有効になっている可能性があるだけですので気にしなくて大丈夫です。

次は、Image Utils Reactiveです。

1

Again you should see the installation taking place.

OutStagram Files

Download the following files: ● Logo ● Application

Install OutStagram

On Studio menu, select Environment and Open Files 2

Flip the type to OutSystems Application Pack and select OutStagram.OAP And proceed with the installation.

In the end you should have something similar to…

3

Create the application

In OutSystems, we can start developing apps from predefined templates. Templates can contain screen layout definitions, CSS, and other logic and data. Templates encourage the reuse of important components and can help create a consistent look and feel across multiple apps. ● Create an App

● Start from scratch

● Select Phone App 4

● Give a name to the application ● Upload the logo

● Create Module 5

You should see something similar to this

Reference OutStagram Core

We will be needing some pre-made methods that exist on the OutStagram core module. 6

Click the manage dependencies icon Search and select Image_Utils_Reactive and check the box for the Resize method. Repeat the process and search and select the CameraPlugin and select the TakePicture method. 7

Repeat the process and search and select the OutStagramCore and then check all the boxes, including the server actions and entities. Click the refresh all button (if enabled) and then the apply button. 8 Go ahead and publish the application for the first time using the one click publish button. Give it a few seconds to finish. When done you should see a similar screen to this: 9

Creating the Home screen

Drag and drop an empty screen to the Main Flow 10 And then select empty screen and call it Home and press create screen 11

The screen already has some structure to it, this is due to the standard empty template and you can always design your own. 12

Now let's add some data to the screen. Flip to the data tab, expand OutStagramCore and drag and drop the post entity to the content area. 13

The platform tries to understand what you are trying to do. In this case when dragging an entity to a screen is interpreted as if you want to display that data so an accelerator kicks in and does several things for you, all of which you could do step by step manually. ● Created a query to grab the data from the Post entity ○ ● Created a pagination so that all the data is not loaded at the same time ○ ● Created a list widget to support the data iteration ○ ● Created a list item with the single item content ○ 14

15

Arranging the data display

Select the image, select the container around it and expand to the full width of the screen. 16

Then select the image again and delete the style class. 17

Delete all attributes from the screen except Description, Date and User Name and re-order them to show User Name, Description and Date. Also remove the bold classes from Description 18

Sort the data

We want to see the latest posts first so let's sort the data. If you do not see the GetPosts query flip the view back from the widget tree 19

Publish the app

You should be ready to publish the application. Put a nice title on your screen and click the big green One Click Publish button. 20 The publishing process consists of several steps. It sends your code to the server and does the appropriate check in, it generates and compiles standard code from your visual model and finally it deploys the application to your server making it available for use.

Testing the Application

You can now test your application in a few different ways. Using your desktop browser, just click the big blue button which will open a browser with a frame simulating your phone form factor. 21

The other option is to test the application on your phone as a PWA (Progressive Web App). In order to do so we need to configure it. 22

Now you just need to scan that QR Code or click the open in browser link and type the url on your phone. A third option is to generate a native cordova application. This will allow you to download an IPK or IPA (Android/IOS package) which can be installed on your phone or sent to the app stores for distribution. If you have an Android phone, go ahead and click the and then the generate app button. A few minutes later you should get another QR Code that will allow you to download and install the App to your Android phone. Depending on your phone security settings you may need to trust yourself as an application publisher. 23 If you have an IOS phone, Apple makes things a bit more complicated. You will need: ● An Apple Developer License ● To choose your build type ● Generate you publisher certificate according to your profile ● Generate a provisioning profile for your app If you want to know more about publishing OutSystems applications for IOS, take a look at the documentation. Finally whatever method you choose, you'll be presented with a login screen. You can login using your community email and password, or you can use one of the test users created for this application (their password is outsystems): ● roz ● mike_wazowski ● James_sullivan 24

You should see something similar to this. 25

Refining the Home Screen

Implementing a like status Every social media app needs a like button. In our example we'll use a heart to allow the user to like and give a visual representation. Flip to the widget tree, expand content, list, list-item, content and drag and drop an if right between the image-container and the other Container.

An if is a visual widget that displays the upper square if the condition is true and the lower one if false. Next search the widgets for icon and drag it into the upper square of the if. 26

Repeat the process for the lower if square, but this time select an empty heart. And of course we need a red heart, not a blck one. So select the full heart and choose a nice red color. The style editor is a quick way to change the style of an element. However you can define classes using pure CSS. 27

Now we need to collect the information for the likes from the database. Our initial data fetch is only returning the posts, we also need to get the likes for each post. So go ahead, flip the widget tree and double click the query. Then flip to the sources, click the add source and select PostLike. 28

Now let's take a look at how the entities relate to each other. 29

All posts Only With users and posts Only With likes. But this is not what we want… We want all posts Only With users and posts With or Without likes. And beyond that if a post does have a like then show me only my likes. So flip the join type to With or Without and double click the expression to type the missing condition "and PostLike.UserId = GetUserId() ".

When you're done go back to the home screen by either clicking the or double clicking the Finally select the if and set the condition to " GetPosts.List.Current.PostLike.Id <> NullIdentifier() ". 30 You should be able to publish your application by using the Implementing the like button Now let's implement the code necessary to accept the user input when either hearts are pressed. Right click the home screen and select add client action and rename your action to LikeOnClick. Create a new input parameter by right clicking on the LikeOnClick ( ), name it PostID and make sure the parameter type is Post Identifier. 31

Now flip to the logic tab, locate the ToggleLike action and drag it to the line of your flow below the start. Fill in the parameters for UserId and PostId. 32

Next grab a refresh widget, drop it on the line below the ToggleLike and select the GetPosts query. 33

Now go back to the Home screen, right click the if and link it to the LikeOnClick action. Fill in the PostID property with " GetPosts.List.Current.Post.Id ". 34

Go ahead publish the app and then click the test button . You can now interact with the heart by clicking on it. 35

36

Implementing a Like counter

We also want to have the total number of likes for each post. For this feature we'll use a slightly different technique by introducing blocks. In OutSystems blocks are pieces of UI that can be reused multiple times on many screens. Creating the Block Double click the , drop a block next to the home screen, rename it to Likes and open it with double click. Then add a new parameter named PostID and make sure it is of type Post Identifier. 37

Next let's grab from the database the number of likes for a particular post. Right click on the Likes block and select Fetch Data from Database. 38 Now, click on the screen and select the PostLike entity. 39 Now, we filter the likes for the PostID passed through the parameter. 40

Displaying the Like count

Back to the Like block, grab an expression and select the count under the query. 41

Change the example to 99 and type " likes" using the keyboard next to the expression. 42 Select the expression and add 10px of left margin from the styles tab. 43

Using the block on the Home screen

On the home screen we need to adjust the UI to make room for the likes counter. Flip to the widget tree, locate the container below the link, flip to the styles and set the width to Fill. 44

The next step is to flip back the widget tree, grab the like block, drop it next to the heart and fill in the PostID parameter. 45

Go ahead publish the app and then click the test button . You can now interact with the heart by clicking on it and should see the counter being updated. 46

Creating a new post

The next step is to make a screen where the user can create a new post, taking a picture and typing some content.

Taking a picture

Navigate back to the and drag a new screen into the canvas. 47 Select the empty template and name the screen NewPost. 48 Fill in the title and drag a new icon to the upper left placeholder. Choose the camera icon. 49 Right click on the camera icon and choose new client action. 50

Rename the action to CaptureImage and double click it to open the code. Also create 2 new local variables. Picture with type Binary Data and Description with type Text. 51 Now let's implement the logic to take a picture and store it. Flip to the logic tab and grab the TakePicture action dropping it into the flow. While you're at it grab an If and drop it below the TakePicture. Aslo swap the if connectors with right click, so that the true branch continues down. On the If condition select TakePicture.Success. 52

Next, drop a message next to the If and link a false branch from it. Drop an End below the message and link from it. Select the Message and choose TakePicture.Error.Message. 53 Now we are going to reduce the picture size to save some bandwidth. Drag the Resize action below the If into the true branch. On the image parameter select TakePicture.ImageCaptured and on the MaxWidthOrHeight set it to 800. 54 Finally let's assign the resized image to the local variable picture. 55 Go ahead publish the app

Creating the UI

Navigate back to the NewPost screen by double clicking Locate the Form, Image and TextArea widgets and drop it on the screen. Set the Image property type to Binary Data and the Image Content property to Picture. Set the TextArea property Variable to Description 56 We also need some buttons to save or cancel the post. Drag a container below the text area, then drag 2 buttons inside the container. Change the buttons name to Post and Cancel and make the post button bigger in length. 57 Select the Cancel button and set its On Click property to MainFlow\home 58 Select the Post Button and set its On Click property to New Client Action. 59

Saving the post to the database.

Flip to the logic tab and locate the NewPost action under Server Actions/OutStagramCore and drop it below the If. On the properties set the UserId to GetUserId(), Picture to Picture and Description to Description. Drag a Destination widget on top of the End node and choose Main Flow/Home as the destination property. 60

Linking the New Post Screen

All we need to do now is to have a way for the user to access the new post screen from the home screen. Navigate to the Home screen and drop an icon on the top left placeholder. Choose the plus sign as the image. Also right click on the icon and choose Link to, MainFlow\NewPost. 61

Go ahead publish the app

Testing the app

Because of the camera it is best to test the app on a mobile phone and because this is a PWA application you can use it without any installation. Navigate to the main tab, switch to the distribute tab and scan the progressive web app QR Code. Or just type the URL directly on your phone. 62

Testing on the desktop browser You can still test on your desktop browser. The experience will be a bit different since the browser will ask you for a file when you try to take a picture. 63

64

What's Next? This was a slightly simplified version of the exercise and you can check out the full version at the OutStagram application. 65

66

Check out the differences and implement them on your app. 67