TangoWebapp insights

Igor Khokhryakov
Igor KhokhryakovSoftware Architector at TANGO Controls Collaboration
TangoWebapp insights
by Igor Khokhriakov
32nd
Tango Users meeting, 2018
What’s inside?
07.06.2018 Igor Khokhriakov 3
1) What is TangoWebapp?
2) Structure of the project
3) Technologies
4) Architecture
5) Deployment guide lines
6) Some tweaks and tips
What is TangoWebapp?
07.06.2018 Igor Khokhriakov 5
1) A bunch of jmvc applications
2) Custom backends: user-context; terminal; etc
07.06.2018 Igor Khokhriakov 6
3) Each jmvc application
07.06.2018 Igor Khokhriakov 7
4) Putting it all together
TangoWebapp insights
TangoWebapp insights
JavaScriptMVC-1.5.x (jmvc)
07.06.2018 Igor Khokhriakov 11
●
https://github.com/jmvc-15x/javascriptmvc-1.5.x
MVC.Model.extend
OpenAjax.hub
.publish
.subscribe
Tests console
07.06.2018 Igor Khokhriakov 15
$> ./jmvcc jmvc/assemble
TangoWebapp insights
Webix
07.06.2018 Igor Khokhriakov 18
Webix is an integrated UI framework:
webix.protoUI
webix.protoUI
+ composition
Data binding
TangoWebapp Architecture
07.06.2018 Igor Khokhriakov 23
1) Layered architecture
2) OpenAjax for loose coupling
3) Platform API
PlatformAPI.UIBuilder
PlatformAPI.UIBuilder
PlatformAPI.UserContext
PlatfrormAPI.Stateful mixin
mixins
PlatformAPI Tango primitives
Quite good so far...
… but there is always
a dark side
Nashorn (JS5, can not handle complex libraries)
JSDoc custom parser
Documentation (User/Developer)
Deployment&CI
07.06.2018 Igor Khokhriakov 34
Branch based build by Travis
TangoWebapp insights
TangoWebapp insights
Future plans (Q'1-2 2019)
07.06.2018 Igor Khokhriakov 38
●
Improve Platform API
– Inject context menu
– Include widgets VS include “platform”
– Improve widgets OpenAjax subscription
●
Get rid off Nashorn
●
Replace custom JSDoc parser with library
●
Use JS6 features (Get rid off jmvc???)
– Classes/modules/lambda etc
●
Documentation (Q'3 2018)
Acknowledgements
07.06.2018 Igor Khokhriakov 40
FS-EC group
Tango Controls steering committee
THANK YOU!
Questions?
mail@ingvord.ru
tango-controls/tango-webapp
1 of 41

Recommended

Introduction of Lambda by
Introduction of LambdaIntroduction of Lambda
Introduction of LambdaKeita Watanabe
129 views50 slides
Waltz-Controls presentation for Canadian Light Source by
Waltz-Controls presentation for Canadian Light SourceWaltz-Controls presentation for Canadian Light Source
Waltz-Controls presentation for Canadian Light SourceIgor Khokhryakov
104 views32 slides
Setup by
SetupSetup
SetupAvitesh Kesharwani
22 views1 slide
KaoNet v2 - Face Translation using CycleGAN by
KaoNet v2 - Face Translation using CycleGANKaoNet v2 - Face Translation using CycleGAN
KaoNet v2 - Face Translation using CycleGANVan Huy
2.4K views28 slides
Web&mobile - 4 ottobre 2012 by
Web&mobile  - 4 ottobre 2012Web&mobile  - 4 ottobre 2012
Web&mobile - 4 ottobre 2012JooinK
1K views9 slides
The WebKit project by
The WebKit projectThe WebKit project
The WebKit projectjuanjosanchezpenas
15.3K views45 slides

More Related Content

Similar to TangoWebapp insights

First Bucharest GTUG event 02 Mar 2010 by
First Bucharest GTUG event 02 Mar 2010First Bucharest GTUG event 02 Mar 2010
First Bucharest GTUG event 02 Mar 2010Petrica Clement Chiriac
1.3K views24 slides
The WebKit project (LinuxCon North America 2012) by
The WebKit project (LinuxCon North America 2012)The WebKit project (LinuxCon North America 2012)
The WebKit project (LinuxCon North America 2012)Igalia
2.9K views45 slides
Using Groovy to empower WebRTC Network Systems by
Using Groovy to empower WebRTC Network SystemsUsing Groovy to empower WebRTC Network Systems
Using Groovy to empower WebRTC Network Systemsantonry
1.4K views76 slides
ClojureScript in Magento 2 - PHPUGMRN by
ClojureScript in Magento 2 - PHPUGMRNClojureScript in Magento 2 - PHPUGMRN
ClojureScript in Magento 2 - PHPUGMRNvinaikopp
474 views35 slides
Implementing Microservices with Jakarta EE and MicroProfile by
Implementing Microservices with Jakarta EE and MicroProfileImplementing Microservices with Jakarta EE and MicroProfile
Implementing Microservices with Jakarta EE and MicroProfileKevin Sutter
740 views52 slides
React workshop presentation by
React workshop presentationReact workshop presentation
React workshop presentationBojan Golubović
6.9K views29 slides

Similar to TangoWebapp insights(20)

The WebKit project (LinuxCon North America 2012) by Igalia
The WebKit project (LinuxCon North America 2012)The WebKit project (LinuxCon North America 2012)
The WebKit project (LinuxCon North America 2012)
Igalia2.9K views
Using Groovy to empower WebRTC Network Systems by antonry
Using Groovy to empower WebRTC Network SystemsUsing Groovy to empower WebRTC Network Systems
Using Groovy to empower WebRTC Network Systems
antonry1.4K views
ClojureScript in Magento 2 - PHPUGMRN by vinaikopp
ClojureScript in Magento 2 - PHPUGMRNClojureScript in Magento 2 - PHPUGMRN
ClojureScript in Magento 2 - PHPUGMRN
vinaikopp474 views
Implementing Microservices with Jakarta EE and MicroProfile by Kevin Sutter
Implementing Microservices with Jakarta EE and MicroProfileImplementing Microservices with Jakarta EE and MicroProfile
Implementing Microservices with Jakarta EE and MicroProfile
Kevin Sutter740 views
JavaScript Library Overview by jeresig
JavaScript Library OverviewJavaScript Library Overview
JavaScript Library Overview
jeresig32.3K views
WebKit and Blink: Open Development Powering the HTML5 Revolution (LinuxCon No... by Igalia
WebKit and Blink: Open Development Powering the HTML5 Revolution (LinuxCon No...WebKit and Blink: Open Development Powering the HTML5 Revolution (LinuxCon No...
WebKit and Blink: Open Development Powering the HTML5 Revolution (LinuxCon No...
Igalia4.4K views
Contributing to JDK Mission Control by Marcus Hirt
Contributing to JDK Mission ControlContributing to JDK Mission Control
Contributing to JDK Mission Control
Marcus Hirt69 views
Magento NodeJS Microservices — Yegor Shytikov | Magento Meetup Online #11 by Magecom UK Limited
Magento NodeJS Microservices — Yegor Shytikov | Magento Meetup Online #11Magento NodeJS Microservices — Yegor Shytikov | Magento Meetup Online #11
Magento NodeJS Microservices — Yegor Shytikov | Magento Meetup Online #11
Magecom UK Limited165 views
Mihai Tataran - Building Windows 8 Applications with HTML5 and JS by ITCamp
Mihai Tataran - Building Windows 8 Applications with HTML5 and JSMihai Tataran - Building Windows 8 Applications with HTML5 and JS
Mihai Tataran - Building Windows 8 Applications with HTML5 and JS
ITCamp800 views
Future of Java EE with SE 8 (revised) by Hirofumi Iwasaki
Future of Java EE with SE 8 (revised)Future of Java EE with SE 8 (revised)
Future of Java EE with SE 8 (revised)
Hirofumi Iwasaki1.9K views
Install sitecore experience commerce 9.0 by Mohamed Krimi
Install sitecore experience commerce 9.0Install sitecore experience commerce 9.0
Install sitecore experience commerce 9.0
Mohamed Krimi445 views
DIY: Computer Vision with GWT. by JooinK
DIY: Computer Vision with GWT.DIY: Computer Vision with GWT.
DIY: Computer Vision with GWT.
JooinK1.1K views
DIY- computer vision with GWT by Francesca Tosi
DIY- computer vision with GWTDIY- computer vision with GWT
DIY- computer vision with GWT
Francesca Tosi406 views
MicroProfile and Jakarta EE - What's Next? by Ian Robinson
MicroProfile and Jakarta EE - What's Next?MicroProfile and Jakarta EE - What's Next?
MicroProfile and Jakarta EE - What's Next?
Ian Robinson163 views
WebKit and Blink: open development powering the HTML5 revolution by juanjosanchezpenas
WebKit and Blink: open development powering the HTML5 revolutionWebKit and Blink: open development powering the HTML5 revolution
WebKit and Blink: open development powering the HTML5 revolution
juanjosanchezpenas12.1K views
Testing with Codeception by Jeremy Coates
Testing with CodeceptionTesting with Codeception
Testing with Codeception
Jeremy Coates20.6K views

More from Igor Khokhryakov

X-Environment Metadata Management by
X-Environment Metadata ManagementX-Environment Metadata Management
X-Environment Metadata ManagementIgor Khokhryakov
1 view7 slides
Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As... by
Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...
Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...Igor Khokhryakov
1 view15 slides
Waltz presentation at ASU and ANL by
Waltz presentation at ASU and ANLWaltz presentation at ASU and ANL
Waltz presentation at ASU and ANLIgor Khokhryakov
194 views32 slides
1st Tango Users Group Russia meeting, overview by
1st Tango Users Group Russia meeting, overview1st Tango Users Group Russia meeting, overview
1st Tango Users Group Russia meeting, overviewIgor Khokhryakov
452 views22 slides
GitHub/git+Cmake+Clion by
GitHub/git+Cmake+ClionGitHub/git+Cmake+Clion
GitHub/git+Cmake+ClionIgor Khokhryakov
798 views41 slides
Applying Enterprise technologies in Science by
Applying Enterprise technologies in ScienceApplying Enterprise technologies in Science
Applying Enterprise technologies in ScienceIgor Khokhryakov
287 views84 slides

More from Igor Khokhryakov(6)

Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As... by Igor Khokhryakov
Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...
Observability of the SCADA Systems Using Elastic APM, Reactive Streams and As...
1st Tango Users Group Russia meeting, overview by Igor Khokhryakov
1st Tango Users Group Russia meeting, overview1st Tango Users Group Russia meeting, overview
1st Tango Users Group Russia meeting, overview
Igor Khokhryakov452 views
Applying Enterprise technologies in Science by Igor Khokhryakov
Applying Enterprise technologies in ScienceApplying Enterprise technologies in Science
Applying Enterprise technologies in Science
Igor Khokhryakov287 views

Recently uploaded

Page Object Model by
Page Object ModelPage Object Model
Page Object Modelartembondar5
7 views5 slides
Techstack Ltd at Slush 2023, Ukrainian delegation by
Techstack Ltd at Slush 2023, Ukrainian delegationTechstack Ltd at Slush 2023, Ukrainian delegation
Techstack Ltd at Slush 2023, Ukrainian delegationViktoriiaOpanasenko
7 views4 slides
Top-5-production-devconMunich-2023-v2.pptx by
Top-5-production-devconMunich-2023-v2.pptxTop-5-production-devconMunich-2023-v2.pptx
Top-5-production-devconMunich-2023-v2.pptxTier1 app
9 views42 slides
Bootstrapping vs Venture Capital.pptx by
Bootstrapping vs Venture Capital.pptxBootstrapping vs Venture Capital.pptx
Bootstrapping vs Venture Capital.pptxZeljko Svedic
16 views17 slides
The Path to DevOps by
The Path to DevOpsThe Path to DevOps
The Path to DevOpsJohn Valentino
6 views6 slides
Winter Projects GDSC IITK by
Winter Projects GDSC IITKWinter Projects GDSC IITK
Winter Projects GDSC IITKSahilSingh368445
416 views60 slides

Recently uploaded(20)

Top-5-production-devconMunich-2023-v2.pptx by Tier1 app
Top-5-production-devconMunich-2023-v2.pptxTop-5-production-devconMunich-2023-v2.pptx
Top-5-production-devconMunich-2023-v2.pptx
Tier1 app9 views
Bootstrapping vs Venture Capital.pptx by Zeljko Svedic
Bootstrapping vs Venture Capital.pptxBootstrapping vs Venture Capital.pptx
Bootstrapping vs Venture Capital.pptx
Zeljko Svedic16 views
University of Borås-full talk-2023-12-09.pptx by Mahdi_Fahmideh
University of Borås-full talk-2023-12-09.pptxUniversity of Borås-full talk-2023-12-09.pptx
University of Borås-full talk-2023-12-09.pptx
Mahdi_Fahmideh12 views
Introduction to Git Source Control by John Valentino
Introduction to Git Source ControlIntroduction to Git Source Control
Introduction to Git Source Control
John Valentino8 views
aATP - New Correlation Confirmation Feature.pptx by EsatEsenek1
aATP - New Correlation Confirmation Feature.pptxaATP - New Correlation Confirmation Feature.pptx
aATP - New Correlation Confirmation Feature.pptx
EsatEsenek1222 views
How to build dyanmic dashboards and ensure they always work by Wiiisdom
How to build dyanmic dashboards and ensure they always workHow to build dyanmic dashboards and ensure they always work
How to build dyanmic dashboards and ensure they always work
Wiiisdom16 views
Mobile App Development Company by Richestsoft
Mobile App Development CompanyMobile App Development Company
Mobile App Development Company
Richestsoft 5 views
Automated Testing of Microsoft Power BI Reports by RTTS
Automated Testing of Microsoft Power BI ReportsAutomated Testing of Microsoft Power BI Reports
Automated Testing of Microsoft Power BI Reports
RTTS11 views

TangoWebapp insights