Hey!
I’ve been scouring the net trying to find some info on how to build and deploy an ionic 2 app as a PWA, but no luck. So I resort to posting here. If anyone could be so kind as to explain how to build and deploy a normal ionic 2 application (standard template is fine) to run as a PWA I’d be very grateful!
For what I can tell you make an Ionic 2 app (as PWA comes pre-set-up in an Ionic 2 App), build it using ionic serve --lab and then upload the files in the www folder to your web server. That’s what I did and it seems to work.
That’s probably not the proper way of doing it but like I say it worked for me.
Not sure what the difference is, or if there is any (maybe some additional possible plugin support?), but you can also add “browser” as a platform with
Yeah, I’ve gotten that far. But as for what do to with the files I am a bit clueless. I also noticed that on my desktop browser I get a 404 because cordova.js is missing. Changing the path in the index.html solves this however, but I am not sure if this is the way to do it or if you’re expected to add more libraries?
I am trying to assemble info on PWA amd gather everything in one place. I have tried to write up a quick guide on how to deploy it. Let me know if it’s helpful or what changes would you like to have.
If you do ionic build browser --prod it will include the Cordova JavaScript files as well, but you need to deploy what’s in platforms/browser/www, not in the top-level www folder.
However unless you specifically need a Cordova plugin that runs in the browser I wouldn’t worry about that. Less JavaScript files to be downloaded by the client is better.
as the file generated have always the same names, how do you force the browser to load a new version after a deployment ? (it will get it from cache until expiration) thanks.
@sebastianovide you can rewrite HTML on the fly (with PHP or so), and include expiry dates (for example the modification time of the file). Or just adjust the cache settings in your server, see http://www.mnot.net/cache_docs/ for instance.
Just an addition, for Ionic 2.2.1, to build a production ready PWA, you may run this command: npm run build --prod
Documentation is provided here: https://github.com/driftyco/ionic-app-scripts
I just wanted everybody to know that pages do not behave as angular components, the web page has a little delay once you change tab or push a page. I’m recoding it to be pure angular2.
Adding the browser platform gives you access to cordova functions and plugins that support the browser platform.
The support is certainly less than ios/android though so it’s not exactly the same, but ok for some functions.
Ok, thanks, I think I get it. So for my PWA, IF there is a browser implementation the plugin should work automatically. If not, I need to check what platform I am on and implement a web version of the plugin if needed…
I could also ignore the Browser platform completely and do the platform check and implementation for all of them.
Thanks. Maybe you would know this: I have a single code base for my native apps and now my new PWA. If I comment out the Service Worker in index.html in the source folder, will it affect my native app cordova build (I use Ionic Cloud to create the native packages). IE do I have to have 2 different Index.html files?