Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dotnet-websharper/data
Client-side data access for WebSharper
https://github.com/dotnet-websharper/data
Last synced: 10 days ago
JSON representation
Client-side data access for WebSharper
- Host: GitHub
- URL: https://github.com/dotnet-websharper/data
- Owner: dotnet-websharper
- License: apache-2.0
- Created: 2015-09-22T09:51:35.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2021-06-23T21:01:31.000Z (over 3 years ago)
- Last Synced: 2024-04-29T11:05:43.840Z (8 months ago)
- Language: F#
- Size: 150 KB
- Stars: 1
- Watchers: 9
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-websharper - Data - Proxy for [FSharp.Data](https://fsharp.github.io/FSharp.Data/) which allows using its JsonProvider and WorldBankProvider on the client side. (Libraries / Other libraries)
README
# WebSharper.Data
WebSharper.Data provides proxies for the [FSharp.Data][1]
project to enable you to write data-rich applications on the client side.## Supported Providers
Currently WebSharper.Data implements the `JsonProvider` and the `WorldBankProvider`
runtimes meaning these are the ones you can acces from the client-side. After installing
the package you should be able to use these types from [FSharp.Data][1], but using other types
will result in the WebSharper Compiler's being unable to compile the code.## Additional Notes
Since the [World Bank API][2] is only available through [JSONP][4] from JavaScript due to
cross-origin issues the implementation of the runtime in JavaScript uses [JSONP][4] to
request data from the API as opposed to [FSharp.Data][1] which uses the JSON API.
This has no effect on anything from the user's point of view.Since a lot of providers don't give access to their JSON APIs for JavaScript clients
because of cross-origin issues (like mentioned above in the case of the [World Bank Database][3]), we sometimes need to use [JSONP][4] instead. To get around this you can
specify your URL in WebSharper.Data like this:```fsharp
open FSharp.Datatype WorldBank = JsonProvider<"WorldBank.json">
let docAsync = WorldBankJson.AsyncLoad("jsonp|http://api.worldbank.org/country/cz/indicator/GC.DOD.TOTL.GD.ZS?format=[JSONP][4]")
async {
let! a = docAsync
for record in a.Array do
record.Value |> Option.iter (fun v ->
printfn "%d: %f" record.Date v)
}
|> Async.Start
```
here `"jsonp|http://url.com"` means that you want to use [JSONP][4] instead JSON.Due to the nature of JavaScript, `Async` and the implementation of `JsonProviderRuntime` you
can only use the async versions of the fetching functions. It would be technically possible
to request data synchronously with Ajax but it would be undesirable and it's currently impossible to implement in WebSharper because the `JsonProvider` uses `Async.RunSynchronously` which cannot be translated to JavaScript.Special thanks to the [FunScript][5] folks for their implementation of the runtimes and showing it's possible (and easy) to do once you have it figured out. Some code and a lot of ideas have been reused from their work.
[1]: http://fsharp.github.io/FSharp.Data/
[2]: http://data.worldbank.org/developers/api-overview
[3]: http://data.worldbank.org/
[4]: http://json-p.org/
[5]: https://github.com/ZachBray/FunScript