One thing I've taken away from this is vanilla Javascript seems to have come a long way, or I've just never taken the time to fully appreciate all the features
For example I didn't even realise JS supported string interpolation
There's some really good examples of this in Wes Bos' (free) javascript30.com course - 30 short videos all using vanilla Javascript and showing some really neat new features.
I had taken a nearly six year break from JavaScript coding until about 7 months ago. It has definitely come a long way and is pretty great to use now.
There’s still a lot of “pain” left in the build processes, transpiling, etc, but they’re less painful than they were half a decade ago. Those are also less specific to issues with the language, and more with how we need to use the language.
While not plain JS, I’d strongly recommend trying Vue if you’re getting back into JS. Is a true pleasure to use on a daily basis, and I never find myself fighting it. It makes writing non static sites with interactivity a breeze, and even when I’m building near static pages, I like how it helps me to organize my code (from a structure standpoint, it isn’t opinionated on this stuff).
I recently stumbled upon the Airbnb Javascript Style Guide, which I found showed a lot of good examples of how to use newer Javascript features: https://github.com/airbnb/javascript
Static doesn’t mean no JavaScript or interaction. In fact many SPAs are just static pages served out of S3 and connecting directly to some API server to fetch data.
A static page means no processing is done on a web server to serve you the rendered content. This saves you time and money, and ensures scalability for any amount of traffic.
This is great. I love the simple, succinct interface — I wish real financial companies like my trading account and my bank had even half this much sense when it comes to pragmatic design.
A few notes from taking a look at the code:
* I've very much started doing the same thing in my projects of just using modern JavaScript constructs like fetch and arrow functions without a transpiler. IE is never going to support any of them, but I've accepted that. Caniuse.com ranks most of them at 85%+ supported.
* It's neat to see that the IEX API supports batch requests (as opposed to having to pull one stock at a time) in its API which makes it possible to implement the project efficiently and in a way that doesn't have to store state.
* Nice work building it to support large users as well. A lot of installations probably won't have more than 100 stocks, but it'll break up requests into multiple batches of <= 100 if they do.
I'm not into stocks, but like the way you coded it. We don't see this sort of good examples that combines the old school simplicity and new JS / DOM API features.
hmm, while this is cool i am not sure if it is a full-fledged replacement for the Google Finance "portfolios" feature. That lets you add the number of stocks you own for each symbol and shows you an aggregate gain/loss per day, etc. That was the main reason i was using google finance.
I have now transitioned to my own Google Sheet with the "=GOOGLEFINANCE()" function for getting the stock data. Works pretty well.
I'm no JS expert by any stretch but it seems pretty simple to add in code for that here. It'd be a chore to hard-code a big portfolio or one that trades frequently, though.
As everything is done client side how about adding some parsing of the URL #hash/?query to encode data of a portfolio? That way you could have a single statically hosted version serving multiple people. Could even have a portfolio builder page that generates the encoded URL.
You might want to look at the code, serve that html page from your local machine and console.log(url) inside the updateDataForBatch(symbols, addTitle) function to see how it works.
It looks like a simple html table, I think LibreOffice might be able to parse that. Else, it should be relatively trivial to change the output to e.g. csv which can be imported.
As for an alternative, and I don't know the options here, but maybe a plugin could be made that pulls the data into Calc itself.
[+] [-] djhworld|7 years ago|reply
For example I didn't even realise JS supported string interpolation
https://github.com/toddwschneider/stocks/blob/master/index.h...
[+] [-] mcintyre1994|7 years ago|reply
Another really awesome new feature which I can't remember if it's in that course or not, is fetch - super simple AJAX API using promises. It's also used in this app: https://github.com/toddwschneider/stocks/blob/master/index.h...
[+] [-] wjossey|7 years ago|reply
There’s still a lot of “pain” left in the build processes, transpiling, etc, but they’re less painful than they were half a decade ago. Those are also less specific to issues with the language, and more with how we need to use the language.
While not plain JS, I’d strongly recommend trying Vue if you’re getting back into JS. Is a true pleasure to use on a daily basis, and I never find myself fighting it. It makes writing non static sites with interactivity a breeze, and even when I’m building near static pages, I like how it helps me to organize my code (from a structure standpoint, it isn’t opinionated on this stuff).
[+] [-] jlubawy|7 years ago|reply
[+] [-] dguo|7 years ago|reply
[1]: http://es6-features.org/
[2]: https://github.com/tc39/proposals
[+] [-] justboxing|7 years ago|reply
[+] [-] meredydd|7 years ago|reply
It let you pick the stocks yourself, and showed you historical graphs too. It was a bit more complex than this, but still only took an hour.
[+] [-] dxxvi|7 years ago|reply
[+] [-] foobaw|7 years ago|reply
[+] [-] Havoc|7 years ago|reply
Why would you? Their volume is likely a fraction of IEX's:
https://markets.cboe.com/us/equities/market_share/
Worse all their stuff is effectively darkpooled. You'd be hard-pressed to find a worse source of market data.
Also:
https://medium.com/@Gangal/robinhood-robbing-from-the-poor-g...
[+] [-] janvidar|7 years ago|reply
[+] [-] sp332|7 years ago|reply
[+] [-] matte_black|7 years ago|reply
A static page means no processing is done on a web server to serve you the rendered content. This saves you time and money, and ensures scalability for any amount of traffic.
[+] [-] brandur|7 years ago|reply
A few notes from taking a look at the code:
* I've very much started doing the same thing in my projects of just using modern JavaScript constructs like fetch and arrow functions without a transpiler. IE is never going to support any of them, but I've accepted that. Caniuse.com ranks most of them at 85%+ supported.
* It's neat to see that the IEX API supports batch requests (as opposed to having to pull one stock at a time) in its API which makes it possible to implement the project efficiently and in a way that doesn't have to store state.
* Nice work building it to support large users as well. A lot of installations probably won't have more than 100 stocks, but it'll break up requests into multiple batches of <= 100 if they do.
[+] [-] mmanfrin|7 years ago|reply
[+] [-] indescions_2018|7 years ago|reply
[+] [-] roadbeats|7 years ago|reply
[+] [-] vigneshv_psg|7 years ago|reply
I have now transitioned to my own Google Sheet with the "=GOOGLEFINANCE()" function for getting the stock data. Works pretty well.
[+] [-] mark212|7 years ago|reply
[+] [-] koolba|7 years ago|reply
As everything is done client side how about adding some parsing of the URL #hash/?query to encode data of a portfolio? That way you could have a single statically hosted version serving multiple people. Could even have a portfolio builder page that generates the encoded URL.
[+] [-] sammyd56|7 years ago|reply
https://samdobson.github.io/stocks/?Banks=GS,MS,JPM&Tech=AAP...
[+] [-] IloveHN84|7 years ago|reply
[+] [-] gbba|7 years ago|reply
[+] [-] procinct|7 years ago|reply
[+] [-] mikeokner|7 years ago|reply
[+] [-] ape4|7 years ago|reply
[+] [-] samfisher83|7 years ago|reply
Here is the code author uses to get data:
[+] [-] dxxvi|7 years ago|reply
[+] [-] bitpow|7 years ago|reply
[+] [-] craftyguy|7 years ago|reply
[+] [-] Cthulhu_|7 years ago|reply
As for an alternative, and I don't know the options here, but maybe a plugin could be made that pulls the data into Calc itself.
[+] [-] jknz|7 years ago|reply
[+] [-] djhworld|7 years ago|reply