HCL Volt MX – een volgende stap in low-code development.

Eerder in mijn blog sprak ik al over HCL Volt, platform waarin de zogenaamde ‘Citizen Developer’, iemand zonder IT achtergrond, toch een mooie toepassing kan bouwen.

Deze maand heeft HCL zijn volgende stap in het low-code development gamma aangekondigd: HCL Volt MX. Dit is geen opvolger of uitbreiding voor Volt, maar wel een ontwikkelomgeving voor IT professionals om vlot nieuwe toepassingen te maken.

MX staat voor Multi-Experience. HCL Volt MX laat dan ook toe om – binnen dezelfde omgeving – te gaan ontwikkelen voor verschillende platformen, van computer tot smartphone, maar ook voor websites, wearables en IoT toepassingen.

Volt MX belooft ook om de achterliggende complexiteit die er is bij het koppelen van verschillende omgevingen te verlichten, zodat de software ontwikkelaar zich kan focussen op de data, workflow en business processen. Bijkomend wil Volt MX de mogelijkheid bieden om Virtual en Augmented Reality, chatbots, Artificiele inteligentie en nog meer te integreren in je eigen toepassingen.

Met Volt MX wil HCL de concurrentie aangaan met Outsystems, Mendix en Microsofts’ Xamarin.
Volgens HCL insiders zijn de sterke punten van Volt MX:

  • De prijssetting
  • Built-in integratie met Foundry Layer
  • Vooraf geconfigureerde connectors met verschillende omgevingen
  • Multi Experience support voor IoT, wearables, Progressive Web-Apps en VR/AR
  • De snelheid waarmee je een applicatie kan ontwikkelen

Wil je meer weten over Volt MX, neem dan een kijkje op de HCL website of schrijf je in voor de sessies over Volt MX op HCL Digital Week 2020.

Als uitsmijter nog het Volt MX promofilmpje van HCL Digital Solutions:

Designing for Nomad (Android)

I’ve been playing around with the Nomad Client for a while now. Most demos you find are built for  iOS devices. However, I’m (un)fortunate to have an Android phone.
Based on my experiences, I rebuilt Theo Heselmans’ Wine Tastings App to guide you through specific issues I encountered while developing for Nomad Android.
Please have a look at this project before reading further. You need to know the design of the Wine Tasting App (Wine App in short) to understand most of my examples.
This article is not for Android only. Some of the issues I encountered happen also on an iOS device, so this blog might help Apple lovers as well.

I know this is a long post. Keep on reading until the end, because there are a lot of examples and best practices I want to share with you.


Using @Platform([Specific]), you get information on the device you are running on. The info you get on an iOS device is different from an Android device (and a Windows device for that matter).
When you run @Platform([specific]) on iOS, you get something like:
“iOS” : “13.1” : “iPad” : “iPad11,4” on an iPad
or “iOS” : “13.1” : “iPhone” : “iPhone10,6” on an iPhone
For an Android Phone, I get
“Android” : “10” : “phone” : “359,678”
I have no Android Tablet available for testing, but i assume that it would be something like
“Android” : “10” : “tablet” : “359,678”. Please correct me if I’m wrong.
On Windows devices, @Platform will again return something different.

Unfortunately, you get no information on the size of your device, nor if you use it in Portrait or Landscape mode. This would be interesting information and hopefully HCL will add it in further releases.
For the Wine App, 2 different UI are defined, one for phone and one for other (bigger) devices. Using @Platform can help to decide the device type. For example, to decide the subform to use on the ‘Tasting’ form, this code is used:

small := "_Small";
large:= "";
Platform := @Platform([Specific]);
suffix := @If(
Platform = "phone";small;
Platform = "iPhone";small;

@If(@Environment("wtPreview") = "Yes":"";"SubPreview";"SubEdit")+suffix

I use similar code throughout the application to do device specific actions.

Form development

The Floating Form

One of the most annoying things in Nomad is the ‘floating form’. When you scroll up and down in a form and accidentally move your finger a bit sideways, the form starts scrolling horizontally and it is very hard to get it centered again.

The form scrolls horizontally while it shouldn’t.

Luckily I found a solution for that, but it takes a few steps.
When you create a form or subform, the first thing to do is to set the margin to 2cm (0.788”) instead of the default. This will make sure the left edge of the form is exactly at the left side of the screen on your mobile device.

Reset the default settings

Then create a single row, single column table that fits with margins.

You can set the border to 0 to make it nicer on the screen. Make sure you do not set any row/column spacing.

I suggest you create an inner table, again with 1 row and 1 column and add a small row and column spacing to this table. This is to avoid that your form content is glued to the edge of your screen.

Now it is time to start adding content to your form. It is important not to set any fixed widths or at least use a width that will certainly fit on a screen. Be careful with a table containing multiple columns with images or a radio/checkbox where you put multiple options on one row.
Note that testing on one device does not guarantee it will work on all devices. Android phones come in a lot of sizes and every device has its own maximum width.

If all goes well, you should have a form that does not scroll sideways. If you played around with complex form design and tables, you know that it can be frustrating. Designing for smartphones does not make it easier. So make sure you test regularly to avoid that you have to start over again.

Dialog actions

The dialog lists on an iPhone show really nice and integrated in the OS. But on Android, the dialog list is a bit clumsy. The selection part is shown in a list on the left of the dialog and the OK and Cancel buttons are shown on the right. Also, the list items are rather small. It is hard to select an item, especially when there is a lot of text in it.

The selection area is small.

Therefor, I created my own dialog box, using a little bit of lotusscript and a form. It can handle single and multi selection. My dialog looks like this:

Unfortunately, it is not possible to change the font style of the list boxes I used but at least, the selection area is wider and you can add a custom title as a bonus.

I also hid the entry helper button on each dialog list. Since I use a custom dialog, I don’t need the drop down arrow and I don’t like it that the button is floating on the right side of the data and thus it’s place depends on the amount of data in the field. I prefer all my selection buttons at the same width. You can still use the default dialog by double tapping on the field.

Display entry helper button is unchecked.

Field Labels

In the Wine App, the labels were next to the fields. Although this saves space in height, some fields became too small to show the data on one line on my device. Therefor I put the labels above the fields. This gives more room for the data, but requires more vertical scrolling to see everything.

Inspired by Material Design’s filled text fields, I only set the bottom border of the cell containing a fields instead of using a filled table cell. Both options are equal, it’s up to your preference. Note that in the design, I always use the actual field in edit mode (in an underlined cell) and a display field in read mode (non-underlined cell). In designer, it looks like this:

In read mode, the form looks like this:

And this is edit mode


For now, the Nomad Client on my Android device does not support (true type) fonts. So don’t bother changing your font to Tahoma, Verdana, Arial or any other font. It will look different on your device anyway. Stick with the ‘Default Sans Serif’ or ‘Default User Interface’ font and you will be fine. Other font settings (bold, underline, italic, size) work fine.
Furthermore, make sure you use a large enough font size (I suggest 12 instead of the default 10).


Categorization and columns

In a lot of (older) Notes applications, you see views containing a lot of data. Sometimes they even look like a spreadsheet. This is not useful on mobile devices. Try to avoid that users have to scroll horizontally. Sometimes it is necessary, but note that you cannot lock the first columns like you can in Excel, so you will loose context.

I’m sure this view won’t fit on your mobile device

As Theo already did in the Wine Tastings, avoid categorized views. Although seasoned Notes users are accustomed to it, it works kind of clumsy on a smartphone. Using embedded views showing a single category works better. Furthermore, the white space you get from the indentation is lost space for other data.

The multi-line row

You can put data on multiple lines in a rows by using multi-value columns with a New Line as separator. This allows you to have more data on the small screen. As a bonus, a row becomes larger, which makes it easier to click.

Name, Region and Vintage Year are shown in one row.

To avoid confusion, it is important that every value (name, region or year) does not wrap to the next row. Therefore I limit each line (= value) to a number of characters, depending on the width of your column. This all depends on your data set, of course. If a lot of rows start with the same characters, it can become difficult to see differences.

Note that there is still a bug in Nomad Android that makes it a little harder using this technique. If the combined data of values fit on one row, Nomad will force them to one row, regardless of the newline for multiple values. This is no issue on iOS as far as I know.

The data in the red rows are cropped to one line

I add a number of blanks as filler to add to the field values to fix this.
Hopefully this will be solved in one of the next releases, but for now, you can avoid it using this snippet:

maxlength := 30;
vals := name : region : @Text(Year);

repeat := @Repeat(" ";maxlength; maxlength);
	tmp := vals[i] + repeat;
	val :=  @If(@Length(vals[i])>maxLength;@Left(vals[i];maxLength) + "...";@Left(tmp;maxLength));
     result := @If(result = ""; val;result:val)

Using previews

Using previews in your application is another way to show more info on a specific row. I changed the preview of the Wine App for two reasons:

First, I wanted to avoid people having to scroll to see data. On my device, the large flag prevented me to see all the data in the preview.

Secondly, I made the preview more compact to show the same data with less height. On smaller devices, previews, headers, category selectors and so on can take so much space that the actual view data lacks space.

The preview shows a lot of info without taking too much place.


As you can see in some screenshots above, I changed the slider bar in the original Wine App to smiley icons. It’s not that I don’t like the slider, but it was to wide to see the rating without having to scroll.
The icons I chose are personal taste, but the main idea is to use icons that use less width.

Icons can help you to put more info on your screen. Use small icons that don’t use a lot of width. If you use the multi-line technique as described above, you even use icons that are a bit larger.

Example of larger icons with
multi-line technique.

The FAB (Floating Action Button)

In Domino/Notes 10 and higher, you can use the FAB icon instead of an actual button. Although this might be handy in some applications, I chose not to use it here.
The reason I didn’t use it, is not because I don’t like the icon (which I don’t), but mainly because it still acts a little buggy on Android devices. The button does not stay at the bottom of the view on my device. Sometimes it is shown over the preview or in the middle of the view.

The FAB is kind of jumpy.

Of course, these are teething problems which will hopefully be solved in a next release.

Another reason not to use the FAB button is because it is not (yet) available on forms and I like form and view actions to be consistent.

Device width

Keep in mind that each device has its own width. This can become annoying in combination with the fixed size of your columns. I would suggest to extend the last column to window width and optimize for smaller devices. But this might not be ideal for your application. In general, try to avoid that people have to scroll sideways to see data.

Also note that a larger device does not necessarily mean that you can see more. It also depends on the pixel density (pixels per inch) on each device.

Frames and navigation

The header bar containing the window tabs in Nomad is very small and it becomes too crowded really fast.

To avoid the opening of a new tab on every click, some redesign is necessary.

@SetTargetFrame is your friend

You can use this by using @SetTargetFrame(<framename>) to set a target frame before opening another frameset, page or view. This way, it will open in the frame instead of a creating a new tab.

Redesigning navigation

If you click on a navigation image of the Home Page in the Wine App, a new tab is opened with the view you selected. You can go back to the home page by closing the view tab or clicking on the Home tab in Notes.
Of course, when you open the view in the same frameset, there is only one tab in Notes and you have to create another way of navigating back to the home page.

I left the original behavior for the desktop/tablet version. For the phone version, I redesigned the navigation to use one single frameset to use the homepage and views.

Main navigation

HomeFS is the frameset opened when launching the application. It contains only one frame.
Using a computed value for the frame content, you can open a different page, depending on the device you work on.

Instead of opening the page ‘HomeSmall’ for phone/iPhone, another frameset (HomeFS_Small) is opened within HomeFS. This is done using the @Platform snippet I mentioned above.

HomeFS_Small is a frameset containing two frames. One frame on top named ‘Header’ containing a page ‘Home_Small_Header’ and one main frame called ‘MainSmall’ containing the page ‘Home_Small’.

HomeFS_Small inner frameset

The frame ‘MainSmall’ is where the magic happens, Pages and other framesets will be targeted in here using @SetTargetFrame.

In the ‘Home_Small’ page, the different tiles all have similar formula’s opening a frameset for that specific view; after targeting ‘MainSmall’

@Environment("wtTitle";"Wines by Vintage");

‘Home_Small_Header’ is a page containing only the action bar. The action bar contains a left aligned Home action, showing the Wine App icon. This action opens ‘Home_Small’ in ‘MainSmall’, similar to the code above. Right aligned, there is an action ‘Menu’ containing two sub-actions; one to create a new tasting and one to exit the application.

Updated Home Page

Vintage Year Navigation

Because of the changes I made, the Year selector on the ‘WinesVintage Header_Small’ form didn’t work anymore. The NotesUIWorkspace.reloadwindow() in the Exiting event of the field caused the complete window – thus the HomeFS frameset – to refresh; resulting in showing the homepage again instead of the updated view. The goal was to only reload or reopen the form containing the embedded view, to show the rows for the newly selected category.

You cannot open a form in a frame using formula or lotusscript. So I created a frameset (YearVintage_Small_Inner) containing only the form loading the embedded view. By reopening the frameset, the form (creating a new document) is loaded, containing the embedded view showing the newly selected category.

Sub Exiting(Source As Field)
	Dim session As New notessession
	Dim ws As New NotesUIWorkspace
	Dim doc As NotesDocument
	Set doc=ws.CurrentDocument.Document
	'Setting the year as session variable in Notes INI
	Call session.setenvironmentvar("wtYear",doc.Year(0))
	'Refreshing this document to update counter	
	Call ws.CurrentDocument.Refresh
	'Setting the target frame (in YearVintage_Small frameset)
	Call ws.SetTargetFrame("Main")
	'Reopening the inner frame causing the form with embedded view to reload
	Call ws.OpenFrameSet("YearVintage_Small_Inner")
End Sub

I also updated the arrow navigators using @setTargetFrame to refresh the Main frame on the inner frameset.

Continent/Country Navigation

The ‘Continents_Small’ frameset is removed. Instead I open a form ‘World_Small’ in the ‘MainSmall’ frame (‘HomeFS_Small’ frameset) to show the map.
The continent/country navigation was one one form, containing both category selectors and the embedded view. Although this works fine and is an easier approach than working with different frames and reloading them as was done for the Vintage Year navigation, I updated the navigation to make it similar to the Vintage Year approach.
The main reason for this is to show a document preview below the view.

I deleted the continent field, because both continent and country fields did not fit well on my screen.
Instead I used a Map Icon to go back to the World Map to select another continent.

Next steps

The tasting form works better now on an Android Phone. However, opening a Tasting document does not open in the same frame. It opens a new tab for each document.
Another issue with the Tasting document is that you have to scroll back to the top when you switch sections (Info, Notes, Label, …). I haven’t found a way to provide a ‘go back to top button’ yet.

Final notes

An important thing to keep in mind when designing an application for Nomad mobile devices is that there is a wide variation in screen resolutions and sizes.
Test your UI on many devices (Android, iPhone and other) to make sure it looks good on all of them.
Screenshots in this article are made with a Nokia 8.1.

Note that every design change does not show immediately on your Android device. To see the result of a design change, you’ll have to close all tabs of the application in Nomad and reopen the app by clicking on the workspace icon.

Some changes I made to Theo’s original application are personal taste and this does not detract from the work already put in the application. I always tried to explain my choices, but feel free to discuss when you think otherwise.

Congratulations, you reached the final paragraph of the article. Thanks for staying with me until the end. As you can see, you can create beautiful, modern looking apps from a Notes database, working on Windows (desktop), iOS and Android. Happy coding…

Download Wine App Android

HCL Domino Volt officiële release

Ik heb al een aantal keren geschreven over Volt, het low-code platform van HCL. En nu is het ook officiëel gereleased door HCL.

Traditionele app-ontwikkelingen zijn tijdrovend, duur om te bouwen en zijn sterk afhankelijk van IT-ontwikkelaars en -bronnen. Domino Volt geeft zakelijke gebruikers en IT-medewerkers meer macht en biedt hen de mogelijkheid om razendsnel enterprise-apps te bouwen om snel uitdagingen te overwinnen en te reageren op de marktvraag.

Als Domino Volt-gebruikers kan je – zonder programmeerkennis – binnen enkele minuten web-apps maken, compleet met formulieren, overzichten, workflow en beveiliging. En dit zelfs vanuit een Excel spreadsheet.
Meer technische ontwikkelaars kunnen apps tot 70% sneller bouwen en ze efficiënt uitbreiden met integraties, aangepaste CSS, JavaScript en REST API’s.
Je apps zijn zonder problemen te gebruiken op een computer als op je smartphone.

Domino Volt wordt aangedreven door Domino. Een Domino Volt applicatie is onderliggend niet meer dan een standaard Domino applicatie. Je kan de toepassing dus zonder probleem integreren in bestaande Notes/Domino applicaties of de data van je bestaande applicaties gebruiken in Domino Volt.

Omdat Volt volledig op Domino gebaseerd is, heb je een Domino licentie nodig. Voor Volt heb je geen apart licentiemodel, je betaalt een meerkost bovenop je Domino licentie. Deze wordt momenteel ingesteld op een meerkost van 10% (tot 200 pers.) tot 6% (> 200 pers.) bovenop de prijs per Domino gebruiker. Je betaalt dus per gebruiker in je adresboek, niet per gebruiker die effectief Volt zal gebruiken. Het voordeel is dan wel dat je je Volt gebruik niet apart moet nakijken.
Momenteel is er nog geen licentiemodel voor anoniem gebruik, maar daar komt binnenkort zeker verandering in.

Je kan Volt zelf proberen op de HCL Sandbox.
Op deze pagina kan je je registreren om vrij te spelen met de software. Je vind er ook de nodige tutorials en video’s om snel aan de slag te gaan. Laat u overtuigen van de mogelijkheden.

Engage 2020

Engage 2020 zit er alweer op. En – zoals we het gewoon zijn – heeft Theo Heselmans er weer een prachtig evenement van gemaakt. Zelfs het coronavirus hield de enthousiastelingen niet tegen. Met meer dan 420 deelnemers, 58 HCL Masters en 5 Grandmasters en meer dan 80 sessies, was het iets drukker dan gewoonlijk op een doordeweekse dag in de Burgers’ Zoo.

Theo opent Engage 2020

Wat ook opviel was dat de mensen van HCL niet alleen aanwezig waren, maar ook vlot aanspreekbaar. De manier waarop zij open staan voor een gesprek en meedenken naar oplossingen is een gigantische stijlbreuk met de IBM aanpak van enkele jaren geleden.

Dinsdag was de officiële start van Engage, maar op maandag waren er al enkele interessante workshops. Ik heb de workshop over HCL Domino Volt gevolgd; een nieuwe tool voor low-code ontwikkeling van applicaties. Volt is momenteel nog in Beta, maar met deze instructiefilm kan je al een idee krijgen van de mogelijkheden.

HCL Domino Volt Tutorial

Wat interessant is: Volt wordt geïnstalleerd als een add-on voor Domino, dus er is geen complexe installatie noodzakelijk.

Tijdens Engage werd HCL Nomad voor Android telefoons gelanceerd. Nomad bestond al een tijdje voor iOS, maar nu is dus ook de versie voor Android publiek beschikbaar. Voor de geïnteresseerden hier de link naar de Google Play pagina.
HCL is sterk bezig met nieuwe features te ontwikkelen voor Nomad. Zo komen er meer en meer mogelijkheden bij die puur gericht zijn op mobiel gebruik. Het gebruik van de camera of GPS lokalisatie in een Notes applicatie was al langer aanwezig, nu richt men zich vooral op de mobiele interface (een traditionele Notes applicatie is meestal niet geschikt voor een klein scherm).

Naast Nomad voor iOS en Android, is men ook hard aan het werken aan een browser versie. Voor een officiële release datum is het nog iets te vroeg, maar de eerste demo’s waren er al wel. Binnenkort kan je je Notes applicaties gewoon in de browser openen.

Uiteraard waren er veel interessante sessies (meer dan 80). Ze allemaal overlopen, zou ons natuurlijk veel te ver leiden, maar neem gerust een kijkje op de Engage website. De meeste presentaties zullen daar binnenkort ook te downloaden zijn, waaronder ook deze van Kris De Bisschop en mezelf over nieuwe Notes/Domino verwezenlijkingen.

Op Engage 2020 werd het toch heel duidelijk dat we de donkere tunnel bijna uit zijn. Het enthousiasme van alle deelnemers werkt inspirerend en de ‘eeuwige stilstand’ onder IBM ligt nu duidelijk achter ons. Om dit aan te tonen, nog een laatste slide van de openingssessie.

Nieuwe features in de releases van Domino (versie 10 en 11 zijn van HCL, versie 9 was nog van IBM)

We have to evolve to avoid being disrupted.

Richard Jefts – Vice President & General Manager Digital Solutions at HCL

Om af te sluiten wil ik Theo nogmaals bedanken voor het organiseren van dit prachtige event. Ik verheug me nu al op Engage 2021.

Een vroeg kerstcadeau: Domino V11

Nu is het (bijna) echt zover. De eerste release van Notes en Domino volledig in beheer van HCL wordt gelanceerd op 20 december. Vanaf dan is Notes & Domino V11 beschikbaar voor het grote publiek. Dat was één van de aankondigingen tijdens het Live From Tokyo event vorige week.

Een ander topic tijdens de webcast was de lancering van HCL Volt. Onder de projectnaam Leap werkte HCL aan een low-code platform om business-users de kans te geven om snel een applicatie in elkaar te boksen. Een tool te vergelijken met waar het met Lotus Notes allemaal mee begonnen is; maar dan wel moderner, natuurlijk.

Leap werd herdoopt tot HCL Volt en is ook binnenkort beschikbaar. Met Volt kan je zonder technische development skills op een snelle en eenvoudige manier een webtoepassing maken gebaseerd op jouw business noden. Vertrekkende vanuit bv. een excel tabel kan je een workflow gebonden toepassing maken die gekoppeld is aan een Domino toepassing, Sharepoint of Saleforce omgeving of eender welke applicatie die een REST API heeft.
Volt genereert voor jouw de web-applicatie, maar deze is volledig Domino gebaseerd. Als de tool toch nog niet voldoet aan jouw wensen, kan een ervaren Domino Developer deze nog verder uitbreiden. Voor meer informatie en een demo van Volt, kan je dit HCL filmpje bekijken.

HCL Volt introduction and demo

Met HCL Domino V11 is de syncronisatie met LDAP veel eenvoudiger. Er is geen third party software meer nodig. De Domino server heeft zijn eigen sync mechanisme om de Domino Directory up-to-date te houden. Domino stuurt een login aanvraag door naar de LDAP directory, waardoor je bv. met je Windows credentials kan aanmelden op Domino, Domino gerelateerde websites en zelfs Traveler. Ook voor de integratie met SAML en Two Factor Authentication is Domino erop vooruit gegaan.

Bij multinationals gebeurt het wel eens dat verschillende delen van het bedrijf een andere oplossing gebruiken om de mail en agenda te beheren. Met OnTime is het mogelijk om meetings te plannen en free-busy tijd te bekijken, ongeacht de genodigden Domino, Exchange of Gmail gebruiken om hun kalender te beheren.

Op systeem en admin niveau zijn er nog enkele andere nieuwigheden in V11, zoals een verdere integratie met docker en de mogelijkheid om DAOS op te zetten over verschillende servers 11. Een overzicht van de vernieuwingen voor administrators vindt u in onderstaand filmpje.

Heel wat vernieuwing dus en dit allemaal vanaf 20 december…

Er zijn niet alleen aankondigingen gedaan rond Domino, maar ook Sametime V11 en Connections 6.5 komen er aan.
De volledige webcast kan u overigens hier herbekijken.

HCL Domino V11 – Wat kan je verwachten?

IBM Notes is niet meer. HCL Notes komt eraan. Nu de deal volledig rond is, kunnen de mensen van HCL zich volledig uitleven voor het ontwikkelen van een volgende versie. HCL Notes & Domino V11 is gepland voor het einde van dit jaar. En ook voor de komende jaren is er een duidelijke roadmap uitgetekend. Wat een verschil met vroeger…

Een overzicht van enkele aankondigingen. Voor de volledige presentatie over V11 kan u hier terecht: What’s new in Domino V11 Webcast.

HCL Leap

HCL Leap is de opvolger van Forms Builder. LEAP staat voor Lightweight Enterprise Applications. Het zal Business Users de mogelijkheid geven om snel een applicatie te maken, speciaal voor hun noden. En dit zonder programmeerwerk. Mogelijk is Leap nog niet klaar bij het uitkomen van V11; maar men is ermee bezig. Een voorbeeldje vind je in volgend demo-filmpje (Engels)

Mobiele Notes applicaties

Het is de bedoeling om de huidige Notes Applicaties naar het mobiele tijdperk te brengen.
Momenteel is het al mogelijk om met IDMA of HCL Nomad een Notes applicatie op een iPad te gebruiken. Maar HCL gaat een aantal stappen verder. In V11 zal het immers mogelijk zijn om de Notes Client te gebruiken op een iPhone, Android tablet en ChromeOS. Een versie voor Android Phone staat ook op de planning, maar zal helaas niet voor V11 zijn.
En heb geen netwerk, geen probleem, want je kan – zoals we dat in een Notes Client gewoon zijn – volledig offline werken.

Met enige zin voor nostalgie, is het misschien leuk om een pre-2000 toepassing op de allernieuwste toestellen te gebruiken, maar echt praktisch zal dat niet altijd zijn. HCL moderniseert daarom verschillende standaard Notes templates om ze op mobile toestellen een vertrouwde, frisse look te geven. Dit zal in verschillende fases zijn en is dus een proces over meerdere releases.

Templates zullen meer en meer aangepast worden voor alle types van toestellen

Maar Notes draait niet enkel om standaard templates, maar vooral rond de zovele op maat gemaakte toepassingen die gebruikt worden.
Ook daaraan wordt gedacht, want het zal mogelijk zijn om deze modernisering door te trekken naar je eigen applicaties. Zo zal het in V11 mogelijk zijn om via LotusScript GPS gegevens op te vragen via het mobiele toestel.

Notes in de browser

Het is de bedoeling om de Notes Client ook volledig naar de browser te brengen. Dit bestond reeds in het verleden, maar toen was er nog wel een java plugin nodig. Door gebruik te maken van de nieuwste technologieën, zal dit in de toekomst zonder bijkomende installatie kunnen, puur op standaard browser technologie, zodat je op eender welke browser aan je applicaties kan.
En opnieuw met replicatie en offline mogelijkheden.

Notes V11 look & feel

V11 zal er anders uitzien. Niet alleen zal deze versie volledig HCL branded zijn, maar er is ook enorm gewerkt aan de layout van de client en de Mail database. Hiervoor is samen gewerkt met een aantal Business Partners en HCL Masters, waaronder mezelf.

DAOS op meerdere servers

DAOS is een geweldige manier om disk ruimte op de server te besparen. DAOS overloopt alle bijlagen in alle DAOS enabled Notes databanken op de server en gaat deze uit de applicatie halen om ze op het file-systeem van de server te bewaren. DAOS vergelijkt de bijlagen in de verschillende applicaties (of mailboxen) en elke bijlage slechts één keer opgeslagen. M.a.w. een bijlage die via mail naar 10 verschillende mensen is gestuurd, zal slechts éénmaal opgeslagen worden op de server. Dit is een ruimtebesparing van 90%.
DAOS werd geïntroduceerd met Domino V9, maar in V11 gaat men een stap verder. Tot nu toe werkte DAOS op elke server apart. Vanaf V11 is er de mogelijkheid om over verschillende servers tegelijk te kijken.

Domino: klaar voor de toekomst

Engage zit er weer op. Na de SS Rotterdam vorig jaar, was Autoworld in Brussel de plaats voor deze fantastische beurs. Altijd prachtige locaties, altijd een super evenement.

Zoals elk jaar zijn er ook heel wat nieuwigheden aangekondigd. Er is een preview gegeven van de nieuwe Notes Client, Notes on mobile is aangekondigd voor Android en voor smartphones (Android en iOS). De plannen voor Sametime en Connections zijn uit de doeken gedaan. Daarnaast zijn er ook veel sessies geweest rond innovatieve technieken, die ons geliefde platform toch naar een hoger niveau brengen.

Notes Client v11

Er is een eerste live demo gegeven van de Notes Client V11. Er werd getoond hoe de mail en kalender er zullen uitzien. Qua look en feel ziet het er een stuk moderner uit. Er is vooral gewerkt aan de gebruiksvriendelijkheid. Minder gebruikte opties zijn verborgen achter open te klappen secties of een submenu. Het nieuwe design ziet er daardoor veel rustgevender uit, zonder dat er aan functionaliteit wordt ingeboet.

Een aantal keren heb ik de opmerking gehoord dat er – buiten het design – niet veel is veranderd. De mail en kalendar zijn echter al heel uitgebreid, ook in V9 en V10. Bovendien zijn de templates gemakkelijk aan te passen en uit te breiden voor specifieke noden. De grootste bekommernis van klanten was het oubollige design; waar nu duidelijk toch iets aan gedaan is. Als we dit design kunnen doortrekken naar de eigen applicaties in de Notes Client, wordt er komaf gemaakt met de verouderde look.

V11 zal bij lancering ook direct beschikbaar zijn voor iOS en Windows én in meerdere talen.

Notes Goes Mobile

De IDMA (IBM Domino Mobile Application) voor iOS tablets bestaat nu al even en is ook in de appstore verkrijgbaar.
De Notes Client naar mobiele toestellen brengen is een prioriteit bij HCL.
Binnenkort zal er ook een Android versie uitkomen en men werkt ook aan een nieuwe browser versie voor de desktop/laptop.
Er is ook een eerste demo gegeven van de Notes Client voor smartphones.

Screenshot 2019-05-16 at 18.37.19
Notes Client applicaties op je iPhone? Binnenkort kan het.

Dit ziet er zeer goed uit, de look en feel komt dicht in de buurt van standaard mobile toepassingen en toch is het een standaard Notes applicatie. Op vlak van development zullen er een aantal mogelijkheden bijkomen om bestaande (en nieuwe) applicaties te optimaliseren voor het kleine scherm.

De toekomst volgens HCL

De Collaboration portfolio van HCL zal bestaan uit 5 grote blokken, waarbij Notes & Domino bovenaan staan. Daarnaast wordt er ook geïnvesteerd in Sametime (chat en online meetings), Leap (NoCode application ontwikkeling voor business users), DX (portaal) en Connections (social platform).

HCL zet vol in op integratie van de verschillende collaboration platformen die ze overnemen van IBM. De producten zullen niet alleen beter met elkaar integreren, maar ook met producten van de concurrentie. Het doel is om uw werkomgeving om te vormen naar één groot, geïntegreerd verhaal.

Denk groots

Nu Domino ook rechtstreeks vanuit Node.js te benaderen is, gaat er een hele nieuwe wereld van mogelijkheden open. Wat dacht u van volgende demo, die eerder dit jaar is gegeven op IBM Think:

Een Notes database aansturen met Alexa? Waarom niet…

Met Node.Red is dit zelfs helemaal niet zo moeilijk om op te zetten. Zo is het ook mogelijk om Notes/Domino applicaties te laten integreren met #Slack of welke andere omgeving dan ook. Begin maar al te dromen.

Rest calls and JSON Parsing in LotusScript

This is my first technical article on this blog. To reach a broader audience in the Notes/Domino community (and to avoid weird translations), I decided to write technical articles in English. Other experiences and opinions on the Notes/Domino world will stay in Dutch.

That being said, I wanted to discuss the new functions in LotusScript to do HTTP Requests and parsing the json response to use it in a Notes application.

You can use the new NotesHTTPRequest class to do the api request. This class allows you to do get, put and post requests. You can set headers using the setHeaderField method.
By default, the returned response can be either a byte array or a string (depending on the service called). To avoid this, set the (undocumented) preferString property to true. This will enforce the response to be a string.

Dim webRequest As NotesHTTPRequest
Set webRequest = session.createhttprequest()

'Get the response Dim response As String
webrequest.preferstrings = True response = webrequest.Get(<URL>)
'Throw error if response status is not OK If InStr(webRequest.Responsecode, "200 OK") = 0 Then 'Return Status is not OK Error 1000, "Request returned response code " + webRequest.responseCode End If

Note that the URL that you pass to the request has to be encoded. Most browsers encode the url after you typed it in the addressbar. But the NotesHTTPRequest does not. Therefor, make sure you encode the url before using it for the request. Here’s a small example:

Dim url as string
url = "https://mysite.com/get?name=John Doe"

'Using this url in the get request won't work
response = webrequest.get(baseurl + parameters)

'By encoding the url, it will
response = webrequest.get(urlEncode(url))

I use this function to encode url parts
It will encode special characters, but won't touch & or =, 
so you can pass the full url in one go
Kuddos to 
Function urlEncode(s As String) As String
    If Len(s) = 0 Then Exit Function

    Dim tmp As String
    Dim c As String
    Dim i As Integer

    For i = 1 To Len(s)
        c = Mid(s, i, 1)
        If (Asc(c) >= 65 And Asc(c) <= 90) _
            Or (Asc(c) >= 97 And Asc(c) <= 122) _
            Or (Asc(c) >= 48 And Asc(c) <= 58) _
            Or Asc(c) = 38 _
            Or (Asc(c) >= 45 And Asc(c) <= 47) _
            Or Asc(c) = 58 Or Asc(c) = 61 _
            Or Asc(c) = 63 Or Asc(c) = 126 Then
            tmp = tmp + c
            tmp = tmp + "%" + Hex(Asc(c))
        End If
    Next i
    urlEncode = tmp
End Function

You can now parse the response using the NotesJSONNavigator class. However, this still has some caveats. The new class doesn’t behave well on some special characters in the json you pass (like CR, LF, °, ü, …) and you’ll get an error trying to parse this. According to HCL, there might still be an issue with the character encoding while processing the json data.

However, there is a workaround to avoid this by forcing the data to UTF-8. When you save the response to a file and then read it using a notesstream with UTF-8 encoding, you will be able to parse the data (Thanks to Dave Cohen for the tip)

'write the requests response to a file
Dim fileNum As Integer
fileNum% = FreeFile()
Dim filepath As String
filepath = "c:\temp\" + Format(Now, "yyyy-mm-dd-hhnnss") + ".json"
Open filepath For Output As fileNum%
Print #filenum, response
Close filenum

'Read the file using a NotesStream
Dim inbuf As NotesStream
Dim json As variant
Set inbuf = session.Createstream()
If Not(inbuf.Open(filepath, "UTF-8")) Then
	Error 1001, "Unable to open JSON file (" + filepath + ")"
End If
json = inbuf.Read()
Call inbuf.Close()

'remove temporary file
Kill filepath

'Create the Json Navigator to parse the data
Dim jsnav As NotesJSONNavigator
If IsArray(json) Then
	Set jsnav = session.CreateJSONNavigator(json)
	Error 1002, "JSON is nothing"
End If

Once you have the NotesJSONNavigator object, you can loop through the different elements. Here’s some sample code to do so.

Dim parsed As string
Dim el As notesjsonelement
Set el = jsnav.Getfirstelement()

While Not el Is Nothing
	parsed = parsed + parseelement(el, "")
	Set el = jsnav.Getnextelement()		

MsgBox parsed

Function parseElement(el As notesjsonelement, parent As string)
	Dim returnValue As String
	Dim sName As String
	sName = parent + el.name
	Select Case el.type
		Case 1: 'Object
			Dim ob As notesjsonobject
			Set ob = el.value
			returnValue = returnValue + parseObject(ob, parent + el.name)
		Case 2: 'Array
			Set ar = el.value
			returnValue = returnValue + parseArray(ar, parent + el.name)
		Case 3: 'String
			returnValue = returnValue +  sName + " - '" & el.Value & "'" + Chr$(10)
		Case 4: 'Number
			returnValue = returnValue +  sName + " - " & el.value + Chr$(10)
		Case 5: 'Boolean
			Dim b As String
			If el.value Then 
				returnValue = returnValue +  sName + " - true" + Chr$(10)
				returnValue = returnValue +  sName + " - false" + Chr$(10)
			End If
		Case 64: 'empty
			returnValue = returnValue +  sName + " - <EMPTY>" + Chr$(10)
		Case Else: 'Unknown
			returnValue = returnValue +  sName + " Unknown type " & el.type + Chr$(10)
	End Select
	parseElement = returnValue
End Function

Function parseObject(ob As notesjsonobject, parent As String) As string
	Dim el As notesjsonelement
	Dim sName As String
	Dim returnValue As string
	Set el = ob.Getfirstelement()
	While Not el Is Nothing
		returnValue = returnValue + parseElement(el, parent + ".")
		Set el = ob.Getnextelement()
	parseObject = returnValue
End Function

Function parseArray(ar As NOTESJSONARRAY, parent As String)
	Dim el As notesjsonelement
	Dim sName As String
	Dim returnValue As String
	Set el = ar.Getfirstelement()
	Dim counter As Integer
	While Not el Is Nothing
		returnValue = returnValue + parseElement(el, parent + "." & counter)
		Set el = ar.Getnextelement()
		counter = counter + 1
	parseArray = returnValue
End Function

Another way to get a json element is to get it by name or by pointer. A
JSON Pointer defines a string syntax for identifying a specific value within a JavaScript Object Notation (JSON) document.

'By name
Set el = jsnav.Getelementbyname("latitude")

'By pointer
Set el = jsnav.getElementbypointer("/daily/data/0")

I created a demo application that allows youto retrieve a weather forecast for any place on earth. I used the Google Maps API to retrieve address information and the Dark Sky API to get a forecast. You’ll need a key for both api to be able to use the app. You can download the demo here.


Laat ik beginnen met iedereen een gelukkig nieuwjaar te wensen. En natuurlijk veel plezier met de Notes & Domino producten.

Eind vorig jaar heb ik een mail van IBM gekregen dat ik me in 2019 voor een jaartje IBM Champion mag noemen. Een extra motivatie om jullie op de hoogte te houden van wat er reilt en zeilt binnen onze community.

2019 wordt een jaar vol verwachtingen. Er staat dan ook wel wat te gebeuren.

IBM Domino Mobile Applications zal dit jaar ook uit ‘early acces mode’ gaan, zodat iedereen zijn Notes toepassingen mobiel kan gebruiken.

Ook wordt Domino opengetrokken naar de node.js wereld. Een grote groep developers zal dus van onze robuuste technologie gebruik kunnen maken.

Als de roadmap gevolgd wordt, gaan we dit jaar al een nieuwe versie van notes & domino voorgeschoteld krijgen. In V10 was de modernisering vooral op server niveau te merken. In V11 mogen heel wat vernieuwing aan client zijde verwachten.

2019 wordt ook het jaar dat Notes/Domino en Connections de IBM portfolio verlaten. Zoals u eerder kon lezen op mijn blog zal HCL deze producten overnemen. HCL heeft al veel tijd en geld gestoken om V10 te realiseren en er staan ons nog veel meer mooie dingen te wachten dit jaar. Wie weet wat ik binnenkort nog allemaal kan aankondigen…